/* The Logo */
.logo {
    display: block;
    margin-left: auto;
    margin-right: auto;
    width: 400px;
    height: 80px;
    padding-bottom: 4px;
    border-bottom: 2px solid black;
    margin-bottom: 10px;
}

#animation {
  transition: opacity 0.5s ease-in-out;
  opacity: 1;
}
/*  -----------------------------   */

/* Formatting for each section  */
.section {
    border-left: 2px solid black;
    border-right: 2px solid black;
    border-top: 2px solid black;
    border-bottom: 2px solid black;
    text-shadow: 2px 2px 4px #888888;
}


/* Intro Section */
.intro {
    padding-top: 10px;
    background-color: #A5F3E8;
}

/* Profile Picture */
.profile_pic {
    justify-content: center;
    display: flex;
}

.shrek {
    width: 128px;
    height: 128px;
    border: 2px ridge black;
    align-self: center;
}

/* My Name */
.name {
    margin-top: 20px;
    font-weight: bold;
    text-align: center;
    font-family: 'Garamond';
    font-size: 36px;
    color:white;
    text-shadow: -1px -1px rgb(200, 0, 0), 1px -1px rgb(200, 0, 0), 1px 1px rgb(200, 0, 0), -1px 1px rgb(50, 0, 0),;
    padding-bottom:12px;
}

/* My Bio */
.bio {
    text-align: center;
    font-family: 'Garamond';
    font-size: 18px;
    padding-bottom: 2px;
    color: white;
}

.toDo {
    margin-left:20px;
    margin-right:20px;
}

/*  -----------------------------   */

/* Social Section */
.socials{
    padding-top: 20px;
    background-color: lightblue;
    font-weight: bold;
    text-align: center;
    font-family: 'Garamond';
    font-size: 24px;
    padding-bottom: 20px;

    column-count: 2;
    column-gap: 6px;
}

.page_links {
    color: blue;
    text-decoration: underline;
    cursor: pointer;
}

.page_links:hover {
    color:red;
}

.social_name {
    column-span: all;
    font-weight: bold;
    text-align: center;
    font-family: 'Garamond';
    font-size: 24px;
}

/* Social Icons Section*/
.social_icons {
    margin-top: 50px;
    /* justify-content: center; */
    /* display: flex; */

}

/* Images that take you to different pages */
.image_link text{
    font-size: 12pt;
    /* padding-right: 20px; */
}

.image_link img {
    width: 240px;
    height: 120px;
    /* margin-left: 50px; */
    /* margin-right: 50px; */
    margin-top: 20px;
    margin-bottom: 30px;
    border: 4px solid #000000;
    transition: border 0.4s;

    display: block;
    margin: 20px auto 30px;

}

.image_link img:hover {
    border: 12px solid transparent; /* Make the border transparent on hover */
    cursor: pointer;

}

.image_link img:default {
    border: 4px solid black;
}



/*  -----------------------------   */

/* Navigation */
.navigation {
    background-color: white;
    position: fixed;
    border: 2px solid black;
    transform: translateY(-50%);
    top: 50%;
    width: 196px;
}

.navigation button {
    display: flex; 
    align-content: center;
    visibility: visible;
    
}

.navigation button:hover {
    color: red;
}

.navigation text {
    display: flex;
    left: 50%;
    padding-top: 2px;
    padding-bottom: 2px;
}




/* Beat Section */
.beat_container {
    padding-top: 20px;
}



.beat_link:hover {
    color: purple
}

.beat_container_title{
    font-weight: bold;
    text-align: center;
    font-family: 'Garamond';
    font-size: 24px
}

.beat_container_description{
    text-align: center;
    font-family: 'Garamond';
    font-size: 18px;
    margin-bottom: 20px;
}

/* Reference to Alucard in beat section */
.alucard {
    font-style: italic;
    font-size: 12pt
}

.alucard:hover {
    font-style: italic;
    font-size: 12pt;
    color: red
}

.beat_title {
    text-align: center;
    display: block;
    font-size: 16pt;
    font-family: 'Times New Roman';
    color: white;
    text-shadow: -1px -1px black, 1px -1px black, 1px 1px black, -1px 1px black;
    padding-bottom: 4px
}



.beat_section {
    display: block;
    padding-top: 20px;
    padding-left: 20px;
    padding-bottom: 10px;
    font-size: 18pt;
    font-family: 'Times New Roman';
    font-style: italic;
    border-top: 1px dashed black;
}

.audio_container {
    column-gap: 20px;
    columns: 2;
    column-fill: auto;
}



.beat_section_desc {
    text-align: left;
    display: block;
    font-size: 12pt;
    font-family: 'Times New Roman';
    font-style: normal;
}

.beat{
    text-align: center;
    display: block;
    padding-top: 16px;
    padding-bottom: 20px

}



/* Specifications for a game section title */
.game_container {
    padding-top: 20px;
    background-color: #D2DEFF;
}

.game_container_title {
    font-weight: bold;
    text-align: center;
    font-family: 'Garamond';
    font-size: 36px
}

.game_container_title{
    font-weight: bold;
    text-align: center;
    font-family: 'Garamond';
    font-size: 24px
}

.game_container_description{
    text-align: center;
    font-family: 'Garamond';
    font-size: 18px;
    margin-bottom: 20px;
}

/* Specifications for a game window */
.game {
    margin: 4px 0 0 4px;
    box-shadow: 0 0 0 2px #000000, 0 0 0 3px #ffffff;
}

/* Progress Bar */
.progress-container {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    background-color: #e0e0e0;
    z-index: 9999;
    box-shadow: 0 -2px 4px rgba(0, 0, 0, 0.1);
    display: flex;
    flex-direction: column;
}

.progress-bar {
    height: 8px;
    width: 0%;
    background: linear-gradient(90deg, #4CAF50, #45a049);
    transition: width 0.3s ease;
}

/* Module 1 - hidden initially, fades in */
/* #module_1 {
    opacity: 0;
    transition: opacity 0.5s ease-in;
    position: absolute;
    top: 20px;
    left: 50%;
    transform: translateX(-50%);
}

#module_1.visible {
    opacity: 1;
} */

/* Module 1 - hidden initially, fades in */
.module {
    opacity: 0;
    transition: opacity 0.5s ease-in;
    position: absolute;
    top: 20px;
    left: 50%;
    transform: translateX(-50%);
    pointer-events: none; /* don't block clicks/hover when hidden */
    z-index: 1;
}

.module.visible {
    opacity: 1;
    pointer-events: auto; /* enable interaction when visible */
}

/* Ensure start button is above module so hover works */
#start {
    position: relative;
    z-index: 2;
}


/* Title fade-out */
#title {
    transition: opacity 0.5s ease-out;
}

/* Multiple Choice Quiz */
.quiz-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    margin: 40px 0;
    padding: 30px;
    background-color: #f5f5f5;
    border-radius: 8px;
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
}

.quiz-question {
    font-size: 20px;
    font-weight: bold;
    font-family: 'Garamond';
    margin-bottom: 20px;
    text-align: center;
}

.quiz-choices {
    display: flex;
    flex-direction: column;
    gap: 15px;
    width: 100%;
}

.choice {
    font-size: 16px;
    font-family: 'Garamond';
    cursor: pointer;
    padding: 10px;
    border-radius: 4px;
    transition: background-color 0.3s ease;
}

.choice:hover {
    background-color: #e0e0e0;
}

.choice input[type="radio"] {
    margin-right: 10px;
    cursor: pointer;
}

.basic_image {
    width: 100%;
    height: auto;
    border: 2px solid black;
}