/* -----------------------------------------------
= main
----------------------------------------------- */
@media print, screen and (min-width: 768px) {/* PC */
.main {
	overflow: hidden;
}
}/* @media */
/* -----------------------------------------------
= page-title
----------------------------------------------- */
@media print, screen and (min-width: 768px) {/* PC */
.page-title {
	max-width: 1300px;
	margin-inline: auto;
}
}/* @media */
/* -----------------------------------------------
= intro
----------------------------------------------- */
.intro {
	margin: 20px 13px 60px;
}
.intro h2 {
	margin-bottom: 40px;
	color: var(--red);
	font-size: calc(1.4rem / 1.6);
	font-weight: 700;
	line-height: calc(24 / 14);
}
.intro .profile {
	padding-bottom: 35px;
	border-bottom: 0.5px solid #b1b1b1;
}
.intro .profile h3 {
	position: relative;
	margin-bottom: 30px;
	font-family: var(--zen);
	font-size: calc(1.4rem / 1.6);
	font-weight: 400;
}
.intro .profile .set {
	text-align: center;
}
.intro .profile .set + .set {
	margin-top: 40px;
}
.intro .profile h3::after {
	content: "";
	position: absolute;
	top: 50%;
	right: 0;
	width: calc(100% - 4em);
	border-top: 0.5px solid #b1b1b1;
}
.intro .profile img {
	width: 160px;
	margin: 0 auto 10px;
}
.intro .profile .name {
	margin-bottom: 10px;
}
.intro .profile .name .jp {
	display: block;
	font-size: calc(2rem / 1.6);
	font-weight: 700;
}
.intro .profile .name .en {
	display: block;
	font-size: calc(1.3rem / 1.6);
}
.intro .profile .division {
	font-size: calc(1.3rem / 1.6);
	line-height: calc(20 / 13);
	letter-spacing: 0;
}
.intro .profile .year {
	font-size: calc(1.3rem / 1.6);
	line-height: calc(20 / 13);
	letter-spacing: 0;
}
@media print, screen and (min-width: 768px) {/* PC */
.intro {
	max-width: 1300px;
	margin: 60px auto 50px;
	padding-inline: 30px;
}
.intro h2 {
	margin-bottom: 90px;
	font-size: calc(2.2rem / 1.6);
	line-height: calc(40 / 22);
}
.intro .profile {
	padding-bottom: 22px;
	border-bottom-width: 1px;
}
.intro .profile h3 {
	font-size: calc(2.4rem / 1.6);
}
.intro .profile h3::after {
	border-top-width: 1px;
}
.intro .profile .inner {
	display: flex;
	justify-content: center;
}
.intro .profile .set + .set {
	margin-top: 0;
}
.intro .profile .set:nth-child(1) {
	margin-right: 120px;
}
.intro .profile .set:nth-child(2) {
	margin-right: 80px;
}
.intro .profile .name .jp {
	margin-right: 25px;
	font-size: calc(2rem / 1.6);
}
.intro .profile .name .en {
	font-size: calc(1.4rem / 1.6);
}
.intro .profile .division {
	font-size: calc(1.6rem / 1.6);
	line-height: calc(24 / 16);
}
.intro .profile .year {
	font-size: calc(1.6rem / 1.6);
	line-height: calc(24 / 16);
}
}/* @media */
/* -----------------------------------------------
= index
----------------------------------------------- */
.index {
	padding: 16px;
	background: #f2f2ee;
}
.index .inner {
	display: flex;
	gap: 0 20px;
}
.index h2 {
	font-family: var(--zen);
	font-size: calc(1.4rem / 1.6);
	font-weight: 400;
}
.index li {
	font-size: calc(1.2rem / 1.6);
	line-height: calc(17 / 12);
	letter-spacing: .02em;
}
.index li + li {
	margin-top: 15px;
}
.index li a span {
	display: block;
}
.index li a span:first-child {
	margin-bottom: 3px;
	font-family: var(--zen);
	font-weight: 400;
}
@media print, screen and (min-width: 768px) {/* PC */
.index {
	margin-bottom: 160px;
	padding: 0 30px;
	background: transparent;
}
.index .inner {
	display: flex;
	gap: 0 calc(200 / 1300 * 100%);
	max-width: 1200px;
	margin-inline: auto;
	padding: 25px 50px;
	background: #f2f2ee;
}
.index h2 {
	font-size: calc(2.4rem / 1.6);
}
.index ol {
	flex: 1;
}
.index li {
	font-size: calc(1.8rem / 1.6);
}
.index li + li {
	margin-top: 20px;
}
.index li a {
	display: flex;
	gap: 0 1em;
}
.index li a span:first-child::after {
	content: "｜";
	margin-left: 1em;
}
.index li a span:last-child {
	flex: 1;
}
}/* @media */
@media (hover:hover) {
.index a {
	transition: color .3s;
}
.index a:hover {
	color: var(--red);
}
}/* @media */
/* -----------------------------------------------
= side
----------------------------------------------- */
.btn-side {
	position: fixed;
	right: 0;
	bottom: 60px;
	z-index: 5;
	padding: 9px 88px 9px 20px;
	color: #fff;
	background:  #b9b9b1;
	font-family: var(--zen);
	font-size: calc(2rem / 1.6);
	font-weight: 400;
}
.btn-side::after {
	content: "";
	position: absolute;
	top: 20px;
	right: 10px;
	width: 33px;
	height: 12px;
	background: url(../../img/index/icon-index.svg) no-repeat 50% / 100% auto;
}
.btn-close {
	position: absolute;
	top: 16px;
	right: 16px;
	width: 30px;
	height: 30px;
}
.btn-close::before,
.btn-close::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 0;
	width: 100%;
	height: 0.5px;
	background: #808080;
}
.btn-close::before {
	transform: rotate(-45deg);
}
.btn-close::after {
	transform: rotate(45deg);
}
.side.index {
	position: fixed;
	right: 0;
	bottom: 60px;
	width: calc(100% - 32px);
	z-index: 6;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: opacity .4s;
}
.side.index[aria-hidden="false"] {
	opacity: 1;
	pointer-events: auto;
	visibility: visible;
}
@media print, screen and (min-width: 768px) {/* PC */
.btn-side {
	right: auto;
	left: 0;
	padding: 6px 70px 6px 20px;
	font-size: calc(2.4rem / 1.6);
	transform: rotate(-90deg);
	transform-origin: top left;
	opacity: 0;
	pointer-events: none;
	transition: opacity .4s;
}
.btn-side::after {
	top: 17px;
	right: 6px;
	transform: rotate(90deg);
}
.btn-side.is-visible {
	opacity: 1;
	pointer-events: auto;
}
.side.index {
	right: auto;
	left: 0;
	width: 100%;
	max-width: 1300px;
	margin-bottom: 0;
	padding: 0;
	box-sizing: border-box;
}
.side.index .inner {
	padding-right: 80px;
}
}/* @media */
@media (hover:hover) {
.btn-side {
	transition: color .3s;
}
.btn-side:hover {
	color: var(--red);
}
}/* @media */
/* -----------------------------------------------
= block
----------------------------------------------- */
.block {
	margin: 0 13px 60px;
	scroll-margin-top: 45px;
}
.block .num {
	display: inline-flex;
	margin-bottom: 15px;
	font-size: calc(1.5rem / 1.6);
}
.block .num span:nth-child(1) {
	padding-inline: 10px;
	color: #fff;
	background: #ff4b56;
	font-family: var(--zen);
	font-weight: 400;
}
.block .num span:nth-child(2) {
	padding-inline: 10px;
	color: var(--red);
	background: #e6e6e6;
	letter-spacing: .08em;
}
.block .title h2 {
	margin-bottom: 35px;
	padding-bottom: 15px;
	border-bottom: 0.5px solid #989898;
	font-size: calc(2rem / 1.6);
	line-height: calc(28 / 20);
	letter-spacing: .12em;
}
.block .text {
	font-size: calc(1.3rem / 1.6);
	line-height: calc(22 / 13);
	letter-spacing: .04em;
}
.block .text + .text {
	margin-top: 2em;
}
.block .img {
	display: block;
	max-width: 240px;
	margin: 35px auto;
	padding-left: 60px;
}
.img-large {
	display: block;
	margin-bottom: 60px;
}
.block .item {
	display: flex;
	gap: 0 18px;
}
.block .item + .item {
	margin-top: 30px;
}
.block .item .thm {
	width: 54px;
}
.block .item .text {
	flex: 1;
	min-height: 54px;
	display: flex;
	align-items: center;
	line-height: calc(30 / 13);
}
.block .item .text img {
	width: 28.8px;
	vertical-align: middle;
}
@media print, screen and (min-width: 768px) {/* PC */
.block {
	max-width: 1500px;
	margin: 0 auto 190px;
	padding-inline: 30px;
	scroll-margin-top: 60px;
}
.block .num {
	font-size: calc(2rem / 1.6);
}
.block .title h2 {
	margin-bottom: 55px;
	font-size: calc(3.2rem / 1.6);
	line-height: calc(48 / 32);
}
.block .text {
	font-size: calc(1.8rem / 1.6);
	line-height: calc(32 / 18);
}
.block .img {
	max-width: 800px;
	margin-block: 65px;
	padding-left: 0;
}
.img-large {
	max-width: 1300px;
	margin: 0 auto 87px;
}
.block .item {
	gap: 0 24px;
}
.block .item + .item {
	margin-top: 35px;
}
.block .item .thm {
	width: 72px ;
}
.block .item .text {
	min-height: 72px;
	line-height: calc(40 / 18);
}
.block .item .text img {
	width: 38.4px;
}
.img-large-last {
	display: block;
	max-width: 1500px;
	margin: 0 auto 120px;
}
}/* @media */
/* -----------------------------------------------
= prologue
----------------------------------------------- */
#prologue {
	scroll-margin-top: 45px;
}
.prologue {
	position: relative;
	margin: 0;
}
.prologue::before,
.prologue::after {
	content: "";
	position: absolute;
	z-index: -1;
}
.prologue::before {
	top: 623px;
	left: 0;
	width: 188px;
	height: 188px;
	background: rgba(255,0,0,.25);
}
.prologue::after {
	top: 1362px;
	right: 0;
	width: 163px;
	height: 163px;
	background: rgba(255,0,0,.3);
	clip-path: polygon(0 0, 100% 0, 100% 100%);
}
.prologue .inner {
	position: relative;
	z-index: 1;
	margin: -110px 58px 60px;
	padding: 10px 10px 0;
}
.prologue .inner::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
	width: 100%;
	height: 110px;
	background: #fff;
}
.prologue .inner::after {
	content: "";
	position: absolute;
	bottom: 217px;
	left: -58px;
	z-index: -1;
	width: 188px;
	height: 188px;
	background: rgba(255,0,0,.25);
}
.prologue .inner .title h2 {
	margin-bottom: 15px;
	letter-spacing: .08em;
}
@media print, screen and (min-width: 768px) {/* PC */
#prologue {
	scroll-margin-top: 60px;
}
.prologue {
	max-width: 900px;
	margin-inline: auto;
}
.prologue::before {
	top: 1630px;
	left: -310px;
	width: 750px;
	height: 634px;
}
.prologue::after {
	display: none;
}
.prologue .inner {
	position: relative;
	margin: -443px 0 230px;
	padding: 40px 40px 0;
}
.prologue .inner::before {
	height: 443px;
}
.prologue .inner::after {
	display: none;
}
}/* @media */
/* -----------------------------------------------
= dialogue
----------------------------------------------- */
.dialogue {
	position: relative;
}
.dialogue::before,
.dialogue::after {
	content: "";
	position: absolute;
	z-index: -1;
}
#dialogue01::before {
	top: 746px;
	left: -13px;
	width: 195px;
	height: 190px;
	background: rgba(255,0,0,.25);
	clip-path: polygon(0 0, 100% 0, 0 100%);
}
#dialogue01::after {
	top: 2300px;
	right: -13px;
	width: 188px;
	height: 158px;
	background: rgba(255,0,0,.25);
}
.dialogue .inner {
	position: relative;
	z-index: 1;
}
.dialogue .inner::before,
.dialogue .inner::after {
	content: "";
	position: absolute;
	z-index: -1;
}
#dialogue01 .inner::before {
	bottom: 1850px;
	left: -13px;
	width: 195px;
	height: 190px;
	background: rgba(255,0,0,.25);
	clip-path: polygon(0 0, 100% 0, 0 100%);
}
#dialogue01 .inner::after {
	bottom: 570px;
	right: -13px;
	width: 188px;
	height: 158px;
	background: rgba(255,0,0,.25);
}
#dialogue02::before {
	top: 1260px;
	left: -13px;
	width: 195px;
	height: 190px;
	background: rgba(255,0,0,.25);
}
#dialogue02::after {
	top: 3062px;
	right: -13px;
	width: 195px;
	height: 187px;
	background: rgba(255,0,0,.25);
	clip-path: polygon(0 0, 100% 0, 100% 100%);
}
#dialogue02 .inner::before {
	bottom: 1880px;
	left: -13px;
	width: 195px;
	height: 190px;
	background: rgba(255,0,0,.25);
}
#dialogue02 .inner::after {
	bottom: 435px;
	right: -13px;
	width: 195px;
	height: 187px;
	background: rgba(255,0,0,.25);
	clip-path: polygon(0 0, 100% 0, 100% 100%);
}
@media print, screen and (min-width: 768px) {/* PC */
.dialogue {
	max-width: 1100px;
	margin-inline: auto;
}
#dialogue01::before {
	top: 692px;
	left: -170px;
	width: 780px;
	height: 760px;
}
#dialogue01::after {
	top: auto;
	bottom: 950px;
	right: -170px;
	width: 750px;
	height: 634px;
}
.dialogue .inner::before,
.dialogue .inner::after {
	display: none;
}
.dialogue .title h2 {
	margin-bottom: 35px;
}
#dialogue02::before {
	top: 720px;
	left: -170px;
	width: 750px;
	height: 634px;
}
#dialogue02::after {
	top: auto;
	bottom: 620px;
	right: -170px;
	width: 780px;
	height: 760px;
}
}/* @media */
/* -----------------------------------------------
= epilogue
----------------------------------------------- */
.epilogue {
	position: relative;
}
.epilogue::before,
.epilogue::after {
	content: "";
	position: absolute;
	z-index: -1;
}
.epilogue::before {
	top: 750px;
	left: -13px;
	width: 195px;
	height: 190px;
	background: rgba(255,0,0,.25);
	clip-path: polygon(0 0, 100% 0, 0 100%);
}
.epilogue::after {
	bottom: 500px;
	right: -13px;
	width: 188px;
	height: 158px;
	background: rgba(255,0,0,.25);
}
@media print, screen and (min-width: 768px) {/* PC */
.epilogue {
	max-width: 1100px;
	margin-inline: auto;
}
.epilogue::before {
	top: 480px;
	left: -170px;
	width: 780px;
	height: 760px;
}
.epilogue::after {
	top: auto;
	bottom: -70px;
	right: -170px;
	width: 750px;
	height: 634px;
}
}/* @media */
/* -----------------------------------------------
= other
----------------------------------------------- */
.other li img {
	margin-bottom: 0;
}
@media print, screen and (min-width: 768px) {/* PC */
.other {
	max-width: 1080px;
}
.other ul {
	grid-template-columns: repeat(2, 1fr);
	gap: 47px;
}
.other li img {
	margin-bottom: 0;
}
}/* @media */


