:root {
	--light-green-500: #9CEB89;
	--light-grey-500: #D3D3D3;
	--light-purple-500: #D2A1B8;
	--mid-purple-500: #A74573;
	--light-red-500: #FA8873;
}

.arrow {
	fill: var(--mid-purple-500);
}

body {
	font-size: 1em;
	font-family: monospace;
	overflow-x: hidden;
	overflow-y: hidden;
	touch-action: manipulation;
}

body, html {
	height: 100%;
}

.dialogue-copy-results {
	padding: 2px;
	margin-top: auto;
	margin-bottom: 50px;
	cursor: pointer;
	border: 2px solid transparent;
	border-radius: 1em;
}

.dialogue-copy-results:hover {
	border: 2px solid var(--mid-purple-500);
}

.dialogue-copy-results:active {
	color: white;
	background-color: var(--mid-purple-500);
	border: 2px solid var(--mid-purple-500);
}

.dialogue-completion-time, .emoji-text-variant {
	font-size: 2em;
	vertical-align: middle;
}

.emoji-text-variant {
  font-variant-emoji: text;
}

.enter-key {
	flex-grow: 100;
	align-items: center;
	border: 4px solid var(--mid-purple-500);
	border-radius: 5px;
	margin-right: 10px;
}

.erase-key {
	margin-left: auto;
	margin-right: auto;
	padding-top: 0px !important;
}

.flex-container {
	display: flex;
	justify-content: space-between;
	flex-flow: column;
	height: 100%;
	overflow-x: hidden;
	position: relative;
}

.header {
	display: flex;
	align-items: flex-start;
	justify-content: space-around;
}

.hints:hover {
	cursor: default;
}

.hints-button {
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 15px;
	border: 1px solid transparent;
	border-radius: 3px;
	background-color: transparent;
	color: var(--light-grey-500);
	padding-top: 1px;
	padding-bottom: 1px;
	padding-left: 4px;
	padding-right: 4px;
	margin: 1px;
	font-size: 1em;
}

.hints-button:hover {
	color: var(--mid-purple-500);
}

.hints-on-button-selected {
	background-color: var(--light-purple-500);
	border: 1px solid var(--light-purple-500);
	color: var(--mid-purple-500);
	cursor: default;
}

.hints-off-button-selected {
	background-color: var(--light-purple-500);
	border: 1px solid var(--light-purple-500);
	color: var(--mid-purple-500);
	cursor: default;
}

hr {
	border: 1px solid lightgrey;
}

.icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 15px;
	border: 1px solid var(--light-purple-500);
	border-radius: 3px;
	background-color: transparent;
	color: var(--mid-purple-500);
	padding-top: 1px;
	padding-bottom: 1px;
	padding-left: 4px;
	padding-right: 4px;
	margin: 2px;
	font-size: 1em;
}

.instructions {
	display: flex;
	align-items: center;
	margin: 10px;
	font-size: 1.1em;
	border: 1px solid var(--light-purple-500);
	border-radius: 15px;
	margin-bottom: 15px;
	padding: 10px 20px 10px 20px;
}

.instructions-header {
	color: var(--mid-purple-500);
	font-size: 1.3em;
	margin: .38em;
}

.instructions-section {
	border-top: 1px dashed var(--light-purple-500);
	display: flex;
	align-items: baseline;
	justify-content: space-between;
}

.keyboard-col {
	display: flex;
	flex-flow: column nowrap;
	gap: 2px;
}

.keyboard-col-letters {
	flex-grow: 10;
}

.keyboard-col-enter {
	flex-grow: 1.5;
}

.keyboard-row {
	display: flex;
	flex-flow: row nowrap;
	flex-grow: 1;
	gap: 6px;
	margin-top: 5px;
	margin-bottom: 5px;
}

.key {
	display: flex;
	border-radius: 10px;
	color: var(--mid-purple-500);
	flex-grow: 1;
	justify-content: center;
	touch-action: manipulation;
}

.key.invisikey {
	border : 1px solid transparent;
	flex-grow: 1;
}

.key.invisikey:hover {
	background-color: transparent;
	cursor: default;
	user-select: none;
}

.key.invisiHalfKey {
	border : 1px solid transparent;
	flex-grow: .5;
}

.key.invisikey, .key.invisiHalfKey {
	user-select: none;
}

.key-hover:hover {
	background-color: var(--light-purple-500);
	cursor: pointer;
}

.keyPressColor {
	background-color: var(--light-purple-500);
	transition-duration: 150ms;
	transition-timing-function: ease-out;
}

.onscreen-keyboard {
	display: flex;
	visibility: hidden;
	justify-content: center;
	font-size: 6em;
	gap: 2px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 50px;
	width: 95vw;
}

.title-block {
	display: flex;
	align-items: center;
	top: 0;
	left: 0;
	padding: 20px;
}

.title-block > p {
	padding-left: 10px;
	font-size: 2em;
	color: var(--mid-purple-500);
}

@keyframes reticule-flash {
	0%{stroke:#fa8873}
	100%{stroke:#9ceb89}
}

.reticule-flash {
	animation: reticule-flash .2s;
}

.rock-salt-regular {
 	font-family: "Rock Salt", cursive;
 	font-weight: 400;
 	font-style: normal;
}

.rotatable {
	rotate: 0deg;
	transform-origin: 50% 50%;
	transition-duration: 150ms;
}

p {
	margin: .5em;
}

.puzzle {
	display: flex;
	overflow-x: hidden;
	min-height: 600px;
	justify-content: center;
	align-items: center;
	font-size: 2.75em;
	touch-action: manipulation;
}

.svg-stack {
	position: absolute;
}

.win-dialogue {
	display: flex;
	position: absolute;
	visibility: hidden;
	justify-content: space-between;
	align-items: center;
	flex-flow: column;
	height: 300px;
	margin: auto;
	margin-top: 50px;
	font-size: .5em;
	color: var(--mid-purple-500);
}

