@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";
:root{--bg-color:#05050a;--bg-gradient:linear-gradient(135deg,#05050a 0%,#0a0a16 100%);--panel-bg:#14141e99;--panel-border:#ffffff14;--primary:#6b46c1;--primary-glow:#6b46c180;--accent:#00d2ff;--accent-glow:#00d2ff66;--text-primary:#fff;--text-secondary:#a0aec0;--error:#e53e3e;--success:#38a169;--font-main:"Outfit",sans-serif;--transition:all .3s cubic-bezier(.25,.8,.25,1)}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-color);background-image:var(--bg-gradient);color:var(--text-primary);font-family:var(--font-main);min-height:100vh;line-height:1.6;overflow-x:hidden}h1,h2,h3,h4{letter-spacing:-.02em;font-weight:600}.font-light{font-weight:300}.text-center{text-align:center}.text-accent{color:var(--accent)}.text-primary{color:var(--primary)}.text-secondary{color:var(--text-secondary)}.title-gradient{background:linear-gradient(90deg,#fff,var(--text-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:1rem;font-size:3.5rem}.blobs{z-index:-1;pointer-events:none;width:100%;height:100%;position:fixed;top:0;left:0;overflow:hidden}.blob{filter:blur(80px);opacity:.5;border-radius:50%;animation:20s cubic-bezier(.4,0,.2,1) infinite alternate float;position:absolute}.blob-1{background:var(--primary-glow);width:500px;height:500px;top:-10%;left:-10%}.blob-2{background:var(--accent-glow);width:600px;height:600px;animation-delay:-5s;bottom:-20%;right:-10%}.blob-3{background:#ec489933;width:300px;height:300px;animation-delay:-10s;top:40%;left:50%;transform:translate(-50%,-50%)}@keyframes float{0%{transform:translate(0)scale(1)}50%{transform:translate(30px,50px)scale(1.1)}to{transform:translate(-20px,20px)scale(.9)}}.glass-nav{-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--panel-border);z-index:100;background:#05050ab3;padding:1rem 2rem;position:sticky;top:0}.logo-container{align-items:center;gap:.75rem;display:flex}.logo-text{letter-spacing:.05em;font-size:1.5rem}.app-main{flex-direction:column;min-height:100vh;display:flex}.content-container{flex:1;max-width:80rem;margin-inline:auto;padding:2rem}.max-w-2xl{max-width:42rem}.mx-auto{margin-left:auto;margin-right:auto}.text-lg{font-size:1.125rem}.hero-section{flex-direction:column;align-items:center;padding:4rem 0 2rem;display:flex}.hero-text{margin-bottom:3rem;animation:.8s ease-out forwards fadeUp}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.upload-container-outer{opacity:0;width:100%;max-width:600px;animation:1s ease-out .2s forwards fadeUp}.glass-panel{background:var(--panel-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--panel-border);border-radius:24px;padding:2rem;box-shadow:0 20px 40px #0000004d}.drop-zone{text-align:center;cursor:pointer;transition:var(--transition);border:2px dashed #fff3;border-radius:16px;margin-bottom:2rem;padding:3rem 2rem;position:relative;overflow:hidden}.drop-zone:hover{border-color:var(--primary);background:#ffffff05}.drop-zone.has-file{border-style:solid;border-color:var(--accent);padding:2rem}.drop-content{flex-direction:column;align-items:center;gap:1rem;display:flex}.icon{margin-bottom:.5rem}@keyframes bounceSlow{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.bounce{animation:3s ease-in-out infinite bounceSlow}.drop-content .primary-text{font-size:1.25rem;font-weight:500}.drop-content span{color:var(--accent)}.file-info{text-align:left;align-items:center;gap:1rem;display:flex}.file-details{flex-direction:column;flex:1;display:flex}.file-name{white-space:nowrap;text-overflow:ellipsis;max-width:300px;font-weight:600;overflow:hidden}.file-size{color:var(--text-secondary);font-size:.875rem}.remove-btn{color:#fff;cursor:pointer;width:32px;height:32px;transition:var(--transition);background:#ffffff1a;border:none;border-radius:50%;place-items:center;display:grid}.remove-btn:hover{background:var(--error)}.upload-action-btn{color:#fff;cursor:pointer;background:0 0;border:1px solid #fff3;border-radius:9999px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;transition:all .2s;display:flex}.upload-action-btn:hover{background:#ffffff1a;border-color:#ffffff4d}.upload-btn{background:linear-gradient(135deg,var(--primary)0%,#4c1d95 100%);color:#fff;cursor:pointer;width:100%;transition:var(--transition);font-size:1.1rem;font-weight:600;font-family:var(--font-main);border:none;border-radius:12px;padding:1rem;box-shadow:0 10px 20px #6b46c14d}.upload-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 15px 25px #6b46c166}.upload-btn:active:not(:disabled){transform:translateY(1px)}.upload-btn.disabled{box-shadow:none;cursor:not-allowed;color:var(--text-secondary);background:#ffffff1a}.progress-bar-container{background:#ffffff1a;border-radius:3px;height:6px;margin-bottom:2rem;overflow:hidden}.progress-bar{background:var(--accent);width:0%;height:100%;box-shadow:0 0 10px var(--accent-glow);transition:width .3s}.status-message{border-radius:8px;align-items:center;gap:.5rem;margin-bottom:1.5rem;padding:.75rem 1rem;font-weight:500;animation:.3s ease-out fadeUp;display:flex}.status-message.error{color:#fc8181;background:#e53e3e1a;border:1px solid #e53e3e33}.status-message.success{color:#68d391;background:#38a1691a;border:1px solid #38a16933}.gallery-section{max-width:1200px;margin:0 auto;padding:4rem 2rem 2rem}.section-header{margin-bottom:3rem}.section-title{margin-bottom:.5rem;font-size:2rem}.divider{background:var(--accent);border-radius:2px;width:60px;height:4px}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;display:grid}.gallery-item{aspect-ratio:1;background:#00000080;border-radius:16px;position:relative;overflow:hidden;box-shadow:0 10px 30px #0003}.media-wrapper{width:100%;height:100%;position:relative}.media-content{object-fit:cover;width:100%;height:100%;transition:transform .6s cubic-bezier(.25,1,.5,1)}.gallery-item:hover .media-content{transform:scale(1.05)}.video-indicator{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;pointer-events:none;background:#00000080;border-radius:50%;padding:.5rem;position:absolute;top:1rem;right:1rem}.hover-overlay{opacity:0;pointer-events:none;background:linear-gradient(#0006 0%,#0000 40%,#000c 100%);flex-direction:column;justify-content:space-between;padding:1.5rem;transition:opacity .3s;display:flex;position:absolute;inset:0}.gallery-item:hover .hover-overlay{opacity:1;pointer-events:auto}.overlay-top{justify-content:flex-end;display:flex}.time-badge{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0009;border-radius:20px;align-items:center;padding:.25rem .75rem;font-size:.75rem;display:flex}.mr-1{margin-right:.25rem}.overlay-bottom{flex-direction:column;align-items:flex-start;transition:transform .3s;display:flex;transform:translateY(10px)}.gallery-item:hover .overlay-bottom{transform:translateY(0)}.file-name-truncate{white-space:nowrap;text-overflow:ellipsis;max-width:100%;margin-bottom:.25rem;font-size:1.1rem;font-weight:500;overflow:hidden}.download-btn-circle{background:var(--accent);color:#000;cursor:pointer;border:none;border-radius:50%;align-self:flex-end;place-items:center;width:44px;height:44px;margin-top:-30px;transition:all .2s;display:grid;box-shadow:0 4px 10px #00d2ff66}.download-btn-circle:hover{background:#fff;transform:scale(1.1)}.loading-state,.empty-state{background:#ffffff05;border:1px dashed #ffffff1a;border-radius:20px;flex-direction:column;justify-content:center;align-items:center;min-height:300px;padding:4rem 2rem;display:flex}.empty-icon-wrap{background:#ffffff0d;border-radius:50%;place-items:center;width:80px;height:80px;margin-bottom:1.5rem;display:grid}.empty-state h3{margin-bottom:.5rem;font-size:1.5rem}.empty-state p{color:var(--text-secondary)}.spinner{border:3px solid #ffffff1a;border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;margin-bottom:1rem;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.app-footer{text-align:center;color:var(--text-secondary);border-top:1px solid var(--panel-border);margin-top:4rem;padding:2rem}@media (max-width:768px){.hero-section{padding:2rem 0}.title-gradient{font-size:2.5rem}.drop-zone{padding:2rem 1rem}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}.gallery-item{border-radius:12px}.content-container{padding:1rem}}.gallery-toolbar{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.item-count{color:var(--text-secondary);font-size:.875rem}.view-toggles{background:#0000004d;border:1px solid #ffffff0d;border-radius:.5rem;gap:.5rem;padding:.25rem;display:flex}.view-toggle-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:.375rem;justify-content:center;align-items:center;padding:.5rem;transition:all .2s;display:flex}.view-toggle-btn:hover{color:#fff;background:#ffffff0d}.view-toggle-btn.active{color:#fff;background:#ffffff26}.video-placeholder{background:#0006;border:1px solid #ffffff0d;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.video-placeholder-icon{color:#6b46c1cc;margin-bottom:.5rem}.video-placeholder-label{color:var(--text-secondary);background:#0009;border-radius:.25rem;padding:.25rem .5rem;font-size:.75rem}.group-hover-visible{opacity:0;transition:opacity .2s}.gallery-item.group:hover .group-hover-visible{opacity:1}.overlay-details{flex-direction:column;padding-right:.5rem;display:flex;overflow:hidden}.gallery-list-view{background:#0003;border:1px solid #ffffff0d;border-radius:.75rem;overflow:hidden}.list-table{text-align:left;border-collapse:collapse;width:100%}.list-table th{color:var(--text-secondary);background:#ffffff0d;padding:1rem;font-size:.875rem;font-weight:400}.list-row{cursor:pointer;border-top:1px solid #ffffff0d;transition:background .2s}.list-row:hover{background:#ffffff0d}.list-cell-name{align-items:center;gap:.75rem;padding:1rem;display:flex}.truncate-text{white-space:nowrap;text-overflow:ellipsis;max-width:200px;overflow:hidden}.icon-video{color:var(--primary)}.icon-image{color:var(--accent)}.list-cell-date,.list-cell-size{color:var(--text-secondary);padding:1rem;font-size:.875rem}.list-cell-action{text-align:right;padding:1rem}.download-btn-icon{color:var(--text-secondary);cursor:pointer;opacity:0;background:0 0;border:none;transition:color .2s}.list-row:hover .download-btn-icon{opacity:1}.download-btn-icon:hover{color:var(--accent)}.preview-modal{z-index:1000;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#000000f2;flex-direction:column;display:flex;position:fixed;inset:0}.modal-header{z-index:10;background:linear-gradient(#000c,#0000);justify-content:space-between;align-items:center;width:100%;padding:1.5rem;display:flex;position:absolute;top:0}.modal-title-group{flex-direction:column;gap:.25rem;display:flex}.modal-title{color:#fff;font-size:1.25rem;font-weight:500}.modal-subtitle{color:#fff9;font-size:.875rem}.modal-actions{gap:1.5rem;display:flex}.modal-action-btn{color:#ffffffb3;cursor:pointer;background:0 0;border:none;transition:all .2s}.modal-action-btn.hover-primary:hover{color:var(--accent);transform:scale(1.1)}.modal-action-btn.hover-danger:hover{color:#fca5a5;transform:scale(1.1)}.modal-body{flex:1;justify-content:center;align-items:center;height:100%;display:flex;position:relative}.nav-btn{z-index:10;color:#ffffffb3;cursor:pointer;background:#00000080;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;padding:1rem;transition:all .2s;display:flex;position:absolute}.nav-btn:hover{color:#fff;background:#ffffff1a;transform:scale(1.1)}.prev-btn{left:2rem}.next-btn{right:2rem}.media-preview-content{justify-content:center;align-items:center;max-width:90vw;height:85vh;padding:2rem;display:flex}.preview-media{object-fit:contain;border-radius:.5rem;max-width:100%;max-height:100%;box-shadow:0 25px 50px -12px #0006}@media (min-width:768px){.truncate-text{max-width:400px}}@media (max-width:768px){.hide-mobile{display:none}.media-preview-content{max-width:100vw;padding:4rem 1rem}.prev-btn{padding:.5rem;left:.5rem}.next-btn{padding:.5rem;right:.5rem}}
