@charset "utf-8";


/* --------------------------------------------------
	override
-------------------------------------------------- */
:root {
	--color-text: #656565;
	--color-text-black: #333333;
	--color-text-pink: #E4007F;
	--color-text-blue: #3A6580;
	--color-text-gray: #969696;
	--color-bg-pink1: #FF96A6;
	--color-bg-pink2: #FFF7F7;
	--color-bg-pink3: #FFF4EB;
	--color-line: #C1C1C1;
	--color-dot: #656565;
	--color-white: #FFFFFF;
}
body {
	background: var(--color-white);
}
#period-article section {
	margin-bottom: 0;
}
#period-article h1,
#period-article h2,
#period-article h3,
#period-article h4,
#period-article h5,
#period-article h6 {
	font-family: "Noto Sans JP", serif;
}
#period-article p {
	margin-bottom: 0;
}
#period-article figure {
	margin: 0 0;
}
#period-article ol {
	list-style-type: none;
	margin: 0 0;
	padding: 0 0;
}

@media screen and (max-width: 680px) {
	.path.cmsPath {
		padding-top: 10px;
		padding-left: 10px;
	}
}

/* --------------------------------------------------
	parts
-------------------------------------------------- */
#period-article {
	position: relative;
	font-family: "Noto Sans JP", serif;
	font-weight: 400;
	font-size: 16px;
	line-height: 2;
	letter-spacing: 0.1em;
	color: var(--color-text);
	padding-top: 1px;
	overflow-x: hidden;
	padding: 8px 0 100px;
}
#period-article .u-font--notosans {
	font-family: "Noto Sans JP", serif;
	font-optical-sizing: auto;
	font-style: normal;
}
#period-article .u-font--zenmarugo {
	font-family: "Zen Maru Gothic", serif;
	font-style: normal;
}
#period-article .u-font--w400 {
	font-weight: 400;
}
#period-article .u-font--w500 {
	font-weight: 500;
}
#period-article .u-font--w700 {
	font-weight: 700;
}
#period-article .u-color--pink {
	color: var(--color-text-pink);
}
#period-article .u-color--blue {
	color: var(--color-text-blue);
}
#period-article .u-color--text {
	color: var(--color-text);
}
#period-article .l-sec {
	position: relative;
}
#period-article .l-sec__inner {
	position: relative;
	max-width: 1260px;
	padding: 0 30px;
	margin-inline: auto;
}
#period-article .l-target {
	scroll-margin-top: 77px;
}
#period-article .c-dotline--bottom {
	background: linear-gradient(to right, var(--color-dot) 0px, var(--color-dot) 1px, transparent 1px, transparent 5px) left bottom / 5px 1px repeat-x;
}
@media screen and (max-width: 680px) {
	#period-article {
		font-size: 14px;
		padding-bottom: 30px;
	}
	#period-article .l-sec__inner {
		padding: 0 8%;
	}
	#period-article .l-target {
		scroll-margin-top: 47px;
	}
}


/* --------------------------------------------------
	visual
-------------------------------------------------- */
#period-article .visual {
	height: 420px;
}
#period-article .visual .l-sec__inner {
	height: 100%;
}
#period-article .visual__image {
	position: relative;
	overflow: hidden;
	height: 100%;
	border-radius: 10px 10px;
}
#period-article .visual__image img {
	object-fit: cover;
	width: 100%;
	height: 100%;
}
#period-article .visual__title {
	position: absolute;
	z-index: 1;
	top: 50%;
	left: 50%;
	width: min(calc(100% - 240px), 690px);
	font-size: min(calc((100vw / 1024) * 40), 40px);
	font-weight: 500;
	line-height: 1.6;
	color: var(--color-text-pink);
	text-align: center;
	transform: translate(-50%, -50%);
}
#period-article .visual__title span {
	display: block;
	border: 1px solid var(--color-text-pink);
	border-radius: 10px 10px;
	padding: 38px calc(60 / 690 * 100%);
}
#period-article .visual__title span::before {
	content: "";
	position: absolute;
	z-index: -1;
	top: 5px;
	left: 5px;
	width: 100%;
	height: 100%;
	border-radius: 10px 10px;
	background: var(--color-white);
}
#period-article .visual__title span em {
	display: block;
	font-size: 18px;
    font-weight: 500;
    margin-bottom: 15px;
    text-align: center;
    color: var(--color-text-blue);
}
@media screen and (max-width: 680px) {
	#period-article .visual {
		height: auto;
	}
	#period-article .visual__title {
		position: relative;
		top: 0;
		left: 0;
		width: calc(275 / 315 * 100%);
		font-size: 24px;
		line-height: 1.8;
		transform: translate(0, 0);
		margin-top: -20px;
	}
	#period-article .visual__title span {
		padding: 22px calc(15 / 275 * 100%);
	}
	#period-article .visual__title span em {
		font-size: 13px;
		margin-bottom: 5px;
	}
}


/* --------------------------------------------------
	intro
-------------------------------------------------- */
#period-article .intro {
	padding: 100px 0 80px;
}
#period-article .intro__text {
	text-align: center;
	font-size: 18px;
	color: var(--color-text-black);
}
#period-article .intro__text p + p {
	margin-top: 2.0em;
}
#period-article .intro__text span {
	color: var(--color-text-pink);
}
#period-article .intro__text .note {
	font-size: 14px;
	color: var(--color-text-gray);
	line-height: 1.6;
}
#period-article .intro__illust {
	position: absolute;
	width: 374px;
	top: -196px;
	left: calc(825 / 1260 * 100%);
}
@media screen and (max-width: 680px) {
	#period-article .intro {
		padding: 40px 0 30px;
	}
	#period-article .intro__text {
		text-align: left;
		font-size: 16px;
		margin-bottom: 20px;
	}
	#period-article .intro__text .note {
		font-size: 12px;
	}
	#period-article .intro__illust {
		position: relative;
		width: 198px;
		top: 0;
		left: 0;
		margin: 0 calc(-18 / 315 * 100%) 0 auto;
	}
}


/* --------------------------------------------------
	pagenav
-------------------------------------------------- */
#period-article .pagenav {
	z-index: 1;
	padding-bottom: 80px;
}
#period-article .pagenav__list {
	border: 1px solid var(--color-line);
	border-radius: 10px 10px;
	padding: 30px calc(70 / 1200 * 100%) 50px;
}
#period-article .pagenav__list li {
	position: relative;
	padding: 20px 0;
}
#period-article .pagenav__list li a {
	position: relative;
	display: block;
	/* color: var(--color-text-blue); */
	font-weight: 500;
	padding-left: 40px;
}
#period-article .pagenav__list li a::before {
	content: "";
	position: absolute;
	top: 6px;
	left: 0;
	width: 24px;
	height: 24px;
	background: var(--color-text-pink);
	border-radius: 50% 50%;
}
#period-article .pagenav__list li a::after {
	content: "";
	position: absolute;
	top: 6px;
	left: 0;
	width: 24px;
	height: 24px;
	background: var(--color-white);
	mask: url("../images/icon_arrow_01.svg") center center / 12px auto no-repeat;
	transform: rotate(90deg);
}
@media (any-hover: hover) {
	#period-article .pagenav__list li a {
		transition: color .3s ease;
	}
	#period-article .pagenav__list li a:hover {
		color: var(--color-text-pink);
	}
}
@media screen and (max-width: 680px) {
	#period-article .pagenav__list {
		border: none;
		padding: 0 0;
	}
	#period-article .pagenav__list li a {
		padding-left: 28px;
	}
	#period-article .pagenav__list li a::before {
		width: 18px;
		height: 18px;
	}
	#period-article .pagenav__list li a::after {
		width: 18px;
		height: 18px;
	}
}


/* --------------------------------------------------
	article
-------------------------------------------------- */
#period-article .article {
	padding: 1px 0 120px;
}
#period-article .article.pink {
	background: var(--color-bg-pink2);
}
#period-article .article:last-of-type:not(.pink) {
	padding-bottom: 0;
}
#period-article .article__inner {
	padding: 0 calc(100 / 1200 * 100%);
}
#period-article .article-unit > * + * {
	margin-top: 2.0em;
}
#period-article .article-unit sup {
	font-size: 0.5em;
	top: -1em;
}
#period-article .article-unit .unit-title--h2 {
	font-size: 34px;
	font-weight: 500;
	line-height: 1.8;
	color: var(--color-text-black);
	text-align: center;
	margin: 120px 0 104px;
}
#period-article .article-unit .unit-title--h2 span {
	position: relative;
	display: inline-block;
	color: var(--color-text-pink);
}
#period-article .article-unit .unit-title--h2 span::before {
	content: "";
	position: absolute;
	bottom: 3px;
	left: 0;
	width: 100%;
	height: 1px;
	background: currentColor;
}
#period-article .article-unit .unit-title--h3 {
	position: relative;
	font-size: 24px;
	font-weight: 500;
	line-height: 1.8;
	color: var(--color-text-blue);
	margin: 96px 0 40px;
	padding-left: 15px;
}
#period-article .article-unit .unit-title--h3::before {
	content: "";
	position: absolute;
	top: 0.3em;
	left: 0;
	width: 4px;
	height: calc(100% - 0.6em);
	background: #74A2BF;
	border-radius: 2px 2px;
}
#period-article .article__image img {
	border-radius: 10px 10px;
}
#period-article .article-unit .unit-list.num {
	text-align: left;
	counter-reset: num 0;
	margin-top: 5.0em;
}
#period-article .article-unit .unit-list.num em{
	color: var(--color-text-pink);
}
#period-article .article-unit .unit-list.num > li {
	position: relative;
	padding: 1.5em 2em 1.5em 6.8em;
	border: 2px solid #FFD9DF;
  	border-radius: 10px;
 	margin-top: 15px;
	background: url("../images/icon_smile.svg") no-repeat 40px 28px #fff;
}
#period-article .article-unit .unit-list.num > li::before {
	content: counter(num)".";
	position: absolute;
	top: 1.5em;
  	left: 4.5em;
	color: var(--color-text-pink);
	font-weight: 500;
	counter-increment: num 1;
}
#period-article .article-unit .mt00 {
	margin-top: 0em;
}
#period-article .article-unit .mt05 {
	margin-top: 0.5em;
}
#period-article .article-unit .mt10 {
	margin-top: 1.0em;
}
#period-article .article-unit .mt15 {
	margin-top: 1.5em;
}
@media screen and (max-width: 680px) {
	#period-article .article {
		padding-bottom: 80px;
	}
	#period-article .article__inner {
		padding: 0 0;
	}
	#period-article .article-unit .unit-title--h2 {
		font-size: 24px;
		margin: 80px 0 48px;
	}
	#period-article .article-unit .unit-title--h3 {
		font-size: 17px;
		margin: 56px 0 32px;
	}
	#period-article .article-unit .unit-title--h3::before {
		width: 3px;
	}
	#period-article .article-unit .unit-list.note {
		font-size: 12px;
	}
	#period-article .article-unit .unit-list.num {
		margin-top: 3.0em;
	}
	#period-article .article-unit .unit-list.num > li {
	padding: 1.0em 1.5em;
 	margin-top: 1.0em;
	background: #fff;
	}
	#period-article .article-unit .unit-list.num > li::before {
		content: none;
	}
}
/* checklist */
#period-article .period__check{
	padding: 20px 10px 0;
}
#period-article .period__check dl + dl {
	margin-top: 15px;
}
#period-article .period__check dt{
	position: relative;
	padding-left: 25px;
	display: inline-block;
	width: 10em;
	font-weight: bold;
	color: var(--color-text-pink);
}
#period-article .period__check dt::before {
  content: '';
  position: absolute;
  top: calc(50% - 7.5px);
  left: 0;
  width: 15px;
  height: 15px;
  background: url("../images/icon_check.png");
  background-size: contain;
}
#period-article .period__check dd{
	display: inline-block;
}
@media screen and (max-width: 680px) {
	#period-article .period__check {
	  padding: 15px 5px 0;
	}
	#period-article .period__check dl {
		font-size: 13px;
	}
	#period-article .period__check dd {
		padding-left: 25px;
	}
}
/* --------------------------------------------------
	localnav
-------------------------------------------------- */
#period-article .pink + .l-localnav {
	margin-top: 0!important;
}
#period-article .l-localnav {
	margin-top: 120px;
	background-color: #F5F5F5;
}
#period-article .l-localnav .l-localnav__inner {
	padding: 80px calc(100 / 1200 * 100%);
}
#period-article .l-localnav .l-localnav__category {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 40px 50px;
}
#period-article .l-localnav li {
	position: relative;
}
#period-article .l-localnav li a {
	position: relative;
	display: block;
	font-weight: 500;
	padding-left: 40px;
	min-height: 80px;
	padding-bottom: 20px;
}
#period-article .l-localnav li a::before {
	content: "";
	position: absolute;
	top: 6px;
	left: 0;
	width: 24px;
	height: 24px;
	background: var(--color-text-pink);
	border-radius: 50% 50%;
}
#period-article .l-localnav li a::after {
	content: "";
	position: absolute;
	top: 6px;
	left: 0;
	width: 24px;
	height: 24px;
	background: var(--color-white);
	mask: url("../images/icon_arrow_01.svg") center center / 12px auto no-repeat;
}
@media (any-hover: hover) {
	#period-article .l-localnav li a {
		transition: color .3s ease;
	}
	#period-article .l-localnav li a:hover {
		color: var(--color-text-pink);
	}
}
@media screen and (max-width: 680px) {
	#period-article .l-localnav {
		margin-top: 100px;
	}
	#period-article .l-localnav .l-localnav__inner {
		padding-top: 20px;
		padding-bottom: 40px;
	}
	#period-article .l-localnav .l-localnav__category {
		display: block;
	}
	#period-article .l-localnav li a {
		padding-left: 28px;
		padding-top: 20px;
		min-height: initial;
	}
	#period-article .l-localnav li a::before {
		top: 26px;
		width: 18px;
		height: 18px;
	}
	#period-article .l-localnav li a::after {
		top: 26px;
		width: 18px;
		height: 18px;
	}
}