@charset "UTF-8";

/* ------------------------------------------------
  個別
------------------------------------------------ */

#topics {
	font-size: 10px;
}
#topics .inner {
	font-weight: bold;
	padding: 19rem 0;
}

#article em {
	color: #8A6C73;
}


#topics .inner h1 {
	width: 21.9rem;
	text-align: center;
	margin: 0 auto 11rem;
}
#topics .inner ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	width: 180rem;
	margin: 0 auto;
}
#topics .inner ul li {
	width: 37.4rem;
	margin: 0 3.7rem;
/* 	opacity: 0;
	transform: translateY(1rrem);
	filter: blur(20px); */
}
@media screen and (min-width: 641px) {
	#topics .inner ul li:nth-child(n+5) {
		margin-top: 7rem;
	}
}

#topics.scrollIn .inner ul li {
/* 	opacity: 1;
	transform: translateY(0);
	filter: blur(0); */
}
#topics.scrollIn .inner ul li.itrem1 {
/* 	transition: opacity 1.2s ease 1.1s,
		transform 1.5s ease 1.3s,
		filter 1.5s ease 1.3s; */
}
#topics.scrollIn .inner ul li.itrem2 {
/* 	transition: opacity 1.2s ease 1.4s,
		transform 1.5s ease 1.6s,
		filter 1.5s ease 1.6s; */
}
#topics.scrollIn .inner ul li.itrem3 {
/* 	transition: opacity 1.2s ease 1.7s,
		transform 1.5s ease 1.9s,
		filter 1.5s ease 1.9s; */
}

#topics .inner ul li a:hover {
	text-decoration: none;
}
#topics .inner ul li a .img {
	border-radius: 1rem;
	overflow: hidden;
	margin-bottom: 3rem;
}
#topics .inner ul li a .img img {
	transition: transform 1.4s ease;
}
#topics .inner ul li a:hover .img img {
	transform: scale(1.1);
}
#topics .inner ul li a .date {
	font-size: 1.6rem;
	color: #AB8085;
	margin-bottom: 0.8rem;
	display: flex;
	justify-content: space-between;
}
#topics .inner ul li a .date em {
	font-style: normal;
	border: 1px solid #AB8085;
	border-radius: 100px;
	font-size: 80%;
	padding: 0.2em 0.5em;
}
#topics .inner ul li a .txt {
	font-size: 1.6rem;
	color: #8A6C73;
	line-height: 1.8;
}

#topics .inner ul + .link_more {
	text-align: center;
	padding-top: 27rem;
	margin-top: -13.5rem;
}
@media screen and (max-width: 640px) {
	#topics .inner {
		padding: 5.4rem 3.6rem;
	}
	#topics .inner h1 {
		width: auto;
		height: 2rem;
		margin: 0 auto 6.5rem;
	}
	#topics .inner h1 img,
	#topics .inner h1 svg {
		width: auto;
		height: 100%;
	}
	#topics .inner ul {
		display: block;
		padding: 0;
		width: auto;
	}
	#topics .inner ul li {
		width: 100%;
		margin: 0 auto 3.7rem;
	}
	#topics .inner ul li a:hover {
		text-decoration: none;
	}
	#topics .inner ul li a .img {
		border-radius: 0.6rem;
		margin-bottom: 1.9rem;
	}
	#topics .inner ul li a .date {
		font-size: 1.3rem;
		margin-bottom: 0.5rem;
	}
	#topics .inner ul li a .txt {
		font-size: 1.3rem;
	}

	#topics .inner ul + .link_more {
		padding-top: 13rem;
		margin-top: -13rem;
	}
}


#article .inner {
	padding: 19rem 0;
	width: 1000px;
	box-sizing: border-box;
	position: relative;
}
@media screen and (max-width: 1220px) {
	#article .inner {
		width: 100rem;
	}
}

#article .inner .end {
	text-align: center;
	margin-top: -3rem;
	margin-bottom: 2rem;
}
#article .inner .end em {
	display: inline-block;
	font-size: 3rem;
	font-style: normal;
	border: 3px solid #AB8085;
	border-radius: 100px;
	line-height: 1;
	padding: 0.2em 1em 0.3em;
}
@media screen and (max-width: 640px) {
	#article .inner .end {
		margin-top: -1.5rem;
	}
	#article .inner .end em {
		font-size: 1.6rem;
	}
}

#article h1 {
	font-size: 5.5rem;
	font-weight: 600;
	color: #8A6C73;
	letter-spacing: 0.06em;
	margin-bottom: 7rem;
}
#article h1 strong {
	display: block;
	text-align: center;
	margin-bottom: 3rem;
}
#article h1 span.small {
	display: block;
	font-size: 70%;
	text-align: left;
}
#article .body {
	width: 1000px;
	margin: 0 auto;
}
@media screen and (max-width: 1220px) {
	#article .body {
		width: 100rem;
	}
}
#article .date {
	font-size: 2.5rem;
	font-weight: 600;
	color: #AB8085;
	letter-spacing: 0.1em;
	margin-bottom: 3rem;

	display: flex;
	justify-content: space-between;
}
#article .date em {
	font-style: normal;
	border: 1px solid #AB8085;
	border-radius: 100px;
	font-size: 80%;
	padding: 0.2em 0.5em 0.3em;
}
#article #kv {
	margin: 0 auto 8rem;
}

#article h2 {
	font-size: 3.8rem;
	font-weight: bold;
		line-height: 1.6;
	margin-top: 12rem;
	margin-bottom: 1.3em;
	text-align: center;
}
#article h2 .sub1 {
	display: block;
	font-size: 3rem;
	letter-spacing: 0.1em;
	margin-bottom: 7rem;
}
#article h2 .sub2 {
	display: block;
	font-size: 2rem;
}

#article h3 {
	font-size: 3.2rem;
	font-weight: bold;
	line-height: 1.5;
	margin-top: 8rem;
	margin-bottom: 1.3em;
}
#article h4 {
	font-size: 2.6rem;
	font-weight: bold;
	margin-top: 4rem;
	margin-bottom: 0.8em;
}

@media screen and (max-width: 640px) {
	#article h1 strong {
		margin-bottom: 1.5rem;
	}

	#article h2 {
		font-size: 1.8rem;
		margin-top: 6rem;
		margin-bottom: 1.3em;
	}
	#article h2 .sub1 {
		font-size: 1.4rem;
		margin-bottom: 2.5rem;
	}
	#article h2 .sub2 {
		font-size: 1rem;
	}

	#article h3 {
		font-size: 1.4rem;
		margin-top: 4rem;
		margin-bottom: 1.3em;
	}
	#article h4 {
		font-size: 1.2rem;
		font-weight: bold;
		margin-top: 4rem;
		margin-bottom: 1.3em;
	}
}

#article em {
	font-weight: bold;
	font-style: normal;
}

#article .txt {
	font-size: 2.6rem;
	color: #8A6C73;
	line-height: 2;
}

#article .center {
	text-align: center;
}

#article .middle {
	font-size: 2rem;
}
@media screen and (max-width: 640px) {
	#article .middle {
		font-size: 1.2rem;
	}
}

#article .small {
	font-size: 1.6rem;
}
@media screen and (max-width: 640px) {
	#article .small {
		font-size: 1rem;
	}
}

.pc-m_sp-s {
	font-size: 2rem;
}
@media screen and (max-width: 640px) {
	.pc-m_sp-s {
		font-size: 1rem;
	}
}

#article .small.block,
#article .middle.block {
	display: block;
}

#article .txt .annotation {
	font-size: 1.8rem;
	display: block;
}
#article .small .annotation {
	font-size: 1.6rem;
}
@media screen and (max-width: 640px) {
	#article .txt .annotation {
		font-size: 1rem;
	}
	#article .small .annotation {
		font-size: 0.9rem;
	}
}

#article .txt th {
	white-space: nowrap;
	font-weight: inherit;
	padding-right: 0.5em;
	text-align: right;
	vertical-align: top;
}

#article .txt a {
	color: #B78791;
	text-decoration: underline;
	display: inline-block;
	line-height: 1.4;
	word-break: break-all;
}
/* #article .txt a span {
	display: inline-block;
	line-height: 1.1;
	border-bottom: 1px solid #B78791;
} */

#article .txt + .txt,
#article .txt p + p {
	margin-top: 5rem;
}

#article .movie {
	position: relative;
	width: 100%;
	margin: 0 auto;
	aspect-ratio: 16 / 9;
	overflow: hidden;
}

#article .movie a::before {
	content: "";
	display: block;
	width: 20.3rem;
	height: 25.9rem;
	position: absolute;
	top: 2rem;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 100;
	margin: auto;
	background-repeat: no-repeat;
	background-image: url(/images/concept/movie_attachment.png);
	background-size: contain;
	pointer-events: none;
	transition: transform 1.4s ease;
}
#article .movie a:hover::before {
	transform: scale(0.95);
}

#article .movie a.ajust::before {
	top: 10rem;
}

#article .media.m37 {
	max-width: 37rem;
	margin: 0 auto;
}
#article .media.m50 {
	max-width: 50rem;
	margin: 0 auto;
}

#article .media.mini {
	max-width: 40rem;
}
#article .media.mini.center {
	margin-left: auto;
	margin-right: auto;
}
#article .media.mini em {
	display: block;
	font-size: 1.2rem;
	font-weight: 500;
	font-style: normal;
	text-align: center;
	margin-top: 0.8rem;
}
@media screen and (min-width: 641px) {
	#article .media img.small {
		width: auto;
		height: auto;
	}
}
@media screen and (max-width: 640px) {
	#article .media.mini {
		max-width: 70%;
	}
}

#article .center {
	text-align: center;
}
#article .center > * {
	text-align: left;
	display: inline-block;
}
#article .center .margin {
	margin-top: 0;
}

#article .txt + .media,
#article .media + .media {
	margin-top: 10rem;
}
#article .media + .txt {
	margin-top: 8.5rem;
}

#article .btn_back {
	margin-top: 12rem;
	text-align: center;
}
#article .btn_back a {
	display: inline-block;
	font-size: 2.2rem;
	color: #8A6C73;
	position: relative;
	letter-spacing: 0.1em;
	padding: 1.8rem 7rem;
	border: 1px solid #8A6C73;
	border-radius: 100rem;
	transition: all 0.2s ease;
}
#article .btn_back a:hover {
	text-decoration: none;
	color: #FFF!important;
	background-color: #8a6d73!important;
	border-color: #8a6d73!important;
}

#article .btn_back a::after {
	content: "";
	display: block;
	width: 1.3rem;
	height: 0;
	padding-top: 1.6rem;
	transform: scale(-1, 1);
	background-position: 0 0;
	background-repeat: no-repeat;
	background-image: url(/images/common/link_arrow3.svg);
	background-size: contain;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 3rem;
	z-index: 100;
	margin: auto;
	transition: left 0.15s ease;
}
#article .btn_back a:hover::after {
	background-image: url(/images/common/link_arrow0.svg);
	left: 2rem;
}



@media screen and (max-width: 640px) {
	#article .inner {
		width: auto;
		padding: 5.4rem 3.6rem;
	}
	#article h1 {
		font-size: 1.8rem;
		margin-bottom: 1.2rem;
	}
	#article .body {
		width: auto;
		margin: 0 auto;
	}
	#article .date {
		font-size: 1.2rem;
		font-weight: 600;
		color: #AB8085;
		letter-spacing: 0.1em;
		margin-bottom: 1rem;
	}
	#article #kv {
		margin: 0 -3.6rem 4rem;
	}

	#article .txt {
		font-size: 1.2rem;
		color: #8A6C73;
		line-height: 2.2;
	}
	#article .txt.small {
		font-size: 1rem;
	}

	#article .txt + .txt,
	#article .txt p + p {
		margin-top: 3rem;
	}

	#article .movie {
		width: 100%;
		margin: 0 auto;
		position: relative;
	}

	#article .movie a::before {
		width: 6.1rem;
		height: 7.77rem;
	}

	#article .txt + .media,
	#article .media + .media {
		margin-top: 3rem;
	}
	#article .media + .txt {
		margin-top: 4rem;
	}

	#article .btn_back {
		margin-top: 6rem;
	}
	#article .btn_back a {
		font-size: 1.2rem;
		padding: 1rem 4rem;
	}
	#article .btn_back a::after {
		width: 0.7rem;
		padding-top: 0.8rem;
		left: 2rem;
	}
}



#article .group {
	display: flex;
	justify-content: space-between;
}
#article .group.center {
	justify-content: center;
}

#article .group .txt h4 {
	margin-top: 0;
}
#article .group .txt {
	flex: 1;
	padding-right: 2rem;
}
#article .group .ph {
	margin-top: 1.5rem;
}
#article .group .ph span {
	display: block;
	width: 19rem;
}
#article .group .ph.c2 {
	display: flex;
	justify-content: space-between;
	width: 39rem;
}
#article .group .ph em {
	display: block;
	font-size: 1.2rem;
	font-weight: 500;
	font-style: normal;
	text-align: center;
	margin-top: 0.8rem;
}
@media screen and (max-width: 640px) {
	#article .group {
		display: block;
	}
	#article .group .ph {
		margin-top: 1.5rem;
	}
	#article .group .ph.c2 {
		width: 100%;
	}
	#article .group .ph span {
		width: 49%;
	}
}



#awards {
	width: 100rem;
	margin: 12rem auto 0;
}
#awards.large {

}
#awards ul.list + .txt {
	margin-top: 8rem;
	text-align: center;
}
#awards ul.list li.frame .group .head {
	width: 100%;
	display: flex;
	flex-direction: column;
}

#awards ul.list li.frame + li.frame {
	margin-top: 16rem;
}

#awards ul.list .product_all {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	margin-bottom: 5rem;
}
#awards ul.list .product_all .logo {
	width: 19rem;
}
#awards ul.list .product_all .txt {
	font-size: 2rem;
	font-weight: 600;
	text-align: center;
	margin-top: 0.5rem;
}

#awards ul.list li.frame .group .head .name_en img {
	width: auto;
}

#awards ul.list li.frame.f1 .group .head .name_en img,
#awards ul.list li.frame.f3 .group .head .name_en img,
#awards ul.list li.frame.f4 .group .head .name_en img,
#awards ul.list li.frame.f5 .group .head .name_en img {
	height: 3.75rem;
}

#awards ul.list li.frame.f25_1 .group .head .name_en img {
	height: 3.75rem;
}
#awards ul.list li.frame.f2 .group .head .name_en img {
	height: 1.35rem;
}

#awards ul.list li.frame .group .head {
	width: 100%;
	display: flex;
	flex-direction: column;
	text-align: center;
	text-align: center;
}
#awards ul.list li.frame .group .head .name_jp {
	font-size: 2rem;
	font-weight: 600;
	color: #916c73;
	letter-spacing: 0.01em;
	margin-top: 1em;
	margin-bottom: 3rem;
}
#awards ul.list li.frame .group .head .ph {
	text-align: center;
}
#awards ul.list li.frame .group .head .ph img {
	width: max-content;
	max-width: 100%;
	display: inline-block;
}


#awards ul.list li.frame .group .award {
	width: 49rem;
	margin-top: 2rem;
}
#awards ul.list li.frame .group .award .logo {
	margin-bottom: 8.3rem;
	margin-bottom: 4rem;
}
#awards ul.list li.frame .group .award ul {
	display: flex;
	flex-direction: column;
}
#awards ul.list li.frame .group .award li {
	position: relative;
	height: 9.1rem;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;

	font-size: 1.7rem;
	font-weight: bold;
	color: #806b70;
	letter-spacing: 0.06em;
	text-align: center;
}
#awards ul.list li.frame .group .award li a {
	font-size: 1.5rem;
	font-weight: 600;
	color: #B78791;
	text-decoration: underline;
	display: inline-block;
	line-height: 1.4;
	word-break: break-all;
	display: block;
	margin-top: 0.7rem;
}

#awards ul.list li.frame .group .award.single_column {
	width: 49rem;
	margin-left: auto;
	margin-right: auto;
}
#awards ul.list li.frame .group .award.single_column ul {
	justify-content: center;
}
#awards ul.list li.frame .group .award.twin_column {
	width: 107rem;
}
#awards ul.list li.frame .group .award.twin_column ul {
	display: flex;
	flex-wrap: wrap;
	flex-direction: row;
	justify-content: space-between;
}
#awards ul.list li.frame .group .award.twin_column li {
	width: 49rem;
	margin-top: 0;
	margin-bottom: 20px;
}
#awards ul.list li.frame .group .award.twin_column li .annotation {
	font-size: 1.4rem;
	color: #8A6C73;
	line-height: 1.8;
	margin-top: 0.5rem;
}



/* #awards ul.list li.frame .group .award li.link {
	text-align: center;
	margin-top: 0.5rem;
}
#awards ul.list li.frame .group .award li.link a {
	font-size: 1.6rem;
	color: #B78791;
	text-decoration: underline;
	display: inline-block;
	line-height: 1.4;
	word-break: break-all;
} */


#awards ul.list li.frame .group .award li + li {
	margin-top: 20px;
}
#awards ul.list li.frame .group .award li em {
	font-style: normal;
	background-color: #ffe7b2;
	background-color: #fff4f0;
	padding: 3px 5px;
}

#awards ul.list li.frame .group .award li::before,
#awards ul.list li.frame .group .award li::after {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	width: 2.7rem;
	height: 100%;
	background-repeat: no-repeat;
	background-size: contain;
	background-position: 50% 50%;
}
#awards ul.list li.frame .group .award li::before {
	left: 0;
	background-image: url(/images/top/leaf_l.svg);
}
#awards ul.list li.frame .group .award li::after {
	right: 0;
	background-image: url(/images/top/leaf_r.svg);
}

#awards .link_more {
	text-align: center;
	margin-top: 7rem;
}
@media screen and (max-width: 640px) {
	#awards,
	#awards.large {
		width: 100%;
		margin: 4.2rem auto 0;
	}
	#awards.large ul.list {
		padding: 0;
	}
	#awards ul.list + .txt {
		margin-top: 4rem;
	}

	#awards ul.list .product_all {
		margin-bottom: 0;
	}
	#awards ul.list .product_all .logo {
		width: 15rem;
	}
	#awards ul.list .product_all .txt {
		font-size: 1.8rem;
		font-weight: 600;
		text-align: center;
		margin-top: 0.5rem;
	}



	#awards ul.list li.frame + li.frame {
		margin-top: 6.5rem;
	}
	#awards ul.list li.frame .group .head .name_en img {
		width: auto;
	}
	#awards ul.list li.frame.f1 .group .head .name_en img,
	#awards ul.list li.frame.f3 .group .head .name_en img,
	#awards ul.list li.frame.f4 .group .head .name_en img,
	#awards ul.list li.frame.f5 .group .head .name_en img {
		height: 1.75rem;
	}

	#awards ul.list li.frame.f25_1 .group .head .name_en img {
		height: 1.75rem;
	}
	#awards ul.list li.frame.f2 .group .head .name_en img {
		height: 1.35rem;
	}
	#awards ul.list li.frame .group .head .name_jp {
		font-size: 1.3rem;
		margin-top: 0.3em;
		margin-bottom: 2rem;
		margin-right: 0;
	}
	#awards ul.list li.frame .group .head .ph {
		text-align: center;
		margin-top: 0;
	}
	#awards ul.list li.frame .group .head .ph img {
		width: auto;
		height: auto;
		/* max-width: initial; */
		display: inline-block;
	}


	#awards ul.list li.frame .group .award {
		width: 100%;
		margin-top: 3rem;
	}
	#awards ul.list li.frame .group .award + .award {
		margin-top: 1.2rem;
	}
	#awards ul.list li.frame .group .award .logo {
		margin-bottom: 1.5rem;
	}
	#awards ul.list li.frame .group.center .award .logo {
		margin-bottom: 0;
	}
	#awards ul.list li.frame .group .award ul {
		display: flex;
		flex-direction: column;
	}
	#awards ul.list li.frame .group .award li {
		height: 4.75rem;
		font-size: 1rem;
	}
	#awards ul.list li.frame .group .award li a {
		font-size: 0.9rem;
		margin-top: 0.3rem;
/* 		margin-bottom: -1rem; */
	}

	#awards ul.list li.frame .group .award.single_column {
		width: 100%;
	}

	#awards ul.list li.frame .group .award.twin_column {
		width: 100%;
	}
	#awards ul.list li.frame .group .award.twin_column ul {
		display: block;
	}
	#awards ul.list li.frame .group .award.twin_column li {
		width: 100%;
		margin-top: 0;
		margin-bottom: 1.2rem;
	}

	#awards ul.list li.frame .group .award li + li {
		margin-top: 1.2rem;
	}
	#awards ul.list li.frame .group .award li em {
		padding: 1.5px 3px;
	}

	#awards ul.list li.frame .group .award li::before,
	#awards ul.list li.frame .group .award li::after {
		width: 2.7rem;
		height: 100%;
	}
	#awards ul.list li.frame .group .award li::before {
		left: 0;
		background-image: url(/images/top/leaf_l.svg);
	}
	#awards ul.list li.frame .group .award li::after {
		right: 0;
		background-image: url(/images/top/leaf_r.svg);
	}

	#awards .link_more {
		text-align: center;
		margin-top: 3.5rem;
	}
}