function showError(msg) infoPanel.style.display = 'block'; formatsContainer.style.display = 'none'; infoPanel.innerHTML = `<div class="error-message">⚠️ $msg</div>`;
.error-message color: #f87171; background: rgba(185, 28, 28, 0.1); padding: 0.75rem 1rem; border-radius: 1rem; font-size: 0.9rem; text-align: center;
.brand h1 font-size: 2.2rem; font-weight: 700; background: linear-gradient(135deg, #E0F2FE, #38BDF8); background-clip: text; -webkit-background-clip: text; color: transparent; letter-spacing: -0.3px;
/* url input area */ .url-input-group background: #0f172a; border-radius: 2rem; border: 1px solid #1e293b; display: flex; flex-wrap: wrap; align-items: center; transition: all 0.2s; margin-bottom: 1.2rem; online video downloader
.video-details flex: 1;
/* main card */ .downloader-card max-width: 860px; width: 100%; background: rgba(18, 25, 45, 0.75); backdrop-filter: blur(8px); border-radius: 2.5rem; box-shadow: 0 25px 45px -12px rgba(0, 0, 0, 0.5), 0 0 0 1px rgba(72, 187, 255, 0.15); padding: 2rem 2rem 2.5rem; transition: all 0.2s ease;
@keyframes spin to transform: rotate(360deg); function showError(msg) infoPanel
.download-link background: #1e293b; border-radius: 2rem; padding: 0.35rem 0.8rem; color: #90cdf4; font-size: 0.8rem; font-weight: 500; text-decoration: none; transition: 0.2s;
.url-input-group:focus-within border-color: #3b82f6; box-shadow: 0 0 0 3px rgba(59,130,246,0.25);
.quality font-weight: 700; color: white; font-size: 0.9rem; function showError(msg) infoPanel.style.display = 'block'
.format-info display: flex; flex-direction: column;
fetchBtn.addEventListener('click', processVideo); // optional: press enter in input urlInput.addEventListener('keypress', (e) => if (e.key === 'Enter') e.preventDefault(); processVideo(); );
function showError(msg) infoPanel.style.display = 'block'; formatsContainer.style.display = 'none'; infoPanel.innerHTML = `<div class="error-message">⚠️ $msg</div>`;
.error-message color: #f87171; background: rgba(185, 28, 28, 0.1); padding: 0.75rem 1rem; border-radius: 1rem; font-size: 0.9rem; text-align: center;
.brand h1 font-size: 2.2rem; font-weight: 700; background: linear-gradient(135deg, #E0F2FE, #38BDF8); background-clip: text; -webkit-background-clip: text; color: transparent; letter-spacing: -0.3px;
/* url input area */ .url-input-group background: #0f172a; border-radius: 2rem; border: 1px solid #1e293b; display: flex; flex-wrap: wrap; align-items: center; transition: all 0.2s; margin-bottom: 1.2rem;
.video-details flex: 1;
/* main card */ .downloader-card max-width: 860px; width: 100%; background: rgba(18, 25, 45, 0.75); backdrop-filter: blur(8px); border-radius: 2.5rem; box-shadow: 0 25px 45px -12px rgba(0, 0, 0, 0.5), 0 0 0 1px rgba(72, 187, 255, 0.15); padding: 2rem 2rem 2.5rem; transition: all 0.2s ease;
@keyframes spin to transform: rotate(360deg);
.download-link background: #1e293b; border-radius: 2rem; padding: 0.35rem 0.8rem; color: #90cdf4; font-size: 0.8rem; font-weight: 500; text-decoration: none; transition: 0.2s;
.url-input-group:focus-within border-color: #3b82f6; box-shadow: 0 0 0 3px rgba(59,130,246,0.25);
.quality font-weight: 700; color: white; font-size: 0.9rem;
.format-info display: flex; flex-direction: column;
fetchBtn.addEventListener('click', processVideo); // optional: press enter in input urlInput.addEventListener('keypress', (e) => if (e.key === 'Enter') e.preventDefault(); processVideo(); );