/* latin */
@font-face {
  font-family: 'Arvo';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('arvo-regular.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
	font-family: 'Arvo';
	font-style: normal;
	font-weight: 700;
	font-display: swap;
	src: url('arvo-bold.woff2') format('woff2');
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
html, body {
	width: 100%;
	height: 100%;
	margin: 0;
}
body {
	font-family: Arvo, system-ui, sans-serif;
	font-weight: 700;
	color: #000;
	background: #fff;
}
#container {
	display: contents;
}

#mindmap {
	display: flex;
	flex-direction: row;
	justify-content: center;
	align-items: center;
	position: relative;
	top: 50%;
	transform: translate(0,-50%);
	z-index: 1
}
#mindmap > div {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	margin: 0 2em;
}
#mindmap > div > div {
	display: flex;
	flex-direction: row;
	margin-bottom: 2em;
	justify-content: center;
	align-items: center;
}
#mindmap > div > div:last-child {
	margin-bottom: 0;
}
#mindmap > div#mm_left > div {
	flex-direction: row-reverse;
	justify-content: right;
}
#mindmap > div#mm_right > div {
	justify-content: left;
}
#mindmap > div#mm_left > div > .title {
	margin: 0 1em 0 1.5em;
}
#mindmap > div#mm_right > div > .title {
	margin: 0 1.5em 0 1em;
}
#mindmap > div > div > div > div > .title {
	margin-top: 1em;
}
#mm_middle {
	text-align: center;
}
#mm_left {
	text-align: right;
}
#mm_right {
	text-align: left;
}

#mindmap .title span {
	border-bottom: 3px solid #fff;
}
#mindmap #mm_1 .title span {
	border-color: #fb3e04;
}
#mindmap #mm_2 .title span {
	border-color: #fd0724;
}
#mindmap #mm_3 .title span {
	border-color: #de0263;
}
#mindmap #mm_4 .title span {
	border-color: #0f7ed0;
}
#mindmap #mm_5 .title span {
	border-color: #655fac;
}
#mindmap #mm_6 .title span {
	border-color: #a904bf;
}
#mindmap > div#mm_left > div > .title span {
	padding: 0 4em 0 1.5em;
}
#mindmap > div#mm_right > div > .title span {
	padding: 0 1.5em 0 4em;
}
#mindmap > div > div > div > div > .title span {
/*	cursor: pointer;*/
}
#mindmap > div#mm_left > div > div > div > .title span {
	padding: 0 1.2em 0 0.3em;
}
#mindmap > div#mm_right > div > div > div > .title span {
	padding: 0 0.3em 0 1.2em;
}
#mindmap .title {
	font-size: 1em;
}
#mindmap > div > div > .title {
	font-size: 1.5em;
}
#mindmap > div#mm_middle > div > .title {
	font-size: 1em;
}
#mm_0_title {
	position: relative;
}
#mm_0_title > span {
	opacity: 0;
}
#title_overlay {
	position: fixed;
	left: 50%;
	top: 50%;
	transform: translate(-50%,-50%);
	padding: 0.5em 0.5em;
	margin-top: 0.1em;
	font-size: 2.5em;
	background: #eee;
	color: #000;
	z-index: 2;
	min-height: 0;
	min-width: 0;
	transition: min-height 0.5s ease, min-width 0.5s ease-out, font-size 0.5s;
}
#mindmap .title #title_overlay > span.root {
	border-bottom: none;
}
/*#mindmap .title #title_overlay > span.root {
	border-bottom: none;
	opacity: 1;
	padding-left: 0;
}
/*#mm_middle #title_overlay.stage {
	min-height: 100%;
	min-width: 90%;
	font-size: 2em;
	transition: min-height 0.5s ease, min-width 0.5s ease-out, font-size 0.5s;
	text-align: left;
}
#mindmap #title_overlay.stage > span {
	padding-left: 20px;
	border: none;
}
#title_overlay .stage_title {
	position: absolute;
	left: 0;
}
#title_overlay .stage_title > span {
	border-bottom: none;
    opacity: 0;
	color:#fff;
    transition: 1.5s;
}
#title_overlay.stage .stage_title > span {
    opacity: 1;
	color:#f00;
    transition: 1.5s;
}
#title_overlay .stage_title > .root {
	visibility: hidden;
}
*/
svg {
	position: absolute;
	z-index: -1;
}
.effect svg {
	z-index: 1;
}
.path {
	stroke: #ffffff;
	fill: none;
	stroke-width: 3;
}
.mm1_path {
	stroke: #CA5835;
}
.mm2_path {
	stroke: #C34150;
}
.mm3_path {
	stroke: #A23E6A;
}
.mm4_path {
	stroke: #0B5D99;
}
.mm5_path {
	stroke: #534E96;
}
.mm6_path {
	stroke: #7B4083;
}

::selection {
	background-color: #000;
	color: #fff;
}
img {
	user-select: none;
}
#mindmap #mm_1 .title span::selection {
	background-color: #fb3e04;
}
#mindmap #mm_2 .title span::selection {
	background-color: #fd0724;
}
#mindmap #mm_3 .title span::selection {
	background-color: #de0263;
}
#mindmap #mm_4 .title span::selection {
	background-color: #0f7ed0;
}
#mindmap #mm_5 .title span::selection {
	background-color: #655fac;
}
#mindmap #mm_6 .title span::selection {
	background-color: #a904bf;
}

#thowi-t {
	position: fixed;
	top: 30px;
	left: 30px;
	cursor: pointer;
    animation: rotation 3s infinite ease;
	z-index: 10;
	width: 32px;
	height: 32px;
}
#thowi-t:hover {
	animation-play-state: paused;
	opacity: 1;
}
@keyframes rotation {
    from {
        transform: rotatey(0deg);
    }
    to {
        transform: rotatey(180deg);
    }
}
#toggle {
	position: fixed;
	top: 30px;
	right: 30px;
	z-index: 10;
	cursor: pointer;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	overflow: hidden;
	border: 2px solid #999;
	background-image: url('./light.svg');
	background-size: 16px 16px;
	background-repeat: no-repeat;
	background-position: center center;
}

#footer {
	position: fixed;
	bottom: 1em;
	left: 50%;
	transform: translate(-50%,0);
	z-index: 2;
}
#footer a {
	color: inherit;
}

@media screen and (min-width: 1300px) {
	#mindmap .title {
		font-size: 1.2em;
	}
	#mindmap > div > div > .title {
		font-size: 1.7em;
	}
	#mindmap > div > div > div > div > .title {
		margin-top: 0.7em;
	}
}
@media screen and (min-width: 1500px) {
	#mindmap .title {
		font-size: 1.5em;
	}
	#mindmap > div > div > .title {
		font-size: 2em;
	}
	#mindmap > div > div > div > div > .title {
		margin-top: 0.6em;
	}
}
@media screen and (max-width: 1299px) {
	#mindmap > div#mm_left > div > .title span {
		padding: 0 2em 0 1em;
	}
	#mindmap > div#mm_right > div > .title span {
		padding: 0 1em 0 2em;
	}
	#mindmap > div#mm_left > div > div > div > .title span {
		padding: 0 1em 0 0;
	}
	#mindmap > div#mm_right > div > div > div > .title span {
		padding: 0 0 0 1em;
	}
	#mindmap .title {
		font-size: 0.9em;
	}
	#mindmap > div > div > .title {
		font-size: 1.2em;
	}
	#mindmap > div#mm_middle > div > .title {
		font-size: 0.9em;
	}
	#title_overlay {
		font-size: 2em;
	}
}
@media screen and (max-width: 1199px) {
	#mindmap > div#mm_left > div > .title span {
		padding: 0 1em 0 1em;
	}
	#mindmap > div#mm_right > div > .title span {
		padding: 0 1em 0 1em;
	}
	#mindmap > div#mm_left > div > .title {
		margin: 0 0.5em 0 1em;
	}
	#mindmap > div#mm_right > div > .title {
		margin: 0 1em 0 0.5em;
	}
	#mindmap > div > div > div > div > .title {
		margin-top: 0.7em;
	}
	#mindmap .title {
		font-size: 0.8em;
	}
	#mindmap > div > div > .title {
		font-size: 1em;
	}
	#mindmap > div#mm_middle > div > .title {
		font-size: 0.8em;
	}
	#title_overlay {
		padding: 0.3em 0.3em;
		font-size: 1.5em;
	}
}
@media screen and (max-width: 899px) {
	body {
		font-weight: 400;
	}
	#mindmap .title span {
		border-bottom: 2px solid;
	}
	#mindmap > div {
		margin: 0 1em;
	}
	#mindmap > div > div {
		margin-bottom: 1em;
	}
	#mindmap > div > div > .title {
		font-size: 0.8em;
	}
	#mindmap > div#mm_middle > div > .title {
		font-size: 0.5em;
	}
	#title_overlay {
		font-size: 1.8em;
	}
	.path {
		stroke-width: 2;
	}
}
@media screen and (max-width: 699px) {
	#mindmap > div#mm_left > div > .title span {
		padding: 0 0.5em 0 1em;
	}
	#mindmap > div#mm_right > div > .title span {
		padding: 0 1em 0 0.5em;
	}
	#mindmap > div {
		margin: 0;
	}
	#mindmap > div#mm_middle {
		display: none;
	}
	.mm_lvl1_path {
		display: none;
	}
}
@media screen and (max-width: 699px) {
	body {
		overflow: hidden;
	}
	#container {
		position: absolute;
		left: 0;
		top: 0;
		width: 100%;
		height: 100%;
		overflow-x: scroll;
		display: block;
	}
	#mindmap {
		flex-direction: column;
		top: 50px;
		transform: none;
		padding-bottom: 60px;
	}
	#mindmap > div > div:last-child {
		margin-bottom: 1em;
	}
	#mindmap > div#mm_left > div {
		flex-direction: row;
		justify-content: left;
	}
	#mindmap > div#mm_left > div > .title {
		margin: 0 1em 0 0.5em;
	}
	#mm_left {
		text-align: left;
	}
	#mindmap > div > div > .title span {
		min-width: 70px;
		display: block;
	}
	#mindmap > div#mm_left > div > .title span {
		padding: 0 1em 0 0.5em;
	}
	#mindmap > div#mm_left > div > div > div > .title span {
		padding: 0 0 0 1em;
	}
	#footer {
		background-color: inherit;
		width: 100%;
		left: 0;
		text-align: center;
		transform: none;
		position: relative;
		padding-top: 20px;
	}
}

body.dark {color: #eee; background: #111;}
.dark #mindmap #mm_1 .title span {border-color: #CA5835;}
.dark #mindmap #mm_2 .title span {border-color: #C34150;}
.dark #mindmap #mm_3 .title span {border-color: #A23E6A;}
.dark #mindmap #mm_4 .title span {border-color: #0B5D99;}
.dark #mindmap #mm_5 .title span {border-color: #534E96;}
.dark #mindmap #mm_6 .title span {border-color: #7B4083;}
.dark #title_overlay {background: #111; color: #eee; box-shadow: 0 0 10px #fff;}
.dark.effect #title_overlay {background: #222;}
.dark .mm1_path {stroke: #CA5835;}
.dark .mm2_path {stroke: #C34150;}
.dark .mm3_path {stroke: #A23E6A;}
.dark .mm4_path {stroke: #0B5D99;}
.dark .mm5_path {stroke: #534E96;}
.dark .mm6_path {stroke: #7B4083;}
.dark ::selection {background-color: #fff; color: #000;}
.dark .title span::selection {color: #fff;}
.dark .title span.root::selection {background-color: #fff; color: #000;}
/*.dark #mindmap #mm_1 .title span::selection {background-color: #CA5835;}
.dark #mindmap #mm_2 .title span::selection {background-color: #C34150;}
.dark #mindmap #mm_3 .title span::selection {background-color: #A23E6A;}
.dark #mindmap #mm_4 .title span::selection {background-color: #0B5D99;}
.dark #mindmap #mm_5 .title span::selection {background-color: #534E96;}
.dark #mindmap #mm_6 .title span::selection {background-color: #7B4083;}*/
.dark #toggle {background-image: url('./dark.svg');}

body.light {color: #000; background: #fff;}
.light #mindmap #mm_1 .title span {border-color: #fb3e04;}
.light #mindmap #mm_2 .title span {border-color: #fd0724;}
.light #mindmap #mm_3 .title span {border-color: #de0263;}
.light #mindmap #mm_4 .title span {border-color: #0f7ed0;}
.light #mindmap #mm_5 .title span {border-color: #655fac;}
.light #mindmap #mm_6 .title span {border-color: #a904bf;}
.light #title_overlay {background: #fff; color: #000; box-shadow: 0 0 10px #000;}
.light.effect #title_overlay {background: #eee;}
.light .mm1_path {stroke: #fb3e04;}
.light .mm2_path {stroke: #fd0724;}
.light .mm3_path {stroke: #de0263;}
.light .mm4_path {stroke: #0f7ed0;}
.light .mm5_path {stroke: #655fac;}
.light .mm6_path {stroke: #a904bf;}
.light ::selection {background-color: #000; color: #fff;}
.light #mindmap #mm_1 .title span::selection {background-color: #fb3e04;}
.light #mindmap #mm_2 .title span::selection {background-color: #fd0724;}
.light #mindmap #mm_3 .title span::selection {background-color: #de0263;}
.light #mindmap #mm_4 .title span::selection {background-color: #0f7ed0;}
.light #mindmap #mm_5 .title span::selection {background-color: #655fac;}
.light #mindmap #mm_6 .title span::selection {background-color: #a904bf;}
.light #toggle {background-image: url('./light.svg');}

#text-content {
	padding: 10px 50px;
	max-width: 1200px;
	margin: 0 auto;
}
#text-content h1,
#text-content h2,
#text-content h3,
#text-content h4,
#text-content p,
#text-content ul li {
	font-family: arial;
	font-weight: 400;
}
