/* --- Final Premium Design CSS --- */
@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;700&display=swap');
@import url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0-beta3/css/all.min.css');

:root {
    --primary-color: #007BFF;
    --primary-hover: #0056b3;
    --background-blur: url('https://images.unsplash.com/photo-1554141421-57a26b384050?q=80&w=2094&auto=format&fit=crop');
    --form-background: rgba(255, 255, 255, 0.95);
    --text-dark: #333;
    --text-light: #6c757d;
    --border-color: #ced4da;
    --border-focus: #80bdff;
    --success-bg: #d1e7dd; --success-text: #0f5132;
    --error-bg: #f8d7da; --error-text: #842029;
}

body {
    font-family: 'Roboto', sans-serif;
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
    padding: 1rem;
    box-sizing: border-box;
    color: var(--text-dark);
    background-image: var(--background-blur);
    background-size: cover;
    background-position: center;
}

.auth-container {
    position: relative;
    width: 100%;
    max-width: 400px;
    padding: 3rem 2.5rem;
    background: var(--form-background);
    border-radius: 1.5rem;
    box-shadow: 0 15px 30px rgba(0, 0, 0, 0.2);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.2);
    animation: fadeIn 0.5s ease-in-out;
}

@keyframes fadeIn { from { opacity: 0; transform: scale(0.95); } to { opacity: 1; transform: scale(1); } }

.auth-header h1 {
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: 0.5rem;
    text-align: left;
    color: var(--text-dark);
}

.auth-header p {
    color: var(--text-light);
    margin-bottom: 2rem;
    text-align: left;
    font-size: 0.9rem;
}
.auth-header p a { color: var(--primary-color); text-decoration: none; font-weight: 500; }

.input-wrapper {
    position: relative;
    margin-bottom: 1.25rem;
}

.input-wrapper .input-icon {
    position: absolute;
    top: 50%;
    left: 1rem;
    transform: translateY(-50%);
    color: var(--text-light);
}

.input-wrapper input {
    width: 100%;
    padding: 0.8rem 1rem 0.8rem 2.5rem;
    border: 1px solid var(--border-color);
    border-radius: 50px;
    font-size: 1rem;
    box-sizing: border-box;
    transition: all 0.2s;
}
.input-wrapper input:focus {
    outline: none;
    border-color: var(--border-focus);
    box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.25);
}

.form-options {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1.5rem;
    font-size: 0.85rem;
}
.form-options label { display: flex; align-items: center; cursor: pointer; color: var(--text-light); }
.form-options input[type="checkbox"] { margin-right: 0.5rem; }
.form-options a { color: var(--primary-color); text-decoration: none; }

.submit-btn {
    width: 100%;
    padding: 0.9rem;
    background: var(--primary-color);
    color: white;
    font-size: 1rem;
    font-weight: 500;
    border-radius: 50px;
    border: none;
    cursor: pointer;
    transition: background-color 0.2s;
}
.submit-btn:hover { background: var(--primary-hover); }

.message-box {
    padding: 0.8rem 1rem; margin-bottom: 1rem; border-radius: 0.5rem;
    font-weight: 500; border: 1px solid transparent; text-align: center;
}
.message-box.success { background-color: #d1e7dd; color: #0f5132; border-color: #badbcc; }
.message-box.error { background-color: #f8d7da; color: #842029; border-color: #f5c2c7; }

/* --- Video Help Modal Styles --- */
.help-section { text-align: center; margin-top: 1.5rem; }
#open-help-modal {
    background: none; border: 1px solid var(--primary-color);
    color: var(--primary-color); padding: 0.5rem 1rem;
    border-radius: 50px; cursor: pointer; font-weight: 500; transition: all 0.2s;
}
#open-help-modal:hover { background: var(--primary-color); color: white; }
.modal {
    display: none; position: fixed; z-index: 1000; left: 0; top: 0;
    width: 100%; height: 100%; overflow: auto; background-color: rgba(0, 0, 0, 0.7);
    justify-content: center; align-items: center;
}
.modal-content {
    background-color: #fff; padding: 20px; border-radius: 1rem;
    width: 90%; max-width: 800px; position: relative;
    box-shadow: 0 5px 15px rgba(0,0,0,0.3); animation: zoomIn 0.3s ease;
}
@keyframes zoomIn { from { transform: scale(0.8); } to { transform: scale(1); } }
.close-modal {
    color: #aaa; position: absolute; top: 10px; right: 25px;
    font-size: 35px; font-weight: bold; cursor: pointer;
}
.close-modal:hover, .close-modal:focus { color: black; }
.video-container {
    position: relative; padding-bottom: 56.25%; height: 0;
    overflow: hidden; margin-top: 10px; border-radius: 0.5rem;
}
.video-container iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }```

### **ফাইল ২: `script.js` (সম্পূর্ণ নতুন কোড)**

**করণীয়:** `script.js` নামে একটি নতুন ফাইল তৈরি করে নিচের সম্পূর্ণ কোডটি সেখানে পেস্ট করুন।

```javascript
/**
 * টেক্সটকে ভয়েসে রূপান্তর করার ফাংশন
 * @param {string} text - যে লেখাটি ভয়েসে বলা হবে
 * @param {boolean} immediate - অন্য কথা চলতে থাকলে সেটা বন্ধ করে hemen বলবে কিনা
 */
function speak(text, immediate = false) {
    if ('speechSynthesis' in window) {
        if (immediate) {
            window.speechSynthesis.cancel(); // আগের কথা বলা বন্ধ করুন
        }
        const utterance = new SpeechSynthesisUtterance(text);
        utterance.lang = 'bn-BD'; // বাংলা ভয়েসের জন্য
        utterance.rate = 0.9;
        utterance.pitch = 1;
        window.speechSynthesis.speak(utterance);
    }
}

/**
 * পেজ লোড হওয়ার সাথে সাথে স্বাগত বার্তা দেওয়ার জন্য ফাংশন
 * @param {string} pageName - কোন পেজ লোড হয়েছে (login/register)
 */
function playWelcomeVoice(pageName) {
    let welcomeMessage = '';
    if (pageName === 'login') {
        welcomeMessage = 'স্বাগতম। আপনার অ্যাকাউন্টে প্রবেশ করতে ইমেল এবং পাসওয়ার্ড দিন।';
    } else if (pageName === 'register') {
        welcomeMessage = 'নতুন অ্যাকাউন্ট তৈরি করতে আপনাকে স্বাগতম। অনুগ্রহ করে নিচের ফর্মটি পূরণ করুন। সাহায্যের প্রয়োজন হলে, হেল্প বাটনে ক্লিক করুন।';
    } else if (pageName === 'verify') {
        welcomeMessage = 'আপনার ইমেইল ভেরিফাই করার জন্য পাঠানো ও, টি, পি, কোডটি এখানে দিন।';
    }
    // ৩০ মিলিসেকেন্ড পরে ভয়েস চালু হবে যাতে পেজটি পুরোপুরি লোড হতে পারে
    setTimeout(() => speak(welcomeMessage, true), 300);
}


// --- ভিডিও পপ-আপ (Modal) এর জন্য জাভাস্ক্রিপ্ট ---
document.addEventListener('DOMContentLoaded', () => {
    const modal = document.getElementById('help-modal');
    const openBtn = document.getElementById('open-help-modal');
    const closeBtn = document.querySelector('.close-modal');
    const videoFrame = document.getElementById('help-video-frame');
    const videoSrc = videoFrame ? videoFrame.src : '';

    if (openBtn) {
        openBtn.onclick = function(e) {
            e.preventDefault();
            if (modal) {
                modal.style.display = 'flex';
            }
        }
    }

    const closeModal = function() {
        if (modal) {
            modal.style.display = 'none';
            // ভিডিও বন্ধ করার জন্য iframe এর src খালি করে দেওয়া হচ্ছে
            if (videoFrame) {
                videoFrame.src = '';
                // আবার খোলার জন্য src পুনরায় সেট করা হচ্ছে
                setTimeout(() => { videoFrame.src = videoSrc; }, 100);
            }
        }
    }

    if (closeBtn) {
        closeBtn.onclick = closeModal;
    }

    window.onclick = function(event) {
        if (event.target == modal) {
            closeModal();
        }
    }
});