*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary: #1a1a2e;--color-primary-light: #16213e;--color-accent: #0f3460;--color-highlight: #e94560;--color-bg: #ffffff;--color-bg-secondary: #f5f5f7;--color-text: #1a1a2e;--color-text-muted: #6b7280;--color-border: #e5e7eb;--color-success: #10b981;--color-danger: #ef4444;--radius: 8px;--radius-lg: 12px;--max-width: 960px;--header-height: 56px}html{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased}a{color:var(--color-accent);text-decoration:none}a:hover{text-decoration:underline}.app-layout{min-height:100vh;display:flex;flex-direction:column}.app-header{position:sticky;top:0;z-index:100;background:var(--color-primary);color:#fff;height:var(--header-height)}.app-nav{display:flex;align-items:center;gap:1rem;max-width:var(--max-width);margin:0 auto;padding:0 1rem;height:100%}.app-logo{font-weight:700;font-size:1.125rem;margin-right:auto}.nav-links{display:flex;list-style:none;gap:.25rem}.nav-link{color:#ffffffb3;padding:.375rem .75rem;border-radius:var(--radius);font-size:.875rem;transition:background .15s,color .15s}.nav-link:hover{color:#fff;background:#ffffff1a;text-decoration:none}.nav-link.active{color:#fff;background:#ffffff26}.app-main{flex:1;max-width:var(--max-width);margin:0 auto;padding:2rem 1rem;width:100%}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border-radius:var(--radius);font-size:.875rem;font-weight:500;cursor:pointer;border:1px solid transparent;transition:background .15s,opacity .15s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-light)}.btn-outline{border-color:var(--color-border);background:transparent;color:var(--color-text)}.btn-outline:hover:not(:disabled){background:var(--color-bg-secondary)}.btn-ghost{background:transparent;color:inherit}.btn-ghost:hover:not(:disabled){background:#ffffff1a}.btn-danger{background:var(--color-danger);color:#fff}.form-label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.25rem}.form-input,.form-textarea{width:100%;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius);font-size:.875rem;outline:none;transition:border-color .15s}.form-input:focus,.form-textarea:focus{border-color:var(--color-accent)}.form-error{color:var(--color-danger);font-size:.8125rem;margin-top:.25rem}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;gap:.75rem}.loading-spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--color-bg-secondary)}.login-card{background:var(--color-bg);padding:2.5rem;border-radius:var(--radius-lg);box-shadow:0 1px 3px #0000001a;width:100%;max-width:400px}.login-title{font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.login-subtitle{color:var(--color-text-muted);margin-bottom:1.5rem}.login-form{display:flex;flex-direction:column;gap:.75rem}.login-success{padding:1rem;background:#ecfdf5;border-radius:var(--radius);color:#065f46}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin:1.5rem 0}.stat-card{background:var(--color-bg-secondary);padding:1.25rem;border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;gap:.25rem}.stat-value{font-size:2rem;font-weight:700}.stat-label{font-size:.8125rem;color:var(--color-text-muted)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.book-list{list-style:none}.book-list-item{border-bottom:1px solid var(--color-border)}.book-link{display:flex;align-items:center;gap:.75rem;padding:.75rem 0;color:inherit}.book-link:hover{text-decoration:none;background:var(--color-bg-secondary);margin:0 -.5rem;padding-left:.5rem;padding-right:.5rem;border-radius:var(--radius)}.book-title{font-weight:500;flex:1}.book-author{color:var(--color-text-muted);font-size:.875rem}.status-badge{font-size:.75rem;padding:.125rem .5rem;border-radius:999px;text-transform:capitalize;white-space:nowrap}.status-reading{background:#dbeafe;color:#1e40af}.status-read{background:#dcfce7;color:#166534}.status-want_to_read{background:#fef3c7;color:#92400e}.library-controls{display:flex;flex-direction:column;gap:.75rem;margin:1rem 0}.search-input{max-width:400px}.filter-tabs{display:flex;gap:.25rem}.filter-tab{padding:.375rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius);background:transparent;cursor:pointer;font-size:.8125rem;transition:background .15s}.filter-tab.active{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.empty-state{text-align:center;padding:3rem 1rem;color:var(--color-text-muted)}.back-btn{margin-bottom:1rem}.book-detail-header{margin-bottom:2rem}.book-detail-header h1{margin-bottom:.25rem}.reading-count{font-size:.875rem;color:var(--color-text-muted);margin-top:.5rem}.book-isbn{font-size:.8125rem;color:var(--color-text-muted)}.book-detail-section{margin-bottom:2rem}.book-detail-section h2{font-size:1.125rem;margin-bottom:.75rem}.status-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.notes-footer{display:flex;justify-content:space-between;align-items:center;margin-top:.5rem}.char-count{font-size:.75rem;color:var(--color-text-muted)}.tag-list{display:flex;gap:.5rem;flex-wrap:wrap}.tag{padding:.25rem .75rem;background:var(--color-bg-secondary);border-radius:999px;font-size:.8125rem}.page-description{color:var(--color-text-muted);margin:.5rem 0 1.5rem}.capture-area{margin-top:1rem}.capture-label{display:flex;align-items:center;justify-content:center;border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:3rem;cursor:pointer;transition:border-color .15s}.capture-label:hover{border-color:var(--color-accent)}.capture-input{display:none}.capture-placeholder{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--color-text-muted)}.capture-icon{font-size:2rem}.preview-image{max-width:100%;max-height:400px;border-radius:var(--radius-lg)}.capture-actions{display:flex;gap:.75rem;margin-top:1rem}.archetype-timeline{margin:1.5rem 0;border-left:2px solid var(--color-border);padding-left:1.5rem}.timeline-entry{position:relative;margin-bottom:1.5rem}.timeline-marker{position:absolute;left:-2rem;top:0;width:12px;height:12px;background:var(--color-accent);border-radius:50%}.timeline-month{position:absolute;left:-6rem;font-size:.75rem;color:var(--color-text-muted);white-space:nowrap}.archetype-name{font-size:1rem;font-weight:600;margin-bottom:.25rem}.archetype-reason{font-size:.875rem;color:var(--color-text-muted)}.archetype-placeholder{padding:1.5rem;background:var(--color-bg-secondary);border-radius:var(--radius-lg);text-align:center;color:var(--color-text-muted)}.settings-section{margin-bottom:2rem}.settings-section h2{font-size:1.125rem;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-border)}.setting-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.setting-label{font-weight:500}.setting-description{font-size:.875rem;color:var(--color-text-muted)}.settings-placeholder{color:var(--color-text-muted);font-size:.875rem}.settings-section .btn{margin-right:.5rem;margin-top:.5rem}.toggle{padding:.375rem 1rem;border-radius:999px;border:1px solid var(--color-border);cursor:pointer;font-size:.8125rem;font-weight:500;transition:background .15s,color .15s}.toggle-on{background:var(--color-success);color:#fff;border-color:var(--color-success)}.toggle-off{background:var(--color-bg-secondary);color:var(--color-text-muted)}.bottom-tabs{display:none}@media(max-width:640px){.nav-links{display:none}.bottom-tabs{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:100;background:var(--color-primary);border-top:1px solid rgba(255,255,255,.1);padding:.25rem 0;padding-bottom:max(.25rem,env(safe-area-inset-bottom))}.tab-link{flex:1;display:flex;flex-direction:column;align-items:center;gap:.125rem;padding:.375rem 0;color:#ffffff80;font-size:.625rem;font-weight:500;text-decoration:none;transition:color .15s}.tab-link:hover{text-decoration:none;color:#fffc}.tab-link.active{color:#fff}.tab-icon{font-size:1.25rem;line-height:1}.app-main{padding-bottom:4.5rem}.stats-grid{grid-template-columns:repeat(2,1fr)}.status-buttons{flex-direction:column}}
