@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap);*{box-sizing:border-box;margin:0;padding:0}body{background:linear-gradient(135deg,#000,#1a1a1a);color:#fff;flex-direction:column;font-family:Inter,system-ui,sans-serif;line-height:1.6;min-height:100vh;overflow-x:hidden}#root,body{display:flex}#root{flex:1 1;flex-direction:column}body:before{animation:backgroundShift 25s ease-in-out infinite;background:radial-gradient(circle at 20% 50%,#ffffff08 0,#0000 50%),radial-gradient(circle at 80% 20%,#ffffff05 0,#0000 50%),radial-gradient(circle at 40% 80%,#ffffff0a 0,#0000 50%);content:"";height:100%;left:0;position:fixed;top:0;width:100%;z-index:-1}@keyframes backgroundShift{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-30px) scale(1.02)}}.container{margin:0 auto;max-width:1200px;padding:0 1rem}.main{display:flex;flex:1 1;flex-direction:column;padding-top:2rem}.section{margin-bottom:4rem;position:relative}.header{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#000000e6;border-bottom:1px solid #ffffff1a;position:sticky;top:0;transition:all .3s ease;z-index:50}.header:before{background:linear-gradient(90deg,#0000,#ffffff4d,#0000);content:"";height:1px;left:0;position:absolute;right:0;top:0}.header-content{height:5rem}.logo{gap:1rem;margin-right:3rem;z-index:10}.logo,.logo-container{align-items:center;display:flex;flex-shrink:0}.logo-container{aspect-ratio:1/1;background:#fffffffa;border:2px solid #fff3;border-radius:50%;box-shadow:0 8px 32px #0006;height:4rem;justify-content:center;max-height:4rem;max-width:4rem;min-height:4rem;min-width:4rem;overflow:hidden;padding:.25rem;transition:all .3s ease;width:4rem}.logo-container:hover{border-color:#fff6;box-shadow:0 12px 40px #fff3;transform:scale(1.05) rotate(2deg)}.logo-image{border-radius:50%;height:100%;object-fit:cover;transition:all .3s ease;width:100%}.logo-container:hover .logo-image{transform:scale(1.1)}.logo-location{color:#fff;font-size:.875rem;font-weight:600;margin:0}.logo-est{color:#a3a3a3;font-size:.75rem;font-weight:500;margin:0}.nav{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#171717cc;border:1px solid #ffffff1a;border-radius:1rem;display:flex;gap:1rem;padding:.5rem}.nav-link{align-items:center;background:none;border:none;border-radius:.75rem;color:#d4d4d4;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;overflow:hidden;padding:.75rem 1.25rem;position:relative;text-decoration:none;transition:all .3s ease}.nav-link:before{background:linear-gradient(90deg,#0000,#ffffff0d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.nav-link:hover:before{left:100%}.nav-link:hover{background:#ffffff14;box-shadow:0 4px 20px #ffffff1a;color:#fff;transform:translateY(-2px)}.nav-link.active{background:linear-gradient(135deg,#fff,#e5e5e5);box-shadow:0 4px 20px #fff3;color:#000}.mobile-menu-button{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#171717e6;border:1px solid #fff3;border-radius:.75rem;color:#fff;cursor:pointer;display:none;justify-content:center;min-height:44px;min-width:44px;padding:.75rem;transition:all .3s ease}.mobile-menu-button:hover{background:#ffffff1a;transform:scale(1.05)}@media (max-width:1024px){.header-content{gap:1rem;padding:0 1rem}.logo{flex:1 1;margin-right:0}.logo,.logo-text{min-width:0}.logo-location{font-size:.8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logo-est{font-size:.7rem;white-space:nowrap}.nav{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#000000f2;border:1px solid #ffffff1a;border-radius:1rem;box-shadow:0 20px 60px #00000080;display:none;flex-direction:column;left:1rem;padding:1.5rem;position:absolute;right:1rem;top:calc(100% + .5rem);z-index:1000}.nav.mobile-open{animation:slideDown .3s ease;display:flex}.mobile-menu-button{display:block;flex-shrink:0;min-height:44px;min-width:44px}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.hero{border-radius:2rem;box-shadow:0 25px 50px #00000080;height:80vh;margin-bottom:4rem;overflow:hidden;position:relative}.hero-image{animation:heroZoom 20s ease-in-out infinite;filter:grayscale(30%) contrast(1.1);height:120%;object-fit:cover;transition:transform 8s ease;width:100%}@keyframes heroZoom{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.hero-overlay{background:linear-gradient(135deg,#000000b3,#11111180 50%,#0000),radial-gradient(circle at 30% 70%,#ffffff1a 0,#0000 70%);inset:0;position:absolute;z-index:10}.hero-content{align-items:center;display:flex;inset:0;justify-content:center;padding:2rem;position:absolute;text-align:center;z-index:20}.hero-text{animation:heroFadeIn 1.5s ease-out;max-width:800px}@keyframes heroFadeIn{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.hero-text h1{color:#fff;font-size:clamp(2.5rem,8vw,5rem);font-weight:900;letter-spacing:-.02em;margin-bottom:1.5rem;text-shadow:0 4px 20px #000c}.hero-text p:first-of-type{color:#e5e5e5;font-size:clamp(1.125rem,3vw,1.5rem);font-weight:600;margin-bottom:2rem;text-shadow:0 2px 10px #000c}.hero-text p:last-of-type{color:#d4d4d4;font-size:clamp(1rem,2.5vw,1.25rem);font-weight:500;text-shadow:0 2px 10px #000c}.card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#171717e6;border:1px solid #ffffff1a;border-radius:1.5rem;box-shadow:0 10px 40px #0000004d;overflow:hidden;padding:2.5rem;position:relative;transition:all .4s ease}.card:before{background:linear-gradient(90deg,#0000,#fff,#0000);content:"";height:2px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.card:hover:before{opacity:.3}.card:hover{border-color:#fff3;box-shadow:0 20px 60px #ffffff0d;transform:translateY(-8px)}.card-with-bg{background-image:linear-gradient(135deg,#000c,#171717b3);background-position:50%;background-size:cover;color:#fff;display:flex;flex-direction:column;justify-content:flex-end;min-height:300px}.card h2,.card h3{color:#fff;font-weight:700;margin-bottom:1.5rem}.card h2{font-size:2.25rem}.card p{color:#d4d4d4;line-height:1.6;margin-bottom:1rem}.event-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#171717e6;border:1px solid #ffffff1a;border-radius:1.25rem;cursor:pointer;overflow:hidden;padding:2rem;position:relative;transition:all .4s ease}.event-card:after{background:linear-gradient(90deg,#0000,#ffffff0d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .6s ease;width:100%}.event-card:hover:after{left:100%}.event-card:hover{background:#282828e6;border-color:#fff3;box-shadow:0 15px 50px #ffffff1a;transform:translateY(-5px) scale(1.02)}.btn{align-items:center;border:none;border-radius:.75rem;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;justify-content:center;letter-spacing:.5px;overflow:hidden;padding:.875rem 2rem;position:relative;text-decoration:none;text-transform:uppercase;transition:all .3s ease}.btn-secondary:hover{background:#ffffff1a;border-color:#ffffff80;transform:translateY(-2px)}.feature-list{display:flex;flex-direction:column;gap:1.5rem}.feature-item{align-items:center;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:.75rem;color:#fff;display:flex;gap:1rem;padding:1rem;transition:all .3s ease}.feature-item:hover{background:#ffffff14;border-color:#fff3;transform:translateX(5px)}.feature-item span{font-size:1.125rem;font-weight:600}.event-meta{color:#d4d4d4;margin-bottom:.5rem}.event-location,.event-meta{align-items:center;display:flex;font-size:.875rem;gap:.5rem}.event-location{color:#a3a3a3;margin-bottom:.75rem}.event-footer{align-items:center;display:flex;justify-content:space-between;margin-top:1rem}.event-attendees{color:#a3a3a3;font-size:.875rem}.grid{grid-gap:2rem;display:grid;gap:2rem}.grid-2{grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.footer{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(135deg,#000000f2,#171717f2);border-top:1px solid #ffffff1a;margin-top:auto;padding:3rem 0;position:relative}.footer:before{background:linear-gradient(90deg,#0000,#ffffff4d,#0000);content:"";height:1px;left:0;position:absolute;right:0;top:0}.footer-content{color:#a3a3a3;font-size:.875rem;font-weight:500;text-align:center}@media (max-width:768px){.hero{height:60vh;margin-bottom:2rem}.container{padding:0 1rem}.grid{gap:1.5rem}.card{padding:1.5rem}.section{margin-bottom:2rem}.header-content{height:4rem;padding:0 .75rem}.logo-container{height:3rem;max-height:3rem;max-width:3rem;min-height:3rem;min-width:3rem;width:3rem}.nav{left:.75rem;padding:1.25rem;right:.75rem}.nav-link{font-size:.9rem;min-height:48px;padding:1rem 1.25rem}}.about-content{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:#000000bf;border:1px solid #ffffff1a;border-radius:1rem;padding:2rem}.about-text{margin-bottom:2rem}.about-text p{line-height:1.7;margin-bottom:1.5rem}.intro-text{color:#fff;font-size:1.25rem;font-weight:600;margin-bottom:1.5rem!important}.description-text{color:#e5e5e5;font-size:1rem;font-weight:400}.mission-text{color:#d4d4d4;font-size:.95rem;font-weight:400}@media (max-width:768px){.about-content{padding:1.5rem}.about-text p{font-size:.95rem;line-height:1.6;margin-bottom:1.25rem}.intro-text{font-size:1.125rem!important;margin-bottom:1.25rem!important}.description-text{font-size:.925rem}.mission-text{font-size:.9rem}.card h2{font-size:1.75rem;margin-bottom:1.25rem}.feature-list{gap:1rem}.feature-item{font-size:.9rem;padding:.75rem}.feature-item span{font-size:1rem}}@media (max-width:480px){.header-content{height:3.5rem;padding:0 .5rem}.logo-container{height:2.5rem;max-height:2.5rem;max-width:2.5rem;min-height:2.5rem;min-width:2.5rem;width:2.5rem}.logo-location{font-size:.75rem}.logo-est{font-size:.65rem}.mobile-menu-button{min-height:40px;min-width:40px;padding:.5rem}.nav{left:.5rem;right:.5rem}.about-content,.nav{padding:1rem}.about-text p{font-size:.9rem;line-height:1.55;margin-bottom:1rem}.intro-text{font-size:1rem!important}.card h2{font-size:1.5rem}}.loading-pulse{animation:pulse 2s infinite;background:linear-gradient(90deg,#ffffff0d 25%,#ffffff1a 50%,#ffffff0d 75%);background-size:200% 100%;border-radius:.5rem}@keyframes pulse{0%{background-position:200% 0}to{background-position:-200% 0}}.album-grid{animation:fadeIn .3s ease-in;display:flex;flex-wrap:wrap;gap:2rem;justify-content:center;padding:0}.album-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#171717e6;border:1px solid #ffffff1a;border-radius:1.5rem;box-shadow:0 10px 40px #0000004d;cursor:pointer;flex-shrink:0;overflow:hidden;transition:all .4s ease;width:350px}.album-card:hover{border-color:#fff3;box-shadow:0 20px 60px #ffffff0d;transform:translateY(-8px)}.album-thumbnail{background:#0f172a80;overflow:hidden;padding-top:66.67%;position:relative;width:100%}.album-thumbnail img{height:100%;left:0;object-fit:cover;position:absolute;top:0;transition:transform .3s ease;width:100%}.album-card:hover .album-thumbnail img{transform:scale(1.05)}.album-placeholder{align-items:center;background:linear-gradient(135deg,#1e293b80,#0f172a80);color:#64748b;display:flex;flex-direction:column;height:100%;justify-content:center;left:0;position:absolute;top:0;width:100%}.album-placeholder p{font-size:.875rem;margin-top:.5rem}.album-overlay{background:linear-gradient(0deg,#000c,#0000);bottom:0;left:0;opacity:0;padding:1rem;position:absolute;right:0;transition:opacity .3s ease}.album-card:hover .album-overlay{opacity:1}.photo-count{font-size:.875rem;gap:.5rem}.album-badge,.photo-count{align-items:center;color:#fff;display:flex}.album-badge{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000000b3;border-radius:.375rem;font-size:.75rem;gap:.25rem;padding:.25rem .5rem;position:absolute;right:.75rem;top:.75rem}.album-badge.public{background:#22c55e33;border:1px solid #22c55e80}.album-badge.private{background:#ef444433;border:1px solid #ef444480}.album-badge.password{background:#fbbf2433;border:1px solid #fbbf2480;left:.75rem;right:auto;top:.75rem}.album-info{padding:1rem}.album-info h3{color:#fff;font-size:1.125rem;font-weight:600;margin:0 0 .5rem}.album-author{align-items:center;color:#94a3b8;display:flex;font-size:.875rem;gap:.375rem;margin:0 0 .25rem}.album-date{color:#64748b;font-size:.75rem;margin:0}.album-list{display:flex;flex-direction:column;gap:1rem}.album-list-item{background:#1e293b80;border:1px solid #94a3b81a;border-radius:.75rem;cursor:pointer;display:flex;gap:1rem;padding:1rem;transition:all .2s ease}.album-list-item:hover{background:#1e293bb3;border-color:#3b82f64d}.album-list-thumbnail{background:#0f172a80;border-radius:.5rem;flex-shrink:0;height:80px;overflow:hidden;width:120px}.album-list-thumbnail img{height:100%;object-fit:cover;width:100%}.album-list-thumbnail .album-placeholder{align-items:center;display:flex;height:100%;justify-content:center;position:relative;width:100%}.album-list-info{flex:1 1;min-width:0}.album-list-info h3{color:#fff;font-size:1.125rem;font-weight:600;margin:0 0 .25rem}.album-description{color:#cbd5e1;margin:0 0 .5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.album-meta{color:#94a3b8;font-size:.75rem}.album-meta span{gap:.25rem}.empty-state{color:#64748b;padding:4rem 2rem;text-align:center}.empty-icon{margin-bottom:1rem;opacity:.5}@media (min-width:1200px){.album-grid{gap:2.5rem}.album-card{width:380px}}@media (min-width:1600px){.album-grid{gap:3rem}.album-card{width:400px}}@media (min-width:1800px){.album-card{width:420px}}@media (max-width:768px){.album-grid{gap:1rem;padding:0}.album-card{width:280px}.album-list-item{flex-direction:column;padding:1rem}.album-list-thumbnail{height:200px;width:100%}.album-meta{align-items:flex-start;flex-direction:column;gap:.75rem}.album-card{border-radius:1rem}}@media (max-width:480px){.album-grid{gap:1rem;padding:0}.album-card{border-radius:1rem;margin-bottom:.5rem}.album-info{padding:.75rem}.album-info h3{font-size:1rem;margin-bottom:.25rem}.album-author{font-size:.8rem;margin-bottom:.25rem}.album-date{font-size:.7rem}.album-meta{gap:.5rem}.album-meta span{font-size:.7rem}}.album-actions-overlay{display:flex;gap:.5rem;opacity:0;position:absolute;right:.5rem;top:.5rem;transition:opacity .2s;z-index:10}.album-card:hover .album-actions-overlay,.album-list-item:hover .album-actions-overlay{opacity:1}.album-action{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000000b3;border:none;border-radius:.375rem;color:#fff;cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s;width:32px}.album-action:hover{transform:scale(1.1)}.album-action.edit-action{background:#3b82f6cc}.album-action.edit-action:hover{background:#2563ebe6}.album-action.delete-action{background:#ef4444cc}.album-action.delete-action:hover{background:#dc2626e6}.album-list-item{position:relative}.album-list-item .album-actions-overlay{position:absolute;right:1rem;top:1rem}.uploader-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#000c;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.uploader-modal{animation:slideIn .3s ease-out;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#171717f2;border:1px solid #ffffff1a;border-radius:1.5rem;box-shadow:0 25px 50px #00000080;max-height:90vh;max-width:1000px;overflow:hidden;width:90%}.uploader-header{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;padding:1.5rem}.uploader-header h2{align-items:center;color:#fff;display:flex;font-size:1.5rem;font-weight:600;gap:.5rem;margin:0}.btn-close{border-radius:.75rem;color:#a3a3a3;transition:all .3s ease}.btn-close:hover:not(:disabled){background:#ffffff14}.uploader-content{max-height:calc(90vh - 120px);overflow-y:auto;padding:1.5rem}.drop-zone{background:#00000080;border:2px dashed #a3a3a3;border-radius:1rem;cursor:pointer;padding:3rem 1.5rem;text-align:center;transition:all .3s ease}.drop-zone.drag-over{background:#ffffff0d;border-color:#fff}.drop-zone:hover{background:#ffffff08;border-color:#fff}.drop-zone-content{align-items:center;display:flex;flex-direction:column;gap:1rem}.drop-zone-icon{color:#a3a3a3}.drop-zone h3{color:#fff;font-size:1.25rem;font-weight:600;margin:0}.drop-zone p{color:#d4d4d4;font-size:.875rem;margin:0}.file-list{margin-top:1rem}.file-list-header{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.file-list-header h4{color:#fff;font-size:1.125rem;font-weight:600;margin:0}.file-actions{display:flex;gap:1rem}.btn-clear{background:#0000;border:1px solid #ffffff1a;border-radius:.75rem;color:#a3a3a3;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:all .3s ease}.btn-clear:hover:not(:disabled){background:#ffffff14;border-color:#fff3;color:#fff}.btn-upload{align-items:center;background:linear-gradient(135deg,#fff,#e5e5e5);border:none;border-radius:.75rem;box-shadow:0 4px 20px #fff3;color:#000;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.5rem 1rem;transition:all .3s ease}.btn-upload:hover:not(:disabled){background:linear-gradient(135deg,#e5e5e5,#d4d4d4);box-shadow:0 8px 30px #ffffff4d;transform:translateY(-2px)}.btn-upload:disabled{background:#ffffff1a;box-shadow:none;color:#a3a3a3;cursor:not-allowed;transform:none}.file-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));max-height:400px;overflow-y:auto}.file-item{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#17171780;border:1px solid #ffffff1a;border-radius:.75rem;overflow:hidden;position:relative;transition:all .3s ease}.file-item.uploading{border-color:#fff;box-shadow:0 0 20px #fff3}.file-item.success{border-color:#22c55e;box-shadow:0 0 20px #22c55e33}.file-item.error{border-color:#ef4444;box-shadow:0 0 20px #ef444433}.file-preview{height:120px;overflow:hidden;position:relative;width:100%}.preview-media{display:block;height:100%;object-fit:cover;width:100%}.video-preview{height:100%;position:relative;width:100%}.video-overlay{border-radius:50%;height:48px;left:50%;top:50%;transform:translate(-50%,-50%);width:48px}.btn-remove,.video-overlay{align-items:center;background:#000000b3;color:#fff;display:flex;justify-content:center;position:absolute}.btn-remove{border:none;border-radius:50%;cursor:pointer;height:24px;opacity:0;right:.5rem;top:.5rem;transition:opacity .2s;width:24px}.file-item:hover .btn-remove{opacity:1}.btn-remove:hover{background:#dc2626cc}.file-status{align-items:center;background:#000000b3;border-radius:50%;bottom:.5rem;display:flex;height:24px;justify-content:center;position:absolute;right:.5rem;width:24px}.status-pending{background:#64748b;border-radius:50%;height:8px;width:8px}.status-success{color:#059669}.status-error{color:#dc2626}.file-info{padding:.75rem}.file-name{color:#fff;font-size:.75rem;margin:0 0 .25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{color:#d4d4d4;font-size:.625rem;margin:0}.file-error{color:#ef4444;font-size:.625rem;margin:.25rem 0 0}.upload-actions{border-top:1px solid #ffffff1a;display:flex;gap:1rem;justify-content:center;margin-top:1.5rem;padding-top:1rem}.btn-select{align-items:center;background:linear-gradient(135deg,#fff,#e5e5e5);border:none;border-radius:.75rem;box-shadow:0 4px 20px #fff3;color:#000;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.btn-select:hover:not(:disabled){background:linear-gradient(135deg,#e5e5e5,#d4d4d4);box-shadow:0 8px 30px #ffffff4d;transform:translateY(-2px)}.btn-camera{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000c;border:1px solid #ffffff4d;border-radius:.75rem;color:#fff;cursor:pointer;display:flex;font-size:.875rem;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.btn-camera:hover:not(:disabled){background:#ffffff1a;border-color:#ffffff80;transform:translateY(-2px)}.btn-camera:disabled,.btn-select:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.uploader-modal{border-radius:1rem;margin:1rem;width:95%}.uploader-header{padding:1rem}.uploader-header h2{font-size:1.25rem}.uploader-content{padding:1rem}.drop-zone{border-radius:.75rem;padding:2rem 1rem}.drop-zone h3{font-size:1.125rem}.file-grid{gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.file-preview{height:100px}.upload-actions{flex-direction:column;gap:.75rem}.btn-camera,.btn-select{justify-content:center;padding:.875rem 1.5rem;width:100%}}@media (max-width:430px){.uploader-modal{margin:.5rem;max-height:95vh;width:98%}.uploader-header{padding:.75rem}.uploader-header h2{font-size:1.125rem}.uploader-content{padding:.75rem}.drop-zone{padding:1.5rem .75rem}.drop-zone h3{font-size:1rem}.drop-zone p{font-size:.8rem}.file-grid{gap:.5rem;grid-template-columns:repeat(3,1fr)}.file-preview{height:80px}.file-info{padding:.5rem}.file-name{font-size:.7rem}.file-size{font-size:.6rem}}@media (max-width:480px){.file-list-header{align-items:flex-start;flex-direction:column;gap:1rem}.file-actions{justify-content:space-between;width:100%}.file-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.file-preview{height:80px}}.album-viewer{background:linear-gradient(135deg,#000,#1a1a1a);color:#fff;font-family:Inter,system-ui,sans-serif;min-height:100vh}.album-header{align-items:flex-start;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#000000e6;border-bottom:1px solid #ffffff1a;border-radius:1.5rem 1.5rem 0 0;display:flex;gap:2rem;justify-content:space-between;margin:0 1rem;padding:2rem}.album-header-left{display:flex;flex:1 1;flex-direction:column;gap:1rem;min-width:0}.album-header-right{flex-shrink:0;gap:.75rem}.album-header-right,.btn-back{align-items:center;display:flex}.btn-back{align-self:flex-start;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:.75rem;color:#a3a3a3;cursor:pointer;font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1rem;text-decoration:none;transition:all .3s ease}.btn-back:hover{background:#ffffff14;border-color:#fff3;color:#fff;transform:translateY(-2px)}.album-title-section{display:flex;flex-direction:column;gap:.75rem;min-width:0}.album-title,.album-title-section h1{color:#fff;font-size:2rem;font-weight:700;line-height:1.2;margin:0;word-break:break-word}.album-description{color:#d4d4d4;font-size:1rem;line-height:1.5;margin:0;max-width:60ch}.album-meta{color:#a3a3a3;flex-wrap:wrap;font-size:.875rem;gap:1rem}.album-meta,.album-meta span{align-items:center;display:flex}.album-meta span{gap:.375rem;white-space:nowrap}.privacy-badge{border-radius:1rem;font-weight:600;gap:.25rem;padding:.25rem .75rem}.privacy-badge.public{color:#22c55e}.privacy-badge.private{color:#ef4444}.btn-primary,.btn-upload{align-items:center;background:linear-gradient(135deg,#fff,#e5e5e5);border:none;border-radius:.75rem;box-shadow:0 4px 20px #fff3;color:#000;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.75rem 1rem;transition:all .3s ease;white-space:nowrap}.btn-primary:hover:not(:disabled),.btn-upload:hover{background:linear-gradient(135deg,#e5e5e5,#d4d4d4);box-shadow:0 8px 30px #ffffff4d;transform:translateY(-2px)}.btn-secondary{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000c;border:1px solid #ffffff4d;border-radius:.75rem;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1rem;transition:all .3s ease;white-space:nowrap}.btn-secondary:hover:not(:disabled){background:#ffffff1a;border-color:#ffffff80;color:#fff;transform:translateY(-2px)}.btn-secondary:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-delete-album{align-items:center;background:#dc2626;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1rem;transition:all .2s;white-space:nowrap}.btn-delete-album:hover:not(:disabled){background:#b91c1c;box-shadow:0 4px 12px #dc26264d;transform:translateY(-1px)}.btn-delete-album:disabled{box-shadow:none;cursor:not-allowed;opacity:.5;transform:none}.btn-settings{align-items:center;background:#0000;border:1px solid #ffffff1a;border-radius:.75rem;color:#a3a3a3;cursor:pointer;display:flex;justify-content:center;padding:.625rem;transition:all .3s ease}.btn-settings:hover{background:#ffffff14;border-color:#fff3;color:#fff}.album-actions{display:flex;flex-shrink:0;gap:1rem}.album-content{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0000004d;border:1px solid #ffffff1a;border-radius:0 0 1.5rem 1.5rem;border-top:none;margin:0 1rem;padding:2rem}.photos-section{margin-top:2rem}.photos-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.photos-title{color:#fff;font-size:1.5rem;font-weight:600;margin:0}.photos-count{color:#94a3b8;font-size:.875rem}.photo-grid{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center;padding:2rem 0}.photo-card,.photo-item{aspect-ratio:4/3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#171717e6;border:1px solid #ffffff1a;border-radius:1.5rem;box-shadow:0 10px 40px #0000004d;cursor:pointer;flex-shrink:0;min-height:200px;overflow:hidden;position:relative;transition:all .4s ease;width:280px}.photo-card:hover,.photo-item:hover{border-color:#fff3;box-shadow:0 20px 60px #ffffff0d;transform:translateY(-8px)}.photo-thumbnail{overflow:hidden;position:relative}.photo-thumbnail,.photo-thumbnail img{border-radius:1.5rem;height:100%;width:100%}.photo-thumbnail img{left:0;object-fit:cover;position:absolute;top:0;transition:transform .4s cubic-bezier(.4,0,.2,1)}.video-thumbnail{border-radius:1.5rem;height:100%;overflow:hidden;position:relative;width:100%}.video-play-overlay{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000000b3;border:2px solid #ffffff4d;border-radius:50%;color:#fff;display:flex;height:60px;justify-content:center;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:all .3s ease;width:60px;z-index:10}.photo-item:hover .video-play-overlay{background:#000000e6;border-color:#ffffff80;transform:translate(-50%,-50%) scale(1.1)}.photo-card:hover .photo-thumbnail img,.photo-item:hover .photo-thumbnail img{transform:scale(1.08)}.cover-badge{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#facc15,#f59e0b);border-radius:2rem;box-shadow:0 4px 12px #0006;color:#1e293b;font-size:.75rem;font-weight:700;gap:.375rem;left:.75rem;letter-spacing:.025em;padding:.375rem .75rem;text-transform:uppercase;top:.75rem;z-index:10}.cover-badge,.photo-overlay{display:flex;position:absolute}.photo-overlay{background:linear-gradient(180deg,#0006 0,#0000 20%,#0000 80%,#000c);border-radius:1.5rem;bottom:0;flex-direction:column;justify-content:flex-end;left:0;opacity:0;padding:1rem;pointer-events:none;right:0;top:0;transition:opacity .3s ease}.photo-card:hover .photo-overlay,.photo-item:hover .photo-overlay{opacity:1}.photo-actions{gap:.5rem;margin-bottom:.5rem}.photo-action,.photo-actions{display:flex;pointer-events:auto}.photo-action{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#000000b3;border:1px solid #ffffff1a;border-radius:50%;color:#fff;cursor:pointer;height:36px;justify-content:center;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);width:36px}.photo-action:hover{background:#000000e6;box-shadow:0 4px 12px #0000004d;transform:scale(1.1)}.photo-action.delete-action{background:#ef4444e6;border-color:#ef44444d}.photo-action.delete-action:hover{background:#dc2626;box-shadow:0 4px 12px #dc262666}.photo-action.cover-action,.photo-action.set-cover{background:#facc15e6;border-color:#facc154d;color:#1e293b}.photo-action.cover-action:hover,.photo-action.set-cover:hover{background:#f59e0b;box-shadow:0 4px 12px #f59e0b66}.photo-action.cover-action.active,.photo-action.set-cover.active{background:#facc15;box-shadow:0 0 20px #facc1599}.photo-card.is-cover,.photo-item.is-cover{border:2px solid #facc15;box-shadow:0 0 20px #facc154d;position:relative}.cover-indicator{align-items:center;background:#facc15;border-radius:50%;box-shadow:0 2px 8px #0000004d;color:#1e293b;display:flex;height:32px;justify-content:center;pointer-events:none;position:absolute;right:.5rem;top:.5rem;width:32px;z-index:2}.photo-info{color:#fff;font-size:.875rem}.photo-filename{font-weight:500;margin-bottom:.25rem}.photo-size{font-size:.75rem;opacity:.8}.empty-photos,.empty-state{color:#a3a3a3;padding:6rem 2rem;text-align:center}.empty-photos-icon,.empty-state .empty-icon{margin-bottom:2rem;opacity:.4}.empty-photos h3,.empty-state h3{color:#d4d4d4;font-size:1.5rem;font-weight:600;margin:0 0 1rem}.empty-photos p,.empty-state p{font-size:1rem;line-height:1.6;margin:0 auto 2rem;max-width:40ch}.loading-spinner,.photos-loading{align-items:center;color:#a3a3a3;display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem}.loading-spinner .spinner,.photos-loading .spinner{animation:spin 1s linear infinite;border:3px solid #ffffff1a;border-radius:50%;border-top-color:#fff;height:40px;margin-bottom:1rem;width:40px}.loading-spinner p,.photos-loading p{font-size:.875rem;margin:0}.photo-thumbnail:before{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,#94a3b81a,#94a3b833 50%,#94a3b81a);bottom:0;content:"";left:0;position:absolute;right:0;top:0;z-index:1}.photo-thumbnail img[src]+:before{display:none}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.spinning{animation:spin 1s linear infinite}.processing-overlay{align-items:center;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:999}.processing-message{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#171717f2;border:1px solid #ffffff1a;border-radius:1.5rem;box-shadow:0 20px 40px #0000004d;max-width:400px;padding:2.5rem;text-align:center;width:90%}.processing-message h3{color:#fff;font-size:1.25rem;margin:1rem 0 .5rem}.processing-message p{color:#d4d4d4;font-size:.875rem;line-height:1.5;margin:0}.lightbox-overlay{animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000000f7;border:none!important;bottom:0!important;height:100vh;left:0!important;margin:0!important;overflow:hidden;padding:0!important;position:fixed;right:0!important;top:0!important;transform:none!important;width:100vw;z-index:99999!important}.lightbox-content,.lightbox-overlay{align-items:center;display:flex;justify-content:center}.lightbox-content{height:100%;max-height:95vh;max-width:95vw;position:relative;width:100%}.lightbox-image{object-fit:contain}.lightbox-image,.lightbox-video{border-radius:.5rem;box-shadow:0 25px 50px #00000080;max-height:85vh;max-width:90vw}.lightbox-close{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#000c;border:1px solid #ffffff1a;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:44px;justify-content:center;position:absolute;right:1.5rem;top:1.5rem;transition:all .2s;width:44px;z-index:1001}.lightbox-close:hover{background:#000000f2;box-shadow:0 4px 12px #0000004d;transform:scale(1.1)}.lightbox-nav{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#000c;border:1px solid #ffffff1a;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:56px;justify-content:center;position:absolute;top:50%;transform:translateY(-50%);transition:all .2s;width:56px}.lightbox-nav:hover{background:#000000f2;box-shadow:0 4px 12px #0000004d;transform:translateY(-50%) scale(1.1)}.lightbox-nav:disabled{cursor:not-allowed;opacity:.3;transform:translateY(-50%)}.lightbox-prev{left:2rem}.lightbox-next{right:2rem}.lightbox-actions{display:flex;gap:.75rem;position:absolute;right:5rem;top:1.5rem;z-index:1001}.lightbox-action{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#000c;border:1px solid #ffffff1a;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:44px;justify-content:center;text-decoration:none;transition:all .2s;width:44px}.lightbox-action:hover{background:#000000f2;box-shadow:0 4px 12px #0000004d;transform:scale(1.1)}.lightbox-action.delete-action{background:#ef4444e6}.lightbox-action.delete-action:hover{background:#dc2626;box-shadow:0 4px 12px #dc262666}.lightbox-action.cover-action,.lightbox-action.set-cover{background:#facc15e6;color:#1e293b}.lightbox-action.cover-action:hover,.lightbox-action.set-cover:hover{background:#f59e0b;box-shadow:0 4px 12px #f59e0b66}.lightbox-action.cover-action.active,.lightbox-action.set-cover.active{background:#facc15;box-shadow:0 0 20px #facc1599}.lightbox-info-toggle{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#000c;border:1px solid #fff3;border-radius:50%;bottom:2rem;color:#fff;cursor:pointer;display:flex;height:48px;justify-content:center;position:absolute;right:2rem;transition:all .3s ease;width:48px;z-index:1001}.lightbox-info-toggle:hover{background:#000000f2;border-color:#fff6;transform:scale(1.1)}.lightbox-details{animation:slideUp .3s ease;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#000000f2;border:1px solid #fff3;border-radius:.75rem;bottom:5rem;color:#fff;left:2rem;margin:0 auto;max-width:400px;position:absolute;right:2rem;z-index:1000}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.lightbox-details-content{padding:1rem 1.25rem}.lightbox-details h4{color:#fff;font-size:1rem;font-weight:600;line-height:1.3;margin:0 0 .5rem;word-break:break-word}.photo-meta-info{color:#cbd5e1;font-size:.8rem;line-height:1.4;margin:0}.delete-confirm-overlay{animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#000c;z-index:1000}.delete-confirm-modal{animation:slideIn .3s ease;background:#1e293b;border:1px solid #94a3b833;border-radius:.75rem;box-shadow:0 20px 40px #00000080;padding:2rem;width:90%}.delete-confirm-modal h3{color:#fff;font-size:1.5rem;margin:0 0 1rem}.delete-confirm-modal p{color:#cbd5e1;line-height:1.6;margin:0 0 1rem}.delete-warning{background:#ef44441a;border:1px solid #ef44444d;border-radius:.5rem;color:#fecaca;font-size:.875rem;padding:1rem}.delete-confirm-actions{gap:1rem;margin-top:1.5rem}.btn-cancel{padding:.625rem 1.25rem}.btn-cancel:hover:not(:disabled){border-color:#94a3b880}.btn-delete{background:#dc2626;border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-size:.875rem;padding:.625rem 1.25rem;transition:all .2s}.btn-delete:hover:not(:disabled){background:#b91c1c}.btn-cancel:disabled,.btn-delete:disabled{cursor:not-allowed;opacity:.5}.upload-status-indicator{align-items:center;animation:slideInFromRight .3s ease;background:#22c55ee6;border-radius:.5rem;color:#fff;display:flex;font-size:.875rem;gap:.5rem;padding:.75rem 1rem;position:fixed;right:1rem;top:1rem;z-index:1000}@keyframes slideInFromRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.upload-status-indicator.processing{background:#3b82f6e6}.upload-status-indicator.error{background:#ef4444e6}.lightbox-overlay:focus-within .lightbox-action,.lightbox-overlay:focus-within .lightbox-close,.lightbox-overlay:focus-within .lightbox-nav{box-shadow:0 0 0 2px #3b82f680}.pagination-controls{align-items:center;display:flex;gap:1rem;justify-content:center;margin:2rem 0;padding:1rem}.pagination-btn{background:#ffffff1a;border:1px solid #fff3;border-radius:.5rem;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:.75rem 1.5rem;transition:all .3s ease}.pagination-btn:hover:not(:disabled){background:#fff3;border-color:#fff6;transform:translateY(-1px)}.pagination-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.pagination-info{color:#cbd5e1;font-size:.9rem;font-weight:500;min-width:200px;text-align:center}@media (max-width:768px){.pagination-controls{flex-direction:column;gap:.75rem;margin:1rem 0;padding:1rem .5rem}.pagination-btn{max-width:200px;padding:.75rem 2rem;width:100%}.pagination-info{font-size:.8rem;min-width:auto}}@media (prefers-contrast:high){.photo-item{border:2px solid #ffffff4d}.photo-overlay{background:linear-gradient(180deg,#000c 0,#0000 30%,#0000 70%,#000000e6)}}@media (max-width:1200px){.photo-grid{gap:1.25rem}.photo-card,.photo-item{width:260px}}@media (max-width:430px){.album-header{flex-direction:column;gap:1rem;margin:0;padding:.75rem}.album-header-left{width:100%}.album-header-right{flex-wrap:wrap;gap:.5rem;justify-content:space-between;width:100%}.album-content{margin:0;padding:.75rem}.album-title,.album-title-section h1{font-size:1.25rem;-webkit-hyphens:auto;hyphens:auto;line-height:1.3;max-width:100%;overflow-wrap:break-word;white-space:normal;word-break:normal}.album-title-section{min-width:0;width:100%}.album-meta{align-items:flex-start;flex-direction:column;gap:.5rem}.btn-delete-album,.btn-primary,.btn-secondary{border-radius:.5rem;flex:1 1;font-size:.8rem;justify-content:center;min-width:0;padding:.625rem .875rem}.btn-delete-album span,.btn-primary span,.btn-secondary span{display:none}.btn-delete-album svg,.btn-primary svg,.btn-secondary svg{margin:0}.photo-grid{gap:.5rem;padding:.75rem 0}.photo-card,.photo-item{aspect-ratio:1;border-radius:.75rem;min-height:auto}.photo-thumbnail,.photo-thumbnail img{border-radius:.75rem}.cover-badge{font-size:.5rem;left:.25rem;padding:.125rem .25rem;top:.25rem}.photo-overlay{border-radius:.75rem;padding:.375rem}.photo-action{height:24px;width:24px}}@media (max-width:1024px){.album-header{padding:1.5rem}.album-content{padding:0 1.5rem}.album-title,.album-title-section h1{font-size:1.75rem}.album-meta{font-size:.8rem;gap:.75rem}}@media (max-width:768px){.album-header{align-items:stretch;flex-direction:column;gap:1rem}.album-header-left{width:100%}.album-header-right{display:flex;flex-wrap:wrap;gap:.5rem;width:100%}.album-title-section{width:100%}.album-title,.album-title-section h1{font-size:1.5rem;overflow-wrap:break-word;word-break:normal}.album-meta{flex-wrap:wrap;gap:.75rem}.btn-delete-album,.btn-primary,.btn-secondary{flex:1 1;min-width:120px}.photo-grid{gap:.75rem;justify-content:center}.photo-card,.photo-item{max-width:200px;min-width:140px;width:calc(50% - .375rem)}}.mobile-photo-viewer{background:#000!important;border:none!important;bottom:0!important;display:flex!important;flex-direction:column!important;height:100vh!important;left:0!important;margin:0!important;padding:0!important;position:fixed;right:0!important;top:0!important;transform:none!important;width:100vw!important;z-index:99999!important}.mobile-viewer-photo-container{align-items:center;display:flex;flex:1 1;justify-content:center;min-height:0;padding:80px 20px 120px}.mobile-viewer-media{-webkit-user-drag:none;user-drag:none;-webkit-touch-callout:none;height:auto;max-height:100%;max-width:100%;object-fit:contain;-webkit-user-select:none;user-select:none;width:auto}.mobile-viewer-close{height:50px;right:20px;top:30px;width:50px}.mobile-viewer-close,.mobile-viewer-nav{align-items:center;background:#000c;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;justify-content:center;position:absolute;z-index:10001}.mobile-viewer-nav{height:60px;top:50%;transform:translateY(-50%);width:60px}.mobile-viewer-prev{left:20px}.mobile-viewer-next{right:20px}.mobile-viewer-info{background:#000c;border-radius:10px;bottom:30px;color:#fff;left:20px;padding:15px 20px;position:absolute;right:20px;text-align:center;z-index:10001}.mobile-viewer-counter{display:block;font-size:14px;margin-bottom:4px;opacity:.8}.mobile-viewer-title{display:block;font-size:16px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-photo-viewer *{-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}.modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#000c;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{animation:slideIn .3s ease-out;background:#1e293b;border:1px solid #94a3b833;border-radius:1rem;max-height:90vh;max-width:500px;overflow:hidden;width:90%}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{border-bottom:1px solid #94a3b833;justify-content:space-between;padding:1.5rem}.modal-header,.modal-header h2{align-items:center;display:flex}.modal-header h2{color:#fff;font-size:1.5rem;font-weight:600;gap:.5rem;margin:0}.btn-close{background:none;border:none;border-radius:.5rem;color:#94a3b8;cursor:pointer;padding:.5rem;transition:all .2s}.btn-close:hover:not(:disabled){background:#94a3b81a;color:#fff}.btn-close:disabled{cursor:not-allowed;opacity:.5}.modal-form{max-height:calc(90vh - 80px);overflow-y:auto;padding:1.5rem}.form-group{margin-bottom:1.5rem}.form-group:last-child{margin-bottom:0}.form-group label{color:#fff;display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.form-section-label{color:#fff;font-size:.875rem;font-weight:600;margin-bottom:1rem!important}.form-group input[type=text],.form-group textarea{background:#0f172acc;border:1px solid #94a3b84d;border-radius:.5rem;color:#fff;font-size:.875rem;padding:.75rem;transition:border-color .2s;width:100%}.form-group input[type=text]:focus,.form-group textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-group input[type=text]::placeholder,.form-group textarea::placeholder{color:#64748b}.form-group input[type=text]:disabled,.form-group textarea:disabled{cursor:not-allowed;opacity:.6}.form-group textarea{font-family:inherit;min-height:80px;resize:vertical}.radio-group{display:flex;flex-direction:column;gap:.75rem}.radio-option{align-items:flex-start;background:#0f172a80;border:1px solid #94a3b833;border-radius:.5rem;cursor:pointer;display:flex;gap:.75rem;padding:1rem;transition:all .2s}.radio-option:hover{background:#0f172acc;border-color:#94a3b866}.radio-option input[type=radio]{accent-color:#3b82f6;margin:.125rem 0 0}.radio-content{align-items:flex-start;display:flex;flex:1 1;gap:.75rem}.radio-icon{color:#94a3b8;margin-top:.125rem}.radio-title{color:#fff;font-size:.875rem;font-weight:500;margin-bottom:.25rem}.radio-description{color:#94a3b8;font-size:.75rem}.checkbox-option{align-items:flex-start;background:#0f172a80;border:1px solid #94a3b833;border-radius:.5rem;cursor:pointer;display:flex;gap:.75rem;margin-bottom:1rem;padding:1rem;transition:all .2s}.checkbox-option:hover{background:#0f172acc;border-color:#94a3b866}.checkbox-option input[type=checkbox]{accent-color:#3b82f6;margin:.125rem 0 0}.checkbox-content{flex:1 1}.checkbox-title{color:#fff;font-size:.875rem;font-weight:500;margin-bottom:.25rem}.checkbox-description{color:#94a3b8;font-size:.75rem}.password-field{margin-top:1rem}.password-input-group{align-items:center;display:flex;position:relative}.password-input-group input{background:#0f172acc;border:1px solid #94a3b84d;border-radius:.5rem;color:#fff;font-size:.875rem;padding:.75rem 3rem .75rem .75rem;transition:border-color .2s;width:100%}.password-input-group input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.btn-toggle-password{background:none;border:none;border-radius:.25rem;color:#94a3b8;cursor:pointer;padding:.25rem;position:absolute;right:.75rem;transition:color .2s}.btn-toggle-password:hover:not(:disabled){color:#fff}.btn-toggle-password:disabled{cursor:not-allowed;opacity:.5}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.btn-cancel{background:#0000;border:1px solid #94a3b84d;border-radius:.5rem;color:#94a3b8;cursor:pointer;font-size:.875rem;padding:.75rem 1.5rem;transition:all .2s}.btn-cancel:hover:not(:disabled){background:#94a3b81a;color:#fff}.btn-cancel:disabled{cursor:not-allowed;opacity:.6}.btn-create{align-items:center;background:#3b82f6;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:background .2s}.btn-create:hover:not(:disabled){background:#2563eb}.btn-create:disabled{background:#64748b;cursor:not-allowed}.spinner-small{animation:spin 1s linear infinite;border:2px solid #fff3;border-radius:50%;border-top-color:#fff;height:16px;width:16px}@media (max-width:768px){.modal-content{margin:1rem;width:95%}.modal-form,.modal-header{padding:1rem}.modal-actions{flex-direction:column}.btn-cancel,.btn-create{justify-content:center;width:100%}}@media (max-width:480px){.radio-group{gap:.5rem}.checkbox-option,.radio-option{padding:.75rem}.radio-content{gap:.5rem}}.admin-modal-overlay{align-items:center;background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.admin-modal{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 25px 50px -12px #00000040;display:flex;flex-direction:column;max-height:90vh;max-width:1000px;width:100%}.admin-modal-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:24px}.admin-modal-header h2{align-items:center;color:var(--text-primary);display:flex;font-size:1.5rem;font-weight:600;gap:12px;margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;padding:8px;transition:all .2s ease}.close-btn:hover{background:var(--hover-bg);color:var(--text-primary)}.admin-content{flex:1 1;overflow-y:auto;padding:24px}.admin-empty,.admin-error,.admin-loading{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;justify-content:center;padding:40px;text-align:center}.admin-error{color:var(--error-color)}.admin-error button{background:var(--primary-color);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;margin-top:16px;padding:8px 16px;transition:background .2s ease}.admin-error button:hover{background:var(--primary-hover)}.admin-albums-list{display:flex;flex-direction:column;gap:16px}.admin-album-item{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;display:flex;gap:16px;padding:16px;transition:all .2s ease}.admin-album-item:hover{border-color:var(--primary-color);box-shadow:0 4px 12px #0000001a}.admin-album-thumbnail{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;flex-shrink:0;height:80px;overflow:hidden;position:relative;width:80px}.admin-album-thumbnail img{height:100%;object-fit:cover;object-position:center;width:100%}.admin-album-placeholder{align-items:center;bottom:0;color:var(--text-muted);display:flex;flex-direction:column;font-size:.75rem;justify-content:center;left:0;position:absolute;right:0;top:0}.admin-album-info{flex:1 1;min-width:0}.admin-album-details h3{color:var(--text-primary);font-size:1.125rem;font-weight:600;line-height:1.4;margin:0 0 8px}.album-description{line-height:1.4;margin:0 0 12px}.admin-album-meta,.album-description{color:var(--text-secondary);font-size:.875rem}.admin-album-meta{display:flex;flex-wrap:wrap;gap:16px}.admin-album-meta span{align-items:center;display:flex;gap:6px}.admin-album-edit{display:flex;flex-direction:column;gap:12px}.admin-album-edit input,.admin-album-edit textarea{background:var(--input-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:.875rem;min-height:auto;padding:8px 12px;resize:vertical}.admin-album-edit input:focus,.admin-album-edit textarea:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f61a;outline:none}.admin-edit-actions{display:flex;gap:8px}.btn-cancel,.btn-save{border:none;border-radius:6px;cursor:pointer;font-size:.875rem;padding:6px 12px;transition:all .2s ease}.btn-save{background:var(--success-color);color:#fff}.btn-save:hover{background:var(--success-hover)}.btn-cancel{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary)}.btn-cancel:hover{background:var(--hover-bg);color:var(--text-primary)}.admin-album-status{align-items:center;display:flex;margin:0 16px}.privacy-badge{align-items:center;border-radius:20px;display:flex;font-size:.75rem;font-weight:500;gap:6px;letter-spacing:.025em;padding:6px 12px;text-transform:uppercase}.privacy-badge.public{background:#22c55e1a;border:1px solid #22c55e33;color:var(--success-color)}.privacy-badge.private{background:#ef44441a;border:1px solid #ef444433;color:var(--error-color)}.admin-album-actions{display:flex;flex-shrink:0;gap:8px}.admin-action-btn{align-items:center;background:none;border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);cursor:pointer;display:flex;height:36px;justify-content:center;padding:8px;transition:all .2s ease;width:36px}.admin-action-btn:hover:not(:disabled){background:var(--hover-bg);border-color:var(--primary-color);color:var(--text-primary)}.admin-action-btn:disabled{cursor:not-allowed;opacity:.5}.edit-btn:hover:not(:disabled){border-color:var(--warning-color);color:var(--warning-color)}.toggle-btn:hover:not(:disabled){border-color:var(--info-color);color:var(--info-color)}.delete-btn:hover:not(:disabled){border-color:var(--error-color);color:var(--error-color)}.delete-confirm-overlay{align-items:center;background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1100}.delete-confirm-modal{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 25px 50px -12px #00000040;max-width:400px;padding:24px;width:100%}.delete-confirm-modal h3{color:var(--text-primary);font-size:1.25rem;font-weight:600;margin:0 0 16px}.delete-confirm-modal p{color:var(--text-secondary);line-height:1.5;margin:0 0 12px}.delete-warning{color:var(--error-color)!important;font-weight:500;margin-bottom:24px!important}.delete-confirm-actions{display:flex;gap:12px;justify-content:flex-end}.delete-confirm-actions .btn-cancel{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);padding:8px 16px}.delete-confirm-actions .btn-delete{background:var(--error-color);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;padding:8px 16px;transition:background .2s ease}.delete-confirm-actions .btn-delete:hover:not(:disabled){background:var(--error-hover)}.delete-confirm-actions .btn-delete:disabled{cursor:not-allowed;opacity:.7}@media (max-width:768px){.admin-modal{margin:10px;max-height:calc(100vh - 20px)}.admin-content,.admin-modal-header{padding:16px}.admin-album-item{align-items:flex-start;flex-direction:column;gap:12px}.admin-album-thumbnail{height:200px;width:100%}.admin-album-status{justify-content:flex-start;margin:0;width:100%}.admin-album-actions{justify-content:flex-end;width:100%}.admin-album-meta{gap:12px}}.gallery-container{color:#fff;font-family:Inter,system-ui,sans-serif;padding-top:2rem;width:100%}.gallery-header{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#000000e6;border-bottom:1px solid #ffffff1a;border-radius:0;margin:0;padding:1rem 0;position:relative;z-index:10}.header-content{justify-content:space-between;margin:0 auto;max-width:100%;padding:0 2rem}.header-content,.header-left{align-items:center;display:flex}.header-left{gap:1rem}.gallery-logo{color:#fff}.header-right{gap:1rem}.header-right,.user-menu{align-items:center;display:flex}.user-menu{gap:.5rem}.user-avatar{border-radius:50%;height:32px;width:32px}.btn-primary{align-items:center;background:linear-gradient(135deg,#fff,#e5e5e5);border:none;border-radius:.75rem;box-shadow:0 4px 20px #fff3;color:#000;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.5rem 1rem;transition:all .3s ease}.btn-primary:hover{background:linear-gradient(135deg,#e5e5e5,#d4d4d4);box-shadow:0 8px 30px #ffffff4d;transform:translateY(-2px)}.btn-discord{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000c;border:1px solid #ffffff4d;border-radius:.75rem;color:#fff;cursor:pointer;font-size:1rem;padding:.75rem 1.5rem;transition:all .3s ease}.btn-discord:hover{background:#ffffff1a;border-color:#ffffff80;transform:translateY(-2px)}.btn-admin{align-items:center;background:linear-gradient(135deg,#7c3aed,#a855f7);border:none;border-radius:.75rem;box-shadow:0 4px 20px #7c3aed4d;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.5rem 1rem;transition:all .3s ease}.btn-admin:hover{background:linear-gradient(135deg,#6d28d9,#9333ea);box-shadow:0 8px 30px #7c3aed66;transform:translateY(-2px)}.gallery-nav{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#171717cc;border:1px solid #ffffff1a;border-radius:0;border-top:none;display:flex;justify-content:space-between;margin:0;padding:1rem 2rem}.nav-tabs{display:flex;gap:1rem}.nav-tab{align-items:center;background:#0000;border:1px solid #0000;border-radius:.75rem;color:#a3a3a3;cursor:pointer;display:flex;gap:.5rem;overflow:hidden;padding:.5rem 1rem;position:relative;transition:all .3s ease}.nav-tab.active{background:linear-gradient(135deg,#fff,#e5e5e5);box-shadow:0 4px 20px #fff3;color:#000}.gallery-main{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0000004d;border:1px solid #ffffff1a;border-radius:0;border-top:none;margin:0;min-height:500px;padding:2rem}.loading-spinner{padding:4rem;text-align:center}.spinner{animation:spin 1s linear infinite;border:3px solid #ffffff1a;border-radius:50%;border-top-color:#fff;height:48px;margin:0 auto 1rem;width:48px}@keyframes spin{to{transform:rotate(1turn)}}@media (min-width:769px){.gallery-container{padding:0}.gallery-header{padding:1.5rem 0}.header-content{padding:0 3rem}.gallery-nav{padding:1.5rem 3rem}.gallery-main{min-height:600px;padding:3rem}}@media (min-width:1200px){.header-content{padding:0 4rem}.gallery-nav{padding:1.5rem 4rem}.gallery-main{min-height:700px;padding:3rem 4rem}}@media (min-width:1600px){.header-content{padding:0 5rem}.gallery-nav{padding:1.5rem 5rem}.gallery-main{min-height:600px;padding:3rem 5rem}}@media (max-width:768px){.gallery-header{margin:0 1rem;padding:1rem 0}.header-content{align-items:center;flex-direction:row;gap:1rem;justify-content:space-between;min-height:60px;padding:0 1rem}.header-left{align-items:center;display:flex;flex:1 1;gap:.75rem;min-width:0}.header-left h1{font-size:1.125rem;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gallery-logo{flex-shrink:0}.header-right{align-items:center;display:flex;flex-shrink:0;gap:.5rem;justify-content:flex-end}.btn-admin,.btn-discord,.btn-primary{font-size:.875rem;min-height:44px;padding:.625rem 1rem;white-space:nowrap}.user-menu{gap:.375rem}.user-menu span{display:none}.user-avatar{height:28px;width:28px}.gallery-nav{flex-direction:column;gap:1.25rem;margin:0 1rem;padding:1rem}.nav-tabs{gap:.75rem;justify-content:space-between;width:100%}.nav-tab{border-radius:.75rem;flex:1 1;font-size:.875rem;justify-content:center;min-height:48px;min-width:0;padding:.875rem 1rem}.gallery-main{margin:0 1rem 1rem;min-height:400px;padding:1rem}}.view-toggle{background:#0000004d;border:1px solid #ffffff1a;border-radius:.75rem;display:flex;gap:.5rem;padding:.25rem}.btn-icon{align-items:center;background:#0000;border:none;border-radius:.5rem;color:#a3a3a3;cursor:pointer;display:flex;justify-content:center;min-height:44px;min-width:44px;padding:.5rem;transition:all .3s ease}.btn-icon:hover{background:#ffffff1a;color:#fff}.btn-icon.active{background:#ffffff26;color:#fff}@media (max-width:430px){.gallery-header{padding:.75rem 0}.header-content{min-height:50px;padding:0 .75rem}.header-right{gap:.375rem}.header-left h1{font-size:1rem}.gallery-logo{height:24px;width:24px}.btn-admin,.btn-discord,.btn-primary{font-size:.8rem;min-height:40px;padding:.5rem .875rem}.gallery-nav{border-radius:0 0 .75rem .75rem;margin:0 .25rem;padding:.75rem}.nav-tabs{gap:.5rem}.nav-tab{border-radius:.5rem;font-size:.8rem;min-height:44px;padding:.75rem .875rem}.view-toggle{gap:.25rem;padding:.125rem}.btn-icon{min-height:40px;min-width:40px;padding:.375rem}.gallery-main{margin:0 .25rem .75rem;padding:.75rem}}@media (max-width:375px){.header-content{min-height:48px;padding:0 .5rem}.header-left h1{font-size:.9rem}.gallery-logo{height:20px;width:20px}.btn-admin,.btn-discord,.btn-primary{font-size:.75rem;min-height:40px;padding:.5rem .75rem}.user-avatar{height:24px;width:24px}.gallery-nav{margin:0 .25rem;padding:.625rem}.nav-tabs{flex-direction:column;gap:.375rem}.nav-tab{font-size:.875rem;min-height:48px;min-width:0;min-width:auto;padding:.875rem 1rem;width:100%}.view-toggle{align-self:center}.gallery-main{margin:0 .25rem .5rem;padding:.5rem}}
/*# sourceMappingURL=main.66efe565.css.map*/