@import url("https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;1,400&display=swap");:root{--color-forest-green:#3d5a3c;--color-sage-green:#6b8e6b;--color-moss-green:#8da88d;--color-soft-sage:#b4c4b4;--color-warm-beige:#e8dcc4;--color-linen:#f5f0e8;--color-taupe:#9d8b7a;--color-mocha:#7d6b5d;--color-sage-gray:#a8b5a8;--color-primary:#6b8e6b;--color-secondary:#9d8b7a;--color-accent:#8da88d;--color-background:#f5f0e8;--color-card:#ebe5d9;--color-text:#3d5a3c;--color-text-light:#7d6b5d;--color-primary-dark:#3d5a3c;--color-primary-light:#8da88d;--color-success:#6b8e6b;--color-error:#c25450;--color-nav-bg:rgba(235,229,217,0.95);--color-nav-border:var(--color-soft-sage);--color-modal-header-border:#e5e7eb;--color-modal-close:#6b7280;--shadow-sm:0 2px 4px rgba(90,90,90,0.1);--shadow-md:0 4px 8px rgba(90,90,90,0.15);--shadow-lg:0 8px 16px rgba(90,90,90,0.2);--border-radius:8px;--border-radius-sm:4px;--border-radius-lg:12px;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem}[data-theme=dark]{--color-primary:#86c786;--color-secondary:#9aa0a6;--color-accent:#aad4aa;--color-background:#18191c;--color-card:#212326;--color-text:#e8eaed;--color-text-light:#9aa0a6;--color-primary-dark:#69b569;--color-primary-light:#aad4aa;--color-success:#81c995;--color-error:#f28b82;--color-soft-sage:#3c4043;--color-linen:#2a2b2e;--color-warm-beige:#2a2b2e;--color-taupe:#9aa0a6;--color-sage-gray:#5f6368;--color-nav-bg:rgba(24,25,28,0.95);--color-nav-border:#3c4043;--color-modal-header-border:#3c4043;--color-modal-close:#9aa0a6;--shadow-sm:0 2px 4px rgba(0,0,0,0.4);--shadow-md:0 4px 8px rgba(0,0,0,0.5);--shadow-lg:0 8px 16px rgba(0,0,0,0.6)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;-webkit-font-smoothing:antialiased;background-color:var(--color-background);color:var(--color-text);line-height:1.6}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);background-color:var(--color-background)}.auth-card{background:var(--color-card);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);padding:var(--spacing-2xl);width:100%;max-width:420px}.auth-header{text-align:center;margin-bottom:var(--spacing-xl)}.auth-header h1{color:var(--color-primary);font-size:2.5rem;margin-bottom:var(--spacing-sm);font-weight:700}.auth-header p{color:var(--color-text);font-size:1rem;opacity:.8}.auth-form{gap:var(--spacing-lg)}.auth-form,.form-group{display:flex;flex-direction:column}.form-group{gap:var(--spacing-sm)}.form-group label{font-weight:600;color:var(--color-text);font-size:.9rem}.form-group input{padding:.75rem 1rem;border:2px solid var(--color-soft-sage);border-radius:var(--border-radius);font-size:1rem;transition:all .3s ease;font-family:inherit;background-color:var(--color-linen);color:var(--color-text)}.form-group input:hover{border-color:var(--color-sage-gray)}.form-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(107,142,107,.15)}.form-group input:disabled{background-color:var(--color-warm-beige);cursor:not-allowed;opacity:.6}.form-group input::placeholder{color:var(--color-taupe);opacity:.7}.btn{padding:.875rem 1.5rem;border:none;border-radius:var(--border-radius);font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;font-family:inherit}.btn-primary{background-color:var(--color-primary);color:var(--color-linen)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.link-button{background:none;border:none;color:var(--color-primary);font-weight:600;cursor:pointer;padding:0;font-family:inherit;font-size:inherit;text-decoration:underline}.link-button:hover:not(:disabled){color:var(--color-primary-dark)}.link-button:disabled{opacity:.6;cursor:not-allowed}.error-message{background-color:rgba(194,84,80,.12);color:var(--color-error);border-left:4px solid var(--color-error)}.error-message,.success-message{padding:var(--spacing-md);border-radius:var(--border-radius);font-size:.9rem}.success-message{background-color:rgba(107,142,107,.1);color:var(--color-success);border-left:4px solid var(--color-success)}.auth-footer{margin-top:var(--spacing-lg);text-align:center;color:var(--color-text);font-size:.9rem}.auth-divider{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--color-text-light);font-size:.85rem;margin:var(--spacing-sm) 0}.auth-divider:after,.auth-divider:before{content:"";flex:1 1;height:1px;background:var(--color-soft-sage)}.btn-google{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:.75rem 1rem;background:var(--color-linen);border:1.5px solid var(--color-soft-sage);border-radius:var(--border-radius);font-family:inherit;font-size:.95rem;font-weight:600;color:var(--color-text);cursor:pointer;text-decoration:none;transition:border-color .15s,box-shadow .15s}.btn-google:hover{border-color:#4285F4;box-shadow:0 0 0 2px rgba(66,133,244,.15)}@media (max-width:480px){.auth-card{padding:var(--spacing-xl)}.auth-header h1{font-size:2rem}}.dashboard-nav{background:var(--color-nav-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 16px rgba(61,90,60,.08);position:-webkit-sticky;position:sticky;top:0;z-index:100;border-bottom:1px solid var(--color-nav-border)}.nav-container{max-width:1200px;margin:0 auto;padding:var(--spacing-md) var(--spacing-lg);padding-left:max(var(--spacing-lg),env(safe-area-inset-left));padding-right:max(var(--spacing-lg),env(safe-area-inset-right));display:flex;align-items:center;gap:1.5rem}.nav-logo{background:linear-gradient(90deg,var(--color-primary) 0,var(--color-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:1.75rem;font-weight:700;margin:0}.nav-discover{display:flex;align-items:center;gap:1rem}.nav-profile-link{flex:1 1;min-width:0;color:var(--color-text);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-username{color:var(--color-text-light);font-weight:400}.nav-actions{display:flex;align-items:center;gap:var(--spacing-md);margin-left:auto}.btn-logout{background-color:var(--color-primary);color:var(--color-linen);border:none;padding:.625rem 1.25rem;border-radius:var(--border-radius);font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap}.btn-logout:hover{background-color:var(--color-primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px rgba(107,142,107,.3)}@media (max-width:639px){.nav-container{display:grid;grid-template-columns:1fr auto;grid-template-areas:"logo actions";grid-column-gap:.75rem;column-gap:.75rem;grid-row-gap:0;row-gap:0;padding:.5rem var(--spacing-md);padding-left:max(var(--spacing-md),env(safe-area-inset-left));padding-right:max(var(--spacing-md),env(safe-area-inset-right))}.nav-logo{grid-area:logo;font-size:1.35rem;align-self:center}.nav-actions{grid-area:actions;margin-left:0;gap:.5rem}.nav-discover,.nav-profile-link{display:none}.btn-logout{padding:.4rem .7rem;font-size:.82rem}}.bottom-nav{display:none}@media (max-width:639px){.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:100;background:var(--color-card);border-top:1px solid var(--color-soft-sage);padding-bottom:env(safe-area-inset-bottom);box-shadow:0 -2px 12px rgba(0,0,0,.07)}.bottom-nav-tab{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 4px 6px;color:var(--color-text-light);text-decoration:none;font-size:.68rem;font-family:inherit;gap:3px;transition:color .15s}.bottom-nav-tab.active,.bottom-nav-tab:hover{color:var(--color-primary)}.dashboard-main{padding-bottom:calc(62px + env(safe-area-inset-bottom))!important}}.dashboard-main{padding:var(--spacing-2xl) var(--spacing-md);min-height:calc(100vh - 70px);background-color:var(--color-background)}.welcome-section{margin-bottom:var(--spacing-2xl);text-align:center;background:var(--color-card);border-radius:var(--border-radius-lg);padding:var(--spacing-2xl);box-shadow:0 4px 16px rgba(61,90,60,.08);position:relative;overflow:hidden;border:1px solid var(--color-soft-sage)}.welcome-section:before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--color-primary) 0,var(--color-secondary) 50%,var(--color-accent) 100%)}.welcome-section h2{color:var(--color-primary);font-size:2rem;margin-bottom:var(--spacing-sm);font-weight:700}.welcome-subtitle{color:var(--color-text);font-size:1.1rem;opacity:.8;max-width:600px;margin:0 auto}@media (max-width:768px){.dashboard-main{padding:var(--spacing-lg) var(--spacing-md)}.welcome-section h2{font-size:1.5rem}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--color-card);border-radius:12px;box-shadow:0 10px 40px rgba(107,142,107,.25);max-width:600px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-out;border:2px solid var(--color-soft-sage)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 28px;border-bottom:1px solid var(--color-modal-header-border)}.modal-header h2{margin:0;font-size:1.5rem;color:var(--color-primary);font-weight:600}.modal-close{background:none;border:none;font-size:2rem;color:var(--color-modal-close);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.modal-close:hover{background-color:rgba(107,142,107,.1);color:var(--color-primary)}.modal-body{padding:24px 28px}.code-input-container{margin:20px 0}.code-input{width:100%;padding:15px;font-size:24px;text-align:center;letter-spacing:10px;border:2px solid var(--color-soft-sage);border-radius:8px;outline:none;transition:border-color .2s;font-family:monospace;background-color:var(--color-linen);color:var(--color-text)}.code-input:focus{border-color:var(--color-primary)}.code-input:disabled{background-color:var(--color-warm-beige);cursor:not-allowed}.attempts-text{margin:10px 0;font-size:13px;color:var(--color-text-light)}@media (max-width:768px){.modal-overlay{padding:10px}.modal-content{max-height:95vh}.modal-body,.modal-header{padding:20px}}.quote-list-container{width:100%;max-width:1200px;margin:0 auto;padding:24px}.quote-list-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;gap:20px}.quote-list-title-section{flex:1 1}.quote-list-title-section h2{margin:0 0 12px;font-size:2rem;color:var(--color-text);font-weight:700}.quote-stats{display:flex;align-items:center;gap:12px;color:var(--color-text-light);font-size:.875rem}.stat-item strong{color:var(--color-primary);font-weight:600}.stat-divider{color:var(--color-sage-gray)}.quote-add-btn{padding:12px 24px;background-color:var(--color-primary);color:var(--color-linen);border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap}.quote-add-btn:hover{background-color:var(--color-primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px rgba(107,142,107,.3)}.quote-list-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;gap:20px}.spinner{width:48px;height:48px;border:4px solid var(--color-soft-sage);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.quote-list-loading p{color:var(--color-text-light);font-size:1rem}.quote-list-error{padding:20px;background-color:rgba(194,84,80,.1);border:1px solid rgba(194,84,80,.3);border-radius:8px;color:var(--color-error);display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.quote-list-error button{padding:8px 16px;background-color:var(--color-error);color:var(--color-linen);border:none;border-radius:6px;cursor:pointer;font-weight:600}.quote-list-empty{padding:80px 20px}.empty-state{max-width:400px;margin:0 auto;text-align:center;display:flex;flex-direction:column;align-items:center;gap:20px}.empty-icon{width:80px;height:80px;color:var(--color-primary);opacity:.5}.empty-state h3{margin:0;font-size:1.5rem;color:var(--color-text);font-weight:600}.empty-state p{margin:0;color:var(--color-text-light);font-size:1rem}.empty-action-btn{padding:12px 32px;background-color:var(--color-primary);color:var(--color-linen);border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:12px}.empty-action-btn:hover{background-color:var(--color-primary-dark);transform:translateY(-2px)}.quote-list-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));grid-gap:24px;gap:24px}@media (max-width:768px){.quote-list-container{padding:16px}.quote-list-header{flex-direction:column;align-items:stretch;margin-bottom:24px}.quote-list-title-section h2{font-size:1.5rem}.quote-add-btn{width:100%}.quote-list-grid{grid-template-columns:1fr;gap:16px}.quote-list-error{flex-direction:column;gap:12px;text-align:center}.quote-list-error button{width:100%}}.quote-card{background:var(--color-card);border-radius:12px;padding:24px;box-shadow:0 2px 8px rgba(61,90,60,.08);transition:all .3s;display:flex;flex-direction:column;gap:16px;border:1px solid var(--color-soft-sage)}.quote-card:hover{box-shadow:0 4px 16px rgba(61,90,60,.12);transform:translateY(-2px)}.quote-card-content{flex:1 1;display:flex;flex-direction:column;gap:16px}.quote-text{font-size:1.125rem;line-height:1.7;color:var(--color-text);margin:0;font-style:italic}.quote-info{display:flex;flex-direction:column;gap:4px;margin-top:8px}.quote-author{font-weight:600;color:var(--color-text);margin:0;font-style:italic}.quote-book{color:var(--color-text-light);margin:0;font-size:.875rem}.quote-meta{padding-top:12px;border-top:1px solid var(--color-soft-sage)}.quote-date{font-size:.75rem;color:var(--color-sage-gray)}.quote-card-actions{display:flex;gap:8px;justify-content:flex-end;padding-top:12px;border-top:1px solid var(--color-soft-sage)}.quote-btn{padding:8px 16px;border:none;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.quote-btn-edit{background:rgba(107,142,107,.1);color:var(--color-primary);border:1px solid rgba(107,142,107,.2)}.quote-btn-edit:hover{background:rgba(107,142,107,.2);border-color:var(--color-primary)}.quote-btn-delete{background-color:rgba(239,68,68,.1);color:var(--color-error);border:1px solid rgba(239,68,68,.2)}.quote-btn-delete:hover{background-color:rgba(239,68,68,.2);border-color:var(--color-error)}@media (max-width:768px){.quote-card{padding:20px}.quote-text{font-size:1rem}.quote-btn{flex:1 1;padding:10px}}.quote-form{display:flex;flex-direction:column;gap:20px}.quote-form-error{padding:12px 16px;background-color:rgba(194,84,80,.1);border:1px solid rgba(194,84,80,.3);border-radius:8px;color:var(--color-error);font-size:.875rem}.quote-form-success{padding:12px 16px;background-color:rgba(107,142,107,.1);border:1px solid rgba(107,142,107,.3);border-radius:8px;color:var(--color-success);font-size:.875rem}.quote-form-group{gap:8px}.quote-form-group,.quote-rows{display:flex;flex-direction:column}.quote-rows{gap:12px}.quote-row{display:flex;flex-direction:column;gap:10px;padding:14px;border:1px solid var(--color-soft-sage);border-radius:var(--border-radius)}.quote-row-header{display:flex;justify-content:space-between;align-items:center}.quote-row-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-light)}.quote-row-remove{background:none;border:none;color:var(--color-text-light);font-size:1.25rem;line-height:1;cursor:pointer;padding:0 4px;border-radius:4px;transition:all .15s}.quote-row-remove:hover{color:var(--color-error);background:rgba(194,84,80,.1)}.quote-add-row-btn{background:none;border:2px dashed var(--color-soft-sage);color:var(--color-primary);padding:10px;border-radius:var(--border-radius);cursor:pointer;font-size:.9rem;font-weight:600;font-family:inherit;transition:all .2s;width:100%}.quote-add-row-btn:hover:not(:disabled){border-color:var(--color-primary);background:rgba(107,142,107,.05)}.quote-add-row-btn:disabled{opacity:.5;cursor:not-allowed}.quote-form-group label{font-weight:600;color:var(--color-text);font-size:.875rem}.quote-form-group input,.quote-form-group textarea{padding:12px 16px;border:1px solid var(--color-soft-sage);border-radius:8px;font-size:1rem;font-family:inherit;transition:all .2s;background-color:var(--color-linen);color:var(--color-text)}.quote-form-group input:focus,.quote-form-group textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(107,142,107,.15)}.quote-form-group input:disabled,.quote-form-group textarea:disabled{background-color:var(--color-warm-beige);cursor:not-allowed;opacity:.6}.quote-form-group textarea{resize:vertical;min-height:120px}.quote-form-group input[type=number]::-webkit-inner-spin-button,.quote-form-group input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.quote-form-group input[type=number]{-moz-appearance:textfield}.quote-form-hint{color:var(--color-text-light);font-size:.75rem;margin-top:-4px}.quote-form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:8px}.quote-form-btn{padding:12px 24px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.quote-form-btn:disabled{opacity:.6;cursor:not-allowed}.quote-form-btn-cancel{background:rgba(107,142,107,.08);color:var(--color-text);border:1px solid var(--color-soft-sage)}.quote-form-btn-cancel:hover:not(:disabled){background:rgba(107,142,107,.15)}.quote-form-btn-submit{background-color:var(--color-primary);color:var(--color-linen)}.quote-form-btn-submit:hover:not(:disabled){background-color:var(--color-primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px rgba(107,142,107,.3)}@media (max-width:768px){.quote-form{gap:16px}.quote-form-actions{flex-direction:column-reverse}.quote-form-btn{width:100%}}.vote-row{display:flex;align-items:center;gap:8px;padding-top:12px;border-top:1px solid var(--color-soft-sage);flex-wrap:wrap}.vote-btn{display:inline-flex;align-items:center;gap:5px;background:none;border:1px solid var(--color-soft-sage);border-radius:20px;padding:5px 11px;cursor:pointer;font-size:.8rem;font-weight:600;font-family:inherit;color:var(--color-text-light);transition:all .2s;line-height:1}.vote-btn:hover:not(:disabled){border-color:var(--color-sage-gray);color:var(--color-text)}.vote-btn:disabled{opacity:.5;cursor:not-allowed}.vote-btn-up.active{background:rgba(107,142,107,.15);border-color:var(--color-primary);color:var(--color-primary)}.vote-btn-down.active{background:rgba(194,84,80,.12);border-color:var(--color-error);color:var(--color-error)}[data-theme=dark] .vote-btn-up.active{background:rgba(134,199,134,.15)}[data-theme=dark] .vote-btn-down.active{background:rgba(242,139,130,.15)}.vote-count{font-size:.78rem}.vote-score{font-size:.82rem;font-weight:700}.vote-score.positive{color:var(--color-primary)}.vote-score.negative{color:var(--color-error)}.search-bar{display:flex;align-items:center;gap:8px;margin-bottom:12px}.search-input{flex:1 1;padding:7px 12px;border:1px solid var(--color-soft-sage);border-radius:var(--border-radius);font-size:.9rem;background-color:var(--color-card);color:var(--color-text);font-family:inherit}.search-input:focus{outline:none;border-color:var(--color-primary)}.search-input::placeholder{color:var(--color-taupe);opacity:.7}.search-btn{padding:7px 16px;background:none;color:var(--color-primary);border:1px solid var(--color-primary);border-radius:var(--border-radius);font-size:.875rem;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap;transition:all .15s}.search-btn:hover{background:var(--color-primary);color:var(--color-background)}.search-clear-btn{padding:7px 12px;background:none;border:1px solid var(--color-soft-sage);border-radius:var(--border-radius);font-size:.875rem;color:var(--color-text-light);cursor:pointer;font-family:inherit;white-space:nowrap}.search-clear-btn:hover{border-color:var(--color-error);color:var(--color-error)}.search-active-label{font-size:.85rem;color:var(--color-text-light);margin-bottom:14px}.sort-controls{display:flex;align-items:center;gap:10px;margin-bottom:20px}.sort-controls label{font-size:.875rem;font-weight:600;color:var(--color-text-light);white-space:nowrap}.sort-select{padding:6px 12px;border:1px solid var(--color-soft-sage);border-radius:var(--border-radius);font-size:.875rem;background-color:var(--color-card);color:var(--color-text);cursor:pointer;font-family:inherit}.confirm-delete p{color:var(--color-text);margin-bottom:var(--spacing-xl);line-height:1.6}.confirm-delete-actions{display:flex;gap:12px;justify-content:flex-end}.confirm-delete-btn{background-color:var(--color-error);color:#fff}.confirm-delete-btn:hover{opacity:.88}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;z-index:200;background:var(--color-card);border:1px solid var(--color-soft-sage);border-top:none;border-radius:0 0 var(--border-radius) var(--border-radius);box-shadow:var(--shadow-md);list-style:none;margin:0;padding:4px 0;max-height:220px;overflow-y:auto}.autocomplete-option{display:flex;flex-direction:column;padding:8px 14px;cursor:pointer;gap:2px;transition:background .15s}.autocomplete-option:hover{background:rgba(107,142,107,.1)}[data-theme=dark] .autocomplete-option:hover{background:rgba(138,180,248,.1)}.autocomplete-title{font-size:.95rem;color:var(--color-text)}.autocomplete-subtitle{font-size:.78rem;color:var(--color-text-light)}.btn-theme{background:none;border:1px solid var(--color-soft-sage);color:var(--color-text);padding:.5rem .75rem;border-radius:var(--border-radius);font-size:1rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;line-height:1}.btn-theme:hover{background:rgba(107,142,107,.12);border-color:var(--color-primary)}.range-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;border-radius:3px;background:var(--color-soft-sage);outline:none;cursor:pointer;padding:0;border:none}.range-input::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:none}.range-input::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:none}[data-theme=dark] .range-input{background:var(--color-soft-sage)}.daily-word{display:flex;flex-direction:column;align-items:center;gap:.35rem;margin-top:var(--spacing-sm);font-family:Playfair Display,Georgia,serif}.daily-word-label{font-size:1.15rem;font-weight:700;color:var(--color-text-light);letter-spacing:.01em;margin-bottom:.4rem}.daily-word-word{font-size:3rem;font-weight:700;color:var(--color-primary);line-height:1.05;margin:0;text-align:center}.daily-word-type{font-size:.9rem;color:var(--color-text-light)}.daily-word-definition{font-size:1.25rem;font-weight:700;color:var(--color-text);width:100%;margin:.6rem 0 0;line-height:1.6;text-align:center}.quote-btn-share{background:none;border:1px solid var(--color-soft-sage);color:var(--color-text-light);padding:6px 8px;display:inline-flex;align-items:center;justify-content:center;min-width:32px;font-size:.75rem}.quote-btn-share:hover{border-color:var(--color-primary);color:var(--color-primary)}.quote-btn-share.share-copied{color:var(--color-success);border-color:var(--color-success);min-width:60px}.load-more-container{display:flex;justify-content:center;margin-top:32px;margin-bottom:16px}.load-more-btn{padding:10px 32px;background:none;border:2px solid var(--color-soft-sage);border-radius:var(--border-radius);font-size:.9rem;font-weight:600;color:var(--color-text-light);cursor:pointer;font-family:inherit;transition:all .2s}.load-more-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.load-more-btn:disabled{opacity:.5;cursor:not-allowed}.voted-list-tabs{display:flex;gap:8px;flex-wrap:wrap}.voted-tab{display:inline-block;padding:4px 14px;border-radius:20px;border:1px solid var(--color-soft-sage);font-size:.82rem;font-weight:600;color:var(--color-text-light);text-decoration:none;transition:all .15s;white-space:nowrap}.voted-tab:hover{border-color:var(--color-primary);color:var(--color-primary)}.voted-tab.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.quote-owner{font-size:.78rem;margin:2px 0 0;font-style:normal}.nav-text-link,.quote-owner{color:var(--color-text-light)}.nav-text-link{font-size:.88rem;font-weight:600;text-decoration:none;transition:color .15s}.nav-text-link-active,.nav-text-link:hover{color:var(--color-primary)}.profile-header{background:var(--color-card);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);padding:var(--spacing-xl);margin-top:var(--spacing-xl)}.profile-header-main{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.profile-display-name{font-size:1.6rem;font-weight:700;color:var(--color-text);margin-bottom:var(--spacing-xs)}.profile-own-badge{font-size:.78rem;font-weight:600;color:var(--color-primary);background:rgba(107,142,107,.12);padding:2px 10px;border-radius:20px;display:inline-block}.profile-stat-row{display:flex;gap:var(--spacing-lg);flex-wrap:wrap;align-items:center}.profile-stat-item{font-size:.9rem;color:var(--color-text-light)}.profile-stat-item strong{color:var(--color-text)}.profile-stat-btn{background:none;border:none;font-family:inherit;font-size:.9rem;color:var(--color-text-light);cursor:pointer;padding:0;transition:color .15s}.profile-stat-btn:hover{color:var(--color-primary);text-decoration:underline}.profile-stat-btn strong{color:var(--color-text)}.profile-follow-btn{padding:7px 20px;border-radius:20px;border:2px solid var(--color-primary);background:var(--color-primary);color:#fff;font-family:inherit;font-size:.88rem;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}.profile-follow-btn:hover:not(:disabled){background:var(--color-primary-dark);border-color:var(--color-primary-dark)}.profile-follow-btn.following{background:transparent;color:var(--color-text-light);border-color:var(--color-soft-sage)}.profile-follow-btn.following:hover:not(:disabled){border-color:var(--color-taupe);color:var(--color-taupe)}.profile-follow-btn:disabled{opacity:.5;cursor:not-allowed}.profile-social-list{margin-top:var(--spacing-md);border-top:1px solid var(--color-soft-sage);padding-top:var(--spacing-md);display:flex;flex-direction:column;gap:2px}.profile-social-empty{font-size:.88rem;color:var(--color-text-light);padding:var(--spacing-sm) 0}.profile-social-user{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-radius:var(--border-radius);text-decoration:none;color:var(--color-text);transition:background .12s}.profile-social-user:hover{background:var(--color-linen)}.profile-social-name{font-weight:600;font-size:.9rem}.profile-social-meta{font-size:.8rem;color:var(--color-text-light)}.user-search-container{max-width:640px;margin:var(--spacing-2xl) auto 0}.user-search-title{font-size:1.4rem;font-weight:700;margin-bottom:var(--spacing-lg);color:var(--color-text)}.user-search-form{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.user-search-input{flex:1 1;padding:.75rem 1rem;border:2px solid var(--color-soft-sage);border-radius:var(--border-radius);font-size:1rem;font-family:inherit;background:var(--color-linen);color:var(--color-text);transition:border-color .15s}.user-search-input:focus{outline:none;border-color:var(--color-primary)}.user-search-input::placeholder{color:var(--color-taupe);opacity:.7}.user-search-btn{padding:.75rem 1.25rem;background:none;color:var(--color-primary);border:1px solid var(--color-primary);border-radius:var(--border-radius);font-family:inherit;font-size:.95rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .15s}.user-search-btn:hover:not(:disabled){background:var(--color-primary);color:var(--color-background)}.user-search-btn:disabled{opacity:.5;cursor:not-allowed}.user-search-error{color:var(--color-error);font-size:.9rem;margin-bottom:var(--spacing-md)}.user-search-empty{color:var(--color-text-light);font-size:.95rem;padding:var(--spacing-md) 0}.user-results{display:flex;flex-direction:column;gap:var(--spacing-sm)}.user-result-card{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);background:var(--color-card);border-radius:var(--border-radius);padding:var(--spacing-md) var(--spacing-lg);box-shadow:var(--shadow-sm);transition:box-shadow .15s}.user-result-card:hover{box-shadow:var(--shadow-md)}.user-result-info{display:flex;flex-direction:column;gap:2px;text-decoration:none;flex:1 1;min-width:0}.user-result-name{font-weight:700;color:var(--color-text);font-size:.95rem;transition:color .12s}.user-result-info:hover .user-result-name{color:var(--color-primary)}.user-result-meta{font-size:.8rem;color:var(--color-text-light)}.quote-owner-link{color:var(--color-text-light);text-decoration:none;font-weight:600;transition:color .12s}.quote-owner-link:hover{color:var(--color-primary);text-decoration:underline}.explore-section{background:var(--color-card);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);padding:var(--spacing-xl);margin-top:var(--spacing-xl)}.explore-section-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.explore-section-title{font-size:1.2rem;font-weight:700;color:var(--color-text)}.explore-period-row{display:flex;gap:6px;flex-wrap:wrap}.explore-period-btn{padding:5px 14px;border-radius:20px;border:1px solid var(--color-soft-sage);background:transparent;font-family:inherit;font-size:.82rem;font-weight:600;color:var(--color-text-light);cursor:pointer;transition:all .15s;white-space:nowrap}.explore-period-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.explore-period-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.explore-filter-form{margin-bottom:var(--spacing-lg)}.explore-filter-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;grid-gap:var(--spacing-sm);gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}@media (max-width:700px){.explore-filter-row{grid-template-columns:1fr 1fr}}@media (max-width:480px){.explore-filter-row{grid-template-columns:1fr}}.explore-filter-input{padding:.6rem .9rem;border:2px solid var(--color-soft-sage);border-radius:var(--border-radius);font-size:.9rem;font-family:inherit;background:var(--color-linen);color:var(--color-text);transition:border-color .15s}.explore-filter-input:focus{outline:none;border-color:var(--color-primary)}.explore-filter-input::placeholder{color:var(--color-taupe);opacity:.7}.explore-filter-actions{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.explore-clear-btn{padding:.6rem 1rem;background:transparent;border:1px solid var(--color-soft-sage);border-radius:var(--border-radius);font-family:inherit;font-size:.88rem;color:var(--color-text-light);cursor:pointer;transition:all .15s}.explore-clear-btn:hover{border-color:var(--color-error);color:var(--color-error)}.explore-error{color:var(--color-error);font-size:.9rem;padding:var(--spacing-sm) 0}.explore-empty{color:var(--color-text-light);font-size:.95rem;padding:var(--spacing-md) 0}.explore-empty-state{text-align:center;padding:var(--spacing-2xl) var(--spacing-xl);background:var(--color-card);border:1px solid var(--color-soft-sage);border-radius:var(--border-radius-lg)}.explore-empty-state-title{font-size:1.05rem;font-weight:600;color:var(--color-text);margin:0 0 var(--spacing-sm)}.explore-empty-state-sub{font-size:.9rem;color:var(--color-text-light);margin:0}.explore-coming-soon{padding:var(--spacing-xl);text-align:center;color:var(--color-text-light);font-size:.95rem;background:var(--color-linen);border-radius:var(--border-radius);border:1px dashed var(--color-soft-sage)}.landing-layout{min-height:100vh;display:flex;flex-direction:row;background-color:var(--color-background)}.landing-hero{flex:1 1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-2xl) var(--spacing-xl);background:var(--color-card);border-right:1px solid var(--color-soft-sage)}.landing-hero-inner{max-width:420px;width:100%}.landing-logo{font-family:Playfair Display,Georgia,serif;font-size:2.8rem;font-weight:700;color:var(--color-primary);margin-bottom:var(--spacing-sm)}.landing-tagline{font-size:1.25rem;color:var(--color-text);font-weight:500;margin-bottom:var(--spacing-xl)}.landing-features{list-style:none;padding:0;margin:0 0 var(--spacing-xl) 0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.landing-features li{color:var(--color-text-light);font-size:.97rem;padding-left:1.2rem;position:relative}.landing-features li:before{content:"—";position:absolute;left:0;color:var(--color-primary)}.landing-explore-link{display:inline-block;color:var(--color-primary);font-weight:600;font-size:.95rem;text-decoration:none;border-bottom:2px solid var(--color-primary);padding-bottom:2px;transition:opacity .15s}.landing-explore-link:hover{opacity:.75}.landing-auth{flex:1 1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-2xl) var(--spacing-xl)}@media (max-width:768px){.landing-layout{flex-direction:column}.landing-hero{border-right:none;border-bottom:1px solid var(--color-soft-sage);padding:var(--spacing-xl) var(--spacing-md)}.landing-logo{font-size:2rem}.landing-auth{padding:var(--spacing-xl) var(--spacing-md)}.landing-auth .auth-container{min-height:unset;padding:0}}.currently-reading-section{margin-top:var(--spacing-xl);padding:var(--spacing-lg) var(--spacing-xl);background:var(--color-card);border-radius:var(--border-radius-lg);border:1px solid var(--color-soft-sage)}.currently-reading-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.currently-reading-title{font-size:1rem;font-weight:700;color:var(--color-text);margin:0}.cr-add-btn{background:none;border:1px solid var(--color-primary);color:var(--color-primary);padding:4px 10px;border-radius:var(--border-radius-sm);font-size:.82rem;font-family:inherit;cursor:pointer;transition:all .15s}.cr-add-btn:hover{background:var(--color-primary);color:var(--color-background)}.cr-limit-note{font-size:.78rem}.cr-empty,.cr-limit-note{color:var(--color-text-light)}.cr-empty{font-size:.9rem;margin:0}.cr-books{display:flex;flex-direction:column;gap:var(--spacing-sm)}.cr-book-card{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-background);border-radius:var(--border-radius);border:1px solid var(--color-soft-sage)}.cr-book-info{display:flex;flex-direction:column;gap:2px;min-width:0}.cr-book-title{font-weight:600;font-size:.95rem;color:var(--color-text)}.cr-book-author,.cr-book-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cr-book-author{font-size:.82rem;color:var(--color-text-light)}.cr-remove-btn{background:none;border:none;color:var(--color-text-light);font-size:.8rem;cursor:pointer;padding:4px 6px;border-radius:var(--border-radius-sm);flex-shrink:0;transition:all .15s;line-height:1}.cr-remove-btn:hover{color:var(--color-error);background:rgba(194,84,80,.08)}.cr-add-form{margin-top:var(--spacing-md);flex-direction:column}.cr-add-fields,.cr-add-form{display:flex;gap:var(--spacing-sm)}.cr-add-fields{flex-wrap:wrap}.cr-input{padding:.6rem .85rem;border:1.5px solid var(--color-soft-sage);border-radius:var(--border-radius);font-family:inherit;font-size:.9rem;background:var(--color-background);color:var(--color-text);transition:border-color .15s;width:100%}.cr-input:focus{outline:none;border-color:var(--color-primary)}.cr-suggestions{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--color-card);border:1px solid var(--color-soft-sage);border-radius:var(--border-radius);box-shadow:var(--shadow-md);z-index:10;overflow:hidden}.cr-suggestions-label{font-size:.75rem;color:var(--color-text-light);padding:6px 10px 2px;margin:0}.cr-suggestion-item{display:flex;justify-content:space-between;align-items:center;width:100%;padding:7px 10px;background:none;border:none;font-family:inherit;font-size:.88rem;color:var(--color-text);cursor:pointer;text-align:left;gap:var(--spacing-sm);transition:background .1s}.cr-suggestion-item:hover{background:var(--color-linen)}.cr-suggestion-author{font-size:.78rem;color:var(--color-text-light);white-space:nowrap}.cr-add-actions{display:flex;gap:var(--spacing-sm)}.cr-save-btn{padding:.5rem 1rem;background:var(--color-primary);color:#fff;border:none;border-radius:var(--border-radius);font-family:inherit;font-size:.88rem;font-weight:600;cursor:pointer;transition:opacity .15s}.cr-save-btn:hover:not(:disabled){opacity:.85}.cr-save-btn:disabled{opacity:.6;cursor:not-allowed}.cr-cancel-btn{padding:.5rem 1rem;background:none;border:1px solid var(--color-soft-sage);border-radius:var(--border-radius);font-family:inherit;font-size:.88rem;color:var(--color-text-light);cursor:pointer;transition:all .15s}.cr-cancel-btn:hover{border-color:var(--color-text-light);color:var(--color-text)}.cr-error{font-size:.85rem;color:var(--color-error);margin:0}.cr-book-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.cr-finish-btn{background:none;border:1px solid var(--color-soft-sage);color:var(--color-text-light);padding:4px 10px;border-radius:var(--border-radius-sm);font-size:.78rem;font-family:inherit;cursor:pointer;white-space:nowrap;transition:all .15s}.cr-finish-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.bh-section{margin-top:var(--spacing-xl);padding:var(--spacing-lg) var(--spacing-xl);background:var(--color-card);border-radius:var(--border-radius-lg);border:1px solid var(--color-soft-sage)}.bh-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.bh-title{font-size:1rem;font-weight:700;color:var(--color-text);margin:0}.bh-carousel-wrapper{position:relative;display:flex;align-items:center;gap:6px}.bh-carousel{display:flex;gap:10px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:4px 2px 8px;scrollbar-width:none;flex:1 1}.bh-carousel::-webkit-scrollbar{display:none}.bh-card{flex:0 0 150px;scroll-snap-align:start;background:var(--color-background);border:1px solid var(--color-soft-sage);border-left:4px solid var(--color-primary);border-radius:var(--border-radius);padding:10px 10px 10px 12px;cursor:pointer;position:relative;transition:border-color .15s,box-shadow .15s,transform .15s;display:flex;flex-direction:column;gap:4px;min-height:90px}.bh-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.bh-card-title{font-size:.82rem;font-weight:700;color:var(--color-text);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin:0;line-height:1.3}.bh-card-author{font-size:.72rem;color:var(--color-text-light);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.bh-card-count{font-weight:500;margin-top:auto}.bh-card-count,.bh-remove-btn{font-size:.7rem;color:var(--color-text-light)}.bh-remove-btn{position:absolute;top:4px;right:4px;background:none;border:none;cursor:pointer;padding:2px 4px;border-radius:var(--border-radius-sm);line-height:1;opacity:0;transition:opacity .15s,color .15s}.bh-card:hover .bh-remove-btn{opacity:1}.bh-remove-btn:hover{color:var(--color-error)}.bh-arrow{flex-shrink:0;width:28px;height:28px;border-radius:50%;background:var(--color-card);border:1px solid var(--color-soft-sage);color:var(--color-text);font-size:1rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;padding:0;line-height:0;align-self:center}.bh-arrow:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.history-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));grid-gap:var(--spacing-md);gap:var(--spacing-md)}.history-grid-card{background:var(--color-card);border:1px solid var(--color-soft-sage);border-left:4px solid var(--color-primary);border-radius:var(--border-radius);padding:12px 12px 10px 14px;display:flex;flex-direction:column;gap:4px;min-height:90px}.history-grid-title{font-size:.85rem;font-weight:700;color:var(--color-text);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin:0;line-height:1.3}.history-grid-author{font-size:.75rem;color:var(--color-text-light);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.history-grid-count{font-size:.72rem;color:var(--color-text-light);margin-top:auto}.bh-view-all-link{font-size:.8rem;color:var(--color-text-light);text-decoration:none;white-space:nowrap;transition:color .15s}.bh-view-all-link:hover{color:var(--color-primary)}.book-prompt{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-linen);border:1px solid var(--color-soft-sage);border-radius:var(--border-radius);margin-bottom:var(--spacing-xl)}.book-prompt-text{font-size:.88rem;color:var(--color-text)}.book-prompt-actions{display:flex;align-items:center;gap:var(--spacing-sm)}.book-prompt-btn{padding:.35rem .85rem;background:var(--color-primary);color:#fff;border:none;border-radius:var(--border-radius-sm);font-family:inherit;font-size:.8rem;font-weight:600;cursor:pointer;transition:opacity .15s}.book-prompt-btn:hover{opacity:.85}.book-prompt-btn-secondary{background:transparent;color:var(--color-primary);border:1px solid var(--color-primary)}.book-prompt-btn-secondary:hover{background:var(--color-primary);color:#fff;opacity:1}.book-prompt-dismiss{background:none;border:none;color:var(--color-text-light);font-size:.85rem;cursor:pointer;padding:2px 6px;border-radius:var(--border-radius-sm);transition:color .15s}.book-prompt-dismiss:hover{color:var(--color-text)}