:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;--app-font-scale: 1;--bg-primary: #f5f5f5;--bg-secondary: #ffffff;--bg-tertiary: #e0e0e0;--text-primary: rgba(0, 0, 0, .87);--text-secondary: #666666;--text-tertiary: #999999;--border-color: #e0e0e0;--shadow: rgba(0, 0, 0, .1);--accent-color: #31708f;--accent-hover: #2a5f7a;color-scheme:light;color:var(--text-primary);background-color:var(--bg-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .3s ease,color .3s ease}.dark-mode{--bg-primary: #1a1a1a;--bg-secondary: #2d2d2d;--bg-tertiary: #404040;--text-primary: #e0e0e0;--text-secondary: #b0b0b0;--text-tertiary: #808080;--border-color: #404040;--shadow: rgba(0, 0, 0, .5);--accent-color: #4a9dd4;--accent-hover: #6bb5e8;color-scheme:dark;color:var(--text-primary);background-color:var(--bg-primary)}body{margin:0;min-width:320px;min-height:100vh}html.font-size-large{zoom:1.15}html.font-size-xlarge{zoom:1.3}@supports not (zoom: 1){html.font-size-large{font-size:18px;zoom:unset}html.font-size-xlarge{font-size:20px;zoom:unset}}button,input{font-family:inherit}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}.bottom-footer{position:fixed;bottom:0;left:0;right:0;z-index:90;display:flex;flex-direction:column;pointer-events:none}.bottom-footer>*{pointer-events:auto}.footer-ad-slot{min-height:84px;padding:10px 16px;background:linear-gradient(135deg,#31708ff2,#234c61f5);border-top:1px solid rgba(255,255,255,.14);box-shadow:0 -2px 10px var(--shadow);text-decoration:none;color:inherit}.footer-ad-slot-adsense{position:relative;min-height:0;padding:0;background:transparent;border-top:0;box-shadow:none;overflow:hidden}.footer-ad-slot-adsense.is-filled{min-height:84px;padding:8px 12px 6px;background:linear-gradient(135deg,#31708ff2,#234c61f5);border-top:1px solid rgba(255,255,255,.14);box-shadow:0 -2px 10px var(--shadow)}.footer-ad-slot-adsense.is-hidden{display:none}.footer-ad-slot:hover{background:linear-gradient(135deg,#387ea0fa,#234c61fa)}.footer-ad-slot:focus-visible{outline:2px solid rgba(255,255,255,.7);outline-offset:-4px}.footer-ad-copy{min-width:0;display:flex;flex-direction:column;gap:2px}.footer-ad-badge{font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#ffffffb8}.footer-ad-title{color:#fff;font-size:.95rem;line-height:1.2}.footer-ad-description{color:#ffffffd1;font-size:.8rem;line-height:1.25}.footer-ad-image,.footer-ad-placeholder{width:108px;min-width:108px;height:56px;border-radius:12px}.footer-ad-image{object-fit:cover;border:1px solid rgba(255,255,255,.16)}.footer-ad-placeholder{display:flex;align-items:center;justify-content:center;padding:0 8px;text-align:center;font-size:.78rem;font-weight:700;color:#fff;background:#ffffff1f;border:1px dashed rgba(255,255,255,.36)}.footer-ad-slot{display:flex;align-items:center;justify-content:space-between;gap:12px}.footer-adsense-ins{width:100%;min-height:0}.footer-ad-slot-adsense.is-filled .footer-adsense-ins{min-height:60px}.footer-ad-badge-overlay{position:absolute;top:6px;left:12px;z-index:1;pointer-events:none}.footer-ad-slot-adsense:not(.is-filled) .footer-ad-badge-overlay{display:none}.bottom-nav{height:56px;padding-bottom:env(safe-area-inset-bottom,0);background-color:var(--bg-secondary);border-top:1px solid var(--border-color, rgba(0, 0, 0, .08));box-shadow:0 -2px 10px var(--shadow);transition:background-color .3s ease,border-color .3s ease,box-shadow .3s ease}.bottom-nav-list{list-style:none;margin:0;padding:0;height:100%;display:flex;align-items:stretch;justify-content:space-around}.bottom-nav-item{flex:1;display:flex;min-width:0}.bottom-nav-item.featured{display:flex;align-items:flex-end;justify-content:center;padding-bottom:0}.bottom-nav-link{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:6px 4px 8px;color:var(--text-secondary);text-decoration:none;font-size:.7rem;font-weight:500;transition:color .2s ease,background-color .2s ease;-webkit-tap-highlight-color:transparent}.bottom-nav-link:hover{color:var(--text-primary);background-color:var(--bg-hover, rgba(0, 0, 0, .04))}.bottom-nav-link.active{color:var(--accent-color, #31708f);font-weight:600}.bottom-nav-link.featured{position:relative;margin-top:-12px;padding:10px 12px 8px;color:var(--text-primary);border-radius:14px}.bottom-nav-link.featured:hover{color:var(--text-primary);background-color:var(--bg-hover, rgba(0, 0, 0, .04))}.bottom-nav-link.featured.active{color:var(--accent-color, #31708f)}.bottom-nav-link.featured .bottom-nav-icon{font-size:1.6rem}.bottom-nav-link.featured .bottom-nav-label{font-weight:600;font-size:.68rem}.bottom-nav-icon{font-size:1.35rem;line-height:1}.bottom-nav-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}@media(min-width:768px){.footer-ad-slot{padding-left:24px;padding-right:24px}.footer-ad-copy{max-width:520px}}@media(max-width:360px){.footer-ad-description{display:none}.footer-ad-image,.footer-ad-placeholder{width:92px;min-width:92px}}.drawer-container{--music-player-height: 80px;--footer-ad-height: 0px;--bottom-nav-height: 56px;min-height:100vh;display:flex;flex-direction:column;background-color:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.drawer-header{background-color:#31708f;color:#fff;padding:15px 20px;display:flex;align-items:center;gap:15px;position:sticky;top:0;z-index:100;box-shadow:0 2px 4px #0000001a}.drawer-toggle{background:none;border:none;color:#fff;font-size:24px;cursor:pointer;padding:5px;display:flex;align-items:center;justify-content:center}.drawer-title{font-size:18px;margin:0;flex:1}.drawer-nav{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1000;pointer-events:none;overflow-x:hidden}.drawer-nav.open{pointer-events:auto}.drawer-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#00000080;opacity:0;transition:opacity .3s}.drawer-nav.open .drawer-overlay{opacity:1}.drawer-menu{position:absolute;top:0;left:0;width:320px;max-width:85%;height:100%;min-height:100vh;background-color:var(--bg-secondary);box-shadow:2px 0 8px var(--shadow);transform:translate(-100%);transition:transform .3s,background-color .3s ease;overflow-x:hidden;overflow-y:auto;display:flex;flex-direction:column}.drawer-nav.open .drawer-menu{transform:translate(0)}.drawer-user{padding:20px;background-color:#31708f;color:#fff;display:flex;align-items:center;gap:15px}.drawer-user-avatar{width:50px;height:50px;border-radius:50%;background-color:#fff3;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;overflow:hidden;flex-shrink:0}.drawer-user-avatar img{width:100%;height:100%;object-fit:cover;display:block}.drawer-user-avatar span{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.drawer-user-info{flex:1;min-width:0;overflow:hidden}.drawer-user-name{font-size:16px;font-weight:700;margin:0 0 5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.drawer-user-email{font-size:12px;opacity:.9;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.drawer-menu-list{list-style:none;padding:0;margin:0;flex:1}.drawer-menu-item{display:flex;align-items:center;gap:15px;padding:15px 20px;color:var(--text-primary);text-decoration:none;border-bottom:1px solid var(--border-color);transition:background-color .2s,color .2s;min-width:0}.drawer-menu-item:hover{background-color:var(--bg-tertiary)}.drawer-menu-item.active{background-color:var(--accent-color);background-color:#31708f1a;color:var(--accent-color);font-weight:700}.dark-mode .drawer-menu-item.active{background-color:#4a9dd433;color:var(--accent-color)}.drawer-menu-icon{font-size:20px}.drawer-menu-label{font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.drawer-actions{padding:20px;display:flex;flex-direction:column;gap:10px;margin-top:auto;border-top:1px solid var(--border-color, rgba(255, 255, 255, .08))}.drawer-logout{padding:12px 16px;background-color:#dc3545;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:opacity .2s ease,background-color .2s ease}.drawer-logout:hover{opacity:.9;background-color:#c82333}.drawer-content{flex:1;padding-bottom:calc(20px + var(--music-player-height) + var(--footer-ad-height) + var(--bottom-nav-height) + env(safe-area-inset-bottom,0px))}@media(min-width:768px){.drawer-container{flex-direction:row;height:100vh;min-height:100vh}.drawer-header{display:none}.drawer-nav{position:relative;width:320px;min-width:320px;flex-shrink:0;pointer-events:auto;display:flex;flex-direction:column;min-height:0;overflow-x:hidden}.drawer-overlay{display:none}.drawer-menu{position:relative;transform:translate(0);box-shadow:none;border-right:1px solid var(--border-color);flex:1;min-height:0;display:flex;flex-direction:column;overflow-x:hidden}.drawer-content{flex:1;overflow-y:auto;min-height:0;padding-bottom:calc(20px + var(--music-player-height) + var(--footer-ad-height) + var(--bottom-nav-height) + env(safe-area-inset-bottom,0px))}}.install-banner{position:sticky;top:0;z-index:999;background:var(--accent-color);color:#fff;padding:12px 16px;box-shadow:0 2px 8px var(--shadow)}.install-banner-inner{max-width:800px;margin:0 auto;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px}.install-banner-text{margin:0;font-size:14px;line-height:1.4;flex:1;min-width:200px}.install-banner-actions{display:flex;flex-wrap:wrap;gap:8px;flex-shrink:0}.install-banner-btn{padding:8px 16px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;border:none;transition:opacity .2s}.install-banner-btn:disabled{opacity:.7;cursor:not-allowed}.install-banner-btn-primary{background:#fff;color:var(--accent-color)}.install-banner-btn-primary:hover:not(:disabled){filter:brightness(.95)}.install-banner-btn-dismiss{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.5)}.install-banner-btn-dismiss:hover{background:#ffffff40}.music-player-global.minimized{position:fixed;bottom:0;left:0;right:0;background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:.5rem 1rem;z-index:1000;box-shadow:0 -2px 10px var(--shadow);transition:all .3s ease;animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.player-global-content-mini{display:flex;align-items:center;gap:.75rem;max-width:1400px;margin:0 auto;cursor:pointer}.player-mini-artwork{width:56px;height:56px;border-radius:4px;object-fit:cover;flex-shrink:0}.player-mini-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.2rem}.player-mini-title{font-weight:600;color:var(--text-primary);font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-mini-artist{color:var(--text-secondary);font-size:.8rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-mini-favorite-button{background:transparent;border:none;font-size:1.3rem;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;transition:transform .2s,opacity .2s;flex-shrink:0;opacity:.8}.player-mini-favorite-button:hover{transform:scale(1.15);opacity:1}.player-mini-favorite-button.active{opacity:1}.player-mini-play-button{background:var(--accent-color);color:#fff;border:none;border-radius:50%;width:48px;height:48px;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s,transform .2s;flex-shrink:0}.player-mini-play-button:hover{background:var(--accent-hover);transform:scale(1.05)}.player-mini-volume-container{position:relative;display:flex;align-items:center;flex-shrink:0;margin-left:.5rem}.player-mini-volume-button{background:transparent;border:none;font-size:1.1rem;cursor:pointer;padding:.4rem;display:flex;align-items:center;justify-content:center;transition:transform .2s,opacity .2s;opacity:.8;flex-shrink:0}.player-mini-volume-button:hover{transform:scale(1.1);opacity:1}.player-mini-volume-slider-container{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:.5rem;padding:.75rem .5rem;background:var(--bg-secondary);border-radius:8px;box-shadow:0 4px 12px var(--shadow);border:1px solid var(--border-color);display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:120px;width:32px;z-index:1001;animation:slideDownVolume .2s ease-out}@keyframes slideDownVolume{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.player-mini-volume-slider{width:100px;height:3px;background:var(--bg-tertiary);border-radius:2px;outline:none;cursor:pointer;-webkit-appearance:none;appearance:none;transform:rotate(-90deg);transform-origin:center}.player-mini-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:var(--accent-color);border-radius:50%;cursor:pointer;transition:transform .2s}.player-mini-volume-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.player-mini-volume-slider::-moz-range-thumb{width:16px;height:16px;background:var(--accent-color);border-radius:50%;border:none;cursor:pointer;transition:transform .2s}.player-mini-volume-slider::-moz-range-thumb:hover{transform:scale(1.2)}.music-player-global.expanded{position:fixed;inset:0;z-index:2000;background:var(--bg-primary);overflow-y:auto;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.player-expanded-overlay{position:fixed;inset:0;background:var(--bg-primary);cursor:pointer}.player-expanded-content{position:relative;z-index:1;display:flex;flex-direction:column;min-height:100vh;padding:1rem;max-width:600px;margin:0 auto;pointer-events:auto}.player-expanded-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;margin-bottom:1rem}.player-expanded-minimize{background:transparent;border:none;color:var(--text-primary);font-size:1.5rem;cursor:pointer;padding:.5rem;transition:transform .2s}.player-expanded-minimize:hover{transform:scale(1.1)}.player-expanded-header-info{flex:1;text-align:center}.player-expanded-context{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px}.player-expanded-playlist{font-size:1rem;font-weight:600;color:var(--text-primary);margin-top:.25rem}.player-expanded-artwork-container{width:100%;aspect-ratio:1;margin:2rem 0;border-radius:12px;overflow:hidden;box-shadow:0 8px 24px var(--shadow)}.player-expanded-artwork{width:100%;height:100%;object-fit:cover}.player-expanded-song-info{margin:1.5rem 0}.player-expanded-title-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.player-expanded-title{flex:1;font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.player-expanded-favorite{color:#1db954;font-size:1.5rem;flex-shrink:0}.player-expanded-artist{font-size:1rem;color:var(--text-secondary)}.player-expanded-progress{margin:2rem 0}.player-expanded-progress-bar{width:100%;height:4px;background:var(--bg-tertiary);border-radius:2px;overflow:hidden;cursor:pointer;margin-bottom:.5rem}.player-expanded-progress-fill{height:100%;background:var(--accent-color);border-radius:2px;transition:width .1s}.player-expanded-time{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-secondary);font-variant-numeric:tabular-nums}.player-expanded-controls{display:flex;align-items:center;justify-content:center;gap:1.5rem;margin:2rem 0}.player-expanded-button{background:transparent;border:none;color:var(--text-primary);font-size:1.5rem;cursor:pointer;padding:.75rem;border-radius:50%;transition:all .2s;opacity:.8}.player-expanded-button:hover{opacity:1;background:var(--bg-tertiary)}.player-expanded-button.active{opacity:1;color:var(--accent-color)}.player-expanded-button.play-button-large{background:var(--accent-color);color:#fff;width:64px;height:64px;font-size:2rem;opacity:1}.player-expanded-button.play-button-large:hover{background:var(--accent-hover);transform:scale(1.05)}.player-expanded-volume{display:flex;align-items:center;justify-content:center;gap:1rem;margin:2rem 0;position:relative}.player-expanded-volume-button{background:var(--bg-tertiary);border:none;font-size:1.5rem;cursor:pointer;padding:.75rem;display:flex;align-items:center;justify-content:center;transition:transform .2s,opacity .2s,background-color .2s;opacity:.9;flex-shrink:0;border-radius:50%;width:48px;height:48px}.player-expanded-volume-button:hover{transform:scale(1.1);opacity:1;background:var(--bg-secondary)}.player-expanded-volume-slider-container{display:flex;flex-direction:row;align-items:center;gap:1rem;padding:1rem 1.5rem;background:var(--bg-tertiary);border-radius:12px;width:auto;justify-content:center;animation:slideDownVolume .2s ease-out}.player-expanded-volume-slider{width:250px;height:4px;background:var(--bg-primary);border-radius:2px;outline:none;cursor:pointer;-webkit-appearance:none;appearance:none}.player-expanded-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;background:var(--accent-color);border-radius:50%;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 2px 4px var(--shadow)}.player-expanded-volume-slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 2px 8px var(--shadow)}.player-expanded-volume-slider::-moz-range-thumb{width:20px;height:20px;background:var(--accent-color);border-radius:50%;border:none;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 2px 4px var(--shadow)}.player-expanded-volume-slider::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:0 2px 8px var(--shadow)}.player-expanded-volume-value{min-width:45px;font-size:.85rem;color:var(--text-secondary);text-align:center;font-variant-numeric:tabular-nums}.player-expanded-actions{display:flex;align-items:center;justify-content:center;gap:2rem;margin-top:2rem;padding:1rem 0;border-top:1px solid var(--border-color)}.player-expanded-action{background:transparent;border:none;color:var(--text-primary);font-size:1.5rem;cursor:pointer;padding:.5rem;opacity:.7;transition:opacity .2s}.player-expanded-action:hover{opacity:1}.player-modal-overlay{position:fixed;inset:0;background:#000000b3;z-index:3000;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.player-modal-content{background:var(--bg-secondary);border-radius:16px;max-width:500px;width:100%;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #00000080;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.player-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--border-color)}.player-modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.player-modal-close{background:transparent;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;padding:.25rem;line-height:1;transition:color .2s}.player-modal-close:hover{color:var(--text-primary)}.player-queue-list{flex:1;overflow-y:auto;padding:.5rem 0;max-height:calc(80vh - 80px)}.player-queue-empty{padding:2rem;text-align:center;color:var(--text-secondary)}.player-queue-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1.5rem;cursor:pointer;transition:background-color .2s}.player-queue-item:hover{background-color:var(--bg-tertiary)}.player-queue-item.active{background-color:var(--bg-tertiary);color:var(--accent-color)}.player-queue-number{min-width:24px;font-size:.9rem;color:var(--text-secondary);text-align:center}.player-queue-item.active .player-queue-number{color:var(--accent-color)}.player-queue-info{flex:1;min-width:0}.player-queue-title{font-weight:500;color:var(--text-primary);font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-queue-item.active .player-queue-title{color:var(--accent-color)}.player-queue-artist{font-size:.85rem;color:var(--text-secondary);margin-top:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-queue-playing{font-size:1rem;color:var(--accent-color)}.player-playlist-list{flex:1;overflow-y:auto;padding:.5rem 0;max-height:calc(80vh - 80px)}.player-playlist-empty{padding:2rem;text-align:center;color:var(--text-secondary)}.player-playlist-empty p{margin:0 0 1rem}.player-playlist-create-btn{background:var(--accent-color);color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:background-color .2s}.player-playlist-create-btn:hover{background:var(--accent-hover)}.player-playlist-item{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;cursor:pointer;transition:background-color .2s;gap:1rem}.player-playlist-item:hover{background-color:var(--bg-tertiary)}.player-playlist-info{flex:1;min-width:0}.player-playlist-name{font-weight:600;color:var(--text-primary);font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-playlist-description{font-size:.85rem;color:var(--text-secondary);margin-top:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-playlist-add-btn{background:transparent;border:none;color:var(--accent-color);font-size:1.5rem;cursor:pointer;padding:.5rem;flex-shrink:0;transition:transform .2s}.player-playlist-add-btn:hover{transform:scale(1.2)}@media(max-width:768px){.player-mini-artwork{width:48px;height:48px}.player-mini-title{font-size:.85rem}.player-mini-artist{font-size:.75rem}.player-mini-play-button{width:44px;height:44px;font-size:1.1rem}.player-mini-volume-container{margin-left:.4rem}.player-mini-volume-slider{width:80px}.player-mini-volume-slider-container{padding:.6rem .8rem;gap:.6rem}.player-expanded-volume-slider{width:200px}.player-expanded-volume-slider-container{padding:.75rem 1.25rem;gap:.75rem}.player-expanded-content{padding:.75rem}.player-expanded-title{font-size:1.25rem}.player-expanded-controls{gap:1rem}.player-expanded-button{font-size:1.25rem}.player-expanded-button.play-button-large{width:56px;height:56px;font-size:1.75rem}.player-expanded-actions{gap:1.5rem}}@media(max-width:480px){.player-mini-artwork{width:44px;height:44px}.player-mini-title{font-size:.8rem}.player-mini-artist{font-size:.7rem}.player-mini-play-button{width:40px;height:40px;font-size:1rem}.player-mini-volume-container{margin-left:.3rem}.player-mini-volume-button{font-size:1rem;padding:.3rem}.player-mini-volume-slider{width:80px}.player-mini-volume-slider-container{padding:.5rem .4rem;min-height:100px;width:28px}.player-expanded-volume-button{width:44px;height:44px;font-size:1.25rem;padding:.6rem}.player-expanded-volume-slider{width:200px}.player-expanded-volume-slider-container{padding:.75rem 1rem;width:auto;gap:.75rem}.player-expanded-volume-value{min-width:40px;font-size:.75rem}.player-expanded-title{font-size:1.1rem}.player-expanded-controls{gap:.75rem}.player-expanded-button{font-size:1.1rem;padding:.5rem}.player-expanded-button.play-button-large{width:52px;height:52px;font-size:1.5rem}}.loading-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:9999}.loading-spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #31708f;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.bible-container{min-height:100vh;background-color:var(--bg-primary);padding:12px;max-width:800px;margin:0 auto;color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.bible-loading{display:flex;justify-content:center;align-items:center;min-height:400px}.bible-loading p{font-size:18px;color:var(--text-secondary)}.bible-section{margin-bottom:12px}.bible-section-title{display:block;font-size:20px;font-weight:700;margin-bottom:10px;color:var(--text-primary)}.bible-select{width:100%;padding:12px;border-radius:10px;border:1px solid var(--accent-color);background-color:var(--bg-secondary);color:var(--text-primary);font-size:16px;cursor:pointer;box-sizing:border-box;transition:background-color .3s ease,color .3s ease,border-color .3s ease}.bible-select:focus{outline:none;border-color:var(--accent-color)}.bible-header-container{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;flex-wrap:wrap;gap:8px}.bible-book-title{font-size:18px;font-weight:700;color:var(--accent-color);margin:0}.bible-version-abbrev{font-size:15px;font-weight:700;color:var(--text-secondary)}.bible-change-book-button{border:1px solid var(--border-color, rgba(0, 0, 0, .08));background:var(--bg-secondary);color:var(--text-secondary);border-radius:8px;padding:6px 10px;font-size:13px;font-weight:600;cursor:pointer}.bible-progress-container{margin-bottom:10px;padding:10px;background-color:var(--bg-secondary);border-radius:10px;transition:background-color .3s ease}.bible-progress-info{display:flex;flex-direction:column;gap:8px}.bible-progress-text{font-size:14px;color:var(--text-secondary);font-weight:500}.bible-progress-bar{width:100%;height:8px;background-color:var(--bg-tertiary);border-radius:4px;overflow:hidden;transition:background-color .3s ease}.bible-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-color),#4caf50);border-radius:4px;transition:width .3s ease}.bible-chapter-audio-wrap{margin-bottom:10px;padding:10px 12px;background-color:var(--bg-secondary);border-radius:10px;border:1px solid var(--accent-color);transition:background-color .3s ease}.bible-chapter-audio-label{margin:0 0 8px;font-size:15px;font-weight:600;color:var(--text-primary)}.bible-chapter-audio{width:100%;height:40px;outline:none}.bible-chapter-audio::-webkit-media-controls-panel{background-color:var(--bg-secondary)}.bible-audio-preload{position:absolute;width:0;height:0;opacity:0;pointer-events:none;visibility:hidden}.bible-verses-container{background-color:var(--bg-secondary);border-radius:10px;padding:12px;margin:10px 0;max-height:calc(100dvh - 330px);overflow-y:auto;box-shadow:0 2px 4px var(--shadow);transition:background-color .3s ease,box-shadow .3s ease}.bible-verse{margin-bottom:15px;padding:10px;border-radius:5px;transition:background-color .2s;display:flex;gap:10px;align-items:flex-start}.bible-verse:hover,.bible-verse.selected{background-color:var(--bg-tertiary)}.bible-verse.read{opacity:.85}.bible-verse.read .verse-text{color:var(--text-secondary)}.verse-read-checkbox{flex-shrink:0;width:28px;height:28px;min-width:28px;border:2px solid var(--accent-color);background-color:var(--bg-secondary);border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;padding:0;transition:all .2s ease;margin-top:2px}.verse-read-checkbox:hover:not(:disabled){background-color:var(--bg-tertiary);transform:scale(1.1)}.verse-read-checkbox:disabled{opacity:.5;cursor:wait}.verse-content{flex:1;cursor:pointer;display:flex;gap:10px}.verse-number{font-weight:700;color:var(--accent-color);flex-shrink:0}.verse-text{color:var(--text-primary);font-size:var(--bible-font-size, 14px);line-height:1.6}.bible-font-controls{display:flex;align-items:center;gap:8px}.font-button{padding:6px 10px;border-radius:8px;border:1px solid var(--border-color, rgba(0, 0, 0, .08));background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;font-weight:600}.font-size-display{min-width:44px;text-align:center;font-size:14px;color:var(--text-secondary)}.bible-navigation{display:flex;justify-content:space-between;gap:8px;margin-top:10px;flex-wrap:wrap}.bible-nav-button{min-width:80px;padding:9px 10px;border-radius:10px;border:none;font-size:14px;cursor:pointer;transition:opacity .3s;display:flex;align-items:center;justify-content:center;gap:5px}.bible-nav-button-primary{flex:1}.bible-nav-button-secondary{min-width:120px}.bible-nav-button:disabled{opacity:.5;cursor:not-allowed}.bible-nav-button.previous{background-color:#8a8a8a;color:#fff}.bible-nav-button.share{background-color:var(--accent-color);color:#fff}.bible-nav-button.next{background-color:#31708f;color:#fff}.bible-nav-button.mark-all-read{background-color:#4caf50;color:#fff;font-weight:500}.bible-nav-button.mark-all-read:hover:not(:disabled){opacity:.85;transform:scale(1.02)}.bible-nav-button:hover:not(:disabled){opacity:.9}.bible-share-wrap{position:relative}.bible-share-overlay{position:fixed;inset:0;z-index:100;background:#0006}.bible-share-menu{position:fixed;bottom:0;left:0;right:0;z-index:101;background:var(--bg-secondary);border-radius:16px 16px 0 0;padding:20px 16px calc(20px + env(safe-area-inset-bottom,0));box-shadow:0 -4px 20px var(--shadow);max-height:70vh;overflow-y:auto;animation:bible-share-slide-up .25s ease}@keyframes bible-share-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.bible-share-menu-title{margin:0 0 16px;font-size:1rem;font-weight:600;color:var(--text-primary);text-align:center}.bible-share-menu-item{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;margin-bottom:8px;background:var(--bg-primary);border:1px solid var(--border-color, rgba(0, 0, 0, .08));border-radius:10px;color:var(--text-primary);font-size:1rem;cursor:pointer;transition:background-color .2s ease,transform .1s ease;text-align:left}.bible-share-menu-item:last-child{margin-bottom:0}.bible-share-menu-item:hover{background-color:var(--bg-hover, rgba(0, 0, 0, .05))}.bible-share-menu-item:active{transform:scale(.98)}.bible-share-icon-wrap{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;flex-shrink:0}.bible-share-icon-wrap.bible-share-icon-emoji{font-size:1.25rem}.bible-share-icon{width:24px;height:24px}.bible-share-icon-whatsapp{color:#25d366;fill:#25d366}.bible-share-icon-facebook{color:#1877f2;fill:#1877f2}.bible-share-icon-instagram{color:#e4405f;fill:#e4405f}@media(min-width:768px){.bible-container{padding:28px}.bible-verses-container{max-height:calc(100vh - 360px)}.bible-share-menu{left:0;right:0;margin:0 auto;border-radius:16px;max-width:360px}}.birthdays-container{min-height:100vh;background-color:var(--bg-primary);padding:20px;max-width:800px;margin:0 auto;color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.birthdays-header{margin-bottom:20px}.birthdays-header h1{color:var(--accent-color);font-size:24px;margin:0}.no-birthdays{display:flex;justify-content:center;align-items:center;min-height:300px}.no-birthdays p{font-size:16px;color:var(--text-secondary)}.birthdays-list{display:flex;flex-direction:column;gap:15px}.birthday-item{display:flex;align-items:center;gap:15px;background-color:var(--bg-secondary);padding:15px;border-radius:10px;box-shadow:0 2px 4px var(--shadow);transition:background-color .3s ease,box-shadow .3s ease}.birthday-photo{width:50px;height:50px;border-radius:25px;object-fit:cover;flex-shrink:0}.birthday-photo-placeholder{width:50px;height:50px;border-radius:25px;background:linear-gradient(135deg,var(--accent-color) 0%,var(--accent-hover) 100%);display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;font-weight:700;flex-shrink:0}.birthday-name{font-size:16px;font-weight:700;color:var(--text-primary);margin:0 0 5px}.birthday-details{font-size:14px;color:var(--text-secondary);margin:0}@media(min-width:768px){.birthdays-container{padding:40px}}.calendar-container{min-height:100vh;background-color:var(--bg-primary);padding:20px;max-width:1400px;margin:0 auto;color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:15px}.calendar-header h1{color:var(--accent-color);font-size:24px;margin:0}.calendar-controls{display:flex;gap:10px;align-items:center}.calendar-nav-btn,.calendar-today-btn{padding:8px 16px;background-color:var(--accent-color);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;transition:opacity .3s}.calendar-nav-btn:hover,.calendar-today-btn:hover{opacity:.9}.calendar-today-btn{background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.calendar-month-header{text-align:center;margin-bottom:20px}.calendar-month-header h2{color:var(--text-primary);font-size:28px;margin:0}.calendar-filters{margin-bottom:20px;display:flex;align-items:center;gap:10px}.calendar-filters label{color:var(--text-secondary);font-size:14px}.filter-select{padding:8px 12px;border:1px solid var(--border-color);border-radius:8px;background-color:var(--bg-secondary);color:var(--text-primary);font-size:14px;cursor:pointer}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:30px;background-color:var(--bg-secondary);padding:10px;border-radius:12px}.calendar-day-header{padding:10px;text-align:center;font-weight:700;color:var(--accent-color);font-size:14px}.calendar-day{min-height:100px;padding:8px;background-color:var(--bg-tertiary);border-radius:8px;cursor:pointer;transition:background-color .2s,transform .1s;display:flex;flex-direction:column;position:relative}.calendar-day:hover{background-color:var(--bg-secondary);transform:scale(1.02)}.calendar-day.today{border:2px solid var(--accent-color);background-color:var(--bg-secondary)}.calendar-day.has-events{border-left:4px solid var(--accent-color)}.calendar-day.empty{background-color:transparent;cursor:default;min-height:0;padding:0}.calendar-day.empty:hover{transform:none}.day-number{font-weight:700;font-size:16px;margin-bottom:4px;color:var(--text-primary)}.day-events{display:flex;flex-wrap:wrap;gap:4px;margin-top:auto}.event-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.event-more{font-size:10px;color:var(--text-secondary);font-weight:700}.events-list-section{margin-top:30px}.events-list-section h3{color:var(--text-primary);font-size:20px;margin-bottom:15px}.no-events{text-align:center;color:var(--text-secondary);padding:40px}.event-item{background-color:var(--bg-secondary);border-radius:8px;padding:15px;border-left:4px solid;cursor:pointer;transition:transform .2s,box-shadow .2s}.event-item:hover{transform:translate(5px);box-shadow:0 2px 8px var(--shadow)}.event-date{color:var(--text-secondary);font-size:12px;margin-bottom:5px}.event-title{color:var(--text-primary);font-size:16px;font-weight:500;margin-bottom:5px}.event-location{color:var(--text-secondary);font-size:13px;margin-top:5px}.event-type-badge{display:inline-block;padding:4px 8px;border-radius:4px;color:#fff;font-size:11px;font-weight:700;margin-top:8px}.event-modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.event-modal{background-color:var(--bg-secondary);border-radius:12px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 4px 20px #0000004d}.event-modal-close{position:absolute;top:15px;right:15px;background:none;border:none;font-size:32px;color:var(--text-secondary);cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s,color .2s;z-index:1001;pointer-events:auto;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.event-modal-close:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.event-modal-close:active{transform:scale(.95)}.event-modal-header{padding:20px;border-top:4px solid;position:relative}.event-modal-header h2{color:var(--text-primary);font-size:24px;margin:0 0 10px}.event-modal-type{display:inline-block;padding:6px 12px;border-radius:6px;color:#fff;font-size:12px;font-weight:700}.event-modal-body{padding:20px}.event-modal-info{display:flex;flex-direction:column;gap:15px}.info-item{color:var(--text-primary)}.info-item strong{color:var(--accent-color);display:block;margin-bottom:5px}.info-item p{margin:5px 0 0;color:var(--text-secondary);line-height:1.6}.event-modal-navigation{display:flex;align-items:center;justify-content:center;gap:15px;padding:15px 20px;background-color:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.event-nav-btn{background:var(--accent-color);color:#fff;border:none;width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s;padding:0}.event-nav-btn:hover:not(:disabled){background:var(--accent-color);opacity:.9;transform:scale(1.1)}.event-nav-btn:disabled{background:var(--bg-tertiary);color:var(--text-secondary);cursor:not-allowed;opacity:.5}.event-counter{color:var(--text-primary);font-size:14px;font-weight:500;min-width:60px;text-align:center}.all-day-events{margin-top:25px;padding-top:25px;border-top:2px solid var(--border-color)}.all-day-events-header{margin-bottom:15px;color:var(--text-primary);font-size:15px}.all-day-events-header strong{color:var(--accent-color)}.all-day-events-list{display:flex;flex-direction:column;gap:10px}.day-event-item{background-color:var(--bg-tertiary);border-radius:8px;padding:12px;cursor:pointer;transition:all .2s;border-left:3px solid transparent}.day-event-item:hover{background-color:var(--bg-primary);transform:translate(3px)}.day-event-item.active{border-left-color:var(--accent-color);background-color:var(--bg-primary);box-shadow:0 2px 8px var(--shadow)}.day-event-time{font-size:12px;color:var(--text-secondary);margin-bottom:4px;font-weight:500}.day-event-title{font-size:14px;color:var(--text-primary);font-weight:500;margin-bottom:6px}.day-event-type{display:inline-block;padding:3px 8px;border-radius:4px;color:#fff;font-size:10px;font-weight:700}@media(max-width:768px){.calendar-container{padding:15px}.calendar-grid{gap:4px;padding:8px}.calendar-day{min-height:80px;padding:6px}.day-number{font-size:14px}.calendar-header{flex-direction:column;align-items:flex-start}.calendar-controls{width:100%;justify-content:center}}.christian-singer-container{min-height:100vh;background-color:var(--bg-primary);padding:20px;max-width:800px;margin:0 auto;color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.christian-singer-loading{display:flex;justify-content:center;align-items:center;min-height:400px}.christian-singer-loading p{font-size:18px;color:var(--text-secondary)}.christian-singer-header{margin-bottom:20px}.christian-singer-header h1{color:var(--accent-color);font-size:24px;margin:0 0 20px}.search-container{display:flex;align-items:center;background-color:var(--bg-secondary);border-radius:25px;padding:10px 15px;box-shadow:0 2px 4px var(--shadow);gap:10px;transition:background-color .3s ease,box-shadow .3s ease}.search-icon{font-size:20px;color:var(--text-secondary)}.search-input{flex:1;border:none;outline:none;font-size:16px;color:var(--text-primary);background:transparent}.search-input::placeholder{color:var(--text-tertiary)}.hymns-list{display:flex;flex-direction:column;gap:10px}.no-hymns{display:flex;justify-content:center;align-items:center;min-height:300px}.no-hymns p{font-size:16px;color:var(--text-secondary)}.hymn-item{padding:15px;background-color:var(--bg-secondary);border-radius:8px;box-shadow:0 2px 4px var(--shadow);cursor:pointer;transition:transform .2s,box-shadow .2s,background-color .3s ease}.hymn-item:hover{transform:translateY(-2px);box-shadow:0 4px 8px var(--shadow)}.hymn-title{font-size:18px;color:var(--text-primary);font-weight:700}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background-color:var(--bg-secondary);border-radius:10px;width:100%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 4px 20px var(--shadow);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.modal-header{position:relative;display:block;padding:56px 20px 20px;border-bottom:1px solid var(--border-color)}.modal-title{font-size:22px;font-weight:700;color:var(--accent-color);margin:0;width:100%;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-close{position:absolute;top:12px;right:12px;background:none;border:none;font-size:26px;color:var(--text-primary);cursor:pointer;padding:6px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background-color .2s}.modal-close:hover{background-color:var(--bg-tertiary)}.modal-header{position:relative;padding-right:120px}.font-controls{position:absolute;top:12px;left:50%;transform:translate(-50%);display:inline-flex;align-items:center;gap:8px;background:#0000000f;padding:6px 8px;border-radius:10px;z-index:5}.font-button{width:34px;height:30px;display:inline-flex;align-items:center;justify-content:center;padding:0 8px;border-radius:8px;border:1px solid var(--border-color, rgba(0, 0, 0, .08));background:transparent;color:var(--text-primary);cursor:pointer;font-weight:700;font-size:13px}.font-button:hover{opacity:.95}.font-reset{font-size:14px}.font-size-display{min-width:44px;text-align:center;font-size:13px;color:var(--text-secondary)}.lyrics-container{flex:1;overflow-y:auto;padding:20px}.hymn-lyrics{font-size:var(--bible-font-size, 16px);color:var(--text-primary);line-height:calc(var(--bible-font-size, 16px) * 1.5);white-space:pre-wrap;word-wrap:break-word;margin:0;font-family:inherit}@media(min-width:768px){.christian-singer-container{padding:40px}.modal-content{max-width:700px}}.dashboard-screen{padding:20px;max-width:1200px;margin:0 auto;min-height:calc(100vh - 60px)}.dashboard-header{margin-bottom:30px}.dashboard-header h1{font-size:32px;color:var(--text-primary);margin:0 0 8px}.dashboard-subtitle{color:var(--text-secondary);font-size:16px;margin:0}.dashboard-content{display:flex;flex-direction:column;gap:30px}.profile-completion-section{border-left:4px solid var(--primary-color, #667eea)}.profile-completion-description{margin:0 0 12px;color:var(--text-primary);font-size:14px}.profile-completion-progress{width:100%;height:12px;background:var(--bg-primary);border-radius:999px;overflow:hidden;border:1px solid var(--border-color, #e0e0e0)}.profile-completion-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-color, #667eea) 0%,var(--accent-color, #31708f) 100%);transition:width .3s ease}.profile-completion-percentage{margin:8px 0 0;font-size:13px;color:var(--text-secondary);font-weight:600}.profile-completion-missing{margin-top:12px;display:flex;flex-wrap:wrap;gap:8px;align-items:center;color:var(--text-secondary);font-size:13px}.profile-completion-chip{background:var(--bg-primary);border:1px solid var(--border-color, #e0e0e0);border-radius:999px;padding:4px 10px;color:var(--text-primary);font-size:12px}.profile-completion-actions{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}.verse-of-the-day-card{background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);border-left:4px solid var(--accent-color)}.verse-of-the-day-title{font-size:18px;color:var(--text-primary);margin:0 0 12px}.verse-of-the-day-ref{font-size:14px;color:var(--accent-color);font-weight:600;margin:0 0 8px}.verse-of-the-day-text{font-size:16px;line-height:1.6;color:var(--text-primary);margin:0 0 16px;padding-left:12px;border-left:3px solid var(--border-color);font-style:italic}.verse-of-the-day-reflection-wrap{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color)}.verse-of-the-day-reflection-label{font-size:12px;color:var(--text-secondary);margin:0 0 6px;text-transform:uppercase;letter-spacing:.5px}.verse-of-the-day-reflection{font-size:14px;line-height:1.5;color:var(--text-primary);margin:0;white-space:pre-wrap;word-wrap:break-word}.verse-of-the-day-reflection.loading{color:var(--text-secondary);font-style:italic}.verse-of-the-day-reflection.error{color:var(--text-secondary);font-size:13px}.verse-of-the-day-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:12px}.verse-of-the-day-share-btn{background:var(--accent-color);color:#fff;border:none;padding:8px 14px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s,transform .1s}.verse-of-the-day-share-btn:hover{background:var(--accent-hover)}.verse-of-the-day-share-btn:active{transform:scale(.98)}.verse-of-the-day-share-menu{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px;padding:12px;background:var(--bg-tertiary);border-radius:8px}.verse-share-option{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;font-size:14px;color:var(--text-primary);cursor:pointer;transition:background-color .2s}.verse-share-option:hover{background:var(--bg-tertiary)}.verse-share-option .share-icon{width:20px;height:20px}.verse-of-the-day-question-wrap{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color)}.verse-of-the-day-question-label{font-size:12px;color:var(--text-secondary);margin:0 0 6px;text-transform:uppercase;letter-spacing:.5px}.verse-of-the-day-question{font-size:14px;line-height:1.5;color:var(--text-primary);margin:0;font-style:italic;white-space:pre-wrap;word-wrap:break-word}.verse-of-the-day-question.loading{color:var(--text-secondary);font-style:italic}.verse-of-the-day-question.error{color:var(--text-secondary);font-size:13px;font-style:normal}.dashboard-section{background:var(--bg-secondary);border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h2{font-size:20px;color:var(--text-primary);margin:0}.view-all-btn{background:none;border:none;color:var(--primary-color, #667eea);cursor:pointer;font-size:14px;font-weight:500;padding:8px 12px;border-radius:6px;transition:background-color .2s}.view-all-btn:hover{background-color:var(--bg-hover, rgba(102, 126, 234, .1))}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:16px}.stat-card{background:var(--bg-primary);border-radius:10px;padding:20px;display:flex;align-items:center;gap:16px;border:1px solid var(--border-color, #e0e0e0);transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.stat-card.highlight{background:linear-gradient(135deg,var(--primary-color, #667eea) 0%,#764ba2 100%);color:#fff;border:none}.stat-card.highlight .stat-icon,.stat-card.highlight .stat-value,.stat-card.highlight .stat-label{color:#fff}.stat-icon{font-size:32px;line-height:1}.stat-content{flex:1}.stat-value{font-size:28px;font-weight:700;color:var(--text-primary);line-height:1.2;margin-bottom:4px}.stat-label{font-size:14px;color:var(--text-secondary);line-height:1.2}.period-stats{margin-top:16px;padding:12px;background:var(--bg-primary);border-radius:8px;border-left:4px solid var(--primary-color, #667eea)}.period-label{margin:0;color:var(--text-primary);font-size:14px}.events-list{display:flex;flex-direction:column;gap:12px}.event-item{display:flex;gap:16px;padding:16px;background:var(--bg-primary);border-radius:10px;border:1px solid var(--border-color, #e0e0e0);cursor:pointer;transition:transform .2s,box-shadow .2s}.event-item:hover{transform:translate(4px);box-shadow:0 2px 8px #0000001a}.event-date-badge{min-width:60px;height:60px;border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;font-weight:600}.event-day{font-size:24px;line-height:1}.event-month{font-size:12px;text-transform:uppercase;opacity:.9}.event-info{flex:1}.event-title{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.event-meta{display:flex;flex-wrap:wrap;gap:12px;font-size:13px;color:var(--text-secondary)}.event-days{margin-left:auto;font-weight:600;color:var(--primary-color, #667eea)}.birthdays-list{display:flex;flex-direction:column;gap:12px}.birthday-item{display:flex;gap:16px;padding:16px;background:var(--bg-primary);border-radius:10px;border:1px solid var(--border-color, #e0e0e0);align-items:center}.birthday-avatar{width:50px;height:50px;border-radius:50%;background:var(--primary-color, #667eea);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:20px;overflow:hidden;flex-shrink:0}.birthday-avatar img{width:100%;height:100%;object-fit:cover}.birthday-info{flex:1}.birthday-name{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.birthday-date{font-size:14px;color:var(--text-secondary)}.birthday-today,.birthday-tomorrow{color:var(--primary-color, #667eea);font-weight:600}.wall-carousel{position:relative;margin-bottom:14px;border-radius:12px;overflow:hidden;cursor:pointer;border:1px solid var(--border-color, #e0e0e0);background:var(--bg-primary)}.wall-carousel-media-wrap{position:relative}.wall-carousel-media{width:100%;height:260px;object-fit:cover;display:block}.wall-carousel-overlay{position:absolute;left:0;right:0;bottom:0;padding:14px;background:linear-gradient(180deg,#0000,#000000b8);color:#fff}.wall-carousel-overlay h3{margin:0;font-size:16px;font-weight:600}.wall-carousel-overlay p{margin:4px 0 0;font-size:12px;opacity:.9}.wall-carousel-nav{position:absolute;top:50%;transform:translateY(-50%);width:34px;height:34px;border:none;border-radius:50%;background:#00000073;color:#fff;font-size:26px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.wall-carousel-nav.prev{left:10px}.wall-carousel-nav.next{right:10px}.wall-carousel-dots{position:absolute;bottom:10px;left:50%;transform:translate(-50%);display:flex;gap:6px}.wall-carousel-dot{width:8px;height:8px;border-radius:50%;border:none;background:#fff9;cursor:pointer;padding:0}.wall-carousel-dot.active{background:#fff}.walls-list{display:flex;flex-direction:column;gap:12px}.wall-item{padding:16px;background:var(--bg-primary);border-radius:10px;border:1px solid var(--border-color, #e0e0e0);cursor:pointer;transition:transform .2s,box-shadow .2s;position:relative}.wall-item:hover{transform:translate(4px);box-shadow:0 2px 8px #0000001a}.wall-type-badge{width:40px;height:40px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;font-size:20px;vertical-align:top;margin-right:16px}.wall-info{display:inline-block;vertical-align:top;max-width:calc(100% - 56px)}.wall-title{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:6px}.wall-meta{font-size:13px;color:var(--text-secondary)}.empty-state{padding:40px 20px;text-align:center;color:var(--text-secondary)}.empty-state p{margin:0;font-size:14px}.ranking-section{display:flex;flex-direction:column;gap:16px}.ranking-section-title{margin:0;font-size:1.25rem;font-weight:700;color:var(--text-primary)}.ranking-period-selector{display:flex;gap:6px;flex-wrap:nowrap}.ranking-period-btn{flex:1;min-width:0;padding:8px 6px;border:1px solid var(--border-color, rgba(255, 255, 255, .12));background:var(--bg-primary);color:var(--text-secondary);border-radius:20px;font-size:12px;font-weight:500;cursor:pointer;transition:background .2s,color .2s,border-color .2s;white-space:nowrap}.ranking-period-btn:hover{background:var(--bg-hover, rgba(0, 0, 0, .05));color:var(--text-primary)}.ranking-period-btn.active{background:var(--accent-color, #31708f);color:#fff;border-color:var(--accent-color, #31708f)}.ranking-empty{padding:32px 20px;text-align:center;background:var(--bg-primary);border-radius:12px;border:1px dashed var(--border-color, rgba(255, 255, 255, .12))}.ranking-empty p{margin:0;font-size:14px;color:var(--text-secondary)}.ranking-empty-hint{margin-top:8px!important;font-size:13px!important;opacity:.85}.ranking-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.ranking-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--bg-primary);border-radius:12px;border:1px solid var(--border-color, rgba(255, 255, 255, .08));transition:border-color .2s,box-shadow .2s}.ranking-item:hover{border-color:var(--border-color, rgba(255, 255, 255, .15));box-shadow:0 2px 8px var(--shadow)}.ranking-item.rank-1{border-left:4px solid #e6b800;background:linear-gradient(90deg,rgba(230,184,0,.08) 0%,transparent 100%)}.ranking-item.rank-2{border-left:4px solid #9ca3af;background:linear-gradient(90deg,rgba(156,163,175,.08) 0%,transparent 100%)}.ranking-item.rank-3{border-left:4px solid #b45309;background:linear-gradient(90deg,rgba(180,83,9,.08) 0%,transparent 100%)}.ranking-position-badge{flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:10px;font-size:1rem;font-weight:700;color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border-color, rgba(255, 255, 255, .08))}.ranking-item.rank-1 .ranking-position-badge{background:#e6b80033;border-color:#e6b80066}.ranking-item.rank-2 .ranking-position-badge{background:#9ca3af33;border-color:#9ca3af66}.ranking-item.rank-3 .ranking-position-badge{background:#b4530933;border-color:#b4530966}.ranking-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;flex-shrink:0;border:2px solid var(--border-color, rgba(255, 255, 255, .12))}.ranking-avatar img{width:100%;height:100%;object-fit:cover}.ranking-avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent-color, #31708f) 0%,#2a6080 100%);color:#fff;font-size:1rem;font-weight:700}.ranking-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.ranking-name{font-size:15px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ranking-stats-inline{font-size:12px;color:var(--text-secondary)}@media(max-width:768px){.dashboard-screen{padding:16px}.profile-completion-actions{flex-direction:column}.profile-completion-actions .btn{width:100%}.stats-grid{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:flex-start;gap:12px}.view-all-btn{align-self:flex-end}.event-item,.birthday-item,.wall-item{flex-direction:column;align-items:flex-start}.event-date-badge{align-self:flex-start}.wall-carousel-media{height:210px}}.achievements-grid-dashboard{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:16px}.achievement-card-dashboard{background:var(--bg-primary);border-radius:12px;padding:16px;text-align:center;border:2px solid var(--border-color, #e0e0e0);transition:transform .2s,box-shadow .2s;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:8px}.achievement-card-dashboard:hover{transform:translateY(-4px);box-shadow:0 6px 16px #00000026;border-color:var(--primary-color, #667eea)}.achievement-icon-dashboard{font-size:48px;line-height:1;margin-bottom:4px}.icon-large-dashboard{display:block;font-size:48px}.achievement-name-dashboard{font-size:13px;font-weight:600;color:var(--text-primary);margin:0;text-align:center;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.achievement-points-dashboard{font-size:11px;color:var(--primary-color, #667eea);font-weight:600;margin-top:auto}@media(max-width:768px){.achievements-grid-dashboard{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px}.achievement-card-dashboard{padding:12px}.achievement-icon-dashboard,.icon-large-dashboard{font-size:40px}.achievement-name-dashboard{font-size:12px}}.escalas-container{min-height:100vh;background-color:var(--bg-primary);padding:20px;max-width:800px;margin:0 auto;color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.escalas-header{margin-bottom:24px}.escalas-header h1{color:var(--accent-color);font-size:24px;margin:0}.escalas-access-denied{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center}.escalas-access-denied h2{font-size:22px;color:#d32f2f;margin-bottom:10px}.escalas-access-denied p{font-size:16px;color:var(--text-secondary)}.escalas-section{margin-bottom:28px}.escalas-section h2{font-size:18px;color:var(--text-primary);margin:0 0 12px}.escalas-filter{display:flex;align-items:center;gap:10px;margin-bottom:12px}.escalas-filter label{font-size:14px;font-weight:500;color:var(--text-secondary)}.escalas-filter select{padding:8px 12px;border:1px solid var(--border-color, #ddd);border-radius:8px;font-size:14px;min-width:160px;background:var(--bg-secondary);color:var(--text-primary)}.escalas-empty{color:var(--text-secondary);font-size:15px;margin:12px 0}.escalas-my-list,.escalas-month-list{list-style:none;padding:0;margin:0}.escalas-my-item{display:flex;flex-wrap:wrap;align-items:center;gap:8px 12px;background-color:var(--bg-secondary);padding:14px 16px;border-radius:10px;margin-bottom:10px;box-shadow:0 2px 4px var(--shadow);transition:background-color .3s ease,box-shadow .3s ease}.escalas-my-item-content{flex:1 1 auto;display:flex;flex-wrap:wrap;align-items:center;gap:8px 12px}.escalas-unvolunteer-my{margin-left:auto}.escalas-type-badge,.escalas-slot-type{padding:4px 10px;border-radius:6px;font-size:13px;font-weight:600;color:#fff}.escalas-date,.escalas-slot-date{font-weight:600;color:var(--text-primary)}.escalas-time,.escalas-slot-time{font-size:14px;color:var(--text-secondary)}.escalas-desc,.escalas-slot-desc{width:100%;font-size:13px;color:var(--text-secondary);margin:4px 0 0}.escalas-month-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding:8px 0}.escalas-month-nav button{background:var(--bg-secondary);border:1px solid var(--border-color, #ddd);color:var(--accent-color);width:40px;height:40px;border-radius:8px;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s,color .2s}.escalas-month-nav button:hover{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.escalas-month-label{font-weight:600;font-size:16px;color:var(--text-primary)}.escalas-month-item{background-color:var(--bg-secondary);padding:14px 16px;border-radius:10px;margin-bottom:10px;box-shadow:0 2px 4px var(--shadow);transition:background-color .3s ease,box-shadow .3s ease}.escalas-month-item-header{display:flex;flex-wrap:wrap;align-items:center;gap:8px 12px}.escalas-slot-assignments{display:flex;flex-wrap:wrap;gap:6px 10px;margin-top:8px;font-size:14px;color:var(--text-secondary)}.escalas-assignment-name{background:var(--bg-primary);padding:4px 8px;border-radius:6px}.escalas-no-assignment{font-style:italic;color:var(--text-secondary)}.escalas-volunteer-btn{margin-top:8px;padding:8px 14px;background:var(--accent-color);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .2s,transform .2s}.escalas-volunteer-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.escalas-volunteer-btn:disabled{opacity:.7;cursor:not-allowed}.escalas-unvolunteer-btn{margin-top:8px;padding:8px 14px;background:transparent;color:var(--text-secondary);border:1px solid var(--text-secondary, #999);border-radius:8px;font-size:13px;cursor:pointer;transition:opacity .2s,border-color .2s,color .2s}.escalas-unvolunteer-btn:hover:not(:disabled){border-color:#c0392b;color:#c0392b}.escalas-unvolunteer-btn:disabled{opacity:.7;cursor:not-allowed}@media(min-width:768px){.escalas-container{padding:40px}}.found-lost-add-container{min-height:100vh;background-color:var(--bg-primary);padding:20px;max-width:600px;margin:0 auto}.found-lost-add-content{background-color:var(--bg-secondary);border-radius:10px;padding:30px;box-shadow:0 2px 8px var(--shadow)}.found-lost-add-content h1{color:var(--accent-color);font-size:24px;margin:0 0 30px}.found-lost-add-form{display:flex;flex-direction:column;gap:20px}.photo-area{display:flex;flex-direction:column;gap:15px;align-items:center}.photo-add-button{padding:15px;background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:10px;text-align:center;cursor:pointer;transition:background-color .3s;width:100%}.dark-mode .found-lost-add-content .photo-add-button{background-color:#404040;color:#e0e0e0;border:1px solid #404040}.dark-mode .found-lost-add-content .photo-add-button:hover{background-color:#505050;color:#e0e0e0}.photo-preview{width:100%;max-width:300px;height:300px;object-fit:cover;border-radius:10px}.found-lost-add-label{font-size:16px;color:var(--text-primary);font-weight:500}.found-lost-add-input{width:100%;padding:15px;border-radius:10px;border:1px solid var(--border-color);background-color:var(--bg-tertiary);color:var(--text-primary);font-size:16px;box-sizing:border-box}.found-lost-add-input:focus{outline:none;border-color:var(--accent-color);background-color:var(--bg-secondary)}.found-lost-container{min-height:100vh;background-color:var(--bg-primary);padding:20px;max-width:1200px;margin:0 auto;color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.found-lost-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.found-lost-header h1{color:var(--accent-color);font-size:24px;margin:0}.no-items{display:flex;justify-content:center;align-items:center;min-height:300px}.no-items p{font-size:16px;color:var(--text-primary)}.section{margin-bottom:40px}.section-title{color:var(--accent-color);font-size:20px;margin:0 0 20px}.items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px}.lost-item{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:5px;padding:15px;display:flex;flex-direction:column;transition:background-color .3s ease,border-color .3s ease}.item-photo{width:100%;height:150px;object-fit:cover;border-radius:5px;margin-bottom:10px}.no-photo{width:100%;height:150px;background-color:var(--bg-tertiary);border-radius:5px;display:flex;flex-direction:column;align-items:center;justify-content:center;margin-bottom:10px;color:var(--text-tertiary);font-size:12px;transition:background-color .3s ease,color .3s ease}.item-title{font-size:15px;margin:10px 0;height:50px;overflow:hidden;text-overflow:ellipsis;color:var(--text-primary)}.item-info{font-size:12px;margin:5px 0;color:var(--text-primary)}.item-info strong{color:var(--text-secondary)}.mine-button{margin-top:10px;width:100%;padding:10px;font-size:14px}@media(min-width:768px){.found-lost-container{padding:40px}}.jellyfin-screen{padding:20px}.jellyfin-header h1{margin:0}.jellyfin-header p{margin:4px 0 16px;color:#9ca3af}.jellyfin-tabs{display:flex;gap:8px;margin-bottom:16px}.jellyfin-tabs button{border:0;border-radius:8px;padding:8px 12px;cursor:pointer;background:#1f2937;color:#e5e7eb}.jellyfin-tabs button.active{background:#2563eb;color:#fff}.jellyfin-error{color:#ef4444;margin-bottom:10px}.jellyfin-loading,.jellyfin-empty{color:#9ca3af}.jellyfin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:12px}.jellyfin-card{background:#111827;border:1px solid #1f2937;border-radius:10px;overflow:hidden}.jellyfin-cover{width:100%;height:260px;object-fit:cover;display:block}.jellyfin-cover.placeholder{background:#1f2937}.jellyfin-body{padding:10px}.jellyfin-body h3{margin:0 0 6px;font-size:14px;color:#f9fafb}.jellyfin-body p{margin:0 0 10px;font-size:12px;color:#9ca3af}.jellyfin-body button{border:0;border-radius:8px;padding:8px 12px;background:#2563eb;color:#fff;cursor:pointer}.login-container{min-height:100vh;background-color:#f5f5f5;display:flex;align-items:center;justify-content:center;padding:20px}.login-content{width:100%;max-width:400px;display:flex;flex-direction:column;align-items:center}.login-logo{margin-bottom:30px}.login-logo img{width:100%;max-width:250px;height:auto}.login-form{width:100%;display:flex;flex-direction:column;gap:15px}.login-input{width:100%;padding:15px;border-radius:10px;border:none;background-color:#e6e6e6;color:#464d70;font-size:16px;box-sizing:border-box}.login-input::placeholder{color:#777}.password-input{flex:1;padding-right:50px}.save-credentials{display:flex;align-items:center;gap:10px;align-self:flex-end;margin-top:-10px}.save-credentials input[type=checkbox]{width:20px;height:20px;cursor:pointer}.save-credentials label{font-size:16px;color:#464d70;cursor:pointer}.login-link{color:#31708f;font-size:16px;text-decoration:underline;text-align:center;margin-top:10px}.social-media-area{margin-top:40px;text-align:center}.social-media-text{font-size:16px;color:#464d70;margin-bottom:10px}.social-media-icons{display:flex;justify-content:center;gap:15px}.social-icon{background:none;border:none;cursor:pointer;padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:transform .2s,background-color .2s;width:44px;height:44px}.social-icon:hover{transform:scale(1.1)}.social-icon.facebook{color:#1877f2}.social-icon.facebook:hover{background-color:#1877f21a}.social-icon.instagram{color:#e4405f}.social-icon.instagram:hover{background-color:#e4405f1a}.social-icon.youtube{color:red}.social-icon.youtube:hover{background-color:#ff00001a}.social-icon svg{width:24px;height:24px}.address{margin-top:20px;text-align:center}.address p{font-size:10px;color:#464d70;margin:0}@media(min-width:768px){.login-content{max-width:450px}}.member-container{min-height:100vh;background-color:var(--bg-primary);padding:20px;max-width:600px;margin:0 auto}.member-content{background-color:var(--bg-secondary);border-radius:10px;padding:30px;box-shadow:0 2px 8px var(--shadow)}.status-section{margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid var(--border-color)}.member-label{font-size:16px;color:var(--text-primary);font-weight:500;margin-bottom:10px;display:block}.member-status{font-size:18px;font-weight:700;margin-bottom:10px}.status-approved{color:green}.dark-mode .status-approved{color:#4caf50}.status-pending{color:orange}.dark-mode .status-pending{color:#ff9800}.status-denied{color:red}.dark-mode .status-denied{color:#f44336}.info-text{font-size:14px;color:var(--text-secondary);margin-bottom:20px;text-align:center}.request-button{margin-top:10px}.member-form{display:flex;flex-direction:column;gap:20px}.member-input{width:100%;padding:15px;border-radius:10px;border:1px solid var(--border-color);background-color:var(--bg-tertiary);color:var(--text-primary);font-size:16px;box-sizing:border-box}.member-input:focus{outline:none;border-color:var(--accent-color);background-color:var(--bg-secondary)}.music-container{min-height:100vh;padding:1rem;background:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.music-header{margin-bottom:2rem}.header-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.header-buttons{display:flex;gap:.75rem;align-items:center}.playlist-manage-button{background:#6c757d;color:#fff;border:none;border-radius:20px;padding:.5rem 1rem;font-size:.9rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .2s;box-shadow:0 2px 4px #0000001a}.playlist-manage-button:hover{background:#5a6268;transform:translateY(-1px);box-shadow:0 4px 6px #00000026}.selected-playlist-info{margin-top:.5rem;margin-bottom:.5rem;padding:.75rem;background:#d1ecf1;border:1px solid #bee5eb;border-radius:8px;color:#0c5460;font-size:.9rem;display:flex;justify-content:space-between;align-items:center}.deselect-playlist-button{background:none;border:none;color:#0c5460;font-size:1.2rem;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:background .2s}.deselect-playlist-button:hover{background:#0000001a}.music-header h1{color:var(--accent-color);margin:0;font-size:1.5rem}.favorites-filter-button{background:#31708f;color:#fff;border:none;border-radius:20px;padding:.5rem 1rem;font-size:.9rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .2s;box-shadow:0 2px 4px #0000001a}.favorites-filter-button:hover{background:#2a5f7a;transform:translateY(-1px);box-shadow:0 4px 6px #00000026}.favorites-filter-button.active{background:#e91e63;animation:heartPulse 1s ease-in-out}.favorites-filter-button.active:hover{background:#c2185b}@keyframes heartPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.play-all-container{margin-top:1rem;display:flex;justify-content:center}.play-all-button{background:#28a745;color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .2s;box-shadow:0 2px 4px #0000001a}.play-all-button:hover{background:#218838;transform:translateY(-1px);box-shadow:0 4px 6px #00000026}.play-all-button:active{transform:translateY(0);box-shadow:0 2px 4px #0000001a}.favorites-filter-info{margin-top:.5rem;padding:.75rem;background:#fff3cd;border:1px solid #ffc107;border-radius:8px;color:#856404;font-size:.9rem;text-align:center}.search-container{display:flex;align-items:center;background:#fff;border-radius:8px;padding:.5rem 1rem;box-shadow:0 2px 4px #0000001a}.search-icon{margin-right:.5rem;font-size:1.2rem}.search-input{flex:1;border:none;outline:none;font-size:1rem;padding:.5rem}.music-content{display:flex;flex-direction:column;gap:2rem}.songs-list{background:var(--bg-secondary);border-radius:8px;padding:1rem;box-shadow:0 2px 4px var(--shadow);max-height:60vh;overflow-y:auto;transition:background-color .3s ease,box-shadow .3s ease}.song-item{display:flex;align-items:center;justify-content:space-between;padding:1rem;margin-bottom:.5rem;border-radius:8px;cursor:pointer;transition:background-color .2s,border-color .2s;border:2px solid transparent}.song-item:hover{background-color:var(--bg-tertiary)}.song-item.active{background-color:#31708f1a;border-color:var(--accent-color)}.dark-mode .song-item.active{background-color:#4a9dd433}.song-info{display:flex;flex-direction:column;flex:1}.song-actions{display:flex;align-items:center;gap:.5rem}.add-to-playlist-button{background:none;border:none;font-size:1.1rem;cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;transition:transform .2s;border-radius:4px}.add-to-playlist-button:hover{transform:scale(1.2)}.favorite-button{background:none;border:none;font-size:1.3rem;cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;transition:transform .2s;border-radius:4px}.favorite-button:hover{transform:scale(1.2)}.favorite-button.favorited{animation:heartBeat .6s ease-in-out}@keyframes heartBeat{0%,to{transform:scale(1)}25%{transform:scale(1.3)}50%{transform:scale(1.1)}75%{transform:scale(1.2)}}.song-title{font-weight:600;color:#464d70;margin-bottom:.25rem}.song-artist{font-size:.9rem;color:#666}.playing-indicator{font-size:1.2rem;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.music-player{position:sticky;bottom:0;background:var(--bg-secondary);border-radius:12px;padding:1.5rem;box-shadow:0 -2px 10px var(--shadow);z-index:10;transition:background-color .3s ease,box-shadow .3s ease}.player-info{text-align:center;margin-bottom:1rem}.player-title-row{display:flex;align-items:center;justify-content:center;gap:.5rem}.player-favorite{font-size:1.2rem}.player-title{color:#31708f;font-size:1.2rem;margin-bottom:.25rem}.player-artist{color:#666;font-size:.9rem}.player-controls{display:flex;justify-content:center;align-items:center;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.player-button{background:var(--accent-color);color:#fff;border:none;border-radius:50%;width:50px;height:50px;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.player-button:hover:not(:disabled){background:var(--accent-hover)}.player-button:disabled{opacity:.5;cursor:not-allowed}.play-button{width:60px;height:60px;font-size:1.5rem}.repeat-button,.shuffle-button{width:45px;height:45px;font-size:1.1rem;opacity:.7;transition:opacity .2s,background-color .2s}.repeat-button:hover,.shuffle-button:hover{opacity:1}.repeat-button.active,.shuffle-button.active{opacity:1;background:var(--accent-hover);box-shadow:0 0 8px #31708f66}.player-progress{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.time-display{font-size:.9rem;color:#666;min-width:45px;text-align:center}.progress-bar{flex:1;height:6px;background:#e0e0e0;border-radius:3px;cursor:pointer;position:relative}.progress-fill{height:100%;background:#31708f;border-radius:3px;transition:width .1s}.player-volume{display:flex;align-items:center;gap:.5rem;justify-content:center}.volume-icon{font-size:1.2rem}.volume-slider{flex:1;max-width:200px;height:4px;background:#e0e0e0;border-radius:2px;outline:none;-webkit-appearance:none}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:#31708f;border-radius:50%;cursor:pointer}.volume-slider::-moz-range-thumb{width:16px;height:16px;background:#31708f;border-radius:50%;cursor:pointer;border:none}.volume-value{font-size:.9rem;color:#666;min-width:40px;text-align:right}.music-loading{display:flex;justify-content:center;align-items:center;min-height:50vh}.music-loading p{color:#666;font-size:1.1rem}.no-songs{text-align:center;padding:3rem 1rem;color:#666}.no-songs p{margin-bottom:1rem}.help-text{font-size:.9rem;color:#999}.help-text code{background:#f0f0f0;padding:.2rem .4rem;border-radius:4px;font-family:monospace}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:var(--bg-secondary);border-radius:12px;padding:2rem;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 4px 20px var(--shadow);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-header h2{margin:0;color:var(--accent-color)}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary);padding:.25rem .5rem;border-radius:4px;transition:background .2s}.modal-close:hover{background:var(--bg-tertiary)}.modal-body{display:flex;flex-direction:column;gap:1.5rem}.create-playlist-button{background:#28a745;color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.create-playlist-button:hover{background:#218838}.playlist-form{display:flex;flex-direction:column;gap:1rem;padding:1rem;background:var(--bg-tertiary);border-radius:8px;transition:background-color .3s ease}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:var(--accent-color)}.form-group input,.form-group textarea{padding:.75rem;border:1px solid var(--border-color);border-radius:4px;font-size:1rem;font-family:inherit;background:var(--bg-secondary);color:var(--text-primary);transition:border-color .2s,background-color .3s ease,color .3s ease}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-color)}.form-actions{display:flex;gap:.75rem;justify-content:flex-end}.submit-button{background:var(--accent-color);color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.submit-button:hover{background:var(--accent-hover)}.cancel-button{background:#6c757d;color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.cancel-button:hover{background:#5a6268}.playlists-list h3{color:var(--accent-color);margin-bottom:1rem}.empty-message{color:var(--text-secondary);text-align:center;padding:2rem;font-style:italic}.playlist-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;margin-bottom:.75rem;border:2px solid var(--border-color);border-radius:8px;transition:all .2s}.playlist-item:hover{border-color:var(--accent-color);background:var(--bg-tertiary)}.playlist-item.selected{border-color:#28a745;background:#28a74533}.dark-mode .playlist-item.selected{background:#28a7454d}.playlist-info{flex:1}.playlist-name{font-weight:600;color:#464d70;margin-bottom:.25rem}.playlist-description{font-size:.9rem;color:#666;margin-bottom:.25rem}.playlist-meta{font-size:.85rem;color:#999}.playlist-actions{display:flex;gap:.5rem}.playlist-action-button{background:var(--accent-color);color:#fff;border:none;border-radius:6px;padding:.5rem .75rem;font-size:.85rem;cursor:pointer;transition:background .2s}.playlist-action-button:hover{background:var(--accent-hover)}.playlist-action-button.play-button{background:#28a745}.playlist-action-button.play-button:hover{background:#218838}.playlist-action-button.delete-button{background:#dc3545}.playlist-action-button.delete-button:hover{background:#c82333}.playlist-song-menu{background:var(--bg-secondary);border-radius:8px;box-shadow:0 4px 12px var(--shadow);padding:.5rem 0;min-width:200px;max-width:300px;max-height:300px;overflow-y:auto;transition:background-color .3s ease,box-shadow .3s ease}.menu-header{padding:.5rem 1rem;font-weight:600;color:var(--accent-color);border-bottom:1px solid var(--border-color);margin-bottom:.25rem}.menu-empty{padding:1rem;color:var(--text-secondary);text-align:center;font-style:italic}.menu-item{width:100%;padding:.75rem 1rem;background:none;border:none;text-align:left;cursor:pointer;transition:background .2s;font-size:.9rem;color:#464d70}.menu-item:hover{background:#f0f0f0}.confirm-dialog{background:var(--bg-secondary);border-radius:12px;padding:2rem;max-width:450px;width:90%;box-shadow:0 4px 20px var(--shadow);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.confirm-dialog-header{margin-bottom:1.5rem}.confirm-dialog-header h3{margin:0;color:var(--accent-color);font-size:1.3rem}.confirm-dialog-body{margin-bottom:1.5rem}.confirm-dialog-body p{margin:0;color:var(--text-primary);font-size:1rem;line-height:1.5}.confirm-dialog-actions{display:flex;gap:.75rem;justify-content:flex-end}.confirm-button{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.confirm-button.confirm-cancel{background:#6c757d;color:#fff}.confirm-button.confirm-cancel:hover{background:#5a6268}.confirm-button.confirm-ok{background:#dc3545;color:#fff}.confirm-button.confirm-ok:hover{background:#c82333}@media(max-width:768px){.music-container{padding:.5rem}.music-header h1{font-size:1.3rem}.songs-list{max-height:50vh}.music-player{padding:1rem}.player-controls{gap:.5rem}.player-button{width:45px;height:45px}.play-button{width:55px;height:55px}.header-buttons{flex-direction:column;gap:.5rem}.playlist-item{flex-direction:column;align-items:flex-start}.playlist-actions{width:100%;margin-top:.75rem;justify-content:flex-start}.modal-content{padding:1rem;width:95%}}.personal-container{min-height:100vh;background-color:var(--bg-primary);padding:20px;max-width:600px;margin:0 auto}.personal-content{background-color:var(--bg-secondary);border-radius:10px;padding:30px;box-shadow:0 2px 8px var(--shadow)}.message{padding:15px;border-radius:10px;margin-bottom:20px;text-align:center}.message.success{background-color:#d4edda;color:#155724}.dark-mode .message.success{background-color:#00b47c33;color:#00b67c}.message.error{background-color:#f8d7da;color:#721c24}.dark-mode .message.error{background-color:#f4433633;color:#f44336}.personal-form{display:flex;flex-direction:column;gap:20px}.personal-label{font-size:16px;color:var(--text-primary);font-weight:500}.personal-input,.personal-select{width:100%;padding:15px;border-radius:10px;border:1px solid var(--border-color);background-color:var(--bg-tertiary);color:var(--text-primary);font-size:16px;box-sizing:border-box}.personal-input:focus,.personal-select:focus{outline:none;border-color:var(--accent-color);background-color:var(--bg-secondary)}.personal-select option{background-color:var(--bg-secondary);color:var(--text-primary)}.prayer-container{min-height:100vh;background-color:var(--bg-primary);padding:20px;max-width:800px;margin:0 auto;color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.prayer-header{margin-bottom:20px}.prayer-header h1{color:var(--accent-color);font-size:24px;margin:0}.prayer-list{display:flex;flex-direction:column;gap:15px;margin-bottom:30px}.no-prayers{display:flex;justify-content:center;align-items:center;min-height:200px}.no-prayers p{font-size:16px;color:var(--text-secondary)}.prayer-item{background-color:var(--bg-secondary);padding:15px;border-radius:10px;box-shadow:0 2px 4px var(--shadow);position:relative;transition:background-color .3s ease,box-shadow .3s ease}.prayer-content{margin-bottom:15px}.prayer-author{font-size:14px;font-weight:700;color:var(--text-primary);margin:0 0 5px}.prayer-description{font-size:14px;color:var(--text-secondary);margin:5px 0}.prayer-visibility{font-size:12px;color:var(--text-tertiary);margin:5px 0 0}.prayer-actions{display:flex;justify-content:space-between;align-items:center;padding-top:10px;border-top:1px solid var(--border-color)}.delete-button{background:none;border:none;cursor:pointer;font-size:20px;padding:5px;color:var(--text-secondary);transition:color .2s}.delete-button:hover{color:var(--text-primary)}.like-button{background:none;border:none;cursor:pointer;font-size:14px;color:var(--accent-color);display:flex;align-items:center;gap:5px;transition:transform .2s,background-color .2s;padding:5px 10px;border-radius:5px}.like-button:hover{background-color:var(--bg-tertiary);transform:scale(1.05)}.like-button.liked{color:#e91e63;font-weight:700}.prayer-form{background-color:var(--bg-secondary);padding:20px;border-radius:10px;box-shadow:0 2px 4px var(--shadow);transition:background-color .3s ease,box-shadow .3s ease}.prayer-input{width:100%;padding:15px;border:1px solid var(--border-color);border-radius:5px;margin-bottom:15px;font-size:16px;font-family:inherit;resize:vertical;box-sizing:border-box;background-color:var(--bg-tertiary);color:var(--text-primary);transition:border-color .2s,background-color .3s ease,color .3s ease}.prayer-input:focus{outline:none;border-color:var(--accent-color);background-color:var(--bg-secondary)}.prayer-select-container{margin-bottom:15px}.prayer-select-label{display:block;font-size:14px;color:var(--text-secondary);margin-bottom:5px}.prayer-select{width:100%;padding:10px;border:1px solid var(--border-color);border-radius:5px;font-size:16px;background-color:var(--bg-secondary);color:var(--text-primary);box-sizing:border-box;transition:border-color .2s,background-color .3s ease,color .3s ease}.prayer-select:focus{outline:none;border-color:var(--accent-color)}@media(min-width:768px){.prayer-container{padding:40px}}.profile-container{min-height:100vh;background-color:var(--bg-primary);padding:20px;max-width:600px;margin:0 auto;color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.profile-content{background-color:var(--bg-secondary);border-radius:10px;padding:30px;box-shadow:0 2px 8px var(--shadow);transition:background-color .3s ease,box-shadow .3s ease}.success-message{background-color:#d4edda;color:#155724;padding:15px;border-radius:10px;margin-bottom:20px;text-align:center}.profile-photo-section{display:flex;flex-direction:column;align-items:center;margin-bottom:30px}.photo-label{cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:10px}.profile-photo{width:100px;height:100px;border-radius:50%;object-fit:cover;border:3px solid #31708f}.photo-edit-text{font-size:14px;color:#31708f;text-decoration:underline}.profile-form{display:flex;flex-direction:column;gap:15px}.profile-input{width:100%;padding:15px;border-radius:10px;border:1px solid var(--border-color);background-color:var(--bg-tertiary);color:var(--text-primary);font-size:16px;box-sizing:border-box;transition:border-color .2s,background-color .3s ease,color .3s ease}.profile-input:focus{outline:none;border-color:var(--accent-color);background-color:var(--bg-secondary)}.btn-secondary{background-color:#8a8a8a;color:#fff}.btn-secondary:hover{opacity:.9}.recover-container{min-height:100vh;background-color:#f5f5f5;display:flex;align-items:center;justify-content:center;padding:20px}.recover-content{width:100%;max-width:400px;display:flex;flex-direction:column;align-items:center}.recover-logo{margin-bottom:30px}.recover-logo img{width:100%;max-width:250px;height:auto}.recover-form{width:100%;display:flex;flex-direction:column;gap:15px}.recover-input{width:100%;padding:15px;border-radius:10px;border:none;background-color:#e6e6e6;color:#464d70;font-size:16px;box-sizing:border-box}.recover-input::placeholder{color:#777}.recover-input:disabled{opacity:.6;cursor:not-allowed}.recover-link{color:#31708f;font-size:16px;text-decoration:underline;text-align:center;margin-top:10px}.register-container{min-height:100vh;background-color:#f5f5f5;display:flex;align-items:center;justify-content:center;padding:20px}.register-content{width:100%;max-width:400px;background-color:#fff;border-radius:10px;padding:30px 20px;box-shadow:0 2px 8px #0000001a}.register-title{color:#31708f;font-size:24px;margin:0 0 30px;text-align:center}.register-form{display:flex;flex-direction:column;gap:15px}.register-input{width:100%;padding:15px;border-radius:10px;border:1px solid #e0e0e0;background-color:#f9f9f9;color:#464d70;font-size:16px;box-sizing:border-box}.register-input:focus{outline:none;border-color:#31708f;background-color:#fff}.password-container{position:relative;display:flex;align-items:center;background-color:#f9f9f9;border-radius:10px;border:1px solid #e0e0e0}.password-container:focus-within{border-color:#31708f;background-color:#fff}.password-input:focus{outline:none}.btn-primary{background-color:#31708f;color:#fff;font-weight:700;margin-top:10px}.register-link{color:#31708f;font-size:14px;text-decoration:underline;text-align:center;margin-top:10px}@media(min-width:768px){.register-content{padding:40px}}.settings-container{min-height:100vh;background-color:var(--bg-primary);padding:20px;max-width:600px;margin:0 auto;color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.settings-loading{text-align:center;padding:40px;color:var(--text-secondary)}.settings-title{font-size:1.5rem;margin-bottom:24px;color:var(--text-primary)}.settings-section{background-color:var(--bg-secondary);border-radius:12px;padding:20px;margin-bottom:24px;box-shadow:0 2px 8px var(--shadow);transition:background-color .3s ease,box-shadow .3s ease}.settings-section-title{font-size:1.1rem;margin-bottom:8px;color:var(--text-primary)}.settings-section-desc{font-size:.9rem;color:var(--text-secondary);margin-bottom:16px;line-height:1.4}.settings-list{display:flex;flex-direction:column;gap:4px}.settings-theme-btn{display:flex;align-items:center;gap:12px;width:100%;padding:14px 12px;border-radius:8px;background-color:var(--bg-primary);border:1px solid var(--shadow, rgba(0, 0, 0, .1));color:var(--text-primary);font-size:1rem;cursor:pointer;transition:background-color .2s ease,transform .1s ease;text-align:left}.settings-theme-btn:hover{background-color:var(--bg-hover, rgba(0, 0, 0, .05))}.settings-theme-btn:active{transform:scale(.98)}.settings-theme-label{flex:1;font-weight:500}.settings-theme-hint{font-size:.85rem;color:var(--text-secondary)}.settings-font-size-options{display:flex;gap:8px;margin-top:8px;flex-wrap:wrap}.settings-font-size-btn{flex:1;min-width:90px;padding:12px 16px;border-radius:8px;border:2px solid var(--border-color);background-color:var(--bg-primary);color:var(--text-primary);font-size:1rem;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:2px;transition:all .2s ease}.settings-font-size-btn:hover{border-color:var(--accent-color);background-color:var(--bg-secondary)}.settings-font-size-btn.active{border-color:var(--accent-color);background-color:var(--accent-color);color:#fff}.settings-font-size-label{font-weight:500}.settings-font-size-hint{font-size:.8rem;opacity:.85}.settings-font-size-btn.active .settings-font-size-hint{opacity:.95}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:14px 12px;border-radius:8px;background-color:var(--bg-primary);cursor:pointer;transition:background-color .2s ease}.settings-row:hover{background-color:var(--bg-hover, rgba(0, 0, 0, .05))}.settings-row-label{display:flex;align-items:center;gap:10px;font-size:1rem;color:var(--text-primary)}.settings-row-icon{font-size:1.2rem}.settings-checkbox{width:22px;height:22px;accent-color:#31708f;cursor:pointer}.settings-hint{font-size:.8rem;color:var(--text-secondary);margin-top:12px;padding-left:4px}.settings-install-actions{display:flex;flex-direction:column;gap:10px;margin-top:8px}.settings-install-btn{padding:12px 16px;font-size:.95rem;font-weight:500;border:none;border-radius:8px;cursor:pointer;transition:opacity .2s ease,background-color .2s ease}.settings-install-btn:disabled{opacity:.7;cursor:not-allowed}.settings-install-btn-primary{background:linear-gradient(135deg,#31708f,#2a6080);color:#fff}.settings-install-btn-primary:hover:not(:disabled){opacity:.95}.settings-install-btn-secondary{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color)}.settings-install-btn-secondary:hover{background:var(--bg-hover, rgba(0, 0, 0, .05))}.settings-save-btn{width:100%;padding:14px 20px;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#31708f,#2a6080);border:none;border-radius:10px;cursor:pointer;transition:opacity .2s ease,transform .1s ease}.settings-save-btn:hover:not(:disabled){opacity:.95}.settings-save-btn:active:not(:disabled){transform:scale(.98)}.settings-save-btn:disabled{opacity:.7;cursor:not-allowed}.sg-detail-app{min-height:100vh;background-color:var(--bg-primary);padding:20px;max-width:800px;margin:0 auto;color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.sg-detail-header{margin-bottom:24px}.sg-back{background:none;border:none;color:var(--accent-color);font-size:14px;cursor:pointer;padding:0 0 12px;margin:0}.sg-back:hover{text-decoration:underline}.sg-detail-header h1{color:var(--accent-color);font-size:24px;margin:0}.sg-detail-banner-wrap{width:100%;margin-bottom:16px;position:relative;border-radius:12px;overflow:hidden;border:1px solid var(--border-color)}.sg-detail-banner{width:100%;height:160px;object-fit:cover;display:block}.sg-detail-banner-actions{position:absolute;bottom:10px;right:10px;display:flex;gap:8px;background:#00000080;padding:8px;border-radius:8px}.sg-detail-banner-actions .sg-btn-small{padding:6px 12px;font-size:12px}.sg-detail-banner-empty{background:var(--bg-secondary);border:1px dashed var(--border-color);border-radius:12px;padding:20px;margin-bottom:16px;text-align:center}.sg-detail-banner-empty p{margin:0 0 10px;font-size:14px;color:var(--text-secondary)}.sg-detail-title-row{display:flex;align-items:flex-start;gap:16px;flex-wrap:wrap}.sg-detail-logo-wrap{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:10px}.sg-detail-logo{width:80px;height:80px;object-fit:cover;border-radius:12px;border:1px solid var(--border-color)}.sg-detail-logo-placeholder{width:80px;height:80px;border-radius:12px;border:1px dashed var(--border-color);background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--text-secondary)}.sg-detail-logo-actions{display:flex;flex-direction:column;align-items:center}.sg-btn-small{padding:6px 12px;font-size:13px}.sg-detail-info{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:20px;margin-bottom:24px}.sg-detail-desc{margin:0 0 16px;font-size:15px;line-height:1.5;color:var(--text-secondary)}.sg-detail-meta{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px;font-size:14px;color:var(--text-secondary)}.sg-detail-meta span{background:#667eea1f;padding:6px 10px;border-radius:8px;color:var(--accent-color)}.sg-detail-info p{margin:0 0 8px;font-size:14px;color:var(--text-secondary)}.sg-request-section,.sg-pending-section,.sg-checkin-section,.sg-feed-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:20px;margin-bottom:24px}.sg-request-section h3,.sg-checkin-section h3,.sg-feed-section h3{margin:0 0 12px;font-size:18px;color:var(--accent-color)}.sg-request-msg,.sg-post-input{width:100%;padding:12px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;font-family:inherit;resize:vertical;margin-bottom:12px}.sg-pending-section p{margin:0 0 12px;color:var(--text-secondary)}.sg-checkin-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.sg-checkin-date{padding:10px 12px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-size:14px}.sg-post-form{margin-bottom:20px}.sg-btn{padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;border:none;transition:opacity .2s}.sg-btn:disabled{opacity:.6;cursor:not-allowed}.sg-btn-primary{background:var(--accent-color);color:#fff}.sg-btn-primary:hover:not(:disabled){filter:brightness(1.1)}.sg-btn-secondary{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color)}.sg-btn-secondary:hover:not(:disabled){background:var(--border-color)}.sg-feed-loading,.sg-feed-empty{margin:0;color:var(--text-secondary);font-size:14px}.sg-feed-list{list-style:none;margin:0;padding:0}.sg-feed-item{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:10px;padding:16px;margin-bottom:12px}.sg-feed-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.sg-feed-header strong{font-size:14px;color:var(--text-primary)}.sg-feed-header-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.sg-feed-date{font-size:12px;color:var(--text-secondary)}.sg-feed-remove{padding:4px 10px;font-size:12px;font-weight:500;color:var(--text-secondary);background:transparent;border:1px solid var(--border-color);border-radius:6px;cursor:pointer;transition:color .2s,border-color .2s,background .2s}.sg-feed-remove:hover:not(:disabled){color:#dc2626;border-color:#dc2626;background:#dc26260f}.sg-feed-remove:disabled{opacity:.6;cursor:not-allowed}.sg-feed-content{margin:0;font-size:14px;line-height:1.5;color:var(--text-primary);white-space:pre-wrap;word-break:break-word}.sg-leader-edit-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:20px;margin-bottom:24px}.sg-leader-edit-section h3{margin:0 0 16px;font-size:18px;color:var(--accent-color)}.sg-data-media{display:flex;flex-wrap:wrap;gap:24px;margin-bottom:20px}.sg-data-media-block{display:flex;flex-direction:column;gap:8px}.sg-data-media-label{font-size:14px;font-weight:500;color:var(--text-secondary)}.sg-data-media-preview{width:80px;height:80px;border-radius:10px;overflow:hidden;border:1px solid var(--border-color);background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center}.sg-data-media-preview-banner{width:160px;height:60px}.sg-data-media-img{width:100%;height:100%;object-fit:cover}.sg-data-media-placeholder{font-size:12px;color:var(--text-tertiary)}.sg-data-media-actions{display:flex;flex-wrap:wrap;gap:8px}.sg-edit-form{display:flex;flex-direction:column;gap:12px}.sg-edit-label{font-size:14px;font-weight:500;color:var(--text-primary)}.sg-edit-input{width:100%;padding:12px;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-primary);font-size:16px;font-family:inherit;box-sizing:border-box}.sg-edit-input:focus{outline:none;border-color:var(--accent-color)}.sg-edit-textarea{resize:vertical;min-height:80px}.sg-edit-actions{display:flex;gap:12px;margin-top:8px}.sg-edit-actions .sg-btn{flex:1}.sg-leader-requests-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:20px;margin-bottom:24px}.sg-leader-requests-section h3{margin:0 0 8px;font-size:18px;color:var(--accent-color)}.sg-leader-hint{margin:0 0 16px;font-size:14px;color:var(--text-secondary);line-height:1.4}.sg-requests-list{list-style:none;margin:0;padding:0}.sg-request-item{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:12px;padding:14px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:10px;margin-bottom:10px}.sg-request-item strong{display:block;font-size:14px;color:var(--text-primary);margin-bottom:2px}.sg-request-list-msg{margin:6px 0 4px;font-size:13px;color:var(--text-secondary);line-height:1.4;white-space:pre-wrap}.sg-request-date{font-size:12px;color:var(--text-secondary)}.sg-request-actions{display:flex;gap:8px;flex-shrink:0}.sg-btn-approve{background:#059669;color:#fff}.sg-btn-approve:hover:not(:disabled){filter:brightness(1.1)}.sg-btn-reject{background:#dc2626;color:#fff}.sg-btn-reject:hover:not(:disabled){filter:brightness(1.1)}.sg-leave-section{margin-top:24px;padding-top:20px;border-top:1px solid var(--border-color)}.sg-btn-leave{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color)}.sg-btn-leave:hover:not(:disabled){background:#dc262614;color:#dc2626;border-color:#dc2626}.small-groups-app{min-height:100vh;background-color:var(--bg-primary);padding:20px;max-width:1200px;margin:0 auto;color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.sg-app-header{margin-bottom:24px}.sg-app-header h1{color:var(--accent-color);font-size:24px;margin:0}.sg-tabs{display:flex;gap:8px;margin-bottom:20px}.sg-tab{padding:10px 20px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.sg-tab:hover{border-color:var(--accent-color);color:var(--accent-color)}.sg-tab.active{background:var(--accent-color);border-color:var(--accent-color);color:#fff}.sg-filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.sg-filters select{padding:8px 12px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:14px;min-width:140px}.sg-empty{text-align:center;padding:60px 20px;color:var(--text-secondary);font-size:16px}.sg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.sg-card-hero{position:relative;margin:-16px -16px 12px;height:100px;border-radius:12px 12px 0 0;overflow:visible;background:var(--bg-secondary)}.sg-card-hero-banner{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;border-radius:12px 12px 0 0}.sg-card-hero-logo{position:absolute;bottom:0;left:20px;z-index:2;transform:translateY(50%);display:flex;align-items:center;justify-content:center}.sg-card-hero-logo-img{width:64px;height:64px;object-fit:cover;border-radius:12px;border:3px solid var(--bg-secondary);box-shadow:0 2px 12px #00000040}.sg-card:has(.sg-card-hero-logo) .sg-card-name{margin-left:92px;min-height:1.2em}.sg-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:20px;cursor:pointer;transition:transform .2s,box-shadow .2s}.sg-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.sg-card-name{margin:0 0 12px;font-size:18px;color:var(--accent-color)}.sg-card-meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px;font-size:13px;color:var(--text-secondary)}.sg-card-meta span{background:#667eea26;padding:4px 8px;border-radius:6px;color:var(--accent-color)}.sg-card-leader,.sg-card-members{margin:0 0 4px;font-size:14px;color:var(--text-secondary)}.sg-card-desc{margin:12px 0 0;font-size:13px;color:var(--text-secondary);line-height:1.4}.statistics-container{min-height:100vh;background-color:var(--bg-primary);padding:20px;max-width:1200px;margin:0 auto;color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.statistics-tabs-header{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid var(--border-color)}.statistics-tab{padding:.75rem 1.5rem;background:transparent;border:none;color:var(--text-secondary);font-size:1rem;font-weight:500;cursor:pointer;border-bottom:3px solid transparent;transition:all .2s;white-space:nowrap}.statistics-tab:hover{color:var(--text-primary);background:var(--bg-tertiary)}.statistics-tab.active{color:var(--accent-color);border-bottom-color:var(--accent-color)}.challenges-section{animation:fadeIn .3s ease-in}.challenges-stats-header{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.challenge-stat-item{display:flex;flex-direction:column;align-items:center;padding:1rem 1.5rem;background:var(--bg-secondary);border-radius:12px;min-width:100px;flex:1}.challenge-stat-value{font-size:1.5rem;font-weight:700;color:var(--accent-color);margin-bottom:.25rem}.challenge-stat-label{font-size:.85rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.challenges-filters-container{margin-bottom:1.5rem;display:flex;flex-direction:column;gap:1rem}.challenges-subtabs{display:flex;gap:.5rem}.challenges-type-filters{display:flex;gap:.5rem;flex-wrap:wrap}.challenge-subtab{padding:.5rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);font-size:.9rem;cursor:pointer;transition:all .2s}.challenge-subtab:hover{background:var(--bg-tertiary);color:var(--text-primary)}.challenge-subtab.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.challenge-type-filter{padding:.5rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);font-size:.9rem;cursor:pointer;transition:all .2s;white-space:nowrap}.challenge-type-filter:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--accent-color)}.challenge-type-filter.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color);font-weight:600}.challenges-grid-compact{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.challenge-card-compact{background:var(--bg-secondary);border-radius:12px;padding:1.25rem;border:1px solid var(--border-color);transition:all .2s;display:flex;flex-direction:column;gap:.75rem}.challenge-card-compact:hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow);border-color:var(--accent-color)}.challenge-card-compact.active{border-left:4px solid var(--accent-color)}.challenge-header-compact{display:flex;align-items:center;gap:.5rem;justify-content:space-between}.challenge-icon-compact{font-size:1.1rem}.challenge-type-label-compact{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.challenge-badge-compact{font-size:1.25rem}.completed-badge-compact{background:#10b981;color:#fff;padding:.2rem .6rem;border-radius:12px;font-size:.7rem;font-weight:600}.progress-badge-compact{background:var(--accent-color);color:#fff;padding:.2rem .6rem;border-radius:12px;font-size:.7rem;font-weight:600}.challenge-title-compact{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0}.challenge-description-compact{color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin:0}.challenge-targets-compact{display:flex;flex-wrap:wrap;gap:.5rem;font-size:.85rem;color:var(--text-secondary)}.challenge-points-compact{color:var(--accent-color);font-weight:600;font-size:.9rem}.challenge-button-compact{padding:.6rem 1.25rem;background:var(--accent-color);color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;margin-top:.5rem;width:100%}.challenge-button-compact:hover:not(:disabled){background:var(--accent-hover);transform:scale(1.02)}.challenge-button-compact:disabled{cursor:not-allowed;opacity:.6}.challenge-button-compact.accepted{background:#10b981;cursor:default}.challenge-button-compact.unavailable{background:#6b7280;cursor:not-allowed}.challenge-completed-badge-compact{display:inline-block;padding:.25rem .75rem;background:#10b981;color:#fff;border-radius:12px;font-size:.75rem;font-weight:600;margin-top:.5rem}.challenge-unavailable-compact{margin-top:.5rem}.challenge-next-available-compact{margin-top:.5rem;font-size:.8rem;color:var(--text-secondary);text-align:center;font-style:italic}.challenge-card-compact:has(.challenge-button-compact.unavailable){opacity:.7;background:var(--bg-tertiary)}.challenge-card-compact.challenge-disabled{opacity:.8;border-left-color:var(--border-color)}.challenge-progress-compact{margin-top:.5rem}.progress-header-compact{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.85rem;color:var(--text-secondary)}.progress-percentage-compact{font-weight:700;color:var(--accent-color)}.progress-bar-compact{width:100%;height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden;margin-bottom:.5rem}.progress-fill-compact{height:100%;background:linear-gradient(90deg,var(--accent-color),var(--accent-hover));border-radius:3px;transition:width .3s ease}.progress-details-compact{display:flex;flex-direction:column;gap:.2rem;font-size:.8rem;color:var(--text-secondary)}.achievements-section{animation:fadeIn .3s ease-in}.achievements-stats-header{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem;margin-bottom:1.5rem}.achievement-stat-item{background:var(--bg-secondary);border-radius:12px;padding:1rem;text-align:center;border:1px solid var(--border-color)}.achievement-stat-value{font-size:1.5rem;font-weight:700;color:var(--accent-color);margin-bottom:.5rem;display:block}.achievement-stat-label{font-size:.85rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.achievements-grid-compact{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.achievement-card-compact{background:var(--bg-secondary);border-radius:12px;padding:1.25rem;border:1px solid var(--border-color);transition:all .2s;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.5rem}.achievement-card-compact:hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow)}.achievement-card-compact.unlocked{border-color:var(--accent-color);background:linear-gradient(135deg,var(--bg-secondary) 0%,rgba(var(--accent-color-rgb),.1) 100%)}.achievement-card-compact.locked{opacity:.7}.achievement-icon-compact{margin-bottom:.25rem}.icon-large-compact{font-size:2.5rem;display:block}.locked-icon-compact{filter:grayscale(100%);opacity:.5}.achievement-name-compact{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0}.achievement-description-compact{color:var(--text-secondary);font-size:.85rem;line-height:1.4;margin:0}.achievement-condition-compact{font-size:.8rem;color:var(--text-secondary);padding:.4rem .8rem;background:var(--bg-tertiary);border-radius:8px}.achievement-points-compact{color:var(--accent-color);font-weight:600;font-size:.85rem}.achievement-unlocked-date-compact{font-size:.75rem;color:#10b981;font-weight:500;margin-top:.25rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.statistics-tabs-header{gap:.25rem}.statistics-tab{padding:.5rem 1rem;font-size:.9rem}.challenges-grid-compact,.achievements-grid-compact{grid-template-columns:1fr}.challenges-stats-header{gap:.75rem}.challenge-stat-item{padding:.75rem 1rem;min-width:80px}.achievements-stats-header{grid-template-columns:repeat(2,1fr)}}.statistics-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;flex-wrap:wrap;gap:15px}.statistics-header h1{color:var(--accent-color);font-size:24px;margin:0}.statistics-filters{display:flex;align-items:center;gap:15px;flex-wrap:wrap}.period-selector,.version-selector{display:flex;align-items:center;gap:10px}.version-select{padding:8px 12px;border:1px solid var(--border-color);border-radius:8px;background-color:var(--bg-secondary);color:var(--text-primary);font-size:14px;cursor:pointer;transition:border-color .2s,background-color .3s ease}.version-select:focus{outline:none;border-color:var(--accent-color)}.period-selector label{color:var(--text-secondary);font-size:14px}.period-select{padding:8px 12px;border:1px solid var(--border-color);border-radius:8px;background-color:var(--bg-secondary);color:var(--text-primary);font-size:14px;cursor:pointer;transition:border-color .2s,background-color .3s ease}.period-select:focus{outline:none;border-color:var(--accent-color)}.statistics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:30px}.progress-card,.progress-item{margin-bottom:20px}.progress-item:last-child{margin-bottom:0}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.progress-label{color:var(--text-primary);font-size:14px;font-weight:500}.progress-value{color:var(--accent-color);font-size:14px;font-weight:700}.progress-bar-container{width:100%;height:12px;background-color:var(--bg-tertiary);border-radius:6px;overflow:hidden;transition:background-color .3s ease}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent-color),#4CAF50);border-radius:6px;transition:width .5s ease}.progress-card-enhanced{background:var(--bg-secondary);border-radius:16px;padding:2rem;border:1px solid var(--border-color);box-shadow:0 2px 8px #0000001a;margin-bottom:2rem;transition:all .3s ease}.progress-card-enhanced:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-2px)}.progress-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--border-color)}.progress-header-icon{font-size:1.75rem;line-height:1}.progress-card-header h2{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary);background:linear-gradient(135deg,var(--accent-color),#4CAF50);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.progress-grid-enhanced{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.progress-card-item{background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-secondary) 100%);border-radius:12px;padding:1.5rem;border:1px solid var(--border-color);display:flex;gap:1rem;align-items:flex-start;transition:all .3s ease;position:relative;overflow:hidden}.progress-card-item:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent-color),#4CAF50);opacity:0;transition:opacity .3s ease}.progress-card-item:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026;border-color:var(--accent-color)}.progress-card-item:hover:before{opacity:1}.progress-item-icon{font-size:2.5rem;line-height:1;flex-shrink:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.progress-item-content{flex:1;display:flex;flex-direction:column;gap:.75rem}.progress-item-label{font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.progress-item-numbers{display:flex;align-items:baseline;gap:.5rem;font-size:1.5rem;font-weight:700;line-height:1.2}.progress-current{color:var(--accent-color);font-size:1.75rem}.progress-separator{color:var(--text-secondary);font-weight:400;opacity:.5}.progress-total{color:var(--text-secondary);font-size:1.25rem;font-weight:500}.progress-bar-container-enhanced{width:100%;height:10px;background:var(--bg-tertiary);border-radius:10px;overflow:hidden;position:relative;box-shadow:inset 0 2px 4px #0000001a}.progress-bar-fill-enhanced{height:100%;border-radius:10px;transition:width .8s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.progress-bar-fill-enhanced:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}.progress-bar-fill-enhanced.books{background:linear-gradient(90deg,#ff6b6b,#ff8e8e);box-shadow:0 0 10px #ff6b6b4d}.progress-bar-fill-enhanced.chapters{background:linear-gradient(90deg,#4ecdc4,#6eddd6);box-shadow:0 0 10px #4ecdc44d}.progress-bar-fill-enhanced.verses{background:linear-gradient(90deg,#45b7d1,#6bc5d8);box-shadow:0 0 10px #45b7d14d}.progress-percentage{font-size:.875rem;font-weight:600;color:var(--accent-color);text-align:right;margin-top:-.25rem}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@media(max-width:768px){.progress-grid-enhanced{grid-template-columns:1fr;gap:1rem}.progress-card-enhanced{padding:1.5rem}.progress-card-item{padding:1.25rem}.progress-item-icon{font-size:2rem}.progress-item-numbers{font-size:1.25rem}.progress-current{font-size:1.5rem}}.books-progress-card{margin-top:20px}.books-progress-list{display:flex;flex-direction:column;gap:15px}.book-progress-item{padding:12px;background-color:var(--bg-tertiary);border-radius:8px;transition:background-color .3s ease}.book-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;flex-wrap:wrap;gap:8px}.book-name{color:var(--text-primary);font-size:14px;font-weight:500}.book-stats{color:var(--text-secondary);font-size:12px}.statistics-card{background-color:var(--bg-secondary);border-radius:12px;padding:20px;box-shadow:0 2px 8px var(--shadow);transition:background-color .3s ease,box-shadow .3s ease}.statistics-card.full-width{grid-column:1 / -1}.statistics-card h2{color:var(--accent-color);font-size:18px;margin:0 0 20px;padding-bottom:10px;border-bottom:2px solid var(--border-color)}.stat-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border-color)}.stat-item:last-child{border-bottom:none}.stat-label{color:var(--text-secondary);font-size:14px}.stat-value{color:var(--text-primary);font-size:16px;font-weight:700}.statistics-empty{display:flex;justify-content:center;align-items:center;min-height:400px;text-align:center}.statistics-empty p{color:var(--text-secondary);font-size:16px}.activity-summary{display:flex;justify-content:space-around;gap:20px;margin-bottom:25px;padding:15px;background-color:var(--bg-tertiary);border-radius:8px}.summary-item{display:flex;flex-direction:column;align-items:center;gap:5px}.summary-label{color:var(--text-secondary);font-size:12px;text-align:center}.summary-value{color:var(--accent-color);font-size:24px;font-weight:700}.daily-activity-chart{display:flex;justify-content:space-around;align-items:flex-end;gap:10px;padding:20px 0;min-height:200px}.chart-bar-container{display:flex;flex-direction:column;align-items:center;flex:1;gap:8px}.chart-bar{width:100%;max-width:60px;background:linear-gradient(to top,var(--accent-color),var(--accent-hover));border-radius:8px 8px 0 0;position:relative;min-height:20px;display:flex;align-items:flex-end;justify-content:center;padding-bottom:5px;transition:opacity .2s}.chart-bar:hover{opacity:.8}.chart-value{color:#fff;font-size:12px;font-weight:700}.chart-label-container{display:flex;flex-direction:column;align-items:center;gap:2px}.chart-label-day{color:var(--text-primary);font-size:14px;font-weight:500}.chart-label-month{color:var(--text-secondary);font-size:11px}.statistics-actions{margin-top:30px;display:flex;justify-content:center;gap:15px;flex-wrap:wrap}.history-button{padding:12px 24px;background-color:var(--accent-color);color:#fff;border:none;border-radius:8px;font-size:16px;cursor:pointer;transition:opacity .3s}.history-button:hover{opacity:.9}.reset-button{padding:12px 24px;background-color:#dc3545;color:#fff;border:none;border-radius:8px;font-size:16px;cursor:pointer;transition:opacity .3s,background-color .3s}.reset-button:hover:not(:disabled){opacity:.9;background-color:#c82333}.reset-button:disabled{opacity:.6;cursor:not-allowed}.history-section{margin-top:30px;background-color:var(--bg-secondary);border-radius:12px;padding:20px;box-shadow:0 2px 8px var(--shadow);transition:background-color .3s ease,box-shadow .3s ease}.history-section h2{color:var(--accent-color);font-size:20px;margin:0 0 20px}.history-loading,.history-empty{text-align:center;padding:40px 20px}.history-loading p,.history-empty p{color:var(--text-secondary);font-size:14px}.history-list{display:flex;flex-direction:column;gap:12px}.history-item{background-color:var(--bg-tertiary);border-radius:8px;padding:15px;transition:background-color .3s ease}.history-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.history-type{color:var(--text-primary);font-size:14px;font-weight:500}.history-date{color:var(--text-secondary);font-size:12px}.history-metadata{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.metadata-item{color:var(--text-secondary);font-size:12px;padding:4px 8px;background-color:var(--bg-secondary);border-radius:4px}.history-pagination{display:flex;justify-content:space-between;align-items:center;margin-top:20px;padding-top:20px;border-top:1px solid var(--border-color)}.pagination-button{padding:8px 16px;background-color:var(--accent-color);color:#fff;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:opacity .3s}.pagination-button:hover:not(:disabled){opacity:.9}.pagination-button:disabled{opacity:.5;cursor:not-allowed}.pagination-info{color:var(--text-secondary);font-size:14px}@media(min-width:768px){.statistics-container{padding:40px}}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.empty-state p{font-size:1.1rem}@media(max-width:600px){.statistics-grid{grid-template-columns:1fr}.statistics-header{flex-direction:column;align-items:flex-start}}.verify-container{min-height:100vh;background-color:#f5f5f5;display:flex;align-items:center;justify-content:center;padding:20px}.verify-content{width:100%;max-width:400px;display:flex;flex-direction:column;align-items:center}.verify-logo{margin-bottom:30px}.verify-logo img{width:100%;max-width:250px;height:auto}.verify-form{width:100%;display:flex;flex-direction:column;gap:15px}.verify-input{width:100%;padding:15px;border-radius:10px;border:none;background-color:#e6e6e6;color:#464d70;font-size:16px;box-sizing:border-box}.verify-input::placeholder{color:#777}.verify-input:disabled{opacity:.6;cursor:not-allowed}.password-container{position:relative;display:flex;align-items:center;background-color:#e6e6e6;border-radius:10px}.password-input{flex:1;padding-right:50px;border:none;background:transparent}.password-toggle{position:absolute;right:10px;background:none;border:none;cursor:pointer;padding:10px;font-size:20px}.btn{width:100%;padding:15px;border-radius:10px;border:none;font-size:16px;cursor:pointer;text-decoration:none;text-align:center;box-sizing:border-box;transition:opacity .3s}.btn-primary{background-color:#31708f;color:#fff;font-weight:700}.verify-link{color:#31708f;font-size:16px;text-decoration:underline;text-align:center;margin-top:10px}.voting-container{min-height:100vh;background-color:var(--bg-primary);padding:20px;max-width:800px;margin:0 auto;color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.voting-header{margin-bottom:30px}.voting-header h1{color:var(--accent-color);font-size:24px;margin:0 0 10px}.voting-description{font-size:14px;color:var(--text-secondary);text-align:center;margin:0}.vote-info{background-color:#28a74533;padding:20px;border-radius:10px;margin-bottom:30px;text-align:center}.dark-mode .vote-info{background-color:#28a7454d}.already-voted-text{font-size:16px;font-weight:700;color:#155724;margin:0 0 10px}.vote-text{font-size:14px;color:#155724;margin:0 0 15px}.voting-form{background-color:var(--bg-secondary);padding:20px;border-radius:10px;box-shadow:0 2px 4px var(--shadow);margin-bottom:30px;transition:background-color .3s ease,box-shadow .3s ease}.voting-input{width:100%;padding:15px;border:1px solid var(--border-color);border-radius:5px;margin-bottom:15px;font-size:16px;box-sizing:border-box;background-color:var(--bg-tertiary);color:var(--text-primary);transition:border-color .2s,background-color .3s ease,color .3s ease}.voting-input:focus{outline:none;border-color:var(--accent-color);background-color:var(--bg-secondary)}.suggestions-list{display:flex;flex-direction:column;gap:5px;margin-bottom:15px}.suggestion-item{padding:10px;background-color:var(--bg-tertiary);border:none;border-radius:5px;cursor:pointer;text-align:left;font-size:14px;color:var(--text-primary);transition:background-color .2s}.suggestion-item:hover{background-color:var(--border-color)}.results-section{background-color:var(--bg-secondary);padding:20px;border-radius:10px;box-shadow:0 2px 4px var(--shadow);transition:background-color .3s ease,box-shadow .3s ease}.top10-results-section{margin-top:22px;border-top:1px solid var(--border-color)}.results-title{font-size:18px;font-weight:700;color:var(--accent-color);margin:0 0 20px}.no-results{text-align:center;color:var(--text-secondary);margin:20px 0}.results-list{display:flex;flex-direction:column;gap:10px}.result-item{display:flex;justify-content:space-between;align-items:center;padding:15px;border-bottom:1px solid var(--border-color);gap:10px}.result-item:last-child{border-bottom:none}.result-rank{font-size:16px;font-weight:700;color:var(--accent-color);min-width:40px;flex-shrink:0}.result-text{font-size:16px;color:var(--text-primary);flex:1}.result-votes{font-size:16px;font-weight:700;color:var(--accent-color);flex-shrink:0}.btn{width:100%;padding:15px;border-radius:5px;border:none;font-size:16px;cursor:pointer;transition:opacity .3s}.btn-danger{background-color:#d9534f;color:#fff;font-weight:700}.btn-danger:hover:not(:disabled){opacity:.9}@media(min-width:768px){.voting-container{padding:40px}}.wall-container{background-color:var(--bg-primary);padding:20px 20px 40px;max-width:800px;margin:0 auto;color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.wall-header{margin-bottom:20px}.wall-header h1{color:var(--accent-color);font-size:24px;margin:0}.no-list-area p{font-size:16px;color:var(--text-secondary)}.wall-list{display:flex;flex-direction:column;gap:12px}.wall-item{background-color:var(--bg-secondary);border-radius:8px;overflow:hidden;box-shadow:0 2px 4px var(--shadow);transition:background-color .3s ease,box-shadow .3s ease;display:block}.wall-item-photos{display:flex;flex-direction:column;gap:0}.wall-item-photo{width:100%;height:auto;max-height:400px;object-fit:cover;display:block}.wall-item-content{padding:8px 10px}.wall-item-header{display:flex;align-items:flex-start;gap:6px;margin-bottom:6px}.wall-item-title{color:var(--accent-color);font-size:17px;margin:0;flex:1;min-width:0;line-height:1.3}.wall-item-expand{font-size:14px;color:var(--accent-color);padding:2px 6px;flex-shrink:0;-webkit-user-select:none;user-select:none;cursor:pointer;margin-left:auto}.wall-item-content:hover{background-color:var(--bg-tertiary)}.wall-item-content{transition:background-color .2s}.wall-item-description{color:var(--text-primary);font-size:15px;line-height:1.4;margin:0 0 8px;white-space:pre-wrap;word-wrap:break-word}.wall-item-footer{display:flex;justify-content:space-between;align-items:center}.wall-item-date{color:var(--text-secondary);font-size:13px}.wall-item-like{background:none;border:none;cursor:pointer;font-size:14px;color:var(--accent-color);display:flex;align-items:center;gap:3px;transition:transform .2s,background-color .2s;padding:3px 6px;border-radius:5px}.wall-item-like:hover{background-color:var(--bg-tertiary);transform:scale(1.05)}.wall-item-like.liked{color:#e91e63;font-weight:700}.refresh-button{margin-top:20px;width:100%;padding:15px;background-color:var(--accent-color);color:#fff;border:none;border-radius:10px;font-size:16px;cursor:pointer;transition:opacity .3s}.refresh-button:hover{opacity:.9}@media(min-width:768px){.wall-container{padding:40px}}.warning-add-container{min-height:100vh;background-color:var(--bg-primary);padding:20px;max-width:600px;margin:0 auto}.warning-add-content{background-color:var(--bg-secondary);border-radius:10px;padding:30px;box-shadow:0 2px 8px var(--shadow)}.warning-add-content h1{color:var(--accent-color);font-size:24px;margin:0 0 30px}.warning-add-form{display:flex;flex-direction:column;gap:20px}.warning-add-label{font-size:16px;color:var(--text-primary);font-weight:500}.warning-add-input,.warning-add-textarea{width:100%;padding:15px;border-radius:10px;border:1px solid var(--border-color);background-color:var(--bg-tertiary);color:var(--text-primary);font-size:16px;font-family:inherit;box-sizing:border-box}.warning-add-textarea{resize:vertical}.warning-add-input:focus,.warning-add-textarea:focus{outline:none;border-color:var(--accent-color);background-color:var(--bg-secondary)}.photo-area{display:flex;flex-direction:column;gap:15px}.photo-add-button{padding:15px;background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:10px;text-align:center;cursor:pointer;transition:background-color .3s}.photo-add-button:hover{background-color:var(--border-color)}.dark-mode .warning-add-content .photo-add-button{background-color:#404040;color:#e0e0e0;border:1px solid #404040}.dark-mode .warning-add-content .photo-add-button:hover{background-color:#505050;color:#e0e0e0}.loading-text{color:var(--accent-color);font-size:14px;margin:0}.photo-list{display:flex;gap:10px;flex-wrap:wrap}.photo-item{position:relative;width:100px;height:100px}.photo-item img{width:100%;height:100%;object-fit:cover;border-radius:10px}.photo-remove-button{position:absolute;top:-5px;right:-5px;width:24px;height:24px;border-radius:50%;background-color:red;color:#fff;border:none;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center}.btn{width:100%;padding:15px;border-radius:10px;border:none;font-size:16px;cursor:pointer;transition:opacity .3s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary:hover:not(:disabled){opacity:.9}.warning-container{min-height:100vh;background-color:var(--bg-primary);padding:20px;max-width:800px;margin:0 auto;color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.warning-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.warning-header h1{color:var(--accent-color);font-size:24px;margin:0}.add-button{width:auto;padding:10px 20px}.filter-container{display:flex;gap:10px;margin-bottom:20px}.filter-button{flex:1;padding:10px;border:2px solid var(--accent-color);border-radius:5px;background-color:var(--bg-secondary);color:var(--accent-color);font-size:16px;cursor:pointer;transition:all .3s}.filter-button.active{background-color:var(--accent-color);color:#fff}.filter-button:hover{opacity:.9}.access-denied{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center}.access-denied h2{font-size:22px;color:#d32f2f;margin-bottom:10px}.access-denied p{font-size:16px;color:var(--text-secondary)}.no-list-area{display:flex;justify-content:center;align-items:center;min-height:300px}.no-list-area p{font-size:16px;color:var(--text-primary)}.warning-list{display:flex;flex-direction:column;gap:15px}.warning-item{background-color:var(--bg-secondary);border:2px solid var(--border-color);border-radius:15px;padding:15px;transition:background-color .3s ease,border-color .3s ease}.warning-header-item{display:flex;justify-content:space-between;margin-bottom:10px}.warning-created-by{font-size:15px;font-weight:700;color:var(--text-secondary);margin:0}.warning-date{font-size:14px;font-weight:700;color:var(--text-secondary);margin:0}.warning-title{font-size:15px;font-weight:700;color:var(--text-primary);margin:0 0 10px}.warning-description{font-size:14px;color:var(--text-primary);margin:10px 0}.warning-status{display:flex;align-items:center;gap:10px;margin:10px 0}.status-icon{font-size:20px}.status-text{font-size:14px;color:var(--text-secondary)}.warning-photos{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}.warning-photo{width:50px;height:50px;border-radius:10px;object-fit:cover;cursor:pointer}.btn{padding:15px;border-radius:10px;border:none;font-size:16px;cursor:pointer;transition:opacity .3s}.btn-primary{background-color:var(--accent-color);color:#fff;font-weight:700}.btn-primary:hover{opacity:.9}@media(min-width:768px){.warning-container{padding:40px}}
