/* ═══════════════════════════════════════════════════
   BloodBridge v5 — assets/css/style.css
   Production stylesheet — white medical theme
   Font: Instrument Serif + DM Sans + JetBrains Mono
═══════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600;9..40,700;9..40,800&family=JetBrains+Mono:wght@400;600&display=swap');

/* ─── Custom Properties ──────────────────────────── */
:root {
  --red:      #d42b3a;
  --red-d:    #a51e2b;
  --red-l:    #ffeced;
  --red-m:    rgba(212,43,58,.12);
  --red-b:    rgba(212,43,58,.2);
  --amber:    #f59e0b;
  --amber-l:  #fffbeb;
  --green:    #10b981;
  --green-l:  #ecfdf5;
  --blue:     #3b82f6;
  --blue-l:   #eff6ff;
  --purple:   #8b5cf6;
  --bg:       #f8f7f5;
  --bg2:      #ffffff;
  --bg3:      #f1f0ee;
  --bg4:      #e8e6e3;
  --bg5:      #d4d1cc;
  --bo:       rgba(0,0,0,.07);
  --bo2:      rgba(0,0,0,.13);
  --bo3:      rgba(0,0,0,.2);
  --t:        #1a1814;
  --t2:       #5c5a55;
  --t3:       #9c9890;
  --t4:       #c8c5bf;
  --fs:       'DM Sans', sans-serif;
  --fd:       'Instrument Serif', serif;
  --fm:       'JetBrains Mono', monospace;
  --sw:       260px;
  --hh:       60px;
  --r:        10px;
  --rl:       16px;
  --pill:     999px;
  --safe-b:   env(safe-area-inset-bottom, 0px);
  --safe-t:   env(safe-area-inset-top, 0px);
  --s1: 0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --s2: 0 4px 16px rgba(0,0,0,.08),0 2px 4px rgba(0,0,0,.04);
  --s3: 0 12px 40px rgba(0,0,0,.12),0 4px 8px rgba(0,0,0,.06);
  --sr: 0 8px 24px rgba(212,43,58,.25);
}

/* ─── Reset ─────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{font-family:var(--fs);background:var(--bg);color:var(--t);line-height:1.6;overflow-x:hidden;-webkit-tap-highlight-color:transparent;font-size:15px}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:var(--bg3)}
::-webkit-scrollbar-thumb{background:var(--bg5);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--t3)}
button,input,select,textarea{font-family:var(--fs);-webkit-appearance:none;appearance:none}
button{cursor:pointer;border:none;background:none}
a{text-decoration:none;color:inherit}
img,video{max-width:100%;height:auto}
input[type=range]{-webkit-appearance:none;appearance:none}

/* Screen reader only */
.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}

/* ─── Auth Screen ────────────────────────────────── */
.auth-page{min-height:100vh}
#authW{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#fff5f5 0%,#fff 40%,#f0f4ff 100%);position:relative;overflow:hidden;padding:20px}
.auth-orb{position:absolute;border-radius:50%;pointer-events:none;filter:blur(60px);opacity:.6}
.auth-orb-1{width:400px;height:400px;background:radial-gradient(circle,rgba(212,43,58,.15),transparent);top:-100px;right:-80px}
.auth-orb-2{width:300px;height:300px;background:radial-gradient(circle,rgba(59,130,246,.1),transparent);bottom:-80px;left:-60px}
.auth-card{background:var(--bg2);border:1px solid var(--bo);border-radius:24px;padding:32px 28px;width:100%;max-width:400px;box-shadow:var(--s3);position:relative;z-index:1}
.auth-logo{display:flex;align-items:center;gap:10px;margin-bottom:28px}
.auth-logo-icon{width:40px;height:40px;background:var(--red);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:0 4px 12px rgba(212,43,58,.3)}
.auth-logo-text{font-family:var(--fd);font-size:22px;color:var(--t)}
.auth-logo-text span{color:var(--red)}
.auth-step{display:none}.auth-step.active{display:block}
.auth-title{font-size:20px;font-weight:700;margin-bottom:5px}
.auth-sub{font-size:13px;color:var(--t2);margin-bottom:22px;line-height:1.6}
.alert-banner{padding:10px 14px;border-radius:var(--r);font-size:13px;margin-bottom:16px}
.alert-banner.error{background:var(--red-l);color:var(--red);border:1px solid var(--red-b)}

/* ─── Form Elements ──────────────────────────────── */
.form-group{margin-bottom:14px}
.form-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--t3);margin-bottom:6px;display:block}
.form-input{width:100%;background:var(--bg3);border:1.5px solid var(--bo);border-radius:var(--r);color:var(--t);font-size:14px;padding:11px 14px;outline:none;transition:border-color .2s,box-shadow .2s}
.form-input:focus{border-color:var(--red-b);box-shadow:0 0 0 3px var(--red-m);background:var(--bg2)}
.form-input::placeholder{color:var(--t4)}
textarea.form-input{resize:vertical;min-height:80px}
.form-select{width:100%;background:var(--bg3);border:1.5px solid var(--bo);border-radius:var(--r);color:var(--t);font-size:14px;padding:11px 14px;outline:none;cursor:pointer;transition:border-color .2s;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%239c9890' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}
.form-select:focus{border-color:var(--red-b);box-shadow:0 0 0 3px var(--red-m)}

/* ─── Buttons ────────────────────────────────────── */
.btn-red{width:100%;background:var(--red);color:#fff;font-size:14px;font-weight:700;padding:13px;border-radius:var(--pill);transition:all .2s;border:none;box-shadow:0 4px 12px rgba(212,43,58,.25);letter-spacing:.01em;display:block;text-align:center}
.btn-red:hover{background:var(--red-d);transform:translateY(-1px);box-shadow:var(--sr)}
.btn-red:active{transform:translateY(0)}
.btn-red:disabled{opacity:.4;pointer-events:none}
.btn-outline{width:100%;background:transparent;color:var(--t2);font-size:13px;font-weight:600;padding:11px;border-radius:var(--pill);border:1.5px solid var(--bo2);transition:all .2s;display:block;text-align:center}
.btn-outline:hover{border-color:var(--bo3);color:var(--t);background:var(--bg3)}
.btn-sm{padding:7px 14px;border-radius:var(--pill);font-size:12px;font-weight:700;cursor:pointer;transition:all .2s;border:none;white-space:nowrap;touch-action:manipulation;display:inline-flex;align-items:center;gap:4px}
.btn-sm.red{background:var(--red);color:#fff}.btn-sm.red:hover{background:var(--red-d)}
.btn-sm.ghost{background:var(--bg3);color:var(--t2);border:1px solid var(--bo2)}.btn-sm.ghost:hover{background:var(--bg4);color:var(--t)}
.btn-sm.green{background:var(--green-l);color:var(--green);border:1px solid rgba(16,185,129,.25)}
.btn-sm.amber{background:var(--amber-l);color:var(--amber);border:1px solid rgba(245,158,11,.3)}
.btn-sm.blue{background:var(--blue-l);color:var(--blue);border:1px solid rgba(59,130,246,.3)}

/* Google button */
.btn-google{width:100%;background:var(--bg2);border:1.5px solid var(--bo2);border-radius:var(--pill);padding:12px;font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:10px;cursor:pointer;transition:all .2s;box-shadow:var(--s1);margin-bottom:16px}
.btn-google:hover{background:var(--bg3);border-color:var(--bo3);box-shadow:var(--s2)}
.btn-google svg{width:18px;height:18px;flex-shrink:0}
.auth-divider{display:flex;align-items:center;gap:12px;margin:16px 0;font-size:12px;color:var(--t3);font-weight:600}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--bo2)}

/* OTP */
.otp-wrap{display:flex;gap:8px;margin-bottom:18px}
.otp-input{flex:1;text-align:center;font-size:20px;font-weight:800;background:var(--bg3);border:1.5px solid var(--bo);border-radius:var(--r);color:var(--t);padding:13px 0;outline:none;transition:border-color .2s;min-width:0;font-family:var(--fm)}
.otp-input:focus{border-color:var(--red);box-shadow:0 0 0 3px var(--red-m);background:var(--bg2)}

/* Blood group grid */
.bg-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:7px;margin-bottom:14px}
.bg-btn{padding:10px 4px;text-align:center;border-radius:var(--r);border:1.5px solid var(--bo);background:var(--bg3);font-family:var(--fm);font-size:12px;font-weight:700;color:var(--t2);cursor:pointer;transition:all .2s}
.bg-btn:hover{border-color:var(--bo3);color:var(--t)}
.bg-btn.sel{border-color:var(--red);background:var(--red-l);color:var(--red)}

/* Toggle */
.toggle{position:relative;width:42px;height:24px;flex-shrink:0}
.toggle input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;inset:0;border-radius:24px;background:var(--bg4);cursor:pointer;transition:.3s;border:1px solid var(--bo2)}
.toggle-slider::before{content:'';position:absolute;left:3px;top:3px;width:16px;height:16px;border-radius:50%;background:var(--t3);transition:.3s}
.toggle input:checked+.toggle-slider{background:var(--green);border-color:var(--green)}
.toggle input:checked+.toggle-slider::before{transform:translateX(18px);background:#fff}

/* Role picker */
.role-picker{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}
.role-btn{padding:12px 6px;text-align:center;border-radius:var(--rl);border:1.5px solid var(--bo);background:var(--bg3);cursor:pointer;transition:all .2s}
.role-btn.sel{border-color:var(--red);background:var(--red-l)}
.role-btn .role-icon{font-size:20px;margin-bottom:4px}
.role-btn .role-label{font-size:11px;font-weight:700;color:var(--t2)}
.role-btn.sel .role-label{color:var(--red)}

/* ─── App Shell ──────────────────────────────────── */
.app-page #authW{display:none}
#appW{display:none;min-height:100vh}
#appW.active{display:flex}

/* Sidebar */
#sb{width:var(--sw);flex-shrink:0;background:var(--bg2);border-right:1px solid var(--bo);display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:100;transition:transform .3s cubic-bezier(.4,0,.2,1);overflow-y:auto;overflow-x:hidden}
.sb-header{padding:16px 14px 12px;border-bottom:1px solid var(--bo)}
.sb-logo{display:flex;align-items:center;gap:9px;text-decoration:none}
.sb-logo-icon{width:32px;height:32px;background:var(--red);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:14px}
.sb-logo-text{font-family:var(--fd);font-size:18px;color:var(--t)}
.sb-logo-text span{color:var(--red)}
.sb-user{margin:10px 10px 6px;padding:10px 11px;background:var(--bg3);border-radius:var(--rl);border:1px solid var(--bo);display:flex;align-items:center;gap:9px}
.sb-avatar{width:36px;height:36px;border-radius:50%;background:var(--red-m);border:2px solid var(--red-b);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:var(--red);flex-shrink:0;overflow:hidden}
.sb-avatar img{width:100%;height:100%;object-fit:cover}
.sb-name{font-size:12px;font-weight:700}
.sb-blood{font-size:9px;font-family:var(--fm);font-weight:700;color:var(--red);background:var(--red-l);padding:2px 6px;border-radius:4px;border:1px solid var(--red-b);margin-top:2px;display:inline-block}
.sb-nav{flex:1;padding:6px 8px;overflow-x:hidden}
.nav-section{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--t4);padding:10px 7px 4px}
.nav-item{display:flex;align-items:center;gap:9px;padding:8px 9px;border-radius:var(--r);color:var(--t2);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;margin-bottom:1px;position:relative;white-space:nowrap;text-decoration:none}
.nav-item:hover{background:var(--bg3);color:var(--t)}
.nav-item.active{background:var(--red-l);color:var(--red);font-weight:700;border:1px solid rgba(212,43,58,.15)}
.nav-icon{font-size:14px;width:16px;text-align:center;flex-shrink:0}
.nav-badge{margin-left:auto;background:var(--red);color:#fff;font-size:9px;font-weight:800;padding:1px 5px;border-radius:var(--pill);min-width:16px;text-align:center;flex-shrink:0}
.nav-item.gold{color:var(--amber)}.nav-item.gold:hover{background:var(--amber-l)}
.sb-avail{margin:0 8px 12px;padding:9px 11px;background:var(--bg3);border:1px solid var(--bo);border-radius:var(--r);display:flex;align-items:center;justify-content:space-between}
.avail-label{font-size:10px;font-weight:700;color:var(--t2)}
.avail-status{font-size:10px;font-weight:600;margin-top:1px}
.avail-status.on{color:var(--green)}.avail-status.off{color:var(--t3)}

/* Header */
#hdr{height:var(--hh);background:var(--bg2);border-bottom:1px solid var(--bo);display:flex;align-items:center;justify-content:space-between;padding:0 16px;position:sticky;top:0;z-index:50;gap:10px;box-shadow:var(--s1)}
.hdr-title{font-size:15px;font-weight:700;color:var(--t);display:flex;align-items:center;gap:8px;min-width:0;flex-shrink:1;overflow:hidden}
.hdr-title span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hdr-right{display:flex;align-items:center;gap:6px;flex-shrink:0}
.hdr-btn{width:36px;height:36px;border-radius:var(--r);background:var(--bg3);border:1px solid var(--bo);display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;transition:all .2s;position:relative;color:var(--t2);flex-shrink:0;text-decoration:none}
.hdr-btn:hover{border-color:var(--bo2);background:var(--bg4);color:var(--t);box-shadow:var(--s1)}
.hdr-btn.need-blood{background:var(--red);border-color:var(--red);color:white;padding:0 14px;width:auto;font-size:12px;font-weight:700;box-shadow:0 2px 8px rgba(212,43,58,.2)}
.notif-dot{position:absolute;top:5px;right:5px;width:6px;height:6px;border-radius:50%;background:var(--red);border:1.5px solid var(--bg2)}

/* Main content */
#mc{margin-left:var(--sw);flex:1;display:flex;flex-direction:column;min-height:100vh}
.scr{display:none;flex:1;padding:20px 18px;overflow-y:auto;overflow-x:hidden}
.scr.active{display:block}

/* Bottom nav */
#bottomNav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:200;background:var(--bg2);border-top:1px solid var(--bo);padding:6px;padding-bottom:calc(6px + var(--safe-b));justify-content:space-around;align-items:center;box-shadow:var(--s2)}
.bnav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px 8px;border-radius:10px;cursor:pointer;transition:all .2s;min-width:48px;touch-action:manipulation;text-decoration:none;background:none;border:none}
.bnav-item.active .bnav-ic,.bnav-item.active .bnav-lb{color:var(--red)}
.bnav-ic{font-size:18px;color:var(--t3)}
.bnav-lb{font-size:9px;font-weight:700;color:var(--t3);white-space:nowrap}
.bnav-sos{width:50px;height:50px;background:var(--red);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;margin-top:-18px;box-shadow:0 4px 18px rgba(212,43,58,.45);border:3px solid var(--bg);flex-shrink:0}
.menu-btn{display:none}

/* ─── Cards ──────────────────────────────────────── */
.stat-card{background:var(--bg2);border:1px solid var(--bo);border-radius:var(--rl);padding:14px;box-shadow:var(--s1);transition:box-shadow .2s}
.stat-card:hover{box-shadow:var(--s2)}
.stat-value{font-family:var(--fd);font-size:28px;line-height:1;letter-spacing:-.01em}
.stat-label{font-size:10px;color:var(--t3);font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-top:4px}
.section-card{background:var(--bg2);border:1px solid var(--bo);border-radius:var(--rl);box-shadow:var(--s1)}
.section-card-header{display:flex;align-items:center;justify-content:space-between;padding:13px 15px;border-bottom:1px solid var(--bo)}
.section-card-title{font-size:13px;font-weight:700}
.section-card-action{font-size:12px;color:var(--red);font-weight:600;cursor:pointer;text-decoration:none}

/* Tags */
.tag{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;padding:3px 9px;border-radius:var(--pill);white-space:nowrap}
.tag.red{background:var(--red-l);color:var(--red);border:1px solid var(--red-b)}
.tag.green{background:var(--green-l);color:var(--green);border:1px solid rgba(16,185,129,.25)}
.tag.amber{background:var(--amber-l);color:var(--amber);border:1px solid rgba(245,158,11,.3)}
.tag.blue{background:var(--blue-l);color:var(--blue);border:1px solid rgba(59,130,246,.3)}
.tag.gray{background:var(--bg3);color:var(--t3);border:1px solid var(--bo2)}

/* Avail dot */
.avail-dot{display:inline-flex;align-items:center;gap:5px;font-size:10px;font-weight:700}
.avail-dot::before{content:'';width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}
.avail-dot.on{color:var(--green)}.avail-dot.off{color:var(--t3)}

/* ─── Home ───────────────────────────────────────── */
.home-greeting h1{font-size:20px;font-weight:700;line-height:1.3}
.home-greeting p{font-size:13px;color:var(--t2);margin-top:2px}
.ad-banner{border-radius:var(--rl);overflow:hidden;margin:14px 0;position:relative;height:88px;cursor:pointer;flex-shrink:0;box-shadow:var(--s2)}
.ad-slide{position:absolute;inset:0;opacity:0;transition:opacity .6s;display:flex;align-items:center;padding:14px 16px;gap:13px}
.ad-slide.active{opacity:1}
.ad-badge{font-size:8px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;padding:2px 7px;border-radius:3px;background:rgba(255,255,255,.25);color:rgba(255,255,255,.95);position:absolute;top:8px;right:8px}
.ad-icon{font-size:28px;flex-shrink:0}
.ad-text{flex:1;min-width:0}
.ad-title{font-size:14px;font-weight:800;color:#fff;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ad-sub{font-size:11px;color:rgba(255,255,255,.75)}
.ad-cta{font-size:10px;font-weight:800;background:rgba(255,255,255,.22);color:#fff;padding:3px 9px;border-radius:var(--pill);margin-top:5px;display:inline-block}
.ad-dots{position:absolute;bottom:6px;left:50%;transform:translateX(-50%);display:flex;gap:4px}
.ad-dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.35);transition:all .3s}
.ad-dot.active{background:#fff;width:12px;border-radius:3px}
.sos-big{width:100%;padding:14px 18px;background:var(--red);border-radius:var(--rl);margin:14px 0;display:flex;align-items:center;justify-content:space-between;cursor:pointer;border:none;box-shadow:var(--sr);font-family:var(--fs);transition:all .25s;touch-action:manipulation;text-decoration:none}
.sos-big:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(212,43,58,.4)}
.sos-big-left{display:flex;align-items:center;gap:12px}
.sos-icon{font-size:22px;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}
.sos-title{font-size:14px;font-weight:800;color:#fff;text-align:left}
.sos-sub{font-size:11px;color:rgba(255,255,255,.75);margin-top:1px;text-align:left}
.stats-row{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:18px}
@media(min-width:600px){.stats-row{grid-template-columns:repeat(4,1fr)}}
.quick-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:12px}
.quick-item{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 6px;background:var(--bg3);border:1px solid var(--bo);border-radius:var(--r);cursor:pointer;transition:all .2s;text-align:center;text-decoration:none}
.quick-item:hover{border-color:var(--bo2);background:var(--bg4);transform:translateY(-1px);box-shadow:var(--s1)}
.quick-icon{font-size:18px}
.quick-label{font-size:10px;font-weight:700;color:var(--t2);line-height:1.3}
.req-item{display:flex;align-items:center;gap:10px;padding:11px 14px;border-bottom:1px solid var(--bo);cursor:pointer;transition:background .15s}
.req-item:last-child{border-bottom:none}
.req-item:hover{background:var(--bg3)}
.req-blood-badge{width:36px;height:36px;border-radius:10px;background:var(--red);display:flex;align-items:center;justify-content:center;font-family:var(--fm);font-size:10px;font-weight:800;color:#fff;flex-shrink:0}
.req-hosp{font-size:13px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.req-meta{font-size:11px;color:var(--t3);margin-top:1px}

/* ─── Donors ─────────────────────────────────────── */
.filter-bar{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap;align-items:center}
.filter-chip{padding:7px 12px;border-radius:var(--pill);border:1.5px solid var(--bo);background:var(--bg2);color:var(--t2);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;touch-action:manipulation}
.filter-chip:hover{border-color:var(--bo2);color:var(--t)}
.filter-chip.on{border-color:var(--red);background:var(--red-l);color:var(--red)}
.donors-grid{display:grid;grid-template-columns:1fr;gap:12px}
@media(min-width:600px){.donors-grid{grid-template-columns:repeat(2,1fr)}}
.donor-card{background:var(--bg2);border:1.5px solid var(--bo);border-radius:var(--rl);padding:14px;transition:all .2s;box-shadow:var(--s1)}
.donor-card:hover{border-color:var(--red-b);transform:translateY(-2px);box-shadow:var(--s2)}
.donor-card-header{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px}
.donor-av{width:42px;height:42px;border-radius:50%;background:var(--bg3);border:2px solid var(--red-b);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;color:var(--red);flex-shrink:0;overflow:hidden}
.donor-av img{width:100%;height:100%;object-fit:cover}
.donor-name{font-size:14px;font-weight:700}
.donor-loc{font-size:11px;color:var(--t3);font-family:var(--fm);margin-top:2px}
.donor-blood-tag{margin-left:auto;background:var(--red);color:#fff;font-family:var(--fm);font-size:12px;font-weight:800;padding:3px 8px;border-radius:7px;flex-shrink:0}
.donor-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:5px;margin-bottom:10px}
.donor-stat{text-align:center;padding:7px;background:var(--bg3);border-radius:8px}
.donor-stat-val{font-size:12px;font-weight:800}
.donor-stat-lbl{font-size:9px;color:var(--t3);font-weight:600;margin-top:2px}
.donor-actions{display:flex;gap:6px}
.donor-call-btn{flex:1;padding:8px;background:var(--red);color:#fff;font-size:12px;font-weight:700;border-radius:var(--pill);border:none;cursor:pointer;transition:all .2s}
.donor-call-btn:hover{background:var(--red-d)}
.donor-icon-btn{width:36px;height:36px;border-radius:var(--pill);display:flex;align-items:center;justify-content:center;font-size:13px;cursor:pointer;transition:all .2s;border:none}
.donor-icon-btn.msg{background:var(--blue-l);border:1px solid rgba(59,130,246,.3)}
.donor-icon-btn.wa{background:rgba(37,211,102,.1);border:1px solid rgba(37,211,102,.25)}
.donor-icon-btn:hover{opacity:.8;transform:scale(1.05)}

/* Donor profile modal */
.dp-head{display:flex;gap:14px;align-items:flex-start;margin-bottom:14px}
.dp-av{width:56px;height:56px;border-radius:50%;background:var(--red-l);border:3px solid var(--red-b);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:800;color:var(--red);flex-shrink:0;overflow:hidden}
.dp-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}
.dp-stat{background:var(--bg3);border-radius:var(--r);padding:10px;text-align:center}
.dp-stat-val{font-size:16px;font-weight:800}
.dp-stat-lbl{font-size:10px;color:var(--t3);margin-top:2px}
.dp-act-row{display:flex;gap:8px;margin-bottom:8px}
.dp-act-btn{flex:1;padding:11px;border-radius:var(--pill);font-size:12px;font-weight:700;cursor:pointer;border:none;transition:all .2s;font-family:var(--fs)}
.dp-act-btn.call{background:var(--red);color:#fff}
.dp-act-btn.msg{background:var(--blue-l);color:var(--blue);border:1px solid rgba(59,130,246,.3)}
.dp-act-btn.req{background:var(--bg3);color:var(--t2);border:1px solid var(--bo2)}
.dp-act-btn:hover{opacity:.87;transform:translateY(-1px)}

/* ─── SOS ────────────────────────────────────────── */
.sos-screen{display:flex;flex-direction:column;align-items:center;text-align:center;padding:10px 0}
.sos-ring-wrap{position:relative;margin-bottom:26px}
.sos-main-btn{width:160px;height:160px;border-radius:50%;background:var(--red);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;border:none;transition:all .2s;position:relative;z-index:2;animation:sosIdle 2.5s ease-in-out infinite}
@keyframes sosIdle{0%,100%{box-shadow:0 0 0 0 rgba(212,43,58,.4)}50%{box-shadow:0 0 0 12px rgba(212,43,58,0)}}
.sos-main-btn:hover{transform:scale(1.04)}
.sos-main-btn.live{animation:sosLive 1s ease-in-out infinite}
@keyframes sosLive{0%{box-shadow:0 0 0 0 rgba(212,43,58,.6)}100%{box-shadow:0 0 0 40px rgba(212,43,58,0)}}
.sos-ring{position:absolute;inset:-20px;border-radius:50%;border:2px solid rgba(212,43,58,.2);z-index:1;animation:sosRing 2.5s ease-in-out infinite}
.sos-ring-2{inset:-40px;border:1px solid rgba(212,43,58,.1);animation-delay:.5s}
@keyframes sosRing{0%,100%{opacity:.3;transform:scale(1)}50%{opacity:.7;transform:scale(1.04)}}
.sos-text{font-family:var(--fd);font-size:48px;color:#fff;letter-spacing:.1em;line-height:1}
.sos-hint{font-size:10px;color:rgba(255,255,255,.65);font-weight:600;margin-top:3px}
.sos-config{width:100%;max-width:380px}
.sos-opts{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
.bcast-box{background:var(--bg2);border:1px solid var(--bo);border-radius:var(--rl);padding:18px;width:100%;max-width:380px;margin-top:16px;display:none;box-shadow:var(--s2)}
.bcast-box.live{display:block;animation:fadeUp .4s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.bcast-num{font-family:var(--fd);font-size:54px;color:var(--red);line-height:1}
.bcast-lbl{font-size:13px;color:var(--t2);margin-bottom:12px}
.responder-list{display:flex;flex-direction:column;gap:6px;max-height:170px;overflow-y:auto}
.resp-item{display:flex;align-items:flex-start;gap:9px;padding:10px 11px;background:var(--green-l);border:1px solid rgba(16,185,129,.2);border-radius:var(--r);animation:fadeUp .3s ease}
.resp-name{font-size:12px;font-weight:700;flex:1}
.verify-card{background:var(--red-l);border:1px solid var(--red-b);border-radius:var(--rl);padding:14px;margin-bottom:14px}
.verify-title{font-size:12px;font-weight:800;color:var(--red);margin-bottom:11px;display:flex;align-items:center;gap:7px}
.verify-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:11px}
.verify-item{aspect-ratio:1;border-radius:var(--r);background:#fff;border:2px dashed var(--red-b);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;font-size:22px;gap:5px;touch-action:manipulation}
.verify-item:hover{border-color:var(--red);background:var(--red-l)}
.verify-item.done{border-color:var(--green);border-style:solid;background:var(--green-l)}
.verify-label{font-size:9px;font-weight:700;color:var(--t3);text-align:center}
.verify-item.done .verify-label{color:var(--green)}
.loc-info{background:var(--blue-l);border:1px solid rgba(59,130,246,.3);border-radius:var(--r);padding:9px 11px;font-size:11px;color:var(--blue);display:none;margin-bottom:9px;align-items:center;gap:7px}
.loc-info.show{display:flex}

/* ─── Map ────────────────────────────────────────── */
#mapLeaflet{width:100%;height:calc(100vh - 230px);min-height:320px;border-radius:var(--rl);overflow:hidden;border:1px solid var(--bo);box-shadow:var(--s2)}
.map-you,.map-donor,.map-hosp,.map-req,.map-pharm{border-radius:50%;border:2px solid #fff}
.map-you{width:14px;height:14px;background:var(--red);box-shadow:0 0 12px rgba(212,43,58,.8)}
.map-donor{width:12px;height:12px;background:var(--amber);box-shadow:0 0 8px rgba(245,158,11,.7)}
.map-hosp{width:14px;height:14px;border-radius:3px;background:var(--blue);box-shadow:0 0 8px rgba(59,130,246,.7)}
.map-req{width:12px;height:12px;background:var(--red);opacity:.7}
.map-pharm{width:12px;height:12px;background:var(--green);box-shadow:0 0 8px rgba(16,185,129,.7)}
.map-stats{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:10px;background:var(--bg2);border:1px solid var(--bo);border-radius:var(--r);padding:9px 14px;box-shadow:var(--s1)}
.map-stat-v{font-size:16px;font-weight:800}
.map-stat-l{font-size:9px;color:var(--t3);font-weight:600}
.map-legend{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}
.map-legend-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--t2)}
.map-legend-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.layer-btn{background:var(--bg2);border:1px solid var(--bo2);color:var(--t2);padding:5px 11px;border-radius:var(--pill);font-size:11px;cursor:pointer;transition:all .2s}
.layer-btn.active{background:var(--red);color:#fff;border-color:var(--red)}

/* ─── Hospitals ──────────────────────────────────── */
.hosp-list{display:grid;grid-template-columns:1fr;gap:12px}
@media(min-width:600px){.hosp-list{grid-template-columns:repeat(2,1fr)}}
.hosp-card{background:var(--bg2);border:1.5px solid var(--bo);border-radius:var(--rl);padding:15px;transition:all .2s;cursor:pointer;box-shadow:var(--s1)}
.hosp-card:hover{border-color:var(--red-b);transform:translateY(-2px);box-shadow:var(--s2)}
.hosp-card.sponsored{border-color:rgba(255,215,0,.35)}
.hosp-name{font-size:14px;font-weight:700;margin-bottom:3px;line-height:1.3}
.hosp-addr{font-size:11px;color:var(--t3)}
.blood-chips{display:flex;flex-wrap:wrap;gap:4px;margin:10px 0}
.blood-chip{font-family:var(--fm);font-size:9px;font-weight:800;padding:3px 6px;border-radius:5px}
.blood-chip.h{background:var(--green-l);color:var(--green);border:1px solid rgba(16,185,129,.25)}
.blood-chip.m{background:var(--blue-l);color:var(--blue);border:1px solid rgba(59,130,246,.25)}
.blood-chip.l{background:var(--amber-l);color:var(--amber);border:1px solid rgba(245,158,11,.25)}
.blood-chip.n{background:var(--bg3);color:var(--t3);border:1px solid var(--bo);opacity:.5}
.hosp-actions{display:flex;gap:5px;flex-wrap:wrap}
.hosp-btn{flex:1;min-width:55px;padding:7px;border-radius:var(--pill);font-size:11px;font-weight:700;cursor:pointer;transition:all .2s;border:none;font-family:var(--fs);text-align:center;text-decoration:none}
.hosp-btn.call{background:var(--red-l);color:var(--red);border:1px solid var(--red-b)}
.hosp-btn.route{background:var(--bg3);color:var(--t2);border:1px solid var(--bo2)}
.hosp-btn.amb{background:var(--amber-l);color:var(--amber);border:1px solid rgba(245,158,11,.3)}

/* ─── Stories ────────────────────────────────────── */
.story-filters{display:flex;gap:7px;margin-bottom:14px;overflow-x:auto;scrollbar-width:none;padding-bottom:5px}
.story-filters::-webkit-scrollbar{display:none}
.story-chip{padding:6px 14px;border-radius:var(--pill);border:1.5px solid var(--bo);background:var(--bg2);color:var(--t2);font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all .2s}
.story-chip.on{border-color:var(--red-b);background:var(--red-l);color:var(--red)}
.stories-masonry{columns:2;gap:10px;column-gap:10px}
@media(min-width:600px){.stories-masonry{columns:3}}
.story-pin{break-inside:avoid;background:var(--bg2);border:1.5px solid var(--bo);border-radius:var(--rl);margin-bottom:10px;overflow:hidden;cursor:pointer;transition:all .2s;display:block;width:100%;box-shadow:var(--s1);text-decoration:none;text-align:left}
.story-pin:hover{border-color:var(--red-b);transform:translateY(-2px);box-shadow:var(--s2)}
.story-pin-img{width:100%;position:relative;overflow:hidden;min-height:90px}
.story-pin-img-fill{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:38px}
.story-pin-grad{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(26,8,8,.5))}
.story-pin-verified{position:absolute;top:8px;right:8px;background:var(--green-l);color:var(--green);font-size:8px;font-weight:800;padding:2px 6px;border-radius:4px}
.story-pin-body{padding:10px}
.story-pin-quote{font-size:12px;color:var(--t2);line-height:1.7;font-style:italic;margin-bottom:8px}
.story-pin-footer{display:flex;align-items:center;gap:8px}
.story-pin-av{width:22px;height:22px;border-radius:50%;background:var(--red-l);border:1px solid var(--red-b);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:800;color:var(--red);flex-shrink:0}
.story-pin-name{font-size:11px;font-weight:700;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.story-pin-likes{font-size:11px;color:var(--t3);flex-shrink:0}

/* ─── Modals ─────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:500;display:flex;align-items:flex-end;justify-content:center;padding:0;opacity:0;pointer-events:none;transition:opacity .25s}
@media(min-width:600px){.modal-overlay{align-items:center;padding:20px}}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{background:var(--bg2);border:1px solid var(--bo);border-radius:24px 24px 0 0;padding:20px 20px calc(20px + var(--safe-b));width:100%;max-width:460px;position:relative;transform:translateY(28px);transition:transform .25s;max-height:92vh;overflow-y:auto;-webkit-overflow-scrolling:touch;box-shadow:var(--s3)}
@media(min-width:600px){.modal{border-radius:20px;transform:translateY(12px);padding-bottom:20px}}
.modal.wide{max-width:580px}
.modal-overlay.open .modal{transform:translateY(0)}
.modal-handle{width:40px;height:4px;background:var(--bg5);border-radius:2px;margin:0 auto 16px;display:block}
@media(min-width:600px){.modal-handle{display:none}}
.modal-close{position:absolute;top:14px;right:14px;width:28px;height:28px;border-radius:50%;background:var(--bg3);border:1px solid var(--bo);display:flex;align-items:center;justify-content:center;font-size:12px;cursor:pointer;color:var(--t2);z-index:1;transition:all .2s}
.modal-close:hover{background:var(--bg4);color:var(--t)}
.modal-title{font-size:17px;font-weight:700;margin-bottom:5px}
.modal-sub{font-size:13px;color:var(--t2);margin-bottom:18px;line-height:1.6}

/* ─── Toast ──────────────────────────────────────── */
#tc{position:fixed;bottom:calc(20px + var(--safe-b));right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;max-width:min(320px,calc(100vw - 32px))}
.toast{background:var(--bg2);border:1px solid var(--bo2);border-radius:var(--r);padding:11px 14px;box-shadow:var(--s3);pointer-events:all;animation:toastIn .3s cubic-bezier(.34,1.56,.64,1);display:flex;gap:9px;align-items:flex-start}
.toast.s{border-left:3px solid var(--green)}.toast.e{border-left:3px solid var(--red)}
.toast.w{border-left:3px solid var(--amber)}.toast.i{border-left:3px solid var(--blue)}
@keyframes toastIn{from{transform:translateX(110%);opacity:0}to{transform:translateX(0);opacity:1}}
.toast-icon{font-size:14px;margin-top:1px;flex-shrink:0}
.toast-title{font-size:12px;font-weight:700;color:var(--t)}
.toast-msg{font-size:11px;color:var(--t2);margin-top:2px;line-height:1.4}

/* ─── Leaderboard ────────────────────────────────── */
.lb-tabs{display:flex;gap:4px;background:var(--bg3);padding:4px;border-radius:var(--pill);width:fit-content;margin-bottom:18px;overflow-x:auto;scrollbar-width:none}
.lb-tabs::-webkit-scrollbar{display:none}
.lb-tab{padding:7px 16px;border-radius:var(--pill);font-size:12px;font-weight:700;cursor:pointer;transition:all .2s;color:var(--t2);white-space:nowrap;background:none;border:none}
.lb-tab.active{background:var(--red);color:#fff}
.lb-podium{display:grid;grid-template-columns:1fr 1.2fr 1fr;gap:10px;margin-bottom:18px;align-items:end}
.pod{text-align:center;padding:14px 8px;border-radius:var(--rl);background:var(--bg2);border:1px solid var(--bo);box-shadow:var(--s1)}
.pod.first{border-color:rgba(245,158,11,.35);background:linear-gradient(160deg,#fffbeb,#fff)}
.pod-rank{font-size:20px;margin-bottom:6px}
.pod-av{width:40px;height:40px;border-radius:50%;background:var(--bg4);border:3px solid var(--bo);margin:0 auto 6px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;color:var(--t2)}
.pod.first .pod-av{border-color:var(--amber);color:var(--amber)}
.pod-name{font-size:12px;font-weight:800;margin-bottom:3px}
.pod-count{font-size:18px;font-weight:800;color:var(--red)}
.pod-label{font-size:10px;color:var(--t3)}
.lb-list{background:var(--bg2);border:1px solid var(--bo);border-radius:var(--rl);overflow:hidden;box-shadow:var(--s1)}
.lb-row{display:flex;align-items:center;gap:10px;padding:11px 14px;border-bottom:1px solid var(--bo);transition:background .15s}
.lb-row:last-child{border-bottom:none}
.lb-row:hover{background:var(--bg3)}
.lb-row.me{background:var(--red-l)}
.lb-pos{font-family:var(--fd);font-size:16px;color:var(--t3);width:24px;text-align:center;flex-shrink:0}
.lb-av{width:34px;height:34px;border-radius:50%;background:var(--bg4);border:2px solid var(--bo);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--t2);flex-shrink:0;overflow:hidden}
.lb-name{font-size:13px;font-weight:700}
.lb-district{font-size:11px;color:var(--t3)}
.lb-count{font-size:15px;font-weight:800;color:var(--red);margin-left:auto;flex-shrink:0}

/* ─── Notifications ──────────────────────────────── */
.notif-list{background:var(--bg2);border:1px solid var(--bo);border-radius:var(--rl);overflow:hidden;box-shadow:var(--s1)}
.notif-item{display:flex;align-items:flex-start;gap:10px;padding:13px 14px;border-bottom:1px solid var(--bo);cursor:pointer;transition:background .15s}
.notif-item:last-child{border-bottom:none}
.notif-item:hover{background:var(--bg3)}
.notif-item.unread{background:var(--red-l)}
.notif-icon{width:36px;height:36px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;background:var(--bg4);border:1px solid var(--bo)}
.notif-body{flex:1;min-width:0}
.notif-title{font-size:13px;font-weight:700;margin-bottom:3px}
.notif-msg{font-size:12px;color:var(--t2);line-height:1.5}
.notif-time{font-size:10px;color:var(--t3);margin-top:4px}
.notif-dot-badge{width:7px;height:7px;border-radius:50%;background:var(--red);flex-shrink:0;margin-top:5px}

/* ─── Blood Card ─────────────────────────────────── */
.blood-card-wrap{display:flex;justify-content:center;margin-bottom:20px}
.blood-card{width:min(300px,100%);background:linear-gradient(135deg,#1a0208 0%,#0a0a14 60%,#150308 100%);border:1px solid rgba(212,43,58,.3);border-radius:20px;padding:20px;position:relative;overflow:hidden;box-shadow:var(--s3)}
.bc-blood{font-family:var(--fd);font-size:52px;color:var(--red);line-height:1;margin-bottom:3px;letter-spacing:.02em}
.bc-name{font-size:14px;font-weight:800;color:#fff;margin-bottom:3px}
.bc-id{font-family:var(--fm);font-size:9px;color:rgba(255,255,255,.3)}
.bc-actions{display:flex;gap:10px;justify-content:center}
.bc-btn{flex:1;max-width:140px;padding:11px;border-radius:var(--pill);font-size:12px;font-weight:700;cursor:pointer;transition:all .2s;text-align:center;border:none;font-family:var(--fs)}
.bc-btn.share{background:var(--red);color:#fff}
.bc-btn.dl{background:var(--bg3);color:var(--t2);border:1px solid var(--bo2)}

/* ─── EDF ────────────────────────────────────────── */
.edf-card{background:var(--bg2);border:1.5px solid var(--bo);border-radius:var(--rl);overflow:hidden;margin-bottom:13px;transition:all .2s;box-shadow:var(--s1)}
.edf-card:hover{box-shadow:var(--s2)}
.edf-card.urgent{border-color:var(--red-b)}
.edf-card.verified{border-color:rgba(16,185,129,.3)}
.edf-top{padding:14px}
.edf-name{font-size:14px;font-weight:800;margin-bottom:2px}
.edf-meta{font-size:11px;color:var(--t3)}
.edf-prog-bar{height:7px;background:var(--bg4);border-radius:4px;overflow:hidden;margin-bottom:6px}
.edf-prog-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--red),var(--amber));transition:width .5s}
.edf-prog-meta{display:flex;justify-content:space-between;font-size:11px}
.edf-raised{font-weight:800;color:var(--red);font-family:var(--fm)}
.edf-pct{font-weight:800;color:var(--amber)}
.edf-goal{color:var(--t3)}
.edf-actions{display:flex;gap:7px;align-items:center;padding:0 14px 14px}
.edf-donate-btn{flex:1;padding:10px;background:var(--red);color:#fff;border-radius:var(--pill);font-size:13px;font-weight:700;border:none;cursor:pointer;transition:all .2s}
.edf-donate-btn:hover{background:var(--red-d)}
.edf-fraud-banner{background:var(--amber-l);border:1px solid rgba(245,158,11,.25);border-radius:var(--r);padding:10px 13px;font-size:12px;color:var(--amber);margin-bottom:14px;line-height:1.6}

/* ─── Inbox / Messages ───────────────────────────── */
.inbox-item{display:flex;align-items:center;gap:10px;padding:13px 14px;border-bottom:1px solid var(--bo);cursor:pointer;transition:background .15s}
.inbox-item:last-child{border-bottom:none}
.inbox-item:hover{background:var(--bg3)}
.inbox-item.unread{background:var(--red-l)}
.inbox-av{width:38px;height:38px;border-radius:50%;background:var(--bg4);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:var(--t2);flex-shrink:0;overflow:hidden}
.inbox-av img{width:100%;height:100%;object-fit:cover}
.inbox-name{font-size:13px;font-weight:700}
.inbox-preview{font-size:12px;color:var(--t2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.inbox-time{font-size:11px;color:var(--t3);flex-shrink:0}
.msg-list{max-height:260px;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px}
.msg-item{max-width:82%;padding:9px 13px;border-radius:14px;font-size:13px;line-height:1.5}
.msg-item.me{align-self:flex-end;background:var(--red);color:#fff;border-bottom-right-radius:3px}
.msg-item.them{align-self:flex-start;background:var(--bg3);border:1px solid var(--bo);border-bottom-left-radius:3px}
.msg-time{font-size:10px;opacity:.6;margin-top:3px;display:block}
.msg-input-wrap{display:flex;gap:7px;padding:9px;border-top:1px solid var(--bo);background:var(--bg2)}
.msg-send{width:38px;height:38px;background:var(--red);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;border:none;flex-shrink:0;color:#fff;transition:all .2s}
.msg-send:hover{background:var(--red-d)}

/* ─── Settings ───────────────────────────────────── */
.settings-section{background:var(--bg2);border:1px solid var(--bo);border-radius:var(--rl);margin-bottom:13px;overflow:hidden;box-shadow:var(--s1)}
.settings-section-title{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--t3);padding:12px 14px 5px}
.settings-item{display:flex;align-items:center;gap:11px;padding:12px 14px;border-top:1px solid var(--bo)}
.settings-item-icon{width:34px;height:34px;border-radius:var(--r);background:var(--bg3);border:1px solid var(--bo);display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}
.settings-item-info{flex:1;min-width:0}
.settings-item-title{font-size:13px;font-weight:700}
.settings-item-sub{font-size:11px;color:var(--t3);margin-top:2px}
.settings-item-right{flex-shrink:0}

/* ─── Profile ────────────────────────────────────── */
.profile-head{display:flex;align-items:flex-start;gap:16px;background:var(--bg2);border:1px solid var(--bo);border-radius:var(--rl);padding:18px;margin-bottom:16px;flex-wrap:wrap;box-shadow:var(--s1)}
.prof-av{width:60px;height:60px;border-radius:50%;background:var(--red-l);border:3px solid var(--red-b);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;color:var(--red);flex-shrink:0;overflow:hidden}
.prof-av img{width:100%;height:100%;object-fit:cover}
.prof-name{font-size:18px;font-weight:700;margin-bottom:3px}
.prof-blood-tag{display:inline-block;font-family:var(--fm);font-size:13px;font-weight:800;color:var(--red);background:var(--red-l);border:1px solid var(--red-b);padding:3px 10px;border-radius:6px;margin-bottom:9px}
.prof-stats{display:flex;gap:18px;flex-wrap:wrap}
.prof-stat-val{font-size:18px;font-weight:800}
.prof-stat-lbl{font-size:10px;color:var(--t3);font-weight:600;margin-top:2px}
.profile-grid{display:grid;grid-template-columns:1fr;gap:13px}
@media(min-width:600px){.profile-grid{grid-template-columns:1fr 1fr}}
.profile-section{background:var(--bg2);border:1px solid var(--bo);border-radius:var(--rl);overflow:hidden;box-shadow:var(--s1)}
.ps-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--bo)}
.ps-title{font-size:13px;font-weight:700}
.ps-edit{font-size:12px;color:var(--red);font-weight:600;cursor:pointer;background:none;border:none}
.ps-body{padding:13px 14px}
.profile-field{margin-bottom:10px}
.profile-field:last-child{margin-bottom:0}
.profile-field-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--t3);margin-bottom:2px}
.profile-field-value{font-size:13px}
.badge-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:13px 14px}
@media(min-width:420px){.badge-grid{grid-template-columns:repeat(4,1fr)}}
.badge-item{padding:10px 6px;text-align:center;border-radius:var(--r);background:var(--bg3);border:1px solid var(--bo);transition:all .2s}
.badge-item.earned{border-color:rgba(245,158,11,.4);background:var(--amber-l)}
.badge-item.locked{opacity:.25;filter:grayscale(1)}
.badge-icon{font-size:20px;display:block;margin-bottom:4px}
.badge-name{font-size:10px;font-weight:700;line-height:1.3}

/* ─── Pharmacy / Cart ────────────────────────────── */
.pharm-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
@media(min-width:600px){.pharm-grid{grid-template-columns:repeat(3,1fr)}}
.pharm-card{background:var(--bg2);border:1.5px solid var(--bo);border-radius:var(--rl);padding:13px;transition:all .2s;box-shadow:var(--s1)}
.pharm-card:hover{border-color:rgba(16,185,129,.4);transform:translateY(-2px);box-shadow:var(--s2)}
.pharm-card-icon{font-size:28px;margin-bottom:8px;display:block}
.pharm-card-name{font-size:13px;font-weight:800;margin-bottom:2px}
.pharm-card-gen{font-size:11px;color:var(--t3);margin-bottom:6px}
.pharm-card-price{font-size:15px;font-weight:800;color:var(--green);font-family:var(--fm)}
.pharm-add-btn{width:100%;margin-top:9px;padding:8px;background:var(--green);color:#fff;border-radius:var(--pill);font-size:12px;font-weight:700;border:none;cursor:pointer;transition:all .2s}
.pharm-add-btn:hover{background:#059669}
.pharm-cats{display:flex;gap:7px;overflow-x:auto;margin-bottom:16px;padding-bottom:5px;scrollbar-width:none}
.pharm-cats::-webkit-scrollbar{display:none}
.pharm-cat{padding:6px 13px;border-radius:var(--pill);border:1.5px solid var(--bo);background:var(--bg2);color:var(--t2);font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .2s;flex-shrink:0;background:none;border-width:1.5px}
.pharm-cat.on{border-color:rgba(16,185,129,.4);background:var(--green-l);color:var(--green)}
.cart-bubble{position:fixed;bottom:calc(78px + var(--safe-b));right:16px;z-index:300;background:var(--red);color:#fff;width:50px;height:50px;border-radius:50%;display:none;align-items:center;justify-content:center;font-size:18px;cursor:pointer;box-shadow:var(--sr);transition:all .2s}
.cart-bubble.show{display:flex}
.cart-count{position:absolute;top:-4px;right:-4px;background:var(--amber);color:#fff;width:19px;height:19px;border-radius:50%;font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center}

/* ─── Gift ───────────────────────────────────────── */
.gift-hero{text-align:center;padding:26px 16px;background:linear-gradient(135deg,var(--amber-l),var(--red-l));border:1px solid rgba(245,158,11,.2);border-radius:var(--rl);margin-bottom:20px;box-shadow:var(--s2)}
.gift-amts{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:14px}
.gift-amt{padding:9px 16px;border-radius:var(--pill);border:2px solid var(--bo2);background:var(--bg2);font-size:14px;font-weight:800;color:var(--t2);cursor:pointer;transition:all .2s;font-family:var(--fm);background:none}
.gift-amt.sel{border-color:var(--amber);background:var(--amber-l);color:var(--amber)}
.gift-methods{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:18px}
.gift-method{padding:10px 14px;border-radius:var(--r);border:1.5px solid var(--bo);background:var(--bg2);cursor:pointer;transition:all .2s;text-align:center;min-width:78px}
.gift-method.sel{border-color:rgba(245,158,11,.4);background:var(--amber-l)}
.gift-method-icon{font-size:20px;display:block;margin-bottom:4px}
.gift-method-label{font-size:11px;font-weight:700;color:var(--t2)}

/* ─── Community ──────────────────────────────────── */
.comm-tabs{display:flex;gap:4px;background:var(--bg3);padding:4px;border-radius:var(--pill);margin-bottom:16px;overflow-x:auto;scrollbar-width:none}
.comm-tabs::-webkit-scrollbar{display:none}
.comm-tab{padding:6px 14px;border-radius:var(--pill);font-size:12px;font-weight:700;cursor:pointer;color:var(--t3);white-space:nowrap;transition:all .2s;background:none;border:none}
.comm-tab.active{background:var(--red);color:#fff}
.comm-post{background:var(--bg2);border:1.5px solid var(--bo);border-radius:var(--rl);margin-bottom:10px;overflow:hidden;transition:all .2s;box-shadow:var(--s1)}
.comm-post:hover{border-color:var(--bo2);box-shadow:var(--s2)}
.vote-col{display:flex;flex-direction:column;align-items:center;padding:12px 9px;background:var(--bg3);gap:4px;min-width:42px;flex-shrink:0}
.vote-btn{width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:12px;cursor:pointer;border:none;background:none;color:var(--t3);transition:all .2s}
.vote-btn:hover{background:var(--bg4);color:var(--t)}
.vote-count{font-family:var(--fm);font-size:12px;font-weight:800}
.post-body{flex:1;padding:12px;min-width:0}
.post-title{font-size:14px;font-weight:700;margin-bottom:5px;cursor:pointer;line-height:1.4}
.post-title:hover{color:var(--red)}
.post-excerpt{font-size:12px;color:var(--t2);line-height:1.7;margin-bottom:9px}
.post-actions{display:flex;gap:10px;flex-wrap:wrap}
.post-action{font-size:12px;color:var(--t3);cursor:pointer;display:flex;align-items:center;gap:4px;padding:3px 6px;border-radius:6px;transition:all .2s;background:none;border:none}
.post-action:hover{background:var(--bg3);color:var(--t)}
.post-action.liked{color:var(--red)}

/* ─── Number Access ──────────────────────────────── */
.num-req-item{display:flex;align-items:flex-start;gap:11px;padding:13px 14px;border-bottom:1px solid var(--bo)}
.num-req-item:last-child{border-bottom:none}
.num-req-av{width:36px;height:36px;border-radius:50%;background:var(--red-l);border:2px solid var(--red-b);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:var(--red);flex-shrink:0}
.num-req-name{font-size:13px;font-weight:700}
.num-req-msg{font-size:12px;color:var(--t2);margin:3px 0;font-style:italic}

/* ─── Area Status ────────────────────────────────── */
.area-grid{display:grid;grid-template-columns:1fr;gap:10px;margin-bottom:16px}
@media(min-width:480px){.area-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.area-grid{grid-template-columns:repeat(3,1fr)}}
.area-card{background:var(--bg2);border:1px solid var(--bo);border-radius:var(--rl);padding:14px;box-shadow:var(--s1)}
.area-name{font-size:14px;font-weight:700;margin-bottom:10px}
.area-bar{display:flex;align-items:center;gap:7px;margin-bottom:5px}
.area-bar-label{font-family:var(--fm);font-size:10px;font-weight:800;width:26px}
.area-bar-bg{flex:1;height:5px;background:var(--bg4);border-radius:3px}
.area-bar-fill{height:100%;border-radius:3px}
.area-bar-pct{font-size:10px;font-weight:700;width:30px;text-align:right}

/* ─── Campaigns ──────────────────────────────────── */
.camp-list{display:flex;flex-direction:column;gap:10px}
.camp-card{background:var(--bg2);border:1.5px solid var(--bo);border-radius:var(--rl);overflow:hidden;display:flex;box-shadow:var(--s1);transition:box-shadow .2s}
.camp-card:hover{box-shadow:var(--s2)}
.camp-accent{width:5px;flex-shrink:0}
.camp-body{padding:13px 15px;flex:1;min-width:0}
.camp-org{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--t3);margin-bottom:3px}
.camp-title{font-size:14px;font-weight:700;margin-bottom:3px}
.camp-meta{font-size:12px;color:var(--t2)}
.camp-right{padding:12px;display:flex;flex-direction:column;align-items:flex-end;justify-content:space-between;flex-shrink:0}
.camp-spots{font-size:12px;font-weight:700;color:var(--amber)}

/* ─── Eligibility ────────────────────────────────── */
.elig-box{background:var(--bg2);border:1px solid var(--bo);border-radius:var(--rl);padding:20px;margin-bottom:16px;box-shadow:var(--s1)}
.elig-num{font-family:var(--fd);font-size:50px;line-height:1;margin-bottom:7px}
.elig-title{font-size:16px;font-weight:700;margin-bottom:6px}
.elig-desc{font-size:13px;color:var(--t2);line-height:1.7}

/* ─── Awareness ──────────────────────────────────── */
.awareness-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:15px}
.awareness-card{background:var(--bg2);border:1px solid var(--bo);border-radius:var(--rl);padding:14px;box-shadow:var(--s1)}
.awareness-icon{font-size:22px;margin-bottom:8px}
.awareness-title{font-size:13px;font-weight:700;margin-bottom:8px}
.awareness-list{list-style:none;display:flex;flex-direction:column;gap:4px}
.awareness-list li{font-size:12px;color:var(--t2);padding-left:14px;position:relative}
.awareness-list li::before{content:'→';position:absolute;left:0;color:var(--red);font-size:10px;top:2px}
.myth-fact-item{display:flex;gap:11px;align-items:flex-start;padding:11px 14px;border-top:1px solid var(--bo)}
.myth-fact-myth{flex:1;font-size:12px;color:var(--red);font-weight:600}
.myth-vs{font-size:10px;font-weight:800;color:var(--t3);flex-shrink:0}
.myth-fact-fact{flex:1;font-size:12px;color:var(--green);font-weight:600}

/* ─── Promo / Analytics ──────────────────────────── */
.promo-hero{background:linear-gradient(135deg,#fff5f5 0%,#fff 50%,#f0f9ff 100%);border:1px solid var(--bo);border-radius:var(--rl);padding:24px 20px;margin-bottom:22px;text-align:center;position:relative;overflow:hidden;box-shadow:var(--s2)}
.promo-hero-title{font-family:var(--fd);font-size:clamp(24px,5vw,32px);letter-spacing:.02em;margin-bottom:6px}
.promo-hero-title span{color:var(--red)}
.tier-grid{display:grid;grid-template-columns:1fr;gap:13px;margin-bottom:24px}
@media(min-width:460px){.tier-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:780px){.tier-grid{grid-template-columns:repeat(4,1fr)}}
.tier-card{background:var(--bg2);border:2px solid var(--bo);border-radius:var(--rl);padding:18px;position:relative;transition:all .3s;cursor:pointer;box-shadow:var(--s1)}
.tier-card:hover{transform:translateY(-3px);box-shadow:var(--s3)}
.tier-card.standard{border-color:var(--blue)}
.tier-card.premium{border-color:var(--red)}
.tier-card.vip{border-color:var(--amber);background:linear-gradient(160deg,#fffbeb,#fff)}
.tier-btn{width:100%;padding:10px;border-radius:var(--pill);font-size:13px;font-weight:800;border:none;cursor:pointer;font-family:var(--fs);transition:all .2s}
.tier-btn:hover{opacity:.88;transform:translateY(-1px)}
.anal-card{background:var(--bg2);border:1px solid var(--bo);border-radius:var(--rl);padding:13px;text-align:center;box-shadow:var(--s1)}
.anal-val{font-family:var(--fd);font-size:28px;color:var(--red);margin-bottom:4px;line-height:1}
.anal-lbl{font-size:10px;color:var(--t3);font-weight:600;text-transform:uppercase;letter-spacing:.07em}
.anal-chg{font-size:10px;margin-top:4px}
.anal-chg.up{color:var(--green)}.anal-chg.dn{color:var(--red)}

/* ─── Responsive ─────────────────────────────────── */
@media(max-width:768px){
  :root{--sw:0px}
  #sb{transform:translateX(-260px);width:260px}
  #sb.open{transform:translateX(0);box-shadow:var(--s3)}
  #mc{margin-left:0;max-width:100vw}
  .scr{padding:16px 14px;padding-bottom:calc(78px + var(--safe-b))}
  .menu-btn{display:flex}
  #bottomNav{display:flex}
}
@media(max-width:400px){
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .bg-grid{grid-template-columns:repeat(4,1fr)}
}
@supports(padding-top:env(safe-area-inset-top)){
  #hdr{padding-top:calc(0px + var(--safe-t))}
}

/* ─── Utility Animations ─────────────────────────── */
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.fade-in{animation:fadeIn .35s ease}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

/* ─── Accessible Focus ───────────────────────────── */
:focus-visible{outline:2px solid var(--red);outline-offset:2px}
button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible{outline:2px solid var(--red);outline-offset:2px}

/* ─── Print ──────────────────────────────────────── */
@media print{
  #sb,#hdr,#bottomNav,#tc,.modal-overlay{display:none!important}
  #mc{margin:0!important}
  .blood-card{print-color-adjust:exact;-webkit-print-color-adjust:exact}
}
.push-banner{position:fixed;bottom:70px;left:12px;right:12px;background:var(--bg,#fff);border:1px solid var(--border,#e0e0e0);border-radius:12px;padding:14px 16px;display:flex;align-items:center;gap:12px;box-shadow:0 4px 24px rgba(0,0,0,.12);z-index:9999;animation:pushBannerIn .3s ease-out}
.push-banner.hidden{display:none}
.push-banner-ic{font-size:24px;flex-shrink:0}
.push-banner-body{flex:1;min-width:0}
.push-banner-body strong{font-size:14px;display:block}
.push-banner-body span{font-size:12px;color:var(--t3,#888);display:block;margin-top:2px}
.push-banner-btn{flex-shrink:0;padding:8px 18px;border:none;border-radius:8px;background:#d42b3a;color:#fff;font-size:13px;font-weight:700;cursor:pointer;-webkit-tap-highlight-color:transparent}
.push-banner-x{flex-shrink:0;width:28px;height:28px;border:none;background:none;font-size:16px;color:var(--t3,#888);cursor:pointer;padding:0;line-height:28px;text-align:center}
@keyframes pushBannerIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

