:root{--bg:#f5f6fa;--bg-card:#fff;--border:#e1e4ea;--text:#1f2933;--muted:#6b7280;--primary:#2563eb;--primary-hover:#1d4ed8;--danger:#dc2626;--radius-lg:12px}*,:before,:after{box-sizing:border-box}body{background:var(--bg);color:var(--text);margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.app-root{flex-direction:column;min-height:100vh;display:flex}.app-main{width:100%;max-width:1000px;margin:1.5rem auto;padding:0 1rem 2rem}.page{background:var(--bg-card);border-radius:var(--radius-lg);padding:1.75rem 1.75rem 2rem;box-shadow:0 10px 25px #0f172a0f}.page-auth{max-width:420px;margin:3rem auto}.page h1{margin-top:0;margin-bottom:.5rem}.page-subtitle{color:var(--muted);margin-top:0;margin-bottom:1.5rem}.navbar{background:var(--bg-card);border-bottom:1px solid var(--border);z-index:10;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;display:flex;position:sticky;top:0}.navbar-brand{color:var(--text);letter-spacing:.03em;font-weight:700;text-decoration:none}.navbar-links{gap:1rem;display:flex}.nav-link{color:var(--muted);font-size:.95rem;text-decoration:none}.nav-link.active{color:var(--primary);font-weight:600}.navbar-auth .btn{font-size:.9rem}.new-book-toast{z-index:100;background:linear-gradient(135deg, #1e3a5f 0%, var(--primary) 100%);color:#fff;padding:.65rem 1rem;position:fixed;top:0;left:0;right:0;box-shadow:0 4px 20px #0f172a33}.new-book-toast-inner{flex-wrap:wrap;align-items:center;gap:.75rem;max-width:1000px;margin:0 auto;display:flex}.new-book-toast-label{text-transform:uppercase;letter-spacing:.06em;opacity:.9;font-size:.8rem;font-weight:600}.new-book-toast-link{color:#fff;text-underline-offset:2px;flex:1;min-width:0;font-weight:600;text-decoration:underline}.new-book-toast-link:hover{color:#e0e7ff}.new-book-toast-dismiss{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:6px;width:2rem;height:2rem;margin-left:auto;font-size:1.25rem;line-height:1}.new-book-toast-dismiss:hover{background:#ffffff59}.form{flex-direction:column;gap:1rem;display:flex}.form-group{flex-direction:column;gap:.35rem;display:flex}.form-group label{font-size:.9rem;font-weight:600}input,textarea{border:1px solid var(--border);border-radius:8px;padding:.6rem .7rem;font-family:inherit;font-size:.95rem}input:focus,textarea:focus{outline:2px solid var(--primary);outline-offset:1px}.btn{cursor:pointer;border:none;border-radius:999px;justify-content:center;align-items:center;padding:.55rem 1.2rem;font-size:.95rem;font-weight:600;text-decoration:none;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-secondary{color:#111827;background:#e5e7eb}.btn-secondary:hover{background:#d1d5db}.btn:disabled{opacity:.7;cursor:default}.alert{border-radius:10px;padding:.75rem .9rem;font-size:.9rem}.alert-error{color:#991b1b;background:#fee2e2}.alert-ok{color:#166534;background:#dcfce7}.search-bar{gap:.5rem;margin-bottom:1.25rem;display:flex}.search-bar input[type=search]{flex:1}.book-list{flex-direction:column;gap:.9rem;display:flex}.book-card{border:1px solid var(--border);background:#fff;border-radius:10px;padding:.9rem 1rem}.book-title{margin:0 0 .2rem;font-size:1.05rem}.book-author,.book-format,.book-filename,.book-publisher{color:var(--muted);margin:.1rem 0 .4rem;font-size:.9rem}.book-description{margin:0 0 .6rem;font-size:.9rem}.book-actions{justify-content:flex-end;display:flex}.book-description-long{line-height:1.6}.muted{color:var(--muted);font-size:.85rem}.back-link{color:var(--primary);margin-bottom:.75rem;font-size:.9rem;text-decoration:none;display:inline-block}.back-link:hover{text-decoration:underline}.book-preview{border-top:1px dashed var(--border);margin-top:1.5rem;padding-top:.75rem;font-size:.95rem}.page-dashboard .page-subtitle{margin-bottom:1.75rem}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.stat-card{border:1px solid var(--border);background:#fff;border-radius:10px;padding:1rem 1.1rem}.stat-label{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.35rem;font-size:.85rem;font-weight:600}.stat-value{color:var(--text);font-size:1.85rem;font-weight:700;line-height:1.2}.stat-hint{color:var(--muted);margin:.6rem 0 0;font-size:.8rem;line-height:1.4}.dashboard-section-title{margin:1.75rem 0 .75rem;font-size:1.1rem}.format-badges{flex-wrap:wrap;gap:.6rem;display:flex}.format-badge{color:#312e81;background:#eef2ff;border-radius:999px;align-items:center;gap:.35rem;padding:.45rem .75rem;font-size:.9rem;display:inline-flex}.format-badge strong{font-weight:700}.table-wrap{border:1px solid var(--border);background:#fff;border-radius:10px;overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:.92rem}.data-table th,.data-table td{text-align:left;border-bottom:1px solid var(--border);padding:.65rem .85rem}.data-table th{color:var(--muted);text-transform:uppercase;letter-spacing:.03em;font-size:.82rem;font-weight:600}.data-table tbody tr:last-child td{border-bottom:none}.cell-actions{text-align:right;width:5rem}.table-link{color:var(--primary);font-size:.9rem;font-weight:600;text-decoration:none}.table-link:hover{text-decoration:underline}@media (width<=640px){.navbar{flex-wrap:wrap;gap:.5rem}.navbar-links{justify-content:center;width:100%}.search-bar{flex-direction:column}.page{padding:1.25rem}}
