*,*:before,*:after{box-sizing:border-box}button,input,select,textarea{font-family:inherit}.ibm-plex-sans{font-family:IBM Plex Sans,sans-serif;font-optical-sizing:auto;font-weight:400;font-style:normal;font-variation-settings:"wdth" 100}h1{font-size:clamp(1.5rem,5vw,4rem);font-weight:400;margin:5px;border-bottom:solid 6px #eeefe9;text-align:center}body{margin:0;background-image:url(https://res.cloudinary.com/dmukukwp6/image/upload/keyboard_garden_bg_dark_9ab088797a.png);background-size:100px 100px;background-repeat:repeat;background-color:#eeefe994;background-blend-mode:lighten;font-family:IBM Plex Sans,sans-serif;font-weight:400;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.home{padding:12px;max-width:1400px;margin:0 auto}.home h1{text-align:center;color:#333;margin-bottom:16px}.home h2{color:#555;margin-top:16px;margin-bottom:12px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:12px}.section-header h2{margin:0;font-size:clamp(1rem,3vw,1.4rem)}.section-header__action{flex-shrink:0;padding:8px 14px;background:#28a745;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:13px;white-space:nowrap}.section-header__action:hover{background:#218838}.section-header__action--danger{background:#dc3545}.section-header__action--danger:hover{background:#c82333}.character-management{background:#f9f9f9;padding:16px;border-radius:8px;margin-bottom:24px;border:1px solid #e0e0e0}.character-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.character-item{display:flex;flex-direction:column;gap:8px;padding:12px;background:#fff;border-radius:4px;border:1px solid #ddd}.character-item__name{font-weight:700}.character-item__location{color:#666;font-size:14px}.character-item__actions{display:flex;gap:8px;flex-wrap:wrap}.character-item button{padding:8px 12px;background:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:13px;flex:1;min-width:0}.character-item button:hover{background:#0056b3}.location-color-swatch{display:flex;align-items:center;gap:8px}.location-color-swatch__dot{width:20px;height:20px;border-radius:50%;flex-shrink:0}.edit-modal{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.edit-modal__content{background:#fff;padding:20px;border-radius:8px;box-shadow:0 4px 6px #0000001a;max-width:400px;width:100%;max-height:calc(100vh - 32px);overflow-y:auto}.edit-modal__content h3{margin-top:0;color:#333;font-size:clamp(1rem,3vw,1.25rem)}.edit-modal__field{margin-bottom:12px;display:flex;flex-direction:column}.edit-modal__field label{font-weight:700;margin-bottom:5px;color:#555;font-size:14px}.edit-modal__field input,.edit-modal__field select{padding:10px;border:1px solid #ddd;border-radius:4px;font-size:16px;font-family:inherit;width:100%}.edit-modal__field input:disabled{background:#f5f5f5;cursor:not-allowed}.edit-modal__field input:focus,.edit-modal__field select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff40}.edit-modal__actions{display:flex;gap:8px;margin-top:16px}.edit-modal__actions button{flex:1;padding:12px;border:none;border-radius:4px;cursor:pointer;font-weight:700;font-size:14px;font-family:inherit}.edit-modal__actions button:first-child{background:#28a745;color:#fff}.edit-modal__actions button:first-child:hover{background:#218838}.edit-modal__actions button:last-child{background:#6c757d;color:#fff}.edit-modal__actions button:last-child:hover{background:#5a6268}.color-picker-row{display:flex;gap:16px;flex-wrap:wrap}.new-group-input{margin-top:8px;padding:10px 12px;border:1px solid #007bff;border-radius:6px;font-size:16px;font-family:inherit;background:#fff;width:100%;box-shadow:0 0 0 3px #007bff26;outline:none}.accordion-list{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.accordion-item{border:1px solid #e0d5c1;border-radius:6px;overflow:hidden;background:#ffffff8c;transition:box-shadow .15s}.accordion-item--open{box-shadow:0 2px 8px #00000014;background:#fff}.accordion-header{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;border:none;background:transparent;cursor:pointer;font-family:inherit;font-size:14px;text-align:left;-webkit-tap-highlight-color:transparent;touch-action:manipulation;min-height:48px}.accordion-header:hover{background:#00000008}.accordion-avatar{flex-shrink:0;line-height:0}.accordion-name{flex:1;font-weight:600;color:#2b2b2b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.accordion-badge{flex-shrink:0;font-size:11px;padding:2px 7px;border-radius:10px;background:#4a3b2c1a;color:#4a3b2c;font-weight:600;white-space:nowrap}.accordion-location{flex-shrink:0;font-size:12px;color:#8a7b6b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:90px}.accordion-chevron{flex-shrink:0;font-size:10px;color:#8a7b6b;margin-left:4px}.accordion-rel-dot{flex-shrink:0;width:10px;height:10px;border-radius:50%}.accordion-body{padding:10px 12px 14px;border-top:1px solid #ede6d8;display:flex;flex-direction:column;gap:8px;background:#fdfbf7}.accordion-detail{margin:0;font-size:13px;color:#4a3b2c;line-height:1.4}.accordion-members{display:flex;flex-wrap:wrap;gap:6px}.group-member-tag{font-size:12px;padding:3px 10px;border-radius:12px;background:#4a3b2c1a;color:#4a3b2c;font-weight:600}.accordion-field{display:flex;flex-direction:column;gap:4px}.accordion-field label{font-size:12px;font-weight:700;color:#6b5c4c;text-transform:uppercase;letter-spacing:.03em}.accordion-field select,.accordion-field input[type=range]{width:100%;padding:8px 10px;border:1px solid #ddd;border-radius:5px;font-size:14px;font-family:inherit;background:#fff}.accordion-field input[type=range]{padding:0;height:28px}.accordion-edit-btn{align-self:flex-start;padding:8px 14px;border:none;border-radius:5px;font-size:13px;font-family:inherit;font-weight:600;cursor:pointer;background:#4a3b2c;color:#fdfbf7;touch-action:manipulation;min-height:40px}.accordion-edit-btn:hover{background:#3a2c1e}.accordion-edit-btn--danger{background:#dc3545;color:#fff}.accordion-edit-btn--danger:hover{background:#c82333}.accordion-empty{font-size:13px;color:#8a7b6b;font-style:italic;margin:8px 0 0}.location-region-group{margin-bottom:2px}.location-region-header{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#6b5c4c;margin:6px 0 3px;padding-left:4px;border-left:3px solid #c2b280}.location-region-header--btn{display:flex;align-items:center;gap:7px;width:100%;background:#c2b2801f;border:1px solid rgba(194,178,128,.35);border-radius:5px;padding:6px 10px;cursor:pointer;font-family:inherit;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#6b5c4c;touch-action:manipulation;min-height:36px}.location-region-header--btn:hover{background:#c2b28038}.location-region-header--ungrouped{background:transparent;border-color:#0000000f;color:#8a7b6b}.location-region-header--ungrouped:hover{background:#00000008}.location-region-chevron{margin-left:auto;font-size:9px;color:#8a7b6b}.map-sheet{position:absolute;bottom:0;left:0;right:0;background:#fdfbf7;border-top:1px solid #e0d5c1;border-radius:10px 10px 0 0;box-shadow:0 -4px 18px #0003;display:flex;flex-direction:column;max-height:42%;z-index:201}.map-sheet__header{display:flex;align-items:center;padding:8px 12px 4px;gap:8px;flex-shrink:0;position:relative}.map-sheet__drag-handle{width:32px;height:3px;border-radius:2px;background:#d5c9b8;position:absolute;top:6px;left:50%;transform:translate(-50%)}.map-sheet__title{flex:1;font-weight:700;font-size:14px;color:#2b2b2b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:4px}.map-sheet__close{flex-shrink:0;background:none;border:none;font-size:15px;color:#8a7b6b;cursor:pointer;padding:2px 4px;line-height:1;touch-action:manipulation}.map-sheet__tabs{display:flex;border-bottom:1px solid #e0d5c1;flex-shrink:0;padding:0 12px}.map-sheet__tab{flex:1;padding:5px 6px;border:none;background:none;font-size:12px;font-family:inherit;font-weight:600;color:#8a7b6b;cursor:pointer;border-bottom:2px solid transparent;touch-action:manipulation;transition:color .15s,border-color .15s}.map-sheet__tab--active{color:#4a3b2c;border-bottom-color:#4a3b2c}.map-sheet__body{padding:10px 12px 12px;display:flex;flex-direction:column;gap:8px}.map-sheet__field-nav{display:flex;gap:5px;flex-wrap:wrap}.map-sheet__field-pill{padding:4px 11px;border:1px solid #c2b280;border-radius:12px;background:transparent;color:#6b5c4c;font-size:12px;font-family:inherit;font-weight:600;cursor:pointer;touch-action:manipulation;transition:background .12s,color .12s}.map-sheet__field-pill--active{background:#4a3b2c;border-color:#4a3b2c;color:#fdfbf7}.map-sheet__active-field{display:flex;flex-direction:column;gap:6px}.map-sheet__active-field input,.map-sheet__active-field select{width:100%;padding:8px 10px;border:1px solid #ddd;border-radius:6px;font-size:15px;font-family:inherit;background:#fff}.map-sheet__colors{display:flex;flex-wrap:wrap;gap:12px;align-items:center;padding:4px 0}.map-sheet__color-swatch{width:30px;height:30px;border-radius:50%;border:2px solid transparent;cursor:pointer;box-shadow:0 2px 4px #0003;touch-action:manipulation;transition:transform .12s,border-color .12s}.map-sheet__color-swatch--active{border-color:#007bff;box-shadow:0 0 0 3px #007bff47;transform:scale(1.15)}.map-sheet__actions{display:flex;gap:8px}.map-sheet__btn{flex:1;padding:9px 10px;border:none;border-radius:6px;font-size:13px;font-family:inherit;font-weight:700;cursor:pointer;touch-action:manipulation;min-height:42px}.map-sheet__btn--save{background:#4a3b2c;color:#fdfbf7}.map-sheet__btn--save:hover{background:#3a2c1e}.map-sheet__btn--danger{background:#dc3545;color:#fff;flex:0 0 auto;padding:9px 14px}.map-sheet__btn--danger:hover{background:#c82333}.map-sheet__hint{font-size:10px;color:#aaa;margin:0;font-style:italic;text-align:center}.map-sheet__empty{font-size:13px;color:#8a7b6b;font-style:italic}.map-sheet__char-list{display:flex;flex-wrap:wrap;gap:6px}.map-sheet__field{display:flex;flex-direction:column;gap:4px}.map-sheet__field label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#8a7b6b}.map-sheet__group-btns{display:flex;flex-wrap:wrap;gap:6px}.map-sheet__group-pill{padding:4px 11px;border:1px solid #4a3b2c;border-radius:12px;background:transparent;color:#4a3b2c;font-size:12px;font-family:inherit;font-weight:600;cursor:pointer;touch-action:manipulation}.map-sheet__group-pill:hover{background:#4a3b2c;color:#fdfbf7}.locations-container{margin-bottom:24px}.map-container{position:relative;width:100%;margin:0 auto;border:1px solid #ddd;border-radius:8px;overflow:hidden;background:#f0f0f0;-webkit-overflow-scrolling:touch}.map-image{width:100%;display:block}.map-pin{position:absolute;transform:translate(-50%,-100%);cursor:pointer;z-index:20;display:flex;flex-direction:column;align-items:center;transition:transform .2s;touch-action:none;--character-width: 18px;--character-height: 24px;--character-overlap: -4px;--character-top-offset: 20px}.map-pin:hover{transform:translate(-50%,-100%) scale(1.1);z-index:30}.map-pin-icon{width:20px;height:20px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);margin-bottom:4px;box-shadow:0 4px 6px #0000004d;border:2px solid white}.map-pin-label{display:block;font-size:9px;font-weight:700;color:#1a1a1a;background:#ffffffd1;border-radius:3px;padding:1px 4px;white-space:nowrap;text-align:center;margin-top:2px;pointer-events:none;letter-spacing:.01em;box-shadow:0 1px 3px #0000002e}.map-pin-characters{display:flex;position:absolute;top:var(--character-top-offset);left:50%;transform:translate(-50%);justify-content:center;pointer-events:none;margin-top:4px}.map-pin-character{width:var(--character-width);height:var(--character-height);margin:0 var(--character-overlap);transition:width .2s,height .2s;position:relative;overflow:visible}.map-pin-character svg{width:100%;height:100%;display:block}.travel-avatar{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;z-index:25;-webkit-user-select:none;user-select:none;transition:left .1s,top .1s;touch-action:none}.travel-avatar svg{width:18px;height:24px;display:block;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}.travel-avatar-name{font-size:9px;font-weight:600;background:#000000ad;color:#f0e6d2;padding:1px 5px;border-radius:3px;margin-top:2px;white-space:nowrap;pointer-events:none}.map-pin-names-label{position:absolute;top:calc(var(--character-top-offset) + var(--character-height) + 3px);left:50%;transform:translate(-50%);font-size:9px;font-weight:600;white-space:nowrap;color:#f0e6d2;background:#000000ad;padding:1px 5px;border-radius:3px;pointer-events:none}.travel-avatar-group-cluster{display:flex;flex-direction:row;align-items:flex-end;gap:2px}.travel-avatar-group-member{width:18px;height:24px;flex-shrink:0}.travel-avatar-group-member svg{width:100%;height:100%;display:block;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}.map-uploader{padding:30px 16px;text-align:center;border:2px dashed #ccc;border-radius:8px;background:#fafafa;margin:0 auto}.map-uploader p{margin-bottom:12px;color:#666}.pin-modal-content{background:#fff;padding:20px;border-radius:8px;box-shadow:0 4px 6px #0000001a;max-width:500px;width:100%;max-height:calc(100vh - 32px);overflow-y:auto}.pin-popup-groups{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.pin-popup-groups button{padding:6px 10px;font-size:12px;background:#6c757d;color:#fff;border:none;border-radius:4px;cursor:pointer}.pin-popup-groups button:hover{background:#5a6268}.book-theme{padding:16px 8px;background-color:#2b2b2b;min-height:100vh;background-image:radial-gradient(circle at center,#3a3a3a,#1a1a1a);max-width:none}.book-title{color:#f0e6d2!important;text-transform:uppercase;letter-spacing:clamp(1px,.5vw,4px);text-shadow:0 4px 10px rgba(0,0,0,.5);font-family:inherit;font-size:clamp(1.2rem,4vw,3rem);border-bottom:none;padding:0 8px;word-break:break-word}.book-container{display:flex;flex-direction:column;max-width:1400px;margin:0 auto;min-height:0;box-shadow:0 10px 30px #0009;border-radius:8px;background:#3c2415;padding:6px;position:relative;gap:4px}.book-container:before{content:"";position:absolute;inset:0;border-radius:8px;box-shadow:inset 0 0 10px #000;pointer-events:none;z-index:5}.book-page{flex:1 1 auto;background-color:#fdfbf7;background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="200" height="200" opacity="0.04"><filter id="noise"><feTurbulence type="fractalNoise" baseFrequency="0.8" numOctaves="4" stitchTiles="stitch"/></filter><rect width="100%" height="100%" filter="url(%23noise)"/></svg>');padding:16px;overflow-y:auto;position:relative;box-shadow:inset 0 0 20px #0000000d;border-radius:4px}.book-page::-webkit-scrollbar{width:6px}.book-page::-webkit-scrollbar-track{background:transparent}.book-page::-webkit-scrollbar-thumb{background:#ddd5c4;border-radius:4px}.book-page-left,.book-page-right{border-radius:4px;box-shadow:inset 0 0 20px #00000014}.book-spine{display:none}.book-spine-crease{position:absolute;top:0;bottom:0;left:50%;width:4px;transform:translate(-50%);background:#00000026;box-shadow:0 0 8px #0006}.book-theme h2{font-family:inherit;color:#4a3b2c;border-bottom:2px solid #e0d5c1;padding-bottom:8px;margin-top:0;font-size:clamp(.95rem,3vw,1.4rem)}.book-theme .character-management{background:transparent;border:none;padding:0;margin-bottom:24px}.book-theme .character-item{background:#fff9;border:1px solid #e0d5c1;box-shadow:0 2px 4px #00000005;transition:all .2s}.book-theme .character-item:hover{background:#fff;box-shadow:0 4px 8px #0000000d;transform:translateY(-1px)}.book-theme .map-container{border:3px solid #4a3b2c;box-shadow:0 4px 15px #0003;border-radius:4px;width:100%}.book-nav-container{display:flex;justify-content:center;padding:12px 0 4px}.book-nav-button{padding:10px 20px;font-family:inherit;font-size:14px;font-weight:700;font-style:italic;background:transparent;color:#4a3b2c;border:1px solid #4a3b2c;border-radius:4px;cursor:pointer;transition:all .2s;width:100%;max-width:200px}.book-nav-button:hover{background:#4a3b2c;color:#fdfbf7}.page-indicator{display:flex;justify-content:center;gap:8px;margin-top:16px;padding:4px 0}.page-dot-wrapper{display:flex;flex-direction:column;align-items:center;cursor:pointer;padding:8px;-webkit-tap-highlight-color:transparent}.page-dot{width:12px;height:12px;border-radius:50%;background:#f0e6d240;border:2px solid rgba(240,230,210,.4);cursor:pointer;transition:all .3s}.page-dot:hover{background:#f0e6d280}.page-dot.active{background:#f0e6d2;border-color:#f0e6d2;box-shadow:0 0 8px #f0e6d280}.page-dot-label{color:#f0e6d280;font-family:inherit;font-size:10px;font-style:italic;text-align:center;margin-top:4px}.page-dot.active+.page-dot-label,.page-dot-wrapper.active .page-dot-label{color:#f0e6d2}.contents-page{padding:0}.char-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;margin-top:10px}.char-card{display:flex;flex-direction:column;align-items:center;background:#fff9;border:1px solid #e0d5c1;border-radius:8px;padding:12px 8px 10px;text-align:center;transition:all .2s;box-shadow:0 2px 4px #0000000a}.char-card:hover{background:#fff;box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.char-card__avatar{width:36px;height:44px;margin-bottom:6px;flex-shrink:0}.char-card__avatar svg{width:100%;height:100%;display:block}.char-card__name{font-family:inherit;font-weight:700;font-size:13px;color:#2b2b2b;margin-bottom:4px;word-break:break-word}.char-card__info{display:flex;flex-direction:column;align-items:center;gap:3px;width:100%}.char-card__location{font-size:10px;color:#5c4e3f;font-style:italic;word-break:break-word}.char-card__skills{font-size:10px;color:#7a6b5a;word-break:break-word}.char-card__traits{display:flex;flex-wrap:wrap;gap:3px;justify-content:center;margin-top:4px}.char-card__trait-tag{font-size:9px;background:#4a3b2c;color:#f0e6d2;padding:1px 6px;border-radius:8px;white-space:nowrap}.group-section{margin-bottom:20px}.group-section-title{font-family:inherit;font-size:13px;font-weight:700;color:#4a3b2c;text-transform:uppercase;letter-spacing:1.5px;border-bottom:1px solid #e0d5c1;padding-bottom:6px;margin-bottom:8px;margin-top:0}.group-card{background:#fff9;border:1px solid #e0d5c1;border-radius:6px;padding:14px;margin-bottom:10px;transition:all .2s}.group-card:hover{background:#fff;box-shadow:0 4px 8px #0000000d}.group-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:8px}.group-card-name{font-family:inherit;font-size:16px;font-weight:700;color:#4a3b2c}.group-card-count{font-size:12px;color:#8a7b6b;font-style:italic;white-space:nowrap}.group-card-members{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.group-member-tag{background:#e0d5c1;color:#4a3b2c;padding:3px 10px;border-radius:12px;font-size:12px;font-family:inherit}.group-card-location{display:flex;align-items:center;gap:8px;font-size:13px;color:#5c4e3f;flex-wrap:wrap}.group-card-location select{padding:6px 8px;border:1px solid #e0d5c1;border-radius:4px;font-family:inherit;font-size:14px;background:#fff;cursor:pointer;flex:1;min-width:0}.group-card-actions{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}.group-card-actions button{padding:6px 12px;font-size:12px;border:none;border-radius:4px;cursor:pointer;font-family:inherit;flex:1;min-width:0}.page-content{min-height:0}@media(min-width:480px){.book-theme{padding:20px 16px}.book-container{padding:8px}.book-page{padding:24px}.map-pin-icon{width:24px;height:24px}.contents-item{font-size:15px}.contents-name{font-size:16px}.character-item{flex-direction:row;align-items:center;gap:12px}.character-item__name{flex:1;min-width:0}.character-item__location{flex-shrink:0}.character-item button{flex:0 0 auto;width:auto}}@media(min-width:768px){.home{padding:30px}.book-theme{padding:40px}.book-container{flex-direction:row;height:80vh;padding:10px 12px;box-shadow:0 20px 50px #000c;gap:0}.book-page{flex:1 1 0;min-width:0;padding:32px;border-radius:0}.book-page-left{border-radius:4px 0 0 4px;box-shadow:inset -25px 0 30px -10px #00000026,inset 3px 0 10px #ffffffb3;transform-origin:right center}.book-page-right{border-radius:0 4px 4px 0;box-shadow:inset 25px 0 30px -10px #00000026,inset -3px 0 10px #ffffffb3;transform-origin:left center}.book-spine{display:block;width:50px;background:linear-gradient(to right,#dcd3c0,#f4ede1 20%,#c4bca9,#f4ede1 80%,#dcd3c0);position:relative;z-index:10;box-shadow:inset 0 0 25px #00000080;flex-shrink:0}.book-nav-container{padding:0}.book-nav-button{position:absolute;bottom:20px;width:auto;max-width:none}.prev-button{left:30px}.next-button{right:30px}.page-indicator{gap:12px;margin-top:20px}.page-dot-label{font-size:11px}.edit-modal__content{padding:30px}.contents-page{padding:20px}.contents-item{font-size:16px}.contents-name{font-size:18px}.map-uploader{padding:50px;max-width:600px}}@media(min-width:1024px){.book-page{padding:40px}.page-content{height:100%;overflow-y:auto}}.bookshelf-view{display:flex;flex-direction:column;align-items:center;min-height:80vh;padding:40px 20px}.bookshelf-header{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:800px;margin-bottom:30px;flex-wrap:wrap;gap:12px}.bookshelf-heading{color:#f0e6d2!important;text-transform:uppercase;letter-spacing:4px;text-shadow:0 4px 10px rgba(0,0,0,.5);font-size:clamp(1.2rem,3vw,2rem);border-bottom:none;margin:0}.bookshelf-header-actions{display:flex;gap:8px}.bookshelf-edit-btn,.bookshelf-add-btn{padding:8px 16px;font-size:13px;font-weight:600;border:1px solid rgba(240,230,210,.25);border-radius:4px;cursor:pointer;transition:all .2s;background:#ffffff14;color:#f0e6d2}.bookshelf-edit-btn:hover,.bookshelf-add-btn:hover{background:#ffffff26}.bookshelf-edit-btn.active{background:#4ab4644d;border-color:#4ab46480}.shelf-settings{background:#ffffff0f;border:1px solid rgba(240,230,210,.15);border-radius:6px;padding:12px 20px;margin-bottom:20px;width:100%;max-width:800px}.shelf-settings label{display:flex;align-items:center;gap:12px;color:#f0e6d2;font-size:14px}.shelf-settings input[type=range]{flex:1;max-width:200px;accent-color:#A0782C}.shelf-settings span{color:#f0e6d2;font-weight:700;min-width:20px;text-align:center}.bookshelf-shelves{display:flex;flex-direction:column;gap:20px;width:100%;max-width:800px}.bookshelf{display:flex;flex-direction:column;align-items:center;width:100%}.bookshelf-books{display:flex;align-items:flex-end;justify-content:center;gap:12px;padding:0 20px;min-height:120px;flex-wrap:wrap}.bookshelf-book-wrapper{display:flex;flex-direction:column;align-items:center;gap:6px}.bookshelf-book{width:50px;border:none;border-radius:3px 6px 6px 3px;cursor:pointer;position:relative;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:2px 2px 6px #0006,inset -2px 0 4px #0003,inset 2px 0 4px #ffffff0d}.bookshelf-book:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:#00000040;border-radius:3px 0 0 3px}.bookshelf-book:after{content:"";position:absolute;inset:8px;border:1px solid rgba(240,230,210,.15);border-radius:2px;pointer-events:none}.bookshelf-book:hover{transform:translateY(-12px);box-shadow:2px 8px 16px #00000080,inset -2px 0 4px #0003,inset 2px 0 4px #ffffff0d}.bookshelf-book__title{writing-mode:vertical-rl;text-orientation:mixed;color:#f0e6d2;font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;text-shadow:0 1px 2px rgba(0,0,0,.5);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-height:calc(100% - 20px);padding:0 2px}.bookshelf-plank{width:100%;height:16px;background:linear-gradient(180deg,#8b6914,#a0782c 30%,#6b4f12);border-radius:0 0 4px 4px;box-shadow:0 4px 8px #0006,inset 0 2px 2px #ffffff26;position:relative}.bookshelf-plank:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#8b6914cc,#b48c32e6,#8b6914cc);border-radius:4px 4px 0 0}.shelf-empty{color:#f0e6d233;font-size:12px;font-style:italic;padding:20px}.book-edit-controls{display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px;background:#0006;border-radius:4px;margin-top:4px;min-width:80px}.book-edit-height{display:flex;align-items:center;gap:4px}.book-edit-height button{background:#ffffff26;border:none;color:#f0e6d2;width:20px;height:20px;border-radius:3px;cursor:pointer;font-size:10px;display:flex;align-items:center;justify-content:center}.book-edit-height button:hover{background:#ffffff40}.book-edit-height span{color:#f0e6d2;font-size:10px;min-width:32px;text-align:center}.book-edit-colors{display:grid;grid-template-columns:repeat(6,1fr);gap:2px}.color-dot{width:12px;height:12px;border-radius:50%;border:1px solid rgba(255,255,255,.2);cursor:pointer;padding:0;transition:transform .15s}.color-dot:hover{transform:scale(1.3)}.color-dot.active{border:2px solid #f0e6d2;box-shadow:0 0 4px #f0e6d280}.book-edit-shelf label{display:flex;align-items:center;gap:4px;color:#f0e6d2;font-size:10px}.book-edit-shelf select{background:#ffffff26;border:1px solid rgba(255,255,255,.2);color:#f0e6d2;border-radius:3px;padding:2px 4px;font-size:10px}.book-delete-btn{background:#dc35454d;border:1px solid rgba(220,53,69,.4);color:#f0e6d2;border-radius:3px;cursor:pointer;padding:2px 6px;font-size:12px;transition:background .2s}.book-delete-btn:hover{background:#dc354580}.close-book-container{display:flex;justify-content:center;margin-top:20px;padding-top:16px;border-top:1px solid #e0d5c1}.close-book-button{padding:10px 24px;font-size:14px;font-weight:700;background:#4a3b2c;color:#f0e6d2;border:1px solid #6b5a48;border-radius:4px;cursor:pointer;transition:all .2s;letter-spacing:.5px}.close-book-button:hover{background:#5c4a38;box-shadow:0 2px 8px #0000004d;transform:translateY(-1px)}
