body {
    background-image: url("square.png");
    background-repeat: repeat;
}
h1 {
    font-family: Helvetica, Arial, sans-serif
}
p {
    margin-block-start: 1em;
    margin-block-end: 1em;
    margin-inline-start: 0px;
    margin-inline-end: 0px;
}
.puzzleRow {
    display: flex;
}
.puzzleTitle {
    flex-basis: auto; 
    flex-grow: 0;
    order: 1;
}
.puzzleAnswer {
    flex-basis: auto; 
    flex-grow: 0;
    order: 3;
}
.dots {
    overflow-wrap: break-word;
    display: inline-block;
    height: 1.5em;
    overflow: hidden;
    vertical-align: top;
    order: 2;
    flex: 3 0px;
}
#mainDiv {
    color: black;
    width: 1000px;
    margin-left: auto;
    margin-right: auto;
}
#prepuzzleImg {
    height: 500px;
    display: block;
    margin-left: auto;
    margin-right: auto;
}
#logoImg {
    height: 60px;
}
#headingImg {
    height: 100px;
}
#headerDiv {
    margin-top: 0px;
    text-align: center;
    margin-bottom: 20px;
}
#bookDiv {
    height: 600px;
    width: 926px;
    margin-left: auto;
    margin-right: auto;
    position: relative;
    background-image: url("book2.png");
    background-repeat: no-repeat;
    background-size: contain;

    font-family: 'Charm', cursive;
    font-size: 18px;
    line-height: 1.5em;
}
#appendixDiv a {
    display: block;
}
#bookDiv a {
    text-decoration: none;
}
#bookDiv a:hover {
    font-weight: bold;
}
#bookDiv a:active, #bookDiv a:visited {
    color: black;
    text-decoration: none;
}
a, a:hover, a:active, a:visited {
    color: black;
}
.puzzleListWrapper {
    margin: 0px 20px;
}
.metaRow {
    font-weight: bold;
    margin-top: 10px;
}
#part1Div {
    position: absolute;
    top: 170px;
    left: 40px;
    width: 427px;
    bottom: 87px;
}
#part2Div {
    position: absolute;
    top: 278px;
    left: 474px;
    width: 417px;
    bottom: 87px;
}
#interactiveDiv {
    position: absolute;
    top: 168px;
    left: 474px;
    width: 417px;
    bottom: 87px;
}
#appendixDiv {
    position: absolute;
    top: 400px;
    left: 474px;
    width: 417px;
    bottom: 90px;
    text-align: center;
}
#bookImg {
    position: absolute;
    top: 0px;
    left: 0px;
    right: 0px;
    bottom: 0px;
    width: 100%;
    height: 100%;
}
#consoleDiv {
    background-color: #EFEEE8;
    width: 100%;
    font-family: 'Courier New', Courier, monospace;
    padding: 0px;
    margin-bottom: 40px;
    margin-left: auto;
    margin-right: auto;
    width: 800px;
}
#aptLogo {
    height: 80px;
    margin-left: 0px;
    vertical-align: bottom;
    margin-bottom: -10px;
}
#citadelLogo {
    height: 60px;
    vertical-align: bottom;
    margin-bottom: -6px;
}
#footerDiv {
    text-align: center;
    line-height:50px;
    font-family: Arial, Helvetica, sans-serif;
    font-weight: bold;
    margin-bottom: 50px;
}
a {
    color: black;
}