@import url(https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;1,400&family=Crimson+Pro:ital,wght@0,300;0,400;1,300&display=swap);body{background-color:#f8f9fa;font-family:Arial,sans-serif;margin:0;padding:20px}:root{--bg:#f5f0e8;--bg2:#ede6d6;--bg3:#e4dbc8;--surface:#faf7f2;--surface2:#f0ead8;--text:#2c2416;--text2:#6b5a3e;--text3:#9c8565;--accent:#8b4513;--accent2:#c17f3a;--accent3:#d4a055;--border:#654a282e;--border2:#654a2852;--shadow:#2c24161f;--highlight:#c17f3a2e;--tag-bg:#8b45131a;--tag-text:#6b3a10;--input-bg:#faf7f2}body.dark{--bg:#1a1108;--bg2:#221708;--bg3:#2a1e0a;--surface:#251c0d;--surface2:#2e2210;--text:#f0e6cc;--text2:#c4a96e;--text3:#8a7050;--accent:#d4842a;--accent2:#e8a845;--accent3:#f2c46a;--border:#d4842a2e;--border2:#d4842a4d;--shadow:#0000008c;--highlight:#d4842a24;--tag-bg:#d4842a1f;--tag-text:#e8a845;--input-bg:#2e2210}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{background:#f5f0e8;background:var(--bg);color:#2c2416;color:var(--text);font-family:Crimson Pro,Georgia,serif;min-height:100vh;transition:background .4s ease,color .4s ease}body:before{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='a'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Cpath filter='url(%23a)' d='M0 0h300v300H0z'/%3E%3C/svg%3E");content:"";inset:0;opacity:.025;pointer-events:none;position:fixed;z-index:0}.app{animation:pageIn .5s ease both;margin:0 auto;max-width:860px;padding:2.5rem 1.5rem 5rem;position:relative;z-index:1}@keyframes pageIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}.header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:2.5rem}.eyebrow{color:#9c8565;color:var(--text3);font-size:11px;font-weight:300;letter-spacing:.22em;margin-bottom:.3rem;text-transform:uppercase}h1{color:#2c2416;color:var(--text);font-family:Playfair Display,Georgia,serif;font-size:clamp(2rem,5vw,3rem);font-weight:600;line-height:1.1}h1 em{color:#c17f3a;color:var(--accent2)}.subtitle,h1 em{font-style:italic}.subtitle{color:#9c8565;color:var(--text3);font-size:15px;font-weight:300;margin-top:.4rem}.toggle-wrap{align-items:center;display:flex;flex-direction:column;flex-shrink:0;gap:5px;padding-top:4px}.toggle-label{color:#9c8565;color:var(--text3);font-size:11px;letter-spacing:.12em;text-transform:uppercase;transition:color .3s}.toggle{cursor:pointer;display:block;height:27px;position:relative;width:50px}.toggle input{height:0;opacity:0;width:0}.toggle-track{align-items:center;background:#e4dbc8;background:var(--bg3);border:1px solid #654a2852;border:1px solid var(--border2);border-radius:14px;display:flex;font-size:10px;inset:0;justify-content:space-between;padding:0 5px;position:absolute;transition:background .35s}body.dark .toggle-track{background:#8b4513;background:var(--accent);border-color:#c17f3a;border-color:var(--accent2)}.toggle-thumb{background:#c17f3a;background:var(--accent2);border-radius:50%;height:19px;left:4px;position:absolute;top:4px;transition:transform .35s cubic-bezier(.34,1.56,.64,1),background .35s;width:19px}body.dark .toggle-thumb{background:#f5f0e8;background:var(--bg);transform:translateX(23px)}.icon-moon,.icon-sun{transition:opacity .3s}.icon-moon,body.dark .icon-sun{opacity:0}body.dark .icon-moon{opacity:1}.divider{background:linear-gradient(90deg,#0000,#654a2852 30%,#654a2852 70%,#0000);background:linear-gradient(90deg,#0000,var(--border2) 30%,var(--border2) 70%,#0000);height:1px;margin:1.5rem 0}.search-row{display:flex;gap:10px;margin-bottom:1rem}.search-wrap{flex:1 1;position:relative}.search-icon{color:#9c8565;color:var(--text3);font-size:18px;left:14px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.text-input{background:#faf7f2;background:var(--input-bg);border:1px solid #654a2852;border:1px solid var(--border2);border-radius:7px;color:#2c2416;color:var(--text);font-family:Crimson Pro,serif;font-size:16px;outline:none;padding:12px 16px 12px 44px;transition:border-color .2s,box-shadow .2s,background .4s;width:100%}.text-input::placeholder{color:#9c8565;color:var(--text3);font-style:italic}.text-input:focus{border-color:#c17f3a;border-color:var(--accent2);box-shadow:0 0 0 3px #c17f3a2e;box-shadow:0 0 0 3px var(--highlight)}.btn{border:1px solid #654a2852;border:1px solid var(--border2);border-radius:7px;cursor:pointer;font-family:Crimson Pro,serif;font-size:15px;letter-spacing:.03em;padding:12px 20px;transition:background .2s,border-color .2s,transform .1s;white-space:nowrap}.btn:active{transform:scale(.97)}.btn-primary{background:#8b4513;background:var(--accent);border-color:#8b4513;border-color:var(--accent);color:#faf7f2}.btn-primary:hover{background:#c17f3a;background:var(--accent2);border-color:#c17f3a;border-color:var(--accent2)}.btn-ghost{background:#0000;color:#6b5a3e;color:var(--text2)}.btn-ghost:hover{background:#f0ead8;background:var(--surface2);color:#2c2416;color:var(--text)}.btn-sm{font-size:14px;padding:9px 16px}.filters-row{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:1.5rem}.filter-label{color:#9c8565;color:var(--text3);font-size:13px;font-style:italic}.filter-select{appearance:none;background:#faf7f2;background:var(--input-bg);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='m0 0 5 6 5-6z' fill='%239c8565'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;border:1px solid #654a282e;border:1px solid var(--border);border-radius:7px;color:#6b5a3e;color:var(--text2);cursor:pointer;font-family:Crimson Pro,serif;font-size:14px;outline:none;padding:8px 30px 8px 12px;transition:border-color .2s,background-color .4s}.filter-select:focus{border-color:#c17f3a;border-color:var(--accent2)}.shelf-section{margin-bottom:1.75rem}.shelf-label{align-items:center;color:#9c8565;color:var(--text3);display:flex;font-size:11px;gap:8px;letter-spacing:.18em;margin-bottom:.6rem;text-transform:uppercase}.shelf-label:after{background:#654a282e;background:var(--border);content:"";flex:1 1;height:1px}.shelf-frame{border:1px solid #654a2852;border:1px solid var(--border2);border-radius:9px;box-shadow:0 6px 28px #2c24161f;box-shadow:0 6px 28px var(--shadow);overflow:hidden;position:relative;transition:box-shadow .3s}.shelf-frame:hover{box-shadow:0 8px 36px #2c24161f;box-shadow:0 8px 36px var(--shadow)}.shelf-img{display:block;height:auto;transition:filter .4s;width:100%}body.dark .shelf-img{filter:brightness(.72) sepia(.25) contrast(1.1)}.shelf-overlay{inset:0}.shelf-hint,.shelf-overlay{pointer-events:none;position:absolute}.shelf-hint{bottom:8px;color:#ffffffa6;font-size:11px;font-style:italic;right:12px;text-shadow:0 1px 3px #00000080}.pin{animation:pinPop .3s cubic-bezier(.34,1.56,.64,1) both;border-radius:50%;height:15px;pointer-events:none;position:absolute;transform:translate(-50%,-50%);width:15px}@keyframes pinPop{0%{transform:translate(-50%,-50%) scale(0)}to{transform:translate(-50%,-50%) scale(1)}}.pin-select{background:#c17f3a;background:var(--accent2);border:2.5px solid #ffffffd9;box-shadow:0 2px 8px #2c24161f;box-shadow:0 2px 8px var(--shadow)}.pin-found{animation:pinPop .3s cubic-bezier(.34,1.56,.64,1) both,pinPulse 2s ease-in-out .3s infinite;background:#8b4513;background:var(--accent);border:2.5px solid #ffffffe6;box-shadow:0 0 0 5px #c17f3a2e,0 2px 10px #2c24161f;box-shadow:0 0 0 5px var(--highlight),0 2px 10px var(--shadow)}@keyframes pinPulse{0%,to{box-shadow:0 0 0 4px #c17f3a2e,0 2px 10px #2c24161f;box-shadow:0 0 0 4px var(--highlight),0 2px 10px var(--shadow)}50%{box-shadow:0 0 0 8px #c17f3a2e,0 2px 10px #2c24161f;box-shadow:0 0 0 8px var(--highlight),0 2px 10px var(--shadow)}}.book-callout{align-items:center;animation:fadeSlide .3s ease both;background:#faf7f2;background:var(--surface);border:1px solid #654a2852;border-left:3px solid #c17f3a;border:1px solid var(--border2);border-left:3px solid var(--accent2);border-radius:9px;display:flex;gap:1rem;margin-bottom:1.5rem;padding:1rem 1.25rem}@keyframes fadeSlide{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}.callout-icon{font-size:26px}.callout-info{flex:1 1;min-width:0}.callout-title{color:#2c2416;color:var(--text);font-family:Playfair Display,serif;font-size:17px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.callout-meta{font-size:13px;font-style:italic;margin-top:2px}.callout-close,.callout-meta{color:#9c8565;color:var(--text3)}.callout-close{background:none;border:none;border-radius:5px;cursor:pointer;font-size:17px;line-height:1;padding:4px 6px;transition:background .15s,color .15s}.callout-close:hover{background:#f0ead8;background:var(--surface2);color:#2c2416;color:var(--text)}.stats-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:1.75rem}.stat-card{background:#faf7f2;background:var(--surface);border:1px solid #654a282e;border:1px solid var(--border);border-radius:9px;flex:1 1;min-width:90px;padding:.75rem 1rem;transition:background .4s,border-color .4s}.stat-num{color:#c17f3a;color:var(--accent2);font-family:Playfair Display,serif;font-size:26px;font-weight:600;line-height:1}.stat-lbl{color:#9c8565;color:var(--text3);font-size:11px;letter-spacing:.1em;margin-top:4px;text-transform:uppercase}.admin-toggle-row{display:flex;justify-content:flex-end;margin-bottom:1rem}.admin-panel{animation:fadeSlide .25s ease both;background:#faf7f2;background:var(--surface);border:1px solid #654a2852;border:1px solid var(--border2);border-radius:10px;margin-bottom:1.75rem;padding:1.5rem}.admin-panel h3{font-family:Playfair Display,serif;font-size:18px;font-weight:600;margin-bottom:1rem}.form-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.form-group{display:flex;flex-direction:column;gap:5px}.form-label{color:#9c8565;color:var(--text3);font-size:11px;letter-spacing:.12em;text-transform:uppercase}.form-input{background:#faf7f2;background:var(--input-bg);border:1px solid #654a2852;border:1px solid var(--border2);border-radius:7px;color:#2c2416;color:var(--text);font-family:Crimson Pro,serif;font-size:15px;outline:none;padding:10px 13px;transition:border-color .2s,box-shadow .2s,background .4s}.form-input:focus{border-color:#c17f3a;border-color:var(--accent2);box-shadow:0 0 0 3px #c17f3a2e;box-shadow:0 0 0 3px var(--highlight)}.pos-hint{color:#9c8565;color:var(--text3);font-size:13px;font-style:italic;margin-top:.6rem}.pos-set{color:#c17f3a;color:var(--accent2)}.form-actions{display:flex;justify-content:flex-end;margin-top:1rem}.books-header{align-items:center;display:flex;margin-bottom:.75rem}.books-header h2{font-family:Playfair Display,serif;font-size:20px;font-weight:600}.book-list{list-style:none}.book-item{align-items:center;border-bottom:1px solid #654a282e;border-bottom:1px solid var(--border);border-radius:0;cursor:pointer;display:flex;gap:14px;padding:13px 14px;transition:background .15s,padding-left .15s}.book-list li:first-child{border-top:1px solid #654a282e;border-top:1px solid var(--border)}.book-item:hover{background:#faf7f2;background:var(--surface);padding-left:18px}.book-item.active{background:#c17f3a2e;background:var(--highlight);padding-left:18px}.book-spine{align-self:stretch;border-radius:3px;flex-shrink:0;min-height:34px;opacity:.6;transition:opacity .2s;width:5px}.book-item.active .book-spine,.book-item:hover .book-spine{opacity:1}.book-item-info{flex:1 1;min-width:0}.book-title{color:#2c2416;color:var(--text);font-family:Playfair Display,serif;font-size:15px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.book-author{color:#9c8565;color:var(--text3);font-size:13px;font-style:italic;margin-top:2px}.book-tag{background:#8b45131a;background:var(--tag-bg);border-radius:5px;color:#6b3a10;color:var(--tag-text);flex-shrink:0;font-size:11px;letter-spacing:.06em;padding:3px 9px;text-transform:uppercase;white-space:nowrap}.book-year{flex-shrink:0;font-size:13px}.book-year,.empty{color:#9c8565;color:var(--text3)}.empty{animation:fadeSlide .3s ease both;padding:3rem 1rem;text-align:center}.empty-icon{font-size:40px;margin-bottom:.5rem}.empty p{font-size:16px;font-style:italic}@media (max-width:580px){.app{padding:1.5rem 1rem 4rem}.form-grid{grid-template-columns:1fr}.book-tag,.book-year{display:none}h1{font-size:1.9rem}.search-row{flex-wrap:wrap}.search-wrap{flex:1 1 100%}}
/*# sourceMappingURL=main.c9891cd3.css.map*/