.sidenav[data-v-d285dda1]{width:var(--sidebar-width);background:var(--surface);border-right:1px solid var(--border);z-index:100;flex-direction:column;display:none;position:fixed;top:0;bottom:0;left:0}.sidenav-header[data-v-d285dda1]{padding:var(--space-5);border-bottom:1px solid var(--border)}.wordmark[data-v-d285dda1]{font-family:var(--font-display);font-size:var(--text-lg);color:var(--text-primary)}.sidenav-links[data-v-d285dda1]{padding:var(--space-4) 0;flex:1}.nav-link[data-v-d285dda1]{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);color:var(--text-secondary);font-size:var(--text-base);transition:color var(--transition-fast), background var(--transition-fast);text-decoration:none;display:flex}.nav-link[data-v-d285dda1]:hover{color:var(--text-primary);background:var(--accent-muted);text-decoration:none}.nav-link.active[data-v-d285dda1]{color:var(--accent);font-weight:var(--weight-medium)}.sidenav-footer[data-v-d285dda1]{padding:var(--space-4) var(--space-5);border-top:1px solid var(--border)}.user-info[data-v-d285dda1]{margin-bottom:var(--space-3)}.username-link[data-v-d285dda1]{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary);transition:color var(--transition-fast);text-decoration:none;display:flex}.username-link[data-v-d285dda1]:hover{color:var(--accent);text-decoration:none}.logout-btn[data-v-d285dda1]{align-items:center;gap:var(--space-2);color:var(--text-secondary);font-size:var(--text-sm);padding:var(--space-2) 0;transition:color var(--transition-fast);display:flex}.logout-btn[data-v-d285dda1]:hover{color:var(--danger)}@media (width>=768px){.sidenav[data-v-d285dda1]{display:flex}}.navbar[data-v-1fd87465]{height:calc(var(--nav-height) + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);padding-left:env(safe-area-inset-left,0px);padding-right:env(safe-area-inset-right,0px);background:var(--surface);border-top:1px solid var(--border);z-index:100;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-item[data-v-1fd87465]{color:var(--text-secondary);padding:var(--space-2);transition:color var(--transition-fast);flex-direction:column;align-items:center;gap:2px;text-decoration:none;display:flex}.nav-item.active[data-v-1fd87465]{color:var(--accent)}.nav-label[data-v-1fd87465]{font-size:var(--text-xs);letter-spacing:.04em}@media (width>=768px){.navbar[data-v-1fd87465]{display:none}}.toast[data-v-7ef44270]{bottom:calc(var(--nav-height) + var(--space-4));background:var(--text-primary);color:var(--surface);padding:var(--space-3) var(--space-5);border-radius:var(--radius-pill);font-size:var(--text-sm);box-shadow:var(--shadow-elevated);z-index:200;text-align:center;max-width:90vw;position:fixed;left:50%;transform:translate(-50%)}.toast.error[data-v-7ef44270]{background:var(--danger)}@media (width>=768px){.toast[data-v-7ef44270]{bottom:var(--space-6)}}.toast-enter-active[data-v-7ef44270],.toast-leave-active[data-v-7ef44270]{transition:opacity var(--transition-normal), transform var(--transition-normal)}.toast-enter-from[data-v-7ef44270],.toast-leave-to[data-v-7ef44270]{opacity:0;transform:translate(-50%)translateY(8px)}.modal-overlay[data-v-414acdb9]{z-index:300;background:#0006;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}@media (width>=768px){.modal-overlay[data-v-414acdb9]{align-items:center}}.modal-content[data-v-414acdb9]{background:var(--surface);border-radius:var(--radius-card) var(--radius-card) 0 0;width:100%;max-width:480px;max-height:90vh;position:relative;overflow-y:auto}@media (width>=768px){.modal-content[data-v-414acdb9]{border-radius:var(--radius-card);max-height:80vh}}.modal-header[data-v-414acdb9]{padding:var(--space-5);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.modal-title[data-v-414acdb9]{font-size:var(--text-lg);font-weight:var(--weight-semibold)}.close-btn[data-v-414acdb9]{font-size:var(--text-lg);color:var(--text-secondary)}.tabs[data-v-414acdb9]{border-bottom:1px solid var(--border);display:flex}.tab-btn[data-v-414acdb9]{padding:var(--space-3);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-secondary);transition:color var(--transition-fast), border-color var(--transition-fast);border-bottom:2px solid #0000;flex:1}.tab-btn.active[data-v-414acdb9]{color:var(--accent);border-bottom-color:var(--accent)}.tab-content[data-v-414acdb9]{padding:var(--space-5)}.search-input[data-v-414acdb9]{width:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--border);border-radius:var(--radius-btn);font-size:var(--text-base);background:var(--bg);margin-bottom:var(--space-4)}.search-input[data-v-414acdb9]:focus{border-color:var(--accent);outline:none}.search-status[data-v-414acdb9]{color:var(--text-secondary);font-size:var(--text-sm);text-align:center;padding:var(--space-5)}.search-results[data-v-414acdb9]{gap:var(--space-2);flex-direction:column;max-height:40vh;display:flex;overflow-y:auto}.result-item[data-v-414acdb9]{gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-btn);cursor:pointer;transition:background var(--transition-fast);display:flex}.result-item[data-v-414acdb9]:hover{background:var(--accent-muted)}.result-cover[data-v-414acdb9]{border-radius:2px;flex-shrink:0;width:40px;height:60px;overflow:hidden}.result-cover img[data-v-414acdb9]{object-fit:cover;width:100%;height:100%}.cover-mini-placeholder[data-v-414acdb9]{background:var(--accent-muted);width:100%;height:100%;font-size:var(--text-sm);color:var(--accent);justify-content:center;align-items:center;display:flex}.result-info[data-v-414acdb9]{min-width:0}.result-title[data-v-414acdb9]{font-size:var(--text-sm);font-weight:var(--weight-medium);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.result-author[data-v-414acdb9],.result-year[data-v-414acdb9]{font-size:var(--text-xs);color:var(--text-secondary)}.manual-form[data-v-414acdb9]{gap:var(--space-4);flex-direction:column;display:flex}.isbn-row[data-v-414acdb9]{gap:var(--space-2);display:flex}.isbn-row .field-input[data-v-414acdb9]{flex:1}.fetch-btn[data-v-414acdb9]{padding:var(--space-2) var(--space-3);background:var(--accent-muted);color:var(--accent);border-radius:var(--radius-btn);font-size:var(--text-sm);font-weight:var(--weight-medium);white-space:nowrap}.fetch-btn[data-v-414acdb9]:disabled{opacity:.5;cursor:not-allowed}.fetch-error[data-v-414acdb9]{font-size:var(--text-xs);color:var(--danger)}.field[data-v-414acdb9]{gap:var(--space-1);flex-direction:column;display:flex}.field-row[data-v-414acdb9]{gap:var(--space-4);display:flex}.field-row .field[data-v-414acdb9]{flex:1}.field-label[data-v-414acdb9]{font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.field-input[data-v-414acdb9]{padding:var(--space-3) var(--space-4);border:1px solid var(--border);border-radius:var(--radius-btn);font-size:var(--text-base);background:var(--bg)}.field-input[data-v-414acdb9]:focus{border-color:var(--accent);outline:none}.add-btn[data-v-414acdb9]{padding:var(--space-3) var(--space-5);background:var(--accent);color:#fff;border-radius:var(--radius-btn);font-weight:var(--weight-medium);transition:opacity var(--transition-fast)}.add-btn[data-v-414acdb9]:disabled{opacity:.6;cursor:not-allowed}.cancel-btn[data-v-414acdb9]{padding:var(--space-3) var(--space-5);border:1px solid var(--border);border-radius:var(--radius-btn);color:var(--text-secondary)}.confirm-overlay[data-v-414acdb9]{padding:var(--space-5);background:#fffffff2;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.confirm-card[data-v-414acdb9]{text-align:center;gap:var(--space-4);flex-direction:column;align-items:center;display:flex}.confirm-title[data-v-414acdb9]{font-size:var(--text-md);font-weight:var(--weight-medium)}.confirm-author[data-v-414acdb9]{color:var(--text-secondary);font-size:var(--text-sm)}.confirm-actions[data-v-414acdb9]{gap:var(--space-3);display:flex}.update-banner[data-v-749ba87e]{bottom:calc(var(--nav-height) + env(safe-area-inset-bottom,0px) + var(--space-3));left:var(--space-4);right:var(--space-4);background:var(--text-primary);color:var(--surface);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);align-items:center;gap:var(--space-3);box-shadow:var(--shadow-elevated);z-index:1000;font-size:var(--text-sm);display:flex;position:fixed}@media (width>=768px){.update-banner[data-v-749ba87e]{left:auto;right:var(--space-6);bottom:var(--space-6);max-width:360px}}.update-banner span[data-v-749ba87e]{flex:1}.update-btn[data-v-749ba87e]{background:var(--accent);color:#fff;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);cursor:pointer;white-space:nowrap;border:none;font-weight:500}.dismiss-btn[data-v-749ba87e]{color:var(--surface);opacity:.6;cursor:pointer;padding:var(--space-1);background:0 0;border:none;font-size:1rem;line-height:1}.dismiss-btn[data-v-749ba87e]:hover{opacity:1}.slide-up-enter-active[data-v-749ba87e],.slide-up-leave-active[data-v-749ba87e]{transition:transform .3s,opacity .3s}.slide-up-enter-from[data-v-749ba87e],.slide-up-leave-to[data-v-749ba87e]{opacity:0;transform:translateY(100%)}.app-layout[data-v-affee5a1]{min-height:100vh;padding-top:env(safe-area-inset-top,0px)}.app-layout.has-nav .main-content[data-v-affee5a1]{padding-bottom:calc(var(--nav-height) + env(safe-area-inset-bottom,0px))}@media (width>=768px){.app-layout.has-nav .main-content[data-v-affee5a1]{margin-left:var(--sidebar-width);padding-bottom:0}}.fab[data-v-affee5a1]{bottom:calc(var(--nav-height) + env(safe-area-inset-bottom,0px) + var(--space-5));right:var(--space-5);background:var(--accent);color:#fff;width:56px;height:56px;box-shadow:var(--shadow-elevated);transition:transform var(--transition-fast), box-shadow var(--transition-fast);z-index:50;border-radius:50%;justify-content:center;align-items:center;display:flex;position:fixed}.fab[data-v-affee5a1]:hover{transform:scale(1.05)}@media (width>=768px){.fab[data-v-affee5a1]{bottom:var(--space-6);right:var(--space-6)}}:root{--bg:#fafaf8;--surface:#fff;--border:#e8e6e1;--text-primary:#1a1a18;--text-secondary:#6b6860;--accent:#2d5a3d;--accent-muted:#eaf0ec;--danger:#c0392b;--text-xs:11px;--text-sm:13px;--text-base:15px;--text-md:17px;--text-lg:22px;--text-xl:32px;--font-display:"DM Serif Display", serif;--font-body:"Inter", sans-serif;--font-mono:"JetBrains Mono", monospace;--weight-regular:400;--weight-medium:500;--weight-semibold:600;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:24px;--space-6:32px;--space-7:48px;--space-8:64px;--radius-card:8px;--radius-btn:6px;--radius-cover:4px;--radius-pill:999px;--shadow-card:0 1px 3px #0000000a;--shadow-elevated:0 4px 12px #00000014;--transition-fast:.15s ease;--transition-normal:.25s ease;--sidebar-width:220px;--nav-height:56px;--breakpoint-desktop:768px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent;-webkit-text-size-adjust:100%;width:100%;overflow-x:hidden}body{font-family:var(--font-body);font-size:var(--text-base);font-weight:var(--weight-regular);color:var(--text-primary);background-color:var(--bg);-webkit-overflow-scrolling:touch;width:100%;min-height:100vh;line-height:1.5;overflow-x:hidden}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;font-size:inherit;cursor:pointer;background:0 0;border:none}input,textarea,select{appearance:none;border-radius:0;font-family:inherit;font-size:16px}img{max-width:100%;display:block}ul,ol{list-style:none}
