:root{--ink: #1c1612;--ink-soft: #4a3f35;--ink-faint: #8a7a6e;--parchment: #f5f0e8;--paper: #faf7f2;--accent: #c45c26;--accent-hover: #a94e1f;--accent-pale: rgba(196, 92, 38, .08);--success: #4a7c59;--error: #9e3a3a;--warning: #b8922a;--border: #ddd5c4;--border-soft: #e8e2d8;--radius: 6px;--radius-lg: 10px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:DM Sans,-apple-system,sans-serif;background:var(--paper);color:var(--ink);line-height:1.5;-webkit-font-smoothing:antialiased}h1,h2,h3{font-family:Playfair Display,serif;font-weight:700;line-height:1.2}h1{font-size:1.75rem;margin-bottom:.5rem}h2{font-size:1.35rem;margin-bottom:.4rem}h3{font-size:1.1rem;margin-bottom:.2rem}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.page-container{max-width:800px;margin:0 auto;padding:2rem 1.5rem}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.page-header h1{margin-bottom:0}.app-header{background:var(--ink);color:var(--parchment);position:sticky;top:0;z-index:50}.header-inner{max-width:800px;margin:0 auto;padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:space-between}.header-wordmark{font-family:Playfair Display,serif;font-weight:700;font-style:italic;font-size:1.15rem;color:var(--parchment);text-decoration:none}.header-wordmark:hover{text-decoration:none;opacity:.9}.nav-links{display:flex;align-items:center;gap:1.25rem}.nav-link{color:var(--parchment);opacity:.7;font-size:.88rem;font-weight:500;text-decoration:none;transition:opacity .2s}.nav-link:hover{opacity:1;text-decoration:none}.nav-link.nav-active{opacity:1;border-bottom:2px solid var(--accent);padding-bottom:2px}.nav-user{font-size:.8rem;opacity:.5;margin-left:.5rem}.logout-btn{background:none;border:1px solid rgba(245,240,232,.2);color:var(--parchment);font-size:.82rem;padding:.3rem .75rem;border-radius:var(--radius);cursor:pointer;opacity:.7;transition:opacity .2s}.logout-btn:hover{opacity:1}.hamburger-btn{display:none;background:none;border:none;cursor:pointer;padding:.5rem}.hamburger-icon,.hamburger-icon:before,.hamburger-icon:after{display:block;width:20px;height:2px;background:var(--parchment);transition:all .3s;position:relative}.hamburger-icon:before,.hamburger-icon:after{content:"";position:absolute;left:0;width:20px}.hamburger-icon:before{top:-6px}.hamburger-icon:after{top:6px}.hamburger-icon.open{background:transparent}.hamburger-icon.open:before{top:0;transform:rotate(45deg)}.hamburger-icon.open:after{top:0;transform:rotate(-45deg)}.card{background:#fff;border:1px solid var(--border-soft);border-radius:var(--radius-lg);padding:1.25rem}.card.interactive{cursor:pointer;transition:border-color .2s,box-shadow .2s;text-decoration:none;color:inherit}.card.interactive:hover{border-color:var(--border);box-shadow:0 2px 8px #1c16120f;text-decoration:none}.book-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.book-card-body{display:flex;gap:1rem;align-items:flex-start}.book-card-content{flex:1;min-width:0}.book-thumb{flex-shrink:0;width:72px}.book-thumb-sm{width:48px}.book-thumb-aspect{position:relative;padding-top:133%;border-radius:3px;overflow:hidden;box-shadow:0 4px 12px #1c161226,0 1px 3px #1c161214}.book-thumb-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.book-thumb-fallback{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#2c2420,#1c1612);display:flex;align-items:center;justify-content:center;padding:.4rem}.book-thumb-title{font-family:Playfair Display,serif;font-style:italic;font-weight:700;color:var(--parchment);font-size:.6rem;text-align:center;line-height:1.2}.book-author{font-family:Lora,serif;font-style:italic;font-size:.85rem;color:var(--ink-faint)}.entry-count{display:block;font-size:.8rem;color:var(--ink-faint);margin-top:.25rem}.book-detail-header{display:flex;gap:1.5rem;align-items:flex-start;margin-bottom:1.5rem}.book-detail-cover{flex-shrink:0;width:120px}.book-detail-cover img{width:100%;border-radius:3px;box-shadow:0 6px 20px #1c16122e}.status-buttons{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.back-link{display:inline-block;margin-bottom:1rem;font-size:.88rem;color:var(--ink-faint)}.back-link:hover{color:var(--ink)}.badge{display:inline-flex;align-items:center;padding:.2rem .6rem;font-size:.75rem;font-weight:600;border-radius:3px;text-transform:uppercase;letter-spacing:.04em}.badge-ink{background:var(--ink);color:var(--parchment)}.badge-accepted{background:var(--success);color:#fff}.badge-pending{background:var(--border);color:var(--ink-soft)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.6rem 1.25rem;font-size:.88rem;font-weight:500;border-radius:var(--radius);border:none;cursor:pointer;transition:background .2s,opacity .2s;text-decoration:none;font-family:inherit}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover);text-decoration:none}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--ink)}.btn-ghost:hover{background:var(--parchment);text-decoration:none}.btn-sm{padding:.35rem .75rem;font-size:.82rem}.btn-block{width:100%}.danger-text{color:var(--error)}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.82rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);margin-bottom:.35rem}.form-group input,.form-group select{width:100%;padding:.65rem .75rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.95rem;font-family:inherit;background:#fff;color:var(--ink);transition:border-color .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--accent)}.form-hint{font-size:.85rem;color:var(--ink-faint);margin-top:.25rem}.form-error{color:var(--error);font-size:.85rem;margin:.5rem 0}.form-inline{display:flex;align-items:center;gap:.75rem}.form-inline label{margin-bottom:0}.form-inline select{width:auto}.filter-bar{display:flex;gap:.5rem;margin-bottom:1.25rem;flex-wrap:wrap}.filter-btn{padding:.35rem .75rem;font-size:.82rem;font-weight:500;border:1px solid var(--border);border-radius:var(--radius);background:#fff;color:var(--ink-soft);cursor:pointer;font-family:inherit;transition:all .2s}.filter-btn:hover{border-color:var(--ink-faint)}.filter-btn.active{background:var(--ink);color:var(--parchment);border-color:var(--ink)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem}.stat-card{text-align:center}.stat-value{display:block;font-family:Playfair Display,serif;font-size:2rem;font-weight:700;color:var(--accent)}.stat-label{font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-faint)}.empty-state{text-align:center;padding:3rem 1rem;color:var(--ink-faint)}.empty-state p{margin-bottom:1rem}.search-results{display:flex;flex-direction:column;gap:.75rem}.search-result{text-decoration:none;color:inherit}.auth-page{min-height:100vh;display:flex}.auth-brand{flex:1;background:var(--ink);display:flex;align-items:center;justify-content:center;padding:2rem}.auth-brand-inner{text-align:center}.auth-wordmark{font-family:Playfair Display,serif;font-style:italic;font-size:2.5rem;color:var(--parchment);margin-bottom:.5rem}.auth-tagline{font-family:Lora,serif;font-style:italic;font-size:1.1rem;color:var(--parchment);opacity:.6}.auth-form-panel{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem}.auth-card{width:100%;max-width:380px}.auth-card h2{margin-bottom:.5rem}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh}.spinner{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite;margin:1rem auto}@keyframes spin{to{transform:rotate(360deg)}}.text-faint{color:var(--ink-faint);font-size:.85rem}.drop-zone{border:2px dashed var(--border);border-radius:var(--radius-lg);padding:3rem 1.5rem;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;margin:1.5rem 0}.drop-zone:hover{border-color:var(--accent);background:var(--accent-pale)}.drop-zone-text{font-size:1rem;color:var(--ink-soft);margin-bottom:.25rem}.drop-zone-hint{font-size:.82rem;color:var(--ink-faint)}.import-processing{text-align:center}.import-preview{max-width:300px;max-height:400px;object-fit:contain;border-radius:var(--radius);border:1px solid var(--border-soft);margin-bottom:1rem}.processing-status{display:flex;align-items:center;justify-content:center;gap:.75rem}.import-controls{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.import-matches,.import-unmatched{margin-bottom:2rem}.import-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem;padding:.75rem 1rem}.import-row.import-duplicate{opacity:.5}.import-checkbox input{width:18px;height:18px;accent-color:var(--accent)}.import-extracted{flex:1;min-width:0;font-size:.88rem}.import-arrow{color:var(--ink-faint);flex-shrink:0}.import-matched-book{flex:1;min-width:0}.import-done{text-align:center;padding:3rem 1rem}.import-done-actions{display:flex;gap:.75rem;justify-content:center;margin-top:1.5rem}.import-thumbnails{display:flex;gap:.75rem;overflow-x:auto;padding:.75rem 0;margin:1rem 0;-webkit-overflow-scrolling:touch}.import-thumbnails-processing{justify-content:center;margin-bottom:1.5rem}.import-thumbnail{position:relative;flex-shrink:0;width:60px;height:80px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border-soft)}.import-thumbnail img{width:100%;height:100%;object-fit:cover}.import-thumbnail-remove{position:absolute;top:2px;right:2px;width:18px;height:18px;border-radius:50%;background:#1c1612b3;color:#fff;border:none;font-size:12px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}.import-thumbnail-remove:hover{background:var(--error)}.import-status-select{padding:.25rem .5rem;font-size:.78rem;font-family:inherit;border:1px solid var(--border-soft);border-radius:var(--radius);background:#fff;color:var(--ink-soft);cursor:pointer}.import-reject-btn{background:none;border:none;color:var(--ink-faint);font-size:.78rem;font-family:inherit;cursor:pointer;padding:.25rem 0;text-decoration:none}.import-reject-btn:hover{color:var(--error);text-decoration:underline}.import-rejected{opacity:.4;flex-direction:column;gap:.25rem}.import-row-content{flex:1;min-width:0;display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.import-row-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.import-unmatched-content{flex:1;min-width:0}.import-manual-form{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;flex-wrap:wrap}.import-manual-input{padding:.35rem .5rem;font-size:.85rem;font-family:inherit;border:1px solid var(--border);border-radius:var(--radius);background:#fff;color:var(--ink);flex:1;min-width:120px}.import-manual-input:focus{outline:none;border-color:var(--accent)}.import-confidence-low{border-color:var(--warning)!important;background:#b8922a0a}.import-confidence-badge{display:inline-block;padding:.1rem .4rem;font-size:.7rem;font-weight:600;border-radius:3px;background:#b8922a26;color:var(--warning);margin-left:.35rem;vertical-align:middle}.import-truncated-badge{display:inline-block;padding:.1rem .4rem;font-size:.7rem;border-radius:3px;background:var(--parchment);color:var(--ink-faint);margin-left:.35rem;vertical-align:middle}.journal-header,.journal-progress-header{margin-bottom:1.5rem}.progress-bar-container{height:4px;background:var(--border-soft);border-radius:2px;margin-bottom:.25rem}.progress-bar-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}.question-card{margin-bottom:1rem}.question-text{margin-bottom:1.25rem;line-height:1.4}.question-options{display:flex;flex-direction:column;gap:.5rem}.option-chip{display:block;width:100%;text-align:left;padding:.75rem 1rem;background:#fff;border:1px solid var(--border-soft);border-radius:var(--radius-lg);font-size:.95rem;font-family:inherit;color:var(--ink);cursor:pointer;transition:border-color .2s,background .2s}.option-chip:hover{border-color:var(--border);background:var(--parchment)}.option-chip-custom{border-style:dashed;border-color:var(--border);background:transparent;color:var(--ink-soft)}.option-chip-custom:hover{background:var(--accent-pale)}.journal-textarea{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.95rem;font-family:inherit;color:var(--ink);resize:vertical;min-height:120px;transition:border-color .2s}.journal-textarea:focus{outline:none;border-color:var(--accent)}.btn-link-faint{background:none;border:none;color:var(--ink-faint);font-size:.88rem;font-family:inherit;cursor:pointer;padding:.5rem 0;text-decoration:none}.btn-link-faint:hover{color:var(--ink);text-decoration:underline}.journal-success{text-align:center;padding:1rem 0}.journal-success-actions{display:flex;gap:.75rem;justify-content:center;margin-top:1.5rem}.mode-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.mode-option{text-align:left;border:1px solid var(--border-soft);cursor:pointer;font-family:inherit;background:#fff;transition:all .2s}.mode-option:hover{border-color:var(--border)}.mode-option:disabled{opacity:.5;cursor:not-allowed}.mode-selected{background:var(--ink)!important;border-color:var(--ink)!important;color:var(--parchment)}.mode-selected h3{color:var(--parchment)}.mode-selected .text-faint{color:var(--parchment);opacity:.7}.entry-display{text-align:left;margin-bottom:1rem}.entry-text{font-family:Lora,serif;font-style:italic;font-size:.95rem;color:var(--ink-soft);line-height:1.7;white-space:pre-wrap}.entry-qa{margin-bottom:1.25rem}.entry-qa:last-child{margin-bottom:0}.entry-question{font-weight:500;font-size:.95rem;color:var(--ink);margin-bottom:.35rem}.entry-answer{font-family:Lora,serif;font-style:italic;font-size:.95rem;color:var(--ink-soft);line-height:1.6}.entry-meta{display:flex;align-items:center;gap:.75rem;margin-top:.5rem}.entry-book-header,.entry-content-card{margin-bottom:1.5rem}.entry-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.entry-tag{display:inline-block;padding:.2rem .6rem;font-size:.78rem;background:var(--parchment);border:1px solid var(--border-soft);border-radius:100px;color:var(--ink-soft)}.catalogue-header{margin-bottom:2rem}.section-label{display:block;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-faint);margin-bottom:.5rem}.catalogue-section{margin-bottom:1.5rem}.selection-grid{display:flex;flex-wrap:wrap;gap:.5rem}.selection-chip{padding:.4rem .85rem;font-size:.88rem;font-family:inherit;border:1px solid var(--border-soft);border-radius:100px;background:#fff;color:var(--ink);cursor:pointer;transition:all .2s}.selection-chip:hover{border-color:var(--ink-faint)}.selection-chip-active{background:var(--ink);border-color:var(--ink);color:var(--parchment);font-weight:600}.catalogue-instructions{background:var(--parchment)}.instructions-list{list-style:none;padding:0;margin:0}.instructions-list li{display:flex;align-items:center;gap:.75rem;padding:.35rem 0;font-size:.88rem;color:var(--ink-soft)}.instruction-icon{display:inline-flex;align-items:center;justify-content:center;width:24px;font-weight:600;color:var(--accent);flex-shrink:0}.swipe-header{text-align:center;margin-bottom:1.5rem}.swipe-card{text-align:center;padding:2rem 1.5rem;margin-bottom:1.5rem}.swipe-card-cover{margin-bottom:1.25rem}.swipe-card-cover img{max-height:240px;max-width:160px;border-radius:3px;box-shadow:0 6px 20px #1c16122e}.swipe-card-info h2{margin-bottom:.25rem}.swipe-actions{display:flex;gap:.75rem;justify-content:center}.decision-btn{flex:1;max-width:160px}.decision-skip{border-color:var(--border)}.decision-want{background:var(--accent);color:#fff}.decision-want:hover:not(:disabled){background:var(--accent-hover)}.decision-read{background:var(--success);color:#fff}.decision-read:hover:not(:disabled){filter:brightness(.9)}.swipe-complete{text-align:center;padding:3rem 1rem}.catalogue-list-header{margin-bottom:1.5rem}.catalogue-book-list{display:flex;flex-direction:column;gap:.75rem}.catalogue-book-card{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.catalogue-book-info{flex:1;min-width:0}.catalogue-book-title-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.catalogue-book-actions{display:flex;gap:.35rem;flex-shrink:0}.catalogue-book-decided{opacity:.5}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1c161280;display:flex;align-items:center;justify-content:center;padding:1.5rem;z-index:100}.modal-content{background:#fff;border-radius:var(--radius-lg);padding:1.5rem;width:100%;max-width:340px;border:1px solid var(--border-soft)}.modal-content h3{text-align:center;margin-bottom:.25rem}.journal-prompt{margin-top:.75rem}.desktop-only{display:inline}.mobile-only{display:none}.library-menu{position:relative}.btn-icon-only{padding:.4rem .6rem;font-size:1.2rem;line-height:1;min-width:auto}.library-menu-dropdown{position:absolute;top:100%;right:0;margin-top:.25rem;background:#fff;border:1px solid var(--border-soft);border-radius:var(--radius-lg);box-shadow:0 4px 16px #1c16121f;min-width:200px;z-index:100;overflow:hidden}.library-menu-item{display:block;padding:.65rem 1rem;font-size:.88rem;color:var(--ink);text-decoration:none;transition:background .15s}.library-menu-item:hover{background:var(--parchment);text-decoration:none}.btn-icon{background:none;border:none;cursor:pointer;font-size:1.1rem;color:var(--ink-faint);padding:.25rem;line-height:1;transition:color .2s}.btn-icon:hover{color:var(--ink)}.btn-favourite{background:none;border:none;cursor:pointer;font-size:1.3rem;color:var(--ink-faint);padding:.25rem;line-height:1;transition:color .2s,transform .2s}.btn-favourite:hover,.btn-favourite.is-favourite{color:var(--error)}.btn-favourite.is-favourite:hover{transform:scale(1.1)}.favourite-badge{color:var(--error);font-size:.75rem;margin-left:.35rem;vertical-align:middle}.bookshelf-search{position:relative;margin-bottom:1rem}.bookshelf-search-input{width:100%;padding:.6rem 2rem .6rem .75rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.88rem;font-family:inherit;background:#fff;color:var(--ink);transition:border-color .2s}.bookshelf-search-input:focus{outline:none;border-color:var(--accent)}.bookshelf-search-input::placeholder{color:var(--ink-faint)}.bookshelf-search-clear{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;font-size:1.2rem;color:var(--ink-faint);cursor:pointer;line-height:1;padding:.25rem}.bookshelf-search-clear:hover{color:var(--ink)}.bookshelf-search-results{background:#fff;border:1px solid var(--border-soft);border-radius:var(--radius-lg);margin-bottom:1.25rem;overflow:hidden}.bookshelf-search-row{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;border-bottom:1px solid var(--border-soft)}.bookshelf-search-row:last-child{border-bottom:none}.bookshelf-search-info{display:flex;align-items:center;gap:.6rem;text-decoration:none;color:inherit;flex:1;min-width:0}.bookshelf-search-info:hover{text-decoration:none}.bookshelf-search-thumb{width:32px;height:48px;object-fit:cover;border-radius:2px;flex-shrink:0}.bookshelf-search-title{display:block;font-size:.88rem;font-weight:500;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bookshelf-search-author{display:block;font-size:.78rem;color:var(--ink-faint);font-style:italic}.bookshelf-visual{margin-bottom:2rem;overflow-x:auto;-webkit-overflow-scrolling:touch}.shelf-row{display:flex;gap:.75rem;padding:1rem .5rem 0;padding-bottom:18px;min-width:min-content;position:relative;flex-wrap:wrap;justify-content:center}.shelf-row:after{content:"";position:absolute;bottom:0;left:-.5rem;right:-.5rem;height:14px;background:linear-gradient(180deg,#a0845c,#8b6f47 30%,#6b5330);border-radius:0 0 4px 4px;box-shadow:0 4px 10px #1c161240,inset 0 1px #a0845c66}.shelf-book{flex-shrink:0;width:72px;cursor:pointer;text-decoration:none;position:relative;z-index:1;transition:transform .2s}.shelf-book:hover{transform:translateY(-4px);text-decoration:none}.shelf-book-cover{width:72px;height:108px;border-radius:2px;overflow:hidden;box-shadow:2px 2px 8px #1c161240}.shelf-book-cover img{width:100%;height:100%;object-fit:cover}.shelf-book-fallback{width:100%;height:100%;background:linear-gradient(135deg,#2c2420,#1c1612);display:flex;align-items:center;justify-content:center;padding:.3rem}.shelf-book-fallback span{font-family:Playfair Display,serif;font-style:italic;font-weight:700;color:var(--parchment);font-size:.55rem;text-align:center;line-height:1.1}.shelf-empty{text-align:center;padding:3rem 1rem 2rem;color:var(--ink-faint);font-size:.88rem;position:relative}.shelf-empty:after{content:"";position:absolute;bottom:0;left:-1rem;right:-1rem;height:12px;background:linear-gradient(180deg,#8b6f47,#a0845c 40%,#6b5330);border-radius:0 0 3px 3px;box-shadow:0 4px 8px #1c161233}@media (max-width: 640px){.auth-page{flex-direction:column}.auth-brand{min-height:30vh}.hamburger-btn{display:block}.nav-links{display:none;position:absolute;top:100%;right:0;left:0;background:var(--ink);flex-direction:column;padding:1rem 1.5rem;gap:.75rem;border-top:1px solid rgba(245,240,232,.1)}.nav-links.nav-open{display:flex}.book-grid{grid-template-columns:1fr}.import-row{flex-wrap:wrap}.import-arrow{display:none}.import-extracted,.import-matched-book{flex-basis:100%}.mode-grid{grid-template-columns:1fr}.swipe-actions{flex-direction:column}.decision-btn{max-width:none}.catalogue-book-card{flex-direction:column}.catalogue-book-actions{width:100%}.catalogue-book-actions .btn{flex:1}.desktop-only{display:none}.mobile-only{display:inline}}
