body{margin:0}*{box-sizing:border-box;margin:0;padding:0}:root{--white:#fdfcfa;--warm-white:#f7f5f0;--sage:#a8b5a0;--sage-light:#d4ddd0;--sage-very-light:#ebf0e8;--sage-pale:#ebf0e8;--warm-yellow:#f3eddc;--cream:#fdfcfa;--warm-black:#2c2c2c;--warm-dark:#2c2c2c;--warm-gray:#5a5a5a;--light-gray:#8a8a8a;--border:#e8e4dc;--gold:#c4a86b;--gold-light:#f5edd8;--spacing-xs:.5rem;--spacing-sm:.75rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-pill:100px;--shadow-sm:0 1px 3px #1a16140f, 0 1px 2px #1a16140a;--shadow-md:0 4px 12px #1a161414, 0 2px 4px #1a16140a;--shadow-lg:0 8px 24px #1a16141f, 0 4px 8px #1a16140f;--transition:.2s cubic-bezier(.4, 0, .2, 1)}body{background:var(--warm-white);color:var(--warm-black);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,sans-serif;line-height:1.6}.app{flex-direction:column;min-height:100vh;display:flex}.header{background:linear-gradient(160deg, var(--white) 0%, var(--sage-pale) 55%, var(--warm-yellow) 100%);text-align:center;border-bottom:1px solid var(--border);padding:64px 24px 48px}.header-eyebrow{letter-spacing:.12em;color:var(--light-gray);margin-bottom:18px;font-size:.78rem;font-weight:500}.header-eyebrow a{color:var(--sage);font-weight:500;text-decoration:none}.header-eyebrow a:hover{color:var(--warm-black)}.header h1{color:var(--warm-black);margin-bottom:.25rem;font-family:Instrument Serif,Georgia,serif;font-size:clamp(2.2rem,5vw,3.6rem);font-weight:400;line-height:1.1}.header-byline{color:var(--light-gray);margin-bottom:.75rem;font-size:.9rem;font-weight:400}.header-byline a{color:var(--sage);border-bottom:1px solid #0000;text-decoration:none;transition:all .2s}.header-byline a:hover{color:var(--warm-black);border-bottom-color:var(--sage)}.header-subhead{color:var(--sage);margin-bottom:.75rem;font-family:Instrument Serif,Georgia,serif;font-size:clamp(2.2rem,5vw,3.6rem);font-style:italic;line-height:1.1}.header-description{max-width:580px;color:var(--light-gray);margin:0 auto;font-family:Inter,-apple-system,sans-serif;font-size:.9rem;font-weight:400;line-height:1.55}.controls{padding:var(--spacing-xl) var(--spacing-lg);width:100%;max-width:1200px;margin:0 auto}.controls-inner{gap:var(--spacing-md);flex-direction:column;align-items:flex-start;display:flex}.inline-search{border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--white);color:var(--warm-black);width:140px;transition:all var(--transition);outline:none;flex-shrink:0;padding:.45rem .85rem;font-family:Inter,-apple-system,sans-serif;font-size:.8rem}.inline-search:focus{border-color:var(--sage);width:180px;box-shadow:0 0 0 2px #a8b5a026}.inline-search::placeholder{color:var(--light-gray)}.filter-group{width:100%}.filter-group label{color:var(--sage);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.75rem;font-size:.75rem;font-weight:500;display:block}.age-slider-group{width:100%;max-width:500px}.age-label-row{align-items:baseline;gap:.35rem;margin-bottom:.75rem;display:flex}.age-label-text{color:var(--light-gray);letter-spacing:.06em;text-transform:uppercase;font-family:Inter,-apple-system,sans-serif;font-size:.85rem;font-weight:500}.age-number{color:var(--warm-black);letter-spacing:-.02em;font-variant-numeric:tabular-nums;text-align:center;min-width:1.2ch;font-family:Instrument Serif,Georgia,serif;font-size:1.85rem;font-weight:400;line-height:1}.dual-slider{width:100%;height:36px;position:relative}.dual-slider-track{background:var(--border);border-radius:3px;height:6px;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.dual-slider-fill{background:var(--sage);border-radius:3px;height:100%;position:absolute;top:0}.dual-slider-input{appearance:none;pointer-events:none;background:0 0;outline:none;width:100%;height:100%;margin:0;position:absolute;top:0;left:0}.dual-slider-input::-webkit-slider-thumb{appearance:none;background:var(--white);border:2px solid var(--sage);cursor:grab;pointer-events:auto;z-index:2;border-radius:50%;width:24px;height:24px;position:relative;box-shadow:0 1px 4px #0000001f}.dual-slider-input::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.15);box-shadow:0 2px 8px #a8b5a066}.dual-slider-input::-moz-range-thumb{background:var(--white);border:2px solid var(--sage);cursor:grab;pointer-events:auto;border-radius:50%;width:24px;height:24px;box-shadow:0 1px 4px #0000001f}.dual-slider-input::-moz-range-thumb:active{cursor:grabbing}.dual-slider-min{z-index:3}.dual-slider-max{z-index:2}.values-group{width:100%;margin-top:0}.values-group label{color:var(--warm-black);letter-spacing:.06em;text-transform:uppercase;text-align:left;margin-bottom:.6rem;font-family:Inter,-apple-system,sans-serif;font-size:.75rem;font-weight:600}.value-chips{flex-wrap:wrap;justify-content:flex-start;gap:.5rem;display:flex}.value-chip{border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--white);color:var(--warm-gray);cursor:pointer;transition:all var(--transition);letter-spacing:0;box-shadow:none;text-transform:capitalize;white-space:nowrap;padding:.55rem 1rem;font-family:Inter,-apple-system,sans-serif;font-size:.85rem;font-weight:500}.value-chip:hover{border-color:var(--sage);color:var(--warm-dark);background:var(--sage-very-light);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.value-chip.active{background:var(--sage);border-color:var(--sage);color:var(--white);font-weight:600;box-shadow:0 2px 6px #8a9d7a40}.results-count{color:var(--light-gray);text-align:left;margin-top:0;font-size:.8rem;font-weight:400}.book-grid{max-width:1200px;padding:var(--spacing-xl) var(--spacing-lg) var(--spacing-2xl);flex:1;grid-template-columns:1fr;gap:clamp(2rem,4vw,2.5rem) clamp(1rem,2.5vw,1.5rem);margin:0 auto;display:grid}@media (width<=640px){.value-chip{padding:.35rem .6rem;font-size:.7rem}}@media (width>=480px){.book-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=640px){.book-grid{grid-template-columns:repeat(3,1fr)}}@media (width>=768px){.book-grid{grid-template-columns:repeat(4,1fr)}}@media (width>=1024px){.book-grid{grid-template-columns:repeat(5,1fr)}}@media (width>=1280px){.book-grid{grid-template-columns:repeat(6,1fr)}}.book-card{color:inherit;transition:transform var(--transition);flex-direction:column;text-decoration:none;display:flex}.book-card.clickable{cursor:pointer}.book-card.clickable:hover{transform:translateY(-6px)}.book-card.non-clickable{cursor:default}.book-cover-container{border-radius:var(--radius-md);width:100%;box-shadow:var(--shadow-md);transition:box-shadow var(--transition);background:#f5f3ed;margin-bottom:clamp(.75rem,1.5vw,1rem);padding-bottom:150%;position:relative;overflow:hidden}.book-card.clickable:hover .book-cover-container{box-shadow:var(--shadow-lg)}.book-cover{object-fit:contain;background:#f5f3ed;width:100%;height:100%;padding:8px;position:absolute;top:0;left:0}.book-cover-placeholder{text-align:center;background:linear-gradient(135deg,#f5f3ed 0%,#e8e4dc 100%);border:1px solid #1a16140f;justify-content:center;align-items:center;width:100%;height:100%;padding:1.5rem;display:flex;position:absolute;top:0;left:0}.book-cover-placeholder-title{color:var(--warm-gray);letter-spacing:-.01em;font-family:Inter,-apple-system,sans-serif;font-size:clamp(.875rem,1.8vw,1rem);font-weight:500;line-height:1.4}.book-year-badge{color:var(--gold-light);border-radius:var(--radius-sm);letter-spacing:.02em;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2;background:#1a1614d9;padding:.25rem .5rem;font-family:Inter,-apple-system,sans-serif;font-size:.6875rem;font-weight:600;position:absolute;top:8px;right:8px;box-shadow:0 2px 8px #0003}.book-info{flex-direction:column;flex:1;padding:0 4px;display:flex}.book-title{-webkit-line-clamp:2;letter-spacing:-.02em;color:var(--warm-black);-webkit-box-orient:vertical;margin-bottom:.375rem;font-family:Inter,-apple-system,sans-serif;font-size:clamp(.9375rem,2vw,1.0625rem);font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.book-author{color:var(--warm-gray);-webkit-line-clamp:2;letter-spacing:-.01em;-webkit-box-orient:vertical;margin-bottom:.5rem;font-size:clamp(.8125rem,1.6vw,.875rem);font-weight:400;line-height:1.4;display:-webkit-box;overflow:hidden}.illustrator{color:var(--light-gray);font-style:italic}.book-description{color:var(--warm-gray);-webkit-line-clamp:3;letter-spacing:-.01em;-webkit-box-orient:vertical;margin-bottom:.625rem;font-size:clamp(.8125rem,1.5vw,.875rem);line-height:1.5;display:-webkit-box;overflow:hidden}.book-meta{flex-wrap:wrap;gap:.375rem;margin-top:auto;font-size:0;display:flex}.book-badge{border-radius:var(--radius-sm);letter-spacing:.01em;white-space:nowrap;padding:.3125rem .625rem;font-family:Inter,-apple-system,sans-serif;font-size:.6875rem;font-weight:600}.badge-age{color:#4a5e3e;background:#8a9d7a1f;border:1px solid #8a9d7a33}.badge-type{color:#7a6335;background:#c9a96e1f;border:1px solid #c9a96e33}.empty-state{text-align:center;padding:clamp(3rem, 8vw, 5rem) var(--spacing-lg);color:var(--warm-gray);flex:1;justify-content:center;align-items:center;display:flex}.empty-state p{letter-spacing:-.01em;font-size:1.0625rem;font-weight:500;line-height:1.6}.loading{text-align:center;color:var(--warm-gray);letter-spacing:-.01em;padding:clamp(3rem,8vw,5rem);font-size:1.0625rem;font-weight:500}.footer{background:var(--warm-black);color:#a09890d9;padding:var(--spacing-xl) var(--spacing-lg);text-align:center;letter-spacing:-.01em;margin-top:auto;font-size:.875rem}.footer p{margin-bottom:.5rem;line-height:1.7}.footer p:last-child{margin-bottom:0}.footer a{color:var(--gold);transition:color var(--transition);border-bottom:1px solid #0000;text-decoration:none}.footer a:hover{color:var(--gold-light);border-bottom-color:#c9a96e66}
