@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap);:root{--navy:#1e4d8c;--navy-dark:#163970;--navy-light:#2e6ab5;--green:#2e8b57;--green-dark:#236b43;--green-light:#3daa6e;--teal:#1a7a6e;--white:#fff;--surface:#f4f7fc;--surface-2:#ebf0f9;--border:#d5e0f0;--border-dark:#b8ccec;--text:#0f1f3d;--text-2:#3d5280;--muted:#6b7fa8;--danger:#dc2626;--danger-bg:#fef2f2;--warn:#d97706;--warn-bg:#fffbeb;--success:#16a34a;--success-bg:#f0fdf4;--info:#0369a1;--info-bg:#eff6ff;--grad-sidebar:linear-gradient(180deg,#163970,#1e4d8c 60%,#1a5c7a);--grad-header:linear-gradient(135deg,#1e4d8c,#2e8b57);--grad-card:linear-gradient(135deg,#ebf3ff,#ebf7f0);--grad-btn:linear-gradient(135deg,#1e4d8c,#2563b0);--grad-btn-green:linear-gradient(135deg,#2e8b57,#3daa6e);--shadow-xs:0 1px 3px #1e4d8c14;--shadow-sm:0 2px 8px #1e4d8c1a;--shadow-md:0 4px 20px #1e4d8c24;--shadow-lg:0 8px 40px #1e4d8c2e;--shadow-xl:0 20px 60px #1e4d8c38;--radius-sm:6px;--radius:10px;--radius-lg:16px;--radius-xl:24px;--font-heading:"Plus Jakarta Sans",system-ui,sans-serif;--font-body:"Inter",system-ui,sans-serif;--sidebar-w:256px}*,:after,:before{box-sizing:border-box;margin:0;padding:0}#root,body,html{-webkit-font-smoothing:antialiased;background:#f4f7fc;background:var(--surface);font-family:Inter,system-ui,sans-serif;font-family:var(--font-body);font-size:15px;height:100%;line-height:1.6}#root,body,h1,h2,h3,h4,html{color:#0f1f3d;color:var(--text)}h1,h2,h3,h4{font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font-heading);font-weight:700;line-height:1.25}a{color:#1e4d8c;color:var(--navy);text-decoration:none;transition:color .15s}a:hover{color:#2e6ab5;color:var(--navy-light)}.app-shell{display:flex;min-height:100vh}.sidebar{background:linear-gradient(180deg,#163970,#1e4d8c 60%,#1a5c7a);background:var(--grad-sidebar);bottom:0;box-shadow:4px 0 24px #0f1f3d2e;color:#ffffffe6;display:flex;flex-direction:column;flex-shrink:0;left:0;overflow-y:auto;position:fixed;top:0;transition:transform .28s cubic-bezier(.4,0,.2,1);width:256px;width:var(--sidebar-w);z-index:100}.sidebar-logo{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;gap:12px;padding:24px 20px 20px;position:relative}.sidebar-logo img{background:#ffffff1a;border-radius:10px;flex-shrink:0;height:44px;object-fit:cover;width:44px}.sidebar-logo-text h1{color:#fff;font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font-heading);font-size:1.05rem;font-weight:800;letter-spacing:-.01em;line-height:1.2}.sidebar-logo-text span{color:#ffffff80;display:block;font-size:.65rem;letter-spacing:.12em;margin-top:2px;text-transform:uppercase}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:2px;padding:12px 10px}.sidebar-nav a,.sidebar-nav button.nav-btn{align-items:center;background:none;border:none;border-radius:10px;border-radius:var(--radius);color:#ffffffa6;cursor:pointer;display:flex;font-family:Inter,system-ui,sans-serif;font-family:var(--font-body);font-size:.875rem;font-weight:500;gap:10px;letter-spacing:.01em;padding:10px 14px;text-align:left;transition:all .18s;width:100%}.sidebar-nav a:hover,.sidebar-nav button.nav-btn:hover{background:#ffffff1a;color:#fff}.sidebar-nav a.active{background:#ffffff26;box-shadow:inset 0 0 0 1px #ffffff2e;color:#fff;font-weight:600}.sidebar-nav .nav-icon{flex-shrink:0;font-size:1.05rem;text-align:center;width:20px}.sidebar-user{border-top:1px solid #ffffff1a;padding:14px 16px}.sidebar-user-inner{background:#ffffff14;border-radius:10px;border-radius:var(--radius);padding:10px 12px}.sidebar-user .name{color:#fff;font-size:.85rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user .role{color:#ffffff80;font-size:.68rem;letter-spacing:.08em;margin-top:2px;text-transform:uppercase}.sidebar-user .logout-btn{align-items:center;background:none;border:none;color:#ffffff73;cursor:pointer;display:flex;font-family:Inter,system-ui,sans-serif;font-family:var(--font-body);font-size:.78rem;gap:6px;margin-top:10px;padding:4px 0;transition:color .15s;width:100%}.sidebar-user .logout-btn:hover{color:#ffffffd9}.main-content{background:#f4f7fc;background:var(--surface);flex:1 1;margin-left:256px;margin-left:var(--sidebar-w);min-height:100vh}.page-header{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fff;background:var(--white);border-bottom:1px solid #d5e0f0;border-bottom:1px solid var(--border);padding:22px 32px;position:sticky;top:0;z-index:50}.page-header h2{color:#0f1f3d;color:var(--text);font-size:1.5rem;font-weight:700;letter-spacing:-.02em}.page-header p{color:#6b7fa8;color:var(--muted);font-size:.85rem;margin-top:2px}.page-content{padding:24px 32px}.card{background:#fff;background:var(--white);border:1px solid #d5e0f0;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #1e4d8c14;box-shadow:var(--shadow-xs);padding:20px;transition:box-shadow .2s,transform .2s}.card:hover{box-shadow:0 2px 8px #1e4d8c1a;box-shadow:var(--shadow-sm)}.card-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.btn{align-items:center;border:1.5px solid #0000;border-radius:10px;border-radius:var(--radius);cursor:pointer;display:inline-flex;font-family:Inter,system-ui,sans-serif;font-family:var(--font-body);font-size:.875rem;font-weight:600;gap:6px;justify-content:center;letter-spacing:.01em;padding:9px 18px;transition:all .18s cubic-bezier(.4,0,.2,1);white-space:nowrap}.btn-primary{background:linear-gradient(135deg,#1e4d8c,#2563b0);background:var(--grad-btn);border-color:#0000;box-shadow:0 2px 8px #1e4d8c40;color:#fff}.btn-primary:hover{background:#163970;background:var(--navy-dark);box-shadow:0 4px 14px #1e4d8c59;transform:translateY(-1px)}.btn-secondary{background:#fff;background:var(--white);border-color:#b8ccec;border-color:var(--border-dark);color:#3d5280;color:var(--text-2)}.btn-secondary:hover{background:#ebf0f9;background:var(--surface-2);border-color:#1e4d8c;border-color:var(--navy);color:#1e4d8c;color:var(--navy)}.btn-success{background:linear-gradient(135deg,#2e8b57,#3daa6e);background:var(--grad-btn-green);border-color:#0000;box-shadow:0 2px 8px #2e8b5740;color:#fff}.btn-success:hover{background:#236b43;background:var(--green-dark);box-shadow:0 4px 14px #2e8b5759;transform:translateY(-1px)}.btn-danger{background:#fff;background:var(--white);border-color:#fecaca;color:#dc2626;color:var(--danger)}.btn-danger:hover{background:#fef2f2;background:var(--danger-bg);border-color:#dc2626;border-color:var(--danger)}.btn-sm{border-radius:6px;border-radius:var(--radius-sm);font-size:.78rem;padding:5px 12px}.btn:disabled{box-shadow:none!important;cursor:not-allowed;opacity:.45;transform:none!important}.form-group{margin-bottom:16px}.form-group label{color:#3d5280;color:var(--text-2);display:block;font-size:.78rem;font-weight:600;letter-spacing:.05em;margin-bottom:6px;text-transform:uppercase}.form-control{background:#fff;background:var(--white);border:1.5px solid #d5e0f0;border:1.5px solid var(--border);border-radius:10px;border-radius:var(--radius);color:#0f1f3d;color:var(--text);font-family:Inter,system-ui,sans-serif;font-family:var(--font-body);font-size:.9rem;outline:none;padding:9px 12px;transition:border-color .18s,box-shadow .18s;width:100%}.form-control:focus{border-color:#1e4d8c;border-color:var(--navy);box-shadow:0 0 0 3px #1e4d8c1f}.form-control::placeholder{color:#6b7fa8;color:var(--muted)}select.form-control{cursor:pointer}textarea.form-control{min-height:80px;resize:vertical}.form-row{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}.badge{align-items:center;border-radius:999px;display:inline-flex;font-size:.68rem;font-weight:700;letter-spacing:.06em;padding:3px 10px;text-transform:uppercase;white-space:nowrap}.badge-available{background:#dcfce7;color:#15803d}.badge-requested{background:#fef3c7;color:#92400e}.badge-request_accepted{background:#dbeafe;color:#1d4ed8}.badge-volunteer_picked{background:#ede9fe;color:#6d28d9}.badge-volunteer_delivered{background:#ccfbf1;color:#0f766e}.badge-issued{background:#dcfce7;color:#15803d}.badge-return_requested{background:#ffe4e6;color:#be123c}.badge-return_picked{background:#ede9fe;color:#6d28d9}.badge-return_delivered{background:#ccfbf1;color:#0f766e}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));margin-bottom:24px}.stat-card{background:#fff;background:var(--white);border:1px solid #d5e0f0;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #1e4d8c14;box-shadow:var(--shadow-xs);overflow:hidden;padding:20px;position:relative;text-align:center;transition:box-shadow .2s,transform .2s}.stat-card:hover{box-shadow:0 4px 20px #1e4d8c24;box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card:before{content:"";height:3px;left:0;position:absolute;right:0;top:0}.stat-card .stat-value,.stat-card:before{background:linear-gradient(135deg,#1e4d8c,#2e8b57);background:var(--grad-header)}.stat-card .stat-value{-webkit-text-fill-color:#0000;-webkit-background-clip:text;background-clip:text;font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font-heading);font-size:2.4rem;font-weight:800;line-height:1}.stat-card .stat-label{color:#6b7fa8;color:var(--muted);font-size:.72rem;font-weight:600;letter-spacing:.08em;margin-top:8px;text-transform:uppercase}.alert{border:1px solid #0000;border-radius:10px;border-radius:var(--radius);font-size:.875rem;font-weight:500;margin-bottom:16px;padding:12px 16px}.alert-error{background:#fef2f2;background:var(--danger-bg);border-color:#fecaca;color:#991b1b}.alert-success{background:#f0fdf4;background:var(--success-bg);border-color:#bbf7d0;color:#166534}.alert-info{background:#eff6ff;background:var(--info-bg);border-color:#bfdbfe;color:#1e40af}.table-wrap{border-radius:16px;border-radius:var(--radius-lg);overflow-x:auto}table{border-collapse:collapse;font-size:.875rem;width:100%}thead th{background:#ebf0f9;background:var(--surface-2);border-bottom:2px solid #d5e0f0;border-bottom:2px solid var(--border);color:#3d5280;color:var(--text-2);font-size:.72rem;font-weight:700;letter-spacing:.07em;padding:11px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}tbody td{border-bottom:1px solid #d5e0f0;border-bottom:1px solid var(--border);color:#0f1f3d;color:var(--text);padding:13px 16px;vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr{transition:background .12s}tbody tr:hover{background:#f4f7fc;background:var(--surface)}.book-card{background:#fff;background:var(--white);border:1px solid #d5e0f0;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius-lg);display:flex;flex-direction:column;overflow:hidden;transition:box-shadow .22s,transform .22s}.book-card:hover{box-shadow:0 4px 20px #1e4d8c24;box-shadow:var(--shadow-md);transform:translateY(-3px)}.book-card-image{align-items:center;background:linear-gradient(135deg,#ebf3ff,#ebf7f0);background:var(--grad-card);display:flex;height:180px;justify-content:center;overflow:hidden;position:relative}.book-card-image img{height:100%;object-fit:cover;width:100%}.book-card-image .no-image{font-size:3.5rem;opacity:.25}.book-card-body{display:flex;flex:1 1;flex-direction:column;padding:16px}.book-card-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#0f1f3d;color:var(--text);display:-webkit-box;font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font-heading);font-size:.95rem;font-weight:700;margin-bottom:4px;overflow:hidden}.book-card-author{color:#6b7fa8;color:var(--muted);font-size:.82rem;margin-bottom:10px}.book-card-meta{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.book-card-tag{background:#ebf0f9;background:var(--surface-2);border:1px solid #d5e0f0;border:1px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);color:#3d5280;color:var(--text-2);font-size:.7rem;font-weight:500;padding:2px 8px}.book-card-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:auto}.modal-overlay{align-items:center;animation:fadeIn .18s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f1f3d8c;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:200}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{animation:slideUp .22s cubic-bezier(.4,0,.2,1);background:#fff;background:var(--white);border-radius:24px;border-radius:var(--radius-xl);box-shadow:0 20px 60px #1e4d8c38;box-shadow:var(--shadow-xl);max-height:90vh;max-width:520px;overflow-y:auto;padding:28px;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;margin-bottom:20px}.modal-header h3{color:#0f1f3d;color:var(--text);font-size:1.2rem;font-weight:700}.modal-close{align-items:center;background:#ebf0f9;background:var(--surface-2);border:none;border-radius:50%;color:#6b7fa8;color:var(--muted);cursor:pointer;display:flex;flex-shrink:0;font-size:1rem;height:30px;justify-content:center;transition:all .15s;width:30px}.modal-close:hover{background:#fef2f2;background:var(--danger-bg);color:#dc2626;color:var(--danger)}.pagination{align-items:center;display:flex;gap:8px;justify-content:center;margin-top:20px}.pagination-info{color:#6b7fa8;color:var(--muted);font-size:.8rem;font-weight:500}.search-bar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.search-bar .form-control{flex:1 1;min-width:180px}.spinner-wrap{align-items:center;display:flex;justify-content:center;padding:56px}.spinner{animation:spin .75s linear infinite;border:3px solid #d5e0f0;border-top-color:#1e4d8c;border:3px solid var(--border);border-radius:50%;border-top-color:var(--navy);height:36px;width:36px}@keyframes spin{to{transform:rotate(1turn)}}.empty-state{color:#6b7fa8;color:var(--muted);padding:56px 20px;text-align:center}.empty-state .empty-icon{font-size:3.5rem;margin-bottom:14px;opacity:.35}.empty-state h3{color:#3d5280;color:var(--text-2);font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font-heading);font-size:1.1rem;margin-bottom:6px}.empty-state p{font-size:.875rem}.auth-page{align-items:center;background:linear-gradient(135deg,#ebf0f9,#ebf7f0);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative}.auth-page:before{background:radial-gradient(circle,#1e4d8c14 0,#0000 70%);height:600px;right:-10%;top:-30%;width:600px}.auth-page:after,.auth-page:before{border-radius:50%;content:"";pointer-events:none;position:absolute}.auth-page:after{background:radial-gradient(circle,#2e8b5712 0,#0000 70%);bottom:-20%;height:500px;left:-10%;width:500px}.auth-card{background:#fff;background:var(--white);border:1px solid #d5e0f0;border:1px solid var(--border);border-radius:24px;border-radius:var(--radius-xl);box-shadow:0 8px 40px #1e4d8c2e;box-shadow:var(--shadow-lg);max-width:440px;padding:44px 40px;position:relative;width:100%;z-index:1}.auth-logo{margin-bottom:28px;text-align:center}.auth-logo img{border-radius:20px;box-shadow:0 4px 20px #1e4d8c24;box-shadow:var(--shadow-md);height:80px;margin-bottom:14px;object-fit:cover;width:80px}.auth-logo h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#1e4d8c,#2e8b57);background:var(--grad-header);-webkit-background-clip:text;background-clip:text;font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font-heading);font-size:1.6rem;font-weight:800;letter-spacing:-.02em}.auth-logo p{font-size:.78rem;font-weight:500;letter-spacing:.08em;margin-top:4px;text-transform:uppercase}.auth-divider,.auth-logo p{color:#6b7fa8;color:var(--muted)}.auth-divider{font-size:.8rem;margin:20px 0;position:relative;text-align:center}.auth-divider:before{background:#d5e0f0;background:var(--border);content:"";height:1px;left:0;position:absolute;right:0;top:50%}.auth-divider span{background:#fff;background:var(--white);padding:0 12px;position:relative}.mobile-topbar{align-items:center;background:#163970;background:var(--navy-dark);box-shadow:0 4px 20px #1e4d8c24;box-shadow:var(--shadow-md);color:#fff;display:none;gap:12px;height:56px;left:0;padding:0 16px;position:fixed;right:0;top:0;z-index:150}.mobile-topbar img{border-radius:8px;height:32px;object-fit:cover;width:32px}.mobile-logo{color:#fff;flex:1 1;font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font-heading);font-size:1rem;font-weight:800;letter-spacing:-.01em}.mobile-role{background:#ffffff1a;border-radius:999px;color:#ffffff80;font-size:.65rem;letter-spacing:.1em;padding:2px 8px;text-transform:uppercase}.hamburger{background:none;border:none;border-radius:6px;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-size:1.3rem;line-height:1;padding:6px 8px;transition:background .15s}.hamburger:hover{background:#ffffff1f}.sidebar-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f1f3d80;display:none;inset:0;position:fixed;z-index:99}.sidebar-close{align-items:center;background:#ffffff1f;border:none;border-radius:50%;color:#fff;cursor:pointer;display:none;display:flex;font-size:1rem;height:28px;justify-content:center;position:absolute;right:14px;top:14px;transition:background .15s;width:28px}.sidebar-close:hover{background:#ffffff38}.bottom-nav{align-items:stretch;background:#163970;background:var(--navy-dark);border-top:1px solid #ffffff14;bottom:0;display:none;height:64px;left:0;position:fixed;right:0;z-index:150}.bottom-nav-item{align-items:center;background:none;border:none;border-radius:0;color:#ffffff73;cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-family:Inter,system-ui,sans-serif;font-family:var(--font-body);gap:3px;justify-content:center;padding:6px 4px;text-decoration:none;transition:color .15s,background .15s}.bottom-nav-item.active,.bottom-nav-item:hover{background:#ffffff14;color:#fff}.bottom-nav-item.active{color:#7dd3fc}.bottom-nav-icon{font-size:1.15rem;line-height:1}.bottom-nav-label{font-size:.6rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}@media (max-width:1024px){.mobile-topbar{display:flex}.sidebar-overlay{display:block}.bottom-nav{display:flex}.sidebar{transform:translateX(-100%)}.sidebar.sidebar-open{transform:translateX(0)}.sidebar-logo{padding-right:48px;position:relative}.sidebar-close{display:flex}.main-content{margin-left:0;padding-bottom:64px;padding-top:56px}.form-row{grid-template-columns:1fr}.page-content{padding:14px}.page-header{padding:14px 16px;top:56px}.page-header h2{font-size:1.25rem}.card-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr 1fr}.auth-card{padding:28px 20px}table{font-size:.78rem}thead th{padding:9px 10px}tbody td{padding:10px}.modal{border-radius:16px;border-radius:var(--radius-lg);padding:20px}.search-bar{flex-direction:column}.search-bar .form-control{min-width:0;min-width:auto}}@media (min-width:1025px){.bottom-nav,.mobile-topbar,.sidebar-close,.sidebar-overlay{display:none!important}.sidebar{transform:translateX(0)!important}.main-content{margin-left:256px;margin-left:var(--sidebar-w);padding-bottom:0;padding-top:0}}@supports (padding-bottom:env(safe-area-inset-bottom)){.bottom-nav{height:calc(64px + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom)}@media (max-width:1024px){.main-content{padding-bottom:calc(64px + env(safe-area-inset-bottom))}}}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#b8ccec;background:var(--border-dark);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:#2e6ab5;background:var(--navy-light)}
/*# sourceMappingURL=main.a6df357e.css.map*/