@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/8a480f0b521d4e75-s.8e0177b5.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7178b3e590c64307-s.b97b3418.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/caa3a2e1cccd8315-s.p.853070df.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Fallback;src:local(Arial);ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.0%;size-adjust:104.76%}.geist_a71539c9-module__T19VSG__className{font-family:Geist,Geist Fallback;font-style:normal}.geist_a71539c9-module__T19VSG__variable{--font-geist-sans:"Geist","Geist Fallback"}
@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/4fa387ec64143e14-s.c1fdd6c2.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/bbc41e54d2fcbd21-s.799d8ef8.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/797e433ab948586e-s.p.dbea232f.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Mono Fallback;src:local(Arial);ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.0%;size-adjust:134.59%}.geist_mono_8d43a2aa-module__8Li5zG__className{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}.geist_mono_8d43a2aa-module__8Li5zG__variable{--font-geist-mono:"Geist Mono","Geist Mono Fallback"}
:root{--background:#fff;--foreground:#171717;--primary:#0070f3;--secondary:#666;--card-bg:#fff;--card-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--overlay-bg:#000c}@media (prefers-color-scheme:dark){:root{--background:#0a0a0a;--foreground:#ededed;--secondary:#a1a1a1;--card-bg:#171717;--card-shadow:0 4px 6px -1px #00000080,0 2px 4px -1px #0000004d}}*{box-sizing:border-box}body{color:var(--foreground);background:var(--background);margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol}.main-container{max-width:1400px;min-height:100vh;margin:0 auto;padding:2rem}.app-header{text-align:center;margin-bottom:4rem}.app-title{background:linear-gradient(90deg,#0070f3,#00c6ff);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:.5rem;font-size:3rem;font-weight:800}.app-subtitle{color:var(--secondary);font-size:1.2rem}.book-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:3rem;padding:2rem;display:grid}.book-item{perspective:1000px;cursor:pointer}.book-cover{aspect-ratio:1/1.4;width:100%;box-shadow:var(--card-shadow);transform-style:preserve-3d;text-align:center;border-radius:4px;flex-direction:column;justify-content:center;align-items:center;padding:1rem;transition:transform .5s,box-shadow .5s;display:flex;position:relative;overflow:hidden}.book-item:hover .book-cover{transform:rotateY(-15deg)scale(1.05);box-shadow:0 20px 25px -5px #0003,0 10px 10px -5px #0000001a}.book-spine{background:#0003;border-top-left-radius:4px;border-bottom-left-radius:4px;width:12px;position:absolute;top:0;bottom:0;left:0}.book-info{z-index:10;transform:translateZ(20px)}.book-title{color:#fff;text-shadow:0 2px 4px #00000080;margin:0 0 .5rem;font-size:1.1rem;font-weight:700}.book-author{color:#ffffffe6;text-shadow:0 1px 2px #00000080;margin:0;font-size:.9rem}.book-detail-overlay{z-index:100;background-color:var(--overlay-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);justify-content:center;align-items:center;padding:2rem;animation:.3s ease-out fadeIn;display:flex;position:fixed;inset:0}.close-button{color:#fff9;cursor:pointer;z-index:110;background:0 0;border:none;font-size:3rem;line-height:1;transition:color .2s;position:absolute;top:1.5rem;right:1.5rem}.close-button:hover{color:#fff}.book-detail-card{background-color:var(--card-bg);border-radius:1rem;flex-direction:column;width:100%;max-width:1200px;height:80vh;animation:.4s cubic-bezier(.16,1,.3,1) slideUp;display:flex;overflow:hidden;box-shadow:0 25px 50px -12px #00000080}@media (min-width:768px){.book-detail-card{flex-direction:row}}.book-3d-container{background-color:#f5f5f5;flex-shrink:0;width:100%;height:50%;position:relative}@media (prefers-color-scheme:dark){.book-3d-container{background-color:#262626}}@media (min-width:768px){.book-3d-container{width:50%;height:100%}}.book-info-container{flex-direction:column;flex:1;justify-content:flex-start;width:100%;height:50%;padding:2.5rem;display:flex;overflow-y:auto}@media (min-width:768px){.book-info-container{width:50%;height:100%;padding:4rem}}.detail-title{margin:0 0 .5rem;font-size:2.5rem;font-weight:800;line-height:1.1}.detail-author{color:var(--secondary);margin:0 0 2rem;font-size:1.25rem;font-weight:500}.detail-content{flex-direction:column;gap:1.5rem;display:flex}.detail-description{color:var(--foreground);opacity:.9;font-size:1.1rem;line-height:1.6}.detail-meta{border-top:1px solid #80808033;margin-top:2rem;padding-top:2rem}.meta-grid{grid-template-columns:1fr;row-gap:1rem;display:grid}.meta-item{flex-direction:column;display:flex}.meta-label{text-transform:uppercase;letter-spacing:.05em;color:var(--secondary);margin-bottom:.25rem;font-size:.85rem}.status-badge{text-transform:capitalize;border-radius:9999px;width:fit-content;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-block}.status-badge.read{color:#059669;background-color:#10b9811a}.status-badge.reading{color:#2563eb;background-color:#3b82f61a}.status-badge.want_to_read{color:#d97706;background-color:#f59e0b1a}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.readers-section{border-top:1px solid #80808033;margin-top:2rem;padding-top:2rem}.readers-title{color:var(--foreground);margin-bottom:1rem;font-size:1.1rem;font-weight:600}.readers-list{flex-direction:column;gap:.5rem;display:flex}.reader-item{border-left:3px solid var(--primary);background-color:#8080800d;border-radius:6px;padding:.75rem;font-size:.95rem}.reader-name{color:var(--foreground);font-weight:600}.reader-status{color:var(--secondary)}.stripe-container{flex-direction:column;width:100vw;min-height:100vh;transition:background-color .5s,color .5s;display:flex;overflow:hidden}.stripe-content{flex-direction:column;flex:1;width:100%;height:100%;display:flex}.stripe-book-section{justify-content:center;align-items:center;width:100%;height:50vh;display:flex;position:relative}.stripe-details-section{z-index:10;flex-direction:column;justify-content:flex-start;width:100%;height:50vh;padding:2rem;display:flex;overflow-y:auto}@media (min-width:768px){.stripe-content{flex-direction:row}.stripe-book-section{width:50%;height:100vh}.stripe-details-section{justify-content:center;width:50%;height:100vh;padding:4rem}}.list-view-toggle{z-index:50;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;color:inherit;background:#fff3;border:1px solid #ffffff4d;border-radius:9999px;padding:.5rem 1rem;font-size:.9rem;font-weight:600;transition:all .2s;position:absolute;top:1.5rem;left:1.5rem}.list-view-toggle:hover{background:#ffffff4d;transform:translateY(-1px)}.stripe-title{margin-bottom:1rem;font-family:serif;font-size:2.5rem;font-weight:700;line-height:1.1}.stripe-author{opacity:.8;margin-bottom:2rem;font-size:1.25rem;font-style:italic}.stripe-divider{opacity:.3;background-color:currentColor;width:50px;height:2px;margin-bottom:2rem}.stripe-description{opacity:.9;max-width:600px;font-size:1.1rem;line-height:1.6}@media (min-width:768px){.stripe-title{font-size:3.5rem}.stripe-author{font-size:1.5rem}}.nav-hint-desktop{display:none}.nav-hint-mobile{display:block}@media (min-width:768px){.nav-hint-desktop{display:block}.nav-hint-mobile{display:none}}
