*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);color:#333;font-family:Inter,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;min-height:100vh}.container{margin:0 auto;max-width:1400px;padding:12px}header{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 8px 32px #667eea66;color:#fff;margin-bottom:25px;overflow:hidden;padding:30px 0 25px;position:relative}header:before{animation:float 6s ease-in-out infinite;background:#ffffff1a;border-radius:50%;content:"";height:500px;position:absolute;right:-10%;top:-50%;width:500px}header h1{font-size:clamp(22px,5vw,36px);font-weight:700;letter-spacing:-.5px;margin:0 auto;max-width:1400px;padding:0 12px;position:relative;text-align:center;z-index:1}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(20px)}}.main-content{grid-gap:20px;align-items:start;display:grid;gap:20px;grid-template-columns:1fr}.uploader-section{height:-webkit-fit-content;height:fit-content;overflow:hidden;padding:0}.gallery-section,.uploader-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d}.gallery-section{padding:20px}@media (min-width:640px){.container{padding:16px}header{margin-bottom:30px}.gallery-section{padding:25px}}@media (min-width:1024px){.container{padding:20px}.main-content{gap:30px;grid-template-columns:360px 1fr}header{margin-bottom:40px;padding:40px 0 30px}header h1{text-align:left}.gallery-section{padding:30px}}.app{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}.uploader{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:20px}.uploader h2{color:#667eea;font-size:clamp(18px,4vw,24px);font-weight:700;letter-spacing:-.5px;margin-bottom:20px}.form-group{margin-bottom:18px}.form-group label{color:#333;display:block;font-size:clamp(12px,2vw,14px);font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.form-group input[type=file],.form-group input[type=text]{-webkit-appearance:none;appearance:none;border:2px solid #e0e0e0;border-radius:10px;font-family:Inter,sans-serif;font-size:14px;padding:12px 14px;transition:all .3s ease;width:100%}.form-group input[type=file]:hover,.form-group input[type=text]:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea1a}.form-group input[type=file]:focus,.form-group input[type=text]:focus{border-color:#667eea;box-shadow:0 0 0 4px #667eea1a;outline:none}.form-group input:disabled{background-color:#f8f9fa;cursor:not-allowed;opacity:.6}.file-types{color:#999;font-size:11px;font-weight:500;margin-top:6px}.progress-bar{background:#f0f0f0;border-radius:10px;box-shadow:inset 0 2px 4px #0000000d;height:24px;margin-bottom:18px;overflow:hidden;width:100%}.progress-fill{align-items:center;background:linear-gradient(90deg,#667eea,#764ba2);box-shadow:0 0 10px #667eea80;color:#fff;display:flex;font-size:11px;font-weight:700;height:100%;justify-content:center;transition:width .3s ease}.alert{animation:slideIn .3s ease;border-left:4px solid;border-radius:10px;font-size:13px;margin-bottom:18px;padding:12px 14px}@keyframes slideIn{0%{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)}}.alert-error{background-color:#fff5f5;border-left-color:#e53e3e;color:#c53030}.alert-success{background-color:#f0fdf4;border-left-color:#22c55e;color:#166534}.btn-primary{-webkit-appearance:none;appearance:none;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;box-shadow:0 4px 15px #667eea66;color:#fff;cursor:pointer;font-size:clamp(12px,2vw,14px);font-weight:700;letter-spacing:.5px;min-height:44px;padding:13px 16px;text-transform:uppercase;transition:all .3s ease;width:100%}.btn-primary:hover:not(:disabled){box-shadow:0 8px 25px #667eea99;transform:translateY(-2px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{background:#cbd5e1;box-shadow:none;cursor:not-allowed}@media (min-width:640px){.uploader{padding:25px}.form-group{margin-bottom:20px}}@media (min-width:1024px){.uploader{padding:30px}.uploader h2{margin-bottom:30px}.form-group{margin-bottom:20px}}.asset-card{background:#fff;border:none;border-radius:12px;box-shadow:0 4px 15px #00000014;display:flex;flex-direction:column;height:100%;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.asset-card:hover{box-shadow:0 12px 30px #667eea40;transform:translateY(-6px) scale(1.02)}.asset-card:active{transform:translateY(-2px)}.asset-preview{align-items:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);display:flex;height:130px;justify-content:center;overflow:hidden;position:relative;width:100%}.asset-preview:after{background:#667eea00;content:"";inset:0;position:absolute;transition:background .3s ease}.asset-card:hover .asset-preview:after{background:#667eea1a}.asset-image{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.asset-card:hover .asset-image{transform:scale(1.05)}.asset-icon{animation:bounce 2s infinite;font-size:48px}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.asset-info{display:flex;flex:1 1;flex-direction:column;min-height:80px;padding:12px}.asset-info h4{color:#2c3e50;font-size:clamp(12px,2vw,14px);font-weight:700;letter-spacing:-.3px;margin:0 0 6px}.asset-info h4,.asset-info p{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.asset-info p{color:#999;font-size:clamp(11px,1.5vw,12px);font-weight:500;margin:3px 0}.file-type{color:#667eea;font-size:10px;font-weight:700;text-transform:uppercase}.file-size{color:#999}.upload-date{color:#bbb;font-size:10px}.tags{color:#e74c3c;font-size:10px;font-weight:600;margin-top:auto}.asset-actions{grid-gap:6px;background:linear-gradient(135deg,#f8f9fa,#f0f0f5);border-top:1px solid #f0f0f0;display:grid;gap:6px;grid-template-columns:1fr 1fr;padding:8px}.btn-delete,.btn-download{align-items:center;-webkit-appearance:none;appearance:none;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:10px;font-weight:700;justify-content:center;letter-spacing:.3px;min-height:34px;padding:8px 6px;text-align:center;text-decoration:none;text-transform:uppercase;transition:all .3s ease}.btn-download{background:linear-gradient(135deg,#2ecc71,#27ae60);box-shadow:0 2px 8px #2ecc714d;color:#fff}.btn-download:hover{box-shadow:0 4px 12px #2ecc7166;transform:translateY(-2px)}.btn-download:active{transform:translateY(0)}.btn-delete{background:linear-gradient(135deg,#e74c3c,#c0392b);box-shadow:0 2px 8px #e74c3c4d;color:#fff}.btn-delete:hover{box-shadow:0 4px 12px #e74c3c66;transform:translateY(-2px)}.btn-delete:active{transform:translateY(0)}@media (min-width:640px){.asset-preview{height:140px}.asset-info{min-height:85px;padding:13px}.asset-actions{padding:10px}.btn-delete,.btn-download{font-size:11px;padding:9px 7px}}@media (min-width:1024px){.asset-preview{height:160px}.asset-info{min-height:100px;padding:16px}.asset-actions{gap:10px;padding:14px}.btn-delete,.btn-download{font-size:12px;grid-column:auto;padding:10px 8px}}.gallery{margin-top:0}.gallery h3{color:#667eea;font-size:clamp(14px,3vw,16px);font-weight:700;letter-spacing:.5px;margin-bottom:18px;text-transform:uppercase}.gallery-grid{grid-gap:12px;animation:fadeIn .4s ease;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.loading{align-items:center;animation:pulse 2s infinite;color:#999;display:flex;font-size:14px;font-weight:500;justify-content:center;min-height:150px;padding:40px 20px;text-align:center}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.empty-state{align-items:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border:2px dashed #667eea4d;border-radius:12px;color:#999;display:flex;font-size:clamp(13px,3vw,16px);font-weight:500;justify-content:center;min-height:200px;padding:50px 25px;text-align:center}@media (min-width:640px){.gallery-grid{gap:14px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.empty-state{min-height:240px;padding:60px 30px}}@media (min-width:1024px){.gallery-grid{gap:16px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.empty-state{min-height:280px;padding:80px 40px}}.search-filter{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border:none;border-radius:12px;box-shadow:0 4px 15px #00000014;margin-bottom:25px;padding:16px}.search-filter h3{color:#667eea;font-size:clamp(14px,3vw,16px);font-weight:700;letter-spacing:.5px;margin-bottom:16px;text-transform:uppercase}.filter-controls{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr}.filter-group{display:flex;flex-direction:column}.filter-group label{color:#555;font-size:11px;font-weight:700;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.filter-group input,.filter-group select{-webkit-appearance:none;appearance:none;background:#fff;border:2px solid #667eea33;border-radius:8px;font-family:Inter,inherit;font-size:13px;min-height:40px;padding:10px 12px;transition:all .3s ease}.filter-group select{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='%23667eea' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;background-size:20px;padding-right:36px}.filter-group input:hover,.filter-group select:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea26}.filter-group input:focus,.filter-group select:focus{border-color:#667eea;box-shadow:0 0 0 4px #667eea1a;outline:none}.filter-buttons{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.btn-filter,.btn-reset{-webkit-appearance:none;appearance:none;border:none;border-radius:8px;cursor:pointer;font-size:clamp(11px,2vw,13px);font-weight:700;letter-spacing:.5px;min-height:40px;padding:11px 14px;text-transform:uppercase;transition:all .3s ease}.btn-filter{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 12px #667eea4d;color:#fff}.btn-filter:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.btn-filter:active{transform:translateY(0)}.btn-reset{background:#fff;border:2px solid #667eea;color:#667eea}.btn-reset:hover{background:#f8f9fa;transform:translateY(-2px)}.btn-reset:active{transform:translateY(0)}@media (min-width:640px){.search-filter{padding:18px}.filter-controls{grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.search-filter{padding:20px}.filter-controls{grid-template-columns:repeat(2,1fr)}}
/*# sourceMappingURL=main.061a46a1.css.map*/