:root{--bg-primary: #ffffff;--bg-secondary: #f8f9fa;--text-primary: #1a1a1a;--text-secondary: #666666;--border-color: #e0e0e0;--accent-color: #2563eb;--accent-hover: #1d4ed8;--rating-color: #fbbf24;--shadow: 0 2px 8px rgba(0, 0, 0, .1);--shadow-hover: 0 8px 16px rgba(0, 0, 0, .15)}html[data-theme=dark]{--bg-primary: #1a1a1a;--bg-secondary: #2d2d2d;--text-primary: #ffffff;--text-secondary: #cccccc;--border-color: #444444;--accent-color: #3b82f6;--accent-hover: #2563eb;--rating-color: #fbbf24;--shadow: 0 2px 8px rgba(0, 0, 0, .3);--shadow-hover: 0 8px 16px rgba(0, 0, 0, .5)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}body{background-color:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease;line-height:1.6}header{background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:1.5rem 0;margin-bottom:2rem;box-shadow:var(--shadow)}.header-container{display:flex;justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto;padding:0 2rem}.header-title{font-size:2rem;font-weight:700;color:var(--text-primary);margin:0}.header-title a{color:inherit}.theme-toggle{background:none;border:2px solid var(--border-color);color:var(--text-primary);padding:.5rem 1rem;border-radius:.375rem;cursor:pointer;font-size:.875rem;transition:all .3s ease;display:flex;align-items:center;gap:.5rem}.theme-toggle:hover{background-color:var(--accent-color);color:#fff;border-color:var(--accent-color)}nav{background-color:var(--bg-secondary);padding:1rem 0}nav a{display:inline-block;padding:.75rem 1.5rem;color:var(--text-primary);text-decoration:none;transition:all .3s ease;border-bottom:2px solid transparent}nav a:hover{background-color:var(--bg-primary);color:var(--accent-color);border-bottom-color:var(--accent-color)}.intro{padding-top:0;padding-bottom:2rem;display:grid;grid-template-columns:minmax(0,1fr) clamp(180px,24vw,300px);gap:2rem;align-items:start}.intro p{margin-bottom:1rem}.flex-container{min-width:0}.headshot{margin-top:1rem;display:flex;justify-content:flex-end}.headshot img{display:block;width:100%;max-width:300px;height:auto;object-fit:cover;border-radius:.75rem}@media(max-width:720px){.intro{grid-template-columns:minmax(0,1fr) 180px;gap:1rem}}@media(max-width:560px){.intro{grid-template-columns:1fr}.headshot{justify-content:center;margin-top:0}}main{max-width:1400px;margin:0 auto;padding:1rem 2rem}.site-footer{margin-top:3rem;border-top:1px solid var(--border-color)}.site-footer-content{max-width:1400px;margin:0 auto;padding:1rem 2rem 2rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.copyright{color:var(--text-secondary);font-size:.95rem}.rss-link{display:inline-flex;align-items:center;gap:.45rem;color:var(--text-secondary);text-decoration:none;font-size:.95rem}.rss-link svg{width:1rem;height:1rem;fill:currentColor;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.rss-link:hover{color:var(--accent-color);text-decoration:none}.book-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4.5rem;margin-bottom:3rem}@media(max-width:1024px){.book-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.book-grid{grid-template-columns:repeat(2,1fr);gap:1rem}}@media(max-width:480px){.book-grid{grid-template-columns:1fr}}.book-card{display:flex;flex-direction:column;background-color:var(--bg-secondary);border-radius:.5rem;overflow:hidden;transition:all .3s ease;box-shadow:var(--shadow);border:1px solid var(--border-color);cursor:pointer}.book-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}.book-cover{width:100%;aspect-ratio:2 / 3;object-fit:cover;background-color:var(--bg-primary)}.book-cover-placeholder{width:100%;aspect-ratio:2 / 3;background:linear-gradient(135deg,var(--border-color) 0%,var(--bg-primary) 100%);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);font-size:.875rem;text-align:center;padding:1rem}.book-info{padding:.75rem;display:flex;flex-direction:column;flex-grow:1;text-align:center}.book-title{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem;line-height:1.2;-webkit-line-clamp:2;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-box-orient:vertical}.book-author{font-size:.75rem;color:var(--text-secondary);margin-bottom:.5rem}.book-rating{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.75rem;color:var(--rating-color);margin-top:auto}.stars{display:flex;gap:.125rem;letter-spacing:.125rem}.book-date{font-size:.7rem;color:var(--text-secondary);margin:.25rem 0 0}.star{color:var(--rating-color);font-size:1rem;line-height:1}.star.empty{color:var(--border-color);opacity:.5}.pagination{display:flex;justify-content:center;align-items:center;gap:.5rem;margin-top:3rem;padding:2rem 0}.pagination-button{padding:.75rem 1rem;border:1px solid var(--border-color);background-color:var(--bg-secondary);color:var(--text-primary);border-radius:.375rem;cursor:pointer;transition:all .3s ease;font-size:.875rem}.pagination-button:hover:not(:disabled){background-color:var(--accent-color);color:#fff;border-color:var(--accent-color)}.pagination-button:disabled{opacity:.5;cursor:not-allowed}.pagination-info{color:var(--text-secondary);font-size:.875rem;margin:0 1rem}a{color:var(--accent-color);text-decoration:none;transition:color .3s ease}a:hover{color:var(--accent-hover);text-decoration:underline}@media(max-width:768px){.header-container{padding:0 1rem;flex-direction:column;gap:1rem}.header-title{font-size:1.5rem}main{padding:0 1rem}}
