.tbsp {
  display: none;
	width: 100%;
	height: 400px;
	background-image: url('images/about-bg.jpg');
	background-size:  cover;
	background-position: center, center;
	background-repeat: no-repeat;
	background-color: #ffffff;
}
@media screen and (max-width: 980px) {
  .tbsp {
    display: block;
  }
}
  

body.social:before {
	content: '';
	display: block;
	background-attachment: scroll;
	height: var(--background-height);
	left: auto;
	pointer-events: none;
	position: fixed;
	top: 0;
	transform: scale(1);
	width: calc(100% - 30rem);
	z-index: 0;
	right: 0;
	background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20viewBox%3D%220%200%20512%20512%22%20width%3D%22512%22%20height%3D%22512%22%20version%3D%221.1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%20%3Cfilter%20id%3D%22noise%22%3E%20%3CfeTurbulence%20type%3D%22fractalNoise%22%20baseFrequency%3D%220.875%22%20result%3D%22noise%22%20%2F%3E%20%3CfeColorMatrix%20type%3D%22matrix%22%20values%3D%220.46875%200%200%200%200%200%200.39453125%200%200%200%200%200%200.25390625%200%200%200%200%200%200.33984375%200%22%20%2F%3E%20%3C%2Ffilter%3E%20%3Crect%20filter%3D%22url%28%23noise%29%22%20x%3D%220%22%20y%3D%220%22%20width%3D%22512%22%20height%3D%22512%22%20fill%3D%22transparent%22%20opacity%3D%221%22%20%2F%3E%3C%2Fsvg%3E'),
		url('images/about-bg.jpg');
	background-size: 512px, cover;
	background-position: center, center;
	background-repeat: repeat, no-repeat;
	background-color: #ffffff;
}
body.social:after {
	background-color: #ccc3b1;
	content: '';
	display: block;
	height: 100%;
	left: 0;
	opacity: 0;
	pointer-events: none;
	position: fixed;
	top: 0;
	transform: scale(1);
	transition: opacity 1s ease-in-out 1s, visibility 1s 1s;
	visibility: hidden;
	width: 100%;
	z-index: 1;
}
:root {
	--background-height: 100vh;
	--site-language-alignment: left;
	--site-language-direction: ltr;
	--site-language-flex-alignment: flex-start;
	--site-language-indent-left: 1;
	--site-language-indent-right: 0;
	--viewport-height: 100vh;
}
html {
	font-size: 15pt;
}
u {
	text-decoration: underline;
}
strong {
	color: inherit;
	font-weight: bolder;
}
em {
	font-style: italic;
}
code {
	background-color: rgba(144, 144, 144, 0.25);
	border-radius: 0.25em;
	font-family: 'Lucida Console', 'Courier New', monospace;
	font-size: 0.9em;
	font-weight: normal;
	letter-spacing: 0;
	margin: 0 0.25em;
	padding: 0.25em 0.5em;
	text-indent: 0;
}
mark {
	background-color: rgba(144, 144, 144, 0.25);
}
spoiler-text {
	-webkit-text-stroke: 0;
	background-color: rgba(32, 32, 32, 0.75);
	text-shadow: none;
	text-stroke: 0;
	color: transparent;
	cursor: pointer;
	transition: color 0.1s ease-in-out;
}
spoiler-text.active {
	color: #ffffff;
	cursor: text;
}
s {
	text-decoration: line-through;
}
sub {
	font-size: smaller;
	vertical-align: sub;
}
sup {
	font-size: smaller;
	vertical-align: super;
}
a {
	color: inherit;
	text-decoration: underline;
	transition: color 0.25s ease;
}
a[onclick]:not([href]) {
	cursor: pointer;
}
#wrapper {
	-webkit-overflow-scrolling: touch;
	align-items: stretch;
	display: flex;
	flex-direction: row;
	justify-content: flex-start;
	min-height: var(--viewport-height);
	overflow: hidden;
	position: relative;
	z-index: 2;
	padding: 0 2.25rem 0 0;
}
#main {
	--alignment: var(--site-language-alignment);
	--flex-alignment: var(--site-language-flex-alignment);
	--indent-left: var(--site-language-indent-left);
	--indent-right: var(--site-language-indent-right);
	--border-radius-tl: 0;
	--border-radius-tr: 0;
	--border-radius-br: 0;
	--border-radius-bl: 0;
	z-index: 1;
	background-color: #184b38;
	background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%201024%201024%22%20width%3D%221024%22%20height%3D%221024%22%20preserveAspectRatio%3D%22none%22%3E%20%3Cstyle%3E%20rect%20%7B%20fill%3A%20rgba(255,246,28,0.239)%3B%20transform-origin%3A%2050%25%2050%25%3B%20transform%3A%20translateX%28-25%25%29%20translateY%28-25%25%29%3B%20%7D%20%3C%2Fstyle%3E%20%3Crect%20x%3D%22256%22%20y%3D%22256%22%20width%3D%224.01%25%22%20height%3D%224.01%25%22%20%2F%3E%20%3Crect%20x%3D%22768%22%20y%3D%22768%22%20width%3D%224.01%25%22%20height%3D%224.01%25%22%20%2F%3E%3C%2Fsvg%3E');
	background-size: 128px;
	background-position: center;
	background-repeat: repeat;
	box-shadow: 0rem 1.75rem 7.625rem 0rem rgba(0, 0, 0, 0.078);
	transition: opacity 1s ease 0.125s, transform 1s ease 0.125s;
}
#main > .inner {
	--padding-horizontal: 3rem;
	--padding-vertical: 3rem;
	--spacing: 1.5rem;
	--width: 30rem;
	border-radius: var(--border-radius-tl) var(--border-radius-tr) var(--border-radius-br) var(--border-radius-bl);
	max-width: 100%;
	position: relative;
	width: var(--width);
	z-index: 1;
	padding: var(--padding-vertical) var(--padding-horizontal);
}
#main > .inner > * {
	margin-top: var(--spacing);
	margin-bottom: var(--spacing);
}
#main > .inner > :first-child {
	margin-top: 0 !important;
}
#main > .inner > :last-child {
	margin-bottom: 0 !important;
}
#main > .inner > .full {
	margin-left: calc(var(--padding-horizontal) * -1);
	max-width: calc(100% + calc(var(--padding-horizontal) * 2) + 0.4725px);
	width: calc(100% + calc(var(--padding-horizontal) * 2) + 0.4725px);
}
#main > .inner > .full:first-child {
	border-top-left-radius: inherit;
	border-top-right-radius: inherit;
	margin-top: calc(var(--padding-vertical) * -1) !important;
}
#main > .inner > .full:last-child {
	border-bottom-left-radius: inherit;
	border-bottom-right-radius: inherit;
	margin-bottom: calc(var(--padding-vertical) * -1) !important;
}
#main > .inner > .full.screen {
	border-radius: 0 !important;
	max-width: 100vw;
	position: relative;
	width: 100vw;
	left: 0;
	margin-left: calc(var(--padding-horizontal) * -1);
	right: auto;
}
body.is-loading #main {
	opacity: 0;
	transform: translateX(0.6375rem);
}
body.is-instant #main,
body.is-instant #main > .inner > *,
body.is-instant #main > .inner > section > * {
	transition: none !important;
}
body.is-instant:after {
	display: none !important;
	transition: none !important;
}
h1,
h2,
h3,
p {
	direction: var(--site-language-direction);
	position: relative;
}
h1 span.p,
h2 span.p,
h3 span.p,
p span.p {
	display: block;
	position: relative;
}
h1 span[style],
h2 span[style],
h3 span[style],
p span[style],
h1 strong,
h2 strong,
h3 strong,
p strong,
h1 a,
h2 a,
h3 a,
p a,
h1 code,
h2 code,
h3 code,
p code,
h1 mark,
h2 mark,
h3 mark,
p mark,
h1 spoiler-text,
h2 spoiler-text,
h3 spoiler-text,
p spoiler-text {
	-webkit-text-fill-color: currentcolor;
}
#text01 {
	text-align: center;
	color: rgba(211, 255, 176, 0.671);
	font-family: 'Kaushan Script', cursive;
	font-size: 2.75em;
	line-height: 1;
	font-weight: 400;
}
#text01 a {
	text-decoration: underline;
}
#text01 a:hover {
	text-decoration: none;
}
#text01 span.p:nth-child(n + 2) {
	margin-top: 1rem;
}
#text12 {
	text-transform: lowercase;
	color: rgba(204, 255, 209, 0.431);
	font-family: 'Carter One', cursive;
	font-size: 1em;
	line-height: 1.75;
	font-weight: 400;
}
#text12 a {
	text-decoration: underline;
}
#text12 a:hover {
	text-decoration: none;
}
#text12 span.p:nth-child(n + 2) {
	margin-top: 1rem;
}
hr {
	align-items: center;
	border: 0;
	display: flex;
	justify-content: var(--flex-alignment);
	min-height: 1rem;
	padding: 0;
	position: relative;
	width: 100%;
}

hr:before {
	content: '';
}
hr.style1:before {
	width: 100%;
	height: 2rem;
	background-size: auto 75.1%;
	background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%20512%20512%22%20width%3D%22512%22%20height%3D%22512%22%20preserveAspectRatio%3D%22none%22%3E%3Cstyle%3Epath%20%7Bfill%3A%20none%3Bstroke-width%3A%203px%3Bstroke%3A%20rgba(255,255,255,0.659)%3Bstroke-linecap%3Around%3Bvector-effect%3A%20non-scaling-stroke%3B%7D%3C%2Fstyle%3E%3Cpath%20d%3D%22M-8%2C400l264-288%20M520%2C400L256%2C112%22%20%2F%3E%3C%2Fsvg%3E');
	background-position: center center;
	background-repeat: repeat-x;
}
.buttons {
	cursor: default;
	display: flex;
	justify-content: var(--flex-alignment);
	letter-spacing: 0;
	padding: 0;
}
.buttons li {
	max-width: 100%;
}
.buttons li a {
	align-items: center;
	justify-content: center;
	max-width: 100%;
	text-align: center;
	text-decoration: none;
	vertical-align: middle;
	white-space: nowrap;
}
#buttons01 {
	gap: 0.625rem;
	flex-direction: column;
	flex-wrap: nowrap;
}
#buttons01 li a {
	display: inline-flex;
	width: 100vw;
	height: auto;
	line-height: 1.875rem;
	padding: 0 1.5rem;
	vertical-align: middle;
	font-family: 'Inconsolata', monospace;
	font-size: 1em;
	font-weight: 500;
	border-radius: 0.75rem;
	flex-direction: row-reverse;
	justify-content: flex-end;
	padding-bottom: 0.9375rem;
	padding-top: 0.9375rem;
	white-space: normal;
	align-items: flex-start;
	transition: transform 0.375s ease, color 0.375s ease, background-color 0.375s ease, border-color 0.375s ease;
}
#buttons01 li a svg {
	display: block;
	fill: rgba(0, 0, 0, 0.431);
	flex-grow: 0;
	flex-shrink: 0;
	height: 1.875rem;
	min-width: 16px;
	width: 1.875em;
	margin-left: 1rem;
	margin-right: calc(-0.125em + 0rem);
	transition: fill 0.375s ease;
}
#buttons01 li a .label {
	direction: var(--site-language-direction);
	overflow: hidden;
	flex-grow: 1;
	flex-shrink: 1;
	text-align: left;
	width: 100%;
}
#buttons01 .button {
	background-color: #ffffff;
	color: rgba(0, 0, 0, 0.431);
}
#buttons01 li a:hover {
	transform: scale(1.0425);
}
#buttons01 .n01 svg {
	fill: #ffffff;
}
#buttons01 .n01 {
	background-color: rgba(0, 72, 255, 0.451);
	color: #ffffff;
}
#buttons01 .n02 svg {
	fill: #fa00ff;
}
#buttons01 .n02 {
	background-color: rgba(15, 15, 14, 0.478);
	color: #ffffff;
}
#buttons01 .n03 svg {
	fill: #ffffff;
}
#buttons01 .n03 {
	background-color: rgba(0, 72, 255, 0.451);
	color: #ffffff;
}
#buttons01 .n04 svg {
	fill: #c79618;
}
#buttons01 .n04 {
	background-color: rgba(15, 15, 14, 0.478);
	color: #ffffff;
}
.icons {
	display: flex;
	flex-wrap: wrap;
	justify-content: var(--flex-alignment);
	letter-spacing: 0;
	padding: 0;
}
.icons li {
	position: relative;
	z-index: 1;
}
.icons li a {
	align-items: center;
	display: flex;
	justify-content: center;
}
.icons li a svg {
	display: block;
	position: relative;
}
.icons li a + svg {
	display: block;
	height: 100%;
	left: 0;
	pointer-events: none;
	position: absolute;
	top: 0;
	width: 100%;
	z-index: -1;
}
.icons li a .label {
	display: none;
}
#icons01 {
	justify-content: center;
	font-size: 1.75em;
	gap: 1.5rem;
}
#icons01 li a {
	border-radius: 0.75rem;
	height: 1em;
	width: 1em;
	transition: transform 0.25s ease, color 0.25s ease, background-color 0.25s ease, border-color 0.25s ease;
}
#icons01 li a svg {
	height: 100%;
	width: 100%;
	transition: fill 0.25s ease;
}
#icons01 a svg {
	fill: rgba(0, 0, 0, 0.431);
}
#icons01 li a + svg {
	transition: transform 0.25s ease, fill 0.25s ease, stroke 0.25s ease;
}
#icons01 li a:hover {
	transform: scale(1.2);
}
#icons01 li a:hover + svg {
	transform: scale(1.2);
}
.icc-credits {
	display: block;
	opacity: 1 !important;
	position: relative;
	transition-delay: 0s !important;
}
.icc-credits span {
	border-radius: 24px;
	cursor: pointer;
	display: inline-block;
	font-family: Arial, sans-serif;
	font-size: 12px;
	letter-spacing: 0;
	line-height: 1;
	position: relative;
	text-decoration: none;
	width: auto;
}
.icc-credits span a {
	display: inline-block;
	padding: 0.5em 0.375em;
	position: relative;
	text-decoration: none;
	transition: color 0.25s ease, transform 0.25s ease;
	z-index: 1;
}
.icc-credits span a:before {
	content: '( ';
	opacity: 1;
	transition: opacity 0.25s ease;
}
.icc-credits span a:after {
	content: ' )';
	opacity: 1;
	transition: opacity 0.25s ease;
}
.icc-credits span::after {
	background-image: linear-gradient(30deg, #a464a1 15%, #3b5dad 85%);
	border-radius: inherit;
	box-shadow: 0 0.25em 1.25em 0 rgba(0, 0, 0, 0.25);
	content: '';
	display: block;
	height: calc(100% + 2px);
	left: -1px;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	top: -1px;
	transition: opacity 0.25s ease, box-shadow 0.25s ease, transform 0.25s ease;
	width: calc(100% + 2px);
}
.icc-credits span:hover {
	text-transform: none !important;
}
.icc-credits span:hover a {
	color: #ffffff !important;
	transform: scale(1.1) translateY(-0.05rem);
}
.icc-credits span:hover a:before {
	opacity: 0;
}
.icc-credits span:hover a:after {
	opacity: 0;
}
.icc-credits span:hover::after {
	opacity: 1;
	transform: scale(1.1) translateY(-0.05rem);
}
#credits span {
	color: rgba(204, 255, 209, 0.498);
	margin-top: 1.5rem !important;
}
@media (max-width: 1920px) {
	body:before {
		width: calc(100% - 30rem);
	}
	#main > .inner {
		--width: 30rem;
	}
}
@media (max-width: 1680px) {
	html {
		font-size: 11pt;
	}
}
@media (max-width: 1280px) {
	body:before {
		width: calc(100% - 30rem);
	}

	#main > .inner {
		--width: 30rem;
	}
}
@media (max-width: 1024px) {
	body:before {
		width: calc(100% - 25rem);
	}
	#main > .inner {
		--width: 25rem;
	}
}
@media (max-width: 980px) {
	body {
		display: flex;
		flex-direction: column;
		background-color: #184b38;
	}
	body:before {
		flex-grow: 1;
		flex-shrink: 0;
		max-height: 45vh;
		overflow: hidden;
		position: relative;
		width: 100%;
	}
	#main {
		border-bottom: none;
		border-left: none;
		border-radius: 0;
		border-right: none;
		box-shadow: none;
		width: 100%;
		background-color: #184b38;
	}
	#main > .inner {
		background: none;
		width: auto;
		transition: opacity 1s ease-in-out 0.125s;
	}
	#wrapper {
		height: auto !important;
		min-height: 0;
		padding: 0;
		box-shadow: -0rem -1.75rem 7.625rem 0rem rgba(0, 0, 0, 0.078);
	}
	body.is-loading #main {
		opacity: 1;
		transform: none;
	}
	body.is-loading #main > .inner {
		opacity: 0;
	}
}
@media (max-width: 736px) {
	#main > .inner {
		--padding-horizontal: 2rem;
		--padding-vertical: 4rem;
		--spacing: 1rem;
	}
	#wrapper {
		width: 100%;
	}
	#text01 {
		letter-spacing: 0rem;
		width: 100%;
		font-size: 2.75em;
		line-height: 1;
	}
	#text12 {
		letter-spacing: 0rem;
		width: 100%;
		font-size: 1em;
		line-height: 1.75;
	}
	hr.style1:before {
		height: 2rem;
		background-size: auto 75.1%;
	}
	#buttons01 {
		gap: 0.625rem;
	}
	#buttons01 li a {
		letter-spacing: 0rem;
		font-size: 1em;
	}
	#buttons01 li a svg {
		width: 1.875em;
	}
	#icons01 {
		font-size: 1.75em;
		gap: 1.5rem;
	}
}
@media (max-width: 480px) {
	#main > .inner {
		--spacing: 1.3125rem;
	}
	#wrapper {
		padding: 0;
	}
	#buttons01 li a {
		max-width: 100%;
		width: 100%;
	}
}
@media (max-width: 360px) {
	#main > .inner {
		--padding-horizontal: 1.5rem;
		--padding-vertical: 3rem;
		--spacing: 1.125rem;
	}
	#wrapper {
		padding: 0;
	}
	#text01 {
		font-size: 2em;
	}
	#text12 {
		font-size: 1em;
	}
	#buttons01 {
		gap: 0.46875rem;
	}
	#icons01 {
		gap: 1.125rem;
	}
}
