@import url('https://fonts.googleapis.com/css2?family=Luckiest+Guy');

:root {
  --link: #0097fe;
  --hover: #0070d6;
  --active: #ed8546;
  --active-hover: #d36629;
  --asu-maroon: #8c1d40;
  --button-blue: #bae5ff;
  --button-blue-hover: #9cdcff;
  --special-font: 'Luckiest Guy';
  --highlight-yellow: #fff597;
}

/* PRINT ONLY */
.print-only{
	display: none !important;
	}			

html{
	scroll-behavior: smooth;
	}

/* ZEROING OUT STYLES ------------------*/
*{
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	}
body, input, button, select, option, textarea {
		background-color: #fff;
    font-family: "Myriad Pro", Helvetica, Arial, "sans-serif";
    font-size: 1em;
    color: #000;
	}

/* LINKS -----------------------*/
a, a:link, a:visited, a:focus, .link{
	color: var( --link );
	text-decoration: none;
	cursor: pointer;
	}
a:hover, .link:hover{
	color: var( --hover );
	}
.red-link{
	color: #c90000;
	cursor: pointer;
	}
.red-link:hover{
	color: #ff0000;
	}

img {
  -webkit-touch-callout: none; /* iOS Safari */
    -webkit-user-select: none; /* Safari */
     -khtml-user-select: none; /* Konqueror HTML */
       -moz-user-select: none; /* Firefox */
        -ms-user-select: none; /* Internet Explorer/Edge */
            user-select: none; /* Non-prefixed version, currently
                                  supported by Chrome and Opera */
	}
div{
	font-size: 100%;
	}

hr.dotted{
	border: 0;
	border-top: dotted 2px #ccc;
	height: 0;
	margin: 2.5em 0 0 0; 
	}

h1{
	color: var( --asu-maroon );
	padding: .5em 0 .25em 0;
	margin: 0;
	line-height: 1.1em;
	font-size: 2.1em;
	}
h2 {
	font-size:  1.6em;
	font-weight: normal;
	padding: 1.5em 0 .5em 0;
	}	
h3 {
	font-size: 1.4em;
	font-weight: normal;
	padding: 1.5em 0 .5em 0;
	line-height:  1.2em;
	}
h4 {
	font-size: 1.2em;
	padding: .5em 0;
	font-weight: normal;
	}

p{
	padding: .75em 0;
	}
ul, ol{
	margin: .75em 0 .75em 1em;
	}	
li{
	padding: .15em 0;
	}

/* HOW TO PLAY PAGE, buttons */
dl{
	display: grid;
	grid-template-columns: 2em auto;
	grid-gap: .75em;
	align-items: center;
	padding: .5em 0;
	}

sup { line-height: 0; }

.no-select { pointer-events: none; }	

.hidden { display: none; }

.rounded-corners { border-radius: .5em; }

/* MAIN BUTTONS --------------------- */	
.button-wrapper{
	padding-top: 2em;
	text-align: center;
	}
.button-wrapper button{
	margin: .25em;
	}	
button {
    position: relative;
    display: inline-block;
    padding: .75em 1em;
    margin: .5em 0 .3em 0;
    background-color: var(--button-blue);
    border: none;
    border-radius: 0.5em;
    min-width: 9em;
    font-weight: bold;
    font-size: 100%;
    cursor: pointer;
    outline: none;
    }
button:hover{
	background-color: var(--button-blue-hover);
	}   
.full-width{
	width: 100%;
	}	
button.padded-top{
	margin-top: 2em;
	}

.split-button-wrapper {
	display: flex;
	}
.split-button-wrapper button{
	margin-top: 1em;
	}	
.split-button-wrapper button:nth-child(2){
	margin-left: auto;
	}			
.button-wrapper.left { text-align: left; }
.button-wrapper.right { text-align: right; }


/* OUTER WRAPPER --------------------- */
#outer-wrapper{} 

/* INNER WRAPPER --------------------- */
#inner-wrapper{
	margin: 4em 0 0 0;
	padding: 0 1em;
	}

/* INLINE MENU --------------------- */
ul.inline-menu {
	list-style-type: none;
	margin: 0;
	padding: 1em 0 0 0;
	}
ul.inline-menu li{
	display: inline;
	}
ul.inline-menu li:after{ 
	content: ' | ';
	color: #000;
	}
ul.inline-menu li:last-child:after{ 
	content: none;
	}
ul.inline-menu + p{
	padding-top: 2em;	
	}

/* HEADER --------------------- */
#header-wrapper {
	border-bottom: solid 2px #000;
	position: fixed;
	top: 0;
	width: 100%;
	margin: 0;
	padding: .25em .5em 0 .5em;
	background-color: #fff;
	z-index: 1000;
	}
#header-top-row{
	display: flex;
	align-items: center;
	}	

/* BREADCRUMBS ----------------*/ 
#breadcrumb{
	padding: .75em 0;
	display: inline-block;
	}
#home-crumb{
	font-weight: bold;
	}

/* GAME ICONS ----------------*/ 
#header-icon-wrapper{
	margin-left: auto;
	}
#header-icon-wrapper img{
	height: 1.7em;
	cursor: pointer;
	margin-right: .5em;
	}
#mute-icon, #sound-icon{
	display: none;
	}

/* RIGHT SIDE IMAGES ----------------*/ 
.img-right-wrapper{
	display: grid;
	}
.img-right-wrapper img.padded{
	padding: 1em;
  background-color: #fff;
	}	
.img-right-wrapper>div:first-child{ order:2 }
.img-right-wrapper>div:nth-child(2){ order:1 }	
.img-right-wrapper img{
	width: 100%;
	color: #939393;
	font-size: .9em;
	}
.img-right-wrapper.small>div:nth-child(2) {
	text-align: center;	
	width: 50%;
	margin: 0 auto;
	}
.img-right-wrapper.medium>div:nth-child(2)	{
	text-align: center;	
	width: 75%;
	margin: 0 auto;
	}		
/* center images */
.img-center-wrapper{
	text-align: center;
	}	 	
.img-center-wrapper img{
	text-align: center;
	width: 100%;
	}	 	

	

/* HOW TO PLAY PAGE ----------------*/ 
#how-to-play dl{
	display: grid;
	grid-template-columns: 2em auto;
	grid-gap: .75em;
	align-items: center;
	padding: .5em 0;
	}

/* HAMBURGER ICON ----------------*/ 
#hamburger-wrapper {
	display: inline-block;
	cursor: pointer;
	margin: 0 0 0 .5em;
	width: 1.5em;
	}
.bar-1, .bar-2, .bar-3 {
	height: .2em;
    background-color: #ccc;
    margin: .25em 0 .25em 0;
	transition: 0.4s;
	}
#hamburger-wrapper.open .bar-1 {
  -webkit-transform: rotate(45deg) translate(.3em, .3em);
  transform: rotate(45deg) translate(.35em, .35em)
	}
#hamburger-wrapper.open .bar-2 {
	opacity: 0;
	}
#hamburger-wrapper.open .bar-3 {
  -webkit-transform: rotate(-45deg) translate(.3em, -.3em);
  transform: rotate(-45deg) translate(.3em, -.3em);
	}

/* NAV ----------------*/ 
nav	{
	display: none;
	}
nav.open{
	display: block;
	}	
nav ul{
	margin: 0;
	padding: 0;
	list-style-type: none;
	}	
nav li{
	padding: .75em 0;
  border-top: 1px solid #ccc;
	}	
nav li.active a:link, nav li.active a:visited, nav li.active a:hover{
	color: #000;
	}
	

/* HOME WARNING BOX ------------- */ 
#home-warning button{
	background-color: #d4c9f0;
	margin-right: .5em;
	margin-top: 1em;
	}
#home-warning button:hover{
	background-color: #c9baee;	
	}
#sandbox-game #help-message>div{
	display: none;
	}	
#help-message .title{
	display: block;
	padding-bottom: .5em;
	font-weight: bold;
	}
	
/* TOP MESSAGE BOXES (HELP, POP UP FOR BREADCRUMB TO GET BACK TO MENU) ----------------- */ 
.top-message-wrapper{
	padding: 1em;
  border-radius: .5em;
	position: relative;
	background-color: #ebe5f9;
	margin-bottom: .25em;
	display: none;
	}
.top-message-wrapper .title{
	font-weight: bold;
	}
.top-message-wrapper p{
	padding: .25em 0;
	}			
.close-icon, .warning-close-icon{
	width: 2em;
  position: absolute;
  right: .75em;
  top: .75em;
  cursor: pointer;
	}
.top-message-wrapper.show{
	display: block;
	margin-top: .5em;
	margin-bottom: .5em;
	}

/* TOGGLE BOXES ---------------------------------- */
.toggle-box{
	margin-top: 1em;
	} 	
.toggle-box + .toggle-box{
	margin-top: 2em;
	}	
.toggle-title{
	background-color: #efefef;
	padding: 1em 1em;
	border-radius: .5em;
	cursor: pointer;
	color: var(--link);
	}
.toggle-title:hover{
	background-color: #ddd;
	color: var(--hover);
	}	
.toggle-box .arrow{
	background-image: url('../images/toggle-arrow-up.svg');
	background-repeat: no-repeat;
	background-position: right 1em center;
  background-size: 1.75rem;
	}	
.toggle-box .toggle-content-wrapper{
	padding: 1.5em 1em;
	display: none;
	border: solid 3px #efefef;
	border-top: none;
  border-radius: 0 0 0.5em 0.5em;
	}	
/* open toggle */
.toggle-box.show .toggle-title{ border-radius: .5em .5em 0 0; }
.toggle-box.show .arrow{ background-image: url('../images/toggle-arrow-down.svg'); }	
.toggle-box.show .toggle-content-wrapper{	display: block;}



/* CARD WRAPPER ---------------------------- */
.card-wrapper{
  background-color: #fff;
  box-shadow: 0 1px 6px 0 rgb(0 0 0 / 15%);
	padding: 1em 1.5em 2em 1.5em;
	}

/* BACK TO TOP ----------------------------- */
#back-to-top{
	position: fixed;
	width: 3em;
	height: 3em;
	background-color: rgba( 0, 0, 0, .4);
	right: 0;
	bottom: 0;
	border-radius: 50%;
	text-align: center;
	margin-right: 1em;
	margin-bottom: 2em;
	padding-top: 0;
	z-index: 500;
	cursor: pointer;
	transition: all 300ms ease-in-out;
	transform: rotate( 240deg) scale(0, 0);
	}	
#tri {
	width: 0;
  height: 0;
  border-left: 1em solid transparent;
  border-right: 1em solid transparent;
  border-bottom: 1.6em solid #fff;
  margin: auto;
  padding-top: .5em;
	}
#back-to-top.show{
	transform: scale(1, 1);
	transform: rotate(0deg);
	}

/* FOOTER --------------------- */
footer{
	border-top: solid 1px #ccc;
	padding: .5em 0 0 0;
	margin: 3em 0 4em 0;
	}
footer ul{
	list-style: none;
	padding: 0;
	margin: 0;
	}
footer li{
	display: inline;
	font-size: .9em;
	color: #aaa;
	}
footer li::after{
	content: ' | ';
	}	
footer li:last-child::after{
	content: '';
	}				
footer a:link, footer a:visited{
	color: #aaa;
	}		
footer a:hover{
	color: #888;
	}	
	
/* REMOVES BLUE HIGHLIGHT WHEN ELEMENT IS CLICKED --------------------- */
a:active, img:active, #back-to-top, .link:active, #main-icons>div a:active, #main-icons>div a:active > *, #choice-icons-wrapper > div, svg * {
	-webkit-touch-callout: none;
  -webkit-tap-highlight-color: transparent;
  outline: none;
	}	



/* PAGE SPECIFIC STYLES ---------------------------------------- */

.scientific{
	font-style: italic;
	}

/* HOME PAGE --------------------- */
#home-title{
	text-align: center;
	font-family: var(--special-font);
	font-weight: normal;
	font-size: 5em;
  line-height: .9em;
  margin: 0;
  padding: .5em .25em .25em .25em;
	}
.banner{
	padding: 1em 0.75em;
  background-color: #FFC627;
  color: #000;
  text-align: center;
  font-weight: bold;
  line-height: 1.1em;
	}
/* ICON GRID FOR HOME PAGE --------------------- */
#main-icons{
	margin: 2em 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
	text-align: center;
	grid-gap: 1em;
	}
#main-icons > div{
	width: 160px;
	}	
#main-icons img {
  max-width: 10em;
  display: block;
  margin: 0 auto .5em auto;
	}
#main-icons button{
	margin: .4em auto .75em auto;
	line-height: 1.1em;
	}


/* CHARACTER MESSAGES ----------------------- */

.character-message-wrapper{
	margin: 1em 0;
	}
.character-message-wrapper.bottom{
	margin-top: 3em;
	}	
.character-message-wrapper > img{
	display: block;
  width: 10rem;
  height: 10rem;
  border-radius: 50%;
  margin: 0 auto -5rem auto;
  position: relative;
  z-index: 100;
	}		
.character-message-wrapper > div{
	position: relative;
	padding: 6em 2em 1.5em 2em;
	border-radius: 1rem;
	border: 3px solid #ddd;
	width: 100%;
	}	
.section-links{
	font-weight: bold;
	}
.section-links a{
	display: block;
	margin: .5em 0;
	}	
.section-links a:last-child{
	margin: 0 0 0 auto;
	}	