body {
    margin: 0;
    padding: 0;
    width: 100vw;
    height: 100vh;
    background-color: white;

    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}
div {
    background-color: rgba(255,255,255,0);
}

p {
    padding: 0 2px 0 2px;
    margin: 0;
}
br {
    display: block; /* makes it have a width */
    content: ""; /* clears default height */
    margin-top: 10px; /* change this to whatever height you want it */
}

br {
    display: block; /* makes it have a width */
    content: ""; /* clears default height */
    margin-top: 10px; /* change this to whatever height you want it */
}

.mainContainer {
    margin: 0;
    padding: 0;
    display: grid;
    width: 100%;
    height: 100%;
    grid-template-columns: 33% 33% 34%;
    grid-template-rows: 25% 25% 25% 25%;
    grid-template-areas: 
        "progression events upgrades"
        "progression events upgrades"
        "progression power inventory"
        "progression power inventory";
}

.mainPanel {
    border: 1px solid black;
    /*background-color: white;*/
    margin: 0;
    padding: 0;
}

.gridArea_power {
    grid-area: power;

    display: grid;
    grid-template-columns: 15% 35% 35% 15%;
    grid-template-rows: 15% 35% 35% 15%;
    grid-template-areas: 
        "miningStats miningStats miningStats miningStats"
        "drillLeft power power drillRight"
        "drillLeft power power drillRight"
        "drillDown drillDown drillDown drillDown";
}
.drillDirectionButton {
    cursor: pointer;
}

.gridArea_events {
    grid-area: events;
}

.gridArea_people {
    grid-area: people;
}

.gridArea_discoveries {
    grid-area: discoveries;
}

.gridArea_upgrades {
    grid-area: upgrades;
}
.gridArea_progression {
    grid-area: progression;
    display: flex;
    flex-direction: column;
}
.levelSelection {
    flex-grow: 1;
    display: flex;
    flex-direction: row;
}
.levelSelectionTip {
    padding: 5px;
    border: 1px solid gray;
}

.scoreDisplay {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    white-space: pre;
    padding: 5px;
}

.nonInteractable {
    pointer-events: none;
}

.powerContainer {
    margin: 0;
    padding: 0;
    display: grid;
    width: 100%;
    height: 100%;
    grid-template-columns: 33% 33% 33%;
    grid-template-rows: 25% 25% 25% 25%;
    grid-template-areas: 
        "people events upgrades"
        "people events upgrades"
        "discoveries power upgrades"
        "discoveries power consumables";
}

#powerTrigger {
    width:100%;
    height: 100%;
    border: 2px solid black;

    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;

    white-space: pre;
    cursor: pointer;
    background-color: rgb(218, 218, 218);
    opacity: 0.5;
}
#powerTrigger:hover {
    background-color: white;
}
#powerTrigger p br {
    margin-top: 0;
}

.shake_low {
    transform-origin: 50% 50%;
    animation: shake_low 0.25s;
    animation-iteration-count: infinite;
}

.shake_med {
    transform-origin: 50% 50%;
    animation: shake_med 0.15s;
    animation-iteration-count: infinite;
}

.shake_high {
    transform-origin: 50% 50%;
    animation: shake_high 0.1s;
    animation-iteration-count: infinite;
}

@keyframes shake_low {
  0% { transform: translate(2px, 2px) rotate(-0.5deg); }
  25% { transform: translate(0px, -2px) rotate(0.5deg); }
  50% { transform: translate(-2px, 2px) rotate(-0.5deg); }
  75% { transform: translate(2px, -2px) rotate(0.5deg); }
  100% { transform: translate(2px, 2px) rotate(-0.5deg); }
}

@keyframes shake_med {
  0% { transform: translate(4px, 4px) rotate(-1deg); }
  25% { transform: translate(0px, -4px) rotate(1deg); }
  50% { transform: translate(-4px, 4px) rotate(-1deg); }
  75% { transform: translate(4px, -4px) rotate(1deg); }
  100% { transform: translate(4px, 4px) rotate(-1deg); }
}

@keyframes shake_high {
  0% { transform: translate(8px, 8px) rotate(-2deg); }
  25% { transform: translate(0px, -8px) rotate(2deg); }
  50% { transform: translate(-8px, 8px) rotate(-2deg); }
  75% { transform: translate(8px, -8px) rotate(2deg); }
  100% { transform: translate(8px, 8px) rotate(-2deg); }
}

#resourcesPanel {
    width: 100%;
    height: 15%;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
}
.resourceContainer {
    flex-basis: 100%;
    padding: 5px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    border: 2px solid darkorange;
}
.resourceType {
    font-size: 100%;
}
.resourceValue {
    font-size: 100%;
}

#upgradesPanel {
    width: 100%;
    height: 90%;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}
.upgradeSlot {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    border: 2px solid darkgreen;
    min-height: 75px;
    align-items: stretch;
}
.upgradeIcon {
    border: 1px solid black;
    width: 75px;
    height: auto;
    text-align: center;
    padding: 5px 5px 5px 5px;
    box-sizing: border-box;

    display: flex;
    justify-content: center;
    align-items: center;
}

.upgradeDescription {
    display: flex;
    flex-grow: 1;
    flex-direction: column;
    justify-content: space-between;
    border: 1px solid black;
    padding: 5px 5px 5px 5px;
}
.upgradeBuyButton {
    width: 50px;
    height: 100%;
    background-color: rgb(153, 255, 153);
}
.upgradeBuyButton:hover {background-color: rgb(226, 255, 209); cursor: pointer;}
/*.upgradeBuyButton:focus {background-color: rgb(125, 197, 141);}*/

.upgradeTooltip {
    display: none;

    position: absolute;
    z-index: 10;
    width: 400px;
    right: 0px;
    background: lightgreen;
}
.upgradeCostTooltip {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    border: 1px solid black;
    padding: 0px 2px 0px 2px;
}
.upgradeResourceCost {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    border: 1px dashed black;
}

.upgradeBuyButton:hover ~ .upgradeTooltip {
    display: block;
}

#powerTriggerContainer {
    grid-area: power;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    height: 100%;
}

.levelSelectionContainer {
    width: 50px;
    height: 100%;
    background-color: rgb(190, 213, 255);

    
}
.levelSelectionSlider { 
    position: relative;
    margin: 0 5px;
    width: 40px;
    height: 100%;

    cursor: pointer;

    -webkit-appearance: slider-vertical;
    writing-mode: bt-lr;
    transform: rotate(180deg);
}



.anim_levelDrilled {
    animation: blink_green 0.1s linear 1;
}
.anim_blinkGreen {
    animation: blink_green 0.1s linear 1;
}

@keyframes blink_red {
  0% { background-color: red; }
}

@keyframes blink_blue {
  0% { background-color: blue; }
}

@keyframes blink_green {
  0% { background-color: lightgreen; }
}

.highlight_green {
    background-color: lightgreen;
}

#eventPanel {
    position: relative;
}
.alertMessageContainer {
    position: absolute;
    width: 70%;
    height: 50%;
    z-index: 10;
    top:-100%;
    left: 15%;

    margin:0;
    padding:0;

    border: 2px solid black;
    background-color: rgb(255, 173, 141);
}
.alertMessage {
    white-space: pre-wrap;
    padding: 10px;
    font-size: 1.5em;
}
.alertDismissContainer {
    position: absolute;
    width: auto;
    height: auto;
    bottom: 0;
    right:0;
    padding:10px;
}
.alertDismissButton {
    padding: 5px 10px;
    font-size: 1.25em;
}
.anim_topIn {
    animation: topIn 0.25s ease-in-out 1;
    opacity: 255;
    top:0%;
}
.anim_topOut {
    animation: topOut 0.25s ease-in-out 1;
    opacity: 0;
    top:-100%;
}

@keyframes topIn {
  0% { top:-100%; opacity: 0; }
  100% { top:0%; opacity: 255; }
}
@keyframes topOut {
  0% { top:0%; opacity: 255; }
  100% { top:-100%; opacity: 0;}
}



#levelAreasContainer {
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;

    height: 100%;
    width: 100%;
    margin: 0 auto 0 0;
    padding: 6px 0 6px 0;
}
.levelArea {
    display: flex;
    flex-direction: row;
    align-items: center;
    border-left: 0;
    width: 100%;
}
.levelAreaBounds {
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;

    height: 100%;
    width: 40px;
    border: 1px dashed red;
    border-left: 0;
}
.occupiedLevelArea  .levelAreaBounds {
    border: 2px solid blue;
    border-left: 0;
}
.levelAreaName {
    padding: 0 5px 0 5px;
    margin: 0 0 0 10px;
    font-size: 1.2em;
}
.unlockedLevelAreaName {
    border: 0.5px solid black;
    background-color: rgb(153, 255, 153);
}
.unlockedLevelAreaName:hover {background-color: rgb(226, 255, 209);}

.levelAreaTooltipContainer {
    flex-grow: 1;
    position: relative;
    height: 100%;

    display: flex;
    align-items: center;
}
.levelAreaTooltip {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    border: 1px solid black;

    position: absolute;
    z-index: 10;
    width: 400px;
    background: lightgreen;
}
.levelAreaTooltip p {
    padding: 2px 6px 2px 6px;
    margin: 0;
}
.levelAreaName ~ .levelAreaTooltipContainer {
    display: none;
}
.unlockedLevelAreaName ~ .levelAreaTooltipContainer {
    display: none;
}
.unlockedLevelAreaName:hover ~ .levelAreaTooltipContainer {
    display: flex;
}



.gridArea_inventory {
    grid-area: inventory;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.inventoryNavigationBar {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-content: stretch;
    align-items: stretch;
}
.inventoryTab {
    height: auto;
    flex-grow: 1;

    font-size: 1.2em;
    border: 1px solid black;
    background-color: rgb(200, 200, 200);

    text-align: left;
}
.inventoryTab:hover {
    background-color: rgb(226, 226, 226);
    cursor: pointer;
}
.inventoryTab.selected {
    background-color: lightskyblue;
}
.inventoryTab p {
    padding: 5px 5px;
}



.inventoryScrollList {
    overflow-y: scroll;
    overflow-x: hidden;
    flex-grow: 1;
    width: auto;
    display: none;
}
.inventoryScrollList.selected {
    display: block;
}
.inventorySlot {
    height: 50px;
    width: auto;
    border: 1px solid black;
    background-color: rgb(240, 240, 240);

    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
}
.inventorySlot:hover {
    background-color: white;
    cursor: pointer;
}
.inventorySlot.selected {
    background-color: lightskyblue;
}
.inventorySlotName {
    font-size: 1.5em;
}
.inventorySlotName p {
    padding: 10px;
}
.inventorySlotAmount {
    font-size: 1.25em;
}
.inventorySlotAmount p {
    padding: 10px;
}



.eventMessageContainer {
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    width: 100%;
    height: 100%;

    display: flex;
    flex-direction: column;

    background-color: rgb(255, 243, 173);
    border: 2px solid rgb(194, 181, 111);
}
.eventMessageName {
    padding: 20px 20px;
    font-size: 2em;
    border-bottom: 2px solid rgb(194, 181, 111);
}
.eventMessageDescription {
    padding: 20px 20px;
    flex-grow: 1;
    font-size: 1.25em;
    white-space: wrap;
}

.hidden {
    display: none;
}

