* {
	margin: 0;
	padding: 0;
	font-size: 100%;
	line-height: 1.3;
	font-family: "Noto Sans JP", sans-serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
}
html {
	background-color: #999;
	color: #fff;
	height: 100%;
}
body {
	padding: 40px;
}
body:target {
	padding: 0;
	z-index: 0;
}
#main-frame {
	width: 700px;
	margin: 0 auto;
	background-color: #000;
	border-radius: 10px;
	padding: 10px 100px;
	position: relative;
	z-index: 9999;
}
h1 {
	font-size: 24px;
	text-align: center;
	color: #933;
	padding: 7px;
	cursor: grab;
}
body:target h1 {
	cursor: auto;
}
#sample-text {
	margin: 10px 0 0;
	width: 100%;
	font-size: 32px;
	color: #999;
	height: 95px;
}
#input-text {
	width: 100%;
	height: 87px;
	overflow-y: hidden;
	font-size: 32px;
	background-color: transparent;
	color: #fff;
	border: none;
	border-bottom: 1px solid #333;
	outline: none;
}
#input-text::placeholder {
	color: #333;
}
#footer {
	width: 100%;
	margin: 20px auto;
	text-align: center;
	color: #333;
}
#footer a {
	color: #333;
}
#sample-text span.correct {
	color: #fff;
}
#sample-text span.incorrect {
	text-decoration: wavy underline 2px #933;
}
#sample-text span.current {
	text-decoration: underline 2px #0f0;
}
#footer-left {
	float: left;
	color: #999;
	width: 160px;
	text-align: left;
}
#total {
	cursor: pointer;
}
#speed {
	cursor: pointer;
	display: none;
}
#footer-right {
	float: right;
	text-align: right;
	width: 160px;
	color: #999;
}
#clock {
	cursor: pointer;
}
#stopwatch {
	display: none;
	cursor: pointer;
}
#popup {
	width: 10px;
	margin-right: 20px;
	position: absolute;
	right: 0px;
	cursor: pointer;
	color: #999;
}
body:target #popup {
	display: none;
}
#behind {
	position: fixed;
	width: 100%;
	top: 0;
	left: 0;
	z-index: 10;
}
#config {
	width: 700px;
	padding: 20px 100px 10px;;
	margin: 40px auto;
}
#config-color {
	height: 70px;
}
#color-buttons button {
	width: 40px;
	height: 40px;
	vertical-align: middle;
	margin: 0 0 10px 10px;
	border-radius:50%
}
#color-buttons button.current:after {
	content: "📍";
	position: relative;
	top: -6px;
	left: 0;
}
#color-buttons button:hover {
	filter: brightness(1.5);
}
#color-default {
	border: 3px solid #999;
	background-color: #000;
}
#color-red {
	border: 3px solid #600;
	background-color: #900;
}
#color-green {
	border: 3px solid #060;
	background-color: #090;
}
#color-blue {
	border: 3px solid #006;
	background-color: #009;
}
#color-orange {
	border: 3px solid #f80;
	background-color: #ffa500;
}
#color-purple {
	border: 3px solid #808;
	background-color: #a0a;
}
#color-sky-blue {
	border: 3px solid #9df;
	background-color: #6cf;
}
#color-matcha {
	border: 3px solid #dd9;
	background-color: #c4c46a;
}
#color-pink {
	border: 3px solid #ffeaea;
	background-color: #ffd6d6;
}
#color-yellow {
	border: 3px solid #ffc;
	background-color: #ff6;
}
#color-white {
	border: 3px solid #efefef;
	background-color: #fff;
}
#skip-text {
	position: absolute;
	top: 140px;
	right:75px;
	cursor: pointer;
	color: #999;
}
#copyright {
	text-align: center;
}
#copyright a {
	color: #b0b0b0;
}

/************************************************
 * Red
 ***********************************************/
html.red {
	background-color: #600;
}
html.red #main-frame {
	background-color: #900;
}
html.red h1 {
	color: #fc0;
}
html.red #sample-text,
html.red #footer-left,
html.red #footer-right,
html.red #skip-text,
html.red #popup {
	color: #daa;
}
html.red #input-text,
html.red #sample-text span.correct {
	color: #fff;
}
html.red #input-text::placeholder,
html.red #footer,
html.red #footer a {
	color: #a66;
}
html.red #input-text {
	border-bottom-color: #a66;
}
html.red #sample-text span.incorrect {
	text-decoration: wavy underline 2px #f00;
}
html.red #sample-text span.current {
	text-decoration: underline 2px #0f0;
}

/************************************************
 * Green
 ***********************************************/
html.green {
	background-color: #060;
}
html.green #main-frame {
	background-color: #090;
}
html.green h1 {
	color: #cf0;
}
html.green #sample-text,
html.green #footer-left,
html.green #footer-right,
html.green #skip-text,
html.green #popup {
	color: #ada;
}
html.green #input-text,
html.green #sample-text span.correct {
	color: #fff;
}
html.green #input-text::placeholder,
html.green #footer,
html.green #footer a {
	color: #6a6;
}
html.green #input-text {
	border-bottom-color: #6a6;
}
html.green #sample-text span.incorrect {
	text-decoration: wavy underline 2px #f00;
}
html.green #sample-text span.current {
	text-decoration: underline 2px #0f0;
}

/************************************************
 * Blue
 ***********************************************/
html.blue {
	background-color: #006;
}
html.blue #main-frame {
	background-color: #009;
}
html.blue h1 {
	color: #fc0;
}
html.blue #sample-text,
html.blue #footer-left,
html.blue #footer-right,
html.blue #skip-text,
html.blue #popup {
	color: #99c;
}
html.blue #input-text,
html.blue #sample-text span.correct {
	color: #fff;
}
html.blue #input-text::placeholder,
html.blue #footer,
html.blue #footer a {
	color: #66a;
}
html.blue #input-text {
	border-bottom-color: #66a;
}
html.blue #sample-text span.incorrect {
	text-decoration: wavy underline 2px #f00;
}
html.blue #sample-text span.current {
	text-decoration: underline 2px #0f0;
}

/************************************************
 * Orange
 ***********************************************/
html.orange {
	background-color: #f80;
}
html.orange #main-frame {
	background-color: #ffa500;
}
html.orange h1 {
	color: #e00;
}
html.orange #sample-text,
html.orange #footer-left,
html.orange #footer-right,
html.orange #skip-text,
html.orange #popup {
	color: #c60;
}
html.orange #input-text,
html.orange #sample-text span.correct {
	color: #930;
}
html.orange #input-text::placeholder,
html.orange #footer,
html.orange #footer a {
	color: #e82;
}
html.orange #input-text {
	border-bottom-color: #e82;
}
html.orange #sample-text span.incorrect {
	text-decoration: wavy underline 2px #f00;
}
html.orange #sample-text span.current {
	text-decoration: underline 2px #0f0;
}

/************************************************
 * Purple
 ***********************************************/
html.purple {
	background-color: #808;
}
html.purple #main-frame {
	background-color: #a0a;
}
html.purple h1 {
	color: #fc0;
}
html.purple #sample-text,
html.purple #footer-left,
html.purple #footer-right,
html.purple #skip-text,
html.purple #popup {
	color: #eae;
}
html.purple #input-text,
html.purple #sample-text span.correct {
	color: #fff;
}
html.purple #input-text::placeholder,
html.purple #footer,
html.purple #footer a {
	color: #d6d;
}
html.purple #input-text {
	border-bottom-color: #d6d;
}
html.purple #sample-text span.incorrect {
	text-decoration: wavy underline 2px #f00;
}
html.purple #sample-text span.current {
	text-decoration: underline 2px #0f0;
}

/************************************************
 * Sky-blue
 ***********************************************/
html.sky-blue {
	background-color: #9df;
}
html.sky-blue #main-frame {
	background-color: #6cf;
}
html.sky-blue h1 {
	color: #03c;
}
html.sky-blue #sample-text,
html.sky-blue #footer-left,
html.sky-blue #footer-right,
html.sky-blue #skip-text,
html.sky-blue #popup {
	color: #bbf0ff;
}
html.sky-blue #input-text,
html.sky-blue #sample-text span.correct {
	color: #fff;
}
html.sky-blue #input-text::placeholder,
html.sky-blue #footer,
html.sky-blue #footer a {
	color: #adf;
}
html.sky-blue #input-text {
	border-bottom-color: #adf;
}
html.sky-blue #sample-text span.incorrect {
	text-decoration: wavy underline 2px #f00;
}
html.sky-blue #sample-text span.current {
	text-decoration: underline 2px #0f0;
}

/************************************************
 * Matcha
 ***********************************************/
html.matcha {
	background-color: #dd9;
}
html.matcha #main-frame {
	background-color: #c4c46a;
}
html.matcha h1 {
	color: #440;
}
html.matcha #sample-text,
html.matcha #footer-left,
html.matcha #footer-right,
html.matcha #skip-text,
html.matcha #popup {
	color: #880;
}
html.matcha #input-text,
html.matcha #sample-text span.correct {
	color: #5f5f00;
}
html.matcha #input-text::placeholder,
html.matcha #footer,
html.matcha #footer a {
	color: #aa3;
}
html.matcha #input-text {
	border-bottom-color: #aa3;
}
html.matcha #sample-text span.incorrect {
	text-decoration: wavy underline 2px #f00;
}
html.matcha #sample-text span.current {
	text-decoration: underline 2px #0f0;
}
 
/************************************************
 * Pink
 ***********************************************/
html.pink {
	background-color: #ffeaea;
}
html.pink #main-frame {
	background-color: #ffd6d6;
}
html.pink h1 {
	color: #800;
}
html.pink #sample-text,
html.pink #footer-left,
html.pink #footer-right,
html.pink #skip-text,
html.pink #popup {
	color: #f88;
}
html.pink #input-text,
html.pink #sample-text span.correct {
	color: #e33;
}
html.pink #input-text::placeholder,
html.pink #footer,
html.pink #footer a {
	color: #fbb;
}
html.pink #input-text {
	border-bottom-color: #fbb;
}
html.pink #sample-text span.incorrect {
	text-decoration: wavy underline 2px #393;
}
html.pink #sample-text span.current {
	text-decoration: underline 2px #0f0;
}
 
/************************************************
 * Yellow
 ***********************************************/
html.yellow {
	background-color: #ffc;
}
html.yellow #main-frame {
	background-color: #ff6;
}
html.yellow h1 {
	color: #e60;
}
html.yellow #sample-text,
html.yellow #footer-left,
html.yellow #footer-right,
html.yellow #skip-text,
html.yellow #popup {
	color: #bb5;
}
html.yellow #input-text,
html.yellow #sample-text span.correct {
	color: #771;
}
html.yellow #input-text::placeholder,
html.yellow #footer,
html.yellow #footer a {
	color: #dd7;
}
html.yellow #input-text {
	border-bottom-color: #dd7;
}
html.yellow #sample-text span.incorrect {
	text-decoration: wavy underline 2px #960;
}
html.yellow #sample-text span.current {
	text-decoration: underline 2px #0f0;
}

/************************************************
 * White
 ***********************************************/
html.white {
	background-color: #efefef;
}
html.white #main-frame {
	background-color: #fff;
}
html.white h1 {
	color: #366;
}
html.white #sample-text,
html.white #footer-left,
html.white #footer-right,
html.white #skip-text,
html.white #popup {
	color: #abb;
}
html.white #input-text,
html.white #sample-text span.correct {
	color: #588;
}
html.white #input-text::placeholder,
html.white #footer,
html.white #footer a {
	color: #ddd;
}
html.white #input-text {
	border-bottom-color: #ddd;
}
html.white #sample-text span.incorrect {
	text-decoration: wavy underline 2px #c60;
}
html.white #sample-text span.current {
	text-decoration: underline 2px #0f0;
}
