:root{--bg-base:#fff;--bg-card:#f9f9f9;--bg-elevated:#f2f2f2;--bg-hover:#f5f5f5;--border:#e8e8e8;--border-bright:#d0d0d0;--accent:#9b1c1c;--accent-hover:#7f1d1d;--accent-muted:#9b1c1c14;--text-primary:#0a0a0a;--text-secondary:#444;--text-muted:#888;--text-inverse:#fff;--reading:#166534;--finished:#9b1c1c;--want:#1e3a5f;--radius:6px;--shadow:0 1px 3px #00000014, 0 4px 16px #0000000a;--shadow-lg:0 8px 32px #0000001f;--nav-height:64px;--sidebar-width:240px}[data-theme=dark]{--bg-base:#000;--bg-card:#0e0e0e;--bg-elevated:#1a1a1a;--bg-hover:#141414;--border:#222;--border-bright:#333;--accent:#dc2626;--accent-hover:#ef4444;--accent-muted:#dc26261a;--text-primary:#f5f5f5;--text-secondary:#a0a0a0;--text-muted:#555;--text-inverse:#000;--reading:#4ade80;--finished:#dc2626;--want:#60a5fa;--shadow:0 1px 3px #0006, 0 4px 16px #0000004d;--shadow-lg:0 8px 32px #0009}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:16px}body{background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100dvh;font-family:Inter,sans-serif;font-weight:400;line-height:1.5}#root{min-height:100dvh;display:flex}.app-shell{flex-direction:column;width:100%;display:flex}.bottom-nav{height:var(--nav-height);background:var(--bg-base);border-top:1px solid var(--border);z-index:50;padding-bottom:env(safe-area-inset-bottom);justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav-link{color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:3px;padding:8px 16px;font-size:.65rem;font-weight:500;text-decoration:none;transition:color .15s;display:flex}.bottom-nav-link.active{color:var(--accent)}.bottom-nav-link svg{stroke-width:1.5px;width:22px;height:22px}.mobile-header{background:var(--bg-base);border-bottom:1px solid var(--border);z-index:50;justify-content:space-between;align-items:center;height:56px;padding:0 20px;display:flex;position:fixed;top:0;left:0;right:0}.mobile-header-logo{color:var(--text-primary);letter-spacing:.02em;font-family:Cormorant Garamond,serif;font-size:1.4rem;font-weight:600}.mobile-header-logo span{color:var(--accent)}.main-content{padding:76px 20px calc(var(--nav-height) + 20px);flex:1;width:100%;max-width:100%}@media (width<=767px){.main-content{padding-bottom:160px}}.sidebar{display:none}@media (width>=768px){.app-shell{flex-direction:row}.bottom-nav,.mobile-header{display:none}.sidebar{width:var(--sidebar-width);background:var(--bg-base);border-right:1px solid var(--border);z-index:40;flex-direction:column;flex-shrink:0;padding:40px 0;display:flex;position:fixed;top:0;bottom:0;left:0}.main-content{margin-left:var(--sidebar-width);max-width:1100px;padding:48px}}.sidebar-logo{border-bottom:1px solid var(--border);margin-bottom:28px;padding:0 28px 36px}.sidebar-logo h1{color:var(--text-primary);letter-spacing:.02em;font-family:Cormorant Garamond,serif;font-size:1.6rem;font-weight:600}.sidebar-logo h1 span{color:var(--accent)}.sidebar-logo p{color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;margin-top:2px;font-size:.7rem}sidebar nav{flex-direction:column;flex:1;gap:2px;padding:0 16px;display:flex}.nav-link{border-radius:var(--radius);color:var(--text-secondary);letter-spacing:.02em;align-items:center;gap:12px;padding:10px 12px;font-size:.8rem;font-weight:400;text-decoration:none;transition:all .15s;display:flex}.nav-link:hover{background:var(--bg-elevated);color:var(--text-primary)}.nav-link.active{color:var(--accent);background:var(--accent-muted);font-weight:500}.nav-link svg{flex-shrink:0;width:16px;height:16px}.sidebar-footer{border-top:1px solid var(--border);margin-top:auto;padding:16px 16px 0}.theme-toggle{border-radius:var(--radius);color:var(--text-muted);cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:8px 12px;font-family:Inter,sans-serif;font-size:.8rem;transition:all .15s;display:flex}.theme-toggle:hover{background:var(--bg-elevated);color:var(--text-primary)}.theme-toggle svg{width:16px;height:16px}.page-header{margin-bottom:32px}.page-header h2{color:var(--text-primary);margin-bottom:4px;font-family:Cormorant Garamond,serif;font-size:2.2rem;font-weight:600;line-height:1.1}.page-header p{color:var(--text-muted);font-size:.8rem}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:20px;padding:20px}@media (width>=768px){.card{padding:28px}}.stats-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px;display:grid}@media (width>=480px){.stats-grid{grid-template-columns:repeat(3,1fr)}}@media (width>=768px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px;margin-bottom:28px}}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.stat-card .label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:6px;font-size:.65rem}.stat-card .value{color:var(--text-primary);font-family:Cormorant Garamond,serif;font-size:1.8rem;line-height:1}.stat-card .sub{color:var(--text-muted);margin-top:4px;font-size:.7rem}.btn{border-radius:var(--radius);cursor:pointer;letter-spacing:.02em;white-space:nowrap;-webkit-tap-highlight-color:transparent;border:none;justify-content:center;align-items:center;gap:6px;padding:10px 20px;font-family:Inter,sans-serif;font-size:.8rem;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-ghost{border:1px solid var(--border);color:var(--text-secondary);background:0 0}.btn-ghost:hover{border-color:var(--border-bright);color:var(--text-primary);background:var(--bg-elevated)}.btn-danger{color:#dc2626;background:0 0;border:1px solid #b43c3c4d}.btn-danger:hover{background:#dc262614}.btn-sm{padding:7px 14px;font-size:.75rem}.btn-full{width:100%}.form-group{margin-bottom:16px}.form-group label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:6px;font-size:.7rem;display:block}.form-control{background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text-primary);appearance:none;outline:none;padding:12px 14px;font-family:Inter,sans-serif;font-size:.875rem;transition:border-color .15s}.form-control:focus{border-color:var(--accent)}.form-control::placeholder{color:var(--text-muted)}select.form-control{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.filter-tabs{flex-wrap:wrap;gap:6px;margin-bottom:20px;display:flex}.filter-tab{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border-radius:20px;padding:7px 14px;font-family:Inter,sans-serif;font-size:.75rem;transition:all .15s}.filter-tab:hover{border-color:var(--border-bright);color:var(--text-primary)}.filter-tab.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:500}.progress-bar{background:var(--border);border-radius:2px;height:2px;overflow:hidden}.progress-fill{background:var(--accent);border-radius:2px;height:100%;transition:width .3s}.status-badge{text-transform:uppercase;letter-spacing:.06em;border-radius:3px;align-items:center;padding:3px 8px;font-size:.6rem;font-weight:500;display:inline-flex}.status-reading{color:var(--reading);background:#1665341a}.status-finished{color:var(--finished);background:#9b1c1c1a}.status-want_to_read{color:var(--want);background:#1e3a5f1a}[data-theme=dark] .status-reading{background:#4ade801a}[data-theme=dark] .status-finished{background:#dc26261a}[data-theme=dark] .status-want_to_read{background:#60a5fa1a}.books-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}@media (width>=480px){.books-grid{grid-template-columns:repeat(4,1fr)}}@media (width>=768px){.books-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:20px}}.book-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:all .2s;overflow:hidden}.book-card:hover{border-color:var(--border-bright);box-shadow:var(--shadow);transform:translateY(-1px)}.book-cover-img{aspect-ratio:2/3;object-fit:cover;width:100%;display:block}.book-cover-placeholder{aspect-ratio:2/3;background:var(--bg-elevated);width:100%;color:var(--text-muted);text-align:center;justify-content:center;align-items:center;padding:12px;font-family:Cormorant Garamond,serif;font-size:.75rem;line-height:1.3;display:flex}.book-info{padding:10px}.book-title{color:var(--text-primary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:2px;font-size:.75rem;font-weight:500;line-height:1.3;display:-webkit-box;overflow:hidden}.book-author{color:var(--text-muted);margin-bottom:6px;font-size:.68rem}.modal-overlay{z-index:100;background:#00000080;justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed;inset:0}.modal{background:var(--bg-base);border:1px solid var(--border);width:100%;max-height:92vh;padding:24px 20px;padding-bottom:calc(24px + env(safe-area-inset-bottom));border-radius:16px 16px 0 0;overflow-y:auto}.modal h3{color:var(--text-primary);margin-bottom:20px;font-family:Cormorant Garamond,serif;font-size:1.5rem;font-weight:600}@media (width>=768px){.modal-overlay{align-items:center;padding:24px}.modal{border-radius:8px;max-width:520px;padding:32px}}.section-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.section-title{color:var(--text-primary);font-family:Cormorant Garamond,serif;font-size:1.1rem;font-weight:600}.session-item{border-bottom:1px solid var(--border);align-items:flex-start;gap:12px;padding:12px 0;display:flex}.session-item:last-child{border-bottom:none}.session-date{color:var(--text-muted);flex-shrink:0;width:48px;padding-top:2px;font-size:.72rem}.session-book{color:var(--text-primary);flex:1;font-size:.825rem}.session-duration{color:var(--accent);flex-shrink:0;font-size:.825rem;font-weight:500}.search-results{border:1px solid var(--border);border-radius:var(--radius);max-height:280px;margin-top:8px;overflow:hidden auto}.search-result-item{border-bottom:1px solid var(--border);cursor:pointer;align-items:center;gap:12px;padding:12px;transition:background .15s;display:flex}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:var(--bg-elevated)}.search-result-cover{object-fit:cover;background:var(--bg-elevated);border-radius:2px;flex-shrink:0;width:32px;height:48px}.search-result-title{color:var(--text-primary);font-size:.825rem;font-weight:500}.search-result-author{color:var(--text-muted);margin-top:2px;font-size:.72rem}.timer-display{color:var(--text-primary);text-align:center;letter-spacing:.12em;font-variant-numeric:tabular-nums;margin:12px 0;font-family:Inter,sans-serif;font-size:3rem;font-weight:300}.heatmap-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.heatmap-cell{background:var(--bg-elevated);border-radius:2px;flex-shrink:0;width:12px;height:12px}.heatmap-cell.level-1{background:#9b1c1c33}.heatmap-cell.level-2{background:#9b1c1c73}.heatmap-cell.level-3{background:#9b1c1cb3}.heatmap-cell.level-4{background:var(--accent)}[data-theme=dark] .heatmap-cell.level-1{background:#dc262633}[data-theme=dark] .heatmap-cell.level-2{background:#dc262673}[data-theme=dark] .heatmap-cell.level-3{background:#dc2626b3}[data-theme=dark] .heatmap-cell.level-4{background:var(--accent)}.loading{color:var(--text-muted);justify-content:center;align-items:center;padding:60px 20px;font-size:.875rem;display:flex}.empty-state{text-align:center;color:var(--text-muted);padding:48px 20px}.empty-state p{margin-bottom:16px;font-size:.875rem}.divider{border:none;border-top:1px solid var(--border);margin:16px 0}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-bright);border-radius:2px}.log-grid{grid-template-columns:1fr;gap:20px;display:grid}@media (width>=768px){.log-grid{grid-template-columns:1fr 1fr;gap:24px}}@keyframes spin{to{transform:rotate(360deg)}}.loading{color:var(--text-muted);justify-content:center;align-items:center;gap:12px;padding:60px 20px;font-size:.875rem;display:flex}@keyframes slideUp{0%{opacity:0;transform:translate(-50%)translateY(8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}@media (width<=767px){.plan-entry-actions .push-back-btn,.plan-entry-actions .add-btn span{display:none}.stats-chart-grid{grid-template-columns:1fr!important}.card{overflow:hidden}}@keyframes pulse-border{0%,to{border-color:#c9707066}50%{border-color:#c97070e6}}.mobile-footer{text-align:center;border-top:1px solid var(--border);background:var(--bg-base);padding:24px 24px 20px;display:none}@media (width<=767px){.mobile-footer{padding-bottom:80px;display:block}.main-content{padding-bottom:180px}}
