/* ---
Moez Technology - Coming Soon Page v7.0
Fully Responsive UX Overhaul
--- */

/* --- 1. General Setup & Variables --- */
:root {
    --font-primary: 'Cairo', sans-serif;
    --font-secondary: 'Tajawal', sans-serif;
    --transition-speed: 0.4s;
    --transition-bezier: cubic-bezier(0.34, 1.56, 0.64, 1);

    /* Light Mode Colors */
    --bg-color-light: #F4F7FC;
    --text-color-light: #333;
    --text-muted-light: #667;
    --glass-bg-light: rgba(255, 255, 255, 0.6);
    --glass-border-light: rgba(255, 255, 255, 0.9);
    --primary-gradient-light: linear-gradient(135deg, #6B73FF 0%, #000DFF 100%);
    --primary-shadow-light: rgba(76, 93, 252, 0.4);
    --success-color-light: #10B981;
    --error-color-light: #EF4444;
    --icon-color-light: #555;

    /* Dark Mode Colors */
    --bg-color-dark: #0D1117;
    --text-color-dark: #E6EDF3;
    --text-muted-dark: #9DA8B7;
    --glass-bg-dark: rgba(22, 27, 34, 0.6);
    --glass-border-dark: rgba(37, 45, 56, 0.8);
    --primary-gradient-dark: linear-gradient(135deg, #8A92FF 0%, #4250FF 100%);
    --primary-shadow-dark: rgba(94, 112, 255, 0.3);
    --success-color-dark: #34D399;
    --error-color-dark: #F87171;
    --icon-color-dark: #C9D1D9;
}

html {
    --bg-color: var(--bg-color-light);
    --text-color: var(--text-color-light);
    --text-muted: var(--text-muted-light);
    --glass-bg: var(--glass-bg-light);
    --glass-border: var(--glass-border-light);
    --primary-gradient: var(--primary-gradient-light);
    --primary-shadow: var(--primary-shadow-light);
    --success-color: var(--success-color-light);
    --error-color: var(--error-color-light);
    --icon-color: var(--icon-color-light);
}

html.dark-mode {
    --bg-color: var(--bg-color-dark);
    --text-color: var(--text-color-dark);
    --text-muted: var(--text-muted-dark);
    --glass-bg: var(--glass-bg-dark);
    --glass-border: var(--glass-border-dark);
    --primary-gradient: var(--primary-gradient-dark);
    --primary-shadow: var(--primary-shadow-dark);
    --success-color: var(--success-color-dark);
    --error-color: var(--error-color-dark);
    --icon-color: var(--icon-color-dark);
}

/* --- 2. Base & Animated Background --- */
*, *::before, *::after {
    box-sizing: border-box;
}

body {
    font-family: var(--font-primary);
    background-color: var(--bg-color);
    color: var(--text-color);
    margin: 0;
    padding: 3rem 1.5rem; /* Increased top/bottom padding for more space */
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
    transition: background-color var(--transition-speed) ease, color var(--transition-speed) ease;
    line-height: 1.8;
    overflow-x: hidden;
}

.background-animation {
    position: fixed; top: 0; left: 0; width: 100%; height: 100%;
    z-index: -1; background: var(--primary-gradient); opacity: 0.1;
    animation: gradient-flow 15s ease infinite;
}
@keyframes gradient-flow { 0% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } 100% { background-position: 0% 50%; } }

/* --- 3. Main Container & Layout --- */
.container {
    max-width: 650px; width: 100%; text-align: center; z-index: 1;
}

/* --- 4. Animations & Transitions --- */
@keyframes fadeIn-down { from { opacity: 0; transform: translateY(-20px); } to { opacity: 1; transform: translateY(0); } }
@keyframes fadeIn-up { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
@keyframes text-fade-in {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

@keyframes shake {
  10%, 90% { transform: translate3d(-1px, 0, 0); }
  20%, 80% { transform: translate3d(2px, 0, 0); }
  30%, 50%, 70% { transform: translate3d(-4px, 0, 0); }
  40%, 60% { transform: translate3d(4px, 0, 0); }
}
.shake {
  animation: shake 0.82s cubic-bezier(.36,.07,.19,.97) both;
}

.main-header, .countdown-section, .counter-section {
    animation: fadeIn-down 0.8s ease-out backwards;
}
.card-wrapper { animation: fadeIn-up 0.8s ease-out 0.2s backwards; }

/* --- 5. Professional Theme Toggle --- */
.theme-toggle-label {
    position: fixed; top: 20px; left: 20px; z-index: 100;
    width: 100px; height: 40px; cursor: pointer;
}
.theme-toggle-label input { display: none; }
.theme-toggle-switch {
    position: relative; width: 100%; height: 100%;
    background-color: #3c4161; border-radius: 20px;
    transition: background-color 0.3s ease;
    overflow: hidden;
}
.theme-toggle-handle {
    position: absolute; top: 4px; left: 4px;
    width: 32px; height: 32px;
    background-color: #f8f8f8; border-radius: 50%;
    transition: transform 0.4s var(--transition-bezier);
    box-shadow: 0 2px 5px rgba(0,0,0,0.2);
}
.theme-toggle-label input:checked ~ .theme-toggle-switch { background-color: #87CEEB; }
.theme-toggle-label input:checked ~ .theme-toggle-switch .theme-toggle-handle { transform: translateX(60px) rotate(360deg); background-color: #FFD700; }

.crater { position: absolute; background-color: #e0e0e0; border-radius: 50%; transition: opacity 0.4s ease; }
.crater-1 { width: 6px; height: 6px; top: 5px; left: 15px; }
.crater-2 { width: 10px; height: 10px; top: 12px; left: 5px; }
.crater-3 { width: 5px; height: 5px; top: 20px; left: 18px; }
input:checked ~ .theme-toggle-switch .theme-toggle-handle .crater { opacity: 0; }

.star { position: absolute; background-color: white; border-radius: 50%; transition: all 0.4s ease; transform: scale(0); }
.star-1 { width: 3px; height: 3px; top: 8px; left: 15px; }
.star-2 { width: 4px; height: 4px; top: 20px; left: 10px; }
.star-3 { width: 2px; height: 2px; top: 15px; left: 30px; }
.star-4 { width: 3px; height: 3px; top: 25px; left: 45px; }
.star-5 { width: 2px; height: 2px; top: 10px; left: 55px; }
.star-6 { width: 4px; height: 4px; top: 22px; left: 80px; }
input:checked ~ .theme-toggle-switch .star { transform: scale(1); transition-delay: 0.2s; }

/* --- 6. Header & Typography --- */
.main-header .title {
    font-family: var(--font-secondary); font-size: clamp(2.5rem, 10vw, 4rem); font-weight: 900;
    margin-bottom: 0.5rem; background: var(--primary-gradient); -webkit-background-clip: text;
    -webkit-text-fill-color: transparent; animation: fadeIn-down 0.6s ease-out;
}
.main-header .subtitle {
    font-size: clamp(1rem, 4vw, 1.25rem); color: var(--text-muted);
    animation: fadeIn-down 0.6s ease-out 0.1s backwards;
}
.incentive-text {
    font-size: 0.9rem;
    color: var(--text-muted);
    margin-top: 1rem;
    font-style: italic;
}

/* --- 7. Countdown Timer --- */
.countdown-section { margin: 2.5rem 0; }
.countdown-section .section-title { font-size: 1.1rem; color: var(--text-muted); margin-bottom: 1.5rem; }
.countdown-container { display: flex; justify-content: center; gap: 1rem; flex-wrap: wrap; }
.time-box {
    background: var(--glass-bg); border: 1px solid var(--glass-border); backdrop-filter: blur(5px);
    border-radius: 12px; padding: 1rem; min-width: 90px; display: flex; flex-direction: column;
    box-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.1); transition: transform 0.3s ease;
}
.time-box:hover { transform: translateY(-5px); }
.time-box span { font-family: var(--font-secondary); font-size: clamp(2rem, 8vw, 3rem); font-weight: 700; line-height: 1.1; color: var(--text-color); }
.time-box label { font-size: 0.8rem; text-transform: uppercase; color: var(--text-muted); margin-top: 0.5rem; }

/* --- 8. Card System & Forms --- */
.card-wrapper { position: relative; min-height: 350px; perspective: 1000px; }
.card {
    background: var(--glass-bg); padding: 2.5rem; border-radius: 20px; border: 1px solid var(--glass-border);
    box-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.1); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
    margin-bottom: 1.5rem; width: 100%; box-sizing: border-box; position: absolute; top: 0; left: 0;
    opacity: 0; transform: rotateY(-30deg) scale(0.9); transition: all 0.6s var(--transition-bezier); pointer-events: none;
}
.card.is-active { opacity: 1; transform: rotateY(0) scale(1); pointer-events: auto; }
.card.is-exiting { opacity: 0; transform: rotateY(30deg) scale(0.9); pointer-events: none; }

#post-challenge-section { position: relative; display: flex; gap: 2rem; text-align: right; }
.skip-feedback-btn {
    position: absolute; top: 15px; left: 15px; background: rgba(128, 128, 128, 0.2); border: none;
    width: 30px; height: 30px; border-radius: 50%;
    font-size: 1.5rem; color: var(--text-muted); cursor: pointer; line-height: 1;
    padding: 0; transition: all 0.3s ease;
}
.skip-feedback-btn:hover { transform: scale(1.2) rotate(90deg); color: var(--text-color); background: rgba(128, 128, 128, 0.3); }

#leaderboard-section, #feedback-section { flex: 1; }
.section-title { margin-top: 0; font-size: 1.6rem; font-weight: 700; color: var(--text-color); }
.card p { color: var(--text-muted); }
.input-group { display: flex; gap: 0.5rem; margin-top: 1.5rem; position: relative; }
input[type="email"], textarea {
    flex-grow: 1; padding: 1rem 1.2rem; border: 1px solid transparent; border-radius: 12px;
    background-color: rgba(128, 128, 128, 0.1); color: var(--text-color); font-family: var(--font-primary);
    font-size: 1rem; transition: all var(--transition-speed) ease;
}
input[type="email"]:focus, textarea:focus { outline: none; border-color: var(--glass-border); background-color: transparent; box-shadow: 0 0 0 4px var(--primary-shadow); }
textarea { resize: vertical; width: 100%; margin-top: 1rem; box-sizing: border-box; }
button {
    padding: 1rem 2rem; background: var(--primary-gradient); color: white; border: none; border-radius: 12px;
    font-family: var(--font-primary); font-size: 1rem; font-weight: bold; cursor: pointer;
    transition: all var(--transition-speed) ease; position: relative; overflow: hidden;
    box-shadow: 0 4px 15px -5px var(--primary-shadow);
}
button:hover { transform: translateY(-3px); box-shadow: 0 7px 20px -5px var(--primary-shadow); }
button:disabled { opacity: 0.6; cursor: not-allowed; }
.form-message { margin-top: 1rem; font-weight: bold; min-height: 24px; transition: color 0.3s; }
.form-message.success { color: var(--success-color); }
.form-message.error { color: var(--error-color); }
.form-message .fade-in-text span {
    opacity: 0;
    animation: text-fade-in 0.5s forwards;
}
.challenge-label { display: block; font-size: 1.2rem; margin-bottom: 1rem; color: var(--text-color); }

.copy-code-btn {
    background: rgba(128, 128, 128, 0.2);
    border: 1px solid var(--glass-border);
    padding: 0.5rem 1rem;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.3s ease;
    margin-top: 0.5rem;
    display: inline-block;
    font-family: var(--font-primary);
}
.copy-code-btn:hover {
    background: rgba(128, 128, 128, 0.3);
    transform: translateY(-2px);
}
.copy-code-btn.copied {
    background: var(--success-color);
    color: white;
    cursor: default;
}
.copy-code-btn code {
    background: none;
    font-weight: bold;
    font-size: 1.1rem;
    color: var(--text-color);
}
.copy-code-btn.copied code {
    color: white;
}

/* --- 9. Leaderboard & Feedback --- */
#leaderboard-list { list-style: none; padding: 0; margin: 1rem 0; }
#leaderboard-list li {
    background-color: rgba(128, 128, 128, 0.1); padding: 0.75rem 1rem; border-radius: 8px;
    margin-bottom: 0.5rem; font-size: 1rem; font-weight: bold; border-left: 4px solid;
    border-image: var(--primary-gradient) 1; transition: all 0.3s ease;
}
#leaderboard-list li.is-user-guess {
    transform: scale(1.05);
    background: var(--primary-gradient);
    color: white;
    box-shadow: 0 5px 15px var(--primary-shadow);
}
#feedback-form button { width: 100%; margin-top: 1rem; }
.final-thanks-content { animation: fadeIn-up 0.8s ease-out; }

/* --- 10. Counters & Footer --- */
.counter-section { margin-top: 2.5rem; color: var(--text-muted); }
#counter-section p { font-size: 1.1rem; }
#subscriber-count { font-weight: bold; color: var(--text-color); }

/* --- 11. Share Modal --- */
.share-modal-overlay {
    position: fixed; top: 0; left: 0; width: 100%; height: 100%;
    background-color: rgba(0,0,0,0.5); z-index: 1000;
    display: flex; justify-content: center; align-items: center;
    padding: 1rem;
    opacity: 0; visibility: hidden; transition: opacity 0.3s ease, visibility 0.3s;
}
.share-modal-overlay.is-visible { opacity: 1; visibility: visible; }
.share-modal-card {
    background: var(--glass-bg); padding: 2.5rem; border-radius: 20px; border: 1px solid var(--glass-border);
    box-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.2); backdrop-filter: blur(15px); -webkit-backdrop-filter: blur(15px);
    max-width: 500px; width: 100%; text-align: center; position: relative;
    transform: scale(0.9); transition: transform 0.4s var(--transition-bezier);
}
.share-modal-overlay.is-visible .share-modal-card { transform: scale(1); }
.close-modal-btn {
    position: absolute; top: 15px; left: 15px; background: none; border: none;
    font-size: 2rem; color: var(--text-muted); cursor: pointer; line-height: 1;
    padding: 0; transition: transform 0.3s ease;
}
.close-modal-btn:hover { transform: scale(1.2) rotate(90deg); color: var(--text-color); }
.share-modal-card h3 { font-size: 1.8rem; margin-top: 0; }
.social-share { display: flex; justify-content: center; gap: 1.5rem; margin-top: 2rem; }
.social-share .social-icon {
    width: 60px; height: 60px; border-radius: 50%; display: flex; justify-content: center; align-items: center;
    transition: transform 0.3s ease;
}
.social-share .social-icon:hover { transform: translateY(-5px) scale(1.1); }
.social-share .social-icon svg { width: 30px; height: 30px; fill: white; }
.social-share .twitter { background: #1DA1F2; }
.social-share .facebook { background: #1877F2; }
.social-share .whatsapp { background: #25D366; }

/* --- 12. Responsive Design --- */
@media (max-width: 768px) {
    #post-challenge-section {
        flex-direction: column;
        gap: 1.5rem;
    }
    .card-wrapper {
        min-height: auto; /* Let content define height */
    }
    .share-modal-card h3 {
        font-size: 1.5rem;
    }
    .social-share .social-icon {
        width: 50px;
        height: 50px;
    }
    .social-share .social-icon svg {
        width: 25px;
        height: 25px;
    }
}

@media (max-width: 480px) {
    body {
        padding: 2rem 1rem;
    }
    .theme-toggle-label {
        width: 80px;
        height: 35px;
        top: 15px;
        left: 15px;
    }
    .theme-toggle-handle {
        width: 27px;
        height: 27px;
    }
    .theme-toggle-label input:checked ~ .theme-toggle-switch .theme-toggle-handle {
        transform: translateX(45px) rotate(360deg);
    }
    .countdown-container {
        gap: 0.5rem;
    }
    .time-box {
        padding: 0.75rem;
        min-width: 65px;
        flex-grow: 1; /* Allow boxes to grow and fill space */
    }
    .card {
        padding: 1.5rem;
    }
    .input-group {
        flex-direction: column;
    }
    #post-challenge-section {
        text-align: center;
    }
    .section-title {
        font-size: 1.4rem;
    }
    .share-modal-card {
        padding: 2rem 1.5rem;
    }
}
