:root {
	--light-purple-500: #D2A1B8;
	--mid-purple-500: #A74573;
}

.arrow {
	fill: var(--mid-purple-500);
}

body {
	font-size: 1em;
	font-family: monospace;
	overflow-x: 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;
	justify-content: space-around;
}

hr {
	border: 1px solid lightgrey;
}

.icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 15px;
	border: 1px solid var(--mid-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: 1px;
	font-size: 1em;
}

.instructions {
	display: flex;
	align-items: center;
	padding: 20px;
	font-size: 1.1em;
}

.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;
}

.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);
}