/* --- Light & Dark Theme Variables --- */
:root, [data-theme='light'] {
    --bg-color: #f0f8ff; /* Light Sea Blue */
    --text-color: #333333;
    --header-color: #0077be; /* Deeper Blue */
    --accent-color: #87ceeb; /* Sky Blue */
    --accent-hover: #6495ed; /* Cornflower Blue */
    --wood-color: #deb887; /* Burly Wood */
    --card-bg: #ffffff;
    --shadow-color: rgba(0, 119, 190, 0.15);
}

[data-theme='dark'] {
    --bg-color: #1a202c;
    --text-color: #e2e8f0;
    --header-color: #87ceeb; /* Sky Blue */
    --accent-color: #0077be; /* Deeper Blue */
    --accent-hover: #6495ed; /* Cornflower Blue */
    --wood-color: #a0522d; /* Sienna */
    --card-bg: #2d3748;
    --shadow-color: rgba(135, 206, 235, 0.15);
}

/* --- General Styles & Fonts --- */
body {
    font-family: 'Quicksand', sans-serif;
    background-color: var(--bg-color);
    color: var(--text-color);
    overflow-x: hidden;
    transition: background-color 0.3s, color 0.3s;
}

h1, h2 {
    font-family: 'Concert One', cursive;
    color: var(--header-color);
}

/* --- Theme Switcher --- */
.theme-switcher {
    position: fixed;
    top: 20px;
    right: 20px;
    cursor: pointer;
    font-size: 24px;
    z-index: 1000;
    color: var(--header-color);
}
.gg-sun { display: var(--gg-sun-display, block); }
.gg-moon { display: var(--gg-moon-display, none); }
[data-theme='dark'] .gg-sun { --gg-sun-display: none; }
[data-theme='dark'] .gg-moon { --gg-moon-display: block; }

/* --- Fluffy Rounded Images & Videos --- */
.rounded-fluffy, .video-container {
    border-radius: 35px; /* More rounded */
    border: 6px solid var(--card-bg);
    box-shadow: 0 12px 30px var(--shadow-color);
    transition: transform 0.4s ease, box-shadow 0.4s ease;
}

.rounded-fluffy:hover, .video-container:hover {
    transform: translateY(-10px) scale(1.03);
    box-shadow: 0 18px 35px var(--shadow-color);
}

/* --- Hero Video Section --- */
.hero-video-section { padding: 0 2rem; }
.video-container {
    overflow: hidden;
    line-height: 0;
    background-color: var(--accent-color); /* Fallback background */
    min-height: 250px; /* Ensure visibility even if video doesn't load */
    display: flex; /* For centering fallback content if any */
    align-items: center;
    justify-content: center;
}
.video-container video {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Ensures video fills the container */
}

/* --- Token & Chart Section --- */
.token-box, .btn-chart {
    background-color: var(--card-bg);
    border-radius: 20px;
    box-shadow: 0 8px 15px rgba(0,0,0,0.05);
    transition: background-color 0.3s, transform 0.3s, box-shadow 0.3s;
}
.token-box { padding: 1.5rem; text-align: left; }
.token-label { font-family: 'Concert One', cursive; color: var(--header-color); margin-bottom: 0.5rem; font-size: 1.2rem; }
#token-ca { background-color: var(--bg-color); border: 1px solid var(--accent-color); color: var(--text-color); }
#copy-btn, .btn-chart {
    background-color: var(--accent-color);
    border-color: var(--accent-color);
    color: white;
    font-weight: bold;
}
#copy-btn:hover, .btn-chart:hover {
    background-color: var(--accent-hover);
    border-color: var(--accent-hover);
    transform: scale(1.05);
}
.btn-chart { padding: 1.2rem; font-size: 1.2rem; height: 100%; display: flex; align-items: center; justify-content: center; }

/* --- Social Media Links --- */
.social-link {
    display: inline-block;
    background-color: var(--accent-color);
    color: #fff;
    padding: 12px 25px;
    border-radius: 50px;
    text-decoration: none;
    font-weight: 700;
    margin-bottom: 10px;
    transition: background-color 0.3s ease, transform 0.3s ease;
}
.social-link i { margin-right: 10px; }
.social-link:hover { background-color: var(--accent-hover); color: #fff; transform: scale(1.08); }

/* --- Story Section --- */
#story p { line-height: 1.9; font-size: 1.1rem; }

/* --- Footer --- */
footer {
    background-color: var(--wood-color);
    color: white;
    padding: 2rem 0;
    margin-top: 3rem;
    border-top: 5px solid var(--card-bg);
}

/* --- Floating Emoji Animation --- */
.floating-emoji { position: fixed; font-size: 2.5rem; animation: float 20s infinite ease-in-out; z-index: -1; opacity: 0.6; }
@keyframes float {
    0% { transform: translateY(110vh) translateX(5vw) rotate(0deg); }
    100% { transform: translateY(-10vh) translateX(95vw) rotate(360deg); }
}