@import"https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&family=Inter:wght@400;500;600;700&family=Italianno&family=JetBrains+Mono:wght@400;500&display=swap";*,*:before,*:after{box-sizing:border-box}:root{--wheat-50: #FAF4E5;--wheat-100: #F5EBD4;--wheat-200: #EDE0C4;--wheat-300: #DFCDA5;--wheat-400: #CDB683;--wheat-500: #B89B62;--ink-900: #2C1A0E;--ink-800: #3D2818;--ink-700: #5A4030;--ink-600: #7C604E;--ink-500: #9B826E;--ink-400: #B7A28F;--honey-50: #FBF1DC;--honey-100: #F5E0B0;--honey-200: #ECC97D;--honey-300: #DBAE52;--honey-500: #C8913A;--honey-600: #A67623;--honey-700: #855B17;--honey-900: #4F3608;--walnut-50: #F4ECE3;--walnut-100: #E5D2BE;--walnut-200: #CFB196;--walnut-300: #B68F6E;--walnut-400: #9B7252;--walnut-500: #7F5A3D;--walnut-600: #6F5037;--walnut-700: #523822;--walnut-900: #2E1F12;--parchment-50: #FBF7F0;--parchment-100: #F7F2EA;--parchment-200: #F5EFE5;--parchment-300: #ECE3D2;--moss-100: #DDE5D2;--moss-500: #5C7048;--moss-700: #3F4E31;--rose-100: #F2D7D2;--rose-500: #B0463A;--rose-700: #7A2F26;--bg-canvas: var(--wheat-200);--bg-surface: #FFFFFF;--bg-sunken: var(--wheat-100);--fg-1: var(--ink-900);--fg-2: var(--ink-700);--fg-3: var(--ink-600);--fg-4: var(--ink-500);--border-subtle: rgba(44, 26, 14, .08);--border-default: rgba(44, 26, 14, .14);--border-strong: rgba(44, 26, 14, .22);--link: var(--walnut-700);--link-hover: var(--walnut-900);--accent: var(--walnut-500);--success: var(--moss-500);--success-bg: var(--moss-100);--danger: var(--rose-500);--danger-bg: var(--rose-100);--font-display: "Fraunces", Georgia, "Times New Roman", serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--radius-xs: 6px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-pill: 999px;--shadow-xs: 0 1px 2px rgba(44, 26, 14, .05);--shadow-sm: 0 2px 6px rgba(44, 26, 14, .06), 0 1px 2px rgba(44, 26, 14, .04);--shadow-md: 0 6px 14px rgba(44, 26, 14, .09), 0 2px 4px rgba(44, 26, 14, .04);--shadow-lg: 0 14px 28px rgba(44, 26, 14, .11), 0 4px 8px rgba(44, 26, 14, .05);--shadow-xl: 0 24px 48px rgba(44, 26, 14, .14);--shadow-drag: 0 8px 22px rgba(44, 26, 14, .18);--ease-out: cubic-bezier(.22, 1, .36, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1);--dur-fast: .14s;--dur-normal: .22s;--dur-slow: .38s;--focus-ring: 0 0 0 3px rgba(127, 90, 61, .25)}body{font-family:var(--font-body);background:var(--bg-canvas);color:var(--ink-900);margin:0;padding:0;min-height:100vh;-webkit-font-smoothing:antialiased}#root{min-height:100vh;display:flex;flex-direction:column}.app-nav{background:transparent;border-bottom:1px solid var(--border-subtle);padding:14px 32px;display:flex;align-items:center;gap:24px;flex-shrink:0}.nav-brand{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}.nav-brand-wordmark{font-family:var(--font-display);font-weight:600;font-size:1.2rem;color:var(--ink-900);letter-spacing:-.012em}.nav-links{display:flex;gap:4px;margin-left:12px}.nav-link{background:transparent;border:none;cursor:pointer;padding:8px 12px;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.875rem;font-weight:500;color:var(--fg-2);text-decoration:none;transition:color var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out)}.nav-link:hover{color:var(--ink-900);background:var(--wheat-100)}.nav-link.active{color:var(--ink-900);font-weight:600}.nav-spacer{flex:1}.nav-user{display:inline-flex;align-items:center;gap:8px;padding:6px 12px 6px 6px;border-radius:var(--radius-pill);background:#fff;border:1px solid var(--border-subtle);text-decoration:none;color:var(--ink-800);font-weight:500;font-size:.875rem;transition:background var(--dur-fast) var(--ease-out)}.nav-user:hover{background:var(--wheat-50)}.nav-avatar{width:28px;height:28px;border-radius:50%;background:var(--walnut-500);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.75rem;flex-shrink:0}.nav-user-menu{position:relative}.nav-user-menu .nav-user{cursor:pointer;border:1px solid var(--border-subtle)}.nav-user-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:140px;background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);box-shadow:0 4px 12px #00000014;display:flex;flex-direction:column;z-index:100;overflow:hidden}.nav-user-dropdown-item{display:block;width:100%;padding:10px 16px;background:transparent;border:none;text-align:left;font-family:var(--font-body);font-size:.875rem;font-weight:500;color:var(--ink-800);text-decoration:none;cursor:pointer;transition:background var(--dur-fast) var(--ease-out)}.nav-user-dropdown-item:hover{background:var(--wheat-100)}.nav-user-dropdown-role{display:block;width:100%;padding:10px 16px;background:transparent;border:none;text-align:left;font-family:var(--font-body);font-size:.875rem;font-weight:500;color:var(--ink-800);text-transform:capitalize;border-bottom:1px solid var(--border-subtle)}.nav-user-dropdown-role--interactive{cursor:pointer;transition:background var(--dur-fast) var(--ease-out)}.nav-user-dropdown-role--interactive:hover{background:var(--wheat-100)}.bottom-tab-bar{display:none}.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;text-decoration:none;color:var(--fg-3);font-size:.6875rem;font-weight:500;padding:8px 4px;border:none;background:transparent;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:color var(--dur-fast) var(--ease-out)}.tab-item.active{color:var(--walnut-600)}@media(max-width:768px){.app-nav{padding:10px 16px;gap:12px}.app-nav .nav-links{display:none}.bottom-tab-bar{display:flex;position:fixed;bottom:0;left:0;right:0;height:calc(56px + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);background:#fff;border-top:1px solid var(--border-subtle);z-index:200}.page{padding-bottom:calc(56px + env(safe-area-inset-bottom) + 1.5rem)}}.page-loading{flex:1;display:flex;align-items:center;justify-content:center;min-height:200px}.login-page{flex:1;display:flex;justify-content:center;align-items:center;padding:2rem 1rem}.login-card{background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:2rem;width:100%;max-width:400px;box-shadow:var(--shadow-sm)}.login-card-header{text-align:center;margin-bottom:1.5rem}.login-card .app-name{font-family:var(--font-display);font-size:1.75rem;font-weight:600;letter-spacing:-.015em;color:var(--ink-900);margin:0 0 .15rem}.login-card .page-title{font-size:.9rem;font-weight:400;color:var(--ink-600);margin:0 0 1.5rem}.form-field{display:flex;flex-direction:column;gap:.3rem;margin-bottom:1rem}.form-field label{font-size:.8125rem;font-weight:600;color:var(--ink-800)}.field-optional{font-weight:400;color:var(--ink-500);font-size:.75rem}.form-field input,.form-field select{padding:.55rem .75rem;border:1.5px solid var(--border-default);border-radius:var(--radius-md);font-size:.9375rem;font-family:var(--font-body);width:100%;background:#fff;color:var(--ink-900);transition:border-color var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out)}.form-field select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236B5744' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .6rem center;padding-right:2rem;cursor:pointer}.form-field input:focus,.form-field select:focus{outline:none;border-color:var(--walnut-500);box-shadow:var(--focus-ring)}.form-field input::placeholder{color:var(--ink-400)}.input-readonly{background:var(--wheat-100)!important;color:var(--ink-600)!important;cursor:default}.btn-primary{width:100%;padding:.65rem;background:var(--ink-900);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.9375rem;font-family:var(--font-body);font-weight:600;cursor:pointer;margin-top:.25rem;transition:background var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out)}.btn-primary:hover{background:var(--ink-800);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn-primary:active{transform:translateY(0);box-shadow:none}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.login-footer{margin:1.25rem 0 0;font-size:.875rem;color:var(--ink-600);text-align:center}.login-footer a{color:var(--link);text-decoration:underline;text-underline-offset:3px}.login-footer a:hover{color:var(--link-hover)}.login-page-footer{display:flex;justify-content:center;flex-wrap:wrap;gap:.25rem 1.5rem;padding:1rem 1.5rem 1.5rem;border-top:1px solid var(--border-subtle)}.error-msg{font-size:.875rem;color:var(--rose-500);background:var(--rose-100);border:1px solid rgba(176,70,58,.2);border-radius:var(--radius-sm);padding:.5rem .75rem;margin:0 0 1rem}.pw-checklist{display:flex;flex-direction:column;gap:5px;padding:.6rem .75rem;margin:-.25rem 0 1rem;background:var(--surface-2, #f9f6f0);border:1px solid var(--border, rgba(0,0,0,.1));border-radius:var(--radius-sm);font-size:.8125rem}.pw-checklist-item{display:flex;align-items:center;gap:.4rem}.pw-checklist-item.met{color:var(--moss-600, #4a7040)}.pw-checklist-item.unmet{color:var(--rose-500, #b0463a)}.pw-checklist-icon{font-size:.75rem;width:1em;text-align:center;flex-shrink:0}.pw-checklist-hibp{margin-top:.25rem;padding-top:.35rem;border-top:1px solid rgba(176,70,58,.2);color:var(--rose-500, #b0463a);font-weight:500}.field-error{display:block;margin-top:.3rem;font-size:.8125rem;color:var(--rose-500, #b0463a)}.page{flex:1;max-width:760px;margin:0 auto;padding:2rem 1.5rem;width:100%}.page-eyebrow{font-size:.6875rem;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--ink-500);margin:0 0 4px}.page h1{font-family:var(--font-display);font-size:1.875rem;font-weight:600;letter-spacing:-.015em;color:var(--ink-900);margin:0 0 1.25rem}.page-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:1.25rem;gap:1rem;flex-wrap:wrap}.page-header h1{margin:0}.page-header>.btn-add{margin-bottom:2px}.btn-add{padding:.5rem 1rem;background:var(--ink-900);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font-body);font-weight:600;cursor:pointer;white-space:nowrap;display:inline-flex;align-items:center;gap:6px;flex-shrink:0;transition:background var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out)}.btn-add:hover{background:var(--ink-800);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn-add:active{transform:translateY(0);box-shadow:none}.book-cover-img{width:36px;height:52px;object-fit:cover;border-radius:1px 3px 3px 1px;display:block;box-shadow:var(--shadow-xs)}.book-details-meta{margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border-subtle);display:grid;grid-template-columns:auto 1fr;gap:.2rem .75rem;font-size:.8rem}.meta-field{display:contents}.meta-label{color:var(--fg-3);white-space:nowrap;font-weight:600}.book-details-refresh{margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border-subtle)}.btn-refresh-meta{font-size:.75rem;color:var(--fg-3);background:transparent;border:1px solid var(--border-default);border-radius:var(--radius-xs);padding:.2rem .6rem;cursor:pointer;font-family:var(--font-body);transition:color var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out)}.btn-refresh-meta:hover{color:var(--ink-700);border-color:var(--border-strong)}.book-find-meta{margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border-subtle)}.book-find-meta-bar{display:flex;gap:.4rem}.book-find-meta-input{flex:1;font-size:.8125rem;font-family:var(--font-body);padding:.3rem .5rem;border:1.5px solid var(--border-default);border-radius:var(--radius-xs);background:#fff;color:var(--ink-900);min-width:0;transition:border-color var(--dur-fast) var(--ease-out)}.book-find-meta-input:focus{outline:none;border-color:var(--walnut-500)}.btn-find-meta{font-size:.8125rem;font-family:var(--font-body);padding:.3rem .75rem;background:var(--ink-900);color:var(--wheat-50);border:none;border-radius:var(--radius-xs);cursor:pointer;white-space:nowrap;transition:background var(--dur-fast) var(--ease-out)}.btn-find-meta:hover:not(:disabled){background:var(--ink-800)}.btn-find-meta:disabled{opacity:.5;cursor:not-allowed}.find-meta-status{font-size:.8rem;color:var(--fg-3);margin:.375rem 0 0;font-style:italic}.find-meta-error{font-size:.8rem;color:var(--danger);margin:.375rem 0 0}.find-meta-results{margin-top:.375rem}.find-meta-result{display:flex;align-items:center;gap:.5rem;padding:.35rem 0;border-bottom:1px solid var(--border-subtle)}.find-meta-result:last-child{border-bottom:none}.find-meta-result-info{flex:1;min-width:0}.find-meta-result-title{font-size:.8125rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.find-meta-result-author{font-size:.75rem;color:var(--fg-3)}.btn-link-meta{font-size:.75rem;font-family:var(--font-body);padding:.2rem .6rem;background:var(--ink-900);color:var(--wheat-50);border:none;border-radius:var(--radius-xs);cursor:pointer;white-space:nowrap;flex:0 0 auto;transition:background var(--dur-fast) var(--ease-out)}.btn-link-meta:hover:not(:disabled){background:var(--ink-800)}.btn-link-meta:disabled{opacity:.5;cursor:not-allowed}.book-search{margin-bottom:1.25rem}.book-search-bar{display:flex;gap:.5rem;align-items:center}.book-search-input-wrap{position:relative;flex:1}.book-search-icon{position:absolute;left:.65rem;top:50%;transform:translateY(-50%);color:var(--fg-4);display:flex;pointer-events:none}.book-search-input{width:100%;padding:.55rem .75rem .55rem 2.1rem;border:1.5px solid var(--border-default);border-radius:var(--radius-md);font-size:.9375rem;font-family:var(--font-body);background:#fff;color:var(--ink-900);transition:border-color var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out)}.book-search-input:focus{outline:none;border-color:var(--walnut-500);box-shadow:var(--focus-ring)}.book-search-input::placeholder{color:var(--ink-400)}.btn-search{padding:.55rem 1.25rem;background:var(--ink-900);color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;font-family:var(--font-body);font-weight:600;cursor:pointer;white-space:nowrap;transition:background var(--dur-fast) var(--ease-out)}.btn-search:hover:not(:disabled){background:var(--ink-800)}.btn-search:disabled{opacity:.5;cursor:not-allowed}.btn-advanced-toggle{padding:.5rem .75rem;background:transparent;border:1.5px solid var(--border-default);border-radius:var(--radius-md);font-size:.8125rem;font-family:var(--font-body);font-weight:500;color:var(--fg-2);cursor:pointer;white-space:nowrap;transition:background var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out)}.btn-advanced-toggle:hover{background:var(--wheat-100);border-color:var(--border-strong)}.btn-advanced-toggle[aria-expanded=true]{background:var(--wheat-100);border-color:var(--walnut-500);color:var(--ink-900)}.book-search-advanced{margin-top:.625rem;padding:1rem;background:var(--wheat-50);border:1px solid var(--border-subtle);border-radius:var(--radius-md)}.advanced-fields{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.625rem;margin-bottom:.75rem}.advanced-field{display:flex;flex-direction:column;gap:.25rem}.advanced-field label{font-size:.75rem;font-weight:600;color:var(--ink-700)}.advanced-field input{padding:.4rem .6rem;border:1.5px solid var(--border-default);border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font-body);background:#fff;color:var(--ink-900)}.advanced-field input:focus{outline:none;border-color:var(--walnut-500);box-shadow:var(--focus-ring)}.btn-search-advanced{padding:.45rem 1rem;background:var(--walnut-600);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font-body);font-weight:600;cursor:pointer;transition:background var(--dur-fast) var(--ease-out)}.btn-search-advanced:hover:not(:disabled){background:var(--walnut-700)}.btn-search-advanced:disabled{opacity:.5;cursor:not-allowed}.book-search-loading{font-size:.875rem;color:var(--fg-3);font-style:italic;margin:.5rem 0}.book-search-hint,.book-search-empty{font-size:.875rem;color:var(--fg-3);margin:.5rem 0}.book-search-error{font-size:.875rem;color:var(--danger);background:var(--danger-bg);border:1px solid rgba(176,70,58,.2);border-radius:var(--radius-xs);padding:.4rem .75rem;margin:.5rem 0}.book-search-results{margin-top:.625rem;border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:#fff;overflow:hidden;box-shadow:var(--shadow-xs)}.search-result{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-bottom:1px solid var(--border-subtle)}.search-result:last-of-type{border-bottom:none}.search-result-cover{width:36px;height:52px;flex-shrink:0;border-radius:3px;overflow:hidden}.search-result-cover img{width:100%;height:100%;object-fit:cover;display:block}.search-cover-placeholder{width:100%;height:100%}.search-result-info{flex:1;min-width:0}.search-result-title{font-weight:600;font-size:.9375rem;color:var(--ink-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-result-meta{font-size:.8125rem;color:var(--fg-3);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-add-result{padding:.35rem .75rem;background:var(--ink-900);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.8125rem;font-family:var(--font-body);font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background var(--dur-fast) var(--ease-out)}.btn-add-result:hover:not(:disabled){background:var(--ink-800)}.btn-add-result:disabled{opacity:.5;cursor:not-allowed}.search-result-footer{padding:.6rem 1rem;border-top:1px solid var(--border-subtle);background:var(--wheat-50)}.btn-add-manually{background:none;border:none;font-size:.875rem;font-family:var(--font-body);color:var(--walnut-600);cursor:pointer;padding:0;font-weight:500;text-decoration:underline;text-underline-offset:3px}.btn-add-manually:hover{color:var(--walnut-700)}.add-book-form{background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1.25rem;box-shadow:var(--shadow-sm)}.add-book-form-fields{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:.75rem;margin-bottom:1rem}.add-book-form-fields .form-field:last-child{grid-column:1 / -1}@media(max-width:560px){.add-book-form-fields{grid-template-columns:1fr 1fr}.add-book-form-fields .form-field:last-child{grid-column:1 / -1}}@media(max-width:380px){.add-book-form-fields{grid-template-columns:1fr}}.add-book-form .form-field{margin-bottom:0}.add-book-form .form-field input{padding:.45rem .65rem;font-size:.9rem;border-radius:var(--radius-sm)}.add-book-form-actions{display:flex;justify-content:flex-end;gap:.5rem;padding-top:.25rem;border-top:1px solid var(--border-subtle)}.error-bar{font-size:.875rem;color:var(--rose-500);background:var(--rose-100);border:1px solid rgba(176,70,58,.2);border-radius:var(--radius-sm);padding:.5rem .75rem;margin:0 0 1rem}.books-empty{background:var(--wheat-100);border:1.5px dashed var(--border-default);border-radius:var(--radius-lg);padding:3rem 1.5rem;text-align:center}.books-empty h2{font-family:var(--font-display);font-size:1.5rem;font-weight:600;color:var(--ink-900);letter-spacing:-.012em;margin:0 0 .5rem}.books-empty p{font-size:.9375rem;color:var(--ink-600);margin:0}.books-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.book-item{display:flex;flex-direction:column;gap:0}.book-row{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:7px 14px;box-shadow:var(--shadow-xs);transition:background var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out);cursor:pointer;-webkit-user-select:none;user-select:none}.book-row:hover{box-shadow:var(--shadow-sm)}.drag-handle{cursor:grab;color:var(--ink-400);padding:0 2px;flex:0 0 auto;touch-action:none;-webkit-user-select:none;user-select:none;line-height:1;display:flex;align-items:center;transition:color var(--dur-fast) var(--ease-out)}.drag-handle:hover{color:var(--ink-700)}.drag-handle:active{cursor:grabbing}.drag-handle--locked{cursor:not-allowed;opacity:.28}.book-row--dragging{background:var(--parchment-200);box-shadow:var(--shadow-drag);border-radius:var(--radius-md)}.book-row--expanded{border-radius:var(--radius-md) var(--radius-md) 0 0}.book-position{font-family:var(--font-mono);font-size:.6875rem;color:var(--ink-400);min-width:18px;text-align:right;flex-shrink:0}.book{flex:0 0 36px;width:36px;height:52px;position:relative;perspective:360px;perspective-origin:70% 50%}.book-stage{position:relative;width:100%;height:100%;transform-style:preserve-3d}.book-pages{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:1px 3px 3px 1px;background:linear-gradient(90deg,#2c1a0e1a 0,#2c1a0e00 3px,#2c1a0e00),#f8efd7;box-shadow:inset -1px 0 #2c1a0e0f,inset 0 -1px #2c1a0e0d;overflow:hidden}.book-pages:before{content:"";position:absolute;left:6px;right:4px;top:9px;bottom:9px;background-image:repeating-linear-gradient(0deg,rgba(82,56,34,.22) 0 1px,transparent 1px 5px);opacity:.7}.book-pages:after{content:"";position:absolute;right:0;top:1px;bottom:1px;width:2px;background:repeating-linear-gradient(0deg,rgba(44,26,14,.12) 0 1px,transparent 1px 2px)}.book-cover-face{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:1px 3px 3px 1px;transform-origin:left center;transform:rotateY(0);transition:transform .56s cubic-bezier(.55,.02,.2,1),box-shadow .32s ease;box-shadow:var(--shadow-xs);will-change:transform}.book-cover-face:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(180deg,#ffffff2e 0,#0000002e)}.book-cover-face:after{content:"";position:absolute;left:5px;right:4px;top:12px;height:8px;background:#ffffff21;border-radius:1px;box-shadow:0 12px 0 -2px #ffffff1a}.book-row--expanded .book-cover-face{transform:rotateY(-155deg);box-shadow:-2px 1px 3px #2c1a0e1a}.book-info{flex:1;min-width:0}@media(prefers-reduced-motion:reduce){.book-cover-face{transition:opacity 1ms,box-shadow 1ms}.book-row--expanded .book-cover-face{transform:rotateY(0);opacity:0}}.book-title{font-family:var(--font-display);font-weight:600;font-size:.9375rem;color:var(--ink-900);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.2}.book-author{font-size:.8rem;color:var(--ink-500);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:2px}.book-date input[type=date]{padding:.25rem .4rem;border:1px solid var(--border-default);border-radius:var(--radius-xs);font-size:.8rem;font-family:var(--font-body);width:9rem;background:var(--wheat-50);color:var(--ink-900);transition:border-color var(--dur-fast) var(--ease-out)}.book-date input[type=date]:focus{outline:none;border-color:var(--walnut-500)}.book-lock-btn{background:transparent;border:none;cursor:pointer;width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--ink-400);flex-shrink:0;transition:color var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out);padding:0}.book-lock-btn:hover{background:var(--wheat-50);color:var(--ink-700)}.book-lock-btn--locked{color:var(--walnut-600)}.book-lock-btn--locked:hover{background:var(--walnut-50);color:var(--walnut-700)}.book-lock{display:flex;align-items:center;gap:.3rem;font-size:.78rem;color:var(--ink-600);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none}.book-actions{display:flex;gap:4px;flex:0 0 auto;align-items:center}.btn-icon{padding:.25rem .45rem;border:1px solid var(--border-subtle);border-radius:var(--radius-xs);background:var(--wheat-50);cursor:pointer;font-size:.85rem;line-height:1;transition:background var(--dur-fast) var(--ease-out)}.btn-icon:hover:not(:disabled){background:var(--wheat-100)}.btn-icon:disabled{opacity:.3;cursor:not-allowed}.btn-remove{background:transparent;border:none;cursor:pointer;width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--ink-500);opacity:.4;flex-shrink:0;transition:color var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out),opacity var(--dur-fast) var(--ease-out);padding:0}.book-row:hover .btn-remove{opacity:1}.btn-remove:hover{background:var(--rose-100);color:var(--rose-500);opacity:1}.book-notice{font-size:.75rem;color:var(--ink-500);font-style:italic;padding:4px 12px;margin:0}.date-removal-prompt{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--ink-600);padding:8px 14px;flex-wrap:wrap;background:var(--wheat-50);border:1px solid var(--border-subtle);border-top:none;border-radius:0 0 var(--radius-md) var(--radius-md)}.date-removal-prompt button{padding:.2rem .55rem;border:1px solid var(--border-default);border-radius:var(--radius-xs);background:#fff;cursor:pointer;font-size:.75rem;font-family:var(--font-body);color:var(--ink-800);transition:background var(--dur-fast) var(--ease-out)}.date-removal-prompt button:hover{background:var(--wheat-50)}.book-details{background:var(--wheat-50);border:1px solid var(--border-subtle);border-top:none;border-radius:0 0 var(--radius-md) var(--radius-md);padding:.65rem .9rem}.book-details-row{display:flex;align-items:center;gap:.6rem}.book-details-row label{font-size:.8rem;font-weight:600;color:var(--ink-600);white-space:nowrap;min-width:2.5rem}.book-details-row input[type=url]{flex:1;padding:.3rem .5rem;border:1.5px solid var(--border-default);border-radius:var(--radius-xs);font-size:.875rem;font-family:var(--font-body);background:#fff;color:var(--ink-900);min-width:0;transition:border-color var(--dur-fast) var(--ease-out)}.book-details-row input[type=url]:focus{outline:none;border-color:var(--walnut-500)}.book-details-date input[type=date]{padding:.25rem .4rem;border:1px solid var(--border-default);border-radius:var(--radius-xs);font-size:.8rem;font-family:var(--font-body);background:var(--wheat-50);color:var(--ink-900);transition:border-color var(--dur-fast) var(--ease-out)}.book-details-date input[type=date]:focus{outline:none;border-color:var(--walnut-500)}.btn-open-link{white-space:nowrap;font-size:.8rem;color:var(--walnut-600);text-decoration:none;border:1px solid var(--border-default);border-radius:var(--radius-xs);padding:.25rem .5rem;background:#fff;flex:0 0 auto;transition:background var(--dur-fast) var(--ease-out)}.btn-open-link:hover{background:var(--wheat-50)}.success-msg{font-size:.875rem;color:var(--moss-500);background:var(--moss-100);border:1px solid rgba(92,112,72,.25);border-radius:var(--radius-sm);padding:.5rem .75rem;margin:0 0 1rem}.oauth-divider{display:flex;align-items:center;gap:.75rem;margin:1.25rem 0;color:var(--ink-400);font-size:.6875rem;letter-spacing:.08em;text-transform:uppercase}.oauth-divider:before,.oauth-divider:after{content:"";flex:1;height:1px;background:var(--border-subtle)}.btn-oauth{display:flex;align-items:center;justify-content:center;gap:.65rem;width:100%;padding:.65rem 1rem;border:1.5px solid var(--border-default);border-radius:var(--radius-md);font-size:.9375rem;font-family:var(--font-body);font-weight:500;cursor:pointer;text-decoration:none;color:var(--ink-900);background:#fff;transition:background var(--dur-fast) var(--ease-out)}.btn-oauth:hover{background:var(--parchment-200)}.btn-oauth-facebook{background:#1877f2;color:#fff;border-color:#1877f2;margin-top:.5rem}.btn-oauth-facebook:hover{background:#166fe5}.btn-oauth-apple{background:#000;color:#fff;border-color:#000;margin-top:.5rem}.btn-oauth-apple:hover{background:#1a1a1a}.btn-oauth-microsoft{margin-top:.5rem}.btn-oauth-email{background:var(--wheat-50);border-color:var(--border-default)}.btn-oauth-email:hover{background:var(--wheat-100)}.btn-secondary{padding:.55rem 1.1rem;background:#fff;color:var(--ink-900);border:1.5px solid var(--border-default);border-radius:var(--radius-sm);font-size:.9rem;font-family:var(--font-body);font-weight:500;cursor:pointer;transition:background var(--dur-fast) var(--ease-out)}.btn-secondary:hover{background:var(--parchment-200)}.profile-section{background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;margin-bottom:1rem;max-width:520px;box-shadow:var(--shadow-xs)}.profile-section h2{font-family:var(--font-body);font-size:.9375rem;font-weight:600;margin:0 0 1rem;color:var(--ink-800)}.profile-detail{margin:.4rem 0;font-size:.9rem;color:var(--ink-700)}.admin-table-wrapper{background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:1.5rem;box-shadow:var(--shadow-xs)}.admin-table{width:100%;border-collapse:collapse}.admin-table th{text-align:left;padding:.7rem 1rem;font-size:.6875rem;font-weight:600;color:var(--ink-500);text-transform:uppercase;letter-spacing:.07em;background:var(--wheat-50);border-bottom:1px solid var(--border-subtle)}.admin-table td{padding:.75rem 1rem;font-size:.875rem;border-bottom:1px solid var(--border-subtle);color:var(--ink-700)}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table tbody tr:hover{background:var(--wheat-50)}.admin-table .btn-sm{padding:.2rem .55rem;border:1px solid var(--border-default);border-radius:var(--radius-xs);background:#fff;cursor:pointer;font-size:.8rem;font-family:var(--font-body);color:var(--ink-800);transition:background var(--dur-fast) var(--ease-out)}.admin-table .btn-sm:hover{background:var(--wheat-50)}.admin-table .btn-sm-danger{padding:.2rem .55rem;border:1px solid rgba(176,70,58,.25);border-radius:var(--radius-xs);background:var(--rose-100);color:var(--rose-500);cursor:pointer;font-size:.8rem;font-family:var(--font-body);transition:background var(--dur-fast) var(--ease-out)}.admin-table .btn-sm-danger:hover{background:#b0463a2e}.role-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-pill);font-size:.6875rem;font-weight:600;letter-spacing:.02em;text-transform:capitalize}.role-badge--admin{background:var(--ink-900);color:#fff}.role-badge--user{background:var(--wheat-100);color:var(--ink-700)}.admin-reset-panel{background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;max-width:420px;box-shadow:var(--shadow-xs)}.admin-reset-panel h2{font-size:.9375rem;font-weight:600;margin:0 0 1rem;color:var(--ink-800)}.admin-reset-panel .form-field{margin-bottom:1rem}.admin-reset-actions{display:flex;gap:.5rem;margin-top:.25rem}.mfa-badge{display:inline-block;padding:2px 9px;border-radius:var(--radius-pill);font-size:.75rem;font-weight:600;letter-spacing:.02em}.mfa-badge--on{background:var(--moss-100);color:var(--moss-500)}.mfa-badge--off{background:var(--wheat-100);color:var(--ink-600)}.mfa-description{margin-bottom:.75rem!important}.mfa-uri-link{display:inline-block;font-size:.875rem;color:var(--link);text-decoration:underline;margin-bottom:.75rem}.mfa-uri-link:hover{color:var(--link-hover)}.mfa-secret-label{margin-top:.75rem!important;margin-bottom:.25rem!important}.mfa-secret{display:block;font-family:var(--font-mono);font-size:.875rem;letter-spacing:.08em;background:var(--wheat-50);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:.5rem .75rem;word-break:break-all;color:var(--ink-800);-webkit-user-select:all;user-select:all}.mfa-secret-row{display:flex;align-items:stretch;gap:.5rem;margin:.25rem 0 .75rem}.mfa-secret-row .mfa-secret{flex:1;margin:0}.btn-copy{display:inline-flex;align-items:center;gap:.375rem;padding:0 .875rem;background:var(--walnut-500);color:#fffcf5;font-family:var(--font-body);font-size:.8125rem;font-weight:500;border:none;border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .15s var(--ease-out)}.btn-copy:hover{background:var(--walnut-700)}.btn-copy--copied{background:var(--moss-500)}.btn-copy--copied:hover{background:var(--moss-700)}.mfa-qr{display:flex;justify-content:center;padding:1rem 0 .75rem}.mfa-qr svg{padding:12px;background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-md)}.mfa-code-input{font-family:var(--font-mono)!important;letter-spacing:.15em;font-size:1.125rem!important}.mfa-action-row{display:flex;align-items:center;gap:.75rem;margin-top:.25rem;flex-wrap:wrap}.mfa-prompt{font-size:.875rem;color:var(--ink-600);margin:0 0 1.25rem}.backup-codes-grid{display:grid;grid-template-columns:1fr 1fr;gap:.3rem 1rem;list-style:none;padding:.75rem;margin:.5rem 0 1rem;background:var(--wheat-50);border:1px solid var(--border-subtle);border-radius:var(--radius-sm)}.backup-codes-grid li code{font-family:var(--font-mono);font-size:.875rem;letter-spacing:.06em;color:var(--ink-800)}.passkey-list{list-style:none;padding:0;margin:0 0 .75rem;display:flex;flex-direction:column;gap:6px}.passkey-item{display:flex;align-items:center;gap:.75rem;padding:.6rem 0;border-bottom:1px solid var(--border-subtle);font-size:.9rem}.passkey-item:last-child{border-bottom:none}.passkey-name{flex:1;color:var(--ink-800);font-weight:500}.passkey-date{font-size:.8rem;color:var(--fg-3)}.passkey-actions{display:flex;gap:.5rem}.passkey-rename{flex:1;display:flex;align-items:center;gap:.5rem}.passkey-rename input{flex:1;padding:.3rem .5rem;border:1.5px solid var(--walnut-500);border-radius:var(--radius-xs);font-size:.875rem;font-family:var(--font-body);background:#fff;color:var(--ink-900);box-shadow:var(--focus-ring)}.btn-link{background:none;border:none;padding:0;font-size:.875rem;color:var(--link);cursor:pointer;text-decoration:underline;font-family:var(--font-body)}.btn-link:hover{color:var(--link-hover)}.btn-link--danger{color:var(--rose-500)}.btn-link--danger:hover{color:var(--rose-700)}.btn-secondary--danger{color:var(--rose-500)!important;border-color:#b0463a4d!important}.btn-secondary--danger:hover{background:var(--rose-100)!important}.landing-root{width:100%;min-height:100vh;background:var(--bg-canvas);display:flex;flex-direction:column;position:relative;overflow:hidden}.landing-header{display:flex;align-items:center;gap:32px;padding:20px 56px;flex-shrink:0}@media(max-width:640px){.landing-header{padding:16px 20px;gap:16px}.landing-nav{display:none}}.landing-logo-link{display:flex;align-items:center;text-decoration:none;flex-shrink:0}.landing-nav{display:flex;gap:28px;margin-left:8px}.landing-nav-link{font-family:var(--font-body);font-size:.875rem;font-weight:500;color:var(--fg-2);text-decoration:none;padding:8px 4px;transition:color var(--dur-fast) var(--ease-out)}.landing-nav-link:hover{color:var(--ink-900);text-decoration:none}.landing-nav-spacer{flex:1}.landing-login-link{font-family:var(--font-body);font-size:.875rem;font-weight:500;color:var(--ink-800);text-decoration:none;white-space:nowrap;transition:color var(--dur-fast) var(--ease-out)}.landing-login-link:hover{color:var(--ink-900);text-decoration:none}.landing-create-btn{display:inline-block;background:var(--walnut-500);color:#fffcf5;font-family:var(--font-body);font-weight:600;font-size:.8125rem;padding:8px 16px;border-radius:var(--radius-sm);text-decoration:none;white-space:nowrap;transition:background .18s var(--ease-out),transform .18s var(--ease-out),box-shadow .18s var(--ease-out)}.landing-create-btn:hover{background:var(--walnut-700);transform:translateY(-1px);box-shadow:0 6px 14px #5238224d;text-decoration:none}.landing-main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 24px 100px;gap:28px}.landing-hero-text{display:flex;flex-direction:column;align-items:center;gap:18px}.landing-wordmark{font-family:var(--font-display);font-size:clamp(52px,8vw,92px);font-weight:600;color:var(--ink-900);letter-spacing:-.028em;line-height:.98;margin:0;font-variation-settings:"opsz" 144,"SOFT" 30}.landing-wordmark-accent{color:var(--walnut-700)}.landing-tagline{font-family:Italianno,Snell Roundhand,cursive;font-size:clamp(30px,4.5vw,48px);font-weight:400;color:var(--ink-800);letter-spacing:.005em;line-height:1.05;margin:0;-webkit-font-smoothing:antialiased}.landing-cta-btn{display:inline-block;background:var(--walnut-500);color:#fffcf5;font-family:var(--font-body);font-weight:600;font-size:.9375rem;padding:14px 30px;border-radius:10px;text-decoration:none;letter-spacing:.01em;box-shadow:0 6px 18px #5238223d,0 1px #3c281873 inset;transition:background .18s var(--ease-out),transform .18s var(--ease-out),box-shadow .18s var(--ease-out);margin-top:8px}.landing-cta-btn:hover{background:var(--walnut-700);transform:translateY(-1px);box-shadow:0 10px 24px #52382252,0 1px #3c28188c inset;text-decoration:none}.landing-cta-secondary{display:inline-block;background:transparent;color:var(--walnut-700);font-family:var(--font-body);font-weight:600;font-size:.9375rem;padding:14px 30px;border-radius:10px;border:2px solid var(--walnut-400);text-decoration:none;letter-spacing:.01em;transition:background .18s var(--ease-out),border-color .18s var(--ease-out),transform .18s var(--ease-out)}.landing-cta-secondary:hover{background:#5238220f;border-color:var(--walnut-600);transform:translateY(-1px);text-decoration:none}.landing-footer{position:absolute;bottom:28px;left:0;right:0;text-align:center;font-family:var(--font-body);font-size:.75rem;color:var(--fg-3);letter-spacing:.04em;pointer-events:none}.info-page{min-height:100vh;background:var(--bg-canvas);display:flex;flex-direction:column}.info-page-header{display:flex;align-items:center;gap:12px;padding:16px 32px;border-bottom:1px solid var(--border-subtle)}.info-page-brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--ink-900)}.info-page-brand-name{font-family:var(--font-display);font-weight:600;font-size:1.1rem;letter-spacing:-.012em}.info-page-main{flex:1;display:flex;justify-content:center;align-items:flex-start;padding:3rem 1.5rem 4rem}.info-page-card{width:100%;max-width:640px}.info-page-card h1{font-family:var(--font-display);font-size:2rem;font-weight:600;letter-spacing:-.018em;color:var(--ink-900);margin:0 0 1rem}.info-page-card p{font-size:.9375rem;line-height:1.6;color:var(--fg-2);margin:0 0 .75rem}.info-page-back{display:inline-block;margin-top:1.5rem;font-size:.875rem;color:var(--link);text-decoration:underline;text-underline-offset:3px}.info-page-back:hover{color:var(--link-hover)}.support-buttons{display:flex;margin:1.75rem 0 .25rem}.support-button-cell{flex:1;display:flex;justify-content:center}.btn-support{display:inline-flex;align-items:center;gap:6px;padding:10px 22px;background:var(--parchment-100);border:2px solid var(--walnut-300);border-radius:8px;color:var(--ink-800);font-family:var(--font-body);font-size:.9375rem;font-weight:500;text-decoration:none;transition:background .15s,border-color .15s,color .15s}.btn-support:hover{background:var(--parchment-200);border-color:var(--walnut-500);color:var(--ink-900)}.privacy-section{margin-top:2rem}.privacy-section h2{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--ink-900);letter-spacing:-.01em;margin:0 0 .6rem}.privacy-section p{font-size:.9375rem;line-height:1.65;color:var(--fg-2);margin:0 0 .65rem}.privacy-list{padding-left:1.25rem;margin:0 0 .65rem;display:flex;flex-direction:column;gap:.35rem}.privacy-list li{font-size:.9375rem;line-height:1.6;color:var(--fg-2)}.privacy-section code{font-family:var(--font-mono);font-size:.85em;background:var(--wheat-100);padding:2px 6px;border-radius:var(--radius-xs);color:var(--ink-800)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#2c1a0e73;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem}.modal-card{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:2rem;width:100%;max-width:400px}.modal-title{font-family:var(--font-serif);font-size:1.25rem;font-weight:600;color:var(--ink-900);margin:0 0 .375rem}.modal-desc{font-size:.9375rem;color:var(--ink-600);margin:0 0 1.25rem}.modal-alt-row{display:flex;justify-content:space-between;margin-top:.875rem;gap:.5rem}@media(max-width:768px){.admin-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.book-search-bar{flex-wrap:wrap}.book-lock-btn,.btn-remove{min-height:44px;min-width:44px}.info-page-header{padding:12px 16px}.info-page-header .landing-nav{display:none}.btn-refresh-meta,.btn-link-meta,.btn-find-meta,.date-removal-prompt button,.btn-icon{min-height:44px}.page-eyebrow,.admin-table th{font-size:.75rem}}@media(max-width:480px){.book-position,.book-date{display:none}.page{padding-left:.75rem;padding-right:.75rem}.book-details-date input[type=date]{flex:1}}.reload-prompt{position:fixed;bottom:1.25rem;left:50%;transform:translate(-50%);background:var(--ink-900);color:#fff;padding:.6rem .75rem .6rem 1rem;border-radius:var(--radius-md);display:flex;align-items:center;gap:.75rem;box-shadow:var(--shadow-lg);z-index:300;white-space:nowrap;font-size:.875rem}.reload-prompt-btn{background:#fff;color:var(--ink-900);border:none;border-radius:var(--radius-sm);padding:.3rem .75rem;font-size:.8125rem;font-family:var(--font-body);font-weight:600;cursor:pointer;transition:opacity var(--dur-fast) var(--ease-out)}.reload-prompt-btn:hover{opacity:.85}.reload-prompt-dismiss{background:transparent;border:none;color:#fff9;cursor:pointer;font-size:.875rem;padding:.25rem;line-height:1;transition:color var(--dur-fast) var(--ease-out)}.reload-prompt-dismiss:hover{color:#fff}@media(max-width:768px){.reload-prompt{bottom:calc(56px + env(safe-area-inset-bottom) + .75rem)}}
