@import url("https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap");:root{--bg:#e8e4dc;--surface:#fff;--card:#fff;--border:#1a1a1a;--shadow:4px 4px 0px #1a1a1a;--shadow-sm:2px 2px 0px #1a1a1a;--shadow-hover:6px 6px 0px #1a1a1a;--text:#1a1a1a;--text-secondary:#4a4a4a;--text-muted:#7a7a7a;--accent:#a855f7;--accent-bg:#f3e8ff;--discord:#5865f2;--discord-bg:#eef0ff;--telegram:#26a5e4;--telegram-bg:#e6f7ff;--success:#22c55e;--success-bg:#dcfce7;--danger:#ef4444;--danger-bg:#fee2e2;--warning:#f59e0b;--warning-bg:#fef3c7;--pink:#ec4899;--cyan:#06b6d4;--yellow:#fbbf24;--radius:12px;--font:"Space Grotesk",sans-serif;--mono:"JetBrains Mono",monospace}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.app{max-width:1200px;margin:0 auto;padding:24px}.header{justify-content:space-between;padding:16px 0;margin-bottom:24px}.header,.header-brand{display:flex;align-items:center}.header-brand{gap:12px}.header-logo{width:48px;height:48px;background:#3d4785;border:3px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center;overflow:hidden}.header-logo img{width:100%;height:100%;object-fit:cover}.header-title{font-size:28px;font-weight:700;letter-spacing:-1px}.header-subtitle{font-size:12px;color:var(--text-muted);font-weight:500}.header-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.stat-item{padding:8px 14px;background:var(--surface);border:2px solid var(--border);border-radius:8px;box-shadow:var(--shadow-sm);text-align:center}.stat-value{font-size:18px;font-weight:700;color:var(--accent)}.stat-label{font-size:10px;font-weight:600;text-transform:uppercase;color:var(--text-muted)}.sync-badge{gap:4px;font-size:11px;color:var(--cyan);padding:4px 10px;background:#e0fffe;border:2px solid var(--cyan);border-radius:20px}.sync-badge,.user-badge{display:flex;align-items:center;font-weight:600}.user-badge{gap:6px;padding:8px 14px;background:var(--accent-bg);font-size:13px}.btn-logout,.user-badge{border:2px solid var(--border);border-radius:8px;box-shadow:var(--shadow-sm)}.btn-logout{padding:8px;background:var(--surface);cursor:pointer;transition:all .1s;display:flex}.btn-logout:hover{background:var(--danger-bg);transform:translate(1px,1px);box-shadow:1px 1px 0 var(--border)}.upload-zone{border:3px dashed var(--border);border-radius:var(--radius);padding:40px 24px;text-align:center;cursor:pointer;transition:all .15s;background:var(--surface);margin-bottom:24px}.upload-zone.active,.upload-zone:hover{background:var(--accent-bg);border-style:solid;transform:translate(-2px,-2px);box-shadow:var(--shadow-hover)}.upload-icon{margin-bottom:12px;color:var(--accent)}.upload-title{font-size:20px;font-weight:700;margin-bottom:4px}.upload-subtitle{font-size:14px;color:var(--text-secondary)}.upload-hint{font-size:12px;color:var(--text-muted);margin-top:10px;font-family:var(--mono)}.upload-progress{background:var(--surface);border:3px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:24px;box-shadow:var(--shadow)}.progress-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.progress-name{font-size:14px;font-weight:600;display:flex;align-items:center;gap:8px}.progress-bar{width:100%;height:8px;background:#e5e5e5;border-radius:4px;border:2px solid var(--border);overflow:hidden}.progress-fill{height:100%;background:var(--accent);transition:width .3s}.status-log{margin-top:10px;padding:8px 10px;background:#f5f5f0;border:2px solid var(--border);border-radius:8px;max-height:100px;overflow-y:auto;font-family:var(--mono);font-size:11px}.status-log-item{padding:2px 0;color:var(--text-muted)}.status-log-item.success{color:var(--success);font-weight:600}.status-log-item.error{color:var(--danger);font-weight:600}.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:20px;flex-wrap:wrap}.search-box{flex:1 1;min-width:200px;position:relative}.search-box input{width:100%;padding:10px 14px 10px 38px;background:var(--surface);border:2px solid var(--border);border-radius:8px;box-shadow:var(--shadow-sm);font-size:14px;font-family:var(--font);outline:none;transition:all .1s}.search-box input:focus{transform:translate(-1px,-1px);box-shadow:var(--shadow);border-color:var(--accent)}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted)}.view-toggle{display:flex;gap:0;border:2px solid var(--border);border-radius:8px;overflow:hidden;box-shadow:var(--shadow-sm)}.view-btn{padding:8px 12px;border:none;background:var(--surface);cursor:pointer;display:flex;align-items:center;transition:all .1s}.view-btn:not(:last-child){border-right:2px solid var(--border)}.view-btn.active{background:var(--accent);color:#fff}.filter-btn{padding:8px 14px;background:var(--surface);border:2px solid var(--border);border-radius:8px;box-shadow:var(--shadow-sm);font-size:12px;font-weight:600;cursor:pointer;transition:all .1s;display:flex;align-items:center;gap:5px}.filter-btn:hover{transform:translate(-1px,-1px);box-shadow:var(--shadow)}.filter-btn.active{background:var(--accent);color:#fff;transform:translate(1px,1px);box-shadow:1px 1px 0 var(--border)}.file-list{display:flex;flex-direction:column;gap:8px}.file-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:all .1s;cursor:pointer}.file-item:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow-hover)}.file-icon{width:42px;height:42px;border-radius:8px;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0}.file-icon.image{background:#fce7f3;color:var(--pink)}.file-icon.video{background:var(--accent-bg);color:var(--accent)}.file-icon.audio{background:var(--success-bg);color:var(--success)}.file-icon.document{background:#dbeafe;color:#3b82f6}.file-icon.archive{background:var(--warning-bg);color:var(--warning)}.file-icon.code{background:#e0fffe;color:var(--cyan)}.file-icon.default{background:#f3f4f6;color:var(--text-muted)}.file-info{flex:1 1;min-width:0}.file-name{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-meta{display:flex;align-items:center;gap:10px;margin-top:3px;font-size:11px;color:var(--text-muted);font-weight:500}.storage-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:700;border:1.5px solid}.storage-badge.discord{background:var(--discord-bg);color:var(--discord);border-color:var(--discord)}.storage-badge.telegram{background:var(--telegram-bg);color:var(--telegram);border-color:var(--telegram)}.file-actions{display:flex;gap:4px;flex-shrink:0}.file-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));grid-gap:14px;gap:14px}.gallery-item{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;cursor:pointer;transition:all .1s;position:relative}.gallery-item:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow-hover)}.gallery-thumb{width:100%;aspect-ratio:1;object-fit:cover;background:#f5f5f0;display:flex;align-items:center;justify-content:center;border-bottom:2px solid var(--border)}.gallery-thumb img,.gallery-thumb video{width:100%;height:100%;object-fit:cover}.gallery-thumb-icon{color:var(--text-muted);opacity:.4}.gallery-info{padding:10px 12px}.gallery-name{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gallery-meta{font-size:10px;color:var(--text-muted);margin-top:4px;display:flex;justify-content:space-between;font-weight:500}.gallery-badge{position:absolute;top:8px;right:8px}.gallery-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-70%);width:44px;height:44px;background:#fff;border:3px solid var(--border);border-radius:50%;justify-content:center}.btn,.gallery-play{display:flex;align-items:center;box-shadow:var(--shadow-sm)}.btn{padding:8px 14px;border-radius:8px;border:2px solid var(--border);background:var(--surface);font-size:12px;font-weight:600;cursor:pointer;transition:all .1s;gap:5px;text-decoration:none;color:var(--text);font-family:var(--font)}.btn:hover{transform:translate(-1px,-1px);box-shadow:var(--shadow)}.btn:active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--border)}.btn-primary{background:var(--accent);color:#fff}.btn-danger{background:var(--surface)}.btn-danger:hover{background:var(--danger-bg);border-color:var(--danger);color:var(--danger)}.btn-icon{padding:8px;border:none;background:transparent;box-shadow:none}.btn-icon:hover{background:#f0f0f0;box-shadow:none;transform:none}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .15s}.modal{background:var(--surface);border:3px solid var(--border);border-radius:var(--radius);padding:24px;max-width:420px;width:100%;box-shadow:8px 8px 0 var(--border)}.modal-title{font-size:20px;font-weight:700}.modal-text{font-size:14px;color:var(--text-secondary);margin-bottom:20px;line-height:1.5}.modal-actions{display:flex;gap:8px;justify-content:flex-end}.preview-modal{background:var(--surface);border:3px solid var(--border);border-radius:var(--radius);max-width:900px;width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:8px 8px 0 var(--border)}.preview-header{padding:14px 18px;border-bottom:3px solid var(--border)}.preview-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.preview-title{font-size:18px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1 1}.preview-meta-row{display:flex;gap:12px;margin-top:6px;font-size:11px;color:var(--text-muted);font-weight:500}.preview-content{flex:1 1;overflow-y:auto;display:flex;align-items:center;justify-content:center;min-height:200px;background:#f5f5f0}.preview-image{max-width:100%;object-fit:contain}.preview-image,.preview-video{max-height:65vh;margin:16px;border-radius:8px;border:2px solid var(--border)}.preview-video{width:calc(100% - 32px)}.preview-audio{width:90%;max-width:500px;margin:40px auto;display:block}.preview-file-info{padding:40px 24px;text-align:center;width:100%}.preview-file-type{font-size:16px;font-weight:600;color:var(--text-secondary);margin:16px 0 24px}.preview-detail-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:2px dashed #e5e5e5;font-size:12px;max-width:380px;margin:0 auto}.preview-detail-label{color:var(--text-muted);font-weight:500}.preview-detail-value{font-weight:600}.preview-footer{padding:14px 18px;border-top:3px solid var(--border);display:flex;justify-content:flex-end;gap:8px}.pagination{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:24px}.pagination button{padding:8px 14px;background:var(--surface);border:2px solid var(--border);border-radius:8px;box-shadow:var(--shadow-sm);font-size:12px;font-weight:600;cursor:pointer;transition:all .1s}.pagination button:hover:not(:disabled){transform:translate(-1px,-1px);box-shadow:var(--shadow)}.pagination button:disabled{opacity:.3;cursor:not-allowed}.empty-state{text-align:center;padding:60px 24px}.empty-state-title{font-size:22px;font-weight:700;margin-bottom:8px}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--bg)}.auth-card{background:var(--surface);border:3px solid var(--border);border-radius:16px;padding:36px;max-width:400px;width:100%;box-shadow:8px 8px 0 var(--border)}.auth-logo{width:70px;height:70px;margin:0 auto 16px;background:#3d4785;border:3px solid var(--border);border-radius:14px;box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center;overflow:hidden}.auth-logo img{width:100%;height:100%;object-fit:cover}.auth-title{font-size:32px;font-weight:700;text-align:center;letter-spacing:-1px}.auth-subtitle{text-align:center;color:var(--text-muted);margin-top:6px;font-size:14px}.auth-tabs{display:flex;gap:0;margin:24px 0 20px;border:2px solid var(--border);border-radius:8px;overflow:hidden;box-shadow:var(--shadow-sm)}.auth-tab{flex:1 1;padding:12px;border:none;background:var(--surface);font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .1s;font-family:var(--font)}.auth-tab:not(:last-child){border-right:2px solid var(--border)}.auth-tab.active{background:var(--accent);color:#fff}.auth-form{display:flex;flex-direction:column;gap:14px}.auth-field label{display:block;font-size:12px;font-weight:700;text-transform:uppercase;margin-bottom:6px}.auth-field input{width:100%;padding:12px 14px;background:var(--surface);border:2px solid var(--border);border-radius:8px;box-shadow:var(--shadow-sm);font-size:14px;font-family:var(--font);outline:none;transition:all .1s}.auth-field input:focus{transform:translate(-1px,-1px);box-shadow:var(--shadow);border-color:var(--accent)}.auth-error{background:var(--danger-bg);border:2px solid var(--danger);color:var(--danger);padding:10px 14px;border-radius:8px;font-size:12px;font-weight:600}.auth-submit{width:100%;padding:14px;font-size:15px;font-weight:700;justify-content:center;margin-top:4px;text-transform:uppercase;letter-spacing:.5px}.install-banner{background:var(--accent-bg);border:3px solid var(--accent);border-radius:var(--radius);padding:14px 16px;margin-bottom:16px;box-shadow:var(--shadow-sm)}.install-banner-content{display:flex;align-items:center;gap:12px}.install-banner-icon{width:40px;height:40px;border-radius:10px;background:var(--accent);color:#fff;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0}.install-banner-text{flex:1 1}.install-banner-text strong{font-size:14px;display:block}.install-banner-text p{font-size:12px;color:var(--text-secondary);margin-top:2px}.install-banner-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.install-btn{padding:8px 16px!important}.share-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:16px;background:var(--bg)}.share-card{background:var(--surface);border:3px solid var(--border);border-radius:16px;padding:24px;max-width:440px;width:100%;box-shadow:8px 8px 0 var(--border)}.share-header{margin-bottom:20px;padding-bottom:16px;border-bottom:3px solid var(--border)}.share-dropzone{border:3px dashed var(--border);border-radius:var(--radius);padding:32px 16px;text-align:center;cursor:pointer;transition:all .1s}.share-dropzone:hover{background:var(--accent-bg);border-style:solid;transform:translate(-2px,-2px);box-shadow:var(--shadow)}.share-files{margin-top:12px;display:flex;flex-direction:column;gap:6px;max-height:200px;overflow-y:auto}.share-file-item{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--surface);border:2px solid var(--border);border-radius:8px;box-shadow:var(--shadow-sm)}.share-results{padding:8px 0}.download-modal{max-width:360px}.success-modal{text-align:center}.success-icon{color:var(--success);margin-bottom:8px}.success-details{background:#f5f5f0;border:2px solid var(--border);border-radius:8px;padding:12px 16px;margin:16px 0;text-align:left}.success-row{display:flex;justify-content:space-between;padding:6px 0;font-size:13px}.success-row span{color:var(--text-muted)}.success-row strong{font-size:13px;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:right}.success-notice{background:var(--warning-bg);border:2px solid var(--warning);border-radius:8px;padding:10px 14px;font-size:12px;color:var(--text-secondary);line-height:1.6}.success-notice p{margin:2px 0}.sync-info{margin-top:24px;padding:12px 16px;background:var(--warning-bg);border:2px solid var(--warning);border-radius:var(--radius);font-size:12px;color:var(--text-secondary);text-align:center;box-shadow:var(--shadow-sm)}.donate-section{margin-top:32px;background:var(--surface);border:3px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.donate-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:3px solid var(--border);background:var(--warning-bg)}.donate-title-row{display:flex;align-items:center;gap:8px}.donate-title{font-size:18px;font-weight:700}.donate-cta{background:#be1e2d!important;border-color:#9a1824!important;color:#fff!important}.donate-cta:hover{background:#9a1824!important}.donate-empty{text-align:center;padding:24px;color:var(--text-muted);font-size:14px}.donate-total{padding:12px 18px;border-top:2px dashed #e5e5e5;font-size:13px;color:var(--text-secondary);text-align:center}.donate-total strong{color:var(--text)}.leaderboard{max-height:320px;overflow-y:auto}.leaderboard-item{display:flex;align-items:center;gap:12px;padding:12px 18px;border-bottom:1px solid #f0f0f0;transition:background .1s}.leaderboard-item:hover{background:#fafaf5}.leaderboard-item.top{background:#fffbeb}.leaderboard-item.top:first-child{background:#fef3c7}.leaderboard-rank{width:32px;text-align:center;font-size:18px;flex-shrink:0}.rank-num{font-size:14px;font-weight:700;color:var(--text-muted)}.leaderboard-info{flex:1 1;min-width:0}.leaderboard-name{font-size:14px;font-weight:600}.leaderboard-msg{font-size:11px;color:var(--text-muted);font-style:italic;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.leaderboard-amount{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--success);white-space:nowrap}.footer{margin-top:24px;padding:20px 0;border-top:3px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:12px;color:var(--text-muted);font-weight:500}.donate-btn{font-size:11px!important;padding:6px 14px!important}.donate-btn.trakteer{background:#be1e2d;color:#fff;border-color:#9a1824}.donate-btn.trakteer:hover{background:#9a1824}@media (max-width:768px){.footer{flex-direction:column;text-align:center}.leaderboard-item{padding:10px 14px}}.spinner{width:24px;height:24px;border:3px solid #e5e5e5;border-top:3px solid var(--accent);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width:768px){.app{padding:14px}.header{flex-direction:column;align-items:flex-start;gap:12px}.header-right{width:100%;justify-content:space-between;flex-wrap:wrap}.upload-zone{padding:30px 16px}.toolbar{flex-direction:column;align-items:stretch}.file-gallery{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.file-actions .btn span{display:none}.preview-modal{max-height:95vh}}@media (max-width:480px){.header-title{font-size:22px}.file-gallery{grid-template-columns:repeat(2,1fr)}.stat-item{padding:6px 10px}}