*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f0f2f5;color:#333}.toast{position:fixed;top:20px;left:50%;transform:translate(-50%);padding:10px 24px;border-radius:8px;font-size:14px;z-index:999;box-shadow:0 4px 12px #00000026;animation:fadeInOut 2.5s ease}.toast.success{background:#27ae60;color:#fff}.toast.error{background:#e74c3c;color:#fff}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%) translateY(-10px)}10%{opacity:1;transform:translate(-50%) translateY(0)}80%{opacity:1}to{opacity:0}}.login-page{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#2c3e50,#3498db)}.login-card{background:#fff;padding:40px;border-radius:12px;width:380px;text-align:center;box-shadow:0 10px 40px #00000026}.login-card h1{font-size:26px;margin-bottom:8px;color:#2c3e50}.login-card .subtitle{color:#999;font-size:14px;margin-bottom:24px}.main-page{max-width:1200px;margin:0 auto;padding:0 16px 40px}header{display:flex;justify-content:space-between;align-items:center;padding:16px 0;border-bottom:1px solid #e0e0e0;margin-bottom:16px}header .logo{font-size:20px;font-weight:700;color:#2c3e50}header .header-right{display:flex;align-items:center;gap:12px}header .user{color:#999;font-size:14px}.logout-btn{color:#e74c3c;border-color:#e74c3c}.input{width:100%;padding:10px 14px;border:1px solid #ddd;border-radius:8px;font-size:14px;margin-bottom:12px;outline:none;transition:border-color .2s}.input:focus{border-color:#3498db}.btn{padding:8px 18px;border:1px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;font-size:14px;transition:all .2s}.btn:hover{border-color:#3498db;color:#3498db}.btn-primary{background:#3498db;color:#fff;border-color:#3498db;width:100%}.btn-primary:hover{background:#2980b9;color:#fff}.btn-danger{background:#e74c3c;color:#fff;border-color:#e74c3c}.btn-danger:hover{background:#c0392b}.btn-download{background:#27ae60;color:#fff;border-color:#27ae60}.btn-download:hover{background:#219a52;color:#fff}.btn-upload{background:#3498db;color:#fff;border-color:#3498db;cursor:pointer}.btn-upload:hover{background:#2980b9}.btn-sm{padding:4px 10px;font-size:12px;border:1px solid #ddd;border-radius:6px;background:#fff;cursor:pointer}.input-sm{padding:4px 8px;font-size:12px;border:1px solid #ddd;border-radius:6px;width:120px;outline:none}.err{color:#e74c3c;font-size:13px;margin-top:8px}.progress-wrap{position:relative;width:100%;height:6px;background:#e9ecef;border-radius:3px;overflow:hidden;margin-bottom:12px}.progress-bar{height:100%;background:#3498db;border-radius:3px;transition:width .2s}.progress-text{position:absolute;right:0;top:-18px;font-size:11px;color:#3498db}.tabs{display:flex;gap:8px;margin-bottom:16px}.tabs button{padding:8px 24px;border:1px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;font-size:14px;transition:all .2s}.tabs button:hover{border-color:#3498db}.tabs button.active{background:#3498db;color:#fff;border-color:#3498db}.search-bar{display:flex;gap:8px;margin-bottom:12px}.search-bar .input{margin-bottom:0;flex:1}.upload-bar{display:flex;align-items:center;gap:12px;margin-bottom:4px}.status{color:#3498db;font-size:13px}.tags-panel{display:flex;align-items:center;flex-wrap:wrap;gap:6px;margin-bottom:16px}.tags-label{font-size:13px;color:#999}.tag-btn{padding:4px 12px;border:1px solid #eee;border-radius:20px;background:#fff;cursor:pointer;font-size:12px;color:#666;transition:all .2s}.tag-btn:hover{border-color:#3498db;color:#3498db}.tag-btn.active{background:#3498db;color:#fff;border-color:#3498db}.tag-btn.add{font-size:16px;padding:2px 10px}.tag-add-inline{display:flex;align-items:center;gap:4px}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.card{background:#fff;border-radius:10px;overflow:hidden;cursor:pointer;box-shadow:0 2px 8px #0000000f;transition:transform .2s,box-shadow .2s}.card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.thumb-wrap{position:relative;width:100%;height:160px;background:#e8e8e8;overflow:hidden}.thumb-wrap img{width:100%;height:100%;object-fit:cover}.thumb-placeholder{display:flex;align-items:center;justify-content:center;height:100%;color:#bbb;font-size:16px}.duration{position:absolute;bottom:6px;right:6px;background:#000000b3;color:#fff;padding:2px 6px;border-radius:4px;font-size:11px}.card-info{padding:10px 12px}.card-name{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.card-meta{font-size:11px;color:#999}.empty{grid-column:1 / -1;text-align:center;padding:60px;color:#bbb;font-size:14px}.loading-text{color:#3498db}.pager{display:flex;justify-content:center;align-items:center;gap:16px;padding:24px 0;font-size:13px;color:#666}.pager button{padding:6px 16px;border:1px solid #ddd;border-radius:6px;background:#fff;cursor:pointer}.pager button:disabled{opacity:.4;cursor:not-allowed}.modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:100}.modal-content{background:#fff;border-radius:12px;max-width:800px;width:90%;max-height:90vh;overflow-y:auto;position:relative}.modal-close{position:absolute;top:12px;right:16px;font-size:24px;border:none;background:none;cursor:pointer;color:#999;z-index:1}.modal-preview{position:relative}.modal-preview img,.modal-preview video{width:100%;max-height:50vh;object-fit:contain;background:#000}.preview-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#00000080;color:#fff;font-size:14px}.modal-info{padding:20px}.modal-info h3{margin-bottom:10px;font-size:18px}.modal-info p{color:#666;font-size:13px;margin-bottom:6px}.tag-section{display:flex;align-items:center;gap:8px;margin:10px 0;flex-wrap:wrap}.item-tag{padding:2px 10px;background:#eaf2f8;color:#3498db;border-radius:12px;font-size:12px}.tag-editor{margin-top:10px;display:flex;gap:8px}.tag-editor .input{margin-bottom:0}.modal-actions{display:flex;gap:10px;margin-top:16px}
