:root{--red: #DC2626;--red-dark: #991B1B;--red-light: #FCA5A5;--red-glow: 0 0 16px rgba(220,38,38,.5);--red-soft: rgba(220,38,38,.12);--bg: #0D0D0D;--surface: #161616;--surface2: #1E1E1E;--border: rgba(255,255,255,.08);--border-red: rgba(220,38,38,.3);--text: #F5F5F5;--text-muted: #888;--text-dim: #555;--white: #FFFFFF;--green: #22C55E;--amber: #F59E0B;--blue: #3B82F6;--purple: #8B5CF6;--rank-volunteer: #6B7280;--rank-helper: #3B82F6;--rank-protector: #8B5CF6;--rank-guardian: #F59E0B;--rank-champion: #EF4444;--rank-legend: #DC2626}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;background:var(--bg);color:var(--text);font-family:Inter,Segoe UI,system-ui,sans-serif;font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden}#app-root{max-width:480px;margin:0 auto;min-height:100vh;position:relative;background:var(--bg)}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#dc26264d;border-radius:4px}h1{font-size:1.5rem;font-weight:800}h2{font-size:1.25rem;font-weight:700}h3{font-size:1.05rem;font-weight:700}.app-header{position:sticky;top:0;z-index:100;background:#0d0d0df2;backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:.75rem 1rem;display:flex;align-items:center;gap:.75rem}.app-header-title{font-size:1.1rem;font-weight:900;color:var(--red);letter-spacing:.08em;text-transform:uppercase}.app-header-sub{font-size:.625rem;color:var(--text-muted);letter-spacing:.14em;text-transform:uppercase}.header-logo{height:36px;width:auto;mix-blend-mode:screen;filter:brightness(1.1)}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;background:#0d0d0dfa;border-top:1px solid var(--border);display:flex;z-index:100;padding-bottom:env(safe-area-inset-bottom,0)}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.6rem .25rem;background:none;border:none;cursor:pointer;color:var(--text-dim);transition:color .15s;text-decoration:none;position:relative}.nav-item.active{color:var(--red)}.nav-item:hover{color:var(--text-muted)}.nav-icon{font-size:1.25rem;line-height:1}.nav-label{font-size:.5625rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.nav-badge{position:absolute;top:.35rem;right:calc(50% - 1.1rem);background:var(--red);color:#fff;font-size:.5rem;font-weight:900;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 3px}.page{padding:1rem 1rem 5rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1rem;margin-bottom:.75rem}.card-red{background:var(--red-soft);border-color:var(--border-red)}.card:last-child{margin-bottom:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.625rem 1.25rem;border-radius:10px;border:none;font-weight:700;font-size:.875rem;cursor:pointer;transition:all .15s;text-decoration:none;letter-spacing:.02em}.btn-primary{background:var(--red);color:#fff;box-shadow:var(--red-glow)}.btn-primary:hover{background:var(--red-dark)}.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--border-red)}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border)}.btn-block{width:100%}.btn-sm{padding:.375rem .75rem;font-size:.75rem;border-radius:8px}.form-group{margin-bottom:1rem}.form-label{display:block;font-size:.6875rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.375rem}.form-input,.form-select,.form-textarea{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:.625rem .875rem;color:var(--text);font-size:.9375rem;outline:none;transition:border-color .15s;font-family:inherit}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--red)}.form-input::placeholder{color:var(--text-dim)}.form-textarea{resize:vertical;min-height:80px}.form-select option{background:var(--surface2)}.blood-badge{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:28px;padding:0 8px;background:var(--red);color:#fff;font-weight:900;font-size:.8125rem;border-radius:6px;letter-spacing:.04em}.blood-badge-outline{background:transparent;border:1.5px solid var(--red);color:var(--red)}.urgency-badge{display:inline-flex;align-items:center;gap:.25rem;padding:2px 8px;border-radius:20px;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.urgency-critical{background:#dc262633;color:#f87171;border:1px solid rgba(220,38,38,.4)}.urgency-urgent{background:#f59e0b33;color:#fcd34d;border:1px solid rgba(245,158,11,.4)}.urgency-normal{background:#3b82f626;color:#93c5fd;border:1px solid rgba(59,130,246,.3)}.rank-badge{display:inline-flex;align-items:center;gap:.25rem;padding:2px 8px;border-radius:20px;font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.avatar{border-radius:50%;object-fit:cover;background:var(--surface2);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:900;color:var(--red);text-transform:uppercase}.avatar-sm{width:36px;height:36px;font-size:.875rem}.avatar-md{width:48px;height:48px;font-size:1.125rem}.avatar-lg{width:72px;height:72px;font-size:1.5rem}.avatar-xl{width:96px;height:96px;font-size:2rem}.section-label{font-size:.6875rem;font-weight:800;color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;margin-bottom:.75rem}.hero-banner{background:linear-gradient(135deg,#1a0000,#2d0a0a,#1a0000);border:1px solid var(--border-red);border-radius:16px;padding:1.5rem;margin-bottom:1.25rem;text-align:center;position:relative;overflow:hidden}.hero-banner:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(220,38,38,.15) 0%,transparent 70%);pointer-events:none}.stat-row{display:flex;gap:.75rem;margin-bottom:1rem}.stat-box{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:.875rem .5rem;text-align:center}.stat-val{font-size:1.5rem;font-weight:900;color:var(--red);line-height:1}.stat-label{font-size:.5625rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-weight:700;margin-top:.25rem}.donor-card{display:flex;align-items:center;gap:.875rem;padding:.875rem;background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:.5rem;text-decoration:none;color:inherit;transition:border-color .15s}.donor-card:hover{border-color:var(--border-red)}.request-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1rem;margin-bottom:.625rem;text-decoration:none;color:inherit;display:block;transition:border-color .15s}.request-card:hover{border-color:var(--border-red)}.request-card.critical{border-color:#dc262666}.msg-bubble{max-width:72%;padding:.5rem .875rem;border-radius:16px;font-size:.9375rem;line-height:1.45;margin-bottom:.375rem}.msg-out{background:var(--red);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}.msg-in{background:var(--surface2);color:var(--text);align-self:flex-start;border-bottom-left-radius:4px}.msg-time{font-size:.5625rem;color:var(--text-dim)}.lb-row{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:.5rem}.lb-rank-num{width:28px;text-align:center;font-weight:900;font-size:.875rem;color:var(--text-muted);flex-shrink:0}.lb-rank-gold{color:#f59e0b}.lb-rank-silver{color:#9ca3af}.lb-rank-bronze{color:#cd7f32}.divider{border:none;border-top:1px solid var(--border);margin:.875rem 0}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--red);border-radius:50%;animation:spin .7s linear infinite;margin:2rem auto}@keyframes spin{to{transform:rotate(360deg)}}.alert{padding:.75rem 1rem;border-radius:10px;font-size:.875rem;font-weight:500;margin-bottom:.875rem}.alert-danger{background:#dc262626;color:#fca5a5;border:1px solid rgba(220,38,38,.3)}.alert-success{background:#22c55e1f;color:#86efac;border:1px solid rgba(34,197,94,.3)}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.empty-state-icon{font-size:3rem;margin-bottom:.75rem}.empty-state h3{margin-bottom:.5rem}.tab-strip{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:3px;margin-bottom:1rem}.tab-btn{flex:1;padding:.4rem;background:none;border:none;border-radius:8px;cursor:pointer;font-size:.75rem;font-weight:700;color:var(--text-muted);transition:all .15s;text-transform:uppercase;letter-spacing:.04em}.tab-btn.active{background:var(--red);color:#fff}.progress-bar{height:6px;background:var(--surface2);border-radius:3px;overflow:hidden;margin-top:.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,var(--red),#FF6B6B);border-radius:3px;transition:width .4s ease}.fab{position:fixed;bottom:5rem;right:max(1rem,calc(50% - 240px + 1rem));width:52px;height:52px;border-radius:50%;background:var(--red);color:#fff;border:none;font-size:1.5rem;cursor:pointer;box-shadow:0 4px 20px #dc262680;display:flex;align-items:center;justify-content:center;z-index:90;transition:transform .15s}.fab:hover{transform:scale(1.08)}.modal-overlay{position:fixed;inset:0;background:#000000bf;z-index:200;display:flex;align-items:flex-end;justify-content:center}.modal-sheet{background:var(--surface);border:1px solid var(--border);border-radius:20px 20px 0 0;padding:1.5rem 1rem;width:100%;max-width:480px;max-height:85vh;overflow-y:auto}.modal-handle{width:40px;height:4px;background:var(--border);border-radius:2px;margin:0 auto 1.25rem}.online-dot{width:10px;height:10px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--green);flex-shrink:0}.offline-dot{width:10px;height:10px;border-radius:50%;background:var(--text-dim);flex-shrink:0}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.blood-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;margin-top:.5rem}.blood-option{display:flex;align-items:center;justify-content:center;height:40px;border-radius:8px;border:1.5px solid var(--border);background:var(--surface2);font-weight:900;font-size:.875rem;cursor:pointer;transition:all .15s;color:var(--text)}.blood-option.selected{border-color:var(--red);background:var(--red);color:#fff}@keyframes pulse-red{0%,to{box-shadow:0 0 #dc262666}50%{box-shadow:0 0 0 8px #dc262600}}.pulse-critical{animation:pulse-red 2s infinite}
