*{box-sizing:border-box;margin:0;padding:0}body{color:#1e293b;background:#f0f2f5;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif}.container{max-width:880px;margin:0 auto;padding:40px 24px 80px}.header{justify-content:space-between;align-items:center;margin-bottom:28px;display:flex}.header h1{color:#0f172a;letter-spacing:-.5px;align-items:center;gap:10px;font-size:26px;font-weight:700;display:flex}.header h1 svg{color:#6366f1}.count{color:#94a3b8;background:#fff;border-radius:20px;padding:6px 14px;font-size:14px;box-shadow:0 1px 2px #0000000a}.dropzone{text-align:center;cursor:pointer;-webkit-user-select:none;user-select:none;background:#fff;border:2px dashed #cbd5e1;border-radius:16px;margin-bottom:32px;padding:48px 20px;transition:all .3s}.dropzone:hover:not(.uploading){background:#f8f7ff;border-color:#6366f1}.dropzone.dragover{background:#eef2ff;border-color:#6366f1;transform:scale(1.01)}.dropzone.uploading{cursor:not-allowed;opacity:.85}.dropzone-idle svg{margin-bottom:14px;animation:3s ease-in-out infinite float}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.dropzone-idle p{color:#475569;margin-bottom:6px;font-size:16px;font-weight:500}.dropzone-idle span{color:#94a3b8;font-size:13px}.spinner{border:3px solid #e2e8f0;border-top-color:#6366f1;border-radius:50%;width:36px;height:36px;margin:0 auto 14px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.dropzone-loading p{color:#6366f1;font-size:15px;font-weight:500}.gallery{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px;display:grid}.card{background:#fff;border-radius:14px;transition:transform .25s,box-shadow .25s;overflow:hidden;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a}.card:hover{transform:translateY(-4px);box-shadow:0 12px 28px #0000001a}.card-img-wrap{cursor:pointer;aspect-ratio:4/3;background:#f1f5f9;position:relative;overflow:hidden}.card-img-wrap img{object-fit:cover;width:100%;height:100%;transition:transform .4s;display:block}.card:hover .card-img-wrap img{transform:scale(1.06)}.card-overlay{opacity:0;background:linear-gradient(#0000 50%,#00000073 100%);justify-content:flex-end;align-items:flex-end;gap:8px;padding:14px;transition:opacity .25s;display:flex;position:absolute;inset:0}.card:hover .card-overlay{opacity:1}.icon-btn{color:#334155;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffffe6;border:none;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;transition:all .2s;display:flex}.icon-btn:hover{background:#fff;transform:scale(1.1)}.icon-btn.danger:hover{color:#dc2626;background:#fecaca}.card-footer{align-items:center;padding:12px 14px;display:flex}.card-footer span{color:#64748b;text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.empty{text-align:center;padding:64px 20px}.empty svg{margin-bottom:16px}.empty p{color:#94a3b8;font-size:15px}.toast{z-index:1000;border-radius:10px;padding:12px 28px;font-size:14px;font-weight:500;animation:.35s slideDown;position:fixed;top:24px;left:50%;transform:translate(-50%);box-shadow:0 8px 24px #0000001f}.toast.success{color:#065f46;background:#ecfdf5}.toast.error{color:#991b1b;background:#fef2f2}@keyframes slideDown{0%{opacity:0;transform:translate(-50%)translateY(-12px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@media (max-width:600px){.container{padding:24px 16px 60px}.header{flex-direction:column;align-items:flex-start;gap:8px}.header h1{font-size:22px}.gallery{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.dropzone{padding:36px 16px}}
