:root{--primary-color: #4ade80;--secondary-color: #3b82f6;--text-color: #333;--light-text: #333;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;font-family:Arial,sans-serif;line-height:1.6;color:var(--text-color);background-color:#1e1e1e;width:100%}#root{width:100%}.app{min-height:100vh;display:flex;flex-direction:column;position:relative;width:100%}.main-content{margin-top:0;padding:1rem;background-color:#1e1e1e;position:relative;width:100%;overflow:visible;flex:1 0 auto;min-height:calc(100vh - 200px)}.main-content-title{display:none;color:#fff;text-align:center;margin-bottom:1rem;font-size:18px;font-weight:500}.loading,.error{text-align:center;padding:2rem;font-size:1.2rem}.rate-limit-error{color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:70vh;gap:1rem}.rate-limit-icon{font-size:4rem;margin-bottom:1rem}.rate-limit-error h2{color:#fff;font-size:2rem;margin-bottom:.5rem}.rate-limit-error p{color:#fff;font-size:1.2rem;margin:.5rem 0}.retry-button{margin-top:1.5rem;padding:.75rem 2rem;font-size:1.1rem;background-color:var(--primary-color);color:#1e1e1e;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;font-weight:600}.retry-button:hover{background-color:var(--primary-color);filter:brightness(.9);transform:translateY(-2px);box-shadow:0 4px 12px color-mix(in srgb,var(--primary-color) 40%,transparent)}.retry-button:active{transform:translateY(0)}.backend-error{color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem;padding:2rem}.error-icon-large{font-size:3rem;margin-bottom:.5rem;animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.backend-error h2{color:#fff;font-size:1.8rem;margin-bottom:.5rem;font-weight:700}.backend-error .error-description{color:#ccc;font-size:1.3rem;margin:.5rem 0;font-weight:500}.backend-error .error-details{color:#999;font-size:1rem;margin:1rem 0;font-family:Courier New,monospace;background-color:#ffffff0d;padding:.75rem 1.5rem;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.footer-wrapper{opacity:0;visibility:hidden;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease,visibility .6s,height 0s .6s;margin-top:auto;height:0;overflow:hidden}.footer-wrapper.visible{opacity:1;visibility:visible;transform:translateY(0);height:auto;transition:opacity .6s ease,transform .6s ease,visibility .6s}@media(max-width:768px){.main-content{padding:.75rem}.main-content:has(.admin-portal){min-height:auto}}@media(max-width:511px){.main-content{margin-top:54px}}@media(max-width:599px){.main-content{padding-bottom:2rem;margin-top:54px}.main-content-title{display:block}}@media(max-width:480px){.main-content{padding-bottom:2rem}}.albums-list-content{padding:1rem;text-align:center;width:100%}.albums-list-content h3{color:#fff;margin-bottom:1rem;font-size:1.5rem}.albums-buttons{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;align-items:center;padding:0 .5rem}.album-button{background:#ffffff1a;color:#fff;padding:.25rem .5rem;border-radius:4px;text-decoration:none;transition:all .2s ease;width:100%;text-align:center;font-size:.9rem}.album-button:hover{background:#fff3;transform:translateY(-2px)}.photo-grid{display:grid;grid-template-columns:repeat(1,1fr);gap:1rem;padding:0;width:100%;max-width:100%;margin-top:1rem;align-items:start}.photo-column{display:flex;flex-direction:column;gap:1rem;max-height:100%}.photo-item{position:relative;cursor:pointer;overflow:hidden;width:100%;border:1px solid rgba(255,255,255,.1);display:block}.photo-item:last-child{margin-bottom:0}.photo-item.albums-list{display:flex;align-items:center;justify-content:center;background-color:#0003;cursor:default}.photo-loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:#0000004d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1;pointer-events:none}.photo-loading-spinner{width:32px;height:32px;border:3px solid rgba(255,255,255,.1);border-top:3px solid rgba(255,255,255,.5);border-radius:50%;animation:photo-spinner-spin .8s linear infinite}@keyframes photo-spinner-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.photo-item img.loaded~.photo-loading-overlay{display:none}.photo-item:hover{border-color:#ffffff4d}.photo-item img{width:100%;height:auto;object-fit:contain;transition:transform .1s ease;display:block;opacity:0;transition:opacity .3s ease}.photo-item img.loaded{opacity:1}.photo-item:hover img{transform:none}.video-play-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#0009;border-radius:50%;width:64px;height:64px;display:flex;align-items:center;justify-content:center;color:#fff;opacity:0;transition:all .2s ease;z-index:2;pointer-events:none;cursor:pointer}@media(hover:hover)and (pointer:fine){.photo-item.video-item:hover .video-play-overlay{opacity:1;pointer-events:auto}.video-play-overlay:hover{background:#000c;transform:translate(-50%,-50%) scale(1.1)}}@media(hover:none),(pointer:coarse),(max-width:1024px){.video-play-overlay{display:none!important;opacity:0!important;pointer-events:none!important}}@media(max-width:511px){.photo-grid{padding-top:0}}@media(min-width:512px){.photo-grid{grid-template-columns:repeat(2,1fr);margin-top:54px}}@media(max-width:599px){.photo-grid{margin-top:0}}@media(min-width:900px){.photo-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1200px){.photo-grid{grid-template-columns:repeat(4,1fr)}}@media(min-width:1600px){.photo-grid{grid-template-columns:repeat(5,1fr)}}@media(max-width:511px){.photo-grid{padding:0;margin-top:0;gap:1rem}.main-content{padding-bottom:2rem}}.photo-grid-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1.5rem;min-height:50vh}.photo-grid-loading .loading-spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.1);border-top:4px solid var(--primary-color);border-radius:50%;animation:photo-grid-spin .8s linear infinite}@keyframes photo-grid-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.photo-grid-loading p{color:#ffffffb3;font-size:1.1rem;margin:0;font-weight:400;letter-spacing:.025em}@media(max-width:768px){.photo-grid-loading{padding:3rem 1.5rem}.photo-grid-loading .loading-spinner{width:40px;height:40px;border-width:3px}.photo-grid-loading p{font-size:1rem}}@media(max-width:511px){.photo-grid-loading{padding:2rem 1rem;min-height:40vh}.photo-grid-loading .loading-spinner{width:36px;height:36px}}.album-actions-banner{background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:8px;margin-bottom:2rem;padding:1.5rem;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.album-actions-content h3{margin:0 0 1rem;font-size:1.2rem;color:#fff}.album-actions-grid-inline{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}.album-actions-grid-inline .btn-action{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#fff;font-size:.95rem;cursor:pointer;transition:all .2s ease}.album-actions-grid-inline .btn-action:hover{background:#ffffff14;border-color:#fff3;transform:translateY(-1px)}.album-actions-grid-inline .btn-manage{background:#4ade8026;border-color:#4ade804d}.album-actions-grid-inline .btn-manage:hover{background:#4ade8040;border-color:#4ade8066}.album-actions-grid-inline .btn-close-edit{background:#ef444426;border-color:#ef44444d}.album-actions-grid-inline .btn-close-edit:hover{background:#ef444440;border-color:#ef444466}.album-actions-hint{margin:0;font-size:.9rem;color:#fff9;font-style:italic}.photos-header{margin-top:54px;margin-bottom:0}.photos-header+.photo-grid{margin-top:0}@media(max-width:768px){.album-actions-banner{padding:1rem;margin-bottom:1.5rem}.album-actions-content h3{font-size:1.1rem}.album-actions-grid-inline{flex-direction:column;gap:.75rem}.album-actions-grid-inline .btn-action{width:100%;justify-content:center}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:70vh;text-align:center;padding:2rem;color:#fff}.empty-icon{font-size:5rem;margin-bottom:1.5rem;opacity:1}.empty-state h2{font-size:1.75rem;font-weight:600;color:#fff;margin:0 0 .75rem}.empty-state p{font-size:1.1rem;color:#a0aec0;margin:0 0 2rem;max-width:500px}.empty-state-button{display:inline-block;padding:.875rem 2rem;background:var(--primary-color);color:#1e1e1e;text-decoration:none;border-radius:8px;font-weight:600;font-size:1rem;transition:all .2s ease;box-shadow:0 4px 12px #4ade804d}.empty-state-button:hover{background:var(--primary-color);filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 6px 20px #4ade8066}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000c;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:1000}.modal.fullscreen{background-color:#000;backdrop-filter:none;-webkit-backdrop-filter:none}.modal-content{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0;width:100%;height:100%}.modal-container{position:relative;max-width:calc(100vw - 20px);max-height:calc(100vh - 100px);display:flex;align-items:center;justify-content:center}.modal-media-container{position:relative;width:calc(100vw - 20px);height:calc(100vh - 100px);max-width:calc(100vw - 20px);max-height:calc(100vh - 100px);display:flex;flex-direction:column;align-items:center;justify-content:center}.modal-photo-container{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.modal-video-player{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;pointer-events:auto}.modal-video-player video{pointer-events:auto}.modal-photo{max-width:100%;max-height:100%;object-fit:contain;display:block}.modal-controls-top{position:absolute;top:0;left:0;right:0;width:100%;display:flex;justify-content:space-between;z-index:1001;transform:translateY(-100%);padding:.25rem;box-sizing:border-box}.modal-controls-left,.modal-controls-right{display:flex;gap:.5rem}.modal-controls-top button{background:#00000080;border:1px solid rgba(51,51,51,.5);color:#fff;padding:.5rem;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;outline:none;box-shadow:0 2px 4px #0003;width:38px;height:38px;min-width:38px;min-height:38px}.modal-controls-top button.active{background:#000c;border-color:#ffffff80}.modal-controls-top button svg{width:20px;height:20px}.modal-controls-top button:hover{background:#000c;border-color:#333c;box-shadow:0 4px 8px #0000004d}.modal-info-panel{position:absolute;top:0;left:0;background:#000000d9;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:1.25rem;width:320px;height:320px;overflow-y:auto;z-index:1003;margin:.5rem;box-shadow:0 8px 32px #0009;color:#fff;animation:fadeIn .2s ease-out}@media(max-width:768px){.modal-info-panel{width:280px;height:280px}}@media(max-width:600px){.fullscreen-toggle{display:none!important}}.modal-info-panel h3{margin:0 0 1rem;font-size:1.15rem;font-weight:600;color:#fff;border-bottom:1px solid rgba(255,255,255,.15);padding-bottom:.75rem;letter-spacing:.025em}.info-item{display:flex;margin-bottom:.75rem;gap:.75rem}.info-item:last-child{margin-bottom:0}.info-label{font-weight:600;color:#ffffffb3;min-width:85px;flex-shrink:0;font-size:.9rem}.info-value{color:#fff;word-break:break-word;font-size:.9rem}.modal-navigation-hint{position:absolute;bottom:0;left:0;right:0;color:#ffffffb3;font-size:.875rem;padding:.5rem;transform:translateY(100%);z-index:1001;-webkit-user-select:none;user-select:none;pointer-events:none;display:flex;justify-content:flex-start}@media(max-width:768px),(hover:none){.modal-navigation-hint{display:none}}.modal-navigation{position:absolute;bottom:0;left:auto;right:0;display:flex;gap:.5rem;transform:translateY(100%);z-index:1001;padding:.25rem;justify-content:flex-end}.modal-navigation button{background:#0009;border:1px solid rgba(51,51,51,.5);color:#fff;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;outline:none;box-shadow:0 2px 4px #0003;min-width:38px;min-height:38px;font-size:1.1rem;pointer-events:auto}.modal-navigation button:hover{background:#000c;border-color:#333c;box-shadow:0 4px 8px #0000004d}.modal-navigation button svg{width:20px;height:20px}.modal-image-title{position:absolute;top:0;left:180px;right:130px;transform:translateY(calc(-100% - .5rem));color:#fff;padding:.5rem 1rem;font-size:.9rem;font-weight:500;text-align:center;z-index:1000;animation:fadeIn .3s ease-out;line-height:1.2;text-shadow:0 2px 8px rgba(0,0,0,.8);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none}@media(max-width:650px){.modal-image-title{left:0;right:0;text-align:center;top:auto;bottom:100%;transform:translateY(-3rem);padding:0 1rem}}@media(max-width:599px){.modal-image-container{max-width:calc(100vw - 20px);max-height:calc(100vh - 80px)}}.not-found-container{color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:70vh;padding:2rem;text-align:center;gap:1rem}.not-found-icon{font-size:5rem;margin-bottom:1rem;animation:wobble 2s ease-in-out infinite}@keyframes wobble{0%,to{transform:rotate(-5deg)}50%{transform:rotate(5deg)}}.not-found-container h1{color:#fff;font-size:2.5rem;margin-bottom:.5rem;font-weight:700}.not-found-container h2{color:#e5e7eb;font-size:1.5rem;margin-bottom:1rem;font-weight:500}.not-found-container p{color:#d1d5db;font-size:1.2rem;margin:.5rem 0}.error-code{color:#9ca3af;font-size:1rem;font-family:SF Mono,Monaco,Cascadia Code,Courier New,monospace;margin-top:1.5rem!important}.not-found-actions{margin-top:2rem;display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.home-button{padding:.75rem 2rem;font-size:1.1rem;background-color:#4ade80;color:#1e1e1e;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;font-weight:600;text-decoration:none;display:inline-block}.home-button:hover{background-color:#22c55e;transform:translateY(-2px);box-shadow:0 4px 12px #4ade8066}.home-button:active{transform:translateY(0)}@media(max-width:768px){.not-found-icon{font-size:4rem}.not-found-container h1{font-size:2rem}.not-found-container h2{font-size:1.25rem}.not-found-container p{font-size:1rem}}.header{background-color:#e7e7e7;color:#1e1e1e;padding:0 1rem;height:54px;display:flex;align-items:center;position:fixed;top:0;left:0;right:0;z-index:1000;border-bottom:1px solid #FFFFFF;box-shadow:0 2px 4px #00000080;visibility:hidden}.header.header-visible{visibility:visible}.header-left{display:flex;align-items:center;gap:1rem}.logout-btn{background:none;border:none;padding:.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease;color:#1e1e1e}.logout-btn:hover{background:#0000001a;color:#ef4444}.logout-btn svg{display:block}.header-left a{display:flex;align-items:center;gap:1rem;text-decoration:none}.header-left:hover{text-decoration:none}.header-left:active{opacity:.8}.avatar{width:40px;height:40px;border-radius:50%;object-fit:cover}.header-left:hover .avatar{box-shadow:0 2px 4px #0000001a}.header-title{font-size:16px;font-weight:500;margin:0;transition:all .1s ease;position:relative;color:#1e1e1e;text-shadow:0 0 2px rgba(255,255,255,.8);white-space:nowrap}.header-left:hover .header-title{color:#666}.header-left:hover .header-title:after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:1px;background-color:#666}.album-nav{display:flex;align-items:center;gap:0rem;position:absolute;right:0;margin-right:1rem}.nav-left,.nav-right{display:flex;align-items:center;gap:.5rem}.nav-center{position:absolute;left:50%;transform:translate(-50%);text-align:center;width:auto;pointer-events:none;display:flex;align-items:center;gap:.5rem}.nav-center .edit-album-btn{pointer-events:auto}.album-title{font-size:18px;font-weight:600;margin:0;color:#1e1e1e;text-shadow:0 0 2px rgba(255,255,255,.8);white-space:nowrap;display:inline-block}.nav-link{background:#edededb3;border:1px solid rgba(255,255,255,.904);color:#000;padding:.25rem .75rem;box-shadow:0 1px 3px #0000001a;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .05s ease;outline:none;font-size:16px;text-decoration:none;min-width:80px;height:35px;border-radius:8px}.nav-link:hover{background:#ffffffe6;color:#000;box-shadow:0 2px 3px #0000001a}.nav-link:active{background:#fffc;color:#000;box-shadow:0 1px 2px #0000001a}.nav-link:focus{outline-offset:2px}.edit-album-btn{display:flex;align-items:center;justify-content:center;background:#edededb3;border:1px solid rgba(255,255,255,.904);color:#000;padding:.5rem;border-radius:8px;width:35px;height:35px;cursor:pointer;transition:all .3s ease-in-out;text-decoration:none}.edit-album-btn:hover{background:#ffffffe6;color:var(--primary-color);box-shadow:0 2px 3px #0000001a;transform:scale(1.05)}.edit-album-btn:active{background:#fffc;box-shadow:0 1px 2px #0000001a;transform:scale(.98)}.edit-album-btn svg{width:16px;height:16px}.dropdown-container{position:relative;display:inline-block;background-color:#fff9;margin-left:1rem;border-radius:8px}.dropdown-arrow{margin-left:.5rem;transition:transform .3s ease-in-out}.dropdown-arrow.open{transform:rotate(180deg)}.folder-chevron{transition:transform .2s ease-in-out;transform:translateY(-50%) rotate(0)}.folder-chevron.open{transform:translateY(-50%) rotate(90deg)}.dropdown-menu{position:absolute;top:100%;right:0;width:240px;margin-top:.7rem;background:#ffffff80;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid #FFF;border-top:none;padding:1rem;box-shadow:0 4px 4px #00000080;z-index:999;display:flex;flex-direction:column;visibility:hidden;opacity:0;border-radius:0 0 8px 8px;transform:translateY(-10px);transition:transform .3s ease-in-out,opacity .3s ease-in-out,visibility .3s ease-in-out}.dropdown-menu.open{visibility:visible;opacity:1;transform:translateY(0)}.dropdown-menu .nav-link{width:100%;text-align:center;padding:.75rem 1rem;margin-bottom:.5rem;border-radius:4px;background:#fff;border:1px solid rgba(51,51,51,.3);color:#000;box-shadow:0 1px 3px #0003;transition:all .3s ease-in-out;display:flex;align-items:center;justify-content:center;min-width:0}.dropdown-menu .nav-link:last-child{margin-bottom:0}.dropdown-menu .nav-link:hover{background:#000;color:#fff}.dropdown-menu .nav-link.active{background:#1e1e1e;color:#fff;border:1px solid #d5d5d5;box-shadow:0 2px 4px #0003}.folder-item{display:flex;flex-direction:column;margin-bottom:.5rem}.folder-item:last-child{margin-bottom:0}.folder-link{width:100%;display:flex;align-items:center;justify-content:center;gap:0;padding:.75rem 1rem;border-radius:4px;background:#fff;border:1px solid rgba(51,51,51,.3);color:#000;box-shadow:0 1px 3px #0003;transition:all .3s ease-in-out;cursor:pointer;font-size:inherit;font-family:inherit;position:relative}.folder-link svg{position:absolute;left:1rem;top:50%;display:block;flex-shrink:0}.folder-link svg:not(.folder-chevron){transform:translateY(-50%)}.folder-link span{display:block;line-height:1;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.folder-link:hover,.folder-link.open{background:#000;color:#fff}.folder-link:hover svg,.folder-link.open svg{stroke:#fff}.folder-submenu{display:flex;flex-direction:column;overflow:hidden;animation:slideDown .25s ease-out}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:1000px}}.folder-submenu .nav-link{margin-bottom:.5rem;display:flex;align-items:center;min-width:0}.folder-submenu .nav-link:last-child{margin-bottom:0}@media(max-width:768px){.edit-album-btn,.logout-btn{display:none!important}}@media(max-width:768px){.album-nav{display:flex}}@media(max-width:599px){.header{padding:0 .5rem}.nav-center{display:none!important}}@media(max-width:400px){.dropdown-arrow{display:none}.dropdown-container{margin-left:0;width:80px;margin-right:-5px;margin-top:-4px}.nav-link,.nav-link:hover,.nav-link:active,.nav-link.active{height:35px}.album-nav{display:flex;flex-wrap:wrap;gap:8px;height:35px;padding:4px}}@media(max-width:335px){.header-title{display:none}}.footer{background-color:#252525;padding:2rem 0;border-top:1px solid #444;position:relative;z-index:100}.footer-content{margin:0 auto;padding:0 1rem;display:flex;flex-direction:column;align-items:center;text-align:center;color:#fff}.footer-bottom{display:flex;flex-direction:row;align-items:center;justify-content:center;width:100%;gap:2rem;position:relative}.footer-left{display:flex;flex-direction:column;align-items:center;gap:.5rem;text-align:center}.footer-right{position:absolute;right:0;display:flex;align-items:center;padding-right:2rem}.footer-links{display:flex;gap:1rem;align-items:center;justify-content:center}.footer-separator{color:#888;-webkit-user-select:none;user-select:none}.footer-link{color:#fff;text-decoration:underline;font-weight:500}.footer-link:hover,.footer-link:visited:hover{opacity:.8}.footer-link:visited{color:#fff}.footer-powered-by{color:#888}.footer-galleria-link{color:#4ade80;text-decoration:none;font-weight:600;border-bottom:1px solid transparent;transition:all .2s ease}.footer-galleria-link:hover{color:#22c55e;border-bottom-color:#22c55e}.footer-galleria-link:visited{color:#4ade80}.footer-signin-btn{display:inline-block;padding:.5rem 1.5rem;background-color:#444;color:#fff;text-decoration:none;border:1px solid #555;border-radius:4px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s ease}.footer-signin-btn:hover{background-color:#555;border-color:#666}.footer-signin-btn:visited,.footer-signin-btn:visited:hover{color:#fff}@media(max-width:768px){.footer-bottom{flex-direction:column;align-items:center;text-align:center;gap:1rem}.footer-left{align-items:center;text-align:center}.footer-right{position:static;padding-right:0}.footer-links{justify-content:center}}@font-face{font-family:Modern DOS;src:url(/fonts/ModernDOS8x16.ttf) format("truetype");font-weight:400;font-style:normal}.progress-percentage{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1rem;font-weight:600;color:var(--primary-color)}.config-grid{margin-top:1.5rem;display:flex;flex-direction:column}.config-group{display:flex;flex-direction:column;margin-bottom:1rem}.section-header{transition:all .2s ease}.section-header:hover{background:linear-gradient(135deg,#ffffff1a,#ffffff12)!important;border-color:#fff3!important}.config-group:last-child{margin-bottom:0}.config-group.full-width{width:100%}.openai-settings-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media(min-width:768px){.openai-settings-grid{grid-template-columns:1fr 1fr}}.settings-section{background:linear-gradient(135deg,#ffffff0d,#ffffff05);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:1.25rem;display:flex;flex-direction:column;gap:1rem;transition:all .2s ease}.settings-section:hover{background:linear-gradient(135deg,#ffffff14,#ffffff05);border-color:#fff3}.settings-section-label{color:var(--primary-color);font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.openai-section{background:linear-gradient(135deg,#ffffff0d,#ffffff05);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:1.25rem;display:flex;flex-direction:column;gap:1rem;transition:all .2s ease}.openai-section:hover{background:linear-gradient(135deg,#ffffff1a,#ffffff12);border-color:#fff3}.openai-section-label{color:var(--primary-color);font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.config-section-title{color:var(--primary-color);font-size:1.2rem;font-weight:600;margin:0;padding-bottom:0;border-bottom:none}.config-section-description{color:#9ca3af;font-size:.9rem;line-height:1.5;margin:.5rem 0 1rem;padding:0}.config-grid-inner{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.array-item{display:flex;gap:.5rem;margin-bottom:.5rem}.array-item .branding-input{flex:1}.btn-remove{background:#ef444433;border:1.5px solid rgba(239,68,68,.3);color:#ef4444;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:1.2rem;font-weight:700;min-width:40px;transition:all .2s ease}.btn-remove:hover{background:#ef44444d;border-color:#ef444480;transform:scale(1.05)}.btn-add{background:#ffffff0d;border:1.5px solid rgba(255,255,255,.1);color:var(--primary-color);padding:.75rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s ease;margin-top:.5rem}.btn-add:hover{background:#ffffff14;border-color:#ffffff26;transform:translateY(-1px)}.titles-output{margin-top:1rem;background:#000;border:1.5px solid rgba(255,255,255,.1);border-radius:6px;padding:1rem;max-height:400px;overflow-y:auto}.titles-output-content{font-family:Modern DOS,Courier New,monospace;font-size:.75rem;line-height:1.4;color:#e5e7eb}@media(max-width:600px){.titles-output-content{font-size:.5rem}}.output-line{margin-bottom:.25rem;word-wrap:break-word}.output-line:last-child{margin-bottom:0}.titles-output::-webkit-scrollbar{width:8px}.titles-output::-webkit-scrollbar-track{background:#0003;border-radius:4px}.titles-output::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.titles-output::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.sse-toaster{position:fixed;width:450px;max-width:calc(100vw - 40px);background:linear-gradient(135deg,#1a1a1a,#0d0d0d);border:1px solid rgba(255,255,255,.15);border-radius:12px;box-shadow:0 8px 32px #0009,0 0 0 1px #ffffff0d;z-index:9999;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);-webkit-user-select:none;user-select:none}.sse-toaster:not(.dragging):not(.initial-animation):not(.maximized){transition:top .3s cubic-bezier(.4,0,.2,1),bottom .3s cubic-bezier(.4,0,.2,1),left .3s cubic-bezier(.4,0,.2,1),right .3s cubic-bezier(.4,0,.2,1)}.sse-toaster.top-right{top:80px;right:20px}.sse-toaster.top-left{top:80px;left:20px}.sse-toaster.bottom-right{bottom:20px;right:20px}.sse-toaster.bottom-left{bottom:20px;left:20px}.sse-toaster.initial-animation.top-right{animation:slideInFromRight .3s ease-out}.sse-toaster.initial-animation.top-left{animation:slideInFromLeft .3s ease-out}.sse-toaster.initial-animation.bottom-right{animation:slideInFromBottomRight .3s ease-out}.sse-toaster.initial-animation.bottom-left{animation:slideInFromBottomLeft .3s ease-out}.sse-toaster.dragging{opacity:.8;transition:opacity .1s ease-out}@keyframes slideInFromRight{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}@keyframes slideInFromLeft{0%{opacity:0;transform:translate(-100px)}to{opacity:1;transform:translate(0)}}@keyframes slideInFromBottomRight{0%{opacity:0;transform:translate(100px,100px)}to{opacity:1;transform:translate(0)}}@keyframes slideInFromBottomLeft{0%{opacity:0;transform:translateY(100px)}to{opacity:1;transform:translateY(0)}}.sse-toaster.expanded,.sse-toaster.collapsed{height:auto;max-height:none}.sse-toaster-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.1);background:#ffffff08;border-radius:12px 12px 0 0}.sse-toaster-title{display:flex;align-items:center;gap:.75rem;flex:1}.sse-toaster-icon{font-size:1.25rem;animation:spin 2s linear infinite}.sse-toaster-label{font-weight:600;color:#fff;font-size:.95rem;text-transform:uppercase;letter-spacing:.05em}.sse-toaster-progress{color:var(--primary-color);font-weight:700;font-size:1rem;margin-left:auto;margin-right:1.5rem}.sse-toaster-actions{display:flex;gap:.5rem;align-items:center}.sse-toaster-stop-btn{background:#dc262626;border:1px solid rgba(220,38,38,.3);color:#ef4444;width:32px;height:32px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:900;line-height:1;transition:all .2s ease;padding:0}.sse-toaster-stop-btn:hover{background:#dc262640;border-color:#ef4444;transform:scale(1.05);box-shadow:0 0 8px #ef44444d}.sse-toaster-maximize-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:#fff;width:32px;height:32px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;padding:0}.sse-toaster-maximize-btn svg{display:block}.sse-toaster-maximize-btn:hover{background:#ffffff1f;border-color:var(--primary-color);transform:scale(1.05)}.sse-toaster-collapse-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:#fff;width:32px;height:32px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:600;line-height:1;transition:all .2s ease;padding:0}.sse-toaster-collapse-btn:hover:not(:disabled){background:#ffffff1f;border-color:var(--primary-color);transform:scale(1.05)}.sse-toaster-collapse-btn:disabled{opacity:.5;cursor:not-allowed}.sse-toaster.maximized{top:70px;left:20px;right:20px;bottom:20px;width:auto;max-width:none;max-height:calc(100vh - 90px)}@keyframes expandToFull{0%{top:80px;right:20px;left:auto;bottom:auto;width:450px}to{top:70px;left:20px;right:20px;bottom:20px;width:auto}}.sse-toaster.maximized .sse-toaster-output{height:calc(100vh - 160px);min-height:calc(100vh - 160px);max-height:calc(100vh - 160px)}.sse-toaster-progress-bar-container{width:100%;height:6px;background:#ffffff1a;overflow:hidden}.sse-toaster-progress-bar{height:100%;background:var(--primary-color);transition:width .3s ease;box-shadow:0 0 10px #4ade8080}.sse-toaster-output{padding:1rem;height:450px;min-height:450px;max-height:450px;overflow-y:auto;background:#000;border-radius:0 0 12px 12px}.sse-toaster-output-content{font-family:Modern DOS,Courier New,monospace;font-size:.75rem;line-height:1.4;color:#e5e7eb}.sse-toaster-output::-webkit-scrollbar{width:8px}.sse-toaster-output::-webkit-scrollbar-track{background:#0003;border-radius:4px}.sse-toaster-output::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.sse-toaster-output::-webkit-scrollbar-thumb:hover{background:#ffffff4d}@media(max-width:768px){.sse-toaster{width:calc(100vw - 40px);left:50%!important;right:auto!important;bottom:20px!important;top:auto!important;transform:translate(-50%)!important;animation:none!important}.sse-toaster:not(.dragging):not(.maximized){transition:opacity .3s ease,bottom .3s ease!important}.sse-toaster-header{cursor:default!important}.sse-toaster-output{height:300px;min-height:300px;max-height:300px}.sse-toaster.expanded{max-height:400px}.sse-toaster.maximized{top:60px!important;left:10px!important;right:10px!important;bottom:10px!important;max-height:calc(100vh - 70px);transform:none!important;animation:none!important;width:calc(100vw - 20px)!important}.sse-toaster.maximized .sse-toaster-output{height:calc(100vh - 140px);min-height:calc(100vh - 140px);max-height:calc(100vh - 140px)}}@media(max-width:600px){.sse-toaster-output-content,.output-line-preview{font-size:.65rem}.sse-toaster-label{font-size:.85rem}}.toggle-container{display:flex;justify-content:space-between;align-items:center;gap:1rem;width:100%}.toggle-label-wrapper{flex:1;min-width:0}.toggle-title{color:#e5e7eb;font-size:.95rem;font-weight:500}.toggle-controls{display:flex;align-items:center;gap:.75rem;flex-shrink:0}@media(max-width:768px){.config-grid-inner{grid-template-columns:1fr;gap:1rem}.toggle-container{flex-wrap:wrap;gap:.75rem}.toggle-title{font-size:.9rem}.toggle-controls{gap:.5rem}}@media(max-width:480px){.toggle-container{align-items:flex-start}.toggle-label-wrapper{flex-basis:100%;margin-bottom:.5rem}.toggle-controls{margin-left:0}}.collapsible-content{overflow:hidden}.collapsible-content.collapsed{max-height:0!important}.collapsible-content.expanded{padding-top:1rem;padding-bottom:1rem}@media(min-width:769px){.regenerate-sections-grid{grid-template-columns:1fr 1fr 1fr!important}}@media(max-width:768px){.config-section-description{display:none!important}.breadcrumbs-container{flex-direction:column;align-items:flex-start!important}.breadcrumbs{text-align:left;justify-content:flex-start;width:100%}.breadcrumbs-actions{width:100%;flex-direction:column}.breadcrumbs-actions button{width:100%}}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.breadcrumbs-container{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.breadcrumbs{display:flex;align-items:center;gap:.5rem;font-size:.95rem;flex:1;min-width:0}.breadcrumbs-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.breadcrumb-link{color:var(--primary-color);background:none;border:none;cursor:pointer;padding:0;font-size:.95rem;transition:opacity .2s ease}.breadcrumb-link:hover{opacity:.8;text-decoration:underline}.breadcrumb-separator{color:#6b7280;font-weight:300;-webkit-user-select:none;user-select:none}.breadcrumb-current{color:#e5e7eb;font-weight:500}.settings-page{max-width:1200px;margin:0 auto}.settings-page-header{margin-bottom:2rem}.settings-page-title{color:var(--primary-color);font-size:1.8rem;font-weight:600;margin:0 0 .5rem}.settings-page-description{color:#9ca3af;font-size:1rem;line-height:1.5;margin:0}.push-notifications-grid,.push-notifications-grid .branding-group,.push-notifications-grid .branding-input{width:100%}@media(max-width:768px){.push-notifications-grid{grid-template-columns:1fr!important}}.push-status-indicator{width:8px;height:8px;border-radius:50%;background:#22c55e;animation:pulse 2s ease-in-out infinite}.push-status-buttons .btn-secondary{padding:.4rem .875rem;font-size:.875rem}.push-status-prompt{color:#888;font-size:.95rem}.push-subscribe-btn{padding:.4rem 1rem;font-size:.875rem}@media(max-width:768px){.push-notification-status{flex-direction:column;align-items:stretch;gap:1rem}.push-status-info{justify-content:center}.push-status-buttons{flex-direction:column;gap:.5rem}.push-status-buttons .btn-secondary,.push-subscribe-btn{width:100%}.push-status-prompt{text-align:center}}.smtp-action-buttons{display:flex;gap:.5rem}.smtp-action-buttons .btn-secondary{padding:.4rem .8rem;font-size:.85rem}@media(max-width:768px){.smtp-action-buttons{flex-direction:column;width:100%}.smtp-action-buttons .btn-secondary{width:100%}.smtp-warning-banner{flex-direction:column!important;align-items:stretch!important}.smtp-warning-banner-buttons{width:100%;flex-direction:column!important}.smtp-warning-banner-buttons button{width:100%}.openai-button-group{flex-direction:column!important}.openai-button-group button{width:100%!important}.image-optimization-banner,.video-optimization-banner{flex-direction:column!important;align-items:stretch!important}.notification-events-grid{grid-template-columns:1fr!important}.notification-events-grid>div{min-width:0!important}.notification-event-description{display:block!important;overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important;padding-left:0!important;max-width:100%}.toggle-controls{flex-shrink:0!important;min-width:auto!important}.toggle-controls .toggle-label{font-size:.75rem!important;min-width:35px!important}.regenerate-keys-banner{flex-direction:column!important;align-items:stretch!important}.regenerate-keys-banner button,.image-optimization-banner button,.video-optimization-banner button{width:100%!important}}.quality-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none}.quality-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--primary-color);border:3px solid #fff;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0003}.quality-slider::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 0 8px var(--primary-color)}.quality-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--primary-color);border:3px solid #fff;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0003}.quality-slider::-moz-range-thumb:hover{transform:scale(1.1);box-shadow:0 0 8px var(--primary-color)}.gpu-test-modal{max-width:900px}.gpu-test-output{background:#000;border:1px solid #3a3a3a;border-radius:8px;padding:1.25rem;max-height:500px;min-height:300px;overflow-y:auto;font-family:Modern DOS,Courier New,monospace;font-size:.875rem;line-height:1.6;margin-bottom:1.5rem}.gpu-test-output::-webkit-scrollbar{width:8px}.gpu-test-output::-webkit-scrollbar-track{background:#0003;border-radius:4px}.gpu-test-output::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.gpu-test-output::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.gpu-test-line{margin-bottom:.25rem;color:#ffffffe6;word-wrap:break-word;white-space:pre-wrap}.gpu-test-line.success{color:#4ade80;font-weight:500}.gpu-test-line.error{color:#ef4444;font-weight:500}.gpu-test-line.warning{color:#fbbf24;font-weight:500}.gpu-test-line.testing{color:#ffffff80;margin-top:.75rem;display:flex;align-items:center;gap:.5rem}.gpu-test-line.testing .spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.2);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.gpu-test-actions{display:flex;justify-content:flex-end;gap:.75rem}@media(max-width:768px){.gpu-test-modal{max-width:100%}.gpu-test-output{font-size:.75rem;max-height:400px;min-height:250px;padding:1rem}.gpu-test-actions{flex-direction:column}.gpu-test-actions button{width:100%}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem;overflow-y:auto;-webkit-overflow-scrolling:touch}body:has(.modal-overlay){overflow:hidden}.generic-modal{background-color:#2a2a2a;border:1px solid rgba(255,255,255,.2);border-radius:12px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000080}.generic-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #3a3a3a}.generic-modal-header h2{margin:0;color:#fff;font-size:1.5rem;font-weight:600}.close-button{background:none;border:none;color:#9ca3af;font-size:2rem;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.close-button:hover{background-color:#3a3a3a;color:#fff}.generic-modal-content{padding:1.5rem}.share-description{color:#d1d5db;margin-bottom:1.5rem;line-height:1.6}.video-share-info{background-color:#1e1e1e;border:1px solid #3a3a3a;border-radius:8px;padding:1rem;margin-bottom:1rem}.video-share-title{color:#fff;font-size:1rem;font-weight:600;margin-bottom:.5rem}.video-share-album{color:#9ca3af;font-size:.875rem}.share-loading{text-align:center;color:#9ca3af;padding:2rem;font-size:.9375rem}.share-link-container{display:flex;gap:.5rem;align-items:stretch;margin-top:1rem}.share-link-input{flex:1;padding:.75rem;background-color:#1e1e1e;border:1px solid #3a3a3a;border-radius:8px;color:#fff;font-size:.875rem;font-family:SF Mono,Monaco,Cascadia Code,Courier New,monospace;word-break:break-all}.share-link-input:focus{outline:none;border-color:#4ade80;box-shadow:0 0 0 3px #4ade801a}.custom-expiration-input{display:flex;gap:.5rem;margin-top:1rem;margin-bottom:1rem}.custom-expiration-input input{flex:1;padding:.75rem;background-color:#1e1e1e;border:1px solid #3a3a3a;border-radius:8px;color:#fff;font-size:1rem}.custom-expiration-input input:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.custom-expiration-input button{padding:.75rem 1.5rem;background-color:#8b5cf6;color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.custom-expiration-input button:hover{background-color:#7c3aed;transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf666}.custom-expiration-input button:active{transform:translateY(0)}.expiration-selector{margin-bottom:1.5rem}.expiration-selector label{display:block;color:#e5e7eb;font-weight:500;margin-bottom:.5rem}.expiration-selector select{width:100%;padding:.75rem;background-color:#1e1e1e;border:1px solid #3a3a3a;border-radius:8px;color:#fff;font-size:1rem;cursor:pointer;transition:border-color .2s ease}.expiration-selector select:hover{border-color:#4ade80}.expiration-selector select:focus{outline:none;border-color:#4ade80;box-shadow:0 0 0 3px #4ade801a}.share-error{background-color:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:.75rem;border-radius:8px;margin-bottom:1rem}.share-success-inline{padding:.75rem;background:#4ade801a;border:1px solid rgba(74,222,128,.3);border-radius:8px;color:#4ade80;margin-bottom:1rem;text-align:center;font-weight:500}.copy-link-button{width:100%;padding:.875rem;background-color:#8b5cf6;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:1rem}.copy-link-button:hover:not(:disabled){background-color:#7c3aed;transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf666}.copy-link-button:active:not(:disabled){transform:translateY(0)}.copy-link-button:disabled{opacity:.5;cursor:not-allowed}.custom-minutes-input{margin-top:1rem}.custom-minutes-input label{display:block;color:#e5e7eb;font-weight:500;margin-bottom:.5rem}.custom-input-group{display:flex;gap:.5rem}.custom-input-group input{flex:1;padding:.75rem;background-color:#1e1e1e;border:1px solid #3a3a3a;border-radius:8px;color:#fff;font-size:1rem}.custom-input-group input:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.apply-custom-button{padding:.75rem 1.5rem;background-color:#8b5cf6;color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.apply-custom-button:hover:not(:disabled){background-color:#7c3aed;transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf666}.apply-custom-button:disabled{opacity:.5;cursor:not-allowed}.share-success{text-align:center;margin-bottom:1.5rem}.success-icon{font-size:3rem;color:#4ade80;margin-bottom:.5rem}.share-success p{color:#e5e7eb;font-size:1.1rem;margin:0}.share-link-info{background-color:#1e1e1e;border:1px solid #3a3a3a;border-radius:8px;padding:1rem;margin-bottom:1.5rem}.share-link-label{color:#9ca3af;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.share-link-url{display:flex;gap:.5rem}.share-link-url input{flex:1;padding:.75rem;background-color:#2a2a2a;border:1px solid #3a3a3a;border-radius:6px;color:#fff;font-size:.875rem;font-family:SF Mono,Monaco,Cascadia Code,Courier New,monospace}.share-link-url input:focus{outline:none;border-color:#4ade80;box-shadow:0 0 0 3px #4ade801a}.copy-button{padding:.75rem 1.5rem;background-color:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.copy-button:hover{background-color:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.copy-button:active{transform:translateY(0)}.copy-button.copied{background-color:#4ade80;color:#1e1e1e}.share-details{background-color:#1e1e1e;border:1px solid #3a3a3a;border-radius:8px;padding:1rem;margin-bottom:1.5rem}.share-detail{color:#d1d5db;padding:.5rem 0}.share-detail:not(:last-child){border-bottom:1px solid #3a3a3a}.share-detail strong{color:#e5e7eb;margin-right:.5rem}.share-actions{display:flex;gap:.75rem;flex-wrap:wrap}.generic-modal-actions .done-button{padding:.875rem;border:1px solid rgba(255,255,255,.1);background-color:#ffffff0d;color:#ffffffb3;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:100px}.generic-modal-actions .done-button:hover{background-color:#ffffff1a;color:#fff;border-color:#fff3;transform:translateY(-1px)}.new-link-button{background-color:#3a3a3a;color:#fff}.new-link-button:hover{background-color:#4a4a4a;transform:translateY(-1px)}.done-button:active,.new-link-button:active{transform:translateY(0)}@media(max-width:768px){.security-setup-modal{max-height:calc(91vh - 54px)}}.video-list-view{display:flex;flex-direction:column;gap:48px;max-width:1024px;margin:0 auto;padding:74px 20px 20px;width:100%}.video-list-item{display:flex;flex-direction:column;gap:16px;width:100%}.video-player-wrapper{overflow:hidden;background:#000;border:1px solid rgba(255,255,255,.2);display:flex;justify-content:center;align-items:center}.video-player-container{position:relative;width:100%;max-height:85vh;display:flex;justify-content:center;align-items:center}.video-player-container img{width:100%;height:auto;max-height:85vh;object-fit:contain;display:block}.video-player-container.playing img{opacity:0!important}.modal-video-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;z-index:5;background:transparent}.video-play-button-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000b3;border:none;border-radius:50%;width:100px;height:100px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;z-index:10;color:#fff}.video-play-button-overlay:hover{background:#000000d9;transform:translate(-50%,-50%) scale(1.1)}.video-play-button-overlay:active{transform:translate(-50%,-50%) scale(.95)}.video-info{display:flex;flex-direction:column;gap:12px}.video-header{display:flex;justify-content:space-between;align-items:center;gap:16px}.video-title{font-size:1.5rem;font-weight:600;color:#fff;margin:0;flex:1;line-height:1.4;min-width:0;word-wrap:break-word}.video-share-button{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:#fff;font-size:.9rem;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.video-share-button:hover{background:#ffffff26;border-color:#ffffff4d}.video-share-button:active{transform:scale(.98)}.video-share-text{font-weight:500}.video-description{font-size:1rem;color:#fffc;line-height:1.6;margin:0;white-space:pre-wrap}@media(max-width:768px){.video-list-view{gap:32px;padding:74px 16px 16px}.video-title{font-size:1.1rem}.video-header{flex-direction:row;align-items:center;gap:12px}.video-share-button{padding:6px 12px;font-size:.85rem;gap:6px;min-width:fit-content}.video-share-button svg{width:16px;height:16px}.video-description{font-size:.9rem}}@media(max-width:600px){.video-list-view{padding-top:0}}.password-input-wrapper{position:relative;display:flex;align-items:center;width:100%}.password-input-wrapper input{flex:1;padding-right:80px}.password-input-buttons{position:absolute;right:8px;display:flex;gap:4px;align-items:center}.password-toggle-btn,.password-copy-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:4px;padding:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;color:#9ca3af}.password-toggle-btn:hover,.password-copy-btn:hover{background:#ffffff1a;border-color:#fff3;color:var(--primary-color)}.password-toggle-btn:active,.password-copy-btn:active{transform:scale(.95)}.password-toggle-btn svg,.password-copy-btn svg{display:block}@media(max-width:768px){.password-input-wrapper input{padding-right:75px}.password-toggle-btn,.password-copy-btn{padding:5px}.password-toggle-btn svg,.password-copy-btn svg{width:16px;height:16px}}.photos-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000059;opacity:0;animation:fadeIn .4s cubic-bezier(.4,0,.2,1) forwards;z-index:1000}.photos-modal-backdrop.closing{animation:fadeOut .3s cubic-bezier(.4,0,.6,1) forwards}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.photos-modal{position:fixed;top:54px;left:50%;transform:translate(-50%);width:100%;max-width:1024px;height:calc(100vh - 54px);max-height:calc(100vh - 54px);background:#1a1a1a;border-left:1px solid #444;border-right:1px solid #444;box-shadow:0 4px 24px #0006;z-index:1001;display:flex;flex-direction:column;overflow:hidden;animation:flipUp .4s cubic-bezier(.4,0,.2,1) forwards}.photos-modal.closing{animation:flipDown .3s cubic-bezier(.4,0,.6,1) forwards}@keyframes flipUp{0%{opacity:0;transform:translate(-50%) translateY(100%) rotateX(-15deg)}to{opacity:1;transform:translate(-50%) translateY(0) rotateX(0)}}@keyframes flipDown{0%{opacity:1;transform:translate(-50%) translateY(0) rotateX(0)}to{opacity:0;transform:translate(-50%) translateY(100%) rotateX(15deg)}}.photos-modal.drag-over{border:1px solid var(--primary-color);background:#4ade8008}.photos-modal-content{flex:1;overflow-y:auto;overflow-x:hidden;background-color:#111;min-height:0}.photos-grid{padding:1.5rem 1.5rem 2rem}.photos-modal-header{background:#1f1f1f;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0}.photos-title-bar{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.06)}.photos-title-left{display:flex;align-items:center;gap:1rem;flex:1;min-width:0}.photos-title-right{display:flex;align-items:center;gap:.75rem;flex:0 0 auto}.publish-toggle-titlebar{flex:0 0 auto!important}.mobile-toggles-stack{display:flex;flex-direction:row;align-items:center;gap:.75rem;flex:0 0 auto}.homepage-toggle-mobile{flex:0 0 auto!important}.toggle-switch-mobile-vertical{flex-direction:column;align-items:center;gap:.25rem;cursor:pointer;position:relative;margin-top:.5rem}.toggle-switch-mobile-vertical input[type=checkbox]{opacity:0;width:0;height:0;position:absolute}.toggle-switch-mobile-vertical .toggle-slider{position:relative;display:block;width:36px;height:20px;background-color:#374151;border-radius:20px;transition:background-color .3s ease}.toggle-switch-mobile-vertical .toggle-slider:before{content:"";position:absolute;width:18px;height:18px;left:1px;top:50%;transform:translateY(-50%);background-color:#9ca3af;border-radius:50%;transition:transform .3s ease,background-color .3s ease}.toggle-switch-mobile-vertical input[type=checkbox]:checked+.toggle-slider{background-color:#22c55e4d}.toggle-switch-mobile-vertical input[type=checkbox]:checked+.toggle-slider:before{transform:translate(17px) translateY(-50%);background-color:#4ade80}.toggle-switch-mobile-vertical .toggle-label-below{font-size:.75rem;font-weight:500;color:#9ca3af;white-space:nowrap;text-align:center}.toggle-switch-mobile-vertical input[type=checkbox]:checked~.toggle-label-below{color:#4ade80}.photos-modal-title{font-size:1.5rem;font-weight:600;color:#fff;margin:0;margin-bottom:0!important;letter-spacing:-.02em}.photos-modal-title.editable{cursor:pointer;transition:color .2s ease}.photos-modal-title.editable:hover{color:var(--primary-color)}.photos-count{font-size:.9rem;color:#888;font-weight:400;white-space:nowrap;flex-shrink:0}.album-title-edit-container{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.album-title-input{flex:1;background:#ffffff0d;border:1px solid rgba(255,255,255,.2);border-radius:6px;padding:.5rem .75rem;font-size:1.25rem;font-weight:600;color:#fff;outline:none;transition:all .2s ease}.album-title-input:focus{background:#ffffff14;border-color:var(--primary-color);box-shadow:0 0 0 3px #4ade801a}.album-title-input:disabled{opacity:.5;cursor:not-allowed}.album-title-edit-actions{display:flex;gap:.5rem;flex-shrink:0}.album-title-btn{padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;border:none;cursor:pointer;transition:all .2s ease;white-space:nowrap}.album-title-btn:disabled{opacity:.5;cursor:not-allowed}.album-title-btn-save{background:var(--primary-color);color:#000}.album-title-btn-save:hover:not(:disabled){background:#22c55e;box-shadow:0 0 0 3px #4ade8033}.album-title-btn-cancel{background:#ffffff1a;color:#fff}.album-title-btn-cancel:hover:not(:disabled){background:#ffffff26}@media(max-width:740px){.mobile-toggles-stack.hidden-mobile{display:none}.photos-close-btn.hidden-when-editing{display:none!important}.album-title-edit-container{gap:.5rem}.album-title-input{font-size:1rem;padding:.4rem .6rem;min-width:0;flex:1 1 auto}.album-title-edit-actions{gap:.4rem;flex-shrink:0}.album-title-btn{padding:.4rem .75rem;font-size:.8125rem}}.photos-close-btn{background:transparent;border:none;color:#888;cursor:pointer;padding:.5rem;border-radius:6px;transition:all .2s ease;display:flex!important;align-items:center;justify-content:center;flex:0 0 auto}.photos-close-btn:hover{background:#ffffff14;color:#fff}.photos-controls-bar{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;gap:1rem;background-color:#1b1b1b}.photos-controls-left,.photos-controls-right{display:flex;align-items:center;gap:.75rem;flex:1}.photos-controls-right{justify-content:flex-end}.photos-controls-left .photos-btn,.photos-controls-right .photos-btn{flex:1;min-width:0}.photos-action-buttons{display:flex;gap:.5rem}.toggle-switch.compact{margin:0}.photos-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1rem;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:1px solid transparent;white-space:nowrap;box-sizing:border-box;line-height:1}label.photos-btn{margin:0;line-height:1}.photos-btn:disabled{opacity:.5;cursor:not-allowed}.photos-btn-primary{background:var(--primary-color);color:#000;border-color:var(--primary-color)}.photos-btn-primary:hover:not(:disabled){background:#5eeb8f;transform:translateY(-1px);box-shadow:0 4px 12px #4ade804d}.photos-btn-secondary{background:#ffffff0f;color:#fff;border-color:#ffffff1f}.photos-btn-secondary:hover:not(:disabled){background:#ffffff1a;border-color:#fff3;transform:translateY(-1px)}.photos-btn-danger{background:#ef44441f;color:#ef4444;border-color:#ef44444d}.photos-btn-danger:hover:not(:disabled){background:#ef444433;border-color:#ef444480;transform:translateY(-1px)}.photos-btn-success{background:var(--primary-color);color:#000;border-color:var(--primary-color)}.photos-btn-success:hover:not(:disabled){background:#5eeb8f;transform:translateY(-1px)}.photos-btn-ghost{background:transparent;color:#888;border-color:#ffffff1f}.photos-btn-ghost:hover:not(:disabled){background:#ffffff0d;color:#fff;border-color:#fff3}.view-toggle{display:flex;gap:0;background:#ffffff0a;border-radius:8px;padding:.25rem;border:1px solid rgba(255,255,255,.08);flex:0 0 auto!important;width:fit-content!important}.view-toggle-btn{padding:.5rem;background:transparent;border:none;color:#666;cursor:pointer;border-radius:6px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.view-toggle-btn:hover{background:#ffffff14;color:#aaa}.view-toggle-btn.active{background:#ffffff1f;color:var(--primary-color)}.photos-reorder-bar{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;background:#1f1f1f;border-top:1px solid rgba(255,255,255,.08);box-shadow:0 -4px 12px #00000080;flex-shrink:0;animation:slideUp .2s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.photos-reorder-left,.photos-reorder-right{display:flex;align-items:center;gap:.75rem}.reorder-hint{font-size:.85rem;color:#aaa}.reorder-hint-desktop{display:inline}.reorder-hint-mobile{display:none}.publish-toggle-titlebar{display:none!important}.publish-toggle-controlbar{display:flex}.homepage-toggle-mobile{display:none!important}.homepage-toggle-desktop{display:flex}@media(max-width:500px){.photos-count{display:none}.album-title-edit-container{gap:.4rem}.album-title-input{font-size:.9375rem;padding:.375rem .5rem}.album-title-btn{padding:.375rem .625rem;font-size:.75rem}}@media(max-width:740px){.photos-modal{height:calc(100vh - 54px);height:calc(100dvh - 54px)}.publish-toggle-titlebar{display:flex!important}.publish-toggle-controlbar{display:none!important}.homepage-toggle-mobile{display:flex!important}.homepage-toggle-desktop{display:none!important}.toggle-switch-mobile-vertical{display:flex!important}.photos-controls-bar{flex-direction:column;align-items:stretch;gap:0rem}.photos-controls-left,.photos-controls-right{width:100%;flex-wrap:wrap}.photos-controls-right{justify-content:stretch}.photos-controls-right:empty{display:none}.photos-btn{padding:.6rem .8rem;font-size:.85rem}.photos-btn span{display:none}.photos-action-buttons{display:flex;gap:.5rem;width:100%}.photos-action-buttons button{flex:1}.view-toggle{width:fit-content!important;flex-shrink:0}}@media(max-width:500px){.photos-reorder-bar{flex-wrap:wrap;gap:.75rem;align-items:stretch}.photos-reorder-bar .photos-btn span{display:inline}.photos-reorder-left,.photos-reorder-right{width:100%;justify-content:space-between}.photos-reorder-left .photos-btn,.photos-reorder-right .photos-btn{flex:1;min-width:0}.reorder-hint-desktop{display:none}.reorder-hint-mobile{display:block;width:100%;text-align:center;order:3;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.06)}.photos-reorder-left{order:1}.photos-reorder-right{order:2}}.albums-management{display:flex;flex-direction:column;gap:2rem}.create-album-section{display:grid;grid-template-columns:1fr 320px;gap:1.5rem;align-items:stretch;margin-bottom:2.5rem}@media(max-width:968px){.create-album-section{grid-template-columns:1fr;gap:1.5rem}}.create-album{background:linear-gradient(135deg,#ffffff0d,#ffffff05);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.5rem;transition:all .3s ease}.create-album:hover{border-color:#ffffff26;box-shadow:0 8px 24px #0003}.create-album h3,.albums-list h3{color:#fff;font-size:1.1rem;margin-bottom:1rem;font-weight:600;display:flex;align-items:center;gap:.5rem;letter-spacing:-.01em}.create-album h3:before{content:"✨";font-size:1.2rem}.albums-list h3{padding-bottom:.625rem;border-bottom:1px solid rgba(255,255,255,.08)}.albums-list h3:before{content:"📚";font-size:1.2rem}.album-input-group{display:flex;gap:.75rem;align-items:stretch}.album-input-group input{flex:1}.album-card{position:relative;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.album-card.unpublished{opacity:.7;border-color:#fbbf244d!important;background:linear-gradient(135deg,#fbbf2414,#fbbf2405)!important}.album-publish-toggle{display:flex;justify-content:flex-end;width:100%}.unpublished-badge{font-size:.9rem;margin-left:.5rem;opacity:.8}.toggle-switch{position:relative;display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-switch input{position:absolute;opacity:0;width:0;height:0}.toggle-slider{position:relative;width:44px;height:24px;background-color:#ffffff1a;border-radius:24px;transition:all .3s ease;border:1px solid rgba(255,255,255,.15)}.toggle-slider:before{content:"";position:absolute;width:18px;height:18px;left:2px;top:2px;background-color:#fff;border-radius:50%;transition:all .3s ease;box-shadow:0 2px 4px #0003}.toggle-switch input:checked+.toggle-slider{background-color:#4ade80;border-color:#4ade80}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.toggle-switch:hover .toggle-slider{box-shadow:0 0 8px #4ade804d}.toggle-label{font-size:.85rem;color:#fffc;font-weight:500;min-width:50px;text-align:right}.toggle-switch input:checked~.toggle-label{color:#4ade80}.main-drop-zone{background:linear-gradient(135deg,#4ade8014,#4ade8008);border:1px dashed rgba(74,222,128,.3);border-radius:16px;padding:2rem 1.5rem;min-height:180px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;transition:all .3s ease;cursor:pointer;position:relative;overflow:hidden}.main-drop-zone:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 50%,rgba(74,222,128,.15) 0%,transparent 70%);opacity:0;transition:opacity .3s ease}.main-drop-zone:hover:before{opacity:1}.main-drop-zone:hover{background:linear-gradient(135deg,#4ade801f,#4ade800d);border-color:#4ade8080;transform:translateY(-2px);box-shadow:0 8px 24px #4ade8026}.main-drop-zone.dragging{background:linear-gradient(135deg,#4ade8033,#4ade801a);border-color:var(--primary-color);border-style:solid;border-width:3px;transform:scale(1.03);box-shadow:0 12px 32px #4ade8040}.main-drop-zone.dragging:before{opacity:1}.main-drop-zone.disabled{opacity:.5;cursor:not-allowed;pointer-events:none;background:#ffffff03;border-color:#ffffff14}.main-drop-zone.disabled .drop-zone-icon{opacity:.3}.main-drop-zone.disabled .drop-zone-text strong,.main-drop-zone.disabled .drop-zone-hint{color:#6b7280}@media(max-width:640px){.main-drop-zone{display:none}}.drop-zone-icon{font-size:3.5rem;opacity:.9;transition:transform .3s ease;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}.main-drop-zone:hover .drop-zone-icon{transform:scale(1.1)}.main-drop-zone.dragging .drop-zone-icon{animation:bounce .6s ease-in-out infinite alternate;transform:scale(1.15)}.drop-zone-text{display:flex;flex-direction:column;align-items:center;gap:.5rem;text-align:center;position:relative;z-index:1}.drop-zone-text strong{color:#fff;font-size:1.05rem;font-weight:600;letter-spacing:-.02em}.drop-zone-hint{color:#a8a8a8;font-size:.875rem;line-height:1.4}.album-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-top:1.25rem;isolation:isolate}@media(max-width:1200px){.album-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}}@media(max-width:768px){.album-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.875rem}}.album-card{background:linear-gradient(135deg,#ffffff0f,#ffffff05);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:1rem 1.125rem;cursor:pointer;transition:border-color .3s,background .3s,box-shadow .3s,opacity .3s,height .3s;position:relative;overflow:hidden;display:flex;flex-direction:column;transform-style:preserve-3d;min-height:60px;height:auto;box-sizing:border-box}.album-card.animating{animation:flipCard .6s ease-in-out;pointer-events:none}@keyframes flipCard{0%{transform:rotateY(0) scale(1)}50%{transform:rotateY(90deg) scale(1.05);box-shadow:0 20px 40px #00000080}to{transform:rotateY(0) scale(1)}}.album-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary-color),color-mix(in srgb,var(--primary-color) 70%,white));opacity:0;transition:opacity .3s ease}@media(hover:hover)and (pointer:fine){.album-card:hover{background:linear-gradient(135deg,#ffffff14,#ffffff0a);border-color:#fff3;box-shadow:0 12px 32px #0000004d}.album-card:hover:before{opacity:1}}.album-card.selected{border-color:var(--primary-color);background:linear-gradient(135deg,color-mix(in srgb,var(--primary-color) 15%,transparent),color-mix(in srgb,var(--primary-color) 8%,transparent));box-shadow:0 8px 24px color-mix(in srgb,var(--primary-color) 20%,transparent)}.album-card.selected:before{opacity:1}.album-card-header{display:flex;justify-content:space-between;align-items:start;gap:.5rem;margin-bottom:.5rem}.album-card h4{color:#fff;margin:0;font-size:1.05rem;font-weight:600;word-break:break-word;overflow-wrap:break-word;letter-spacing:-.01em;display:flex;align-items:center;gap:.5rem;line-height:1.3;flex:1;min-width:0}.album-card h4 .album-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.album-rename-btn{position:absolute;top:.5rem;right:.5rem;display:inline-flex;align-items:center;justify-content:center;background:#0009;border:1px solid rgba(255,255,255,.3);border-radius:6px;padding:.5rem;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10}@media(min-width:769px){.album-rename-btn{display:none}.album-card:hover .album-rename-btn{display:inline-flex}}.album-rename-btn:hover{background:#000c;border-color:#ffffff80;transform:scale(1.1)}.album-rename-btn svg{display:block;stroke:#fff}.btn-delete-small{background:#dc35451a;border:1px solid rgba(220,53,69,.3);color:#ef4444;width:28px;height:28px;border-radius:5px;font-size:1.4rem;line-height:1;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0;opacity:.7}.btn-delete-small:hover{background:#dc3545;color:#fff;border-color:#dc3545;opacity:1;transform:scale(1.05);box-shadow:0 4px 12px #dc35454d}.album-badge{padding:.25rem .5rem;background:linear-gradient(135deg,var(--primary-color),color-mix(in srgb,var(--primary-color) 80%,white));color:#000;border-radius:5px;font-size:.7rem;font-weight:700;display:inline-flex;align-items:center;gap:.3rem;box-shadow:0 2px 6px color-mix(in srgb,var(--primary-color) 30%,transparent);white-space:nowrap;flex-shrink:0}.album-badge:before{content:"📷";font-size:.8rem}.album-photos{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.9);width:90vw;max-width:1400px;height:85vh;max-height:900px;background:#1e1e1e;border-radius:12px;box-shadow:0 20px 60px #00000080;z-index:1001;overflow-y:auto;animation:modalFadeIn .2s ease-out forwards}@keyframes modalFadeIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.album-photos-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000b3;z-index:1000;animation:fadeIn .2s ease-out forwards}.album-photos.drag-over{border-color:var(--primary-color);border-width:1px;background:#4ade800d}@media(max-width:768px){.album-photos{width:95vw;height:90vh;max-height:none;border-radius:16px}.album-controls-row{flex-wrap:wrap;gap:.75rem}.album-controls-row .btn-action .btn-text{display:none}.album-controls-row .btn-action{padding:.5rem;min-width:40px;justify-content:center}}.drop-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#000000d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:8px;display:flex;align-items:center;justify-content:center;z-index:100;pointer-events:none}.drop-overlay-content{text-align:center;color:var(--primary-color)}.drop-icon{font-size:4rem;margin-bottom:1rem;animation:bounce .6s ease-in-out infinite alternate}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-10px)}}.drop-overlay-content p{font-size:1.5rem;font-weight:600;margin:0;text-shadow:0 2px 4px rgba(0,0,0,.5)}.photos-header{display:flex;flex-direction:column;gap:1rem;padding:1.5rem;background:#1e1e1e;border-bottom:1px solid rgba(255,255,255,.1);position:sticky;top:0;z-index:10}.photos-header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.photos-panel-title{color:#fff;font-size:1.3rem;margin:0;font-weight:600}.album-controls-row{display:flex;align-items:center;gap:1rem;padding:.75rem 0;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:1rem}.album-controls-row .toggle-switch{margin:0}.album-controls-row .btn-action{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:#fff;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.album-controls-row .btn-action:hover{background:#ffffff1f;border-color:#ffffff40;transform:translateY(-1px)}.album-controls-row .btn-preview{background:#3b82f626;border-color:#3b82f64d}.album-controls-row .btn-preview:hover{background:#3b82f640;border-color:#3b82f680}.album-controls-row .btn-generate-link{background:#f9731626;border-color:#f973164d}.album-controls-row .btn-generate-link:hover{background:#f9731640;border-color:#f9731680}.view-toggle{display:flex;gap:.25rem;background:#ffffff0d;border-radius:6px;padding:.25rem;margin-left:auto}.view-toggle-btn{padding:.4rem .6rem;background:transparent;border:none;color:#888;cursor:pointer;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.view-toggle-btn:hover{background:#ffffff14;color:#fff}.view-toggle-btn.active{background:#ffffff1f;color:#fff}.photos-panel-close-btn{background:transparent;border:none;color:#fff;font-size:2rem;line-height:1;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.photos-panel-close-btn:hover{background:#ffffff1a;transform:scale(1.1)}.photos-header h3{color:#fff;font-size:1.3rem;margin:0;font-weight:600;letter-spacing:-.02em;display:flex;align-items:center;gap:.5rem}.album-actions-grid{display:flex;flex-direction:row;flex-wrap:wrap;gap:.5rem;width:100%;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.btn-action-item{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1rem;min-width:40px;height:40px}@media(max-width:768px){.album-actions-grid{gap:.5rem}.btn-action-item{padding:.6rem;min-width:44px;flex:1;height:44px;gap:0}.btn-action-item:not(.toggle-switch){width:44px;flex:0 0 44px}.btn-action-item svg{width:20px!important;height:20px!important}.btn-action-item .btn-text{display:none}.toggle-switch.btn-action-item{width:100%;flex:1 1 100%;padding:.75rem 1rem}.toggle-switch.btn-action-item .toggle-label{display:inline}}.toggle-switch.btn-action-item{background:#ffffff0d;padding:.75rem 1.5rem;border-radius:8px;border:1px solid rgba(255,255,255,.15);transition:all .2s ease;cursor:pointer}.toggle-switch.btn-action-item:hover{background:#ffffff14;border-color:#fff3;transform:translateY(-1px)}.btn-action{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1rem;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:1px solid;background:#ffffff0d;color:#fff}.btn-action:disabled{opacity:.5;cursor:not-allowed}.btn-action svg{width:16px;height:16px;flex-shrink:0}.btn-action.btn-preview{border-color:#4ade804d;color:#4ade80}.btn-action.btn-preview:hover{background:#4ade801a;border-color:#4ade80;transform:translateY(-1px);box-shadow:0 4px 12px #4ade8033}.btn-action.btn-generate-link{border-color:#8b5cf64d;color:#a78bfa}.btn-action.btn-generate-link:hover{background:#8b5cf61a;border-color:#8b5cf6;transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf633}.btn-action.btn-delete{border-color:#dc35454d;color:#ef4444}.btn-action.btn-delete:hover{background:#dc35451a;border-color:#dc3545;transform:translateY(-1px);box-shadow:0 4px 12px #dc354533}.btn-action.btn-upload{border-color:#4ade8066;background:#4ade8014;color:#4ade80}.btn-action.btn-upload:hover{background:#4ade8026;border-color:#4ade80;transform:translateY(-1px);box-shadow:0 4px 12px #4ade8033}.photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;--shuffle-columns: 5;transition:grid-template-columns .3s ease,gap .3s ease}.photos-grid.shuffling-grid{grid-template-columns:repeat(var(--shuffle-columns, 5),1fr);gap:.5rem}@media(min-width:1400px){.photos-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}@media(max-width:768px){.photos-grid{grid-template-columns:repeat(3,1fr);gap:.75rem}}.photos-list{display:flex;flex-direction:column;gap:0;-webkit-user-select:none;user-select:none;overflow-y:auto}.list-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1.5rem;min-height:76px;border-bottom:1px solid #2e2e2e;background:#161616;transition:background .15s ease;cursor:grab;touch-action:pan-y;-webkit-user-select:none;user-select:none}.list-item:hover{background:#232323}.list-item:active{cursor:grabbing}.list-item:last-child{border-bottom:none}.list-item.deleting{animation:crtDelete .8s cubic-bezier(.4,0,.2,1) forwards}.list-item.shuffling-active{transition:transform .2s ease!important}.list-item-thumbnail{position:relative;flex-shrink:0;width:60px;height:60px;border-radius:6px;overflow:hidden;border:1px solid rgba(95,95,95,.42);transition:border-color .2s ease}.list-item:hover .list-item-thumbnail{border-color:var(--primary-color)}.list-item-thumbnail img{width:100%;height:100%;object-fit:cover;display:block}.thumbnail-placeholder{width:100%;height:100%;background:#1a1a1a}.list-item-title{flex:1;min-width:0}.title-text{font-size:1rem;color:#cfcfcf;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-text{font-size:.75rem;color:#9ca3af;margin-top:.25rem}.list-item-actions{flex-shrink:0;display:flex;gap:.5rem}.list-action-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:4px;cursor:pointer;transition:all .2s ease;padding:0}.list-action-btn:not(.delete){background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:var(--primary-color)}.list-action-btn:not(.delete):hover{background:var(--primary-color);color:#000;border-color:var(--primary-color);transform:scale(1.1)}.list-action-btn.delete{background:#dc3545;border:none;color:#fff}.list-action-btn.delete:hover{background:#c82333;transform:scale(1.1)}.photos-list .photo-error-badge{display:none!important}.photos-list .admin-photo-item:last-child>*{border-bottom:none!important}.photos-grid .photo-info{display:none}.admin-photo-item{position:relative;width:100%;padding-bottom:100%;border-radius:12px;overflow:hidden;background:#ffffff08;border:1px solid rgba(95,95,95,.42);transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0003;touch-action:pan-y;-webkit-user-select:none;user-select:none}.photos-modal-content.is-dragging .admin-photo-item,.photos-modal-content.is-dragging .list-item{touch-action:none!important}@media(hover:hover)and (pointer:fine){.photos-grid .admin-photo-item:hover{transform:translateY(-4px) scale(1.02);border-color:#fff3;box-shadow:0 8px 24px #0000004d}.photos-grid .admin-photo-item:hover .photo-overlay{opacity:1}}@media(hover:none)and (pointer:coarse){.admin-photo-item.show-overlay{transform:scale(1.02);border-color:#fff3;box-shadow:0 8px 24px #0000004d;transition:all .2s cubic-bezier(.4,0,.2,1)}}@media(hover:none)and (pointer:coarse){.photo-overlay{opacity:0!important;pointer-events:none!important;transition:opacity .2s ease}.photo-overlay button{pointer-events:none!important}.admin-photo-item.show-overlay .photo-overlay{opacity:1!important;pointer-events:none!important}.admin-photo-item.show-overlay .photo-overlay .photo-actions,.admin-photo-item.show-overlay .photo-overlay button{pointer-events:auto!important}.admin-photo-item.show-overlay .admin-photo-thumbnail{pointer-events:none}}.admin-photo-thumbnail{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;display:block;opacity:1!important;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.admin-photo-item img{opacity:1!important;object-fit:cover}.video-icon-overlay{position:absolute;bottom:8px;right:8px;background:#000000b3;border-radius:4px;padding:4px 6px;display:flex;align-items:center;justify-content:center;color:#fff;z-index:2;pointer-events:none}.photo-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:.75rem;opacity:0;transition:opacity .2s ease;z-index:10;pointer-events:none}.photo-overlay button{pointer-events:none}.admin-photo-item:hover .photo-overlay,.admin-photo-item:hover .photo-overlay button{pointer-events:auto}.btn-delete-photo{background:#dc3545;border:none;color:#fff;width:32px;height:32px;border-radius:4px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;padding:0;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.btn-delete-photo:hover{background:#c82333;transform:scale(1.1)}.status-indicator{width:8px;height:8px;border-radius:50%;background-color:var(--primary-color);animation:pulse 2s infinite}.status-indicator.online{background-color:var(--primary-color)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.admin-user-email{color:#888;margin:0;font-size:.9rem}.message{padding:1rem;margin-bottom:1.5rem;border-radius:4px;font-size:.95rem}.message-success{background-color:#1a4d2e;color:var(--primary-color);border:1px solid var(--primary-color)}.message-error{background-color:#4d1a1a;color:#f87171;border:1px solid #dc2626}.admin-section{margin-bottom:3rem;background:linear-gradient(135deg,#ffffff08,#ffffff03);border-radius:16px;padding:2.5rem;border:1px solid rgba(255,255,255,.08);box-shadow:0 4px 16px #0003;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}@media(max-width:768px){.admin-section{padding:1rem;border-radius:8px;margin-bottom:1.5rem}.admin-section h2{font-size:1.3rem}}@media(max-width:480px){.admin-section{padding:.75rem;border-radius:6px;margin-bottom:1rem}.admin-section h2{font-size:1.2rem}}.admin-section h2{color:#fff;font-size:1.75rem;margin-bottom:.5rem;font-weight:500;display:flex;align-items:center;gap:.75rem;letter-spacing:-.03em}.admin-section h2:before{content:"";width:5px;height:32px;background:linear-gradient(180deg,var(--primary-color),color-mix(in srgb,var(--primary-color) 70%,black));border-radius:3px;flex-shrink:0;box-shadow:0 2px 8px color-mix(in srgb,var(--primary-color) 40%,transparent)}.section-description{color:#b4b4b4;font-size:1.05rem;line-height:1.6;max-width:800px}.photo-optimizing{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#ffffff0d;gap:.5rem;font-size:.875rem;color:#888}.uploading-placeholder{background:#000!important}.spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0;aspect-ratio:1 / 1}.progress-circle{position:relative;display:flex;align-items:center;justify-content:center}.progress-ring{transform:rotate(-90deg)}.progress-ring-circle{transition:stroke-dashoffset .3s ease}.progress-percentage{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1rem;font-weight:700;color:var(--primary-color)}.optimization-settings{background:linear-gradient(135deg,#2d2d2d,#262626);border:1px solid #535353;border-radius:12px;padding:1.25rem;margin-bottom:1.25rem;box-shadow:0 4px 12px #0000004d;transition:all .2s ease;overflow:visible}.optimization-settings:hover{box-shadow:0 8px 24px #0006;border-color:#4b5563}.optimization-settings h3{margin:0 0 1rem;font-size:1.15rem;color:#f9fafb;font-weight:700;letter-spacing:-.025em}.optimization-settings input[type=number],.optimization-settings label{color:#d1d5db}.optimization-settings input[type=number]{padding:.75rem 1rem;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#fff;font-size:1rem;transition:all .2s ease;font-family:inherit}.optimization-settings input[type=number]:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary-color) 10%,transparent);background:#00000080}.optimization-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-bottom:1.5rem}.optimization-group{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);padding:1.5rem;border-radius:8px}.optimization-group h4{color:#f9fafb;margin:0 0 1rem;font-size:1rem;font-weight:600}.optimization-group .form-group{margin-bottom:1rem}.optimization-group .form-group:last-child{margin-bottom:0}.optimization-group label{display:block;margin-bottom:.5rem;color:#e5e7eb;font-size:.95rem;font-weight:500}.optimization-group input[type=number]{width:100%;padding:.75rem 1rem;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#fff;font-size:1rem;transition:all .2s ease;font-family:inherit}.optimization-group input[type=number]:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary-color) 10%,transparent);background:#00000080}.optimization-group input[type=number]::placeholder{color:#6b7280}.output-console{background:#000;color:#d1d5db;padding:1rem;border-radius:4px;font-family:Modern DOS,Monaco,Menlo,Ubuntu Mono,Consolas,source-code-pro,monospace;font-size:1rem;max-height:500px;overflow-y:auto;line-height:1.4}.output-line{margin-bottom:.25rem;white-space:pre-wrap;word-break:break-word}.output-line:empty{height:.25rem}.button-warning{background-color:#f59e0b;color:#fff}.button-warning:hover:not(:disabled){background-color:#d97706}.button-warning:disabled{background-color:#fbbf24;opacity:.6;cursor:not-allowed}@media(max-width:768px){.optimization-grid{grid-template-columns:1fr}}.btn-force-regenerate{background-color:#dc3545;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-force-regenerate:hover:not(:disabled){background-color:#c82333;box-shadow:0 4px 12px #dc354566;transform:translateY(-1px)}.btn-force-regenerate:disabled{cursor:not-allowed;opacity:.6}.photo-actions{display:flex;gap:.5rem;justify-content:center;align-items:center;pointer-events:auto;position:relative;z-index:11}.btn-edit-photo{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:var(--primary-color);width:32px;height:32px;border-radius:4px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;padding:0;touch-action:manipulation;-webkit-tap-highlight-color:transparent;position:relative;z-index:12;pointer-events:auto;user-select:none;-webkit-user-select:none}.btn-edit-photo svg{pointer-events:none}.btn-edit-photo:hover:not(:disabled){background:var(--primary-color);color:#000;border-color:var(--primary-color);transform:scale(1.1)}.btn-edit-photo:disabled{opacity:.5;cursor:not-allowed}.btn-retry-photo{background:#ffc10733;border:1px solid rgba(255,193,7,.4);color:#ffc107;padding:.5rem;border-radius:50%;width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;transition:all .15s ease}.btn-retry-photo:hover:not(:disabled){background:#ffc1074d;border-color:#ffc107;transform:scale(1.1)}.btn-retry-photo:active{transform:scale(.95)}.btn-retry-photo:disabled{opacity:.5;cursor:not-allowed}.photo-error-badge{position:absolute;bottom:8px;left:8px;right:8px;padding:.4rem .6rem;font-size:.75rem;font-weight:500;border-radius:4px;display:flex;align-items:center;gap:.4rem;z-index:2;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.photo-error-badge.optimization-error{background:#dc3545e6;border:1px solid rgba(220,53,69,1);color:#fff}.photo-error-badge.ai-error{background:#ffc107e6;border:1px solid rgba(255,193,7,1);color:#000}.edit-title-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem;overflow-y:auto;-webkit-overflow-scrolling:touch;animation:fadeIn .2s ease-out}@supports not (backdrop-filter: blur(8px)){.edit-title-modal{background:#000000e6}}.edit-modal{background:linear-gradient(135deg,#1f1f1f,#181818);border:1px solid rgba(255,255,255,.1);border-radius:12px;max-width:500px;width:100%;max-height:90vh;overflow:hidden;box-shadow:0 20px 60px #0009;animation:slideUp .3s ease-out;position:relative;z-index:10001}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.edit-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.edit-modal-header h3{margin:0;color:#fff;font-size:1.25rem;font-weight:600}.modal-close-btn{background:transparent;border:none;color:#888;font-size:2rem;line-height:1;cursor:pointer;transition:all .2s ease;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;padding:0}.modal-close-btn:hover{background:#ffffff1a;color:#fff}.edit-modal-body{padding:0 1.5rem 1.5rem;overflow-y:auto;max-height:calc(90vh - 180px)}.edit-modal-photo{width:calc(100% + 2rem);margin-left:-1rem;margin-right:-1rem;max-height:400px;border-radius:0;overflow:hidden;margin-bottom:1.5rem;background:#ffffff08;border:none;border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center}.edit-modal-photo img{width:100%;height:auto;max-height:400px;object-fit:contain;display:block}.edit-modal-info{display:flex;flex-direction:column}.edit-modal-label{color:#e5e7eb;font-size:.9rem;font-weight:500;display:block}.filename-display{color:#888;font-weight:400;font-family:Monaco,Menlo,monospace;font-size:.85rem}.edit-modal-input{width:100%;padding:.75rem 1rem;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#fff;font-size:1rem;font-family:inherit;transition:all .2s ease;margin-top:.5rem}.edit-modal-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary-color) 10%,transparent);background:#00000080}.edit-modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:1px solid rgba(255,255,255,.1)}@media(max-width:600px){.edit-modal{max-width:100%;margin:1rem}.edit-modal-header,.edit-modal-body,.edit-modal-footer{padding:1rem}}.upload-progress-container{margin:1rem 0 1.5rem;padding:1rem;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:8px;animation:fadeIn .3s ease-out}.upload-progress-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;font-size:.95rem}.upload-progress-percent{color:var(--primary-color);font-weight:600;font-size:1.1rem}.upload-speed{color:#a1a1aa;font-size:.9rem;font-family:Monaco,Menlo,monospace}.upload-progress-bar{width:100%;height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden;position:relative}.upload-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-color),color-mix(in srgb,var(--primary-color) 80%,white));border-radius:4px;transition:width .3s ease;position:relative;overflow:hidden}.upload-progress-fill:after{content:"";position:absolute;top:0;left:0;bottom:0;right:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.3) 50%,transparent 100%);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.uploading-photo-item{position:relative}.photo-state-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#000000b3;gap:.5rem;padding:1rem;text-align:center}.photo-state-overlay.error{background:#8b00004d;border:1px solid #dc3545;border-radius:12px}.retry-upload-btn{margin-top:.75rem;padding:.5rem 1rem;background:#dc3545;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.retry-upload-btn:hover{background:#c82333;transform:translateY(-1px);box-shadow:0 4px 8px #0000004d}.retry-upload-btn:active{transform:translateY(0)}.state-icon{font-size:2rem;margin-bottom:.25rem}.state-text{color:#fff;font-size:.85rem;font-weight:500}.error-message{color:#f87171;font-size:.75rem;margin-top:.25rem;line-height:1.3}.photo-complete-badge{position:absolute;top:.5rem;right:.5rem;background:var(--primary-color);color:#000;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;box-shadow:0 2px 8px #0000004d;z-index:10}.photo-filename{position:absolute;bottom:0;left:0;right:0;background:#000c;color:#fff;padding:.5rem;font-size:.75rem;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.upload-errors-summary{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:1rem;margin:1rem 0 1.5rem;animation:fadeIn .3s ease-out}.errors-summary-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.error-icon{font-size:1.25rem}.errors-summary-header strong{font-size:1rem;color:#fca5a5}.error-files-list{display:flex;flex-direction:column;gap:.5rem}.error-file-item{background:#0000004d;border:1px solid rgba(239,68,68,.2);border-radius:6px;padding:.75rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}.error-file-info{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:0}.error-filename{color:#fca5a5;font-weight:600;font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.error-reason{color:#9ca3af;font-size:.85rem}.error-dismiss-btn{background:#ef444433;border:1px solid rgba(239,68,68,.3);color:#fca5a5;width:28px;height:28px;border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.25rem;line-height:1;transition:all .2s ease;flex-shrink:0}.error-dismiss-btn:hover{background:#ef44444d;border-color:#ef444480}.admin-photo-item{cursor:grab;position:relative;transition:all .2s ease}.admin-photo-item:active{cursor:grabbing}.admin-photo-item.dragging{opacity:.5;z-index:1000;transform:scale(1.05);box-shadow:0 8px 24px #0006}.admin-photo-item.shuffling-active{transition:transform .2s ease!important}.admin-photo-item.flip-complete{animation:flipComplete .3s ease-in-out}@keyframes flipComplete{0%{transform:perspective(800px) rotateY(0) scale(1)}50%{transform:perspective(800px) rotateY(90deg) scale(.95)}to{transform:perspective(800px) rotateY(0) scale(1)}}.admin-photo-item.crt-delete{animation:crtDelete .5s cubic-bezier(.25,.46,.45,.94) forwards;pointer-events:none}@keyframes crtDelete{0%{transform:scaleY(1) scaleX(1);opacity:1;filter:brightness(1) saturate(1)}30%{transform:scaleY(.01) scaleX(1);opacity:.9;filter:brightness(10) saturate(0)}70%{transform:scaleY(.01) scaleX(.01);opacity:.6;filter:brightness(10) saturate(0)}to{transform:scaleY(0) scaleX(0);opacity:0;filter:brightness(0) saturate(0)}}.btn-cancel-order{background:#ef444426!important;border:1.5px solid rgba(239,68,68,.3)!important;color:#ef4444!important}.btn-cancel-order:hover:not(:disabled){background:#ef444440!important;border-color:#ef444480!important;transform:scale(1.05);box-shadow:0 4px 12px #ef44444d}.btn-cancel-order:disabled{opacity:.5;cursor:not-allowed}@property --shuffle-angle{syntax: "<angle>"; initial-value: 0deg; inherits: false;}.btn-shuffle-order{--shuffle-angle: 0deg;background:#8b5cf626!important;border:1.5px solid rgba(139,92,246,.3)!important;border-radius:8px!important;color:#8b5cf6!important;transition:transform .2s ease,box-shadow .2s ease,color .2s ease;position:relative;z-index:1;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.btn-shuffle-order:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:8px;padding:2px;background:conic-gradient(from var(--shuffle-angle),rgba(255,0,0,.6),rgba(255,127,0,.6),rgba(255,255,0,.6),rgba(0,255,0,.6),rgba(0,0,255,.6),rgba(75,0,130,.6),rgba(148,0,211,.6),rgba(255,0,0,.6));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask-composite:exclude;z-index:-1;opacity:0;filter:blur(1px);transition:opacity .3s ease}.btn-shuffle-order:hover:not(:disabled){background:#8b5cf640!important;color:#fff!important;transform:scale(1.05);box-shadow:0 4px 20px #8b5cf666}.btn-shuffle-order:hover:not(:disabled):before{opacity:1;animation:rotate-shuffle-border var(--animation-speed, 3s) linear infinite}.btn-shuffle-order.shuffling-active:hover:not(:disabled):before{animation:rotate-shuffle-border var(--animation-speed, .4s) linear infinite}.btn-shuffle-order.shuffling-slowing:hover:not(:disabled):before{animation:rotate-shuffle-border var(--animation-speed, 1.2s) linear infinite}@keyframes rotate-shuffle-border{to{--shuffle-angle: 360deg}}.btn-shuffle-order:disabled{opacity:.5;cursor:not-allowed}.btn-save-order{animation:pulse-glow 2s ease-in-out infinite;background:linear-gradient(135deg,var(--primary-color),color-mix(in srgb,var(--primary-color) 80%,white))!important;color:#000!important;font-weight:600}@keyframes pulse-glow{0%,to{box-shadow:0 0 8px #4ade804d}50%{box-shadow:0 0 16px #4ade8080}}.btn-save-order:hover{transform:scale(1.05);box-shadow:0 4px 16px #4ade8066!important}.unsaved-indicator{color:#fbbf24;font-size:.85rem;font-weight:500;font-style:italic;display:flex;align-items:center;gap:.35rem}.unsaved-indicator:before{content:"●";font-size:.75rem;animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.folder-card{padding:.5rem 1rem 1rem;border:1px solid rgba(255,255,255,.2);border-radius:12px;background:linear-gradient(135deg,#ffffff0d,#ffffff05);position:relative;transition:all .2s ease;min-height:100px}.folder-card.unpublished{opacity:.7;border-color:#fbbf244d!important;background:linear-gradient(135deg,#fbbf2414,#fbbf2405)!important}.folder-card:hover{border-color:#ffffff4d;box-shadow:0 4px 12px #0003}.folder-card.drag-over .folder-albums-grid{border-color:#3b82f6!important;background:#3b82f61a!important;box-shadow:0 0 20px #3b82f64d!important}.folder-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;gap:1rem;position:relative}.folder-drag-handle{flex:1;min-width:0;display:flex;align-items:center;gap:.75rem}.folder-card-title{margin:0;font-size:1rem;font-weight:600;color:#fff;display:flex;align-items:center;gap:.5rem;flex-shrink:0}.folder-controls{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.folder-delete-btn{background:transparent;border:none;color:#ef4444;cursor:pointer;padding:.25rem;font-size:1.2rem;line-height:1;transition:all .2s ease;flex-shrink:0}.folder-delete-btn:hover{transform:scale(1.2);color:#dc2626}.folder-delete-btn-text{background:#dc35451a;border:1px solid rgba(220,53,69,.3);color:#ef4444;padding:.4rem .8rem;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;transition:all .2s ease;flex-shrink:0}.folder-delete-btn-text:hover{background:#dc354533;border-color:#dc2626;color:#dc2626;transform:translateY(-1px);box-shadow:0 2px 4px #dc354533}.folder-count{font-size:.75rem;color:#888;font-weight:400;margin:0}.folder-albums-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;margin:0rem 0;padding:1rem;border:1px solid rgba(255,255,255,.1);background:#0003;border-radius:8px;isolation:isolate}@media(max-width:768px){.folder-card-header{flex-direction:column;align-items:stretch;gap:.75rem}.folder-drag-handle{flex-direction:column;align-items:flex-start;gap:.25rem}.folder-controls{width:100%;justify-content:space-between;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.1)}.folder-albums-grid{grid-template-columns:1fr}}.uncategorized-section{padding:1rem 2rem 2rem;border:1px solid rgba(255,255,255,.1);border-radius:12px;background:#ffffff05;transition:all .2s ease;min-height:170px}.uncategorized-section.drag-over-uncategorized{border-color:#3b82f6!important;background:#3b82f626!important;box-shadow:0 0 20px #3b82f64d!important}.ghost-album-tile,.ghost-folder-tile{border:1px dashed rgba(74,222,128,.4)!important;background:linear-gradient(135deg,#4ade800d,#4ade8005)!important;cursor:pointer;transition:all .3s ease;padding:0rem 1rem;display:flex;flex-direction:column;height:60px;box-sizing:border-box}body.dragging .ghost-album-tile,body.dragging .ghost-folder-tile{pointer-events:none!important}.ghost-album-tile:hover,.ghost-folder-tile:hover{border-color:#4ade8099!important;background:linear-gradient(135deg,#4ade801a,#4ade800d)!important;transform:scale(1.02)}.ghost-album-tile.drag-over-ghost,.ghost-folder-tile.drag-over-ghost{border:1px solid rgba(74,222,128,.9)!important;background:linear-gradient(135deg,#22c55e40,#4ade804d,#10b98140,#4ade804d,#22c55e40)!important;background-size:200% 200%!important;animation:ghost-tile-glow 2s ease infinite!important;transform:scale(1.05);box-shadow:0 0 15px #4ade8066,0 0 25px #4ade8033,inset 0 0 15px #4ade8014!important}@keyframes ghost-tile-glow{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.ghost-tile-content{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:.1rem;color:#4ade80e6}.ghost-tile-content svg{margin:0;display:block}.ghost-tile-text{font-size:1rem;font-weight:500;margin:0}.ghost-tile-hint{font-size:.85rem;color:#4ade80b3;font-style:italic;margin:0;line-height:1}.ghost-tile-disabled{border:1px dashed rgba(156,163,175,.4)!important;background:linear-gradient(135deg,#6b72800d,#6b728005)!important;cursor:not-allowed!important;pointer-events:none;opacity:.7}.ghost-tile-disabled .ghost-tile-content{color:#9ca3af99}.album-drop-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#4ade8026;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:var(--primary-color);font-weight:500;border-radius:inherit;z-index:10}.album-card.drag-over-album{border-color:var(--primary-color)!important;transform:scale(1.05);box-shadow:0 8px 24px #4ade804d}.album-mobile-arrows,.folder-mobile-arrows{position:absolute;top:8px;right:8px;display:flex;flex-direction:row;gap:4px;z-index:15}.arrow-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#000000b3;border:1px solid rgba(255,255,255,.3);border-radius:6px;color:#fff;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);-webkit-tap-highlight-color:transparent}.arrow-btn:hover{background:#000000e6;border-color:var(--primary-color);transform:scale(1.1)}.arrow-btn:active{transform:scale(.95)}.arrow-btn svg{pointer-events:none;stroke:currentColor}@media(min-width:769px){.album-mobile-arrows,.folder-mobile-arrows{display:none}}.album-card,.folder-card{transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s ease,box-shadow .3s ease,border-color .3s ease,background .3s ease;will-change:transform}.album-grid>*,.folder-albums-grid>*{transition:all .3s cubic-bezier(.4,0,.2,1)}.folder-mobile-arrows{top:12px;right:12px}.folders-container{display:flex;flex-direction:column;gap:1rem;isolation:isolate}.folders-container>*{transition:transform .3s cubic-bezier(.4,0,.2,1)}.album-move-folder-btn{position:absolute;top:.5rem;right:.5rem;display:inline-flex;align-items:center;justify-content:center;background:#0009;border:1px solid rgba(255,255,255,.3);border-radius:6px;padding:.5rem;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10;color:var(--primary-color)}@media(min-width:769px){.album-move-folder-btn{display:none}.album-card:hover .album-move-folder-btn{display:inline-flex}}.album-move-folder-btn:hover{background:#000c;border-color:var(--primary-color);transform:scale(1.1)}.album-move-folder-btn svg{display:block;stroke:currentColor}.modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10000;animation:fadeIn .2s ease-out}.move-folder-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.95);width:90%;max-width:500px;background:linear-gradient(135deg,#1f1f1f,#181818);border:1px solid rgba(255,255,255,.1);border-radius:12px;box-shadow:0 20px 60px #0009;z-index:10001;opacity:0;animation:modalAppear .2s ease-out forwards}@keyframes modalAppear{0%{opacity:0;transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.move-folder-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.move-folder-modal-header h3{margin:0;color:#fff;font-size:1.25rem;font-weight:600}.move-folder-modal-body{padding:1.5rem;max-height:60vh;overflow-y:auto}.move-folder-hint{color:#a8a8a8;font-size:.9rem;margin:0 0 1.5rem;line-height:1.5}.folder-list{display:flex;flex-direction:column;gap:.75rem}.folder-option{display:flex;align-items:center;gap:1rem;padding:1rem;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:8px;cursor:pointer;transition:all .2s ease;text-align:left;width:100%}.folder-option:hover:not(:disabled){background:#ffffff0f;border-color:var(--primary-color);transform:translate(4px)}.folder-option:disabled{opacity:.6;cursor:not-allowed}.folder-option.current{background:#4ade8014;border-color:#4ade804d}.folder-option-icon{font-size:1.5rem;flex-shrink:0}.folder-option-name{flex:1;color:#fff;font-size:1rem;font-weight:500}.current-badge{padding:.25rem .75rem;background:#4ade8033;color:var(--primary-color);border-radius:4px;font-size:.75rem;font-weight:600;flex-shrink:0}@media(max-width:600px){.move-folder-modal{width:95%;max-width:none}.move-folder-modal-header,.move-folder-modal-body{padding:1rem}}.album-toolbar{display:flex;justify-content:space-between;align-items:center;margin-top:3rem;margin-bottom:1rem;gap:1rem}.album-toolbar-top{flex:0 0 auto}.album-toolbar-unsaved{display:flex;align-items:center;gap:1rem;flex:0 0 auto}.album-toolbar-unsaved .unsaved-text{color:#fbbf24;font-size:.9rem;font-weight:500}.album-toolbar-unsaved .unsaved-actions{display:flex;gap:.75rem}@media(max-width:768px){.album-card-icon-in-folder{display:none}}@media(max-width:768px){.album-toolbar{flex-direction:column;align-items:stretch;gap:1rem;margin-top:1.5rem}.album-toolbar-top{width:100%}.album-toolbar-top button{width:100%;justify-content:center}.album-toolbar-unsaved{flex-direction:column;align-items:stretch;gap:.75rem;padding:1rem;background:#fbbf2414;border:1px solid rgba(251,191,36,.2);border-radius:8px}.album-toolbar-unsaved .unsaved-text{text-align:center}.album-toolbar-unsaved .unsaved-actions{display:flex;gap:.5rem;width:100%}.album-toolbar-unsaved .unsaved-actions button{flex:1;min-width:0}}.album-upload-progress{padding:.25rem 0;display:flex;flex-direction:column;gap:.25rem;margin-top:.25rem}.upload-progress-text{font-size:.75rem;color:#ffffffb3;font-weight:500}.upload-progress-bar-container{width:100%;height:3px;background:#ffffff1a;border-radius:2px;overflow:hidden}.upload-progress-bar{height:100%;background:linear-gradient(90deg,#10b981,#34d399);border-radius:2px;transition:width .3s ease}.photo-order-controls{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.photo-order-row{display:flex;align-items:center;gap:.75rem}.photo-order-row-primary{justify-content:space-between}.photo-order-row-secondary{justify-content:flex-start}@media(min-width:769px){.photo-order-controls{flex-direction:row;justify-content:space-between;align-items:center}.photo-order-row{flex:0 0 auto}.photo-order-row-secondary{order:1}.photo-order-row-primary{order:2}}@media(max-width:768px){.photo-order-controls{display:grid;grid-template-columns:1fr;gap:.75rem}.photo-order-row-primary,.photo-order-row-secondary{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;width:100%}.photo-order-row-primary{order:1}.photo-order-row-secondary{order:2}.photo-order-row-primary .unsaved-indicator{text-align:left;display:flex;align-items:center}}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.visitor-map-wrapper{position:relative;width:100%;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #0000004d}.visitor-map-wrapper>div{border:1px solid #444}.visitor-map{width:100%;height:400px;border-radius:12px;z-index:1;background:#000}.visitor-map .leaflet-container{background:#000;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;width:100%!important;height:100%!important}.visitor-map .leaflet-control-zoom a{background-color:#2d2d2d;color:#e5e7eb;border:1px solid #535353}.visitor-map .leaflet-control-zoom a:hover{background-color:#3a3a3a;border-color:var(--secondary-color)}.visitor-map .leaflet-control-attribution{display:none!important}.visitor-map .leaflet-popup-content-wrapper{background:linear-gradient(135deg,#2d2d2d,#262626);color:#e5e7eb;border:1px solid #535353;border-radius:8px;box-shadow:0 8px 24px #0009}.visitor-map .leaflet-popup-tip{background:#2d2d2d;border:1px solid #535353}.visitor-map .leaflet-popup-close-button{color:#9ca3af!important;font-size:20px;padding:4px 8px}.visitor-map .leaflet-popup-close-button:hover{color:var(--secondary-color)!important}.visitor-popup{padding:.5rem;min-width:200px}.popup-location{font-size:1.1rem;margin-bottom:.75rem;color:#f9fafb;border-bottom:1px solid var(--secondary-color);padding-bottom:.5rem}.popup-stats{display:flex;flex-direction:column;gap:.5rem}.popup-stat{display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.stat-label{color:#9ca3af;margin-right:1rem}.stat-value{color:var(--secondary-color);font-weight:600;font-variant-numeric:tabular-nums}.visitor-map-legend{position:absolute;bottom:10px;right:10px;background:linear-gradient(135deg,#2d2d2df2,#262626f2);border:1px solid #535353;border-radius:8px;padding:.75rem 1rem;z-index:1000;box-shadow:0 4px 12px #00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.legend-title{font-size:.85rem;font-weight:600;color:#f9fafb;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.legend-items{display:flex;flex-direction:column;gap:.4rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:#9ca3af}.legend-marker{width:16px;height:16px;border-radius:50%;border:1px solid #ffffff}.legend-marker-low{background-color:var(--secondary-color);opacity:.4}.legend-marker-medium{background-color:var(--secondary-color);opacity:.65}.legend-marker-high{background-color:var(--secondary-color);opacity:.9}.visitor-map-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:400px;background:linear-gradient(135deg,#2d2d2d,#262626);border-radius:12px;color:#9ca3af}.visitor-map-loading .loading-spinner{width:40px;height:40px;border:3px solid #535353;border-top-color:var(--secondary-color);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:.75rem}.visitor-map-loading p{font-size:.9rem}.visitor-map-empty{display:flex;align-items:center;justify-content:center;height:400px;background:linear-gradient(135deg,#2d2d2d,#262626);border-radius:12px;color:#9ca3af;font-style:italic;text-align:center;padding:2rem;font-size:.9rem}@media(max-width:768px){.visitor-map-wrapper{margin-left:-1rem;margin-right:-1rem;margin-bottom:-1rem;border-radius:0;width:calc(100% + 2rem)}.visitor-map,.visitor-map-loading,.visitor-map-empty{height:400px;border-radius:0}.visitor-map-legend{bottom:20px;right:5px;padding:.5rem .75rem;font-size:.75rem}.legend-title{font-size:.75rem}.legend-item{font-size:.7rem}.legend-marker{width:12px;height:12px}}@media(max-width:480px){.visitor-map-wrapper{margin-left:-.75rem;margin-right:-.75rem;margin-bottom:-.75rem;width:calc(100% + 1.5rem)}.visitor-map,.visitor-map-loading,.visitor-map-empty{height:300px}.visitor-map-legend{display:none}}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes skeleton-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton-base{background:linear-gradient(90deg,#ffffff08,#ffffff14,#ffffff08);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite}.skeleton-card{pointer-events:none}.skeleton-icon{width:48px;height:48px;border-radius:8px;background:#ffffff0d;animation:skeleton-pulse 1.5s ease-in-out infinite;flex-shrink:0}.skeleton-value{height:1.5rem;width:70%;border-radius:4px;background:#ffffff0d;animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-label{height:.8rem;width:85%;border-radius:4px;background:#ffffff08;animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-chart-container{position:relative;min-height:300px}.skeleton-chart{position:relative;width:100%;height:300px;background:#ffffff03;border-radius:8px;overflow:hidden}.skeleton-chart-bars{display:flex;align-items:flex-end;justify-content:space-around;height:100%;padding:2rem 1rem 1rem;gap:4px}.skeleton-bar{flex:1;background:linear-gradient(90deg,#ffffff08,#ffffff14,#ffffff08);background-size:200% 100%;animation:skeleton-shimmer 2s ease-in-out infinite;border-radius:4px 4px 0 0;min-height:20%}.skeleton-bar:nth-child(2n){animation-delay:.1s}.skeleton-chart-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:#0000004d;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.skeleton-chart-overlay span{color:#9ca3af;font-size:.9rem;font-weight:500}.skeleton-table-container{pointer-events:none}.skeleton-text{height:.875rem;border-radius:4px;background:#ffffff0d;animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-thumbnail{width:60px;height:60px;border-radius:6px;background:#ffffff0d;animation:skeleton-pulse 1.5s ease-in-out infinite;flex-shrink:0}.skeleton-map{position:relative;width:100%;height:400px;background:#ffffff05;border-radius:8px;overflow:hidden;min-height:400px}.skeleton-map:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle at 30% 40%,rgba(255,255,255,.03) 0%,transparent 50%),radial-gradient(circle at 70% 60%,rgba(255,255,255,.03) 0%,transparent 50%),radial-gradient(circle at 50% 20%,rgba(255,255,255,.02) 0%,transparent 50%);animation:skeleton-pulse 2s ease-in-out infinite}.skeleton-map-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:#0000004d;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1}.skeleton-map-overlay span{color:#9ca3af;font-size:.9rem;font-weight:500}@media(max-width:768px){.skeleton-chart{height:200px}.skeleton-chart-container{min-height:200px}.skeleton-map{height:300px}.skeleton-thumbnail{width:50px;height:50px}.skeleton-value{width:80%;height:1.25rem}.skeleton-label{width:90%;height:.7rem}.skeleton-icon{width:40px;height:40px}}@media(max-width:480px){.skeleton-value{width:85%;height:1rem}.skeleton-label{width:95%;height:.65rem}.skeleton-icon{width:35px;height:35px}}.metrics-header-wrapper{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;margin-bottom:2rem;flex-wrap:wrap}.metrics-header-content{flex:1;min-width:300px}.metrics-time-range{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.metrics-time-range label{font-weight:500;color:#9ca3af}.time-range-select{padding:.75rem 2.25rem .75rem 1rem;border:1.5px solid rgba(255,255,255,.1);border-radius:6px;background:#0006;color:#fff;font-size:.95rem;cursor:pointer;transition:all .2s ease;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .75rem center;background-size:1rem;width:155px}.time-range-select:hover{border-color:#ffffff26;background-color:#00000073}.time-range-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary-color) 10%,transparent);background-color:#00000080}.metrics-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.metric-card{background:#ffffff05;border:1px solid rgba(255,255,255,.05);border-radius:8px;padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:all .2s ease}.metric-card:hover{background:#ffffff08;border-color:#ffffff14}.metric-icon{font-size:1.5rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#161616;color:#a8a8a8;border:1px solid var(--primary-color);border-radius:8px}.metric-content{flex:1}.metric-value{font-size:1.5rem;font-weight:700;color:#f9fafb;line-height:1.2}.metric-label{font-size:.8rem;color:#9ca3af;margin-top:.15rem;font-weight:500}.metrics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:1.5rem}.metrics-section{background:#ffffff05;border:1px solid rgba(255,255,255,.05);border-radius:8px;padding:1.5rem;transition:all .2s ease;overflow:visible}.admin-section>.metrics-section{margin-bottom:1.5rem}.metrics-section:hover{background:#ffffff08;border-color:#ffffff14}.metrics-section h3{margin:0 0 1rem;font-size:1.1rem;color:var(--primary-color);font-weight:600;text-transform:uppercase;letter-spacing:.05em;font-size:.875rem}.chart-container{padding:.5rem 0}.chart-loading{text-align:center;padding:2rem;color:#9ca3af;font-size:.9rem}.metrics-table-container{max-height:400px;overflow-y:auto;overflow-x:hidden;border-radius:8px;margin-bottom:0}.metrics-table-container.expanded{max-height:none}.view-more-btn{display:none;width:100%;padding:.75rem;margin-top:.75rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--primary-color);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease}.view-more-btn:hover{background:#ffffff14;border-color:var(--primary-color);transform:translateY(-1px)}.metrics-table th{text-align:left;padding:.75rem 1rem;background:#383838;color:#9ca3af;font-weight:700;font-size:.75rem;border-bottom:1px solid #535353;text-transform:uppercase;letter-spacing:.075em}.metrics-table th.text-right{text-align:right}.metrics-table td{padding:.75rem 1rem;border-bottom:1px solid #535353;color:#e5e7eb;font-size:.875rem;background:#2d2d2d}.metrics-table td.text-right{text-align:right;font-weight:500;font-variant-numeric:tabular-nums}.metrics-table th:first-child,.metrics-table td:first-child{padding-left:1.5rem}.metrics-table th:last-child,.metrics-table td:last-child{padding-right:1.5rem}.metrics-table tbody tr{transition:all .15s ease}.metrics-table tbody tr:hover,.metrics-table tbody tr:hover td{background:#323232}.metrics-table tbody tr:last-child td{border-bottom:none}.metrics-table tbody{display:table-row-group}.metrics-table tbody tr:last-child{margin-bottom:0;padding-bottom:0}.metrics-table .page-path{font-family:SF Mono,Monaco,Cascadia Code,Courier New,monospace;color:var(--primary-color);font-weight:500;font-size:.9rem}.metrics-table .referrer{color:#fff;max-width:900px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.875rem}.metrics-table{overflow-x:auto;overflow-y:hidden;border-radius:8px;border:1px solid #535353}.metrics-table table{width:100%;border-collapse:separate;border-spacing:0;table-layout:fixed}.metrics-table .event-type{font-weight:500;color:#fff;text-transform:lowercase}.metrics-table .clickable-row:hover,.metrics-table .clickable-row:hover td,.metrics-table .clickable-row.expanded-row{background:#3a3a3a!important}.metrics-table .clickable-row.expanded-row td{background:#3a3a3a!important;border-bottom:none!important}.metrics-table .expanded-content-row{background:#323232!important}.metrics-table .expanded-content-row td{background:#323232!important;padding:1rem 1.5rem!important;border-bottom:1px solid #535353!important}.expanded-content{display:flex;flex-direction:column;gap:.75rem;font-size:.875rem}.expanded-detail{display:flex;flex-direction:column;gap:.25rem}.expanded-detail strong{color:#9ca3af;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.expanded-actions{margin-top:.5rem;padding-top:.75rem;border-top:1px solid #535353}.view-photo-btn{display:inline-block;padding:.5rem 1rem;background:var(--primary-color);color:#000;text-decoration:none;border-radius:6px;font-weight:600;font-size:.875rem;transition:all .2s ease;box-shadow:0 2px 8px color-mix(in srgb,var(--primary-color) 30%,transparent)}.view-photo-btn:hover{filter:brightness(.9);transform:translateY(-2px);box-shadow:0 4px 12px color-mix(in srgb,var(--primary-color) 40%,transparent)}.photo-thumbnail-cell{padding:.5rem 1.5rem!important}.photo-thumbnail-wrapper{position:relative;display:inline-block}.photo-thumbnail-small{width:60px;height:60px;object-fit:cover;border-radius:6px;border:1px solid #535353;transition:border-color .2s ease}.clickable-row:hover .photo-thumbnail-small{border-color:var(--primary-color)}.photo-thumbnail-preview{position:absolute;left:100%;top:50%;transform:translateY(-50%);margin-left:1rem;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;z-index:1000;pointer-events:none}.photo-thumbnail-wrapper:hover .photo-thumbnail-preview{opacity:1;visibility:visible}.photo-thumbnail-preview img{width:250px;height:auto;max-height:350px;object-fit:contain;border:1px solid var(--primary-color);border-radius:8px;box-shadow:0 8px 24px #0009;background:#1a1a1a}.metrics-footer{text-align:center;padding:1rem;color:#6b7280;font-size:.8rem}.loading-container,.error-message{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;color:#f9fafb}.loading-spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.1);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}.error-message{color:#ef4444}.error-message p{margin-bottom:1rem;font-size:1.1rem;color:#f9fafb}.no-data{text-align:center;padding:1.5rem;color:#9ca3af;font-style:italic;font-size:.9rem}@media(max-width:768px){.metrics-grid{grid-template-columns:1fr;gap:1rem}.view-more-btn{display:block}.metrics-table-container:not(.expanded){max-height:400px;overflow-y:hidden;position:relative}.metrics-table-container:not(.expanded):after{content:"";position:absolute;bottom:0;left:0;right:0;height:60px;background:linear-gradient(to bottom,transparent,rgba(45,45,45,.95));pointer-events:none}.metrics-header-wrapper{gap:1rem}.metrics-header-content{min-width:100%}.metrics-time-range{width:100%;justify-content:flex-start}.metrics-time-range label{display:none}.time-range-select{font-size:.85rem;padding:.4rem .75rem}.metrics-section{padding:1rem;border-radius:6px}.metrics-section h3{font-size:.8rem;margin-bottom:.75rem}.metrics-summary{grid-template-columns:repeat(3,1fr);gap:.5rem;margin-bottom:1rem}.metric-card{padding:.75rem;flex-direction:column;text-align:center;gap:.5rem}.metric-icon{font-size:1.5rem;width:40px;height:40px}.metric-value{font-size:1.25rem}.metric-label{font-size:.7rem}.chart-container{margin-left:-1rem;margin-right:-1rem;padding-left:.25rem;padding-right:.25rem}.line-chart{height:200px}.bar-label{font-size:.6rem}.metrics-table{font-size:.85rem;margin-left:-1rem;margin-right:-1rem;border-left:none;border-right:none;border-radius:0}.metrics-table th,.metrics-table td{padding:.5rem .75rem}.metrics-table th:first-child,.metrics-table td:first-child{padding-left:1.5rem}.metrics-table th:last-child,.metrics-table td:last-child{padding-right:1.5rem}.photo-thumbnail-small{width:50px;height:50px}.photo-thumbnail-preview{display:none}.metrics-footer{font-size:.75rem;padding:.75rem}}@media(max-width:480px){.time-range-select{font-size:.8rem;padding:.35rem .6rem}.metrics-section{padding:.75rem}.metrics-summary{grid-template-columns:repeat(3,1fr);gap:.4rem}.metric-card{padding:.5rem;flex-direction:column;text-align:center;gap:.4rem}.metric-icon{font-size:1.25rem;width:35px;height:35px}.metric-value{font-size:1rem}.metric-label{font-size:.65rem}.chart-container{margin-left:-.75rem;margin-right:-.75rem;padding-left:.125rem;padding-right:.125rem}.metrics-table{margin-left:-.75rem;margin-right:-.75rem}.metrics-table th,.metrics-table td{padding:.4rem .5rem;font-size:.8rem}.metrics-table th:first-child,.metrics-table td:first-child{padding-left:1.5rem}.metrics-table th:last-child,.metrics-table td:last-child{padding-right:1.5rem}.line-chart{gap:2px}.bar-label{display:none}}.settings-home-header{margin-bottom:2rem}.settings-home-header h2{color:#fff;font-size:1.8rem;font-weight:500;margin:0 0 .5rem}.settings-home-description{color:#9ca3af;font-size:1rem;line-height:1.5;margin:0}.settings-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem .5rem}.settings-card{background:none;border:none;padding:0;cursor:pointer;transition:all .2s ease;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.75rem}.settings-card-icon-wrapper{position:relative;display:inline-block}@media(hover:hover){.settings-card:hover .settings-card-icon{background:#55ff682e;border-color:#4ade804d;transform:scale(1.05);box-shadow:0 0 25px #81ff6f21}}.settings-card:active .settings-card-icon{transform:scale(1.02)}.settings-card-icon{width:88px;height:88px;display:flex;align-items:center;justify-content:center;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:12px;color:var(--primary-color);transition:all .2s ease}.settings-card-icon>svg{opacity:.8}.settings-card-icon.needs-config{background:#f59e0b1a;border-color:#f59e0b4d}.settings-card-icon.needs-config>svg{color:#f59e0b;opacity:.9}@media(hover:hover){.settings-card:hover .settings-card-icon.needs-config{background:#f59e0b26;border-color:#f59e0b66;box-shadow:0 0 25px #f59e0b33}.settings-card:hover .settings-card-icon.needs-config>svg{opacity:1}}.settings-card-badge{position:absolute;top:-4px;right:-4px;width:20px;height:20px;background:#f59e0b;color:#1a1f2e;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;border:2px solid #1a1f2e;box-shadow:0 2px 8px #f59e0b66;z-index:1}.settings-card-title{color:#e5e7eb;font-size:.9rem;font-weight:500;margin:0;letter-spacing:.01em;transition:all .2s ease}@media(hover:hover){.settings-card:hover .settings-card-title{color:#fff;transform:scale(1.05)}}@media(max-width:480px){.settings-home-header h2{font-size:1.5rem}.settings-home-description{font-size:.9rem}.settings-grid{gap:1rem .5rem}.settings-card-icon{width:64px;height:64px}.settings-card-icon>svg{width:36px;height:36px}.settings-card-badge{width:16px;height:16px;font-size:.65rem;top:-3px;right:-3px}.settings-card-title{font-size:.8rem}}@media(min-width:480px){.settings-grid{grid-template-columns:repeat(4,1fr);gap:1.25rem .5rem}.settings-card-icon{width:72px;height:72px}.settings-card-icon>svg{width:40px;height:40px}.settings-card-badge{width:18px;height:18px;font-size:.7rem}.settings-card-title{font-size:.85rem}}@media(min-width:600px){.settings-grid{grid-template-columns:repeat(5,1fr)}}@media(min-width:800px){.settings-grid{grid-template-columns:repeat(6,1fr)}}.branding-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.branding-group{display:flex;flex-direction:column;gap:.75rem;background:#ffffff05;padding:1.5rem;border-radius:8px;border:1px solid rgba(255,255,255,.05);transition:all .2s ease}.branding-group:hover{background:#ffffff08;border-color:#ffffff14}.section-button-group{display:flex;gap:.75rem;margin-top:.5rem}.new-user-button-group{display:flex;gap:.75rem;width:100%}.new-user-button-group button{flex:1;min-width:0}.btn-small{padding:.625rem 1rem;font-size:.875rem;flex:1}.branding-group.full-width{grid-column:1 / -1}.branding-label{color:var(--primary-color);font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.branding-description{color:#a1a1aa;font-size:.875rem;line-height:1.5;margin-bottom:.5rem}.branding-input,.branding-textarea{padding:.875rem 1rem;background:#0006;border:1.5px solid rgba(255,255,255,.1);border-radius:6px;color:#fff;font-size:1rem;transition:all .2s ease;font-family:inherit}select.branding-input{max-width:100%;width:100%;cursor:pointer;padding-right:2.5rem;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23fff' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;-webkit-appearance:none;-moz-appearance:none;appearance:none}select.branding-input option{background:#1a1a1a;color:#fff;padding:.5rem}.branding-input:hover,.branding-textarea:hover{border-color:#ffffff26;background:#00000073}.branding-input:focus,.branding-textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary-color) 10%,transparent);background:#00000080}.branding-input::placeholder,.branding-textarea::placeholder{color:#6b7280}.branding-textarea{resize:vertical;min-height:80px}.avatar-upload-container{display:flex;flex-direction:column;gap:1rem;align-items:center}.current-avatar-preview{width:120px;height:120px;object-fit:cover;transition:transform .2s ease,box-shadow .2s ease}.upload-avatar-btn{cursor:pointer;width:100%;text-align:center}.color-input-group{display:flex;gap:.75rem;align-items:center}.color-picker{width:60px;height:60px;border:1px solid rgba(255,255,255,.1);border-radius:8px;cursor:pointer;background:#0000004d;padding:4px;transition:all .2s ease}.color-picker:hover{border-color:#fff3;transform:scale(1.05)}.color-picker::-webkit-color-swatch-wrapper{padding:0;border-radius:6px}.color-picker::-webkit-color-swatch{border:none;border-radius:6px}.color-picker::-moz-color-swatch{border:none;border-radius:6px}.color-text{flex:1}.branding-preview{margin-top:2rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.1)}.branding-preview h3{color:#e5e7eb;font-size:1.2rem;margin-bottom:1rem;font-weight:600}.preview-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:1.5rem;margin-bottom:1rem}.preview-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.preview-avatar{width:60px;height:60px;border-radius:50%;overflow:hidden;background:#ffffff1a;display:flex;align-items:center;justify-content:center}.preview-avatar img{width:100%;height:100%;object-fit:cover}.preview-avatar-placeholder{font-size:2rem;color:#6b7280}.preview-info h4{color:#fff;margin:0 0 .5rem;font-size:1.2rem;font-weight:600}.preview-info p{color:#a1a1aa;margin:0;font-size:.9rem;line-height:1.4}.preview-colors{display:flex;gap:.75rem}.preview-color{width:40px;height:40px;border-radius:6px;border:1px solid rgba(255,255,255,.2)}@media(max-width:768px){.branding-grid{grid-template-columns:1fr;gap:1rem}.branding-group{padding:1.25rem}.section-button-group{flex-direction:column}.section-button-group button{width:100%}.new-user-button-group{flex-direction:column}.new-user-button-group button{width:100%}.current-avatar-preview{width:100px;height:100px}.color-picker{width:50px;height:50px}.color-input-group{flex-direction:column;align-items:stretch}.color-text{width:100%}}.links-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.link-item{display:flex;gap:1rem;align-items:center;padding:1.25rem;background:#ffffff08;border-radius:8px;border:1px solid rgba(255,255,255,.08);transition:all .2s ease}.link-item:hover{background:#ffffff0d;border-color:#ffffff1f;transform:translateY(-1px)}.link-fields{display:flex;gap:.75rem;flex:1}.link-input{padding:.75rem 1rem;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#fff;font-size:1rem;transition:all .2s ease}.link-input:first-child{flex:1}.link-input:last-child{flex:2}.link-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary-color) 10%,transparent);background:#00000080}.link-input::placeholder{color:#666}.link-controls{display:flex;flex-direction:row;align-items:center;gap:.75rem}.reorder-buttons{display:flex;gap:.5rem}.btn-reorder{display:flex;align-items:center;justify-content:center;padding:.5rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#fff;cursor:pointer;transition:all .2s ease}.btn-reorder:hover:not(:disabled){background:color-mix(in srgb,var(--primary-color) 10%,transparent);border-color:var(--primary-color);color:var(--primary-color)}.btn-reorder:disabled{opacity:.3;cursor:not-allowed}.btn-delete-link{padding:.5rem 1rem;background:#dc26261a;border:1px solid rgba(220,38,38,.3);border-radius:6px;color:#dc2626;cursor:pointer;transition:all .2s ease;font-size:.875rem;font-weight:500;flex:1}.btn-delete-link:hover{background:#dc262633;border-color:#dc2626}@media(max-width:768px){.link-item{padding:1rem;flex-direction:column;gap:.75rem}.link-fields{flex-direction:column;width:100%}.link-controls{width:100%;justify-content:space-between}.section-actions{flex-direction:column}.section-actions button{width:100%}}.push-notification-status{background:#667eea1a;border:1px solid rgba(102,126,234,.2);border-radius:8px;padding:1rem;margin-bottom:1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.push-status-info{display:flex;align-items:center;gap:.5rem}.push-status-indicator{width:8px;height:8px;border-radius:50%;background:#22c55e}.push-status-text{color:#fff;font-size:.95rem}.push-status-buttons{display:flex;gap:.5rem}.push-status-buttons button{padding:.4rem .875rem;font-size:.875rem}.push-status-prompt{color:#888;font-size:.95rem;flex:1}.push-subscribe-btn{padding:.4rem 1rem;font-size:.875rem;white-space:nowrap}@media(max-width:768px){.push-notification-status{flex-wrap:wrap}.push-status-buttons{width:100%;flex:1 1 100%}.push-status-buttons button{flex:1}}.notification-event-description{line-height:1.4;word-wrap:break-word;overflow-wrap:break-word}@media(max-width:768px){.notification-event-description{display:none}.notification-events-grid{grid-template-columns:1fr!important}.settings-page{padding-left:.5rem!important;padding-right:.5rem!important}.settings-section{margin-left:0!important;margin-right:0!important}}.logging-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:1.5rem}.logging-button-container{display:flex;align-items:flex-end}.logging-button-container .btn-secondary{width:100%;padding:.5rem .75rem;display:flex;align-items:center;justify-content:center;gap:.5rem;height:auto;margin-top:1.8rem}@media(max-width:768px){.logging-grid{grid-template-columns:1fr!important;gap:1rem}.logging-button-container .btn-secondary{margin-top:0}}.license-page{padding:2rem 1rem 0;margin-top:1rem;margin-bottom:0}.license-container{max-width:900px;margin:0 auto;padding:0}.license-container h1{font-size:3rem;margin-bottom:1rem;font-weight:700;color:#fff}.license-section{margin-bottom:2.5rem}.license-section:last-child{margin-bottom:0}.license-section h2{font-size:2rem;margin-bottom:1rem;font-weight:600;color:var(--primary-color, #4ade80)}.license-section h3{font-size:1.35rem;margin-bottom:1rem;font-weight:600;color:#fff}.license-section p{line-height:1.8;color:#ffffffd9;margin-bottom:1rem;font-size:1.05rem}.license-url{margin-top:.75rem}.license-url a{color:var(--primary-color, #4ade80);text-decoration:none;word-break:break-all;font-weight:500}.license-url a:hover{text-decoration:underline;filter:brightness(1.2)}.license-full-text{background-color:#ffffff08;padding:2rem;border-radius:12px;border-left:4px solid var(--primary-color, #4ade80);font-size:1rem;line-height:1.8;color:#ffffffe6;box-shadow:0 2px 8px #0000001a}.license-notice{background-color:#4ade8014;padding:2rem;border-radius:12px;border-left:4px solid var(--primary-color, #4ade80);box-shadow:0 2px 8px #0000001a}.license-notice h3{margin-top:0}.license-attribution-example{background-color:#0000004d;padding:1.25rem;border-radius:8px;margin-top:1.25rem;border:1px solid rgba(255,255,255,.1)}.license-attribution-example code{font-family:Monaco,Courier New,monospace;font-size:.95rem;color:#fffffff2;word-break:break-word;line-height:1.6}@media(max-width:768px){.license-page{padding:1.5rem 1rem 0}.license-container{padding:0}.license-container h1{font-size:2rem}.license-section h2{font-size:1.5rem}.license-section h3{font-size:1.1rem}.license-full-text{padding:1rem;font-size:.9rem}}.auth-error-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background-color:#000}.auth-error-container{max-width:500px;width:100%;text-align:center;padding:3rem;background-color:#1a1a1a;border-radius:8px;border:1px solid #333}.error-icon{margin:0 auto 2rem;width:64px;height:64px;color:#dc3545}.auth-error-container h1{margin-bottom:1rem;color:#fff;font-size:2rem}.error-message{font-size:1.1rem;color:#fff;margin-bottom:1rem;line-height:1.6}.error-details{color:#888;margin-bottom:2rem;line-height:1.6}.error-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn-home{padding:.75rem 1.5rem;border-radius:4px;text-decoration:none;font-size:1rem;cursor:pointer;transition:all .2s;background-color:#3b3b3b;color:#fff;display:inline-block}.restart-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000d9;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.restart-modal{background:#1a1a1a;border-radius:12px;padding:0;max-width:500px;width:90%;box-shadow:0 8px 32px #00000080;border:1px solid rgba(255,255,255,.1)}.restart-modal-header{padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.restart-modal-header h2{margin:0;font-size:1.25rem;color:#fff;font-weight:600}.restart-modal-body{padding:1.5rem}.restart-message{color:#d1d5db;font-size:.95rem;margin:0 0 1rem;line-height:1.5}.restart-status{color:#9ca3af;font-size:.9rem;margin:0 0 1.5rem;text-align:center}.restart-spinner-container{display:flex;justify-content:center;margin:1.5rem 0}.restart-spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.1);border-top-color:var(--primary-color, #4ade80);border-radius:50%;animation:restart-spin .8s linear infinite}@keyframes restart-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.restart-checks{display:flex;flex-direction:column;gap:.75rem}.restart-check{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1);transition:all .3s ease}.restart-check.up{background:#4ade801a;border-color:#4ade804d}.restart-check.polling{background:#fbbf241a;border-color:#fbbf244d}.restart-check.error{background:#ef44441a;border-color:#ef44444d}.restart-status-light{width:12px;height:12px;border-radius:50%;flex-shrink:0;box-shadow:0 0 8px currentColor;transition:all .3s ease}.restart-status-light.green{background:#4ade80;box-shadow:0 0 12px #4ade80}.restart-status-light.yellow{background:#fbbf24;box-shadow:0 0 12px #fbbf24;animation:restart-pulse 1.5s ease-in-out infinite}.restart-status-light.red{background:#ef4444;box-shadow:0 0 12px #ef4444}@keyframes restart-pulse{0%,to{opacity:1}50%{opacity:.5}}.restart-check-label{color:#d1d5db;font-size:.9rem;font-weight:500;flex:1}.restart-check-status{color:#9ca3af;font-size:.85rem;font-weight:400}.restart-success-animation{display:flex;justify-content:center;align-items:center;padding:2rem 0}.restart-checkmark{font-size:4rem;color:var(--primary-color, #4ade80);animation:checkmark-pop .5s ease-out}@keyframes checkmark-pop{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.restart-error-details{color:#ef4444;font-size:.9rem;margin:0 0 1.5rem;padding:1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;line-height:1.5}.restart-modal-body .btn-primary{width:100%;padding:.75rem;font-size:1rem}.setup-wizard{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:#1a1a1a;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;position:relative;overflow:hidden}.setup-wizard:before{content:"";position:absolute;top:-50%;right:-50%;bottom:-50%;left:-50%;background:conic-gradient(from 0deg at 50% 50%,#0a1820,#0d2825,#1f280a,#281a0a,#0a1f28,#152820,#201a15,#0d2825,#0a1820 360deg);animation:rotateGradient 20s linear infinite;opacity:.7;pointer-events:none}.setup-wizard.animation-boost:before{animation:rotateGradient 4s linear infinite!important}.setup-wizard.animation-boost:after{animation:float 3s ease-in-out infinite,pulse 1s ease-in-out infinite!important}.setup-wizard.animation-boost .setup-container:before{animation:float 3.2s ease-in-out infinite,pulse 1.3s ease-in-out infinite!important}.setup-wizard.animation-boost .setup-container:after{animation:float 2.5s ease-in-out infinite reverse,pulse 1.2s ease-in-out infinite reverse!important}.setup-wizard:after{content:"";position:absolute;top:-50%;right:-25%;width:800px;height:800px;background:radial-gradient(circle,rgba(255,193,7,.15) 0%,rgba(255,152,0,.08) 35%,transparent 60%);border-radius:50%;animation:float 18s ease-in-out infinite,pulse 6s ease-in-out infinite;pointer-events:none;z-index:0}.setup-container:after{content:"";position:fixed;bottom:-40%;left:-25%;width:700px;height:700px;background:radial-gradient(circle,rgba(0,188,212,.15) 0%,rgba(0,150,136,.08) 35%,transparent 60%);border-radius:50%;animation:float 22s ease-in-out infinite reverse,pulse 8s ease-in-out infinite reverse;pointer-events:none;z-index:0}.setup-container:before{content:"";position:fixed;top:40%;left:50%;width:650px;height:650px;background:radial-gradient(circle,rgba(74,222,128,.12) 0%,rgba(34,197,94,.06) 35%,transparent 60%);border-radius:50%;animation:float 25s ease-in-out infinite,pulse 10s ease-in-out infinite;pointer-events:none;z-index:0;transform:translate(-50%,-50%)}@keyframes float{0%{transform:translate(0) scale(1) rotate(0)}12%{transform:translate(-60px,40px) scale(1.08) rotate(45deg)}25%{transform:translate(80px,-30px) scale(.92) rotate(110deg)}37%{transform:translate(-40px,-60px) scale(1.12) rotate(195deg)}50%{transform:translate(50px,70px) scale(.95) rotate(250deg)}62%{transform:translate(-70px,-20px) scale(1.06) rotate(300deg)}75%{transform:translate(30px,-80px) scale(1.1) rotate(340deg)}87%{transform:translate(-50px,50px) scale(.98) rotate(390deg)}to{transform:translate(0) scale(1) rotate(450deg)}}@keyframes pulse{0%{opacity:1}25%{opacity:.7}50%{opacity:.5}75%{opacity:.8}to{opacity:1}}.setup-container{background:#2a2a2af2;border-radius:12px;border:1px solid #404040;box-shadow:0 8px 32px #00000080;max-width:700px;width:100%;padding:3rem;animation:slideUp .4s ease-out;position:relative;z-index:2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.setup-header{text-align:center;margin-bottom:2.5rem;position:relative;z-index:10}.setup-header h1{font-size:2rem;font-weight:700;color:#fff;margin:0 0 .5rem}.setup-header p{font-size:1rem;color:#a0aec0;margin:0}.setup-progress{display:flex;align-items:center;justify-content:space-between;margin-bottom:3rem;padding:0 1rem;position:relative;z-index:3}.progress-step{display:flex;flex-direction:column;align-items:center;gap:.5rem;flex:0 0 auto}.step-number{width:40px;height:40px;border-radius:50%;background:#404040;color:#666;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.1rem;transition:all .3s ease;border:1px solid #404040}.progress-step.active .step-number{background:var(--primary-color);color:#1e1e1e;border-color:var(--primary-color);transform:scale(1.1);box-shadow:0 0 12px #4ade8066}.progress-step.complete .step-number{background:var(--primary-color);color:#1e1e1e;border-color:var(--primary-color)}.progress-step.complete .step-number:before{content:"✓"}.step-label{font-size:.875rem;color:#666;font-weight:500;white-space:nowrap}.progress-step.active .step-label{color:var(--primary-color);font-weight:600}.progress-line{flex:1;height:2px;background:#404040;margin:0 .5rem 1.5rem;align-self:center}.setup-message{padding:1rem 1.25rem;border-radius:8px;margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.setup-message.error{background:#b91c1c33;color:#fca5a5;border:1px solid #991b1b}.setup-message.success{background:#22c55e33;color:var(--primary-color);border:1px solid var(--primary-color)}.message-icon{font-size:1.25rem}.setup-form{margin-bottom:2rem;position:relative;z-index:3}.setup-step{animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.setup-step h2{font-size:1.5rem;font-weight:600;color:#fff;margin:0 0 .5rem}.step-description{font-size:.95rem;color:#a0aec0;margin:0 0 2rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-weight:500;color:#e5e7eb;margin-bottom:.5rem;font-size:.95rem}.field-hint{display:block;font-weight:400;color:#9ca3af;font-size:.85rem;margin-top:.25rem}.form-group input[type=text],.form-group input[type=email],.form-group input[type=password],.form-group textarea{width:100%;padding:.75rem 1rem;background:#1e1e1e;border:1px solid #404040;border-radius:6px;color:#fff;font-size:1rem;transition:all .2s ease;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);background:#252525;box-shadow:0 0 0 3px #4ade801a}.form-group textarea{resize:vertical;min-height:80px}.color-inputs{display:flex;gap:1.5rem}.color-input-group{flex:1;display:flex;flex-direction:column;gap:.5rem}.color-input-group label{font-size:.875rem;font-weight:500;color:#e5e7eb;margin:0}.color-input-group input[type=color]{width:100%;height:60px;background:#1e1e1e;border:1px solid #404040;border-radius:6px;cursor:pointer;transition:all .2s ease}.color-input-group input[type=color]:hover{border-color:var(--primary-color)}.color-value{font-size:.875rem;color:#9ca3af;font-family:Courier New,monospace;text-align:center}.avatar-upload{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.avatar-preview{width:80px;height:80px;border-radius:50%;overflow:hidden;border:1px solid var(--primary-color);box-shadow:0 0 12px #4ade804d}.avatar-preview img{width:100%;height:100%;object-fit:cover}.file-input{display:none}.file-label{padding:.75rem 1.5rem;background:#404040;color:#e5e7eb;border-radius:6px;cursor:pointer;transition:all .2s ease;font-weight:500;border:1px solid #4a4a4a}.file-label:hover{background:#4a4a4a;border-color:var(--primary-color)}.button-text{background:none;border:none;color:#ef4444;cursor:pointer;font-size:.9rem;text-decoration:underline;padding:.5rem 1rem;transition:opacity .2s ease}.button-text:hover{opacity:.8}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;padding:.75rem;border-radius:6px;transition:background .2s ease;color:#e5e7eb}.checkbox-label:hover{background:#333}.checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer}.info-box{background:#4ade801a;border-left:3px solid var(--primary-color);padding:1rem 1.25rem;border-radius:6px;margin-bottom:1.5rem}.info-box p{margin:0 0 .75rem;font-size:.9rem;color:#d1d5db}.info-box p:last-child{margin-bottom:0}.info-box ol{margin:.5rem 0 0 1.25rem;padding:0;font-size:.875rem;color:#9ca3af}.info-box li{margin-bottom:.5rem}.info-box code{background:#1e1e1e;padding:.125rem .375rem;border-radius:3px;font-size:.85rem;font-family:Courier New,monospace;color:var(--primary-color)}.info-box a{color:var(--primary-color);text-decoration:none;font-weight:500}.info-box a:hover{text-decoration:underline}.form-section-divider{display:flex;align-items:center;gap:1rem;margin:2rem 0 1.5rem;color:#6b7280;font-size:.875rem;font-weight:500}.form-section-divider:before,.form-section-divider:after{content:"";flex:1;height:1px;background:#404040}.form-actions{display:flex;gap:1rem;margin-top:2rem}.button{flex:1;padding:.875rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit}.button-primary{background:var(--primary-color);color:#1e1e1e}.button-primary:hover:not(:disabled){background:var(--primary-color);filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 4px 12px #4ade8066}.button-primary:disabled{background:#404040;color:#666;cursor:not-allowed}.button-secondary{background:#404040;color:#e5e7eb}.button-secondary:hover{background:#4a4a4a}.setup-complete{text-align:center;padding:2rem 0}.setup-complete p{color:#d1d5db;font-size:1rem;margin:.5rem 0}.complete-icon{width:80px;height:80px;border-radius:50%;background:var(--primary-color);color:#1e1e1e;display:flex;align-items:center;justify-content:center;font-size:3rem;margin:0 auto 1.5rem;animation:scaleIn .5s ease-out;box-shadow:0 0 24px #4ade8080}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.complete-subtext{color:#9ca3af;font-size:.95rem}.next-steps{background:#4ade800d;border:1px solid #404040;border-radius:8px;padding:1.5rem;margin-top:2rem;text-align:left}.next-steps h3{margin:0 0 1rem;font-size:1.1rem;color:#fff}.next-steps ul{list-style:none;padding:0;margin:0}.next-steps li{padding:.5rem 0;color:#d1d5db;font-size:.95rem}.next-steps code{background:#1e1e1e;padding:.125rem .5rem;border-radius:4px;color:var(--primary-color);font-family:Courier New,monospace;font-size:.9rem}.setup-footer{text-align:center;padding-top:1.5rem;border-top:1px solid #404040;color:#6b7280;font-size:.875rem;position:relative;z-index:3}.setup-footer a{color:var(--primary-color);text-decoration:none;font-weight:500}.setup-footer a:hover{text-decoration:underline}.setup-loading,.setup-error{text-align:center;padding:3rem 2rem}.loading-spinner{width:50px;height:50px;border:4px solid #404040;border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}.setup-loading p,.setup-error p{color:#9ca3af;font-size:1rem}.setup-error h2{font-size:1.5rem;color:#fca5a5;margin:0 0 1rem}.retry-button{margin-top:1.5rem;padding:.75rem 2rem;background:var(--primary-color);color:#1e1e1e;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.retry-button:hover{background:var(--primary-color);filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 4px 12px #4ade8066}@media(max-width:640px){.setup-wizard{padding:1rem}.setup-container{padding:2rem 1.5rem}.setup-header h1{font-size:1.5rem}.setup-progress{padding:0}.step-label{font-size:.75rem}.step-number{width:36px;height:36px;font-size:1rem}.color-inputs{flex-direction:column;gap:1rem}.form-actions,.auth-method-choice{flex-direction:column}}.auth-method-choice{display:flex;gap:1rem;margin-top:.5rem}.auth-method-option{flex:1;display:flex;align-items:center;gap:1rem;padding:1rem;background:#333;border:1px solid #404040;border-radius:8px;cursor:pointer;transition:all .2s ease}.auth-method-option:hover{border-color:#555;background:#3a3a3a}.auth-method-option input[type=radio]{width:20px;height:20px;accent-color:var(--primary-color);cursor:pointer}.auth-method-option input[type=radio]:checked+.auth-method-label{color:#fff}.auth-method-option:has(input[type=radio]:checked){border-color:var(--primary-color);background:#4ade801a}.auth-method-label{display:flex;flex-direction:column;gap:.25rem;color:#a0aec0;transition:color .2s ease}.auth-method-label strong{font-size:1rem;color:#e0e0e0}.auth-method-label span{font-size:.875rem;color:gray}.video-page{display:flex;flex-direction:column;min-height:100vh;background:#000;color:#fff;padding:20px}.video-page-header{margin-bottom:24px}.back-button{display:flex;align-items:center;gap:8px;padding:10px 20px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:#fff;font-size:.95rem;cursor:pointer;transition:all .2s ease}.back-button:hover{background:#ffffff26;border-color:#ffffff4d}.back-button:active{transform:scale(.98)}.video-page-content{display:flex;flex-direction:column;gap:24px;max-width:1200px;margin:0 auto;width:100%}.video-page-player{width:100%;aspect-ratio:16 / 9;border-radius:8px;overflow:hidden;background:#000}.video-page-info{display:flex;flex-direction:column;gap:16px}.video-page-title{font-size:2rem;font-weight:600;color:#fff;margin:0;line-height:1.3}.video-page-description{font-size:1.1rem;color:#fffc;line-height:1.6;margin:0;white-space:pre-wrap}.video-page-loading,.video-page-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:20px;text-align:center;padding:20px}.video-page-error{color:#fff}.loading-spinner{border:4px solid rgba(255,255,255,.1);border-top:4px solid var(--primary-color, #4ade80);border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite}.error-icon{font-size:3rem}@media(max-width:768px){.video-page{padding:16px}.video-page-header{margin-bottom:16px}.back-button{width:100%;justify-content:center}.video-page-title{font-size:1.5rem}.video-page-description{font-size:1rem}}@font-face{font-family:Modern DOS;src:url(/fonts/ModernDOS8x16.ttf) format("truetype");font-weight:400;font-style:normal}.admin-portal{position:relative}.admin-portal.animated-bg:before{content:"";position:fixed;top:-100%;right:-100%;bottom:-100%;left:-100%;background:radial-gradient(circle at 50% 50%,#1a1a1a 0%,transparent 30%),conic-gradient(from 0deg at 50% 50%,#0a1820,#0d2825,#1f280a,#281a0a,#0a1f28,#152820,#201a15,#0d2825,#0a1820 360deg);animation:rotateGradient 20s linear infinite;opacity:.7;pointer-events:none;z-index:0}@keyframes rotateGradient{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.admin-portal.animated-bg:after{content:"";position:fixed;top:-50%;right:-25%;width:800px;height:800px;background:radial-gradient(circle,rgba(255,193,7,.15) 0%,rgba(255,152,0,.08) 35%,transparent 60%);border-radius:50%;animation:float 18s ease-in-out infinite,pulse 6s ease-in-out infinite;pointer-events:none;z-index:0}.bokeh-circle-1{position:fixed;bottom:-40%;left:-25%;width:700px;height:700px;background:radial-gradient(circle,rgba(0,188,212,.15) 0%,rgba(0,150,136,.08) 35%,transparent 60%);border-radius:50%;animation:floatReverse 22s ease-in-out infinite,pulseReverse 8s ease-in-out infinite;pointer-events:none;z-index:0}.bokeh-circle-2{position:fixed;top:40%;left:50%;width:650px;height:650px;background:radial-gradient(circle,rgba(74,222,128,.12) 0%,rgba(34,197,94,.06) 35%,transparent 60%);border-radius:50%;animation:floatCenter 25s ease-in-out infinite,pulse 10s ease-in-out infinite;pointer-events:none;z-index:0}@keyframes float{0%,to{transform:translate(0) rotate(0)}33%{transform:translate(30px,-30px) rotate(5deg)}66%{transform:translate(-20px,20px) rotate(-5deg)}}@keyframes floatReverse{0%,to{transform:translate(0) rotate(0)}33%{transform:translate(-30px,30px) rotate(-5deg)}66%{transform:translate(20px,-20px) rotate(5deg)}}@keyframes floatCenter{0%,to{transform:translate(-50%,-50%) rotate(0)}33%{transform:translate(calc(-50% + 30px),calc(-50% - 30px)) rotate(5deg)}66%{transform:translate(calc(-50% - 20px),calc(-50% + 20px)) rotate(-5deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}@keyframes pulseReverse{0%,to{opacity:.8}50%{opacity:1}}.toast-container{position:fixed;bottom:20px;right:20px;z-index:99999;pointer-events:none;display:flex;flex-direction:column-reverse;gap:1rem}.toast{position:relative;min-width:300px;max-width:500px;padding:1rem 1.25rem;border-radius:8px;box-shadow:0 8px 32px #0006,0 2px 8px #0003;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);animation:slideInRight .3s ease-out;pointer-events:all}@keyframes slideInRight{0%{transform:translateY(100px);opacity:0}to{transform:translateY(0);opacity:1}}.toast-content{display:flex;align-items:center;gap:.75rem}.toast-icon{font-size:1.5rem;flex-shrink:0;line-height:1}.toast-text{flex:1;font-size:.95rem;line-height:1.5}.toast-close{background:none;border:none;color:inherit;font-size:1.75rem;line-height:1;padding:0;margin-left:.5rem;cursor:pointer;opacity:.6;transition:opacity .2s ease,transform .2s ease;flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.toast-close:hover{opacity:1;transform:scale(1.1)}.toast-close:active{transform:scale(.95)}.toast-success{background:linear-gradient(135deg,#1a4d2ef2,#143c24f2);border:1.5px solid var(--primary-color);color:var(--primary-color)}.toast-success .toast-icon{color:var(--primary-color)}.toast-error{background:linear-gradient(135deg,#4d1a1af2,#3c1414f2);border:1.5px solid #f87171;color:#f87171}.toast-error .toast-icon{color:#f87171}@media(max-width:600px){.toast-container{right:10px;left:10px}.toast{min-width:unset;max-width:400px;margin:0 auto}@keyframes slideInRight{0%{transform:translateY(100px);opacity:0}to{transform:translateY(0);opacity:1}}}@media(min-width:600px){.admin-portal{margin-top:54px}}.admin-container{max-width:1024px;margin:0 auto;position:relative;z-index:1;overflow:visible}.admin-header{display:flex;justify-content:space-between;align-items:center;position:relative;margin-bottom:1rem}.admin-header .btn-logout{flex-shrink:0}.admin-header .admin-tabs{margin-left:auto}.admin-user-info{display:flex;align-items:center;gap:1rem}.admin-avatar{width:50px;height:50px;border-radius:50%;border:1px solid #444}.admin-container h1{margin:0;color:#fff;font-size:2.2rem;font-weight:700;background:linear-gradient(135deg,#fff,#e5e7eb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:flex;align-items:center;gap:.75rem}.admin-status{display:flex;align-items:center;gap:.5rem;margin-top:.25rem}.admin-tabs{display:flex;gap:.5rem}.tab-button{padding:.75rem 1.5rem;background:transparent;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#888;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;height:100%;display:flex;align-items:center;justify-content:center}.tab-button:hover{color:#fff;background:#ffffff0d;border-color:#fff3}.tab-button.active{color:#fff;background:color-mix(in srgb,var(--primary-color) 15%,transparent);border-color:var(--primary-color)}.btn-delete{padding:.5rem;background-color:transparent;border:1px solid #444;border-radius:4px;color:#dc3545;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-delete:hover{background-color:#dc3545;color:#fff;border-color:#dc3545}.section-actions{display:flex;gap:1rem;justify-content:flex-end}.btn-primary,.btn-secondary,.btn-danger,.btn-logout,.btn-login,.btn-home{padding:.75rem 1.5rem;border-radius:6px;text-decoration:none;font-size:1rem;cursor:pointer;transition:all .2s;border:none;font-family:inherit;display:inline-flex;align-items:center;justify-content:center}.btn-primary{background:var(--primary-color);color:#000;font-weight:600;box-shadow:0 4px 12px color-mix(in srgb,var(--primary-color) 30%,transparent);transition:all .2s ease}.btn-primary:hover:not(:disabled){background:var(--primary-color);filter:brightness(.9);box-shadow:0 6px 16px color-mix(in srgb,var(--primary-color) 40%,transparent);transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:#ffffff0d;color:#fff;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .2s ease}.btn-secondary:hover{background:#ffffff1a;border-color:#fff3;transform:translateY(-1px)}.btn-danger{background:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.3);font-weight:600;transition:all .2s ease}.btn-danger:hover:not(:disabled){background:#ef444440;border-color:#ef444480;color:#ff6b6b;transform:translateY(-1px)}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.btn-logout{background:transparent;color:#888;border:1px solid rgba(255,255,255,.1);font-weight:500;transition:all .2s ease}.btn-logout:hover{background:#ffffff0d;border-color:#fff3;color:#fff;transform:translateY(-1px)}.btn-login{background:linear-gradient(135deg,#4285f4,#357ae8);color:#fff;font-weight:500;box-shadow:0 4px 12px #4285f44d;transition:all .2s ease}.btn-login:hover{background:linear-gradient(135deg,#357ae8,#2d5aa0);box-shadow:0 6px 16px #4285f466;transform:translateY(-1px)}.btn-home{background-color:#3b3b3b;color:#fff;text-align:center}.btn-home:hover{background-color:#4b4b4b}.auth-section{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:80vh;padding:2rem 1rem}.auth-header{text-align:center;margin-bottom:3rem}.auth-subtitle{color:#a0a0a0;font-size:1.1rem;margin-top:.5rem;font-weight:400}.auth-card{background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:3rem 2.5rem;width:100%;max-width:400px;text-align:center;box-shadow:0 20px 40px #0000004d;position:relative;overflow:hidden}.auth-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent)}.auth-icon{display:flex;justify-content:center;margin-bottom:1.5rem;color:var(--primary-color)}.auth-card h2{color:#fff;font-size:1.8rem;font-weight:600;margin:0 0 1rem;background:linear-gradient(135deg,#fff,#e5e7eb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-description{color:#b0b0b0;font-size:1rem;line-height:1.6;margin:0 0 2rem}.auth-input-group{margin-bottom:1rem;text-align:left}.auth-input-label{display:block;font-size:.875rem;font-weight:500;color:#e5e7eb;margin-bottom:.5rem}.auth-input{width:100%;padding:.875rem 1rem;background:#ffffff0d;border:1.5px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;font-size:1rem;box-sizing:border-box;transition:all .2s ease;outline:none}.auth-input::placeholder{color:#ffffff4d}.auth-input:hover{border-color:#fff3;background:#ffffff12}.auth-input:focus{border-color:var(--primary-color);background:#ffffff14;box-shadow:0 0 0 3px rgba(var(--primary-color-rgb, 129, 140, 248),.1)}.auth-input:disabled{opacity:.5;cursor:not-allowed}.auth-actions{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.auth-actions .btn-login{background:linear-gradient(135deg,#4285f4,#357ae8);color:#fff;font-weight:600;padding:1rem 2rem;border-radius:8px;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;font-size:1.1rem;box-shadow:0 4px 12px #4285f44d;transition:all .3s ease;border:none;cursor:pointer}.auth-actions .btn-login:hover{background:linear-gradient(135deg,#357ae8,#2d5aa0);box-shadow:0 6px 20px #4285f466;transform:translateY(-2px)}.auth-actions .btn-home{background:#ffffff1a;color:#fff;font-weight:500;padding:.875rem 2rem;border-radius:8px;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;font-size:1rem;border:1px solid rgba(255,255,255,.2);transition:all .3s ease;cursor:pointer}.auth-actions .btn-home:hover{background:#ffffff26;border-color:#ffffff4d;transform:translateY(-1px)}.auth-features{text-align:left;background:#ffffff08;border-radius:8px;padding:1.5rem;border:1px solid rgba(255,255,255,.05)}.auth-features h3{color:#fff;font-size:1.1rem;font-weight:600;margin:0 0 1rem;text-align:center}.auth-features ul{list-style:none;padding:0;margin:0}.auth-features li{color:silver;font-size:.95rem;line-height:1.5;margin-bottom:.5rem;padding-left:1.5rem;position:relative}.auth-features li:before{content:"✓";position:absolute;left:0;color:var(--primary-color);font-weight:700}.auth-features li:last-child{margin-bottom:0}.login-error{background:#fee2e2;border:1px solid #ef4444;color:#991b1b;padding:.75rem 1rem;border-radius:6px;margin-bottom:1.5rem;font-size:.875rem}.mfa-info-box{text-align:center;margin-bottom:1.5rem;padding:1rem;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px}.mfa-info-box-title{font-weight:600;color:#15803d;margin:0 0 .5rem}.mfa-info-box-text{font-size:.875rem;color:#16a34a;margin:0 0 .5rem}.mfa-info-box-email{font-size:.875rem;color:#15803d;font-weight:600;margin:0;font-family:monospace}.auth-form-full{width:100%}.auth-input-group-spaced{margin-bottom:1.5rem}.mfa-token-input{font-size:1.5rem;text-align:center;letter-spacing:.5em;font-weight:600}.btn-login-google{display:flex;align-items:center;justify-content:center;text-decoration:none;width:100%;height:56px;background:#fff;border:1px solid #d1d5db;box-shadow:0 4px 12px #00000014;color:#374151;transition:box-shadow .2s ease}.btn-login-google:hover{box-shadow:0 6px 20px #0000001f}.btn-login-passkey{display:flex;align-items:center;justify-content:center;width:100%;height:56px;background:linear-gradient(135deg,#3b82f6,#2563eb);border:1px solid rgba(59,130,246,.3);box-shadow:0 4px 12px #3b82f64d;transition:box-shadow .2s ease}.btn-login-passkey:hover{box-shadow:0 6px 20px #3b82f666}.btn-login-password{display:flex;align-items:center;justify-content:center;width:100%;height:56px;background:linear-gradient(135deg,#10b981,#059669);border:1px solid rgba(16,185,129,.3);box-shadow:0 4px 12px #10b9814d;transition:box-shadow .2s ease}.btn-login-password:hover{box-shadow:0 6px 20px #10b98166}.btn-login-full{width:100%}.btn-back{width:100%;padding:.75rem;background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;color:#6b7280;transition:all .2s ease}.btn-back:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.btn-back:disabled{opacity:.5;cursor:not-allowed}.loading-container-full{min-height:calc(100vh - 100px);display:flex;flex-direction:column;justify-content:center;align-items:center;padding-top:2rem}.auth-return-link{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.auth-version{text-align:center;margin-top:1rem;color:#fff6;font-size:.875rem;font-weight:400}@media(max-width:768px){.auth-section{padding:1rem;min-height:70vh}.auth-card{padding:2rem 1.5rem;margin:0 1rem}.auth-header h1{font-size:2rem}.auth-card h2{font-size:1.5rem}.auth-actions{gap:.75rem}.auth-actions .btn-login,.auth-actions .btn-home{padding:.875rem 1.5rem;font-size:1rem}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;gap:1rem}.loading-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.1);border-top:3px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container p{color:#a1a1aa;font-size:1rem;margin:0}.admin-footer{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #333;display:flex;justify-content:space-between;align-items:center}.footer-info p{color:#6b7280;font-size:.85rem;margin:0}@media(max-width:768px){.admin-header{flex-direction:row;gap:1rem;align-items:center}.admin-header .btn-logout{flex-shrink:0;padding:.5rem .75rem;font-size:.85rem}.admin-header .btn-logout svg{display:none}.admin-header .admin-tabs{position:static;transform:none;overflow-x:auto;margin-left:auto}.admin-tabs{gap:.25rem;height:100%}.tab-button{padding:.5rem .75rem;font-size:.85rem;white-space:nowrap}.tab-button svg{display:none}.admin-footer{flex-direction:column;gap:1rem;align-items:flex-start}.admin-footer .btn-logout{width:100%}.album-input-group{flex-direction:column;align-items:stretch}.album-grid{grid-template-columns:1fr}.photos-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.photos-header{flex-direction:column;align-items:stretch}.admin-container h1{font-size:1.8rem}.admin-section{margin-bottom:2rem;padding:1.5rem}.admin-section h2{font-size:1.4rem}.link-fields,.section-actions{flex-direction:column}.section-actions button{width:100%}.branding-grid{grid-template-columns:1fr;gap:1rem}.color-input-group{flex-direction:column;align-items:stretch}.color-picker{width:100%;height:40px}.link-item{padding:1rem}.branding-input,.branding-textarea,.link-input{font-size:16px}}.galleria-footer{margin-top:3rem;padding:2rem 0 1rem;text-align:center;border-top:1px solid rgba(255,255,255,.1)}.galleria-footer .footer-text{font-size:.85rem;color:#fff6;font-weight:500;letter-spacing:.02em}.galleria-footer .footer-galleria-link{color:#4ade80;text-decoration:none;font-weight:600;border-bottom:1px solid transparent;transition:all .2s ease}.galleria-footer .footer-galleria-link:hover{color:#22c55e;border-bottom-color:#22c55e}.galleria-footer .footer-galleria-link:visited{color:#4ade80}@media(max-width:768px){.galleria-footer{margin-top:2rem;padding:1.5rem 0 1rem}.galleria-footer .footer-text{font-size:.8rem}}
