:root {
	--white: #fff;
	--light-creem: #faf8f5;
	--creem: #f8f4e9;
	--thin-green: #ebf5d4;
	--light-green: #7d9963;
	--green: #547443;
	--dark-green: #365c22;
	--red: #d32929;
	--light-brown: #d4c2b8;
	--brown: #817269;
	--dark-brown: #372216;
	--cr-dot-brown: #d4c2b8;
	--cr-overray: rgb(55 34 22 / 80%);
	--cr-switcher-shadow: rgb(85 63 52 / 20%);
	--cr-highlight-green: rgb(125 153 99 / 12%);
	--ff-ja: "Noto Sans JP", sans-serif;
	--ff-en: "Roboto", sans-serif;
	--cl-text-base: var(--dark-brown);
	--ff-base: var(--ff-ja);
	--cl-focus: var(--dark-green);
}

.js-rotation {
	animation: 40s linear infinite rotation;
}

.show-fadeup {
	opacity: 0;
	transition: opacity 2.5s cubic-bezier(0.25, 1, 0.5, 1), transform 1s cubic-bezier(0.25, 1, 0.5, 1);
	transform: translateY(60px);
	will-change: opacity, transform;
}

.show-fadeup.is-visible {
	opacity: 1;
	transform: translateY(0);
}

.show-fadein {
	opacity: 0;
	transition: opacity 6s cubic-bezier(0.25, 1, 0.5, 1) 0.5s;
	will-change: opacity;
}

.show-fadein.is-visible {
	opacity: 1;
}

.p-about__result {
	padding: 82px 0 60px;
}

.p-about__sub-title {
	font-size: 24px;
	font-weight: 700;
	line-height: 1.5;
}

.p-about__prof {
	padding: 42px 0;
}

.p-about__about {
	padding: 37px 0;
}

.p-about-result {
	margin-top: 40px;
}

.p-about-result__box {
	display: grid;
	gap: 18px;
	padding-bottom: 23px;
}

.p-about-result__box:not(:last-child) {
	border-bottom: 1.5px solid var(--light-brown);
}

.p-about-result__box:not(:first-child) {
	padding-top: 23px;
}

.p-about-result__box:last-child {
	padding-bottom: 0;
}

.p-about-result__box--small {
	gap: 9px;
}

.p-about-result__heading {
	font-size: 16px;
	font-weight: 700;
	line-height: 1.5;
}

.p-about-result__body {
	display: flex;
	flex-direction: column;
	gap: 24px;
}

.p-about-result__text {
	line-height: 1.78;
}

.p-about-result__content {
	display: flex;
	flex-direction: column;
	gap: 12px;
	align-items: center;
	padding: 12px 16px;
	background: var(--light-creem);
	border: 2px solid var(--white);
	border-radius: 8px;
}

.p-about-result__content.is-en {
	width: min(100%, 696px);
}

.p-about-result__content-fig {
	display: block;
	width: 100%;
	height: auto;
}

.p-about-result__content-img-wrap {
	overflow: hidden;
	border-radius: 8px;
}

.p-about-result__content-img {
	width: 100%;
	height: auto;
}

.p-about-result__content-img-text {
	display: block;
	width: -moz-fit-content;
	width: fit-content;
	margin-inline: auto;
	margin-top: 2px;
	font-size: 12px;
	text-align: center;
}

.p-about-result__btn-wrap {
	display: flex;
	flex-direction: column;
	gap: 8px;
	align-items: center;
}

.p-about-prof__top {
	display: flex;
	flex-direction: column;
	gap: 16px;
	margin-top: 40px;
}

.p-about-prof__img-wrap {
	height: -moz-fit-content;
	height: fit-content;
	overflow: hidden;
	border-radius: 8px;
}

.p-about-prof__top-name {
	font-size: 20px;
	font-weight: 700;
	line-height: 1.5;
}

.p-about-prof__top-name-en {
	font-family: var(--ff-en);
	font-size: 14px;
	font-weight: 700;
	line-height: 1.4;
	color: var(--brown);
}

.p-about-prof__top-text {
	margin-top: 20px;
	font-size: 14px;
}

.p-about-prof__bottom {
	display: grid;
	gap: 40px;
	margin-top: 40px;
}

.p-about-prof__bottom-title {
	margin-bottom: 4px;
	font-size: 16px;
	font-weight: 700;
	line-height: 1.5;
}

.p-about-prof__bottom-table table th,
.p-about-prof__bottom-table table td {
	padding: 0;
	font-size: 14px;
	font-weight: 500;
	line-height: 1.75;
	vertical-align: top;
	border: none;
}

.p-about-prof__bottom-table table tr td:first-child {
	width: 58px;
	padding-right: 8px;
}

.p-about-prof__bottom-table table tr:not(:first-of-type) th,
.p-about-prof__bottom-table table tr:not(:first-of-type) td {
	padding-top: 4.6px;
}

.p-about-prof__bottom-table.is-en table tr td:first-child {
	width: 50px;
}

.p-about-prof__until-text {
	line-height: 1.8;
}

.u-hidden__pc {
	display: block;
}

.u-hidden__pc--sm {
	display: block;
}

.u-hidden__pc--lg {
	display: block;
}

.u-hidden__pc--xl {
	display: block;
}

.u-hidden__pc--xxl {
	display: block;
}

.u-hidden__sp {
	display: none;
}

.u-hidden__sp--sm {
	display: none;
}

.u-hidden__sp--lg {
	display: none;
}

.u-hidden__sp--xl {
	display: none;
}

.u-hidden__sp--xxl {
	display: none;
}

.u-mt--28 {
	margin-top: 28px;
}

.u-mt--16sp {
	margin-top: 16px;
}

@media (width >= 576px) {

.u-hidden__pc--sm {
	display: none;
}

.u-hidden__sp--sm {
	display: block;
}

}

@media (width >= 768px) {

.p-about__result {
	padding: 78px 0;
}

.p-about__sub-title {
	font-size: 36px;
}

.p-about__prof {
	padding: 75px 0;
}

.p-about__about {
	padding: 84px 0;
}

.p-about-result__box:not(:last-child) {
	border-width: 2px;
}

.p-about-result__box {
	grid-template-columns: 360fr 800fr;
	gap: 40px;
}

.p-about-result__heading {
	font-size: 18px;
}

.p-about-result__text {
	font-size: 18px;
}

.p-about-prof__top {
	flex-direction: row;
	gap: 60px;
}

.p-about-prof__img-wrap {
	width: min(100%, 300px);
}

.p-about-prof__top-name {
	font-size: 36px;
}

.p-about-prof__top-name-en {
	font-size: 16px;
}

.p-about-prof__top-text {
	font-size: 16px;
}

.p-about-prof__bottom {
	grid-template-columns: repeat(2, 1fr);
	margin-top: 56px;
}

.p-about-prof__bottom-title {
	margin-bottom: 8px;
	font-size: 24px;
}

.p-about-prof__bottom-table table th,
.p-about-prof__bottom-table table td {
	font-size: 16px;
	line-height: 1.92;
}

.p-about-prof__bottom-table table tr td:first-child {
	width: 64px;
}

.p-about-prof__until-text {
	line-height: 1.75;
}

.u-hidden__pc {
	display: none;
}

.u-hidden__sp {
	display: block;
}

.u-mt--16sp {
	margin-top: 0;
}

.u-mt--10pc {
	margin-top: 10px;
}

}

@media (width >= 992px) {

.u-hidden__pc--lg {
	display: none;
}

.u-hidden__sp--lg {
	display: block;
}

}

@media (width >= 1200px) {

.p-about-result__content {
	flex-direction: row;
	gap: 24px;
	width: min(100%, 680px);
	padding: 20px;
}

.p-about-result__content-fig {
	width: min(100%, 300px);
}

.p-about-result__btn-wrap {
	gap: 12px;
	align-items: flex-start;
}

.u-hidden__pc--xl {
	display: none;
}

.u-hidden__sp--xl {
	display: block;
}

}

@media (width >= 1400px) {

.u-hidden__pc--xxl {
	display: none;
}

.u-hidden__sp--xxl {
	display: block;
}

}

@keyframes rotation {

0% {
	transform: rotate(0);
}

100% {
	transform: rotate(360deg);
}

}

@keyframes swing {

0% {
	transform: rotate(6deg);
	transform-origin: right bottom;
}

25% {
	transform: rotate(1deg);
}

50% {
	transform: rotate(-6deg);
}

75% {
	transform: rotate(1deg);
}

100% {
	transform: rotate(6deg);
}

}

@keyframes swing2 {

0% {
	transform: rotate(0);
	transform-origin: left bottom;
}

25% {
	transform: rotate(5deg);
}

50% {
	transform: rotate(10deg);
}

75% {
	transform: rotate(5deg);
}

100% {
	transform: rotate(0);
}

}

@keyframes swing3 {

0% {
	transform: rotate(0deg);
	transform-origin: right bottom;
}

25% {
	transform: rotate(-5deg);
}

50% {
	transform: rotate(-10deg);
}

75% {
	transform: rotate(-5deg);
}

100% {
	transform: rotate(0deg);
}

}

