/* ================================================================
   DHRUB FOUNDATION — DONOR PORTAL v5.0
   Modern Responsive Design · All Screen Sizes
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=DM+Mono:wght@400;500&display=swap');

:root {
  /* Brand greens */
  --sg-950:#010f08;--sg-900:#021a0e;--sg-800:#052e19;--sg-700:#0a4a2a;
  --sg-600:#0d7a3a;--sg-500:#16a34a;--sg-400:#22c55e;--sg-300:#4ade80;
  --sg-200:#86efac;--sg-100:#dcfce7;--sg-50:#f0fdf4;

  /* Accent palette */
  --amber-700:#92400e;--amber-600:#b45309;--amber-500:#f59e0b;
  --amber-400:#fbbf24;--amber-300:#fcd34d;--amber-200:#fde68a;
  --amber-100:#fef3c7;--amber-50:#fffbeb;

  --blue-800:#1e3a8a;--blue-700:#1d4ed8;--blue-600:#2563eb;--blue-500:#3b82f6;
  --blue-400:#60a5fa;--blue-200:#bfdbfe;--blue-100:#dbeafe;--blue-50:#eff6ff;

  --red-700:#b91c1c;--red-600:#dc2626;--red-500:#ef4444;
  --red-100:#fee2e2;--red-50:#fef2f2;

  --purple-700:#6d28d9;--purple-600:#7c3aed;--purple-500:#8b5cf6;
  --purple-300:#c4b5fd;--purple-100:#ede9fe;--purple-50:#f5f3ff;

  --teal-600:#0d9488;--teal-500:#14b8a6;--teal-100:#ccfbf1;--teal-50:#f0fdfa;

  --gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;
  --gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;
  --gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;

  /* Semantic theme */
  --color-primary:#16a34a;--color-primary-d:#0d7a3a;--color-primary-l:#22c55e;
  --color-bg:#f8fafc;--color-bg-alt:#f1f5f9;
  --color-surface:#ffffff;--color-surface-raised:#fafafa;
  --color-border:#e2e8f0;--color-border-subtle:#f1f5f9;
  --color-text:#0f172a;--color-text-muted:#64748b;
  --color-text-subtle:#94a3b8;--color-text-placeholder:#cbd5e1;

  /* Sidebar */
  --sb-w:250px;--sb-col-w:68px;
  --topbar-h:64px;

  /* Typography */
  --font:'Inter',system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
  --font-display:'Plus Jakarta Sans',system-ui,sans-serif;
  --font-mono:'DM Mono','Fira Code',monospace;

  /* Shadows */
  --shadow-xs:0 1px 2px rgba(0,0,0,.04);
  --shadow-sm:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);
  --shadow-md:0 4px 6px rgba(0,0,0,.07),0 2px 4px rgba(0,0,0,.04);
  --shadow-lg:0 10px 15px rgba(0,0,0,.1),0 4px 6px rgba(0,0,0,.04);
  --shadow-xl:0 20px 25px rgba(0,0,0,.1),0 10px 10px rgba(0,0,0,.04);
  --shadow-colored-green:0 4px 14px rgba(22,163,74,.25);
  --shadow-colored-blue:0 4px 14px rgba(59,130,246,.25);
  --shadow-colored-amber:0 4px 14px rgba(245,158,11,.25);
  --shadow-colored-purple:0 4px 14px rgba(139,92,246,.25);

  /* Motion */
  --t:.18s cubic-bezier(.4,0,.2,1);
  --t-slow:.3s cubic-bezier(.4,0,.2,1);
  --t-bounce:.4s cubic-bezier(.34,1.56,.64,1);

  /* Radii */
  --radius-sm:6px;--radius:10px;--radius-lg:14px;--radius-xl:18px;--radius-2xl:24px;
}

/* ── RESET ─────────────────────────────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{font-size:14px;scroll-behavior:smooth;}
body{font-family:var(--font);background:var(--color-bg);color:var(--color-text);
  -webkit-font-smoothing:antialiased;min-height:100vh;overflow-x:hidden;line-height:1.55;}
img{max-width:100%;display:block;}
a{color:var(--color-primary);text-decoration:none;transition:color var(--t);}
a:hover{color:var(--color-primary-d);text-decoration:none;}
button{font-family:var(--font);cursor:pointer;line-height:1;}
ul,ol{list-style:none;}
:focus-visible{outline:2px solid var(--sg-400);outline-offset:2px;border-radius:4px;}
::-webkit-scrollbar{width:6px;height:6px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:99px;}
::-webkit-scrollbar-thumb:hover{background:var(--gray-400);}

/* ── APP LAYOUT ──────────────────────────────────────────────────── */
.app-layout{display:flex;min-height:100vh;}

/* ══ SIDEBAR ══════════════════════════════════════════════════════ */
.sidebar{
  width:var(--sb-w);
  background:linear-gradient(180deg,#0f172a 0%,#1a2e1a 100%);
  position:fixed;top:0;left:0;bottom:0;z-index:500;
  display:flex;flex-direction:column;overflow:hidden;
  transition:width var(--t-slow),transform var(--t-slow);
  border-right:1px solid rgba(255,255,255,.06);
}
.sidebar.collapsed{width:var(--sb-col-w);}

.sidebar::before{
  content:'';position:absolute;top:0;left:0;right:0;height:200px;pointer-events:none;
  background:linear-gradient(180deg,rgba(22,163,74,.1) 0%,transparent 100%);
}

.sb-brand{
  display:flex;align-items:center;gap:12px;
  padding:0 16px;height:64px;flex-shrink:0;overflow:hidden;
  border-bottom:1px solid rgba(255,255,255,.08);position:relative;
}
.sb-logo{width:36px;height:36px;border-radius:10px;object-fit:contain;flex-shrink:0;
  background:rgba(255,255,255,.08);padding:4px;border:1px solid rgba(255,255,255,.1);}
.sb-logo-fallback{width:36px;height:36px;border-radius:10px;flex-shrink:0;
  background:linear-gradient(135deg,var(--sg-600),var(--sg-400));display:none;
  align-items:center;justify-content:center;font-family:var(--font-display);
  font-size:15px;color:#fff;font-weight:700;}
.sb-org-wrap{flex:1;min-width:0;overflow:hidden;}
.sb-org{font-size:14px;font-weight:700;color:#fff;white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis;}
.sb-portal-tag{display:flex;align-items:center;gap:5px;font-size:10px;font-weight:600;
  color:var(--sg-400);margin-top:2px;text-transform:uppercase;letter-spacing:.04em;}
.sb-portal-tag::before{content:'';width:6px;height:6px;background:var(--sg-400);
  border-radius:50%;animation:pulse 2.5s infinite;flex-shrink:0;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}

.sb-toggle{width:28px;height:28px;border-radius:7px;flex-shrink:0;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  color:rgba(255,255,255,.4);font-size:11px;display:flex;align-items:center;
  justify-content:center;cursor:pointer;transition:all var(--t);}
.sb-toggle:hover{background:rgba(255,255,255,.12);color:rgba(255,255,255,.85);}

.sb-nav{flex:1;padding:14px 12px;overflow-y:auto;scrollbar-width:none;}
.sb-nav::-webkit-scrollbar{display:none;}

.sb-group-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.25);padding:0 10px;margin:18px 0 8px;
  white-space:nowrap;overflow:hidden;}
.sb-group-label:first-child{margin-top:6px;}

.nav-item{margin-bottom:3px;}
.nav-link{
  display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;
  color:rgba(255,255,255,.55);font-size:13px;font-weight:500;
  text-decoration:none;white-space:nowrap;overflow:hidden;
  transition:all var(--t);min-height:42px;
}
.nav-link:hover{background:rgba(255,255,255,.08);color:rgba(255,255,255,.95);}
.nav-link.active{background:rgba(22,163,74,.18);color:#fff;
  border:1px solid rgba(34,197,94,.25);box-shadow:0 2px 8px rgba(22,163,74,.15);}
.nav-link.donate-link{color:rgba(251,191,36,.7);}
.nav-link.donate-link:hover{background:rgba(251,191,36,.12);color:rgba(251,191,36,1);}
.nav-link.logout-link{color:rgba(248,113,113,.6);}
.nav-link.logout-link:hover{background:rgba(248,113,113,.12);color:rgba(248,113,113,.95);}

.nav-icon{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;
  justify-content:center;font-size:13px;flex-shrink:0;
  background:rgba(255,255,255,.06);transition:all var(--t);}
.nav-link.active .nav-icon{background:rgba(34,197,94,.25);color:var(--sg-300);}
.nav-link:hover .nav-icon{background:rgba(255,255,255,.1);}

.sidebar.collapsed .nav-link>span:not(.nav-icon){display:none;}
.sidebar.collapsed .sb-group-label{text-indent:-9999px;}
.sidebar.collapsed .sb-org-wrap,.sidebar.collapsed .sb-portal-tag,.sidebar.collapsed .sb-toggle{display:none;}
.sidebar.collapsed .nav-link{justify-content:center;padding:10px;}
.sidebar.collapsed .nav-icon{width:36px;height:36px;font-size:14px;}
.sidebar.collapsed .sb-footer .sb-donor-info,
.sidebar.collapsed .sb-footer .sb-chevron,
.sidebar.collapsed .sb-footer .sb-online{display:none;}

.sb-footer{padding:12px;border-top:1px solid rgba(255,255,255,.06);flex-shrink:0;}
.sb-donor{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  text-decoration:none;cursor:pointer;transition:all var(--t);}
.sb-donor:hover{background:rgba(255,255,255,.08);}
.sb-avatar{width:36px;height:36px;border-radius:10px;flex-shrink:0;overflow:hidden;
  background:linear-gradient(135deg,var(--sg-600),var(--sg-400));
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;color:white;}
.sb-avatar img{width:100%;height:100%;object-fit:cover;}
.sb-donor-info{flex:1;min-width:0;}
.sb-dname{font-size:13px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sb-did{font-size:10px;color:rgba(255,255,255,.4);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:var(--font-mono);}
.sb-online{width:8px;height:8px;border-radius:50%;background:var(--sg-400);
  box-shadow:0 0 6px var(--sg-400);flex-shrink:0;}
.sb-chevron{font-size:10px;color:rgba(255,255,255,.2);flex-shrink:0;}

.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:499;
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);}
.sidebar-overlay.active{display:block;}

/* ══ MAIN WRAP ═══════════════════════════════════════════════════ */
.main-wrap{
  flex:1;margin-left:var(--sb-w);min-height:100vh;
  transition:margin-left var(--t-slow);
  display:flex;flex-direction:column;
}
.main-wrap.collapsed{margin-left:var(--sb-col-w);}

/* ══ TOPBAR ══════════════════════════════════════════════════════ */
.topbar{
  height:var(--topbar-h);background:var(--color-surface);
  border-bottom:1px solid var(--color-border);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 24px;position:sticky;top:0;z-index:200;
  box-shadow:var(--shadow-sm);gap:14px;
}
.topbar-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0;}
.tb-menu{display:none;width:40px;height:40px;border-radius:10px;
  background:var(--color-bg);border:1px solid var(--color-border);
  color:var(--color-text-muted);font-size:16px;align-items:center;justify-content:center;cursor:pointer;
  transition:all var(--t);}
.tb-menu:hover{background:var(--sg-50);border-color:var(--sg-200);color:var(--color-primary);}
.tb-collapse{display:flex;align-items:center;gap:6px;background:none;border:none;
  color:var(--color-text-subtle);font-size:12px;padding:6px 12px;border-radius:8px;
  transition:all var(--t);}
.tb-collapse:hover{background:var(--color-bg);color:var(--color-text-muted);}
.tb-sep{width:1px;height:20px;background:var(--color-border);margin:0 4px;}
.tb-breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--color-text-subtle);}
.tb-breadcrumb a{color:var(--color-text-subtle);transition:color var(--t);}
.tb-breadcrumb a:hover{color:var(--color-primary);}
.tb-breadcrumb .sep{color:var(--color-border);}
.tb-breadcrumb .current{color:var(--color-text);font-weight:600;}
.tb-right{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.btn-donate-top{display:flex;align-items:center;gap:7px;background:linear-gradient(135deg,var(--sg-500),var(--sg-400));
  color:white;padding:9px 18px;border-radius:10px;font-size:13px;font-weight:600;
  text-decoration:none;transition:all var(--t);border:none;}
.btn-donate-top:hover{background:linear-gradient(135deg,var(--sg-600),var(--sg-500));color:white;
  box-shadow:var(--shadow-colored-green);transform:translateY(-1px);}
.btn-donate-top .d-txt{display:block;}
.tb-btn{width:40px;height:40px;border-radius:10px;background:var(--color-bg);
  border:1px solid var(--color-border);color:var(--color-text-muted);font-size:15px;
  display:flex;align-items:center;justify-content:center;text-decoration:none;
  transition:all var(--t);}
.tb-btn:hover{background:var(--sg-50);border-color:var(--sg-200);color:var(--color-primary);}

/* ══ PAGE CONTENT ════════════════════════════════════════════════ */
.page-content{padding:28px 32px;flex:1;animation:fadeIn .25s ease;}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

.page-header{margin-bottom:24px;}
.page-header-row{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:16px;}
.page-eyebrow{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;
  color:var(--color-primary);margin-bottom:6px;}
.page-title{font-family:var(--font-display);font-size:28px;font-weight:800;color:var(--color-text);line-height:1.2;}
.page-subtitle{font-size:14px;color:var(--color-text-muted);margin-top:6px;line-height:1.6;}

/* ══ CARDS ════════════════════════════════════════════════════════ */
.card{background:var(--color-surface);border:1px solid var(--color-border);
  border-radius:var(--radius-lg);overflow:hidden;margin-bottom:18px;
  box-shadow:var(--shadow-xs);transition:box-shadow var(--t);}
.card:hover{box-shadow:var(--shadow-sm);}
.card-header{display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;border-bottom:1px solid var(--color-border);gap:12px;}
.card-title{font-size:15px;font-weight:600;color:var(--color-text);
  display:flex;align-items:center;gap:10px;}
.card-title i{color:var(--color-primary);font-size:14px;}
.card-body{padding:20px;}
.card-footer{padding:14px 20px;border-top:1px solid var(--color-border);
  background:var(--color-bg);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;}
.view-all{font-size:12px;font-weight:600;color:var(--color-primary);
  display:inline-flex;align-items:center;gap:6px;}
.view-all:hover{color:var(--color-primary-d);}

/* ══ HERO BANNER ═════════════════════════════════════════════════ */
.hero-banner{
  background:linear-gradient(135deg,#0f172a 0%,#1e293b 50%,var(--sg-900) 100%);
  border-radius:var(--radius-xl);padding:28px 32px;margin-bottom:24px;color:white;
  display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;
  position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.08);
}
.hero-banner::before{
  content:'';position:absolute;top:-60%;right:-15%;width:450px;height:450px;
  background:radial-gradient(circle,rgba(22,163,74,.18) 0%,transparent 60%);
  pointer-events:none;
}
.hero-banner::after{
  content:'';position:absolute;bottom:-50%;left:5%;width:300px;height:300px;
  background:radial-gradient(circle,rgba(59,130,246,.1) 0%,transparent 60%);
  pointer-events:none;
}
.hero-left,.hero-right{position:relative;z-index:1;}
.hero-greeting{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.14em;
  color:rgba(255,255,255,.45);margin-bottom:8px;}
.hero-name{font-family:var(--font-display);font-size:26px;font-weight:800;color:white;line-height:1.2;
  margin-bottom:14px;}
.hero-name em{color:var(--sg-300);font-style:normal;font-weight:600;font-size:16px;}
.hero-badges{display:flex;gap:8px;flex-wrap:wrap;align-items:center;}
.hero-badge{display:inline-flex;align-items:center;gap:6px;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);
  color:rgba(255,255,255,.85);padding:6px 12px;border-radius:8px;
  font-size:11px;font-weight:600;}
.hero-badge.gold{background:rgba(251,191,36,.15);border-color:rgba(251,191,36,.35);color:#fde68a;}
.hero-right{display:flex;gap:1px;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:6px;}
.hero-stat{padding:14px 24px;text-align:center;position:relative;}
.hero-stat+.hero-stat::before{content:'';position:absolute;left:0;top:25%;bottom:25%;
  width:1px;background:rgba(255,255,255,.12);}
.hero-stat-val{font-family:var(--font-display);font-size:24px;font-weight:800;color:white;line-height:1;}
.hero-stat-lbl{font-size:10px;color:rgba(255,255,255,.45);margin-top:5px;font-weight:600;
  text-transform:uppercase;letter-spacing:.08em;}

/* ══ TIER CARD ═══════════════════════════════════════════════════ */
.tier-card{background:var(--color-surface);border:1px solid var(--color-border);
  border-radius:var(--radius-lg);padding:14px 20px;margin-bottom:18px;}
.tier-inner{display:flex;align-items:center;gap:14px;}
.tier-info{flex:1;min-width:0;}

/* ══ TIER BADGES ══════════════════════════════════════════════════ */
.tier-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;
  border-radius:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;}
.tier-badge.tier-bronze,.tier-bronze{background:#b08d5718;color:#b08d57;border:1px solid #b08d5735;}
.tier-badge.tier-silver,.tier-silver{background:#a8b6c218;color:#6b7a84;border:1px solid #a8b6c235;}
.tier-badge.tier-gold,.tier-gold{background:#d4af3720;color:#9a6c00;border:1px solid #d4af3745;}
.tier-badge.tier-platinum,.tier-platinum{background:#667c8c18;color:#4a6270;border:1px solid #667c8c35;}

/* ══ STAT CARDS — ERP STYLE ══════════════════════════════════════ */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:24px;}

.stat-card{
  border-radius:var(--radius-lg);padding:22px;
  transition:all var(--t);position:relative;overflow:hidden;
}
.stat-card::after{
  content:'';position:absolute;right:-25px;top:-25px;
  width:110px;height:110px;border-radius:50%;
  background:rgba(255,255,255,.08);pointer-events:none;
}
.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.stat-card.green{background:linear-gradient(135deg,#16a34a,#22c55e);color:white;box-shadow:var(--shadow-colored-green);}
.stat-card.blue{background:linear-gradient(135deg,#2563eb,#3b82f6);color:white;box-shadow:var(--shadow-colored-blue);}
.stat-card.amber{background:linear-gradient(135deg,#d97706,#f59e0b);color:white;box-shadow:var(--shadow-colored-amber);}
.stat-card.purple{background:linear-gradient(135deg,#7c3aed,#8b5cf6);color:white;box-shadow:var(--shadow-colored-purple);}

.stat-head,.stat-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;}
.stat-label{font-size:12px;font-weight:600;color:rgba(255,255,255,.85);letter-spacing:.02em;}
.stat-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;
  justify-content:center;font-size:17px;background:rgba(255,255,255,.2);color:white;}
.stat-value{font-family:var(--font-display);font-size:30px;font-weight:800;
  color:white;line-height:1;margin-bottom:8px;}
.stat-footer{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:rgba(255,255,255,.7);}
.trend{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;
  padding:3px 8px;border-radius:99px;}
.trend-up{background:rgba(255,255,255,.2);color:white;}
.trend-down{background:rgba(255,255,255,.15);color:rgba(255,255,255,.9);}
.trend-flat{background:rgba(255,255,255,.15);color:rgba(255,255,255,.85);}

/* ══ PROGRESS ════════════════════════════════════════════════════ */
.progress-bar{height:7px;background:rgba(0,0,0,.06);border-radius:99px;overflow:hidden;}
.stat-card .progress-bar{background:rgba(255,255,255,.2);}
.progress-fill{height:100%;background:rgba(255,255,255,.7);
  border-radius:99px;transition:width .6s cubic-bezier(.34,1.56,.64,1);}
.card .progress-bar{background:var(--color-border);}
.card .progress-fill{background:linear-gradient(90deg,var(--sg-400),var(--sg-500));}

/* ══ GRIDS ════════════════════════════════════════════════════════ */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}

/* ══ DONATION ITEMS ══════════════════════════════════════════════ */
.donation-item{display:flex;align-items:center;gap:14px;padding:14px 20px;
  border-bottom:1px solid var(--color-border);transition:background var(--t);}
.donation-item:last-child{border-bottom:none;}
.donation-item:hover{background:var(--color-bg);}
.d-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
.d-dot.completed{background:var(--sg-500);box-shadow:0 0 6px rgba(22,163,74,.5);}
.d-dot.pending{background:var(--amber-400);box-shadow:0 0 6px rgba(251,191,36,.4);}
.d-dot.failed{background:var(--red-500);box-shadow:0 0 6px rgba(239,68,68,.4);}
.d-info{flex:1;min-width:0;}
.d-prog{font-size:14px;font-weight:600;color:var(--color-text);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.d-meta{display:flex;gap:8px;align-items:center;margin-top:4px;flex-wrap:wrap;}
.d-meta span,.d-meta code{font-size:12px;color:var(--color-text-muted);}
.d-amount{font-family:var(--font-display);font-size:15px;font-weight:700;
  color:var(--color-text);flex-shrink:0;}

/* ══ BAR CHART ════════════════════════════════════════════════════ */
.bar-chart{display:flex;align-items:flex-end;gap:8px;height:90px;padding:0 6px;}
.bar-col{display:flex;flex-direction:column;align-items:center;flex:1;gap:5px;}
.bar{width:100%;min-height:4px;background:linear-gradient(180deg,var(--sg-400),var(--sg-500));
  border-radius:5px 5px 0 0;position:relative;transition:all var(--t-slow);cursor:pointer;
  opacity:.7;}
.bar:hover,.bar.active{opacity:1;box-shadow:0 4px 10px rgba(22,163,74,.35);}
.bar-tip{position:absolute;top:-30px;left:50%;transform:translateX(-50%);
  background:var(--gray-800);color:white;font-size:10px;padding:4px 8px;border-radius:6px;
  white-space:nowrap;opacity:0;pointer-events:none;transition:opacity var(--t);}
.bar:hover .bar-tip{opacity:1;}
.bar-lbl{font-size:10px;color:var(--color-text-subtle);font-weight:500;}
.bar-lbl.active{color:var(--color-primary);font-weight:700;}

/* ══ CAMPAIGN CARDS ══════════════════════════════════════════════ */
.campaign-card{background:var(--color-surface);border:1px solid var(--color-border);
  border-radius:var(--radius-lg);padding:18px;transition:all var(--t);}
.campaign-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);}
.campaign-card.supported{border-color:var(--sg-200);
  background:linear-gradient(160deg,var(--sg-50) 0%,white 60%);}
.c-name{font-size:15px;font-weight:700;color:var(--color-text);margin-bottom:5px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.c-desc{font-size:12px;color:var(--color-text-muted);line-height:1.6;margin-bottom:12px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.c-contrib{background:var(--sg-50);border:1px solid var(--sg-100);border-radius:8px;
  padding:8px 12px;margin-bottom:12px;display:flex;justify-content:space-between;
  font-size:12px;color:var(--sg-700);}
.ca{font-weight:700;color:var(--color-primary);}
.cl{color:var(--sg-600);}
.c-actions{display:flex;gap:8px;margin-top:12px;}

/* ══ QUICK ACTIONS ════════════════════════════════════════════════ */
.quick-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:18px;}
.quick-action{display:flex;flex-direction:column;align-items:center;gap:8px;
  padding:16px 10px;border-radius:12px;background:var(--color-bg);
  border:1px solid var(--color-border);text-decoration:none;color:var(--color-text-muted);
  font-size:11px;font-weight:600;transition:all var(--t-bounce);}
.quick-action:hover{background:var(--sg-50);border-color:var(--sg-200);
  color:var(--color-primary);transform:translateY(-3px);}
.quick-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;
  justify-content:center;font-size:16px;background:var(--color-surface);
  border:1px solid var(--color-border);color:var(--color-text-muted);transition:all var(--t);}
.quick-action:hover .quick-icon{background:var(--sg-50);border-color:var(--sg-200);color:var(--sg-500);}

/* ══ INFO ROWS ════════════════════════════════════════════════════ */
.info-row{display:flex;align-items:center;gap:12px;padding:12px 20px;
  border-bottom:1px solid var(--color-border);}
.info-row:last-child{border-bottom:none;}
.info-row-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;
  justify-content:center;font-size:13px;background:var(--sg-50);color:var(--sg-500);flex-shrink:0;}
.info-row-label{flex:1;font-size:13px;color:var(--color-text-muted);}
.info-row-value{font-size:13px;font-weight:600;color:var(--color-text);}

/* ══ SUMMARY BAR ══════════════════════════════════════════════════ */
.summary-bar{background:var(--color-surface);border:1px solid var(--color-border);
  border-radius:var(--radius);padding:12px 18px;display:flex;align-items:center;
  gap:18px;flex-wrap:wrap;font-size:13px;color:var(--color-text-muted);}
.summary-bar span{display:flex;align-items:center;gap:6px;}
.summary-bar strong{color:var(--color-text);}

/* ══ BADGES ══════════════════════════════════════════════════════ */
.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:6px;
  font-size:11px;font-weight:600;}
.badge-primary{background:var(--sg-50);color:var(--sg-700);}
.badge-ok,.badge-completed{background:var(--sg-50);color:var(--sg-700);border:1px solid var(--sg-100);}
.badge-warn,.badge-pending{background:var(--amber-50);color:var(--amber-700);border:1px solid var(--amber-100);}
.badge-fail,.badge-failed{background:var(--red-50);color:var(--red-700);border:1px solid var(--red-100);}
.badge-neutral{background:var(--gray-100);color:var(--gray-600);}
.badge-method{background:var(--blue-50);color:var(--blue-700);border:1px solid var(--blue-100);}
.badge-refunded{background:var(--purple-50);color:var(--purple-700);border:1px solid var(--purple-100);}

/* ══ ALERTS ══════════════════════════════════════════════════════ */
.alert{display:flex;align-items:flex-start;gap:12px;padding:14px 18px;border-radius:var(--radius);
  margin-bottom:16px;font-size:13px;line-height:1.6;}
.alert i{margin-top:2px;flex-shrink:0;font-size:15px;}
.alert-error{background:var(--red-50);border:1px solid #fca5a5;color:var(--red-700);}
.alert-success{background:var(--sg-50);border:1px solid var(--sg-200);color:#15803d;}
.alert-info{background:var(--blue-50);border:1px solid var(--blue-200);color:var(--blue-700);}
.alert-warn{background:var(--amber-50);border:1px solid var(--amber-200);color:var(--amber-700);}

/* ══ BUTTONS ══════════════════════════════════════════════════════ */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:10px;
  font-family:var(--font);font-size:13px;font-weight:600;text-decoration:none;
  cursor:pointer;transition:all var(--t);border:none;white-space:nowrap;}
.btn-primary{background:linear-gradient(135deg,var(--sg-500),var(--sg-400));color:white;box-shadow:var(--shadow-xs);}
.btn-primary:hover{background:linear-gradient(135deg,var(--sg-600),var(--sg-500));color:white;
  box-shadow:var(--shadow-colored-green);transform:translateY(-2px);}
.btn-outline{background:transparent;color:var(--color-text-muted);
  border:2px solid var(--color-border);}
.btn-outline:hover{background:var(--color-bg);border-color:var(--sg-300);color:var(--color-primary);}
.btn-ghost{background:transparent;color:var(--color-primary);border:none;padding:8px 14px;}
.btn-ghost:hover{background:var(--sg-50);}
.btn-sm{padding:8px 16px;font-size:12px;}
.btn-xs{padding:5px 12px;font-size:11px;}
.btn-full,.w-full{width:100%;justify-content:center;}
.btn-danger{background:var(--red-500);color:white;}
.btn-danger:hover{background:var(--red-600);}
.btn-export-csv{background:var(--sg-50);color:var(--sg-700);border:2px solid var(--sg-200);}
.btn-export-csv:hover{background:var(--sg-100);}
.btn-export-pdf{background:var(--red-50);color:var(--red-700);border:2px solid var(--red-100);}
.btn-export-pdf:hover{background:var(--red-100);}

/* ══ FORMS ════════════════════════════════════════════════════════ */
.form-group{margin-bottom:18px;}
.form-label{display:block;font-size:12px;font-weight:600;color:var(--color-text);margin-bottom:7px;}
.form-label small{color:var(--color-text-muted);font-weight:500;}
.input-group{position:relative;display:flex;align-items:center;}
.input-icon{position:absolute;left:13px;color:var(--color-text-placeholder);font-size:14px;pointer-events:none;z-index:1;}
.form-input{width:100%;padding:12px 14px 12px 40px;border:2px solid var(--color-border);
  border-radius:10px;font-family:var(--font);font-size:14px;color:var(--color-text);
  background:var(--color-surface);transition:all var(--t);}
.form-input:focus{outline:none;border-color:var(--sg-400);
  box-shadow:0 0 0 4px rgba(22,163,74,.1);}
.form-input::placeholder{color:var(--color-text-placeholder);}
textarea.form-input{padding-left:14px;min-height:80px;resize:vertical;}
.form-select{width:100%;padding:11px 14px;border:2px solid var(--color-border);
  border-radius:10px;font-family:var(--font);font-size:14px;color:var(--color-text);
  background:var(--color-surface);cursor:pointer;transition:all var(--t);}
.form-select:focus{outline:none;border-color:var(--sg-400);box-shadow:0 0 0 4px rgba(22,163,74,.1);}
.form-hint{display:block;font-size:11px;color:var(--color-text-muted);margin-top:5px;}
.input-sfx,.input-suffix-btn{position:absolute;right:12px;background:none;border:none;
  color:var(--color-text-subtle);cursor:pointer;padding:5px;font-size:14px;transition:color var(--t);}
.input-sfx:hover{color:var(--color-text-muted);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}

/* ══ TABLE ════════════════════════════════════════════════════════ */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
.portal-table{width:100%;border-collapse:collapse;font-size:13px;}
.portal-table th{background:var(--color-bg);padding:12px 16px;text-align:left;
  font-size:11px;text-transform:uppercase;letter-spacing:.07em;
  color:var(--color-text-subtle);border-bottom:2px solid var(--color-border);
  font-weight:700;white-space:nowrap;}
.portal-table td{padding:14px 16px;border-bottom:1px solid var(--color-border);vertical-align:middle;}
.portal-table tr:last-child td{border-bottom:none;}
.portal-table tbody tr{transition:background var(--t);}
.portal-table tbody tr:hover td{background:var(--color-bg);}
.portal-table code{font-family:var(--font-mono);font-size:11px;
  background:var(--gray-100);padding:3px 7px;border-radius:5px;color:var(--gray-700);}

/* ══ CODE ELEMENTS ════════════════════════════════════════════════ */
code{font-family:var(--font-mono);font-size:11px;background:var(--gray-100);
  border:1px solid var(--gray-200);padding:3px 7px;border-radius:5px;color:var(--gray-700);}

/* ══ SEARCH BOX ══════════════════════════════════════════════════ */
.search-box{position:relative;display:flex;align-items:center;}
.search-box i{position:absolute;left:12px;color:var(--color-text-placeholder);font-size:14px;}
.search-box input{width:100%;padding:11px 14px 11px 36px;border:2px solid var(--color-border);
  border-radius:10px;font-family:var(--font);font-size:14px;background:var(--color-surface);}
.search-box input:focus{outline:none;border-color:var(--sg-400);box-shadow:0 0 0 4px rgba(22,163,74,.1);}

/* ══ EMPTY STATE ═════════════════════════════════════════════════ */
.empty-state{padding:60px 28px;text-align:center;}
.empty-icon{width:72px;height:72px;border-radius:18px;background:var(--sg-50);
  border:2px solid var(--sg-100);display:flex;align-items:center;justify-content:center;
  font-size:28px;color:var(--sg-300);margin:0 auto 20px;}
.empty-state h3{font-size:18px;font-weight:700;color:var(--color-text);margin-bottom:8px;}
.empty-state p{font-size:14px;line-height:1.6;color:var(--color-text-muted);margin-bottom:22px;}

/* ══ FILTER BAR ══════════════════════════════════════════════════ */
.filter-bar{background:var(--color-surface);border:1px solid var(--color-border);
  border-radius:var(--radius-lg);margin-bottom:18px;overflow:hidden;}
.filter-head{display:flex;align-items:center;justify-content:space-between;
  padding:14px 20px;cursor:pointer;font-size:14px;font-weight:600;
  color:var(--color-text);user-select:none;}
.filter-head:hover{background:var(--color-bg);}
.filter-toggle-icon{color:var(--color-text-subtle);transition:transform var(--t);}
.filter-body{padding:18px 20px;border-top:1px solid var(--color-border);
  display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:14px;}

/* ══ INV-NO ══════════════════════════════════════════════════════ */
.inv-no{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--color-primary);}
.muted{color:var(--color-text-muted);}

/* ══ PROFILE ═════════════════════════════════════════════════════ */
.profile-card{background:var(--color-surface);border:1px solid var(--color-border);
  border-radius:var(--radius-xl);overflow:hidden;margin-bottom:18px;}
.profile-cover{background:linear-gradient(135deg,#0f172a,var(--sg-900));
  padding:28px;display:flex;align-items:flex-end;gap:18px;flex-wrap:wrap;min-height:120px;}
.profile-av{width:80px;height:80px;border-radius:16px;background:linear-gradient(135deg,var(--sg-500),var(--sg-400));
  display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;
  color:white;border:4px solid rgba(255,255,255,.15);overflow:hidden;flex-shrink:0;}
.profile-av img{width:100%;height:100%;object-fit:cover;}
.av-upload{position:relative;cursor:pointer;display:block;}
.av-overlay{position:absolute;inset:0;border-radius:16px;background:rgba(0,0,0,.55);
  display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--t);
  color:white;font-size:20px;}
.av-upload:hover .av-overlay{opacity:1;}
.av-upload input[type=file]{display:none;}
.profile-name{font-family:var(--font-display);font-size:22px;font-weight:800;color:white;line-height:1.2;}
.profile-sub{font-size:13px;color:rgba(255,255,255,.55);margin-top:3px;}
.profile-stats{display:flex;border-top:1px solid var(--color-border);}
.ps-item{flex:1;padding:18px;text-align:center;border-right:1px solid var(--color-border);}
.ps-item:last-child{border-right:none;}
.ps-val{font-family:var(--font-display);font-size:24px;font-weight:800;color:var(--color-text);}
.ps-lbl{font-size:10px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;margin-top:3px;font-weight:600;}

.donor-id-card{display:flex;align-items:center;gap:14px;background:var(--sg-50);
  border:2px solid var(--sg-200);border-radius:var(--radius-lg);padding:16px 20px;margin-bottom:18px;}
.donor-id-card i{font-size:24px;color:var(--sg-500);}
.id-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--sg-600);margin-bottom:2px;}
.id-value{font-family:var(--font-mono);font-size:18px;font-weight:700;color:var(--color-text);}
.id-hint{font-size:11px;color:var(--color-text-muted);margin-top:3px;}

.tabs-nav{display:flex;gap:3px;background:var(--color-bg);border:1px solid var(--color-border);
  border-radius:12px;padding:4px;margin-bottom:18px;overflow-x:auto;}
.tab-link{flex:1;padding:10px 18px;border-radius:9px;border:none;background:none;
  font-family:var(--font);font-size:13px;font-weight:500;color:var(--color-text-muted);
  cursor:pointer;transition:all var(--t);text-decoration:none;text-align:center;white-space:nowrap;
  display:flex;align-items:center;justify-content:center;gap:8px;}
.tab-link.active{background:white;color:var(--color-primary);font-weight:600;
  box-shadow:var(--shadow-sm);}
.tab-link:hover:not(.active){background:rgba(255,255,255,.5);color:var(--color-text);}

.mt-4{margin-top:18px;}

/* ══ LOGIN PAGE ══════════════════════════════════════════════════ */
.login-layout{display:flex;min-height:100vh;}
.login-panel{
  flex:0 0 460px;
  background:linear-gradient(160deg,#0f172a 0%,#1a2e1a 50%,#052e19 100%);
  padding:52px 48px;display:flex;flex-direction:column;gap:28px;
  position:relative;overflow:hidden;
}
.login-panel::before{
  content:'';position:absolute;top:-100px;right:-100px;width:360px;height:360px;
  background:radial-gradient(circle,rgba(22,163,74,.2) 0%,transparent 65%);pointer-events:none;
}
.login-panel::after{
  content:'';position:absolute;bottom:-80px;left:-80px;width:280px;height:280px;
  background:radial-gradient(circle,rgba(16,163,74,.12) 0%,transparent 65%);pointer-events:none;
}
.lp-brand{display:flex;align-items:center;gap:14px;position:relative;z-index:1;}
.lp-logo{width:52px;height:52px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);
  border-radius:14px;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:8px;flex-shrink:0;}
.lp-logo img{width:100%;height:100%;object-fit:contain;}
.lp-brand-name{font-size:16px;font-weight:700;color:white;}
.lp-brand-sub{font-size:10px;color:var(--sg-300);font-weight:600;text-transform:uppercase;letter-spacing:.12em;margin-top:2px;}
.lp-headline{font-family:var(--font-display);font-size:36px;line-height:1.2;color:white;
  font-weight:800;position:relative;z-index:1;}
.lp-headline em{color:var(--sg-300);font-style:italic;font-weight:600;}
.lp-tagline{font-size:14px;color:rgba(255,255,255,.55);line-height:1.8;position:relative;z-index:1;}
.lp-stats{display:flex;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);
  border-radius:14px;overflow:hidden;position:relative;z-index:1;}
.lp-stats>div{flex:1;padding:16px 12px;text-align:center;border-right:1px solid rgba(255,255,255,.1);}
.lp-stats>div:last-child{border-right:none;}
.lp-stat-val{font-family:var(--font-display);font-size:22px;font-weight:800;color:var(--sg-300);}
.lp-stat-lbl{font-size:9px;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.4);margin-top:3px;font-weight:600;}
.lp-testimonial{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  border-radius:14px;padding:20px;position:relative;z-index:1;}
.lp-testimonial blockquote{font-size:14px;color:rgba(255,255,255,.7);line-height:1.8;
  font-style:italic;margin-bottom:10px;}
.lp-testimonial cite{font-size:12px;color:var(--sg-300);font-style:normal;font-weight:600;}

.login-form-side{flex:1;display:flex;align-items:center;justify-content:center;
  padding:52px 44px;background:var(--color-bg);}
.login-box{width:100%;max-width:440px;}
.login-title{font-family:var(--font-display);font-size:32px;font-weight:800;color:var(--color-text);
  margin-bottom:8px;}
.login-sub{font-size:14px;color:var(--color-text-muted);margin-bottom:32px;line-height:1.7;}
.donor-status{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:10px;
  font-size:13px;margin-bottom:16px;}
.donor-status.found{background:var(--sg-50);border:2px solid var(--sg-200);color:#15803d;}
.donor-status.not-found{background:var(--red-50);border:2px solid var(--red-100);color:var(--red-700);}
.sec-badge{display:flex;align-items:center;gap:8px;padding:12px 16px;margin-top:22px;
  background:var(--sg-50);border:2px solid var(--sg-100);border-radius:10px;
  font-size:12px;color:var(--sg-700);}
.sec-badge i{font-size:14px;color:var(--sg-500);}

/* ══ AUTH PAGES ══════════════════════════════════════════════════ */
.auth-bg{min-height:100vh;background:var(--color-bg);display:flex;align-items:center;
  justify-content:center;padding:28px;}
.auth-box{background:var(--color-surface);border:1px solid var(--color-border);
  border-radius:var(--radius-xl);padding:40px;box-shadow:var(--shadow-lg);max-width:500px;margin:0 auto;width:100%;}
.auth-header{text-align:center;margin-bottom:32px;}
.auth-step{display:inline-block;background:var(--sg-50);color:var(--sg-700);
  font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;
  padding:4px 14px;border-radius:99px;margin-bottom:14px;}
.auth-header h1{font-family:var(--font-display);font-size:26px;font-weight:800;
  color:var(--color-text);margin-bottom:10px;}
.auth-header p{font-size:14px;color:var(--color-text-muted);line-height:1.7;}
.auth-footer{text-align:center;font-size:13px;color:var(--color-text-muted);margin-top:24px;}
.auth-footer a{color:var(--color-primary);font-weight:600;}
.check-label{display:flex;align-items:flex-start;gap:10px;font-size:13px;cursor:pointer;
  color:var(--color-text-muted);}
.check-label input[type=checkbox]{accent-color:var(--sg-500);margin-top:3px;flex-shrink:0;width:16px;height:16px;}

/* ══ RESPONSIVE — TABLET ══════════════════════════════════════════ */
@media(max-width:1200px){
  .stats-grid{grid-template-columns:repeat(2,1fr);}
  .grid-3{grid-template-columns:repeat(2,1fr);}
}

/* ══ RESPONSIVE — MOBILE ══════════════════════════════════════════ */
@media(max-width:960px){
  .sidebar{transform:translateX(-100%);transition:transform var(--t-slow),width var(--t-slow);}
  .sidebar.open{transform:translateX(0);width:280px !important;}
  .main-wrap,.main-wrap.collapsed{margin-left:0;}
  .tb-menu{display:flex;}
  .tb-collapse{display:none;}
  .grid-2{grid-template-columns:1fr;}
  .login-panel{display:none;}
  .login-form-side{padding:36px 24px;}
  .page-content{padding:20px 18px;}
  .hero-banner{flex-direction:column;padding:24px;gap:20px;}
  .hero-right{width:100%;justify-content:center;}
  .hero-stat{padding:12px 18px;}
  .hero-stat-val{font-size:20px;}
  .topbar{padding:0 18px;height:58px;}
  .page-title{font-size:24px;}
  .stat-value{font-size:26px;}
  .card-header,.card-body,.card-footer{padding:16px;}
  .form-row{grid-template-columns:1fr;}
  .profile-cover{padding:22px;}
  .profile-av{width:70px;height:70px;font-size:24px;}
  .profile-name{font-size:20px;}
  .ps-item{padding:14px 10px;}
  .ps-val{font-size:20px;}
  .donation-item{padding:12px 16px;}
  .info-row{padding:10px 16px;}
  .filter-body{grid-template-columns:1fr 1fr;}
}

@media(max-width:640px){
  .stats-grid{grid-template-columns:1fr;gap:14px;}
  .grid-3{grid-template-columns:1fr;}
  .stat-card{padding:18px;}
  .stat-value{font-size:24px;}
  .stat-icon{width:38px;height:38px;font-size:15px;}
  .quick-grid{grid-template-columns:repeat(2,1fr);gap:8px;}
  .quick-action{padding:14px 8px;}
  .btn-donate-top .d-txt{display:none;}
  .btn-donate-top{padding:9px 14px;}
  .hero-banner{padding:20px;}
  .hero-name{font-size:22px;}
  .hero-badges{gap:6px;}
  .hero-badge{padding:5px 10px;font-size:10px;}
  .hero-stat{padding:10px 14px;}
  .hero-stat-val{font-size:18px;}
  .hero-stat-lbl{font-size:9px;}
  .page-title{font-size:22px;}
  .page-subtitle{font-size:13px;}
  .portal-table{font-size:12px;}
  .portal-table th,.portal-table td{padding:10px 12px;}
  .login-box{padding:0 4px;}
  .login-title{font-size:26px;}
  .auth-box{padding:28px 22px;}
  .filter-body{grid-template-columns:1fr;}
  .tb-breadcrumb .current{max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .tabs-nav{gap:3px;padding:3px;}
  .tab-link{padding:8px 12px;font-size:12px;}
  .profile-stats{flex-wrap:wrap;}
  .ps-item{flex:0 0 50%;border-right:1px solid var(--color-border);border-bottom:1px solid var(--color-border);}
  .ps-item:nth-child(2n){border-right:none;}
  .ps-item:nth-last-child(-n+2){border-bottom:none;}
  .donor-id-card{flex-direction:column;text-align:center;gap:10px;}
  .c-actions{flex-direction:column;}
  .c-actions .btn{width:100%;justify-content:center;}
}

@media(max-width:400px){
  .page-content{padding:16px 14px;}
  .topbar{padding:0 14px;}
  .hero-banner{padding:16px;}
  .hero-name{font-size:20px;}
  .hero-right{flex-wrap:wrap;gap:6px;}
  .hero-stat{flex:0 0 calc(50% - 3px);padding:10px;border-radius:8px;background:rgba(255,255,255,.04);}
  .hero-stat+.hero-stat::before{display:none;}
  .stat-card{padding:16px;}
  .stat-value{font-size:22px;}
  .card-header,.card-body,.card-footer{padding:14px;}
  .quick-grid{gap:6px;}
  .quick-action{padding:12px 6px;}
  .quick-icon{width:36px;height:36px;font-size:14px;}
  .btn{padding:9px 16px;font-size:12px;}
  .btn-sm{padding:7px 14px;font-size:11px;}
}

/* ══ PRINT ════════════════════════════════════════════════════════ */
@media print{
  .no-print{display:none!important;}
  body{background:white;font-size:12px;}
  .sidebar,.topbar{display:none!important;}
  .main-wrap{margin-left:0!important;}
  .page-content{padding:20px!important;}
  .card{box-shadow:none!important;border:1px solid #ddd!important;}
}
