@charset "UTF-8";

/* ===============================================
 base
=============================================== */

:root {
	--txt-base-color: #4d4d4d;
	--title-base-color: #000;
	--bk-base-color: #ecedef;
	--corporate-color: #4cbca6;
}
body {
	font-family: "Noto Sans JP", sans-serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
	font-size: 16px;
	font-size: 1rem;
	line-height: 1.5;
	font-feature-settings: "palt";
	color: var(--txt-base-color);
	position: relative;
	-webkit-print-color-adjust: exact;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
* {
	box-sizing: border-box;
	font-family: inherit;
	font-size: inherit;
	line-height: inherit;
}
::after, ::before {
	box-sizing: inherit;
}
a, abbr, address, article, aside, audio, blockquote, body, canvas, caption, cite, code, dd, del, details, dfn, div, dl, dt, em, fieldset, figcaption, figure, footer, form, h1, h2, h3, h4, h5, h6, header, hgroup, html, iframe, img, ins, label, legend, li, main, mark, nav, ol, p, pre, q, section, small, span, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, time, tr, ul, video {
	padding: 0;
	margin: 0;
	border: 0;
}
a {
	outline: 0;
	-webkit-touch-callout: none;
	text-decoration: none;
}
a:hover {
	text-decoration: none;
}
:focus, a:focus {
	outline: 0;
}
a, a:visited {
	color: inherit;
}
article, aside, footer, header, main, nav, section {
	display: block;
}
ol, ul {
	list-style: none;
}

img, video {
	max-width: 100%;
}
img {
	vertical-align: top;
	border-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote::after, blockquote::before, q::after, q::before {
	content: none;
}
[hidden] {
	display: none !important;
}
[disabled] {
	cursor: not-allowed;
}
:focus:not(:focus-visible) {
	outline: 0;
}
input[type=date], input[type=email], input[type=number], input[type=password], input[type=tel], input[type=text], input[type=time], textarea {
	-webkit-appearance: none;
	-webkit-tap-highlight-color: transparent;
}
textarea {
	display: block;
}
fieldset {
	margin: 0;
	border: none;
}
legend {
	display: none;
}
table {
	border-spacing: 0;
	border-collapse: collapse;
}
[v-cloak] {
	display: none;
}

/* ===============================================
 common
=============================================== */

/* br for PC/SP
----------------------- */
.br_pc {
	display: inline !important;
}
.br_sp {
	display: none !important;
}
@media screen and (max-width: 767px) {
	.br_pc {
		display: none !important;
	}
	.br_sp {
		display: inline !important;
	}
}

/* wrap_inner
----------------------- */
.wrap_inner {
	max-width: 1100px;
	margin: 0 auto;
	padding: 0 50px;
}
@media screen and (max-width: 767px) {
	.wrap_inner {
		max-width: 100%;
		padding: 0 4vw;
	}
}

/* ===============================================
 header
=============================================== */

header {
	width: 100%;
	background-color: var(--bk-base-color);
	padding: 40px 0;
}
header div img {
	display: block;
	width: 266px;
	margin: 0 auto;
}
@media screen and (max-width: 767px) {
	header {
		padding: 20px 0;
	}
	header div img {
		width: 140px;
	}
}

/* ===============================================
 footer
=============================================== */

footer {
	background-color: var(--bk-base-color);
}

/* totop
----------------------- */
footer .pagetop {
	display: none;
}
@media screen and (max-width: 767px) {
	footer .pagetop {
		display: block;
		background-color: var(--corporate-color);
		width: 100%;
		height: 10.666vw;
		text-align: center;
		position: relative;
	}
	footer .pagetop span {
		position: absolute;
		left: 50%;
		transform: translate(-50%, 0);
		bottom: calc(50% - 3.6vw);
		color: #fff;
		font-size: 10px;
		font-size: 2.666vw;
		font-weight: 700;
	}
	footer .pagetop span::before {
		content: "";
		position: absolute;
		left: 50%;
		top: -3px;
		width: 12px;
		height: 12px;
		border-top: 1px solid #fff;
		border-right: 1px solid #fff;
		transform: translate(-50%, -50%) rotate(-45deg);
	}
}

/* footer_inner
----------------------- */
.footer_inner {
	padding: 90px 0 75px;
	text-align: center;
}
.footer_logo img {
	display: block;
	width: 266px;
	margin: 0 auto 50px;
}
.copyright {
	font-family: "Yu Gothic","游ゴシック",YuGothic,sans-serif;
	font-size: 14px;
	font-size: 0.875rem;
}
@media screen and (max-width: 767px) {
	.footer_inner {
		padding: 12vw 0 10vw;
	}
	.footer_logo img {
		width: 140px;
		margin: 0 auto 6.666vw;
	}
	.copyright {
		font-size: 8px;
		font-size: 0.5rem;
	}
}

/* ===============================================
 top
=============================================== */

.sec_top {
	background-color: #fff;
	padding: 60px 0;
	text-align: center;
}
.sec_top h1 {
	font-size: 48px;
	font-size: 3rem;
	font-weight: 900;
	color: var(--title-base-color);
}
@media screen and (max-width: 910px) {
	.sec_top h1 {
		font-size: 5.4vw;
	}
}
@media screen and (max-width: 767px) {
	.sec_top {
		padding: 30px;
	}
	.sec_top h1 {
		font-size: 27px;
		font-size: 1.6875rem;
		line-height: 1.4;
	}
}

/* ===============================================
 block01
=============================================== */

.sec_block01 {
	background-color: #fff0f5;
	padding: 100px 0;
}
.sec_block01 p {
	font-size: 22px;
	font-size: 1.375rem;
	color: var(--title-base-color);
	margin: 80px 0;
}
.wrap_inner_1200 {
	width: 1200px;
	margin: 0 auto;
}
.wrap_inner_1200_2 {
	width: 1200px;
	margin: 0 auto;
}
@media screen and (max-width: 767px) {
	.sec_block01 {
		padding: 20px 0 50px;
	}
	.sec_block01 p {
		font-size: 14px;
		font-size: 0.875rem;
		margin: 40px 0;
	}
	.wrap_inner_1200 {
		width: 100%;
		padding: 0 4vw;
	}
	.wrap_inner_1200_2 {
		width: 100%;
		padding: 0;
	}
}

/* ===============================================
 block02
=============================================== */

.sec_block02 {
	background-color: #fff;
	padding: 100px 0 20px;
}
.block02_box {
	display: flex;
	justify-content: space-between;
}
.sec_block02 h2 {
	font-size: 32px;
	font-size: 2rem;
	font-weight: 700;
	color: #f4545a;
	margin: 100px 0 0;
}
.sec_block02 p {
	font-size: 16px;
	font-size: 1rem;
	color: var(--title-base-color);
	margin: 30px 0 100px;
}
.sec_block02 p.sponsorship {
	font-size: 12px;
	font-size: 0.75rem;
	margin: 10px auto 0;
	text-align: right;
}
.sec_block02 ul {
	display: flex;
	justify-content: space-between;
}
.sec_block02 li {
	width: 54%;
}
.sec_block02 li:nth-child(2) {
	width: 46%;
}
.sec_block02 img {
	width: 100%;
	margin: 0 auto;
}
@media screen and (max-width: 767px) {
	.sec_block02 {
		padding: 25px 0 20px;
	}
	.block02_box {
		display: block;
	}
	.sec_block02 h2 {
		font-size: 20px;
		font-size: 1.25rem;
		margin: 30px 0 0;
	}
	.sec_block02 p {
		font-size: 14px;
		font-size: 0.875rem;
		margin: 15px 0 30px;
	}
	.sec_block02 p.sponsorship {
		text-align: left;
	}
	.block02_box > li ul {
		margin: 10px 0 0;
	}
	.block02_box > li ul li {
		font-size: 14px;
		font-size: 0.875rem;
	}
	.sec_block02 ul {
		display: block;
	}
	.sec_block02 li {
		width: 100%;
		margin: 25px 0 0;
	}
	.sec_block02 li:nth-child(2) {
		width: 95%;
		margin: 0 auto;
		padding: 20px 0 10px;
	}
}

/* ===============================================
 block03
=============================================== */

.sec_block03 {
	background-color: #fff0f5;
	padding: 0 0 100px;
}
.sec_block03 h2 {
	background-color: #f4545a;
	width: 100%;
	margin: 0 auto;
	padding: 15px 0;
	font-size: 30px;
	font-size: 1.875rem;
	font-weight: 500;
	line-height:70px;
	color: #fff;
	text-align: center;
}
.sec_block03 p {
	font-size: 24px;
	font-size: 1.5rem;
	font-weight: 500;
	color: var(--title-base-color);
	margin: 100px auto 50px;
	text-align: center;
}
.sec_block03 ul {
	display: flex;
	justify-content: space-between;
}
.sec_block03 li {
	width: 47%;
}
.sec_block03 img {
	width: 100%;
	margin: 0 auto;
}
.sec_block03 ul {
	display: flex;
	justify-content: flex-start;
	flex-wrap: wrap;
	width: 100%;
	margin: 0 auto 100px;
}
.sec_block03 li {
	width: 24%;
	margin: 0 1.3% 0 0;
}
.sec_block03 li:nth-child(4n) {
	margin: 0;
}
.sec_block03 li p {
	font-size: 16px;
	font-size: 1rem;
	color: var(--txt-base-color);
	margin: 10px 0 0;
}
.sec_block03 .variations_box {
	background-color: #fff;
	margin: 0 auto;
	padding: 2% 4% 4%;
}
.sec_block03 .variations_box p {
	font-size: 24px;
	font-size: 1.5rem;
	font-weight: 500;
	color: var(--title-base-color);
	margin: 10px auto 40px;
	text-align: center;
}
@media screen and (max-width: 767px) {
	.sec_block03 {
		padding: 0 0 13.333vw;
	}
	.sec_block03 h2 {
		width: 100%;
		font-size: 18px;
		font-size: 1.125rem;
		line-height:1.5;
		padding: 20px 0;
	}
	.sec_block03 p {
		font-size: 14px;
		font-size: 0.875rem;
		margin: 40px auto 30px;
		text-align: center;
	}
	.sec_block03 ul {
		margin: 0 auto 40px;
	}
	.sec_block03 li p {
		font-size: 10px;
		font-size: 0.625rem;
		margin: 5px 0 0;
	}
	.sec_block03 .variations_box {
		padding: 5px 10px 25px;
	}
	.sec_block03 .variations_box p {
		font-size: 14px;
		font-size: 0.875rem;
		margin: 20px 0;
		text-align: center;
	}
}

/* ===============================================
 links
=============================================== */

.sec_links {
	background-color: #fff;
	padding: 0 0 70px;
}
.sec_links h2 {
	width: 100%;
	display: block;
	padding: 60px 0 0;
	font-size: 32px;
	font-size: 2rem;
	font-weight: 400;
	color: var(--title-base-color);
	text-align: center;
}
.sec_links nav {
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 660px;
	margin: 45px auto 0;
}
.sec_links nav a {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 300px;
	height: 68px;
	border-radius: 68px;
	font-size: 22px;
	font-size: 1.375rem;
	font-weight: 400;
	text-decoration: none;
	transition: all 250ms ease;
	position: relative;
}
.sec_links nav a.btn_contact {
	background-color: var(--corporate-color);
	color: #fff;
	border: 1px solid var(--corporate-color);
}
.sec_links nav a.btn_contact::after {
	content: "";
	position: absolute;
	top: calc(50% - 5px);
	right: 22px;
	width: 10px;
	height: 10px;
	border-right: 2px solid #fff;
	border-top: 2px solid #fff;
	transform: rotate(45deg);
	transition: all 250ms ease;
}
.sec_links nav a.btn_contact:hover {
	background-color: #fff;
	color: var(--corporate-color);
}
.sec_links nav a.btn_contact:hover::after {
	border-right: 2px solid var(--corporate-color);
	border-top: 2px solid var(--corporate-color);
}
.sec_links nav a.btn_pdf {
	background-color: #fff;
	color: #000;
	border: 1px solid #e6e6e6;
}
.sec_links nav a.btn_pdf::after {
	background: url("../images/icon_blank.svg") no-repeat left top;
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	right: 22px;
	width: 12px;
	height: 12px;
	margin: auto;
	transition: all 250ms ease;
}
.sec_links nav a.btn_pdf:hover {
	background-color: #3e3e3e;
	color: #fff;
	border: 1px solid #3e3e3e;
}
.sec_links nav a.btn_pdf:hover::after {
	background: url("../images/icon_blank_white.svg") no-repeat left top;
}
@media screen and (max-width: 767px) {
	.sec_links {
		padding: 0 0 10vw;
	}
	.sec_links h2 {
		padding: 8vw 0 0;
		font-size: 16px;
		font-size: 1rem;
	}
	.sec_links nav {
		width: 315px;
		margin: 5.333vw auto 0;
	}
	.sec_links nav a {
		width: 150px;
		height: 38px;
		border-radius: 38px;
		font-size: 12px;
		font-size: 0.75rem;
		line-height: 38px;
	}
	.sec_links nav a.btn_contact::after {
		top: calc(50% - 4px);
		right: 14px;
		width: 8px;
		height: 8px;
		border-right: 1px solid #fff;
		border-top: 1px solid #fff;
	}
	.sec_links nav a.btn_contact:hover::after {
		border-right: 1px solid var(--corporate-color);
		border-top: 1px solid var(--corporate-color);
	}
	.sec_links nav a.btn_pdf::after {
		right: 14px;
		width: 12px;
		height: 12px;
	}
}

/* +++ */

