.spinner-wrap{display:inline-flex;align-items:center;gap:.5rem;margin:.5rem 0}.spinner-wrap.centered{justify-content:center;width:100%;min-height:240px}.spinner{width:18px;height:18px;border-radius:50%;border:2px solid #d1d5db;border-top-color:#2563eb;animation:spin .8s linear infinite}.details-card{display:grid;gap:.7rem}.meta-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem}.loan-form{display:grid;grid-template-columns:2fr 2fr 1fr auto;gap:.6rem}@keyframes spin{to{transform:rotate(360deg)}}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;display:flex;flex-direction:column;gap:.5rem;z-index:9999;pointer-events:none}.toast{padding:.75rem 1.1rem;border-radius:10px;font-size:.9rem;font-weight:500;box-shadow:0 4px 16px #00000026;animation:toastIn .25s ease;max-width:320px}.toast-success{background:#059669;color:#fff}.toast-error{background:#dc2626;color:#fff}.toast-info{background:#2563eb;color:#fff}@keyframes toastIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border)}.pagination .page-info{font-size:.9rem;color:var(--muted)}.pagination .page-jump{display:inline-flex;align-items:center;gap:.5rem}.pagination .page-jump input{width:4.5rem;padding:.45rem .55rem;border:1px solid var(--border);border-radius:.6rem;background:var(--surface);color:var(--text)}@media (max-width: 900px){.meta-grid,.loan-form{grid-template-columns:1fr}}:root{--bg: #f4f6fb;--surface: #ffffff;--text: #1f2937;--muted: #6b7280;--border: #e5e7eb;--primary: #2563eb;--primary-dark: #1d4ed8;--danger: #dc2626;--warning: #d97706;--success: #059669;--space-1: clamp(.5rem, 1.4vw, .8rem);--space-2: clamp(.75rem, 1.8vw, 1rem);--space-3: clamp(1rem, 2.4vw, 1.4rem)}*{box-sizing:border-box}html,body,#root{width:100%;max-width:100%;overflow-x:hidden}body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;color:var(--text);background:linear-gradient(180deg,#f8fbff 0%,var(--bg) 100%);line-height:1.45}h1,h2,h3,p{margin:0}a{color:inherit;text-decoration:none}.app-shell{min-height:100vh;display:grid;grid-template-columns:250px 1fr}.sidebar{background:#0f172a;color:#e2e8f0;padding:var(--space-2);display:flex;flex-direction:column;gap:var(--space-2)}.nav-group{display:flex;flex-direction:column;gap:.4rem}.nav-link{padding:.75rem .9rem;border-radius:8px;color:#cbd5e1;min-height:44px;display:flex;align-items:center}.nav-link.active,.nav-link:hover{background:#ffffff26;color:#fff}.sidebar-footer{margin-top:auto;display:grid;gap:.4rem}.role-pill{text-transform:uppercase;letter-spacing:.04em}.content{min-width:0;padding:var(--space-3)}.page-header{margin-bottom:var(--space-2)}.page-header h2{font-size:clamp(1.25rem,2.8vw,1.8rem);line-height:1.2}.page-header .muted{margin-top:.3rem}.page-header-top{display:none}.mobile-menu-btn{display:none;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:8px;padding:.5rem .75rem;min-height:44px;font-size:.92rem;font-weight:600}.muted{color:var(--muted)}.small{font-size:.85rem}.full{width:100%}.btn{background:var(--primary);color:#fff;border:none;border-radius:8px;padding:.62rem .9rem;cursor:pointer;min-height:44px;min-width:44px;font-weight:600}.btn:hover{background:var(--primary-dark)}.btn-secondary{background:#e5e7eb;color:#111827}.btn-secondary:hover{background:#d1d5db}.btn-danger{background:var(--danger)}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:var(--space-2);min-width:0}.book-card{display:flex;flex-direction:column;gap:.8rem;height:100%;transition:all .2s ease;box-shadow:0 1px 3px #00000014;overflow:hidden}.book-card:hover{box-shadow:0 10px 25px #0000001f;transform:translateY(-4px);border-color:var(--primary)}.book-cover{width:100%;aspect-ratio:2 / 3;min-height:180px;padding:.75rem;background:linear-gradient(160deg,#eef4ff,#dbe7ff);border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center;flex-shrink:0}.book-cover img{width:100%;height:100%;object-fit:contain;object-position:center;border-radius:6px;background:#fff;box-shadow:0 8px 20px #0f172a1f}.book-content{display:flex;flex-direction:column;gap:.6rem;flex-grow:1}.book-card h3{font-size:1.1rem;font-weight:600;line-height:1.3;margin-bottom:.2rem}.book-card .muted{font-size:.95rem;font-weight:500;margin:.3rem 0}.book-card .small{padding:.6rem 0 .4rem;margin-bottom:.2rem;display:flex;gap:.6rem;font-size:.85rem;border-top:1px solid #f3f4f6}.book-card .badge{align-self:flex-start;margin-bottom:.2rem;font-weight:600}.book-card .btn{margin-top:auto;font-weight:500;transition:all .15s ease}.cards-grid,.summary-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:var(--space-2)}.metric{font-size:1.8rem;font-weight:700;margin-top:.5rem}.metric.warning{color:var(--warning)}.filters{display:grid;grid-template-columns:1.4fr 1.1fr 1fr 1fr;gap:.65rem;margin-bottom:var(--space-2)}.filters>*{min-width:0}input,select,textarea{width:100%;padding:.68rem .72rem;border:1px solid var(--border);border-radius:8px;background:#fff;min-height:44px;font-size:.98rem}button,input,select,textarea{font:inherit}input:focus-visible,select:focus-visible,textarea:focus-visible,button:focus-visible,.nav-link:focus-visible{outline:2px solid color-mix(in srgb,var(--primary) 65%,white);outline-offset:1px}textarea{min-height:100px;resize:vertical}label{display:grid;gap:.35rem;font-size:.92rem}.form-grid{display:grid;gap:.8rem;grid-template-columns:repeat(2,minmax(0,1fr))}.form-grid .span-2{grid-column:1 / -1}.actions{margin:.7rem 0;display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.inline-actions{display:flex;gap:.4rem;width:100%}.inline-field{width:100%}.copy-barcode-list{max-width:100%}.copy-barcode-row{gap:.6rem}.copy-barcode-row span{min-width:0;overflow-wrap:anywhere}.pagination{flex-wrap:wrap}.table-wrap{overflow:auto;background:var(--surface);border:1px solid var(--border);border-radius:10px;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse}th,td{padding:.7rem;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}th{background:#f9fafb;font-size:.9rem;white-space:nowrap}.badge{display:inline-flex;align-items:center;padding:.2rem .55rem;border-radius:999px;font-size:.8rem}.badge-success{background:#05966926;color:var(--success)}.badge-warning{background:#d9770626;color:var(--warning)}.badge-danger{background:#dc262626;color:var(--danger)}.badge-neutral{background:#6b728026;color:#374151}.auth-page{min-height:100vh;display:grid;place-items:center;padding:1rem}.auth-card{width:min(420px,100%);background:#fff;border:1px solid var(--border);border-radius:14px;padding:1.2rem;display:grid;gap:.8rem;text-align:center}.auth-card h1,.auth-card p{margin:0}.auth-card label{text-align:left}.login-logo{width:100%;max-width:240px;height:auto;margin:0 auto .5rem;display:block}.error-text{color:var(--danger)}.empty-state{border:1px dashed var(--border);border-radius:10px;background:#fff;padding:1rem}@media (max-width: 900px){.app-shell{grid-template-columns:1fr}.sidebar{position:fixed;inset:0 auto 0 0;width:min(82vw,320px);max-width:100%;transform:translate(-102%);transition:transform .25s ease;z-index:30;overflow-y:auto;box-shadow:0 10px 30px #0003}.app-shell.menu-open .sidebar{transform:translate(0)}.content{position:relative;padding:var(--space-2)}.page-header h2{font-size:clamp(1.15rem,4.8vw,1.5rem)}.app-shell.menu-open .content:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:#02061759;z-index:20}.page-header-top{display:flex;justify-content:flex-start;margin-bottom:.5rem}.mobile-menu-btn{display:inline-flex;align-items:center}.page-header .muted{font-size:.92rem}input,select,textarea{font-size:16px}.filters,.form-grid,.loan-form,.cards-grid,.summary-grid{grid-template-columns:1fr}.book-cover{min-height:140px}.book-card h3{font-size:1rem}.book-card .muted{font-size:.9rem}.actions{gap:.6rem}.actions .btn{flex:1 1 100%}.actions>:not(.btn){width:100%;min-width:0}.inline-actions{flex-direction:column}.inline-actions .btn{width:100%}.inline-field{flex-direction:column;align-items:stretch}.copy-barcode-row{flex-direction:column;align-items:flex-start}.copy-barcode-row .btn{width:100%}.table-wrap{overflow:visible;border:none;background:transparent}.table-wrap table,.table-wrap thead,.table-wrap tbody,.table-wrap tr,.table-wrap th,.table-wrap td{display:block;width:100%}.table-wrap thead{display:none}.table-wrap tr{border:1px solid var(--border);background:var(--surface);border-radius:10px;padding:.45rem .65rem;margin-bottom:.65rem}.table-wrap td{border-bottom:1px solid #eef1f5;padding:.55rem 0;white-space:normal;overflow-wrap:anywhere}.table-wrap td .btn{width:100%}.table-wrap td .badge{max-width:100%;white-space:normal}.table-wrap td:last-child{border-bottom:none}.table-wrap td:before{content:attr(data-label);display:block;margin-bottom:.2rem;color:var(--muted);font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.table-wrap td:empty:before{content:"";margin:0}.table-wrap td:empty{display:none}.toast-container{left:.75rem;right:.75rem;bottom:.75rem}.toast{max-width:none}.pagination{margin-top:1rem;gap:.65rem}.pagination .btn{flex:1 1 100%}.pagination .page-info{width:100%;text-align:center}}@media (max-width: 560px){.page-header{margin-bottom:.75rem}.page-header .muted{display:none}.auth-page{padding:.7rem}.auth-card{border-radius:12px;padding:1rem}.card{border-radius:10px;padding:var(--space-1)}.table-wrap tr{padding:.5rem .6rem}}
