@import "https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Crimson+Pro:ital,wght@0,300;0,400;0,500;0,600;1,400&family=JetBrains+Mono:wght@400;500&family=Mrs+Saint+Delafield&display=swap";:root{--bg-primary:#f5f0e8;--bg-secondary:#ece6d9;--bg-tertiary:#e4ddd0;--bg-card:#faf7f2;--bg-card-hover:#f7f3eb;--bg-glass:#f5f0e8eb;--text-primary:#1a1510;--text-secondary:#4a4035;--text-muted:#8a7e70;--text-accent:#9e7c3c;--accent-primary:#c8a84b;--accent-secondary:#a88a32;--accent-tertiary:#9e7c3c;--accent-glow:#c8a84b14;--accent-glow-strong:#c8a84b26;--gradient-primary:linear-gradient(135deg, #c8a84b 0%, #a88a32 100%);--gradient-accent:linear-gradient(135deg, #d4b85a 0%, #c8a84b 50%, #a88a32 100%);--gradient-subtle:linear-gradient(135deg, #c8a84b0f 0%, #a88a3208 100%);--gradient-hero:radial-gradient(ellipse at 20% 50%, #c8a84b0f 0%, transparent 50%), radial-gradient(ellipse at 80% 20%, #a88a320a 0%, transparent 40%), radial-gradient(ellipse at 50% 80%, #c8a84b08 0%, transparent 50%);--border-subtle:#e0d8c8;--border-medium:#cfc5b0;--border-strong:#b8ad96;--tag-lifestyle:#5a8a5a;--tag-philosophy:#5a6a8a;--tag-music:#8a5a70;--tag-culture:#8a7a3a;--tag-books:#7a6a4a;--tag-personal:#a0704a;--tag-mindfulness:#4a7a6a;--tag-writing:#7a5a7a;--tag-creativity:#8a5a4a;--font-sans:"Crimson Pro", Georgia, "Times New Roman", serif;--font-serif:"Playfair Display", Georgia, "Times New Roman", serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--text-5xl:3rem;--text-6xl:3.75rem;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-2xl:1.5rem;--radius-full:9999px;--shadow-sm:0 1px 2px #1a15100f;--shadow-md:0 4px 6px -1px #1a151014, 0 2px 4px -2px #1a15100f;--shadow-lg:0 10px 15px -3px #1a151014, 0 4px 6px -4px #1a15100f;--shadow-xl:0 20px 25px -5px #1a15101a, 0 8px 10px -6px #1a15100f;--shadow-glow:0 2px 12px #c8a84b14;--shadow-glow-strong:0 4px 20px #c8a84b1f;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-in-out:cubic-bezier(.65, 0, .35, 1);--duration-fast:.15s;--duration-normal:.25s;--duration-slow:.4s;--max-width:1200px;--max-width-narrow:800px;--nav-height:72px}[data-theme=dark]{--bg-primary:#1a1614;--bg-secondary:#241e1b;--bg-tertiary:#2a2420;--bg-card:#2a2420;--bg-card-hover:#332c28;--bg-glass:#1a1614eb;--text-primary:#e6dfd5;--text-secondary:#b5a898;--text-muted:#827769;--text-accent:#c8a84b;--border-subtle:#3a322d;--border-medium:#4a413a;--border-strong:#5a5048;--accent-primary:#c8a84b;--accent-secondary:#d4b85a;--accent-tertiary:#a88a32;--accent-glow:#c8a84b26;--accent-glow-strong:#c8a84b40;--status-success:#4ade80;--status-warning:#fbbf24;--status-error:#f87171;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 6px -1px #0006, 0 2px 4px -2px #0003;--shadow-lg:0 10px 15px -3px #00000080, 0 4px 6px -4px #0000004d;--shadow-xl:0 20px 25px -5px #0009, 0 8px 10px -6px #0006}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);font-size:var(--text-base);color:var(--text-primary);background-color:var(--bg-primary);min-height:100vh;line-height:1.6;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)' opacity='0.03'/%3E%3C/svg%3E");width:100%;height:100%;position:fixed;top:0;left:0}#root{z-index:1;flex-direction:column;min-height:100vh;display:flex;position:relative}main{flex:1}a{color:var(--accent-secondary);transition:color var(--duration-fast) var(--ease-out);text-decoration:none}a:hover{color:var(--accent-primary)}img{max-width:100%;display:block}h1,h2,h3,h4,h5,h6{font-family:var(--font-serif);color:var(--text-primary);line-height:1.2}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--accent-primary)}.container{max-width:var(--max-width);padding:0 var(--space-6);margin:0 auto}.container--narrow{max-width:var(--max-width-narrow)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 10px #c8a84b26}50%{box-shadow:0 0 20px #c8a84b4d}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-fade-in{animation:fadeIn var(--duration-slow) var(--ease-out) both}.animate-fade-in-up{animation:fadeInUp var(--duration-slow) var(--ease-out) both}.animate-stagger-1{animation-delay:50ms}.animate-stagger-2{animation-delay:.1s}.animate-stagger-3{animation-delay:.15s}.animate-stagger-4{animation-delay:.2s}.animate-stagger-5{animation-delay:.25s}.animate-stagger-6{animation-delay:.3s}.animate-stagger-7{animation-delay:.35s}.animate-stagger-8{animation-delay:.4s}::selection{background:var(--accent-primary);color:#fff}.fulfillment-subtitle{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:var(--space-6);text-align:center;font-size:10px}.fulfillment-divider{background:linear-gradient(to right, transparent, var(--border-subtle), transparent);height:1px;margin:var(--space-8) 0;width:100%}.fulfillment-manual-override{gap:var(--space-2);margin-top:var(--space-4);background:var(--bg-secondary);padding:var(--space-2) var(--space-4);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);transition:all .3s;display:flex}.fulfillment-manual-override:focus-within{border-color:var(--accent-primary);box-shadow:0 0 0 4px var(--accent-primary-alpha)}.fulfillment-manual-override input{color:var(--text-primary);font-family:var(--font-mono);padding:var(--space-2) 0;background:0 0;border:none;outline:none;flex:1;font-size:12px}.fulfillment-manual-submit{color:var(--accent-primary);cursor:pointer;padding:0 var(--space-2);background:0 0;border:none;justify-content:center;align-items:center;transition:transform .2s;display:flex}.fulfillment-manual-submit:hover:not(:disabled){transform:translate(3px)}.fulfillment-manual-submit:disabled{opacity:.3;cursor:not-allowed}.fulfillment-manual-submit .arrow{font-size:18px;font-weight:300}.fulfillment-isbn-search{gap:var(--space-2);margin-bottom:var(--space-6);background:var(--bg-secondary);padding:var(--space-2) var(--space-4);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);transition:all .3s;display:flex}.fulfillment-isbn-search:focus-within{border-color:var(--accent-primary)}.fulfillment-isbn-search input{color:var(--text-primary);font-family:var(--font-mono);background:0 0;border:none;outline:none;flex:1;font-size:12px}.fulfillment-isbn-search button{background:var(--accent-primary);color:var(--bg-primary);padding:var(--space-1) var(--space-4);border-radius:var(--radius-md);font-family:var(--font-mono);text-transform:uppercase;cursor:pointer;border:none;font-size:10px;font-weight:700}.theme-toggle{cursor:pointer;border-radius:var(--radius-full);color:var(--text-secondary);transition:all var(--duration-fast) var(--ease-out);background:0 0;border:none;justify-content:center;align-items:center;width:40px;height:40px;padding:0;display:flex}.theme-toggle:hover{background:var(--bg-tertiary);color:var(--accent-primary);transform:scale(1.05)}.theme-toggle:active{transform:scale(.95)}.theme-toggle__icon{font-size:1.25rem;line-height:1;transition:transform .5s cubic-bezier(.68,-.55,.265,1.55)}.theme-toggle__icon--dark{transform:rotate(360deg)}.navbar{height:var(--nav-height);z-index:1000;background:var(--bg-glass);-webkit-backdrop-filter:blur(20px)saturate(180%);border-bottom:1px solid var(--border-subtle);animation:fadeInDown var(--duration-slow) var(--ease-out);position:fixed;top:0;left:0;right:0}.navbar__inner{justify-content:space-between;align-items:center;height:100%;display:flex}.navbar__logo{font-family:"Playfair Display", var(--font-serif);color:var(--accent-primary);letter-spacing:.08em;text-transform:uppercase;transition:opacity var(--duration-fast);white-space:nowrap;font-size:1.1rem;font-weight:600}.navbar__logo:hover{opacity:.8}.navbar__menu{align-items:center;gap:var(--space-8);display:flex}.navbar__links{align-items:center;gap:var(--space-6);margin:0;padding:0;list-style:none;display:flex}.navbar__item{position:relative}.navbar__link{font-family:var(--font-sans);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;padding:var(--space-2) 0;transition:color var(--duration-fast);align-items:center;gap:var(--space-1);background:0 0;border:none;font-weight:500;display:flex}.navbar__link:hover,.navbar__link.active{color:var(--text-primary)}.navbar__dropdown-arrow{transition:transform var(--duration-fast);opacity:.5}.navbar__item--has-dropdown:hover .navbar__dropdown-arrow{transform:rotate(180deg)}.navbar__dropdown{border-radius:var(--radius-md);min-width:180px;padding:var(--space-3);box-shadow:var(--shadow-xl);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);gap:var(--space-1);background:#12100e;border:1px solid #c8a84b4d;flex-direction:column;display:flex;position:absolute;top:100%;left:-20px}.navbar__dropdown-link{font-family:Crimson Pro,serif;font-size:var(--text-base);color:#ffffffb3;padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);transition:all var(--duration-fast)}.navbar__dropdown-link:hover{color:var(--accent-primary);padding-left:var(--space-4);background:#c8a84b1a}.navbar__actions{align-items:center;gap:var(--space-5);border-left:1px solid var(--border-subtle);padding-left:var(--space-6);display:flex}.navbar__utility-link{color:var(--text-muted);cursor:pointer;transition:color var(--duration-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.navbar__utility-link:hover{color:var(--accent-primary)}.navbar__hamburger{cursor:pointer;z-index:2000;background:0 0;border:none;flex-direction:column;justify-content:space-between;width:24px;height:16px;padding:0;display:none}.navbar__hamburger span{background-color:var(--text-primary);width:100%;height:2px;transition:all .3s var(--ease-out);border-radius:2px}.navbar__hamburger--open span:first-child{transform:translateY(7px)rotate(45deg)}.navbar__hamburger--open span:nth-child(2){opacity:0}.navbar__hamburger--open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}@media (width<=768px){.navbar__hamburger{display:flex}.navbar__logo{font-size:.9rem}.navbar__menu{width:100%;height:100vh;padding:var(--space-20) var(--space-8);transition:transform .5s var(--ease-out);justify-content:center;gap:var(--space-10);background:#12100e;flex-direction:column;position:fixed;top:0;left:0;transform:translate(100%)}.navbar__menu--open{transform:translate(0)}.navbar__links{align-items:flex-start;gap:var(--space-8);flex-direction:column;width:100%}.navbar__item{width:100%}.navbar__link{font-size:var(--text-2xl);width:100%}.navbar__dropdown{box-shadow:none;padding:var(--space-4) 0 0 var(--space-4);opacity:1;background:0 0;border:none;position:static;transform:none}.navbar__dropdown-link{font-size:var(--text-xl)}.navbar__actions{padding-left:0;padding-top:var(--space-10);justify-content:center;gap:var(--space-10);border-top:1px solid #ffffff1a;border-left:none;width:100%}.navbar__utility-link svg{width:28px;height:28px}}.footer{padding:var(--space-16) 0 var(--space-8);border-top:1px solid var(--border-subtle);background:var(--bg-secondary);margin-top:auto}.footer__inner{gap:var(--space-8);flex-direction:column;display:flex}.footer__top{gap:var(--space-3);flex-direction:column;display:flex}.footer__brand{align-items:center;gap:var(--space-2);display:flex}.footer__logo-dot{background:var(--gradient-primary);border-radius:50%;width:6px;height:6px}.footer__logo-text{font-family:var(--font-sans);font-size:var(--text-base);color:var(--text-primary);letter-spacing:-.02em;font-weight:600}.footer__tagline{color:var(--text-muted);font-size:var(--text-sm);font-style:italic;font-family:var(--font-serif)}.footer__divider{background:var(--border-subtle);height:1px}.footer__bottom{justify-content:space-between;align-items:center;display:flex}.footer__copyright{color:var(--text-muted);font-size:var(--text-sm)}.footer__links{gap:var(--space-6);display:flex}.footer__link{color:var(--text-muted);font-size:var(--text-sm);transition:color var(--duration-fast) var(--ease-out);font-weight:500}.footer__link:hover{color:var(--accent-secondary)}@media (width<=640px){.footer__bottom{gap:var(--space-4);flex-direction:column;align-items:flex-start}}.now-playing{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-4);max-width:320px;box-shadow:var(--shadow-sm);transition:all .3s}.now-playing:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-md), var(--shadow-glow)}.now-playing__container{align-items:center;gap:var(--space-4);display:flex}.now-playing__image{border-radius:var(--radius-sm);flex-shrink:0;width:60px;height:60px;position:relative;overflow:hidden;box-shadow:0 4px 10px #0003}.now-playing__image img{object-fit:cover;width:100%;height:100%}.now-playing__info{min-width:0}.now-playing__status{font-family:var(--font-mono);color:var(--accent-primary);text-transform:uppercase;letter-spacing:1px;margin-bottom:2px;font-size:10px}.now-playing__title{font-family:var(--font-serif);font-size:var(--text-sm);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-weight:600;text-decoration:none;display:block;overflow:hidden}.now-playing__title:hover{color:var(--accent-primary)}.now-playing__artist{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.now-playing__equalizer{align-items:flex-end;gap:2px;height:12px;display:flex;position:absolute;bottom:4px;right:4px}.eq-bar{background:var(--accent-primary);border-radius:1px;width:3px;animation:1s ease-in-out infinite eq-bounce}.bar-1{height:100%;animation-delay:0s}.bar-2{height:60%;animation-delay:.2s}.bar-3{height:80%;animation-delay:.4s}@keyframes eq-bounce{0%,to{transform:scaleY(.4)}50%{transform:scaleY(1)}}.now-playing--offline{opacity:.8;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-6);border-style:dashed;display:flex}.now-playing--offline .now-playing__icon{filter:grayscale();font-size:1.5rem}.now-playing--offline .now-playing__status{color:var(--text-muted)}.now-playing--offline .now-playing__track{font-family:var(--font-serif);font-size:var(--text-sm);color:var(--text-secondary);display:block}.home{background:var(--bg-primary);min-height:100vh;position:relative}.home__noise-overlay{z-index:1000;pointer-events:none;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");position:fixed;inset:0}.hero{padding:calc(var(--nav-height) + var(--space-20)) 0 var(--space-16);position:relative;overflow:hidden}.hero__text-wrapper{justify-content:space-between;align-items:center;gap:var(--space-12);width:100%;display:flex}.hero__text{max-width:600px}.hero__greeting{font-family:var(--font-mono);color:var(--accent-secondary);text-transform:uppercase;letter-spacing:.3em;margin-bottom:var(--space-6);opacity:.8;font-size:10px}.hero__title{font-family:var(--font-serif);letter-spacing:-.02em;margin-bottom:var(--space-8);font-size:clamp(3rem,8vw,5rem);font-weight:700;line-height:1}.hero__title-line{background:linear-gradient(135deg, var(--text-primary) 0%, var(--accent-primary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero__subtitle{font-family:var(--font-sans);font-size:var(--text-xl);color:var(--text-secondary);max-width:500px;line-height:1.6}.hero-reading-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-lg);padding:var(--space-6);width:380px;box-shadow:var(--shadow-xl), 0 20px 40px #0006;background:#12100e99;border:1px solid #c8a84b33;flex-shrink:0;position:relative;overflow:hidden;transform:rotate(1.5deg)translateY(-20px)}.hero-reading-card__glass{pointer-events:none;background:linear-gradient(135deg,#ffffff0d 0%,#0000 100%);position:absolute;inset:0}.hero-reading-card__header{border-bottom:1px solid var(--border-subtle);margin-bottom:var(--space-5);padding-bottom:var(--space-2)}.hero-reading-card__badge{font-family:var(--font-mono);color:var(--accent-secondary);letter-spacing:.15em;font-size:9px}.hero-reading-card__content{gap:var(--space-6);align-items:center;display:flex}.hero-reading-card__cover-3d{perspective:1000px;flex-shrink:0}.hero-reading-card__cover{object-fit:contain;border-radius:var(--radius-sm);width:85px;height:125px;transition:transform .4s var(--ease-out);background-color:#ffffff0d;transform:rotateY(-15deg);box-shadow:12px 12px 25px #00000080}.hero-reading-card:hover .hero-reading-card__cover{transform:rotateY(-5deg)scale(1.02)}.hero-reading-card__cover-placeholder{background:var(--bg-tertiary);width:85px;height:125px;font-family:var(--font-serif);font-size:var(--text-2xl);color:var(--accent-primary);border-radius:var(--radius-sm);justify-content:center;align-items:center;display:flex;transform:rotateY(-15deg)}.hero-reading-card__info{flex-direction:column;flex:1;display:flex}.hero-reading-card__title{font-family:var(--font-serif);font-size:var(--text-lg);color:var(--text-primary);margin-bottom:2px;line-height:1.2}.hero-reading-card__author{font-family:var(--font-sans);font-size:var(--text-xs);color:var(--text-muted);margin-bottom:var(--space-4)}.hero-reading-card__progress-meta{margin-bottom:var(--space-2);justify-content:space-between;align-items:baseline;display:flex}.hero-reading-card__percent{font-family:var(--font-serif);font-weight:700;font-size:var(--text-sm);color:var(--accent-primary)}.hero-reading-card__pages{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;font-size:8px}.hero-reading-card__progress-track{border-radius:var(--radius-full);width:100%;height:3px;margin-bottom:var(--space-3);background:#ffffff0d;overflow:hidden}.hero-reading-card__progress-fill{background:var(--accent-primary);height:100%;box-shadow:0 0 10px var(--accent-primary);transition:width 1.5s var(--ease-out)}.hero-reading-card__edit-hint{font-family:var(--font-mono);color:var(--accent-secondary);text-transform:uppercase;letter-spacing:.1em;opacity:.6;margin-top:auto;font-size:8px;text-decoration:none;transition:opacity .2s}.hero-reading-card__edit-hint:hover{opacity:1}.shelf-section{padding:var(--space-20) 0;background:linear-gradient(to bottom, var(--bg-primary), var(--bg-secondary));border-top:1px solid var(--border-subtle)}.shelf-header{margin-bottom:var(--space-10);justify-content:space-between;align-items:flex-end;gap:var(--space-6);flex-wrap:wrap;display:flex}.shelf-title{font-family:var(--font-serif);font-size:var(--text-2xl);font-weight:600}.shelf-link{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--accent-secondary);text-transform:uppercase;letter-spacing:.1em;font-weight:600}.shelf-row{gap:var(--space-6);padding:var(--space-4) 0 var(--space-8);scrollbar-width:none;display:flex;overflow-x:auto}.shelf-row::-webkit-scrollbar{display:none}.shelf-item{flex-shrink:0;width:140px}.shelf-item__cover{object-fit:contain;border-radius:var(--radius-sm);width:100%;height:210px;box-shadow:var(--shadow-lg);transition:all .4s var(--ease-out);border:1px solid var(--border-subtle);background-color:#ffffff0d}.shelf-item:hover .shelf-item__cover{transform:translateY(-5px);box-shadow:0 15px 30px #0003}.shelf-item__placeholder{background:var(--bg-tertiary);width:100%;height:210px;font-family:var(--font-serif);font-size:var(--text-3xl);color:var(--accent-primary);border-radius:var(--radius-sm);border:1px solid var(--border-subtle);justify-content:center;align-items:center;display:flex}.footnotes-section{padding:var(--space-12) 0 var(--space-16);background:var(--bg-secondary);border-top:1px solid var(--border-subtle)}.footnotes-header{margin-bottom:var(--space-8)}.footnotes-micro-tag{font-family:var(--font-mono);color:var(--accent-secondary);letter-spacing:.2em;margin-bottom:2px;font-size:9px;display:block}.footnotes-title{font-family:var(--font-serif);font-size:var(--text-xl);color:var(--text-primary);font-weight:600}.footnotes-grid{grid-template-columns:repeat(3,1fr);align-items:stretch;gap:2rem;display:grid}.footnote-editorial,.footnote-travel,.footnote-spotify{flex-direction:column;height:100%;min-height:280px;display:flex}.footnote-editorial{padding:var(--space-6) 0 var(--space-6) var(--space-8);border-left:2px solid var(--accent-primary);transition:transform .3s var(--ease-out);background:0 0;text-decoration:none;position:relative}.footnote-editorial:hover{transform:translate(8px)}.footnote-editorial__date{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--space-4);font-size:8px}.footnote-editorial__title{font-family:var(--font-serif);font-size:var(--text-lg);color:var(--text-primary);margin-bottom:var(--space-4);line-height:1.3}.footnote-editorial__excerpt{font-family:Crimson Pro,serif;font-size:var(--text-base);color:var(--text-secondary);-webkit-line-clamp:2;margin-bottom:var(--space-6);-webkit-box-orient:vertical;font-style:italic;line-height:1.5;display:-webkit-box;overflow:hidden}.footnote-editorial__link{font-family:var(--font-mono);color:var(--accent-primary);text-transform:uppercase;margin-top:auto;font-size:9px;font-weight:700}.footnote-travel{border-radius:var(--radius-md);padding:var(--space-8);background:var(--bg-card);box-shadow:var(--shadow-md);text-decoration:none;position:relative;overflow:hidden}.footnote-travel__bg{transition:transform .6s var(--ease-out);background-position:50%;background-size:cover;position:absolute;inset:0}.footnote-travel:hover .footnote-travel__bg{transform:scale(1.08)}.footnote-travel__overlay{background:linear-gradient(#0003 0%,#0006 40%,#000000e6 100%);position:absolute;inset:0}.footnote-travel__content{z-index:2;margin-top:auto;position:relative}.footnote-travel__label{font-family:var(--font-mono);color:var(--accent-primary);text-transform:uppercase;letter-spacing:.15em;margin-bottom:var(--space-2);font-size:8px;display:block}.footnote-travel__title{font-family:var(--font-serif);font-size:var(--text-lg);color:#fff;margin-bottom:4px;line-height:1.2}.footnote-travel__location{font-family:var(--font-sans);font-size:var(--text-xs);color:#ffffffb3}.footnote-spotify{flex-direction:column;display:flex}.footnote-spotify__player{border:1px solid var(--border-medium);border-radius:var(--radius-md);padding:var(--space-8);background:#12100e;flex-direction:column;height:100%;display:flex;position:relative;overflow:hidden;box-shadow:0 8px 25px #0006}.footnote-spotify__header{align-items:center;gap:var(--space-3);margin-bottom:var(--space-6);display:flex}.footnote-spotify__label{font-family:var(--font-mono);color:var(--accent-secondary);text-transform:uppercase;letter-spacing:.15em;font-size:8px}.footnote-spotify__eq{align-items:flex-end;gap:2px;height:10px;display:flex}.footnote-spotify__eq span{background:var(--accent-primary);width:2px;animation:1s ease-in-out infinite eq-pulse}.footnote-spotify__eq span:first-child{height:100%}.footnote-spotify__eq span:nth-child(2){height:60%;animation-delay:.2s}.footnote-spotify__eq span:nth-child(3){height:80%;animation-delay:.4s}@keyframes eq-pulse{0%,to{transform:scaleY(.4)}50%{transform:scaleY(1)}}.footnote-spotify__player .now-playing{box-shadow:none;background:0 0;border:none;flex:1;align-items:center;margin-top:0;padding:0;display:flex}.footnote-spotify__player .now-playing__container{gap:var(--space-6);width:100%}.footnote-spotify__player .now-playing__image{border-radius:var(--radius-sm);width:75px;height:75px;position:relative;box-shadow:0 4px 15px #00000080}.footnote-spotify__player .now-playing__image:after{content:"";background:var(--accent-primary);filter:blur(15px);opacity:.15;z-index:-1;position:absolute;inset:-5px}.footnote-spotify__player .now-playing__status{display:none}.footnote-spotify__player .now-playing__title{font-size:var(--text-base);color:#fff;margin-bottom:4px}.footnote-spotify__player .now-playing__artist{font-size:var(--text-xs);color:#ffffff80}.footnote-spotify__progress-bar{background:var(--accent-primary);opacity:.6;width:100%;height:2px;position:absolute;bottom:0;left:0}@media (width<=1024px){.hero{padding-bottom:var(--space-24)}.hero__text-wrapper{text-align:center;gap:var(--space-16);flex-direction:column}.hero__subtitle{margin-left:auto;margin-right:auto}.hero-reading-card{margin-top:var(--space-8);width:100%;max-width:420px;margin-left:auto;margin-right:auto;transform:none}.footnotes-grid{gap:var(--space-12);grid-template-columns:1fr}.footnote-editorial,.footnote-travel,.footnote-spotify{min-height:220px}}@media (width<=640px){.hero__title{font-size:2.8rem}.shelf-header{align-items:flex-start;gap:var(--space-2);flex-direction:column}.shelf-link{margin-top:var(--space-2);align-self:flex-end}.shelf-item{width:120px}.shelf-item__cover,.shelf-item__placeholder{height:180px}}.blog-card{border-radius:var(--radius-xl);border:1px solid var(--border-subtle);background:var(--bg-card);transition:all var(--duration-normal) var(--ease-out);overflow:hidden}.blog-card:hover{border-color:var(--border-medium);background:var(--bg-card-hover);box-shadow:var(--shadow-md), var(--shadow-glow);transform:translate(4px)}.blog-card__link{padding:var(--space-6) var(--space-8);align-items:center;gap:var(--space-6);color:inherit;text-decoration:none;display:flex}.blog-card__content{gap:var(--space-3);flex-direction:column;flex:1;display:flex}.blog-card__meta{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-muted);display:flex}.blog-card__separator{color:var(--text-muted)}.blog-card__title{font-family:var(--font-serif);font-size:var(--text-2xl);color:var(--text-primary);transition:color var(--duration-fast) var(--ease-out);font-weight:600;line-height:1.3}.blog-card:hover .blog-card__title{color:var(--accent-tertiary)}.blog-card__excerpt{font-size:var(--text-base);color:var(--text-secondary);line-height:1.6}.blog-card__tags{gap:var(--space-2);margin-top:var(--space-1);flex-wrap:wrap;display:flex}.blog-card__tag{font-size:var(--text-xs);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);background:color-mix(in srgb, var(--tag-color) 12%, transparent);color:var(--tag-color);letter-spacing:.02em;font-weight:500}.blog-card__arrow{color:var(--text-muted);transition:all var(--duration-normal) var(--ease-out);flex-shrink:0}.blog-card:hover .blog-card__arrow{color:var(--accent-secondary);transform:translate(4px)}@media (width<=640px){.blog-card__link{padding:var(--space-4) var(--space-5)}.blog-card__title{font-size:var(--text-xl)}.blog-card__arrow{display:none}}.blog-page{padding-top:calc(var(--nav-height) + var(--space-16));padding-bottom:var(--space-24);min-height:100vh}.page-header{margin-bottom:var(--space-12)}.page-header__title{font-family:var(--font-serif);letter-spacing:-.03em;margin-bottom:var(--space-4);background:linear-gradient(135deg, var(--text-primary) 0%, var(--accent-secondary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:clamp(2.5rem,6vw,3.75rem);font-weight:700}.page-header__subtitle{font-size:var(--text-lg);color:var(--text-secondary);max-width:500px;line-height:1.6}.blog-list{gap:var(--space-4);flex-direction:column;display:flex}.blog-post-page{padding:calc(var(--nav-height) + var(--space-8)) 0 var(--space-24)}.blog-post__back{margin-bottom:var(--space-8);font-size:var(--text-sm);color:var(--accent-secondary);transition:color var(--duration-fast) var(--ease-out);font-weight:500;display:inline-block}.blog-post__back:hover{color:var(--accent-primary)}.blog-post__featured-image{margin-bottom:var(--space-8);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden}.blog-post__featured-image img{width:100%;height:auto;display:block}.blog-post__header{margin-bottom:var(--space-8);text-align:center}.blog-post__meta{justify-content:center;align-items:center;gap:var(--space-3);font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-4);display:flex}.blog-post__title{font-family:var(--font-serif);color:var(--text-primary);margin-bottom:var(--space-6);font-size:clamp(2rem,5vw,3.5rem);font-weight:700;line-height:1.1}.blog-post__content{font-size:var(--text-lg);color:var(--text-secondary);line-height:1.8}.blog-post__content p{margin-bottom:var(--space-6)}.blog-post__content h2{font-family:var(--font-serif);font-size:var(--text-2xl);color:var(--text-primary);margin:var(--space-12) 0 var(--space-4)}.blog-post__content h3{font-family:var(--font-serif);font-size:var(--text-xl);color:var(--text-primary);margin:var(--space-8) 0 var(--space-4)}.blog-post__content ul,.blog-post__content ol{margin-bottom:var(--space-6);padding-left:var(--space-6)}.blog-post__content li{margin-bottom:var(--space-2)}.blog-post__content strong{color:var(--text-primary);font-weight:600}.blog-post__content em{font-style:italic}.blog-post__content blockquote{border-left:3px solid var(--accent-primary);padding-left:var(--space-6);margin:var(--space-8) 0;color:var(--text-primary);font-style:italic}.blog-post__content img{border-radius:var(--radius-lg);max-width:100%;height:auto;margin:var(--space-8) 0;box-shadow:var(--shadow-md)}.blog-post__linked-book{margin-top:var(--space-16);padding-top:var(--space-12);border-top:1px dashed var(--border-medium)}.blog-post__linked-book h3{font-family:var(--font-serif);font-size:var(--text-xl);color:var(--text-primary);margin-bottom:var(--space-6);text-align:center}.linked-book-card{gap:var(--space-6);padding:var(--space-6);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);max-width:400px;transition:all var(--duration-normal);margin:0 auto;display:flex}.linked-book-card:hover{border-color:var(--border-medium);box-shadow:var(--shadow-lg), var(--shadow-glow);transform:translateY(-2px)}.linked-book-card__cover{border-radius:var(--radius-md);object-fit:cover;width:80px;height:120px;box-shadow:var(--shadow-md);flex-shrink:0}.linked-book-card__cover--placeholder{background:var(--bg-tertiary);font-family:var(--font-serif);font-size:var(--text-2xl);color:var(--text-muted);justify-content:center;align-items:center;display:flex}.linked-book-card__info{flex-direction:column;justify-content:center;display:flex}.linked-book-card__info h4{font-family:var(--font-serif);font-size:var(--text-lg);color:var(--text-primary);margin-bottom:2px}.linked-book-card__info p{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-3);font-style:italic}.linked-book-card__link{font-size:var(--text-xs);color:var(--accent-primary);text-transform:uppercase;letter-spacing:.05em;margin-top:auto;font-weight:600}@media (width<=768px){.blog-post__title{font-size:var(--text-3xl)}}.top-artists{margin:var(--space-12) 0;perspective:1000px}.top-artists__bento{gap:var(--space-6);grid-template-columns:repeat(4,1fr);grid-auto-rows:180px;display:grid}.artist-bento-card{border-radius:var(--radius-xl);border:1px solid var(--border-subtle);cursor:pointer;transform-style:preserve-3d;background:#111;position:relative;overflow:hidden}.card--large{grid-area:span 2/span 2}.card--small{grid-area:span 1/span 1}.vinyl-wrapper{justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative}.artist-photo{object-fit:cover;width:100%;height:100%;transition:filter .5s}.artist-bento-card:hover .artist-photo{filter:brightness(.6)blur(2px)}.vinyl-grooves{z-index:2;pointer-events:none;opacity:0;background:repeating-radial-gradient(circle,#0000 0 2px,#ffffff0d 3px);width:100%;height:100%;transition:opacity .5s;position:absolute;top:0;left:0}.artist-bento-card:hover .vinyl-grooves{opacity:1}.artist-overlay{width:100%;padding:var(--space-4);z-index:3;background:linear-gradient(#0000,#000c);position:absolute;bottom:0;left:0}.artist-rank{font-family:var(--font-mono);color:var(--accent-primary);margin-bottom:2px;font-size:10px;display:block}.artist-name{font-family:var(--font-serif);font-size:var(--text-lg);color:#fff;margin:0;font-weight:600}.card--large .artist-name{font-size:var(--text-2xl)}.artist-genre{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-top:4px;font-size:10px}@media (width<=1024px){.top-artists__bento{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.top-artists__bento{grid-template-columns:1fr;grid-auto-rows:200px}.card--large{grid-area:span 1/span 1}}.listening-log{margin:var(--space-12) 0;max-width:600px}.section-title--left{font-family:var(--font-serif);font-size:var(--text-xl);color:var(--text-primary);margin-bottom:var(--space-6);display:inline-block;position:relative}.section-title--left:after{content:"";background:var(--accent-primary);width:40px;height:2px;position:absolute;bottom:-4px;left:0}.listening-log__list{gap:var(--space-3);flex-direction:column;display:flex}.log-item{align-items:center;gap:var(--space-4);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border-left:2px solid #0000;transition:background .2s;display:flex}.log-item:hover{border-left-color:var(--accent-primary);background:#c8a84b0d}.log-item__image{border-radius:var(--radius-sm);width:40px;height:40px;box-shadow:var(--shadow-sm);flex-shrink:0;overflow:hidden}.log-item__image img{object-fit:cover;width:100%;height:100%}.log-item__info{flex-grow:1;justify-content:space-between;align-items:center;min-width:0;display:flex}.log-item__main{flex-direction:column;min-width:0;display:flex}.log-item__title{font-family:var(--font-serif);font-size:var(--text-sm);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.log-item__artist{color:var(--text-muted);font-size:11px}.log-item__time{font-family:var(--font-mono);color:var(--accent-secondary);margin-left:var(--space-4);flex-shrink:0;font-size:10px}.the-crate{margin:var(--space-20) 0}.crate-grid{gap:var(--space-12);margin-top:var(--space-10);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.crate-item{gap:var(--space-6);cursor:pointer;flex-direction:column;display:flex}.record-stack{width:220px;height:220px;margin:0 auto;position:relative}.record-sleeve{z-index:2;border-radius:var(--radius-sm);background:#222;width:100%;height:100%;transition:transform .4s cubic-bezier(.34,1.56,.64,1);position:absolute;top:0;left:0;overflow:hidden;box-shadow:0 10px 30px #00000080}.record-sleeve img{object-fit:cover;width:100%;height:100%}.record-vinyl{z-index:1;background:#111 repeating-radial-gradient(circle,#0000 0 2px,#ffffff0d 3px);border-radius:50%;justify-content:center;align-items:center;width:210px;height:210px;transition:transform .5s cubic-bezier(.34,1.56,.64,1);display:flex;position:absolute;top:5px;right:0}.vinyl-center{background:#333;border:2px solid #222;border-radius:50%;width:40px;height:40px}.crate-item:hover .record-sleeve{transform:translate(-20px)}.crate-item:hover .record-vinyl{transform:translate(40px)rotate(90deg)}.playlist-meta{text-align:center}.playlist-name{font-family:var(--font-serif);font-size:var(--text-xl);color:var(--text-primary);margin-bottom:var(--space-2);font-weight:600}.playlist-description{font-family:var(--font-serif);font-style:italic;font-size:var(--text-sm);color:var(--accent-primary);opacity:.8;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.4;display:-webkit-box;overflow:hidden}@media (width<=640px){.record-stack{width:180px;height:180px}.record-vinyl{width:170px;height:170px}}.opt-image-wrapper{background-color:var(--bg-tertiary);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.opt-image{object-fit:cover;opacity:0;width:100%;height:100%;transition:opacity .4s ease-in-out}.opt-image--loaded{opacity:1}.music-page{padding:calc(var(--nav-height) + var(--space-8)) 0 var(--space-24)}.page-header__now{margin-bottom:var(--space-8);justify-content:center;display:flex}.page-header__stats{margin-top:var(--space-4)}.genre-summary{font-family:var(--font-serif);font-size:var(--text-sm);color:var(--text-secondary)}.genre-summary span{color:var(--accent-primary);text-transform:capitalize;font-weight:600}.music-split-view{gap:var(--space-16);margin:var(--space-16) 0;grid-template-columns:1fr 350px;display:grid}.music-loading{text-align:center;font-family:var(--font-serif);color:var(--text-muted);padding:4rem 0}.music-grid{gap:var(--space-8);margin-top:var(--space-8);grid-template-columns:repeat(auto-fill,minmax(220px,1fr));display:grid}.music-card{cursor:pointer;gap:var(--space-4);opacity:0;flex-direction:column;animation:.5s ease-out forwards fade-in-up;display:flex}.music-card__cover-wrapper{aspect-ratio:1;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--border-subtle);transition:all .3s;position:relative;overflow:hidden}.music-card:hover .music-card__cover-wrapper{border-color:var(--accent-primary);box-shadow:var(--shadow-lg), var(--shadow-glow);transform:translateY(-4px)}.music-card__cover{object-fit:cover;width:100%;height:100%}.music-card__overlay{opacity:0;background:#0006;justify-content:center;align-items:center;width:100%;height:100%;transition:opacity .3s;display:flex;position:absolute;top:0;left:0}.music-card:hover .music-card__overlay{opacity:1}.play-icon{color:var(--accent-primary);filter:drop-shadow(0 0 10px #00000080);font-size:2rem}.music-card__info{flex-direction:column;gap:2px;display:flex}.music-card__title{font-family:var(--font-serif);font-size:var(--text-lg);color:var(--text-primary);font-weight:600;line-height:1.2}.music-card__artist{font-size:var(--text-sm);color:var(--text-secondary);font-family:var(--font-sans)}.music-card__type{font-family:var(--font-mono);color:var(--accent-secondary);text-transform:uppercase;letter-spacing:1px;margin-top:var(--space-1);font-size:10px}.playlist-modal{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;width:100%;height:100%;padding:var(--space-4);background:#0a0a0ad9;justify-content:center;align-items:center;animation:.3s ease-out fade-in;display:flex;position:fixed;top:0;left:0}.playlist-modal__content{border-radius:var(--radius-xl);border:1px solid var(--accent-primary);background:#282828;width:100%;max-width:600px;position:relative;overflow:hidden;box-shadow:0 20px 50px #00000080}.playlist-modal__close{color:#fff;cursor:pointer;z-index:10;opacity:.7;background:0 0;border:none;font-size:2rem;line-height:1;transition:opacity .2s;position:absolute;top:10px;right:15px}.playlist-modal__close:hover{opacity:1;color:var(--accent-primary)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@media (width<=1100px){.music-split-view{gap:var(--space-12);grid-template-columns:1fr}}@media (width<=768px){.music-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}.music-offline-notice{background:var(--bg-card);border:1px dashed var(--accent-primary);border-radius:var(--radius-lg);padding:var(--space-12);text-align:center;margin:var(--space-8) auto;max-width:600px;box-shadow:var(--shadow-sm)}.notice-icon{margin-bottom:var(--space-4);filter:drop-shadow(0 0 10px var(--accent-primary));font-size:3rem}.music-offline-notice h2{font-family:var(--font-serif);color:var(--accent-primary);margin-bottom:var(--space-2)}.music-offline-notice p{color:var(--text-secondary);font-size:var(--text-md);line-height:1.5}.collection-card{border-radius:var(--radius-xl);height:100%;transition:all var(--duration-normal) var(--ease-out);cursor:default;background:0 0;border:none;flex-direction:column;display:flex;overflow:visible}.collection-card[role=button]{cursor:pointer}.collection-card:hover{background:0 0;transform:translateY(-8px)}.collection-card__cover{height:280px;margin-bottom:var(--space-4);background:0 0;justify-content:center;align-items:flex-end;padding:0;display:flex;position:relative;overflow:visible}.collection-card__image{object-fit:contain;object-position:bottom;filter:drop-shadow(0 12px 24px #0006);width:100%;height:100%;transition:filter .3s,transform .3s}.collection-card:hover .collection-card__image{filter:drop-shadow(0 20px 40px #000c)}.collection-card__placeholder{border-radius:var(--radius-sm);width:100%;height:280px;box-shadow:var(--shadow-lg);font-family:var(--font-serif);font-size:var(--text-4xl);color:#fff3;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.collection-card__cover-pattern{transition:opacity var(--duration-normal) var(--ease-out);background:repeating-linear-gradient(45deg,#0000,#0000 8px,#1a15100d 8px 9px);position:absolute;inset:0}.collection-card:hover .collection-card__cover-pattern{opacity:.6}.collection-card__year{z-index:1;font-family:var(--font-mono);font-size:var(--text-xs);color:#1a1510cc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);background:#fff9;position:relative}.collection-card__status-badge{top:var(--space-3);right:var(--space-3);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-full);font-family:var(--font-sans);font-size:var(--text-sm);color:#fff;box-shadow:var(--shadow-sm);z-index:2;letter-spacing:.5px;background:#1a1510d9;padding:4px 10px;font-weight:500;position:absolute}.collection-card__edition-badge{top:var(--space-3);left:var(--space-3);background:var(--accent-primary);color:#12100e;width:22px;height:22px;font-family:var(--font-mono);box-shadow:var(--shadow-md), 0 0 10px #c8a84b33;z-index:3;border-radius:4px;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex;position:absolute}.collection-card__synopsis-badge{top:32px;left:var(--space-3);background:var(--bg-card);color:var(--accent-primary);border:1px solid var(--accent-primary);width:22px;height:22px;box-shadow:var(--shadow-md);z-index:3;border-radius:4px;justify-content:center;align-items:center;display:flex;position:absolute}.collection-card__edition-badge--list{width:18px;height:18px;font-size:9px;top:4px;left:4px}.collection-card__info{padding:var(--space-4) 0 0 0;gap:var(--space-1);flex-direction:column;flex-grow:1;display:flex}.collection-card__title{font-family:var(--font-serif);font-size:var(--text-base);color:var(--text-primary);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.collection-card__subtitle{font-size:var(--text-sm);color:var(--text-secondary)}.collection-card__meta,.collection-card__list-bottom{gap:var(--space-2);padding-top:var(--space-3);flex-direction:column;margin-top:auto;display:flex}.collection-card__meta{gap:var(--space-2);flex-direction:column;display:flex}.collection-card__genres{flex-wrap:wrap;gap:4px;max-width:100%;display:flex;overflow:hidden}.collection-card__genre{color:var(--accent-tertiary);background:var(--accent-glow);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;text-overflow:ellipsis;max-width:130px;padding:2px 8px;font-size:10px;font-weight:500;overflow:hidden}.collection-card__rating{font-size:var(--text-xs);color:#fbbf24;letter-spacing:1px}.collection-card__notes{font-size:var(--text-sm);color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;min-height:3em;margin-top:auto;font-style:italic;line-height:1.5;display:-webkit-box;overflow:hidden}.collection-card__format-badges{bottom:var(--space-3);left:var(--space-3);z-index:2;gap:4px;display:flex;position:absolute}.format-badge{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:var(--accent-primary);width:22px;height:22px;box-shadow:var(--shadow-sm);background:#12100ed9;border:1px solid #c8a84b33;border-radius:4px;justify-content:center;align-items:center;transition:transform .2s;display:flex}.collection-card:hover .format-badge{border-color:var(--accent-primary);transform:translateY(-2px)}.collection-card--list{border-radius:var(--radius-lg);flex-direction:row;align-items:stretch;gap:0;min-height:120px;padding:0}.collection-card--list:hover{transform:translate(4px)}.collection-card__cover--list{width:90px;height:auto;aspect-ratio:unset;border-radius:0;flex-shrink:0;padding:0;box-shadow:1px 0 8px #0000001a}.collection-card__list-info{padding:var(--space-3) var(--space-5);gap:var(--space-1);flex-direction:column;flex:1;justify-content:center;min-width:0;height:100%;display:flex}.collection-card__list-top{flex-direction:column;gap:2px;display:flex}.collection-card__list-bottom{justify-content:space-between;align-items:center;gap:var(--space-3);flex-wrap:nowrap;margin-top:auto;display:flex;flex-direction:row!important}.collection-card__status-inline{font-size:var(--text-xs);color:var(--text-muted);font-family:var(--font-mono)}.collection-card__notes--list{-webkit-line-clamp:1}.collection-card__rating-row{justify-content:space-between;align-items:center;display:flex}.library-hero{width:100%;max-width:800px;margin:0 auto var(--space-16);border-radius:var(--radius-2xl);min-height:280px;box-shadow:var(--shadow-2xl);transition:transform var(--duration-normal) var(--ease-out);background:#ffffff08;border:1px solid #ffffff14;display:flex;position:relative;overflow:hidden}.library-hero--clickable{cursor:pointer}.library-hero--clickable:hover{border-color:#d4af374d;transform:translateY(-4px)}.library-hero__glass{-webkit-backdrop-filter:blur(20px)saturate(1.2);backdrop-filter:blur(20px)saturate(1.2);z-index:0;background:linear-gradient(135deg,#ffffff0d 0%,#ffffff05 100%);position:absolute;inset:0}.library-hero__accent{filter:blur(60px)opacity(.2);z-index:0;pointer-events:none;background-position:50%;background-size:cover;width:60%;height:140%;position:absolute;top:-20%;right:-10%;transform:rotate(15deg)}.library-hero__content{z-index:1;width:100%;padding:var(--space-8) var(--space-10);gap:var(--space-10);align-items:center;display:flex;position:relative}.library-hero__cover-column{flex-shrink:0}.library-hero__cover-3d{perspective:1000px;width:130px;height:200px;position:relative}.library-hero__cover{object-fit:contain;border-radius:var(--radius-sm);width:100%;height:100%;transition:transform var(--duration-normal);background-color:#ffffff0d;transform:rotateY(-10deg)rotateX(2deg);box-shadow:10px 10px 30px #00000080,-1px -1px 1px #ffffff1a}.library-hero--clickable:hover .library-hero__cover{transform:rotateY(-5deg)rotateX(0)translateY(-5px)}.library-hero__cover-placeholder{border-radius:var(--radius-sm);width:100%;height:100%;font-family:var(--font-serif);font-size:var(--text-6xl);color:#fff3;background:var(--bg-tertiary);justify-content:center;align-items:center;display:flex;box-shadow:10px 10px 30px #0006}.library-hero__info-column{gap:var(--space-3);flex-direction:column;flex:1;min-width:0;display:flex}.library-hero__label{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--accent-primary);text-transform:uppercase;letter-spacing:.2em;text-shadow:0 0 10px #d4af374d;font-weight:600}.library-hero__title{font-family:"Playfair Display", var(--font-serif);font-size:var(--text-4xl);color:#fff;margin-bottom:var(--space-1);line-height:1.1}.library-hero__author{font-family:var(--font-sans);font-size:var(--text-lg);color:var(--text-secondary);opacity:.9;font-style:italic}.library-hero__progress-section{margin-top:var(--space-6);max-width:320px}.library-hero__progress-meta{margin-bottom:var(--space-2);justify-content:space-between;align-items:flex-end;display:flex}.library-hero__progress-text{font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.library-hero__progress-percent{font-family:var(--font-serif);font-size:var(--text-xl);color:var(--accent-primary);font-weight:600}.library-hero__progress-track{border-radius:var(--radius-full);width:100%;height:6px;margin-bottom:var(--space-2);background:#ffffff1a;overflow:hidden}.library-hero__progress-bar{background:var(--accent-primary);border-radius:var(--radius-full);height:100%;transition:width .8s var(--ease-out);box-shadow:0 0 12px #d4af3780}.library-hero__progress-pages{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.05em;font-size:10px}.library-hero__edit-hint{margin-top:var(--space-4);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--accent-primary);opacity:.6;transition:opacity var(--duration-fast)}.library-hero--clickable:hover .library-hero__edit-hint{opacity:1}@media (width<=768px){.library-hero{max-width:100%;min-height:auto;margin-bottom:var(--space-8);flex-direction:column}.library-hero__content{text-align:center;padding:var(--space-8) var(--space-6);gap:var(--space-6);flex-direction:column}.library-hero__cover-3d{width:100px;height:150px;margin:0 auto}.library-hero__progress-section{margin:var(--space-6) auto 0}.library-hero__title{font-size:var(--text-2xl)}}.view-toggle{border:1px solid var(--border-medium);border-radius:var(--radius-md);display:flex;overflow:hidden}.view-toggle__btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--bg-card);color:var(--text-muted);font-family:var(--font-sans);font-size:var(--text-sm);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);border:none;border-right:1px solid var(--border-medium);font-weight:500;display:flex}.view-toggle__btn:last-child{border-right:none}.view-toggle__btn:hover{background:var(--bg-card-hover);color:var(--text-primary)}.view-toggle__btn--active{background:var(--accent-glow-strong);color:var(--accent-primary)}.view-toggle__btn--active:hover{background:var(--accent-glow-strong)}.isbn-scanner-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2000;width:100%;height:100%;padding:var(--space-4);background:#12100efa;justify-content:center;align-items:center;display:flex;position:fixed;top:0;left:0}.scanner-container--batch{border:1px solid var(--border-medium);border-radius:var(--radius-xl);background:#1a1a1a;flex-direction:column;width:100%;max-width:500px;max-height:90dvh;display:flex;overflow:hidden;box-shadow:0 20px 80px #000c}.scanner-header{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--border-subtle);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.scanner-header h2{font-family:var(--font-serif);font-size:var(--text-lg);color:var(--text-primary);margin:0}.scanner-header-meta{align-items:center;gap:var(--space-4);display:flex}.scanner-queue-count{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--accent-primary);border-radius:var(--radius-full);background:#c8a84b1a;border:1px solid #c8a84b33;padding:4px 10px;font-size:10px}.scanner-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:24px;line-height:1}.scanner-body{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.scanner-viewport{aspect-ratio:1;background:#000;border:3px solid #0000;flex-shrink:0;transition:border-color .3s;position:relative;overflow:hidden}.scanner-viewport--flash{border-color:var(--accent-primary);animation:.6s ease-out flash-gold}@keyframes flash-gold{0%{border-color:var(--accent-primary);box-shadow:inset 0 0 30px #c8a84b66}to{box-shadow:none;border-color:#0000}}.scanner-reader{width:100%!important;height:100%!important}.scanner-reader video{object-fit:cover!important;width:100%!important;height:100%!important}.scanner-ui-overlay{pointer-events:none;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:absolute;top:0;left:0}.scanner-target{border:2px solid var(--accent-primary);border-radius:var(--radius-lg);width:260px;height:260px;position:relative;overflow:hidden;box-shadow:0 0 0 1000px #0009}.scanner-laser{background:linear-gradient(90deg, transparent, var(--accent-primary), transparent);width:100%;height:3px;box-shadow:0 0 15px var(--accent-primary);animation:2s ease-in-out infinite sweep;position:absolute;top:0;left:0}@keyframes sweep{0%,to{top:0%}50%{top:100%}}.scanner-hint{margin-top:var(--space-8);font-family:var(--font-mono);text-transform:uppercase;color:var(--accent-primary);letter-spacing:.1em;font-size:10px}.scanner-camera-error{background:#000c;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.scanner-camera-error p{color:#ff4d4d;font-family:var(--font-mono);text-align:center;padding:var(--space-4);font-size:12px}.scanner-queue{border-top:1px solid var(--border-medium);flex-direction:column;flex:1;min-height:0;display:flex}.scanner-queue-header{padding:var(--space-3) var(--space-5);border-bottom:1px solid var(--border-subtle)}.scanner-queue-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.15em;color:var(--accent-primary);font-size:9px}.scanner-queue-list{border-bottom:1px solid var(--border-subtle);flex:1;min-height:150px;overflow-y:auto}.queue-item{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);border-bottom:1px solid var(--border-subtle);transition:background .2s;display:flex;position:relative}.queue-item:hover{background:#ffffff05}.queue-item--draft{background:#c88c280d;border-left:3px solid #c88c2866}.queue-item-cover{flex-shrink:0;width:40px}.queue-item-cover img{object-fit:cover;border:1px solid var(--border-subtle);border-radius:3px;width:40px;height:56px}.queue-item-info{flex:1;min-width:0}.queue-item-title{font-family:var(--font-serif);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;line-height:1.3;overflow:hidden}.queue-item-author{font-family:var(--font-sans);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.queue-item-draft-badge{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:#c8982b;background:#c8982b1f;border:1px solid #c8982b33;border-radius:3px;margin-top:2px;padding:2px 6px;font-size:8px;display:inline-block}.queue-item-genre-row{margin-top:3px}.queue-item-genre-select{border:1px solid var(--border-subtle);color:var(--text-secondary);font-family:var(--font-mono);cursor:pointer;background:#ffffff0d;border-radius:3px;outline:none;max-width:180px;padding:2px 6px;font-size:9px;transition:border-color .2s}.queue-item-genre-select:focus{border-color:var(--accent-primary)}.queue-item-remove{border:1px solid var(--border-subtle);border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text-muted);cursor:pointer;background:0 0;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;line-height:1;transition:all .2s;display:flex}.queue-item-remove:hover{color:#ff4d4d;background:#ff4d4d1a;border-color:#ff4d4d4d}.scanner-commit-bar{padding:var(--space-4) var(--space-5);border-top:1px solid var(--border-medium);background:#1a1a1a;flex-shrink:0}.scanner-commit-btn{width:100%;padding:var(--space-3) var(--space-5);background:var(--accent-primary);color:#12100e;border-radius:var(--radius-md);font-family:var(--font-serif);font-size:var(--text-md);cursor:pointer;justify-content:center;align-items:center;gap:var(--space-3);border:none;font-weight:700;transition:all .2s;display:flex}.scanner-commit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #c8a84b4d}.scanner-commit-btn:disabled{opacity:.7;cursor:not-allowed}.scanner-committing-overlay{justify-content:center;align-items:center;gap:var(--space-4);color:var(--accent-primary);font-family:var(--font-mono);z-index:100;background:#12100ef2;flex-direction:column;font-size:11px;display:flex;position:absolute;inset:0}.scanner-commit-progress{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-size:9px}.spinner--small{border-width:2px;width:16px;height:16px}@keyframes spin{to{transform:rotate(360deg)}}.scanner-toast-container{z-index:2100;gap:var(--space-2);pointer-events:none;flex-direction:column;align-items:center;display:flex;position:fixed;bottom:100px;left:50%;transform:translate(-50%)}.scanner-toast{border-radius:var(--radius-md);font-family:var(--font-mono);letter-spacing:.02em;white-space:nowrap;text-overflow:ellipsis;pointer-events:auto;max-width:360px;padding:8px 16px;font-size:11px;overflow:hidden;box-shadow:0 8px 25px #0006}.scanner-toast--info{color:var(--text-secondary);border:1px solid var(--border-medium);background:#282832f2}.scanner-toast--success{color:#8dd98d;background:#1e3c28f2;border:1px solid #64c86433}.scanner-toast--warning{color:#d4a843;background:#3c2d14f2;border:1px solid #c8982b33}.scanner-toast--error{color:#ff6b6b;background:#3c1414f2;border:1px solid #ff4d4d33}.scanner-provenance{padding:var(--space-4);border-bottom:1px solid var(--border-subtle);background:#0003}.scanner-provenance-input{background:var(--bg-primary);border:1px solid var(--border-medium);border-radius:var(--radius-md);width:100%;color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-sm);padding:10px 14px;transition:all .2s}.scanner-provenance-input:focus{border-color:var(--accent-primary);outline:none;box-shadow:0 0 0 2px #c8a84b33}.scanner-provenance-input::placeholder{color:var(--text-muted)}@media (width<=640px){.scanner-container--batch{border-radius:0;max-width:100%;height:100%;max-height:100dvh}.scanner-viewport{aspect-ratio:3/4}.scanner-queue-list{max-height:200px}.queue-item-genre-select{max-width:140px}}.library-filters{align-items:center;display:flex;position:relative}.add-filter-btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-full);color:var(--text-primary);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;transition:all .2s var(--ease-out);font-size:11px;display:flex;position:relative}.add-filter-btn:hover,.add-filter-btn--open{border-color:var(--accent-primary);background:var(--bg-hover)}.add-filter-btn--active{border-color:var(--accent-primary);color:var(--accent-primary)}.add-filter-btn__icon{color:var(--accent-primary);font-size:14px;font-weight:600}.add-filter-indicator{background:var(--accent-primary);border:2px solid var(--bg-primary);border-radius:50%;width:8px;height:8px;position:absolute;top:-2px;right:-2px}.unified-filter-dropdown{top:calc(100% + var(--space-2));-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-medium);border-radius:var(--radius-lg);width:500px;max-width:90vw;box-shadow:var(--shadow-2xl);z-index:100;background:#12100ef2;position:absolute;left:0;overflow:hidden}.filter-dropdown-content{gap:var(--space-4);padding:var(--space-5);grid-template-columns:1fr 1fr 1fr;max-height:400px;display:grid;overflow-y:auto}.filter-section{gap:var(--space-3);flex-direction:column;display:flex}.filter-section-title{font-family:var(--font-mono);text-transform:uppercase;color:var(--text-muted);letter-spacing:.1em;padding-bottom:var(--space-2);border-bottom:1px solid var(--border-subtle);font-size:10px}.filter-options{flex-direction:column;gap:2px;display:flex}.filter-option{text-align:left;font-family:var(--font-sans);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;text-overflow:ellipsis;background:0 0;border:none;padding:6px 10px;font-size:12px;transition:all .2s;overflow:hidden}.filter-option:hover{color:var(--text-primary);background:#ffffff0d}.filter-option--active{color:var(--accent-primary);background:#c8a84b1a;font-weight:600}@media (width<=640px){.unified-filter-dropdown{width:280px}.filter-dropdown-content{grid-template-columns:1fr}}.books-page{padding-top:calc(var(--nav-height) + var(--space-12));padding-bottom:var(--space-24);background:var(--bg-primary);min-height:100vh}.books-control-header{gap:var(--space-6);margin-bottom:var(--space-8);padding-bottom:var(--space-6);border-bottom:1px solid var(--border-subtle);flex-direction:column;display:flex}.books-omni-row{justify-content:space-between;align-items:center;gap:var(--space-6);display:flex}.books-omni-search{flex:1;max-width:600px;position:relative}.books-view-controls{align-items:center;gap:var(--space-6);display:flex}.books-filter-row{justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.books-status-group{align-items:center;gap:var(--space-6);flex-wrap:wrap;display:flex}.books-filter-actions{align-items:center;gap:var(--space-4);display:flex}.books-search-input{width:100%;padding:var(--space-2) var(--space-10) var(--space-2) var(--space-4);border:1px solid var(--border-medium);border-radius:var(--radius-full);font-family:var(--font-sans);font-size:var(--text-sm);color:#fff;transition:all .3s var(--ease-out);background:#12100e;outline:none}.books-search-input:focus{border-color:var(--accent-primary);box-shadow:0 0 15px #c8a84b26}.books-search-input::placeholder{color:#fff3}.search-icon{right:var(--space-4);opacity:.3;pointer-events:none;font-size:14px;position:absolute;top:50%;transform:translateY(-50%)}.books-filter-group{align-items:center;gap:var(--space-2);display:flex}.books-filter-group label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-size:9px}.books-select{padding:var(--space-1) var(--space-3);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);font-family:var(--font-sans);color:var(--text-secondary);cursor:pointer;background:0 0;outline:none;font-size:11px;transition:all .2s}.books-select:hover{border-color:var(--accent-muted)}.books-select:focus{border-color:var(--accent-primary)}.books-tab{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-full);cursor:pointer;transition:all .3s var(--ease-out);background:0 0;font-size:11px;display:inline-flex}.books-tab:hover{border-color:var(--accent-secondary);color:var(--text-primary)}.books-tab--active{background:var(--accent-primary);border-color:var(--accent-primary);color:#12100e;font-weight:700}.books-tab__emoji{font-size:14px}.books-tab--review{color:#c8982bb3;border-color:#c8982b40}.books-tab--review:hover{color:#c8982b;border-color:#c8982b80}.books-tab--review-active{color:#c8982b;background:#c8982b26;border-color:#c8982b;font-weight:700}.books-content{margin-top:var(--space-4)}.books-loading{height:400px;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;display:flex}.books-loading__spinner{border:2px solid var(--border-subtle);border-top-color:var(--accent-primary);border-radius:var(--radius-full);width:40px;height:40px;margin-bottom:var(--space-4);animation:1s linear infinite spin}.books-empty{height:300px;font-family:var(--font-serif);color:var(--text-muted);justify-content:center;align-items:center;font-style:italic;display:flex}@media (width<=1024px){.books-toolbar,.books-controls{flex-direction:column;align-items:stretch}.books-filter-group{justify-content:space-between}}@media (width<=640px){.virtuoso-grid-list{gap:var(--space-4)!important;grid-template-columns:repeat(2,1fr)!important}}.books-fab{background:var(--accent-primary);color:#12100e;cursor:pointer;z-index:1000;border:none;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:64px;height:64px;transition:all .3s;display:flex;position:fixed;bottom:2rem;right:2rem;box-shadow:0 8px 30px #0006,0 0 15px #c8a84b4d}.books-fab svg{margin-bottom:-2px}.books-fab__label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;opacity:.8;margin-top:2px;font-size:8px;font-weight:700}.books-fab:hover{background:var(--accent-secondary);transform:translateY(-2px)}@media (width<=640px){.books-fab{width:56px;height:56px;bottom:1.5rem;right:1.5rem}}.books-active-pills{align-items:center;gap:var(--space-2);margin-left:var(--space-4);padding-left:var(--space-4);border-left:1px solid var(--border-subtle);animation:.4s ease-out fadeIn;display:flex}.active-filter-pill{align-items:center;gap:var(--space-2);border-radius:var(--radius-full);font-family:var(--font-mono);text-transform:uppercase;color:var(--accent-primary);letter-spacing:.05em;background:#c8a84b1a;border:1px solid #c8a84b33;padding:4px 10px;font-size:10px;display:flex}.active-filter-pill button{color:var(--accent-primary);cursor:pointer;opacity:.6;background:0 0;border:none;justify-content:center;align-items:center;padding:0;font-size:8px;transition:opacity .2s;display:flex}.active-filter-pill button:hover{opacity:1}@media (width<=1024px){.books-omni-row{flex-direction:column;align-items:stretch}.books-omni-search{max-width:none}.books-view-controls{justify-content:space-between}}@media (width<=768px){.books-filter-row,.books-status-group{flex-direction:column;align-items:stretch}.books-active-pills{border-left:none;border-top:1px solid var(--border-subtle);padding-left:0;padding-top:var(--space-4);flex-wrap:wrap;margin-left:0}}.slideover-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#1a151099;position:fixed;inset:0}.slideover-panel{background:var(--bg-card);border-left:1px solid var(--border-subtle);width:460px;max-width:100vw;height:100dvh;box-shadow:var(--shadow-xl);z-index:201;flex-direction:column;display:flex;position:fixed;top:0;right:0;overflow:hidden}.slideover-inner{flex-direction:column;height:100%;display:flex;overflow:hidden}.slideover-header{padding:var(--space-6);border-bottom:1px solid var(--border-subtle);background:var(--bg-secondary);flex-shrink:0}.slideover-close{margin-left:auto;margin-bottom:var(--space-4);color:var(--text-muted);cursor:pointer;padding:var(--space-1);border-radius:var(--radius-sm);transition:color var(--duration-fast), background var(--duration-fast);background:0 0;border:none;display:block}.slideover-close:hover{color:var(--text-primary);background:var(--bg-tertiary)}.slideover-cover-row{gap:var(--space-5);align-items:flex-start;display:flex}.slideover-cover-img{object-fit:cover;border-radius:var(--radius-md);width:90px;height:130px;box-shadow:var(--shadow-lg);flex-shrink:0}.slideover-cover-placeholder{border-radius:var(--radius-md);width:90px;height:130px;font-family:var(--font-serif);font-size:var(--text-4xl);color:#ffffff80;flex-shrink:0;justify-content:center;align-items:center;display:flex}.slideover-meta{gap:var(--space-2);flex-direction:column;min-width:0;display:flex}.slideover-title{font-family:var(--font-serif);font-size:var(--text-xl);color:var(--text-primary);line-height:1.25}.slideover-author{font-size:var(--text-sm);color:var(--text-secondary);font-style:italic}.slideover-genre{font-size:var(--text-xs);background:var(--bg-tertiary);border:1px solid var(--border-subtle);color:var(--text-muted);border-radius:var(--radius-full);font-family:var(--font-mono);padding:2px 8px;display:inline-block}.slideover-status-pill{font-size:var(--text-xs);border-radius:var(--radius-full);font-weight:600;font-family:var(--font-sans);width:fit-content;padding:3px 10px;display:inline-block}.slideover-body{padding:var(--space-6);gap:var(--space-2);flex-direction:column;flex:1;display:flex;overflow-y:auto}.slideover-section{padding-bottom:var(--space-5);border-bottom:1px solid var(--border-subtle)}.slideover-section:last-child{border-bottom:none}.slideover-section-label{font-family:var(--font-serif);font-size:var(--text-sm);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-3);font-weight:600}.slideover-stars-display{font-size:var(--text-xl);color:var(--accent-primary);letter-spacing:2px}.slideover-review-text{font-family:var(--font-sans);font-size:var(--text-base);color:var(--text-secondary);font-style:italic;line-height:1.7}.slideover-empty{color:var(--text-muted);text-align:center;padding:var(--space-10) 0;font-style:italic}.slideover-select,.slideover-input{width:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--border-medium);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-base);transition:border-color var(--duration-fast)}.slideover-select:focus,.slideover-input:focus{border-color:var(--accent-primary);outline:none}.slideover-textarea{width:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--border-medium);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-base);resize:vertical;min-height:120px;transition:border-color var(--duration-fast)}.slideover-textarea:focus{border-color:var(--accent-primary);outline:none}.slideover-star-input{gap:var(--space-1);display:flex}.slideover-star{font-size:var(--text-2xl);color:var(--border-medium);cursor:pointer;transition:color var(--duration-fast), transform var(--duration-fast);background:0 0;border:none;padding:0;line-height:1}.slideover-star.active,.slideover-star:hover{color:var(--accent-primary);transform:scale(1.15)}.slideover-parent-title{font-family:Playfair Display,serif;font-size:var(--text-4xl);color:var(--text-primary);margin-top:var(--space-4);margin-bottom:var(--space-2);line-height:1.1}.slideover-author{font-family:Crimson Pro,serif;font-size:var(--text-lg);color:var(--text-secondary);font-style:italic}.slideover-edit-field{margin-top:var(--space-2);align-items:baseline;gap:4px;display:flex}.slideover-title-input{font-family:Playfair Display,serif;font-size:var(--text-3xl);color:var(--text-primary);border:none;border-bottom:1px solid var(--border-subtle);padding:var(--space-1) 0;background:0 0;outline:none;width:100%;line-height:1.1;transition:border-color .2s}.slideover-title-input:focus{border-bottom-color:var(--accent-primary)}.slideover-author-prefix{font-family:Crimson Pro,serif;font-size:var(--text-lg);color:var(--text-secondary);flex-shrink:0;font-style:italic}.slideover-author-input{font-family:Crimson Pro,serif;font-size:var(--text-lg);color:var(--text-secondary);border:none;border-bottom:1px solid var(--border-subtle);padding:var(--space-1) 0;background:0 0;outline:none;flex:1;font-style:italic;transition:border-color .2s}.slideover-author-input:focus{border-bottom-color:var(--accent-primary)}.slideover-review-toggle{padding:var(--space-3) var(--space-4);border:1px solid var(--border-subtle);border-radius:var(--radius-md);margin-bottom:var(--space-4);background:#c8982b0d;transition:all .2s}.slideover-review-toggle.active{background:#c8982b1a;border-color:#c8982b4d}.review-toggle-label{align-items:center;gap:var(--space-3);cursor:pointer;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);font-size:11px;display:flex}.review-toggle-label input[type=checkbox]{display:none}.review-toggle-switch{background:var(--border-medium);border-radius:9px;flex-shrink:0;width:34px;height:18px;transition:background .2s;position:relative}.review-toggle-switch:after{content:"";background:var(--text-muted);border-radius:50%;width:14px;height:14px;transition:all .2s;position:absolute;top:2px;left:2px}.review-toggle-label input:checked+.review-toggle-switch{background:#c8982b66}.review-toggle-label input:checked+.review-toggle-switch:after{background:#c8982b;transform:translate(16px)}.review-toggle-text{color:var(--text-muted)}.slideover-review-toggle.active .review-toggle-text{color:#c8982b}.slideover-progress-stat{margin-bottom:var(--space-8)}.stat-row{margin-bottom:var(--space-2);justify-content:space-between;align-items:flex-end;display:flex}.stat-label{font-family:var(--font-mono);text-transform:uppercase;color:var(--text-muted);font-size:10px}.stat-value{font-family:var(--font-mono);color:var(--accent-primary);font-size:12px}.stat-bar{border-radius:var(--radius-full);background:#ffffff0d;height:4px;overflow:hidden}.stat-bar-fill{background:var(--accent-primary);height:100%;transition:width .6s cubic-bezier(.16,1,.3,1)}.edition-card{border:1px solid var(--border-subtle);border-radius:var(--radius-lg);margin-bottom:var(--space-4);background:#ffffff05;transition:border-color .3s;overflow:hidden}.edition-card.editing{border-color:var(--accent-primary)}.edition-card-main{padding:var(--space-4);gap:var(--space-5);display:flex}.edition-card-art{border-radius:var(--radius-xs);width:70px;height:100px;box-shadow:var(--shadow-md);background:var(--bg-tertiary);flex-shrink:0;overflow:hidden}.edition-card-art img{object-fit:cover;width:100%;height:100%}.edition-art-placeholder{width:100%;height:100%;font-family:var(--font-mono);color:var(--text-muted);justify-content:center;align-items:center;display:flex}.edition-card-content{flex-direction:column;flex:1;justify-content:center;min-width:0;display:flex}.edition-card-top{margin-bottom:var(--space-2);justify-content:space-between;align-items:flex-start;display:flex}.edition-publisher{font-family:var(--font-serif);font-size:var(--text-base);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.edition-edit-trigger{color:var(--accent-primary);font-family:var(--font-mono);text-transform:uppercase;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:10px;transition:background .2s}.edition-edit-trigger:hover{background:#c8a84b1a}.edition-card-meta{gap:var(--space-3);flex-wrap:wrap;align-items:center;display:flex}.edition-card-actions{gap:var(--space-2);align-items:center;display:flex}.edition-primary-btn{border:1px solid var(--border-subtle);color:var(--text-muted);font-family:var(--font-mono);text-transform:uppercase;cursor:pointer;background:0 0;border-radius:4px;align-items:center;gap:4px;padding:3px 8px;font-size:9px;transition:all .2s;display:flex}.edition-primary-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.edition-primary-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:var(--bg-primary);font-weight:700}.edition-card.is-primary{background:#c8a84b08;border-color:#c8a84b4d}.edition-format-tag{background:var(--accent-primary);color:var(--bg-primary);text-transform:uppercase;border-radius:3px;padding:1px 6px;font-size:10px;font-weight:700}.edition-mono{font-family:var(--font-mono);color:var(--text-muted);font-size:10px}.edition-edit-form{padding:var(--space-5);border-top:1px solid var(--border-subtle);gap:var(--space-4);background:#0000001a;flex-direction:column;display:flex}.form-row{gap:var(--space-4);grid-template-columns:1.5fr 1fr;display:grid}.form-group{flex-direction:column;gap:4px;display:flex}.form-group label{font-family:var(--font-mono);text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em;font-size:9px}.form-group input,.form-group select{background:var(--bg-primary);border:1px solid var(--border-medium);color:var(--text-primary);font-size:13px;font-family:var(--font-sans);border-radius:4px;padding:8px 12px}.isbn-input-wrapper{gap:4px;display:flex}.isbn-fetch-btn{background:var(--accent-primary);color:var(--bg-primary);font-family:var(--font-mono);cursor:pointer;white-space:nowrap;border:none;border-radius:4px;padding:0 10px;font-size:9px}.isbn-fetch-btn:hover{opacity:.9}.slideover-actions{padding-top:var(--space-4);justify-content:flex-end;display:flex}.slideover-btn-save{padding:var(--space-3) var(--space-8);background:var(--accent-primary);color:var(--bg-primary);border-radius:var(--radius-md);font-family:var(--font-serif);font-size:var(--text-base);cursor:pointer;transition:opacity var(--duration-fast), transform var(--duration-fast);border:none;font-weight:600}.slideover-btn-save:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.slideover-btn-save:disabled{opacity:.5;cursor:not-allowed}@media (width<=640px){.slideover-panel{width:100vw}}.slideover-edition-details{gap:var(--space-2);margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--border-subtle);flex-wrap:wrap;display:flex}.slideover-edition-details span{font-size:var(--text-xs);color:var(--text-muted);background:var(--bg-tertiary);border-radius:var(--radius-full);border:1px solid var(--border-subtle);padding:2px 10px}.slideover-isbn{letter-spacing:.03em;font-family:var(--font-mono)!important}.slideover-translator{font-size:var(--text-xs);color:var(--text-muted);font-style:italic}.slideover-genre-select{background:var(--bg-tertiary);border:1px solid var(--border-color);width:100%;color:var(--text-primary);border-radius:6px;margin-top:5px;padding:10px;font-family:inherit;font-size:.95rem}.slideover-genre-select:focus{border-color:var(--accent-color);outline:none}.related-works{margin-top:var(--space-16);padding-top:var(--space-10);border-top:1px solid var(--border-subtle);animation:fadeIn 1.2s var(--ease-out)}.related-works__header{font-family:var(--font-sans);color:var(--text-muted);letter-spacing:.25em;text-transform:uppercase;margin-bottom:var(--space-8);align-items:center;gap:var(--space-4);font-size:11px;font-weight:700;display:flex}.related-works__header:after{content:"";background:linear-gradient(to right, var(--border-subtle), transparent);flex:1;height:1px}.related-works__grid{gap:var(--space-8);grid-template-columns:repeat(auto-fill,minmax(160px,1fr));display:grid}.related-book-card{text-align:left;cursor:pointer;transition:all .4s var(--ease-out);background:0 0;border:none;padding:0;position:relative}.related-book-card:hover{transform:translateY(-6px)}.related-book-card__cover{aspect-ratio:2/3;border-radius:var(--radius-md);background:var(--bg-tertiary);box-shadow:var(--shadow-md);margin-bottom:var(--space-4);border:1px solid var(--border-subtle);transition:all .4s var(--ease-out);position:relative;overflow:hidden}.related-book-card:hover .related-book-card__cover{box-shadow:var(--shadow-xl), 0 0 20px var(--accent-glow);border-color:var(--accent-primary)}.related-book-card__cover img{object-fit:cover;width:100%;height:100%;transition:transform .6s var(--ease-out)}.related-book-card:hover img{transform:scale(1.05)}.related-cover-placeholder{width:100%;height:100%;font-family:var(--font-serif);font-size:var(--text-3xl);color:var(--text-muted);background:linear-gradient(135deg, var(--bg-secondary), var(--bg-tertiary));justify-content:center;align-items:center;display:flex}.related-book-card__info{gap:var(--space-1);padding:0 var(--space-1);flex-direction:column;display:flex}.related-book-card__title{font-family:var(--font-serif);font-size:var(--text-sm);color:var(--text-primary);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-weight:600;line-height:1.3;transition:color .3s;display:-webkit-box;overflow:hidden}.related-book-card:hover .related-book-card__title{color:var(--accent-primary)}.related-book-card__author{color:var(--text-muted);font-size:11px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;display:block}.related-works-loading{font-family:var(--font-serif);color:var(--text-muted);font-style:italic;font-size:var(--text-sm);margin-top:var(--space-12);text-align:center;opacity:.7}.book-detail-page{padding-top:calc(var(--nav-height) + var(--space-12));padding-bottom:var(--space-24);background:var(--bg-primary);min-height:100vh}.book-detail-nav-row{margin-bottom:var(--space-12);justify-content:space-between;align-items:center;display:flex}.book-detail-back{align-items:center;gap:var(--space-2);color:var(--text-muted);font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.1em;width:fit-content;text-decoration:none;transition:color .3s;display:flex}.book-detail-edit-btn{color:var(--accent-primary);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;padding:var(--space-2) var(--space-4);border-radius:var(--radius-sm);cursor:pointer;background:#c8a84b0d;border:1px solid #c8a84b33;font-size:10px;transition:all .3s}.book-detail-edit-btn:hover{border-color:var(--accent-primary);background:#c8a84b26;box-shadow:0 0 15px #c8a84b1a}.book-detail-back:hover{color:var(--accent-primary)}.book-detail-grid{gap:var(--space-16);grid-template-columns:repeat(12,1fr);align-items:flex-start;display:grid}.book-detail-art-column{grid-column:span 4}.sticky-art-wrapper{position:sticky;top:120px}.book-detail-primary-cover{aspect-ratio:2/3;width:100%;transform-style:preserve-3d;perspective:1000px;position:relative}.book-detail-primary-cover img{object-fit:contain;border-radius:var(--radius-sm);border:none;width:100%;height:100%;transform:rotateY(-12deg)rotateX(2deg);box-shadow:20px 20px 40px #0006}.cover-placeholder{width:100%;height:100%;font-family:var(--font-serif);font-size:var(--text-6xl);color:#fff3;border-radius:var(--radius-sm);justify-content:center;align-items:center;display:flex;transform:rotateY(-12deg)rotateX(2deg);box-shadow:20px 20px 40px #0006}.book-detail-content-column{grid-column:span 8}.book-detail-title{font-family:Playfair Display,serif;font-size:clamp(var(--text-4xl), 5vw, var(--text-6xl));color:var(--text-primary);margin-bottom:var(--space-2);font-weight:900;line-height:1.1}.book-detail-author{font-family:Crimson Pro,serif;font-size:var(--text-2xl);color:var(--text-secondary);margin-bottom:var(--space-6);font-style:italic}.book-detail-review-banner{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-family:var(--font-mono);color:#c8982b;margin-bottom:var(--space-6);background:#c8982b14;border:1px solid #c8982b33;font-size:11px;display:flex}.review-banner-icon{font-size:14px}.book-detail-meta{align-items:center;gap:var(--space-6);margin-bottom:var(--space-12);display:flex}.book-detail-stars{color:var(--accent-primary);font-size:var(--text-xl);letter-spacing:2px}.book-detail-date{font-family:var(--font-mono);text-transform:uppercase;color:var(--text-muted);letter-spacing:.1em;font-size:11px}.book-detail-review-body{max-width:65ch}.book-detail-review-body p{font-family:Crimson Pro,serif;font-size:var(--text-lg);color:var(--text-secondary);margin-bottom:var(--space-8);line-height:1.8}.no-review{color:var(--text-muted);font-style:italic}.book-detail-synopsis{margin-top:var(--space-8);margin-bottom:var(--space-12);padding-bottom:var(--space-8);border-bottom:1px solid var(--border-subtle)}.synopsis-text{font-family:"Crimson Pro", var(--font-serif);font-size:var(--text-base);color:var(--text-muted);opacity:.9;max-width:65ch;font-style:italic;line-height:1.8}@media (width>=768px){.synopsis-text{font-size:var(--text-lg)}}.book-detail-archival-meta{margin-top:var(--space-12);background:0 0;border:none;padding:0}.archival-meta-title{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.3em;color:var(--accent-secondary);margin-bottom:var(--space-8);opacity:.7;font-size:10px}.archival-meta-grid{gap:var(--space-12);grid-template-columns:1fr 1fr;display:grid}.archival-meta-grid.full-width{grid-template-columns:1fr}.archival-meta-column h4{font-family:var(--font-serif);font-size:var(--text-base);color:var(--text-primary);margin-bottom:var(--space-4);border-bottom:1px solid var(--border-subtle);padding-bottom:var(--space-2);letter-spacing:.05em}.archival-meta-setting-grid{gap:var(--space-8);margin-bottom:var(--space-10);grid-template-columns:1fr 1fr;display:grid}.setting-grid-item{gap:var(--space-1);flex-direction:column;display:flex}.setting-label{font-family:var(--font-mono);text-transform:uppercase;color:var(--accent-primary);letter-spacing:.2em;opacity:.8;font-size:10px}.setting-value{color:var(--text-primary);font-size:var(--text-sm);line-height:1.4}.meta-index-row{gap:var(--space-2);margin-bottom:var(--space-8);flex-direction:column;display:flex}.meta-index-tags{gap:var(--space-1) var(--space-3);flex-wrap:wrap;line-height:1.8;display:flex}.meta-index-btn{font-family:var(--font-sans);text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);cursor:pointer;background:0 0;border:none;align-items:center;margin:0;padding:0;font-size:12px;transition:color .2s;display:flex}.meta-index-btn:hover{color:var(--accent-primary)}.meta-separator{margin:0 var(--space-2);color:var(--accent-secondary);opacity:.5;font-size:12px}.meta-label{font-family:var(--font-mono);text-transform:uppercase;color:var(--accent-primary);opacity:.8;letter-spacing:.2em;margin-bottom:var(--space-1);flex-shrink:0;font-size:10px}.meta-value{color:var(--text-primary);font-size:var(--text-sm)}.meta-defect-text{font-size:var(--text-sm);color:#ff8a80;opacity:.9}.archival-meta-divider{margin-top:var(--space-12);border-bottom:1px solid var(--border-subtle)}.saga-roadmap-item.ghost{opacity:.4;filter:grayscale();pointer-events:none}.saga-roadmap-item.ghost .saga-roadmap-dot{border:1px dashed var(--border-medium);background:0 0}.saga-roadmap-item.ghost .saga-roadmap-title{font-weight:400}.book-detail-saga-sync-btn{align-items:center;gap:var(--space-2);background:var(--bg-card);border:1px solid var(--accent-primary);color:var(--accent-primary);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;border-radius:var(--radius-sm);cursor:pointer;transition:all .3s var(--ease-out);margin-top:var(--space-4);padding:8px 16px;font-size:10px;display:inline-flex}.book-detail-saga-sync-btn:hover:not(:disabled){background:var(--accent-primary);color:#12100e;box-shadow:0 0 20px #c8a84b33}.book-detail-saga-sync-btn:disabled{opacity:.5;cursor:not-allowed;border-color:var(--border-subtle);color:var(--text-muted)}@media (width<=768px){.archival-meta-grid{grid-template-columns:1fr}}.book-detail-holdings{margin-top:var(--space-20);padding-top:var(--space-12);border-top:1px solid var(--border-subtle)}.holdings-title{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.2em;color:var(--accent-secondary);margin-bottom:var(--space-8);font-size:12px}.holdings-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}.holding-card{gap:var(--space-4);padding:var(--space-4);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);background:#ffffff05;transition:border-color .3s,background .3s;display:flex}.holding-card:hover{border-color:var(--accent-primary);background:#c8a84b08}.holding-art{border-radius:var(--radius-xs);width:60px;height:90px;box-shadow:var(--shadow-sm);flex-shrink:0;overflow:hidden}.holding-art img{object-fit:cover;width:100%;height:100%}.holding-info{flex-direction:column;justify-content:center;gap:2px;display:flex}.holding-format-row{align-items:center;gap:var(--space-2);color:var(--accent-primary);margin-bottom:2px;display:flex}.holding-format{font-family:var(--font-serif);font-weight:600;font-size:var(--text-sm);color:var(--text-primary)}.holding-publisher{color:var(--text-secondary);font-size:12px}.holding-isbn{font-family:var(--font-mono);color:var(--text-muted);margin-top:2px;font-size:9px}.saga-progress-dot{background:var(--border-subtle);border-radius:50%;width:9px;height:9px;transition:all .3s}.saga-progress-dot.active{background:var(--accent-primary);transform:scale(1.3);box-shadow:0 0 10px #c8a84b66}.book-detail-saga-badge{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.15em;color:var(--accent-primary);margin-bottom:var(--space-4);background:#c8a84b14;border:1px solid #c8a84b26;border-radius:4px;padding:4px 10px;font-size:10px;display:inline-block}.book-detail-saga-nav{margin-top:var(--space-12);padding:var(--space-8);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);background:#ffffff05}.saga-nav-header{margin-bottom:var(--space-8);padding-bottom:var(--space-4);border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:flex-end;display:flex}.saga-nav-title{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.2em;color:var(--text-muted);font-size:10px}.saga-nav-progress-text{font-family:var(--font-mono);color:var(--accent-primary);letter-spacing:.05em;font-size:10px}.saga-roadmap{gap:var(--space-6);flex-direction:column;display:flex}.saga-roadmap-item{gap:var(--space-4);align-items:flex-start;display:flex}.saga-roadmap-dot-track{flex-direction:column;align-items:center;width:12px;padding-top:6px;display:flex}.saga-roadmap-dot{background:var(--border-medium);z-index:2;border-radius:50%;width:8px;height:8px;transition:all .3s}.saga-roadmap-line{width:1px;height:calc(100% + var(--space-6));background:var(--border-subtle);margin-top:4px}.saga-roadmap-item.active .saga-roadmap-dot{background:var(--accent-primary);transform:scale(1.4);box-shadow:0 0 10px #c8a84b66}.saga-roadmap-item.missing .saga-roadmap-dot{border:1px solid var(--border-subtle);background:0 0}.saga-roadmap-content{flex:1}.saga-roadmap-meta{font-family:var(--font-mono);text-transform:uppercase;color:var(--text-muted);margin-bottom:2px;font-size:9px}.saga-roadmap-title{font-family:Playfair Display,serif;font-size:var(--text-lg);color:var(--text-primary);font-weight:700;text-decoration:none;transition:color .3s}.saga-roadmap-title:hover{color:var(--accent-primary)}.saga-roadmap-title--missing{color:var(--text-muted);opacity:.6;font-style:italic}.saga-roadmap-item.active .saga-roadmap-title{color:var(--accent-primary)}.saga-roadmap-flex{justify-content:space-between;align-items:center;gap:var(--space-4);display:flex}.saga-add-to-checklist-btn{color:var(--accent-primary);font-family:var(--font-mono);text-transform:uppercase;cursor:pointer;white-space:nowrap;background:#c8a84b0d;border:1px solid #c8a84b4d;border-radius:4px;padding:4px 8px;font-size:9px;transition:all .2s}.saga-add-to-checklist-btn:hover{background:var(--accent-primary);color:#12100e;border-color:var(--accent-primary)}.saga-wishlisted-badge{font-family:var(--font-mono);color:var(--accent-primary);text-transform:uppercase;letter-spacing:.05em;background:#c8a84b1a;border:1px solid #c8a84b33;border-radius:4px;padding:4px 8px;font-size:10px}.book-detail-loading,.book-detail-error{justify-content:center;align-items:center;gap:var(--space-4);height:100vh;color:var(--text-muted);flex-direction:column;display:flex}.spinner{border:2px solid var(--border-subtle);border-top-color:var(--accent-primary);border-radius:50%;width:30px;height:30px;animation:1s linear infinite spin}@media (width<=1024px){.book-detail-grid{gap:var(--space-10)}}@media (width<=768px){.book-detail-grid{flex-direction:column;display:flex}.book-detail-art-column{width:200px;margin:0 auto var(--space-12)}.sticky-art-wrapper{position:relative;top:0}.book-detail-title{text-align:center}.book-detail-author{text-align:center;margin-bottom:var(--space-8)}.book-detail-meta{justify-content:center}}.book-detail-admin-actions{margin-top:var(--space-20);padding-top:var(--space-8);border-top:1px dashed var(--border-subtle);justify-content:center;display:flex}.deaccession-btn{color:#7f1d1d80;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.2em;padding:var(--space-4);cursor:pointer;background:0 0;border:none;font-size:10px;transition:all .3s}.deaccession-btn:hover{color:#ef4444}.deaccession-btn.confirm{color:#ef4444;font-weight:700;animation:2s infinite pulse-red}@keyframes pulse-red{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.book-detail-admin-actions{gap:var(--space-4);margin-top:var(--space-12);padding-top:var(--space-8);border-top:1px solid var(--border-subtle);flex-direction:column;display:flex}.enrichment-sync-btn{border:1px solid var(--accent-primary);color:var(--accent-primary);padding:var(--space-4);border-radius:var(--radius-md);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.2em;cursor:pointer;background:0 0;width:100%;font-size:10px;font-weight:700;transition:all .3s}.enrichment-sync-btn:hover:not(:disabled){background:var(--accent-primary);color:var(--bg-primary)}.enrichment-sync-btn:disabled{opacity:.5;cursor:wait}.reviews-page{padding-top:calc(var(--nav-height) + var(--space-12));padding-bottom:var(--space-24);background:var(--bg-primary);min-height:100vh}.page-header__top{justify-content:space-between;align-items:flex-start;gap:var(--space-8);margin-bottom:var(--space-8);display:flex}.reviews-timeline-group{margin-bottom:var(--space-16)}.timeline-header{align-items:center;gap:var(--space-6);margin-bottom:var(--space-10);opacity:.8;display:flex}.timeline-header__label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.2em;color:var(--accent-secondary);white-space:nowrap;flex-shrink:0;font-size:10px}.timeline-header__line{background:var(--accent-primary);opacity:.2;flex:1;height:1px}.reviews-grid-inner--list{gap:var(--space-12);flex-direction:column;display:flex}.reviews-grid-inner--grid{gap:var(--space-8);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}.journal-entry{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);cursor:pointer;transition:border-color .3s var(--ease-out), box-shadow .3s var(--ease-out);display:flex;position:relative;overflow:hidden}.journal-entry:hover{border-color:var(--border-medium);box-shadow:var(--shadow-md)}.journal-entry--list{gap:var(--space-10);padding:var(--space-8);flex-direction:row}.journal-entry--grid{flex-direction:column;padding:0}.journal-entry__cover-wrapper{flex-shrink:0}.journal-entry--list .journal-entry__cover-wrapper{width:180px}.journal-entry--grid .journal-entry__cover-wrapper{width:100%}.journal-entry__cover{aspect-ratio:2/3;object-fit:contain;background:#1a1510;width:100%;display:block;box-shadow:4px 4px 12px #0003}.journal-entry--list .journal-entry__cover{border-radius:var(--radius-sm)}.journal-entry--grid .journal-entry__cover{border-bottom:1px solid var(--border-subtle)}.journal-entry__cover-placeholder{aspect-ratio:2/3;color:#fff;width:100%;font-family:var(--font-serif);font-size:var(--text-3xl);justify-content:center;align-items:center;display:flex;box-shadow:4px 4px 12px #0003}.journal-entry__content{flex-direction:column;flex:1;display:flex}.journal-entry--grid .journal-entry__content{padding:var(--space-6)}.journal-entry__header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.journal-entry__stars{gap:2px;display:flex}.star{color:var(--border-medium);font-size:14px}.star.filled{color:var(--accent-primary)}.journal-entry__title{font-family:var(--font-serif);font-size:var(--text-xl);color:var(--text-primary);margin-bottom:var(--space-1);font-weight:700;line-height:1.2}.journal-entry--list .journal-entry__title{font-size:var(--text-2xl)}.journal-entry__author{font-family:Crimson Pro,serif;font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-4);font-style:italic}.journal-entry__reflection{font-family:Crimson Pro,serif;font-size:var(--text-base);color:var(--text-secondary);margin-bottom:var(--space-6);white-space:pre-wrap;line-height:1.6}.journal-entry--list .journal-entry__reflection{padding-left:var(--space-6);border-left:2px solid var(--border-subtle);line-height:1.7}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.journal-entry__footer{margin-top:auto}.journal-entry__tag{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;color:var(--accent-secondary);border-radius:var(--radius-full);background:#c8a84b0d;border:1px solid #c8a84b1a;padding:2px 8px;font-size:9px}.reviews-loading,.reviews-empty{height:400px;color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.reviews-loading__spinner{border:2px solid var(--border-subtle);border-top-color:var(--accent-primary);border-radius:var(--radius-full);width:32px;height:32px;margin-bottom:var(--space-4);animation:.8s linear infinite spin}@media (width<=768px){.journal-entry--list{padding:var(--space-6);flex-direction:column}.journal-entry--list .journal-entry__cover-wrapper{width:140px;margin-bottom:var(--space-6)}}.drawer-backdrop{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:3000;background:#1a151099;position:fixed;inset:0}.drawer-panel{background:var(--bg-primary);border-left:1px solid var(--border-subtle);width:100%;max-width:600px;box-shadow:var(--shadow-xl);z-index:3001;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;right:0;overflow:hidden}.drawer-header{padding:var(--space-6) var(--space-8);border-bottom:1px solid var(--border-subtle);background:var(--bg-secondary);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.drawer-title{font-family:var(--font-serif);font-size:var(--text-xl);color:var(--text-primary);margin:0}.drawer-close-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;transition:color .2s;display:flex}.drawer-close-btn:hover{color:var(--accent-primary)}.drawer-content{flex:1;padding:0;overflow-y:auto}@media (width<=640px){.drawer-panel{max-width:100%}}.drawer-content .book-detail-page{padding-top:0}.drawer-content .book-detail-nav-row{display:none}.drawer-content .book-detail-grid{gap:var(--space-8);padding:var(--space-6) var(--space-8);flex-direction:column;display:flex}.drawer-content .book-detail-art-column{width:100%;max-width:280px;margin:0 auto}.drawer-content .sticky-art-wrapper{position:relative;top:0}.drawer-content .book-detail-content-column{width:100%}.drawer-content .book-detail-title{font-size:var(--text-2xl)}.drawer-content .archival-meta-grid{grid-template-columns:1fr}.collection-page{padding-top:calc(var(--nav-height) + var(--space-12));padding-bottom:var(--space-24);background:var(--bg-primary);min-height:100vh}.collection-header-container{margin-bottom:var(--space-8);padding:0 var(--space-4);justify-content:space-between;align-items:center;display:flex}.collection-title{font-family:var(--font-serif);font-size:var(--text-3xl);color:var(--text-primary);margin:0;font-weight:700}.collection-view-toggle-container{margin-bottom:var(--space-8);justify-content:center;display:flex}.segmented-toggle{background:var(--bg-tertiary);border-radius:var(--radius-full);border:1px solid var(--border-subtle);width:fit-content;padding:4px;display:flex}.segmented-toggle .toggle-btn{border-radius:var(--radius-full);color:var(--text-muted);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;cursor:pointer;transition:all .3s var(--ease-out);background:0 0;border:none;padding:8px 24px;font-size:10px}.segmented-toggle .toggle-btn:hover{color:var(--text-primary)}.segmented-toggle .toggle-btn.active{background:var(--bg-primary);color:var(--accent-primary);box-shadow:var(--shadow-sm)}.collection-header-actions{align-items:center;gap:var(--space-4);display:flex}.collection-sync-badge{font-family:var(--font-mono);color:var(--accent-secondary);text-transform:uppercase;letter-spacing:.1em;font-size:10px}.quick-add-minimal-btn{background:var(--bg-tertiary);border:1px solid var(--border-subtle);color:var(--text-primary);cursor:pointer;width:36px;height:36px;transition:all .3s var(--ease-out);border-radius:50%;justify-content:center;align-items:center;display:flex}.quick-add-minimal-btn:hover{border-color:var(--accent-primary);background:var(--bg-secondary);box-shadow:0 0 15px var(--accent-glow)}.quick-add-minimal-btn.active{background:var(--accent-primary);color:var(--bg-primary);transform:rotate(45deg)}.progress-ring-wrapper{justify-content:center;align-items:center;display:flex;position:relative}.progress-check-overlay{width:12px;height:12px;color:var(--accent-primary);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.collection-controls-sticky{top:var(--nav-height);background:var(--bg-glass);-webkit-backdrop-filter:blur(20px)saturate(180%);z-index:100;padding:var(--space-4) 0;margin-bottom:var(--space-8);border-bottom:1px solid var(--border-subtle);position:sticky}.collection-search-bar{width:100%;padding:var(--space-3) var(--space-5);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);font-family:var(--font-sans);font-size:var(--text-sm);color:var(--text-primary);margin-bottom:var(--space-4);background:#ffffff08;outline:none;transition:all .3s}.collection-search-bar:focus{border-color:var(--accent-primary);background:#ffffff0d}.collection-controls-row{justify-content:space-between;align-items:center;gap:var(--space-4);display:flex}.collection-filters{gap:var(--space-2);display:flex}.collection-filter-btn{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border:1px solid var(--border-subtle);border-radius:var(--radius-full);cursor:pointer;background:0 0;padding:4px 12px;font-size:9px;transition:all .2s}.collection-filter-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:var(--bg-primary);font-weight:700}.collection-sort-controls{gap:var(--space-2);display:flex}.sort-btn{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border:1px solid var(--border-subtle);border-radius:var(--radius-full);cursor:pointer;background:0 0;padding:4px 12px;font-size:9px;transition:all .2s}.sort-btn.active{border-color:var(--accent-primary);color:var(--accent-primary);background:#c8a84b1a;font-weight:700}.collection-library{flex-direction:column;display:flex}.collection-genre-section{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);margin-bottom:var(--space-4);transition:all .3s var(--ease-out);position:relative;overflow:hidden}.collection-genre-section:hover{border-color:var(--border-medium);box-shadow:var(--shadow-md)}.collection-genre-header{padding:var(--space-6) var(--space-8);cursor:pointer;background:#ffffff05;justify-content:space-between;align-items:center;transition:background .3s;display:flex;position:relative}.collection-genre-header:hover{background:#ffffff0a}.collection-genre-header:after{content:"";background:var(--border-subtle);opacity:.3;height:2px;transition:all .3s;position:absolute;bottom:0;left:0;right:0}.collection-genre-section.open .collection-genre-header:after{background:var(--cat-color);opacity:1;height:2px}.collection-genre-title-wrapper{align-items:center;gap:var(--space-5);display:flex}.collection-genre-text-group{flex-direction:column;gap:2px;display:flex}.collection-genre-title{font-family:var(--font-serif);font-size:var(--text-lg);color:var(--text-primary);font-weight:600}.collection-spine-badge{font-family:var(--font-mono);text-transform:uppercase;color:var(--accent-secondary);opacity:.7;font-size:8px}.collection-genre-stats{align-items:center;gap:var(--space-4);font-family:var(--font-mono);color:var(--text-muted);font-size:10px;display:flex}.collection-chevron{color:var(--text-muted);transition:transform .3s cubic-bezier(.4,0,.2,1)}.collection-genre-section.open .collection-chevron{transform:rotate(180deg)}.collection-book-list{background:#0000001a;overflow:hidden}.collection-book-item{align-items:center;gap:var(--space-5);padding:var(--space-4) var(--space-6);cursor:pointer;border-bottom:1px solid #ffffff08;transition:all .2s;display:flex}.collection-book-item:last-child{border-bottom:none}.collection-book-item:hover{background:#ffffff08}.collection-book-item.unowned{opacity:.6}.collection-book-item.unowned:hover{opacity:1}.collection-checkbox{border:2px solid var(--border-medium);border-radius:4px;justify-content:center;align-items:center;width:20px;height:20px;transition:all .2s;display:flex}.collection-checkbox.checked{background:var(--accent-primary);border-color:var(--accent-primary)}.collection-checkbox svg{width:14px;height:14px;color:var(--bg-primary)}.collection-book-details{flex:1;min-width:0}.collection-book-title{font-family:var(--font-serif);font-size:var(--text-base);color:var(--text-primary);line-height:1.2}.collection-book-item.owned .collection-book-title{color:var(--accent-primary)}.collection-book-author{font-family:var(--font-sans);font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.collection-view-details-btn{color:var(--text-muted);padding:var(--space-2);cursor:pointer;border-radius:var(--radius-full);background:0 0;border:none;justify-content:center;align-items:center;transition:all .2s;display:flex}.collection-view-details-btn:hover{color:var(--accent-primary);background:#ffffff0d}.collection-delete-btn{color:var(--text-muted);padding:var(--space-2);cursor:pointer;border-radius:var(--radius-full);background:0 0;border:none;justify-content:center;align-items:center;transition:all .2s;display:flex}.collection-delete-btn:hover{color:#f44;background:#ff444414}.is-imprint .collection-genre-title{color:var(--cat-color)}.collection-quick-add-container{margin-bottom:var(--space-8);z-index:50;position:relative}.quick-add-form{gap:var(--space-4);flex-direction:column;display:flex}.quick-add-row{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.smart-search-input{background:var(--bg-tertiary);border:1px solid var(--border-subtle);width:100%;color:var(--text-primary);padding:var(--space-4) var(--space-5);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-base);transition:all .3s}.smart-search-input:focus{border-color:var(--accent-primary);background:var(--bg-secondary);outline:none}.quick-add-form .submit-btn{background:var(--accent-primary);color:var(--bg-primary);padding:var(--space-3) var(--space-8);border-radius:var(--radius-md);font-weight:700;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;border:none;align-self:flex-end;width:fit-content;font-size:11px;transition:all .2s}.quick-add-form .submit-btn:hover{opacity:.9;transform:translateY(-1px)}.autocomplete-wrapper{position:relative}.search-suggestions{z-index:1000;border-radius:var(--radius-md);width:100%;box-shadow:var(--shadow-xl);background:#1a1a1a;border:1px solid #2d3748;margin-top:8px;position:absolute;top:100%;left:0;overflow:hidden}.suggestion-item{padding:var(--space-4) var(--space-5);cursor:pointer;border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;transition:background .2s;display:flex}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover{background:#c8a84b1a}.suggestion-title{font-family:var(--font-serif);font-weight:600;font-size:var(--text-sm);display:block}.suggestion-author{font-size:var(--text-xs);color:var(--text-muted);display:block}.suggestion-year{font-family:var(--font-mono);color:var(--accent-primary);font-size:10px}.collection-stats{justify-content:center;gap:var(--space-12);margin-bottom:var(--space-12);padding:var(--space-8);border-radius:var(--radius-xl);border:1px solid var(--border-subtle);background:#ffffff05;display:flex}.collection-stat-box{flex-direction:column;align-items:center;display:flex}.collection-stat-val{font-family:var(--font-serif);font-size:var(--text-2xl);color:var(--text-primary);font-weight:700}.collection-stat-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-top:4px;font-size:10px}.fulfillment-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;padding:var(--space-4);background:#000000d9;justify-content:center;align-items:center;animation:.3s fade-in;display:flex;position:fixed;inset:0}.fulfillment-modal{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);width:100%;max-width:600px;padding:var(--space-8);box-shadow:var(--shadow-2xl), 0 0 50px #c8a84b1a}.fulfillment-modal h3{font-family:var(--font-serif);font-size:var(--text-2xl);margin-bottom:var(--space-2);color:var(--accent-primary)}.fulfillment-modal p{color:var(--text-muted);font-size:var(--text-sm);margin-bottom:var(--space-8)}.fulfillment-loading{align-items:center;gap:var(--space-4);padding:var(--space-12);color:var(--text-muted);flex-direction:column;display:flex}.fulfillment-spinner{border:2px solid #c8a84b33;border-top-color:var(--accent-primary);border-radius:50%;width:30px;height:30px;animation:1s linear infinite spin}.fulfillment-grid{gap:var(--space-6);margin-bottom:var(--space-8);max-height:400px;padding:var(--space-2);grid-template-columns:repeat(auto-fill,minmax(140px,1fr));display:grid;overflow-y:auto}.fulfillment-card{background:var(--bg-tertiary);border-radius:var(--radius-md);cursor:pointer;transition:all .3s var(--ease-out);border:1px solid #0000;overflow:hidden}.fulfillment-card:hover{border-color:var(--accent-primary);transform:translateY(-5px);box-shadow:0 10px 20px #0000004d}.fulfillment-cover-wrapper{aspect-ratio:2/3;background:var(--bg-primary);position:relative}.fulfillment-cover-wrapper img{object-fit:cover;width:100%;height:100%}.fulfillment-card-info{padding:var(--space-3);flex-direction:column;gap:2px;display:flex}.fulfillment-publisher{font-size:10px;font-family:var(--font-mono);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.fulfillment-isbn{font-size:9px;font-family:var(--font-mono);color:var(--text-muted)}.fulfillment-cancel{width:100%;padding:var(--space-4);border:1px solid var(--border-subtle);color:var(--text-muted);border-radius:var(--radius-md);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;cursor:pointer;background:0 0;font-size:11px;transition:all .3s}.fulfillment-cancel:hover{color:var(--text-primary);background:#ffffff0d}.fulfillment-overlay{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:#000000e6;justify-content:center;align-items:center;display:flex;z-index:9999!important;width:100vw!important;height:100vh!important;margin:0!important;padding:0!important;position:fixed!important;top:0!important;left:0!important}.fulfillment-modal{flex-direction:column;max-height:90vh;display:flex;margin:auto!important;transform:none!important}.fulfillment-modal-header{margin-bottom:var(--space-2);justify-content:space-between;align-items:flex-start;display:flex}.fulfillment-close-top{color:var(--text-muted);font-size:var(--text-xl);cursor:pointer;padding:var(--space-2);background:0 0;border:none;line-height:1}.fulfillment-isbn-search{gap:var(--space-2);margin-bottom:var(--space-6);display:flex}.fulfillment-isbn-search input{background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);color:var(--text-primary);font-family:var(--font-mono);font-size:var(--text-xs);flex:1}.fulfillment-isbn-search input:focus{border-color:var(--accent-primary);outline:none}.fulfillment-isbn-search button{background:var(--accent-primary);color:var(--bg-primary);border-radius:var(--radius-md);padding:0 var(--space-6);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;cursor:pointer;border:none;font-size:10px;font-weight:700}.fulfillment-isbn-search button:disabled{opacity:.5;cursor:not-allowed}body:has(.fulfillment-overlay){overflow:hidden}.checklist-container{color:#fff;max-width:1400px;min-height:100vh;margin:0 auto;padding:120px 40px 80px}.checklist-header{border-left:4px solid #c8a84b;margin-bottom:60px;padding-left:24px}.checklist-header h1{letter-spacing:-.02em;background:linear-gradient(135deg,#fff 0%,#c8a84b 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin:0;font-family:Outfit,sans-serif;font-size:3.5rem;font-weight:700}.checklist-header p{color:#ffffff80;margin-top:8px;font-size:1.1rem}.tracker-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:32px;display:grid}.tracker-card{text-align:center;cursor:pointer;background:#ffffff08;border:1px solid #ffffff14;border-radius:24px;flex-direction:column;align-items:center;padding:32px;transition:all .4s cubic-bezier(.2,0,0,1);display:flex;position:relative;overflow:hidden}.tracker-card:hover{background:#ffffff0f;border-color:#c8a84b4d;transform:translateY(-8px)}.tracker-card:before{content:"";opacity:0;background:#c8a84b;width:100%;height:4px;transition:opacity .3s;position:absolute;top:0;left:0}.tracker-card:hover:before{opacity:1}.progress-container{width:120px;height:120px;margin-bottom:24px;position:relative}.progress-ring{transform:rotate(-90deg)}.progress-ring-circle{stroke:#c8a84b;stroke-linecap:round;transition:stroke-dashoffset 1s ease-in-out}.progress-ring-bg{stroke:#ffffff0d}.progress-text{flex-direction:column;align-items:center;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.progress-percentage{font-family:Outfit,sans-serif;font-size:1.5rem;font-weight:700}.progress-label{text-transform:uppercase;letter-spacing:.1em;color:#fff6;font-size:.7rem}.tracker-name{margin:0;font-family:Outfit,sans-serif;font-size:1.25rem;font-weight:600}.drill-down-container{animation:.5s ease-out fadeIn}.back-button{color:#fff;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;align-items:center;gap:8px;margin-bottom:40px;padding:10px 20px;font-size:.9rem;transition:all .2s;display:flex}.back-button:hover{background:#ffffff1a}.tracker-books-list{flex-direction:column;gap:16px;display:flex}.book-row{background:#ffffff05;border:1px solid #ffffff0d;border-radius:16px;align-items:center;gap:24px;padding:12px 20px;transition:all .3s;display:flex}.book-row.owned{border-color:#c8a84b33}.book-row.wanted{opacity:.5}.book-cover-mini{object-fit:cover;background:#ffffff0d;border-radius:6px;flex-shrink:0;width:50px;height:75px}.fallback-cover{text-align:center;box-sizing:border-box;background-color:#1a1a1a;border:1px solid #1f2937;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:50px;height:75px;padding:8px;display:flex;overflow:hidden}.fallback-cover span{color:#c8a84b;-webkit-line-clamp:4;-webkit-box-orient:vertical;font-family:Playfair Display,serif;font-size:.65rem;line-height:1.1;display:-webkit-box;overflow:hidden}.tracker-controls{background:var(--bg-glass);-webkit-backdrop-filter:blur(12px);z-index:100;border-bottom:1px solid var(--border-subtle);box-shadow:var(--shadow-sm);border-radius:0 0 16px 16px;align-items:center;gap:16px;margin:0 -24px 24px;padding:16px 24px;display:flex;position:sticky;top:72px}.tracker-search-input{background:var(--bg-secondary);border:1px solid var(--border-subtle);color:var(--text-primary);border-radius:12px;flex:1;padding:12px 16px;font-size:.95rem;transition:all .2s}.tracker-search-input::placeholder{color:var(--text-muted)}.tracker-search-input:focus{border-color:var(--accent-primary);background:var(--bg-card);box-shadow:0 0 0 3px var(--accent-glow);outline:none}.tracker-sort-toggle{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:12px;gap:4px;padding:4px;display:flex}.tracker-sort-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:8px 16px;font-size:.85rem;font-weight:600;transition:all .2s}.tracker-sort-btn:hover{color:var(--text-primary)}.tracker-sort-btn.active{background:var(--accent-primary);color:var(--bg-primary)}.book-info{flex:1}.book-title{margin-bottom:4px;font-size:1.1rem;font-weight:600}.book-author{color:#ffffff80;font-size:.9rem}.book-meta{color:#ffffff4d;margin-top:4px;font-size:.8rem}.fulfill-btn{color:#c8a84b;cursor:pointer;background:0 0;border:1px solid #c8a84b;border-radius:8px;padding:8px 16px;font-size:.85rem;font-weight:600;transition:all .2s}.fulfill-btn:hover{color:#000;background:#c8a84b}.status-indicator{border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.status-indicator.owned{color:#000;background:#c8a84b}.status-indicator.wanted{border:2px solid #fff3}.fulfillment-actions{align-items:center;gap:16px;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;background:#000000e6;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-content{background:#111;border:1px solid #ffffff1a;border-radius:24px;width:100%;max-width:800px;max-height:90vh;padding:40px;position:relative;overflow-y:auto}.modal-header{margin-bottom:32px}.modal-header h2{margin:0;font-family:Outfit,sans-serif}.cover-selection-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:20px;margin-bottom:40px;display:grid}.cover-option{aspect-ratio:2/3;cursor:pointer;background:#ffffff0d;border:2px solid #0000;border-radius:12px;transition:all .3s;overflow:hidden}.cover-option:hover{border-color:#c8a84b;transform:scale(1.05)}.cover-option img{object-fit:cover;width:100%;height:100%}.manual-override{border-top:1px solid #ffffff1a;padding-top:32px}.manual-override input{color:#fff;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;width:100%;margin-top:12px;padding:12px 16px}.ai-form-group{flex-direction:column;gap:8px;margin-bottom:24px;display:flex}.ai-form-group label{color:#c8a84b;font-family:Outfit,sans-serif;font-size:.95rem;font-weight:600}.ai-form-group input,.ai-form-group textarea{color:#fff;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:16px;width:100%;padding:16px;font-size:1rem;transition:all .3s}.ai-form-group input:focus,.ai-form-group textarea:focus{background:#ffffff14;border-color:#c8a84b;outline:none}.ai-form-group textarea{resize:vertical;min-height:140px}.ai-generate-btn{color:#000;cursor:pointer;background:linear-gradient(135deg,#c8a84b 0%,#b08d37 100%);border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:1rem;font-weight:700;transition:all .3s;display:flex}.ai-generate-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #c8a84b4d}.ai-generate-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.ai-error-msg{color:#ff6b6b;background:#ff6b6b1a;border:1px solid #ff6b6b33;border-radius:12px;margin-bottom:24px;padding:16px;font-size:.9rem}.floating-add-btn{color:#000;cursor:pointer;z-index:900;background:linear-gradient(135deg,#c8a84b 0%,#b08d37 100%);border:none;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;font-size:2.5rem;font-weight:300;transition:all .3s cubic-bezier(.2,0,0,1);display:flex;position:fixed;bottom:40px;right:40px;box-shadow:0 8px 32px #c8a84b66}.floating-add-btn:hover{transform:scale(1.1)rotate(90deg);box-shadow:0 12px 40px #c8a84b99}.smart-search-results{flex-direction:column;gap:12px;max-height:300px;margin:24px 0;padding-right:8px;display:flex;overflow-y:auto}.smart-search-item{cursor:pointer;background:#ffffff08;border:1px solid #ffffff14;border-radius:16px;align-items:center;gap:16px;padding:12px 16px;transition:all .2s;display:flex}.smart-search-item:hover{background:#ffffff0f;border-color:#c8a84b4d}.smart-search-item.selected{background:#c8a84b26;border-color:#c8a84b}.smart-search-cover{object-fit:cover;background:#ffffff0d;border-radius:6px;flex-shrink:0;width:40px;height:60px}.smart-search-info{flex:1;min-width:0}.smart-search-title{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:1rem;font-weight:600;overflow:hidden}.smart-search-author{color:#ffffff80;white-space:nowrap;text-overflow:ellipsis;margin-top:4px;font-size:.85rem;overflow:hidden}.add-mode-actions{gap:16px;margin:24px 0;display:flex}.add-mode-btn{color:#fff;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:16px;flex:1;padding:14px;font-family:Outfit,sans-serif;font-weight:600;transition:all .2s}.add-mode-btn:hover{background:#ffffff1a;border-color:#c8a84b66}.add-mode-btn.active{color:#000;background:#c8a84b;border-color:#c8a84b}.delete-book-btn{color:#ff6b6b;cursor:pointer;background:0 0;border:1px solid #ff6b6b4d;border-radius:8px;justify-content:center;align-items:center;padding:8px 12px;font-size:.9rem;transition:all .2s;display:flex}.delete-book-btn:hover{background:#ff6b6b26;border-color:#ff6b6b;transform:translateY(-1px)}.delete-book-btn:disabled{opacity:.5;cursor:not-allowed}.delete-tracker-btn{color:#ff6b6b;cursor:pointer;background:#ff6b6b1a;border:1px solid #ff6b6b4d;border-radius:12px;align-items:center;gap:8px;padding:10px 20px;font-size:.9rem;font-weight:600;transition:all .2s;display:flex}.delete-tracker-btn:hover{background:#ff6b6b33;border-color:#ff6b6b}.delete-tracker-btn:disabled{opacity:.5;cursor:not-allowed}@media (width<=768px){.checklist-container{padding:100px 20px 40px}.checklist-header h1{font-size:2.5rem}.tracker-grid{grid-template-columns:1fr}.floating-add-btn{width:56px;height:56px;font-size:2rem;bottom:24px;right:24px}}.login-page{padding-top:calc(var(--nav-height) + var(--space-16));padding-bottom:var(--space-24);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);width:100%;max-width:400px;padding:var(--space-8);box-shadow:var(--shadow-lg)}.login-title{font-family:var(--font-serif);font-size:var(--text-3xl);text-align:center;margin-bottom:var(--space-2)}.login-subtitle{color:var(--text-muted);text-align:center;margin-bottom:var(--space-8);font-size:var(--text-sm)}.login-oauth{gap:var(--space-3);margin-bottom:var(--space-6);flex-direction:column;display:flex}.login-btn{width:100%;padding:var(--space-3);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-base);cursor:pointer;justify-content:center;align-items:center;gap:var(--space-3);transition:all var(--duration-fast);font-weight:500;display:flex}.login-btn--github{color:#fff;background:#24292e;border:none}.login-btn--github:hover{background:#1b1f23}.login-btn--google{color:#3c4043;background:#fff;border:1px solid #dadce0}.login-btn--google:hover{background:#f8f9fa}.login-divider{text-align:center;margin-bottom:var(--space-6);color:var(--text-muted);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.1em;align-items:center;display:flex}.login-divider:before,.login-divider:after{content:"";border-bottom:1px solid var(--border-subtle);flex:1}.login-divider span{padding:0 var(--space-3)}.login-form{gap:var(--space-4);flex-direction:column;display:flex}.login-input-group{gap:var(--space-2);flex-direction:column;display:flex}.login-input-group label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.login-input-group input{padding:var(--space-3);border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-base);transition:border-color var(--duration-fast);outline:none}.login-input-group input:focus{border-color:var(--accent-primary)}.login-btn--email{background:var(--text-primary);color:var(--bg-card);margin-top:var(--space-2);border:none}.login-btn--email:hover{background:var(--text-secondary)}.login-btn--email:disabled{opacity:.7;cursor:not-allowed}.login-error{color:#b91c1c;padding:var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);margin-bottom:var(--space-4);text-align:center;background:#fef2f2}.login-success{color:#15803d;padding:var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);margin-bottom:var(--space-4);text-align:center;background:#f0fdf4}.login-forgot-link{color:var(--accent-primary);font-size:var(--text-xs);cursor:pointer;text-underline-offset:2px;opacity:.8;transition:opacity var(--duration-fast);background:0 0;border:none;padding:0;text-decoration:underline}.login-forgot-link:hover{opacity:1}.tiptap-wrapper{border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-primary);flex-direction:column;display:flex;overflow:hidden}.tiptap-toolbar{gap:var(--space-2);padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--border-subtle);background:var(--bg-card);flex-wrap:wrap;align-items:center;display:flex}.tiptap-toolbar button,.tiptap-image-upload{padding:var(--space-1) var(--space-3);border-radius:var(--radius-sm);color:var(--text-secondary);font-family:var(--font-sans);font-size:var(--text-sm);cursor:pointer;background:0 0;border:1px solid #0000;align-items:center;font-weight:500;transition:all .2s;display:inline-flex}.tiptap-toolbar button:hover,.tiptap-image-upload:hover{background:var(--bg-card-hover);color:var(--text-primary)}.tiptap-toolbar button.is-active{background:var(--accent-glow);color:var(--accent-primary);border-color:var(--accent-primary)}.tiptap-toolbar-divider{background:var(--border-subtle);width:1px;height:20px;margin:0 var(--space-1)}.tiptap-content{padding:var(--space-4);cursor:text;min-height:300px}.tiptap-content .ProseMirror{outline:none;min-height:250px}.tiptap-content .ProseMirror>*+*{margin-top:.75em}.tiptap-content .ProseMirror img{border-radius:var(--radius-md);max-width:100%;height:auto}.tiptap-content .ProseMirror h1,.tiptap-content .ProseMirror h2{font-family:var(--font-serif);line-height:1.2}.blog-admin{width:100%}.featured-image-upload{gap:var(--space-3);margin-top:var(--space-2);flex-direction:column;display:flex}.featured-preview{border-radius:var(--radius-md);max-width:200px;height:auto;box-shadow:var(--shadow-sm);border:1px solid var(--border-subtle)}.form-help{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-1)}.admin-sub-tab-container{width:100%}.admin-sub-tabs{gap:var(--space-4);margin-bottom:var(--space-6);border-bottom:1px solid var(--border-subtle);padding-bottom:var(--space-2);display:flex}.admin-sub-tabs button{color:var(--text-secondary);font-family:var(--font-sans);font-size:var(--text-sm);cursor:pointer;padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);background:0 0;border:none;font-weight:500;transition:all .2s}.admin-sub-tabs button:hover{background:var(--bg-card-hover);color:var(--text-primary)}.admin-sub-tabs button.active{background:var(--accent-glow);color:var(--accent-primary)}.films-search-form{gap:var(--space-2);margin-bottom:var(--space-6);display:flex}.films-search-form input{padding:var(--space-3) var(--space-4);border:1px solid var(--border-medium);border-radius:var(--radius-md);background:var(--bg-tertiary);color:var(--text-primary);font-family:var(--font-sans);flex:1}.films-search-form button{padding:0 var(--space-6);background:var(--accent-primary);color:var(--bg-primary);border-radius:var(--radius-md);cursor:pointer;border:none;font-weight:600;transition:all .2s}.films-search-form button:hover{background:var(--accent-secondary)}.films-search-form button:disabled{opacity:.7;cursor:not-allowed}.films-results{gap:var(--space-4);max-height:400px;padding-right:var(--space-2);grid-template-columns:repeat(auto-fill,minmax(120px,1fr));display:grid;overflow-y:auto}.film-result-card{cursor:pointer;border-radius:var(--radius-md);background:var(--bg-tertiary);border:1px solid #0000;transition:all .2s;overflow:hidden}.film-result-card:hover{border-color:var(--accent-primary);transform:translateY(-2px)}.film-result-card img{aspect-ratio:2/3;object-fit:cover;width:100%;display:block}.film-result-placeholder{aspect-ratio:2/3;background:var(--bg-card);width:100%;color:var(--text-muted);font-size:var(--text-xs);text-align:center;justify-content:center;align-items:center;display:flex}.film-result-info{padding:var(--space-2)}.film-result-info h4{font-size:var(--text-xs);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;overflow:hidden}.film-result-info p{color:var(--text-secondary);font-size:10px}.film-review-form{background:var(--bg-card);padding:var(--space-6);border-radius:var(--radius-lg);border:1px solid var(--border-subtle)}.film-review-header{gap:var(--space-6);margin:var(--space-6) 0;display:flex}.film-review-header img{border-radius:var(--radius-sm);width:80px;box-shadow:var(--shadow-sm)}.film-review-header h3{font-family:var(--font-serif);font-size:var(--text-xl);color:var(--text-primary);margin-bottom:var(--space-2)}.film-review-header p{color:var(--text-secondary);font-size:var(--text-sm)}.admin-page{padding-top:calc(var(--nav-height) + var(--space-8));padding-bottom:var(--space-16);min-height:80vh}.admin-page .page-header{margin-bottom:var(--space-8)}.admin-page .page-header__title{color:var(--text-primary);font-family:var(--font-serif);font-size:var(--text-4xl);margin-bottom:var(--space-2)}.admin-page .page-header__subtitle{color:var(--text-secondary);font-size:var(--text-lg)}.admin-card{background-color:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-8);box-shadow:var(--shadow-md);max-width:600px;margin:0 auto}.admin-form{gap:var(--space-6);margin-top:var(--space-6);flex-direction:column;display:flex}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-group label{font-family:var(--font-serif);color:var(--text-primary);font-weight:600;font-size:var(--text-base)}.form-group input,.form-group select,.form-group textarea{padding:var(--space-3);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background-color:var(--bg-primary);font-family:var(--font-sans);font-size:var(--text-base);color:var(--text-primary);transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent-primary);outline:none}.admin-submit-btn{background-color:var(--accent-primary);color:var(--text-primary);padding:var(--space-4);border-radius:var(--radius-md);font-family:var(--font-serif);font-size:var(--text-lg);cursor:pointer;margin-top:var(--space-4);border:none;font-weight:600;transition:all .2s}.admin-submit-btn:hover{background-color:var(--accent-secondary);color:#fff;box-shadow:var(--shadow-md);transform:translateY(-2px)}.admin-submit-btn:disabled{background-color:var(--text-muted);cursor:not-allowed;box-shadow:none;transform:none}.admin-message{margin-top:var(--space-4);padding:var(--space-3);border-radius:var(--radius-sm);text-align:center;font-family:var(--font-sans);font-weight:500}.admin-message.success{color:#155724;background-color:#d4edda;border:1px solid #c3e6cb}.admin-message.error{color:#721c24;background-color:#f8d7da;border:1px solid #f5c6cb}.btn-cancel{padding:var(--space-3) var(--space-5);background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border-medium);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);cursor:pointer;font-weight:500;transition:all .2s}.btn-cancel:hover:not(:disabled){background:var(--bg-card-hover);color:var(--text-primary)}.btn-cancel:disabled{opacity:.4;cursor:not-allowed}.admin-tabs{gap:var(--space-2);margin-bottom:var(--space-6);border-bottom:1px solid var(--border-subtle);padding-bottom:var(--space-1);display:flex}.admin-tab{padding:var(--space-3) var(--space-5);border-radius:var(--radius-md) var(--radius-md) 0 0;font-family:var(--font-sans);font-size:var(--text-sm);color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;font-weight:500;transition:all .2s}.admin-tab:hover{color:var(--text-primary)}.admin-tab--active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.admin-lookup-btn{padding:var(--space-3) var(--space-6);background:var(--accent-glow-strong);color:var(--accent-primary);border:1px solid var(--accent-primary);border-radius:var(--radius-md);font-family:var(--font-serif);font-size:var(--text-base);cursor:pointer;font-weight:600;transition:all .2s}.admin-lookup-btn:hover:not(:disabled){background:var(--accent-primary);color:var(--bg-primary)}.admin-lookup-btn:disabled{opacity:.4;cursor:not-allowed}.admin-source-badge{margin-left:var(--space-3);font-size:var(--text-xs);font-family:var(--font-mono);color:var(--text-muted);background:var(--bg-tertiary);border-radius:var(--radius-full);border:1px solid var(--border-subtle);padding:2px 8px;display:inline-block}.admin-form-row,.admin-meta-grid{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.admin-batch-info{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-4);margin-bottom:var(--space-5);font-size:var(--text-sm);color:var(--text-secondary);line-height:1.6}.admin-batch-info h3{font-family:var(--font-serif);color:var(--text-primary);margin-bottom:var(--space-2)}.admin-batch-info code{background:var(--bg-tertiary);border:1px solid var(--border-medium);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--accent-primary);padding:2px 8px;display:inline-block}.admin-csv-input{width:100%;padding:var(--space-3);border:1px solid var(--border-medium);border-radius:var(--radius-md);background:var(--bg-primary);font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-primary);resize:vertical;margin-bottom:var(--space-4);transition:border-color .2s}.admin-csv-input:focus{border-color:var(--accent-primary);outline:none}.admin-batch-controls{gap:var(--space-3);margin-bottom:var(--space-4);display:flex}.admin-batch-status{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--accent-secondary);margin-bottom:var(--space-4);line-height:1.8}.admin-batch-table{border:1px solid var(--border-subtle);border-radius:var(--radius-md);max-height:320px;overflow:auto}.admin-batch-table table{border-collapse:collapse;width:100%;font-size:var(--text-sm)}.admin-batch-table th{background:var(--bg-secondary);padding:var(--space-2) var(--space-3);text-align:left;font-family:var(--font-serif);color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);font-weight:600;position:sticky;top:0}.admin-batch-table td{padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--border-subtle);color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;max-width:240px;overflow:hidden}.batch-row--done td{color:var(--text-muted)}.batch-row--error td{color:#f87171}@media (width<=640px){.admin-form-row,.admin-meta-grid{grid-template-columns:1fr}.admin-batch-controls{flex-direction:column}}.admin-actions-grid{gap:var(--space-4);margin-bottom:var(--space-10);display:flex}.admin-action-card{border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-6);text-align:center;cursor:pointer;transition:all .3s var(--ease-out);align-items:center;gap:var(--space-2);background:#1a1a1a;flex-direction:column;flex:1;display:flex}.admin-action-card:hover{border-color:var(--accent-primary);background:#c8a84b0d;transform:translateY(-2px)}.admin-action-card.active{border-color:var(--accent-primary);background:#c8a84b1a}.admin-action-card .action-icon{margin-bottom:var(--space-2);font-size:24px}.admin-action-card .action-label{font-family:var(--font-serif);color:var(--text-primary);font-weight:600}.admin-action-card .action-desc{color:var(--text-muted);font-size:11px}.admin-success-toast{margin-top:var(--space-4);padding:var(--space-2) var(--space-6);border:1px solid var(--accent-primary);border-radius:var(--radius-full);color:var(--accent-primary);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;background:#c8a84b1a;font-size:11px;display:inline-block;box-shadow:0 4px 15px #c8a84b1a}.scanner-btn{border-color:var(--accent-primary)!important;background:#c8a84b08!important}.scanner-btn .action-icon{filter:drop-shadow(0 0 5px var(--accent-primary))}.admin-global-actions{max-width:300px;margin:0 auto var(--space-8) auto}.admin-identity-badge{font-family:var(--font-mono);color:var(--text-muted);text-align:center;margin-bottom:var(--space-4);text-transform:uppercase;letter-spacing:.1em;font-size:9px}.enrichment-page{padding-top:var(--space-8);padding-bottom:var(--space-12)}.enrichment-header{margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:flex-end;display:flex}.enrichment-header h3{font-family:var(--font-serif);font-size:var(--text-xl);color:var(--text-primary);margin-bottom:var(--space-1)}.enrichment-header p{color:var(--text-secondary);font-size:var(--text-sm);margin:0}.enrichment-progress{margin-bottom:var(--space-6)}.progress-bar{background:var(--bg-secondary);border-radius:var(--radius-full);width:100%;height:8px;margin-bottom:var(--space-2);overflow:hidden}.progress-fill{background:var(--accent-primary);height:100%;transition:width .3s}.enrichment-progress p{font-size:var(--text-xs);color:var(--text-secondary);text-align:right;font-family:var(--font-mono);margin:0}.enrichment-content{gap:var(--space-6);grid-template-columns:2fr 1fr;align-items:start;display:grid}.enrichment-list{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-4);max-height:500px;overflow-y:auto}.enrichment-list table{border-collapse:collapse;width:100%;font-size:var(--text-sm)}.enrichment-list th,.enrichment-list td{padding:var(--space-3);text-align:left;border-bottom:1px solid var(--border-subtle)}.enrichment-list th{color:var(--text-secondary);background:var(--bg-secondary);font-weight:500;position:sticky;top:0}.status-pending td{color:var(--text-secondary)}.status-processing td{color:var(--accent-primary)}.status-success td{color:#4caf50}.status-error td{color:#f44336}.enrichment-log{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);flex-direction:column;height:500px;display:flex}.enrichment-log h4{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-subtle);font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary);margin:0}.log-container{padding:var(--space-3);gap:var(--space-2);flex-direction:column;flex:1;display:flex;overflow-y:auto}.log-entry{font-family:var(--font-mono);font-size:var(--text-xs);padding:var(--space-2);border-radius:var(--radius-sm);background:#0003}.log-info{color:var(--text-primary)}.log-warning{color:var(--accent-primary)}.log-success{color:#4caf50;border-left:2px solid #4caf50}.log-error{color:#f44336;border-left:2px solid #f44336}.log-empty{color:var(--text-muted);font-family:var(--font-mono);font-size:var(--text-xs);text-align:center;margin-top:var(--space-4)}@media (width<=768px){.enrichment-content{grid-template-columns:1fr}}.travel-page{padding:calc(var(--nav-height) + var(--space-8)) 0 var(--space-24)}.travel-empty{text-align:center;color:var(--text-muted);margin-top:var(--space-12);font-style:italic}.trips-list{gap:var(--space-24);flex-direction:column;display:flex}.trip-section{border-top:1px solid var(--border-subtle);padding-top:var(--space-12)}.trip-header{margin-bottom:var(--space-8);max-width:600px}.trip-title{font-family:var(--font-serif);font-size:var(--text-3xl);color:var(--text-primary);margin-bottom:var(--space-2);font-weight:600}.trip-meta{gap:var(--space-4);font-family:var(--font-mono);font-size:var(--text-sm);color:var(--accent-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-4);display:flex}.trip-notes{font-size:var(--text-base);color:var(--text-secondary);line-height:1.6}.trip-gallery{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));align-items:start;display:grid}.trip-photo-wrapper{gap:var(--space-2);flex-direction:column;display:flex}.trip-photo{border-radius:var(--radius-lg);aspect-ratio:4/3;overflow:hidden}.trip-photo-caption{font-size:var(--text-xs);color:var(--text-muted);text-align:center;font-style:italic}.now-page{padding:calc(var(--nav-height) + var(--space-8)) 0 var(--space-24)}.now-empty{text-align:center;color:var(--text-muted);margin-top:var(--space-12);font-style:italic}.now-content{margin-top:var(--space-12);gap:var(--space-6);flex-direction:column;display:flex}.now-status{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-8);font-size:var(--text-xl);color:var(--text-primary);line-height:1.6;font-family:var(--font-serif);box-shadow:var(--shadow-md)}.now-meta{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;text-align:right}.about-page{padding:calc(var(--nav-height) + var(--space-8)) 0 var(--space-24)}.about-bio{font-size:var(--text-lg);color:var(--text-primary);margin-bottom:var(--space-16);line-height:1.8}.about-bio p{margin-bottom:var(--space-6)}.about-section-title{font-family:var(--font-serif);font-size:var(--text-2xl);color:var(--text-primary);margin-bottom:var(--space-8);border-bottom:1px solid var(--border-subtle);padding-bottom:var(--space-4);font-weight:600}.about-empty{color:var(--text-muted);font-style:italic}.gear-grid{gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(250px,1fr));display:grid}.gear-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all var(--duration-normal) var(--ease-out);flex-direction:column;display:flex;overflow:hidden}.gear-card:hover{border-color:var(--border-medium);box-shadow:var(--shadow-md), var(--shadow-glow);transform:translateY(-2px)}.gear-card__image-wrapper{aspect-ratio:16/9;background:var(--bg-tertiary);overflow:hidden}.gear-card__image{border-radius:0}.gear-card__content{padding:var(--space-4);gap:var(--space-2);flex-direction:column;display:flex}.gear-card__category{font-family:var(--font-mono);color:var(--accent-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:10px}.gear-card__title{font-family:var(--font-serif);font-size:var(--text-lg);color:var(--text-primary);font-weight:600}.gear-card__title a{color:inherit;text-decoration:none;transition:color .2s}.gear-card__title a:hover{color:var(--accent-primary)}.gear-card__desc{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5}.films-page{padding:calc(var(--nav-height) + var(--space-8)) 0 var(--space-24)}.films-empty{text-align:center;color:var(--text-muted);margin-top:var(--space-12);font-style:italic}.films-grid{gap:var(--space-8) var(--space-6);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));display:grid}.film-card{gap:var(--space-3);flex-direction:column;display:flex}.film-card__poster-wrapper{aspect-ratio:2/3;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);transition:transform .3s,box-shadow .3s;position:relative;overflow:hidden}.film-card:hover .film-card__poster-wrapper{box-shadow:var(--shadow-xl), var(--shadow-glow);transform:translateY(-4px)}.film-card__poster{border-radius:0}.film-card__poster-placeholder{background:var(--bg-tertiary);width:100%;height:100%;font-family:var(--font-serif);font-size:var(--text-4xl);color:var(--text-muted);justify-content:center;align-items:center;display:flex}.film-card__rating{top:var(--space-2);right:var(--space-2);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:var(--radius-full);color:var(--accent-primary);letter-spacing:1px;background:#0a0a0acc;border:1px solid #c8a84b4d;padding:4px 8px;font-size:10px;position:absolute}.film-card__info{flex-direction:column;gap:2px;display:flex}.film-card__title{font-family:var(--font-serif);font-size:var(--text-lg);color:var(--text-primary);font-weight:600;line-height:1.2}.film-card__meta{font-size:var(--text-xs);color:var(--text-secondary)}.film-card__review{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-2);-webkit-line-clamp:3;-webkit-box-orient:vertical;font-style:italic;display:-webkit-box;overflow:hidden}@media (width<=600px){.films-grid{gap:var(--space-6) var(--space-4);grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}
