@import "https://fonts.googleapis.com/css2?family=Jua&display=swap";
:root{--yellow-base:#fffdf0;--yellow-warm:#ffe082;--white-sub:#fff;--text-color:#795548;--diary-border:#e0e0e0;--shadow-color:#0000000d}body{background-color:var(--yellow-base);color:var(--text-color);flex-direction:column;width:100%;min-height:100vh;margin:0;padding:0;font-family:Jua,sans-serif;display:flex;overflow-x:hidden}*{box-sizing:border-box}.lucide-icon{vertical-align:middle;margin-top:-3px;margin-right:6px;display:inline-block}.rounded-card{background-color:var(--white-sub);box-shadow:0 4px 12px var(--shadow-color);border-radius:15px;padding:18px}.cute-input{background-color:var(--white-sub);border:2px solid var(--yellow-warm);color:var(--text-color);border-radius:15px;outline:none;width:100%;padding:10px 14px;font-family:Jua,sans-serif;font-size:clamp(1rem,3vw,1.2rem);transition:all .2s}.cute-input:focus{border-color:#ffb300;box-shadow:0 0 0 3px #ffe0824d}.cute-button{background-color:var(--yellow-warm);color:var(--text-color);cursor:pointer;box-shadow:0 2px 4px var(--shadow-color);border:none;border-radius:15px;padding:10px 20px;font-family:Jua,sans-serif;font-size:clamp(1rem,3vw,1.2rem);transition:transform .1s,background-color .2s}.cute-button:hover{background-color:#ffca28}.cute-button:active{transform:scale(.95)}.cute-button.disabled,.cute-button:disabled{color:#999;cursor:not-allowed;opacity:.6;background-color:#e0e0e0;transform:none}.cute-button.disabled:hover,.cute-button:disabled:hover{background-color:#e0e0e0;transform:none}@media (min-width:768px){.rounded-card{border-radius:20px;padding:24px}.cute-input{border-radius:20px;padding:10px 16px}.cute-button{border-radius:20px;padding:12px 24px}.cute-input:focus{box-shadow:0 0 0 4px #ffe0824d}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin-anim{animation:3s linear infinite spin}.diary-book{background-color:var(--white-sub);cursor:pointer;border-radius:6px 15px 15px 6px;flex-direction:column;justify-content:space-between;min-height:140px;padding:15px 12px 15px 28px;transition:transform .2s;display:flex;position:relative;box-shadow:-2px 4px 10px #00000014}.diary-book:hover{transform:translateY(-4px)}.diary-book:before{content:"";background:repeating-linear-gradient(#0000,#0000 12px,#cfd8dc 12px 20px);border-radius:5px;width:10px;position:absolute;top:10%;bottom:10%;left:8px;box-shadow:inset 2px 2px 4px #0000001a}@media (min-width:768px){.diary-book{border-radius:8px 20px 20px 8px;min-height:160px;padding:15px 15px 15px 35px}.diary-book:before{background:repeating-linear-gradient(#0000,#0000 15px,#cfd8dc 15px 25px);border-radius:6px;width:12px;left:12px}}.diary-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:20px;padding:10px;display:grid}@media (min-width:600px){.diary-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}}@media (min-width:900px){.diary-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:30px}}.main-container{flex-direction:column;gap:20px;display:flex;box-sizing:border-box!important;width:100%!important;max-width:1400px!important;margin:0 auto!important;padding:4vh 6vw 150px!important}.main-header{flex-direction:column;align-items:stretch;gap:15px;display:flex}.header-title-group{align-items:center;gap:10px;display:flex}.header-duck-image{mix-blend-mode:multiply;border-radius:50%;width:50px;height:50px}.main-title{color:var(--text-color);margin:0;font-size:clamp(1.5rem,5vw,2rem)}.main-subtitle{color:#9e9e9e;margin:0;font-size:clamp(.75rem,2.5vw,.9rem)}.write-button{white-space:nowrap;text-align:center;padding:12px 20px;text-decoration:none}.write-button-text{display:inline}.categories-nav{-webkit-overflow-scrolling:touch;gap:10px;padding-bottom:10px;display:flex;overflow-x:auto}.categories-nav::-webkit-scrollbar{height:4px}.categories-nav::-webkit-scrollbar-thumb{background:var(--yellow-warm);border-radius:4px}.category-button{border:2px solid var(--yellow-warm);background:var(--white-sub);color:var(--text-color);cursor:pointer;white-space:nowrap;box-shadow:0 2px 4px var(--shadow-color);border-radius:20px;padding:8px 18px;font-family:inherit;font-size:clamp(.9rem,2.5vw,1.1rem);transition:all .2s}.category-button.active{background:var(--yellow-warm)}.empty-state{text-align:center;color:#9e9e9e;margin-top:20px;padding:40px 20px}.empty-state-text{font-size:clamp(1rem,3vw,1.2rem);line-height:1.6}.pagination-container{justify-content:center;align-items:center;gap:10px;margin-top:30px;padding:20px 10px;display:flex}.pagination-button{border:2px solid var(--yellow-warm);color:var(--text-color);cursor:pointer;box-shadow:0 2px 4px var(--shadow-color);background-color:#fff;border-radius:12px;padding:10px 16px;font-family:Jua,sans-serif;font-size:1rem;transition:all .2s}.pagination-button:hover:not(:disabled){background-color:var(--yellow-warm);box-shadow:0 4px 8px var(--shadow-color);transform:translateY(-1px)}.pagination-button:disabled{opacity:.4;cursor:not-allowed;color:#9e9e9e;background-color:#f5f5f5;border-color:#e0e0e0}.pagination-info{color:var(--text-color);box-shadow:0 2px 4px var(--shadow-color);text-align:center;background-color:#fff;border-radius:12px;min-width:80px;padding:8px 16px;font-family:Jua,sans-serif;font-size:1rem}.category-section{margin-bottom:40px}.category-section-title{color:var(--text-color);border-bottom:3px solid var(--yellow-warm);margin-bottom:20px;padding-bottom:10px;font-family:Jua,sans-serif;font-size:clamp(1.3rem,4vw,1.8rem);display:inline-block}@media (min-width:768px){.main-container{gap:25px;padding:30px}.main-header{flex-direction:row;justify-content:space-between;align-items:center}.header-duck-image{width:60px;height:60px}.write-button{padding:12px 24px}}@media (min-width:1024px){.main-container{max-width:1200px;padding:40px}.categories-nav{overflow-x:visible}.write-button-text:before{content:" "}}.write-container{flex-direction:column;gap:20px;display:flex;box-sizing:border-box!important;width:100%!important;max-width:1400px!important;margin:0 auto!important;padding:4vh 6vw 150px!important}.write-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.write-title{color:var(--text-color);margin:0;font-size:clamp(1.3rem,4vw,1.8rem)}.write-close-button{color:#9e9e9e;font-size:clamp(1rem,3vw,1.2rem);font-weight:700;text-decoration:none}.close-button-text{display:inline}.write-form{flex-direction:column;gap:20px;display:flex}.write-book-section{padding:20px 15px 20px 35px}.write-title-input{margin-bottom:15px}.write-category-section{flex-direction:column;gap:10px;display:flex}.category-label{color:var(--text-color);font-size:clamp(.9rem,2.5vw,1rem);font-weight:700}.category-select,.custom-category-input{width:100%}.write-textarea{resize:vertical;width:100%;min-height:200px}.write-media-section{flex-direction:column;gap:15px;display:flex}.photo-upload-section{flex-direction:column;align-items:flex-start;gap:10px;display:flex}.photo-button{cursor:pointer;background:#fff59d;padding:10px 16px;font-size:clamp(.9rem,2.5vw,1rem)}.photo-button-text{display:inline}.photo-selected-badge{color:#4caf50;font-size:clamp(.8rem,2vw,.9rem)}.photo-preview{object-fit:cover;border-radius:15px;width:100%;max-height:300px}.music-section{flex-direction:column;gap:10px;margin-top:10px;display:flex}.music-input-wrapper{flex-direction:column;gap:10px;display:flex}.music-label{color:var(--text-color);font-size:clamp(.9rem,2.5vw,1rem);font-weight:700}.music-input{width:100%;font-size:clamp(.75rem,2vw,.85rem)}.music-select-wrapper{flex-direction:column;gap:8px;display:flex}.music-select-label{color:var(--text-color);font-size:clamp(.85rem,2vw,.95rem);font-weight:700}.music-select{width:100%;font-size:clamp(.85rem,2vw,1rem)}.music-preview{margin-top:10px}.music-no-playlists{color:#9e9e9e;text-align:center;padding:20px;font-size:clamp(.85rem,2vw,.95rem)}.music-loading{color:#9e9e9e;text-align:center;padding:15px;font-size:clamp(.85rem,2vw,.95rem);font-style:italic}.music-free-notice{border:2px solid var(--yellow-warm);background:#fff9c4;border-radius:12px;margin-top:10px;padding:15px}.music-free-notice p{color:var(--text-color);margin:0 0 8px;font-size:clamp(.85rem,2vw,.95rem);line-height:1.5}.music-free-notice p:last-child{margin-bottom:0}.notice-subtitle{color:#8d6e63;font-size:clamp(.75rem,1.8vw,.85rem)}.spotify-login-section{background:#f4a0c014;border:1.5px dashed #f4a0c066;border-radius:12px;padding:15px}.spotify-login-description{color:#666;text-align:center;margin:0;font-size:clamp(.85rem,2vw,.95rem)}.music-search-row{background:#f4a0c01a;border:1.5px solid #f4a0c059;border-radius:12px;align-items:center;gap:8px;padding:8px 12px;transition:border-color .2s;display:flex}.music-search-row:focus-within{border-color:var(--yellow-warm);background:#f4a0c026}.music-search-input{color:var(--text-color);background:0 0;border:none;outline:none;flex:1;font-family:Jua,sans-serif;font-size:clamp(.85rem,2vw,.95rem)}.music-search-input::placeholder{color:#bbb}.music-search-clear{cursor:pointer;color:#999;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:2px;transition:all .2s;display:flex}.music-search-clear:hover{color:#666;background:#0000000d}.music-search-results{background:#fff;border:1.5px solid #f4a0c033;border-radius:12px;max-height:280px;margin-top:8px;padding:6px;overflow-y:auto;box-shadow:0 4px 12px #0000001a}.music-search-hint{color:#999;text-align:center;margin:0;padding:12px;font-size:clamp(.8rem,2vw,.9rem)}.music-result-item{cursor:pointer;text-align:left;background:0 0;border:2px solid #0000;border-radius:10px;align-items:center;gap:10px;width:100%;padding:8px 10px;transition:all .2s;display:flex}.music-result-item:hover{background:#f4a0c01a}.music-result-item.selected{background:var(--yellow-base);border-color:var(--yellow-warm)}.music-result-thumb{object-fit:cover;border-radius:8px;flex-shrink:0;width:40px;height:40px;box-shadow:0 2px 6px #00000026}.music-result-thumb-empty{color:#c07090;background:#f4a0c033;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.music-result-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex;overflow:hidden}.music-result-name{color:var(--text-color);white-space:nowrap;text-overflow:ellipsis;font-family:Jua,sans-serif;font-size:clamp(.85rem,2vw,.95rem);font-weight:600;overflow:hidden}.music-result-artist{color:#666;white-space:nowrap;text-overflow:ellipsis;font-size:clamp(.75rem,1.8vw,.85rem);overflow:hidden}.music-result-action{color:var(--yellow-warm);background:#f4a0c01a;border-radius:6px;flex-shrink:0;padding:4px 8px;font-size:clamp(.75rem,1.8vw,.85rem);font-weight:600}.music-result-item.selected .music-result-action{color:#4caf50;background:#fff}.music-attached-list{background:#ffebf580;border:1.5px solid #f4a0c04d;border-radius:12px;margin-top:12px;padding:12px}.music-attached-label{color:var(--text-color);margin:0 0 8px;font-family:Jua,sans-serif;font-size:clamp(.8rem,2vw,.9rem);font-weight:600}.music-chip{border:1.5px solid var(--yellow-warm);background:#fff;border-radius:20px;align-items:center;gap:6px;margin-bottom:6px;padding:6px 10px;transition:all .2s;display:flex}.music-chip:last-child{margin-bottom:0}.music-chip:hover{background:var(--yellow-base);transform:translate(2px)}.music-chip-name{color:var(--text-color);white-space:nowrap;text-overflow:ellipsis;flex-shrink:1;min-width:0;font-size:clamp(.8rem,2vw,.9rem);font-weight:600;overflow:hidden}.music-chip-artist{color:#666;white-space:nowrap;text-overflow:ellipsis;flex-shrink:1;min-width:0;font-size:clamp(.75rem,1.8vw,.85rem);overflow:hidden}.music-chip-remove{cursor:pointer;color:#666;background:#f4a0c033;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;padding:3px;transition:all .2s;display:flex}.music-chip-remove:hover{color:#fff;background:#ff1744;transform:scale(1.1)}.submit-button{margin-top:10px;padding:15px;font-size:clamp(1.1rem,3vw,1.4rem)}@media (min-width:768px){.write-container{padding:25px}.write-book-section{padding:25px 20px 25px 45px}.write-category-section{flex-direction:row;align-items:center}.category-label{white-space:nowrap}.category-select,.custom-category-input{flex:1}.photo-upload-section,.music-input-wrapper{flex-direction:row;align-items:center}.music-label{white-space:nowrap}.music-input{flex:1}.music-select-wrapper{flex-direction:row;align-items:center}.music-select-label{white-space:nowrap;min-width:100px}.music-select{flex:1}}.decorate-container{flex-direction:column;gap:20px;max-width:800px;min-height:100vh;margin:0 auto;padding:15px 15px 150px;display:flex;overflow-x:hidden}.decorate-header{flex-direction:column;align-items:stretch;gap:15px;display:flex}.decorate-title{color:var(--text-color);word-wrap:break-word;margin:0;font-size:clamp(1.2rem,4vw,1.6rem)}.entry-title-text{display:inline}.decorate-actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.save-button{padding:10px 20px;font-size:clamp(.9rem,2.5vw,1rem)}.decorate-cancel-button{color:#9e9e9e;align-self:center;font-size:clamp(.9rem,2.5vw,1rem);font-weight:700;text-decoration:none}.cancel-button-text{display:inline}.decorate-canvas{touch-action:none;width:100%;max-width:350px;margin:0 auto}.sticker-hint{color:#a1887f;opacity:.6;pointer-events:none;z-index:1;text-align:right;max-width:40%;font-size:clamp(.75rem,2vw,1rem);position:absolute;top:15%;right:10%}.draggable-sticker{touch-action:none}.sticker-palette{flex-direction:column;flex-shrink:0;gap:10px;margin-top:auto;margin-bottom:20px;display:flex}.palette-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.palette-title{color:var(--text-color);font-size:clamp(.9rem,2.5vw,1rem);font-weight:700}.add-sticker-button{cursor:pointer;background:#fff59d;padding:8px 16px;font-size:clamp(.85rem,2vw,1rem)}.add-sticker-text{display:inline}.sticker-list{-webkit-overflow-scrolling:touch;align-items:center;gap:15px;padding:10px 0;display:flex;overflow-x:auto}.sticker-list::-webkit-scrollbar{height:6px}.sticker-list::-webkit-scrollbar-thumb{background:var(--yellow-warm);border-radius:6px}.sticker-item{cursor:pointer;mix-blend-mode:multiply;border-radius:10px;flex-shrink:0;width:60px;height:60px}.uploaded-sticker{object-fit:cover}@media (min-width:768px){.decorate-container{padding:25px}.decorate-header{flex-direction:row;justify-content:space-between;align-items:center}.decorate-actions{flex-wrap:nowrap}.decorate-canvas{max-width:400px}.sticker-item{width:70px;height:70px}}@media (min-width:1024px){.decorate-container{padding:40px}.decorate-canvas{max-width:450px}.sticker-item{width:80px;height:80px}}.auth-screen{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:20px;min-height:100vh;padding:20px;display:flex}.auth-card{background:var(--white-sub);box-shadow:0 8px 24px var(--shadow-color);border:3px solid var(--yellow-warm);border-radius:30px;flex-direction:column;align-items:center;gap:20px;width:100%;max-width:400px;padding:30px;display:flex}.password-card{max-width:400px}.spotify-card{text-align:center;max-width:500px}.auth-duck-image{mix-blend-mode:multiply;border-radius:50%;width:80px;height:80px}.auth-title{color:var(--text-color);margin:0;font-size:clamp(1.6rem,5vw,2rem)}.auth-subtitle{color:#9e9e9e;margin:0;font-size:clamp(.9rem,2.5vw,1rem)}.spotify-title{color:var(--text-color);margin:0;font-size:clamp(1.4rem,4vw,1.8rem)}.spotify-description{color:#9e9e9e;font-size:clamp(.9rem,2.5vw,1rem);line-height:1.6}.spotify-login-button{color:#fff;background:#1db954;width:100%;font-weight:700}.spotify-warning{background:#ffebee;border-radius:15px;width:100%;margin-top:10px;padding:15px}.spotify-warning-text{color:#d32f2f;margin:0;font-size:clamp(.75rem,2vw,.85rem);line-height:1.5}.auth-form{flex-direction:column;gap:15px;width:100%;display:flex}.auth-error{color:#ff5252;margin:0;font-size:clamp(.85rem,2vw,.9rem)}@media (min-width:768px){.auth-screen,.auth-card{padding:40px}.auth-duck-image{width:100px;height:100px}}.global-player-wrapper{z-index:9999;flex-direction:column;align-items:center;gap:8px;width:95%;max-width:400px;display:flex;position:fixed;bottom:10px;left:50%;transform:translate(-50%)}.read-container{background:var(--white-base);box-sizing:border-box;flex-direction:column;width:100%;max-width:100%;min-height:100dvh;display:flex;position:relative;overflow-x:hidden;padding:4vh 6vw 150px!important}.playlist-select{background:var(--white-sub);opacity:.95;width:100%;padding:6px 10px;font-size:.75rem}.global-player-container{background:var(--white-sub);box-shadow:0 6px 20px var(--shadow-color);border:3px solid var(--yellow-warm);border-radius:40px;align-items:center;gap:8px;width:100%;padding:8px 10px;display:flex}.vinyl-image{object-fit:cover;mix-blend-mode:multiply;background-color:#fff;border:2px solid #fff59d;border-radius:50%;flex-shrink:0;width:50px;height:50px}.vinyl-image.spinning{animation:4s linear infinite spin}.player-control-button{cursor:pointer;color:var(--yellow-warm);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;width:30px;padding:0;font-size:1.3rem;transition:transform .1s;display:flex}.player-control-button:active{transform:scale(.8)}.spotify-iframe-wrapper{display:none}.play-button{background:var(--yellow-warm);cursor:pointer;width:36px;height:36px;color:var(--text-color);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:transform .15s,box-shadow .15s;display:flex;box-shadow:0 2px 6px #0000001f}.play-button:hover{transform:scale(1.08);box-shadow:0 4px 10px #0000002e}.play-button:active{transform:scale(.9)}.play-button:disabled{opacity:.5;cursor:not-allowed}.player-track-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex;overflow:hidden}.player-track-name{color:var(--text-color);white-space:nowrap;text-overflow:ellipsis;font-size:.78rem;font-weight:700;overflow:hidden}.player-artist-name{color:#a88;white-space:nowrap;text-overflow:ellipsis;font-size:.68rem;overflow:hidden}.post-player-play-btn{background:var(--yellow-warm);cursor:pointer;width:44px;height:44px;color:var(--text-color);border:none;border-radius:50%;justify-content:center;align-items:center;transition:transform .15s;display:flex;box-shadow:0 2px 6px #0000001a}.post-player-play-btn:hover{transform:scale(1.1)}.player-search-panel{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#fffffff7;border:1.5px solid #ffc8dc66;border-radius:18px;width:100%;max-width:380px;margin-bottom:8px;padding:12px 10px 6px;animation:.2s searchPanelIn;box-shadow:0 8px 32px #00000021}@keyframes searchPanelIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.player-search-input-row{background:#f4a0c01a;border:1px solid #f4a0c059;border-radius:12px;align-items:center;gap:6px;margin-bottom:8px;padding:7px 10px;display:flex}.player-search-icon{color:#c07090;flex-shrink:0}.player-search-input{color:var(--text-color);background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:.83rem}.player-search-input::placeholder{color:#bbb}.player-search-clear{cursor:pointer;color:#bbb;background:0 0;border:none;flex-shrink:0;align-items:center;padding:0;display:flex}.player-search-results{flex-direction:column;gap:2px;max-height:220px;display:flex;overflow-y:auto}.player-search-hint{color:#bbb;text-align:center;margin:0;padding:6px 0;font-size:.73rem}.player-search-result-item{border-radius:10px;align-items:center;gap:8px;width:100%;padding:6px 8px;transition:background .12s;display:flex}.player-search-result-item:hover{background:#f4a0c01f}.player-result-thumb{object-fit:cover;border-radius:6px;flex-shrink:0;width:36px;height:36px}.player-result-thumb-empty{color:#c07090;background:#f4a0c033;justify-content:center;align-items:center;display:flex}.player-result-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.player-result-name{color:var(--text-color);white-space:nowrap;text-overflow:ellipsis;font-size:.78rem;font-weight:700;overflow:hidden}.player-result-sub{color:#aaa;white-space:nowrap;text-overflow:ellipsis;font-size:.68rem;overflow:hidden}.player-result-play-icon{color:#d090b0;opacity:0;flex-shrink:0;transition:opacity .15s}.player-search-result-item:hover .player-result-play-icon{opacity:1}.player-result-actions{flex-shrink:0;align-items:center;gap:4px;display:flex}.player-result-action-btn{cursor:pointer;color:var(--text-color);background:#f4a0c026;border:1px solid #f4a0c04d;border-radius:6px;justify-content:center;align-items:center;padding:6px;transition:all .2s;display:flex}.player-result-action-btn:hover{background:var(--yellow-warm);border-color:var(--yellow-warm);transform:scale(1.05)}.player-result-action-btn.play-btn{color:#d090b0}.player-result-action-btn.queue-btn{color:#4caf50}.player-result-action-btn.queue-btn:hover{color:#fff;background:#4caf50;border-color:#4caf50}.repeat-button{position:relative}.queue-item{padding-left:20px;position:relative}.queue-number{color:var(--yellow-warm);border:1.5px solid var(--yellow-warm);background:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:.7rem;font-weight:700;display:flex;position:absolute;top:50%;left:0;transform:translateY(-50%)}.queue-remove-btn{cursor:pointer;color:#999;background:#f4a0c026;border:1px solid #f4a0c04d;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;padding:5px;transition:all .2s;display:flex}.queue-remove-btn:hover{color:#fff;background:#ff1744;border-color:#ff1744;transform:scale(1.1)}@media (min-width:768px){.global-player-wrapper{align-items:flex-end;width:auto;max-width:500px;bottom:20px;left:auto;right:20px;transform:none}.playlist-select{width:300px;padding:6px 12px;font-size:.85rem}.global-player-container{gap:12px;width:auto;padding:10px 15px}.vinyl-image{border:3px solid #fff59d;width:70px;height:70px}.player-control-button{width:auto;font-size:1.6rem}.spotify-iframe-wrapper{width:250px;height:70px}}@media (min-width:1024px){.vinyl-image{width:80px;height:80px}.player-control-button{font-size:1.8rem}.spotify-iframe-wrapper{width:300px;height:80px}}.diary-cover-title-tag{z-index:2;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#ffffffd9;border:2px solid #ffe08299;border-radius:12px;padding:5%}.diary-cover-title{color:#5d4037;margin:0 0 5px;font-size:clamp(.85rem,3.5vw,1.4rem);line-height:1.3}.diary-cover-meta{color:#8d6e63;margin:0;font-size:clamp(.65rem,2vw,.9rem)}.diary-cover-player{z-index:2;margin-top:auto}.diary-cover-actions{z-index:3;gap:8px;display:flex;position:absolute;top:5%;right:5%}.diary-cover-decorate-button,.diary-cover-delete-button{border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;padding:0;transition:all .2s;display:flex;box-shadow:0 2px 6px #00000026}.diary-cover-decorate-button{background-color:var(--yellow-warm);border:2px solid #ffb300}.diary-cover-decorate-button:hover:not(:disabled){background-color:#ffb300;transform:scale(1.1)}.diary-cover-delete-button{color:#fff;background-color:#ff5252;border:2px solid #e53935}.diary-cover-delete-button:hover:not(:disabled){background-color:#ff1744;transform:scale(1.1)}.decorate-button-text,.delete-button-text{display:none}@media (min-width:768px){.diary-cover-title{font-size:clamp(1rem,3vw,1.4rem)}.diary-cover-meta{font-size:clamp(.75rem,2vw,.9rem)}.diary-cover-decorate-button,.diary-cover-delete-button{width:45px;height:45px}}.post-player-container{background:var(--yellow-base);border:2px solid var(--yellow-warm);border-radius:15px;align-items:center;gap:10px;padding:8px;display:flex}.post-player-vinyl{object-fit:cover;border-radius:50%;flex-shrink:0;width:35px;height:35px}.post-player-embed{flex-direction:column;flex:1;gap:8px;min-width:0;display:flex}.post-player-info{flex-direction:column;gap:2px;display:flex;overflow:hidden}.post-player-track-name{color:var(--text-color);white-space:nowrap;text-overflow:ellipsis;font-family:Jua,sans-serif;font-size:clamp(.85rem,2.5vw,1rem);font-weight:600;overflow:hidden}.post-player-artist{color:#666;white-space:nowrap;text-overflow:ellipsis;font-size:clamp(.7rem,2vw,.85rem);overflow:hidden}.post-player-controls{align-items:center;gap:6px;display:flex}.post-player-play-btn{background-color:var(--yellow-warm);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex;box-shadow:0 2px 4px #0000001a}.post-player-play-btn:hover{background-color:#ffb300;transform:scale(1.05)}.post-player-play-btn:active{transform:scale(.95)}.post-player-ctrl-btn{border:1px solid var(--yellow-warm);cursor:pointer;width:28px;height:28px;color:var(--text-color);background-color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:all .2s;display:flex}.post-player-ctrl-btn:hover:not(:disabled){background-color:var(--yellow-base);transform:translateY(-1px)}.post-player-ctrl-btn:disabled{opacity:.3;cursor:not-allowed}.post-player-modal-overlay{z-index:9999;background:#0000004d;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.post-player-modal-content{background:#fff;border-radius:20px;flex-direction:column;width:calc(100% - 40px);max-width:380px;max-height:70vh;animation:.3s slideUp;display:flex;overflow:hidden;box-shadow:0 20px 60px #0000004d}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.post-player-modal-header{border-bottom:2px solid var(--yellow-base);flex-shrink:0;justify-content:space-between;align-items:center;padding:15px;display:flex}.post-player-modal-title{color:var(--text-color);margin:0;font-family:Jua,sans-serif;font-size:clamp(1.1rem,3vw,1.4rem)}.post-player-modal-close{background:var(--yellow-base);cursor:pointer;color:var(--text-color);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:6px;transition:all .2s;display:flex}.post-player-modal-close:hover{background:var(--yellow-warm);transform:rotate(90deg)}.post-player-tracklist{flex:1;min-height:0;padding:10px;overflow-y:auto}.post-player-track-item{cursor:pointer;text-align:left;background:0 0;border:2px solid #0000;border-radius:12px;align-items:center;gap:8px;width:100%;margin-bottom:6px;padding:10px;transition:all .2s;display:flex}.post-player-track-item:last-child{margin-bottom:0}.post-player-track-item:hover{background-color:var(--yellow-base);border-color:var(--yellow-warm);transform:translate(4px)}.post-player-track-item.active{background-color:var(--yellow-warm);border-color:#ffb300}.post-player-track-item-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.post-player-track-item-name{color:var(--text-color);white-space:nowrap;text-overflow:ellipsis;font-family:Jua,sans-serif;font-size:clamp(.95rem,2.5vw,1.05rem);font-weight:600;overflow:hidden}.post-player-track-item-artist{color:#666;white-space:nowrap;text-overflow:ellipsis;font-size:clamp(.8rem,2vw,.9rem);overflow:hidden}@media (min-width:768px){.post-player-container{border-radius:20px;gap:15px;padding:10px}.post-player-vinyl{width:40px;height:40px}.post-player-embed{height:80px}}.read-container{max-width:1400px;min-height:100vh;margin:0 auto;padding:15px 15px 150px}.read-loading{text-align:center;color:var(--text-color);padding:60px;font-size:clamp(1.2rem,3vw,1.5rem)}.read-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:15px;margin-bottom:20px;display:flex}.read-back-button{color:var(--text-color);font-size:clamp(1rem,2.5vw,1.2rem);font-weight:700;text-decoration:none;transition:color .2s}.read-back-button:hover{color:#ffb300}.back-button-text{display:inline}.decorate-link-button{padding:10px 18px;font-size:clamp(.9rem,2.5vw,1rem)}.diary-book-open{background:linear-gradient(90deg,#f5f5f5 0%,#fff 10% 90%,#f5f5f5 100%);border-radius:8px;gap:0;max-width:1200px;margin:0 auto;display:flex;position:relative;overflow:hidden;box-shadow:0 10px 40px #00000026}.read-actions{flex-wrap:wrap;gap:10px;display:flex}.diary-page{background:var(--white-sub);flex:1;min-height:500px;padding:30px 20px;position:relative;min-width:0!important}.left-page{background:linear-gradient(to right, #fafaf8 0%, var(--white-sub) 100%);border-right:1px solid #e0e0e0}.right-page{background:linear-gradient(to left, #fafaf8 0%, var(--white-sub) 100%);border-left:1px solid #e0e0e0}.binder-rings-left,.binder-rings-right{width:15px;position:absolute;top:0;bottom:0}.binder-rings-left{right:-8px}.binder-rings-right{left:-8px}.binder-rings-left .ring,.binder-rings-right .ring{background:#e0e0e0;border-radius:50%;width:8px;height:8px;position:absolute;box-shadow:inset 1px 1px 3px #0003}.center-binder{background:linear-gradient(90deg,#b0bec5,#eceff1 20%,#fff 50%,#eceff1 80%,#b0bec5);flex-shrink:0;width:30px;position:relative;box-shadow:inset 0 0 10px #0003,0 4px 8px #0000001a}.binder-ring{background:linear-gradient(135deg,#757575,#bdbdbd);border-radius:50%;width:16px;height:16px;position:absolute;left:50%;transform:translate(-50%);box-shadow:0 2px 6px #0000004d,inset 1px 1px 3px #ffffff4d}.left-page-content{flex-direction:column;gap:20px;height:100%;display:flex}.cover-preview{aspect-ratio:1/1.3;background-blend-mode:overlay;background:#fff9c4 url(/assets/cloud_v6.png) 0 0/40%;border-radius:12px;flex-direction:column;width:100%;padding:20px;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 12px #0000001a}.cover-preview-bg{position:absolute;inset:0}.cover-info-box{z-index:2;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#ffffffe6;border:2px solid #ffe08299;border-radius:12px;margin-top:auto;padding:15px;position:relative}.cover-title{color:#5d4037;margin:0 0 8px;font-size:clamp(1rem,3vw,1.3rem);line-height:1.3}.cover-date{color:#8d6e63;margin:4px 0;font-size:clamp(.8rem,2vw,.95rem)}.cover-category{color:#8d6e63;margin:4px 0;font-size:clamp(.8rem,2vw,.95rem);font-weight:700}.left-page-decoration{text-align:center;margin-top:auto}.decoration-duck{mix-blend-mode:multiply;border-radius:50%;width:60px;height:60px}.right-page-content{flex-direction:column;gap:20px;height:100%;display:flex}.diary-header{border-bottom:3px double var(--yellow-warm);padding-bottom:15px}.diary-title{color:var(--text-color);margin:0 0 12px;font-size:clamp(1.4rem,4vw,2rem);line-height:1.3}.diary-meta{color:#8d6e63;flex-wrap:wrap;gap:15px;font-size:clamp(.85rem,2vw,1rem);display:flex}.meta-date,.meta-category{align-items:center;gap:5px;display:flex}.diary-content{flex:1;overflow-y:auto}.content-text{color:var(--text-color);white-space:pre-wrap;word-wrap:break-word;font-size:clamp(1rem,2.5vw,1.2rem);line-height:1.8}.diary-music{border-top:2px dashed var(--yellow-warm);margin-top:auto;padding-top:15px}.music-label{color:var(--text-color);margin-bottom:10px;font-size:clamp(.9rem,2vw,1rem);font-weight:700}.right-page-decoration{text-align:right;opacity:.6}.decoration-cloud{mix-blend-mode:multiply;width:50px;height:50px}@media (max-width:767px){.diary-book-open{flex-direction:column}.center-binder{background:linear-gradient(#b0bec5,#eceff1 20%,#fff 50%,#eceff1 80%,#b0bec5);width:100%;height:30px}.binder-ring{top:50%;left:auto;transform:translateY(-50%)}.binder-ring:first-child{left:10%}.binder-ring:nth-child(2){left:30%}.binder-ring:nth-child(3){left:50%}.binder-ring:nth-child(4){left:70%}.binder-ring:nth-child(5){left:90%}.left-page{border-bottom:1px solid #e0e0e0;border-right:none}.right-page{border-top:1px solid #e0e0e0;border-left:none}.binder-rings-left,.binder-rings-right{display:none}.diary-page{min-height:auto;padding:20px 15px}.cover-preview{max-width:300px;margin:0 auto}.decoration-duck{width:50px;height:50px}}@media (min-width:768px){.read-container{padding:30px}.read-header{margin-bottom:30px}.diary-page{min-height:600px;padding:40px 30px}.decoration-duck{width:80px;height:80px}.decoration-cloud{width:60px;height:60px}}@media (min-width:1024px){.read-container{padding:40px}.diary-page{min-height:700px;padding:50px 40px}}.error-banner{cursor:pointer;background:linear-gradient(135deg,#ffebee,#ffcdd2);border:2px solid #ef5350;border-radius:12px;justify-content:space-between;align-items:center;margin:.5rem 0 1rem;padding:.8rem 1rem;transition:all .2s;display:flex;box-shadow:0 2px 8px #ef53501a}.error-banner:hover{background:linear-gradient(135deg,#ffe0e3,#ffb3ba);transform:scale(1.01)}.error-banner span{color:#c62828;flex:1;font-size:.9rem;font-weight:500}.error-close{color:#c62828;cursor:pointer;background:0 0;border:none;padding:0 .5rem;font-size:1.2rem;line-height:1;transition:transform .2s}.error-close:hover{transform:scale(1.2)}.sticker-wrapper{position:relative}.sticker-delete-btn{color:#fff;cursor:pointer;z-index:10;background:linear-gradient(135deg,#ff6b6b,#ee5a6f);border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;padding:0;font-size:16px;font-weight:700;line-height:1;transition:all .2s;display:none;position:absolute;top:-8px;left:-8px;box-shadow:0 2px 8px #0003}.sticker-wrapper:hover .sticker-delete-btn{display:flex}.sticker-delete-btn:hover{background:linear-gradient(135deg,#ff5252,#e63946);transform:scale(1.15);box-shadow:0 4px 12px #ff6b6b66}.sticker-delete-btn:active{transform:scale(.95)}.sticker-resize-handle{background:linear-gradient(135deg, var(--yellow-warm), #ffb300);cursor:nwse-resize;z-index:10;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;transition:all .2s;display:none;position:absolute;bottom:0;right:0;box-shadow:0 2px 6px #0003}.sticker-resize-handle:after{content:"⇲";color:#fff;font-size:10px;font-weight:700}.sticker-wrapper:hover .sticker-resize-handle{display:flex}.sticker-resize-handle:hover{background:linear-gradient(135deg,#ffb300,#ffa000);transform:scale(1.15);box-shadow:0 4px 12px #ffb30066}.sticker-resize-handle:active{transform:scale(.95)}.sticker-rotate-handle{cursor:crosshair;color:#fff;z-index:10;background:linear-gradient(135deg,#9c27b0,#e1bee7);border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:10px;font-weight:700;transition:all .2s;display:none;position:absolute;top:-5px;left:50%;transform:translate(-50%);box-shadow:0 2px 6px #0003}.sticker-rotate-handle:after{content:"↻"}.sticker-wrapper:hover .sticker-rotate-handle{display:flex}.sticker-rotate-handle:hover{background:linear-gradient(135deg,#7b1fa2,#ce93d8);transform:translate(-50%)scale(1.15);box-shadow:0 4px 12px #9c27b066}.sticker-rotate-handle:active{transform:translate(-50%)scale(.95)}.sticker-shape-btn{cursor:pointer;color:#fff;z-index:10;background:linear-gradient(135deg,#4caf50,#81c784);border:2px solid #fff;border-radius:4px;justify-content:center;align-items:center;width:20px;height:20px;font-size:10px;font-weight:700;transition:all .2s;display:none;position:absolute;top:5px;left:5px;box-shadow:0 2px 6px #0003}.sticker-wrapper:hover .sticker-shape-btn{display:flex}.sticker-shape-btn:hover{background:linear-gradient(135deg,#388e3c,#66bb6a);transform:scale(1.15);box-shadow:0 4px 12px #4caf5066}.sticker-shape-btn:active{transform:scale(.95)}.shape-selector-popup{z-index:1000;background:#fff;border-radius:8px;flex-direction:column;gap:6px;padding:8px;animation:.2s slideDown;display:flex;position:absolute;top:35px;left:5px;box-shadow:0 4px 16px #0003}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.shape-selector-popup button{cursor:pointer;background:#fff;border:2px solid #e0e0e0;border-radius:6px;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;transition:all .2s;display:flex}.shape-selector-popup button:hover{border-color:var(--yellow-warm);background:#f5f5f5;transform:scale(1.1)}.shape-selector-popup button:active{transform:scale(.95)}.delete-zone{background:linear-gradient(135deg,#f5f5f5,#e8e8e8);border:3px dashed #ccc;border-radius:16px;max-width:1200px;margin:20px auto;padding:20px;transition:all .3s}.delete-zone-content{color:#999;justify-content:center;align-items:center;gap:10px;padding:15px;font-size:1.1rem;display:flex}.delete-zone-active{background:linear-gradient(135deg,#ffe0e0,#fcc);border-color:#ff6b6b;transform:scale(1.05);box-shadow:0 8px 24px #ff6b6b4d}.delete-zone-active .delete-zone-content{color:#ff6b6b;font-weight:700}.delete-zone-text{font-size:1rem}.remove-all-button{background:linear-gradient(135deg,#f99,#ffb3b3);border:2px solid #ff6b6b}.remove-all-button:hover{background:linear-gradient(135deg,#f77,#f99);transform:translateY(-2px);box-shadow:0 4px 12px #ff6b6b4d}.remove-all-text{font-size:.9rem}@media (max-width:767px){.sticker-delete-btn{width:24px;height:24px;font-size:14px;display:flex;top:-6px;left:-6px}.delete-zone{margin:15px;padding:15px}.delete-zone-content{padding:10px;font-size:.95rem}.delete-zone-text{font-size:.85rem}.remove-all-text{display:none}}.diary-book-open{perspective:2500px;perspective-origin:50%;min-height:700px;transform-style:preserve-3d;flex:1;position:relative;width:100%!important;max-width:1400px!important;margin:0!important}.magic-flap{width:50%;height:100%;transform-style:preserve-3d;transform-origin:0;z-index:100;position:absolute;top:0;right:0}.magic-flap-front,.magic-flap-back{backface-visibility:hidden;width:100%;height:100%;position:absolute;top:0;left:0}.magic-flap-front{border-radius:0 12px 12px 0;transform:rotateY(0)}.magic-flap-back{background:var(--white-sub);background-blend-mode:overlay;background-image:url(/assets/cloud_v6.png);background-size:40%;border-radius:12px 0 0 12px;transform:rotateY(180deg);box-shadow:inset -5px 0 15px #0000001a}.book-opening .diary-book-open{transform:scale(.85)translate(-25%)}.book-opening .magic-flap{transform:rotateY(0);box-shadow:20px 0 40px #0006}.book-opening .left-page,.book-opening .right-page,.book-opening .center-binder{opacity:0}.book-opened .diary-book-open{animation:1.4s cubic-bezier(.34,1.56,.64,1) forwards bookWrapperSlideRight}.book-opened .magic-flap{animation:1.4s cubic-bezier(.34,1.56,.64,1) forwards magicFlapTurnLeft}.book-opened .left-page,.book-opened .right-page,.book-opened .center-binder{animation:1.4s linear forwards revealPages}@keyframes bookWrapperSlideRight{0%{transform:scale(.85)translate(-25%)}to{transform:scale(1)translate(0)}}@keyframes magicFlapTurnLeft{0%{opacity:1;transform:rotateY(0);box-shadow:20px 0 40px #0006}50%{opacity:1;transform:rotateY(-90deg)translateY(-10px);box-shadow:0 0 35px #00000059}99%{opacity:1;transform:rotateY(-180deg);box-shadow:-20px 0 40px #0000001a}to{opacity:0;transform:rotateY(-180deg)}}@keyframes revealPages{0%{opacity:0}49%{opacity:0}50%{opacity:1}to{opacity:1}}@keyframes binderExpand{0%{opacity:.5;transform:scaleY(.3)}to{opacity:1;transform:scaleY(1)}}.diary-page{transform-style:preserve-3d;transition:box-shadow .3s;min-height:700px!important;padding:50px 40px!important}.diary-page:hover{box-shadow:0 8px 30px #00000026!important}.left-page:before,.right-page:before{content:"";pointer-events:none;opacity:0;background:repeating-linear-gradient(0deg,#0000,#0000 2px,#00000003 2px 4px);animation:.5s ease-in 1s forwards paperTextureAppear;position:absolute;inset:0}@keyframes paperTextureAppear{to{opacity:1}}.book-opened .left-page-content,.book-opened .right-page-content{animation:.6s ease-out .8s both contentFadeIn}@keyframes contentFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:1400px){.diary-book-open{perspective:2000px;width:100%!important;max-width:100%!important}}@media (max-width:1024px){.diary-book-open{perspective:1500px;min-height:600px;width:100%!important;max-width:100%!important}.diary-page{min-height:600px!important;padding:40px 30px!important}}@media (max-width:767px){.read-header{width:calc(100% - 40px)!important;margin:0 auto 20px!important}.diary-book-open{perspective:2500px;flex-direction:column;min-height:auto;width:calc(100% - 40px)!important;margin:0 auto 100px!important}.diary-page{box-sizing:border-box!important;width:100%!important;min-height:400px!important;padding:30px 20px!important}.magic-flap{transform-origin:top!important;width:100%!important;height:50%!important;display:block!important;top:50%!important;left:0!important;right:0!important}.magic-flap-front{border-radius:0 0 12px 12px!important}.magic-flap-back{border-radius:12px 12px 0 0!important;transform:rotateX(180deg)!important}.book-opening .diary-book-open{transform:scale(.85)translate(0)translateY(-25%)!important}.book-opening .magic-flap{transform:rotateX(0)!important}.book-opening .left-page,.book-opening .right-page{opacity:0!important;transform:none!important}.book-opened .diary-book-open{animation:1.4s cubic-bezier(.34,1.56,.64,1) forwards bookWrapperSlideDownMobile!important}.book-opened .magic-flap{animation:1.4s cubic-bezier(.34,1.56,.64,1) forwards magicFlapTurnUpMobile!important}}@keyframes bookWrapperSlideDownMobile{0%{transform:scale(.85)translate(0)translateY(-25%)}to{transform:scale(1)translate(0)translateY(0)}}@keyframes magicFlapTurnUpMobile{0%{opacity:1;transform:rotateX(0);box-shadow:0 20px 40px #0006}50%{opacity:1;transform:rotateX(90deg)translateZ(10px);box-shadow:0 0 35px #00000059}99%{opacity:1;transform:rotateX(180deg);box-shadow:0 -20px 40px #0000001a}to{opacity:0;transform:rotateX(180deg)}}.book-opening .binder-ring,.book-opened .binder-ring{opacity:1;transform:translate(-50%)scale(1)}.book-opened .binder-ring:first-child{animation-delay:.3s}.book-opened .binder-ring:nth-child(2){animation-delay:.4s}.book-opened .binder-ring:nth-child(3){animation-delay:.5s}.book-opened .binder-ring:nth-child(4){animation-delay:.6s}.book-opened .binder-ring:nth-child(5){animation-delay:.7s}@keyframes binderRingAppear{0%{opacity:0;transform:translate(-50%)scale(.5)}to{opacity:1;transform:translate(-50%)scale(1)}}.book-opening .binder-rings-left .ring,.book-opening .binder-rings-right .ring,.book-opened .binder-rings-left .ring,.book-opened .binder-rings-right .ring{opacity:1;transform:scale(1)}.book-opened .binder-rings-left .ring:first-child,.book-opened .binder-rings-right .ring:first-child{animation-delay:.5s}.book-opened .binder-rings-left .ring:nth-child(2),.book-opened .binder-rings-right .ring:nth-child(2){animation-delay:.6s}.book-opened .binder-rings-left .ring:nth-child(3),.book-opened .binder-rings-right .ring:nth-child(3){animation-delay:.7s}.book-opened .binder-rings-left .ring:nth-child(4),.book-opened .binder-rings-right .ring:nth-child(4){animation-delay:.8s}@keyframes sideRingAppear{0%{opacity:0;transform:scale(0)}50%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}.left-page:after,.right-page:after{content:"";pointer-events:none;opacity:0;background:linear-gradient(#0000,#00000008);width:100%;height:30px;position:absolute;bottom:0}.left-page:after{border-radius:0 0 0 8px;left:0}.right-page:after{border-radius:0 0 8px;right:0}.book-opened .left-page:after,.book-opened .right-page:after{animation:.5s ease-out 1.2s forwards pageCurlAppear}@keyframes pageCurlAppear{to{opacity:1}}.book-opened .decoration-duck,.book-opened .decoration-cloud{animation:.6s cubic-bezier(.34,1.56,.64,1) 1.3s both decorationBounce}@keyframes decorationBounce{0%{opacity:0;transform:scale(.5)rotate(-10deg)}50%{transform:scale(1.1)rotate(5deg)}to{opacity:1;transform:scale(1)rotate(0)}}.book-opened .cover-info-box{animation:.5s cubic-bezier(.34,1.56,.64,1) 1.1s both coverInfoSlide}@keyframes coverInfoSlide{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.book-opened .preview-sticker{animation:.4s cubic-bezier(.34,1.56,.64,1) both stickerPop}.book-opened .preview-sticker:first-child{animation-delay:1.2s}.book-opened .preview-sticker:nth-child(2){animation-delay:1.3s}.book-opened .preview-sticker:nth-child(3){animation-delay:1.4s}.book-opened .preview-sticker:nth-child(4){animation-delay:1.5s}.book-opened .preview-sticker:nth-child(5){animation-delay:1.6s}@keyframes stickerPop{0%{opacity:0;transform:scale(0)rotate(-180deg)}60%{transform:scale(1.15)rotate(10deg)}to{opacity:1;transform:scale(1)rotate(0)}}.image-gallery{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-bottom:1rem;display:grid}.image-gallery-item{aspect-ratio:1;background-color:#f5f5f5;border-radius:12px;transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden;box-shadow:0 2px 8px #0000001a}.image-gallery-item:hover{transform:translateY(-3px);box-shadow:0 4px 12px #00000026}.gallery-image{object-fit:cover;width:100%;height:100%}.image-remove-btn{color:#f44336;cursor:pointer;opacity:0;background-color:#fffffff2;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:16px;font-weight:700;transition:all .2s;display:flex;position:absolute;top:6px;right:6px;box-shadow:0 2px 6px #0003}.image-gallery-item:hover .image-remove-btn{opacity:1}.image-remove-btn:hover{color:#fff;background-color:#f44336;transform:scale(1.1)}.diary-images-gallery{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin:1.5rem 0;display:grid}.diary-image-item{aspect-ratio:4/3;border-radius:12px;overflow:hidden;box-shadow:0 3px 10px #0000001a}.diary-image{object-fit:cover;cursor:pointer;width:100%;height:100%;transition:transform .3s}.diary-image:hover{transform:scale(1.05)}@media (max-width:768px){.image-gallery{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}.diary-images-gallery{grid-template-columns:1fr;gap:12px}}.spotify-login-section{text-align:center;background:linear-gradient(135deg,#f5f5f5 0%,#e8f5e9 100%);border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:2rem 1rem;display:flex}.spotify-login-description{color:#666;max-width:400px;margin:0;font-size:.95rem}.spotify-login-button{color:#fff;background:linear-gradient(135deg,#1db954 0%,#1ed760 100%);border:none;padding:12px 24px;font-size:1rem;transition:all .3s;box-shadow:0 4px 12px #1db9544d}.spotify-login-button:hover{background:linear-gradient(135deg,#1ed760 0%,#1db954 100%);transform:translateY(-2px);box-shadow:0 6px 16px #1db95466}
