@charset "UTF-8";
/*****************************
 変数 
 *****************************/
:root {
	--primary-white: #fefefe;
	--footer-gray: #e8e8e8;
	--background-gray: #f9f9f9;
	--text-color--darkgray: #333333;
	--text-color--black: #000000;
	--primary-blue: #42bce4;
	--primary-hoge: #01050a;
	--color--ranking1: #0062b8;
	--color--ranking2: #e29898;
	--color--ranking3: #855a5a;
	--color--ranking4: #252323;
	--button-color--blue: #1946c3;
	--width-short: 57vw;
	--width-1320: 80vw;
	--primary-gap--pc: 30px;
	--button-color--orange: #ff3100;
	--bg-blue: #e7eef3;
	--title--blue: #002daa;
	--border-top: 8px solid #1968c3;
}
/*****************************
 common 
 *****************************/

.ranking__title {
	font-weight: bold;
	font-size: 2rem;
	margin-right: 20px;
}
.ranking__color1 {
	color: var(--color--ranking1);
}
.ranking__color2 {
	color: var(--color--ranking2);
}
.ranking__color3 {
	color: var(--color--ranking3);
}
.ranking__color4 {
	color: var(--color--ranking4);
}

h2 {
	display: block;
	margin: 64px auto 30px auto;
	font-size: 5rem;
	width: auto;
	border-top: solid 1px var(--primary-hoge);
	color: var(--primary-hoge);
	line-height: 1.3;
}
@media (max-width: 767px) {
	h2 {
		display: block;
		margin: 50px auto 0 auto;
		font-size: 3rem;
		width: auto;
		border-top: solid 1px var(--primary-hoge);
		color: var(--primary-hoge);
		line-height: 1.5;
	}

	body {
		background-color: var(--background-gray, #f9f9f9);
		font-family: "Noto Sans JP", sans-serif;
		width: 100%;
	}
}
h3 {
	font-size: 3rem;
}
h4 {
	display: block;
	font-size: 1.8rem;
	margin: 15px 15px 0 0;
	color: var(--primary-blue);
	line-height: 1.4;
}

.marking {
	display: block;
	font-size: 1.3rem;
	color: red;
	line-height: 1.5;
	margin: 5px auto 30px auto;
}
.link {
	display: block;
	font-size: 1.5rem;
	color: var(--button-color--blue);
	line-height: 1.5;
	margin: 20px auto;
}
.section__wrap--1439px,
.section__wrap--926px {
	padding: 0 20px 0 20px;
}
@media (max-width: 1024px) {
	.section__wrap--1439px,
	.section__wrap--926px {
		padding: 0 7px 0 7px;
	}
}
.textsize {
	display: inline-block;
	font-size: 2.5rem;
	margin: 7px auto;
}
a {
	color: var(--text-color--darkgray);
}
.link__img::after {
	content: "";
	border-left: 1px solid var(--text-color--darkgray);
	position: absolute;
	right: 0;
}
.dela-gothic-one-regular {
	font-family: "Dela Gothic One", sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: 2.5rem;
	line-height: 1.5;
}

.shippori-mincho-b1-regular {
	font-family: "Shippori Mincho B1", serif;
	font-weight: 400;
	font-style: normal;
	font-size: 2.5rem;
	line-height: 1.5;
}

.comingsoon {
	font-size: 3.5rem;
	font-weight: 600;
	margin: 0 auto;
}
.strong {
	font-weight: bold;
}

/*****************************
animation
 *****************************/
.blink {
	animation: blink 2s ease-in-out alternate;
	animation-iteration-count: infinite;
	color: var(--primary-blue);
}

@keyframes blink {
	0% {
		color: var(--primary-blue);
	}
	50% {
		color: var(--text-color--darkgray);
	}
	100% {
		color: var(--primary-blue);
	}
}

.comingSoon__animationArea {
	width: 100%;
	height: 200px;
	position: relative;
}
.comingSoon__animationPosition {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

.x__maincontent--wrap {
	display: block;
}

.x__link--position {
	margin: 20px auto;
}

.survay {
	background-color: var(--primary-white);
	border: solid 2px var(--text-color--black);
	line-height: 2;
	margin: 30px auto;
	text-align: center;
	width: 80%;
}
@media (max-width: 767px) {
	.x__maincontent--wrap {
		display: block;
	}
}
.x__kaitozyoukyouBox--survay {
	display: flex;
	margin: 30px auto 0 auto;
	width: auto;
	position: relative;
}

/*****************************
date
 *****************************/
.dateTimeSwitching {
	display: none;
}
/*****************************
header__nav
 *****************************/

.header__wrap {
	display: flex;
	padding: 8px 20px;
	background-color: var(--background-gray);
}

.header__logo {
	object-fit: contain;
	width: 90%;
	padding: 19px;
}

.header__cta-btn--wrap {
	margin: auto 0 auto auto;
	height: 100%;
	position: relative;
	overflow: hidden;
}
.header__cta-btn--wrap a {
	position: relative;
}
.header__cta-btn--wrap a::before,
.header__cta-btn--wrap a::after,
.header__cta-btn--wrap::before,
.header__cta-btn--wrap::after {
	content: "";
	position: absolute;
	background: var(--button-color--orange);
	z-index: 1;
}
.header__cta-btn--wrap::before {
	top: 0;
	left: 0px;
	width: 400px;
	height: 2px;
	animation: topAnim 1s linear 0.5s infinite;
}
.header__cta-btn--wrap::after {
	top: -200px;
	right: 0;
	width: 2px;
	height: 150px;
	animation: rightAnim 1s linear 0s infinite;
}

.header__cta-btn--wrap a::before {
	bottom: 2px;
	right: 0px;
	width: 400px;
	height: 2px;
	animation: bottomAnim 1s linear 0.5s infinite;
}
.header__cta-btn--wrap a::after {
	bottom: -200px;
	left: 0;
	width: 2px;
	height: 150px;
	animation: leftAnim 1s linear 0s infinite;
}

@keyframes topAnim {
	0% {
		left: -400px;
	}
	100% {
		left: 700px;
	}
}
@keyframes rightAnim {
	0% {
		top: -150px;
	}
	100% {
		top: 100px;
	}
}
@keyframes bottomAnim {
	0% {
		right: -400px;
	}
	100% {
		right: 700px;
	}
}
@keyframes leftAnim {
	0% {
		bottom: -150px;
	}
	100% {
		bottom: 100px;
	}
}
.hedder__btn {
	width: 100%;
	height: 100%;
}

@media (min-width: 768px) {
	.header__cta-btn--wrap:hover {
		cursor: pointer;
	}
}

.toTopBtn {
	position: fixed;
	content: "";
	z-index: 1000;
	width: 40px;
	height: 40px;
	right: 40px;
	bottom: 20px;
	background-color: rgba(255, 255, 255, 0);
	border-radius: 50%;
	transition: 0.4s;
}
.toTopBtn::before {
	position: absolute;
	content: "";
	width: 12px;
	height: 12px;
	border-left: solid 4px var(--text-color--darkgray);
	border-top: solid 4px var(--text-color--darkgray);
	transform: rotate(45deg);
	right: 12px;
	bottom: 10px;
	transition: 0.4s;
}

@media (min-width: 768px) and (max-width: 1439px) {
	.header__cta-btn--wrap {
		cursor: pointer;
	}
	.header__cta-btn--cta-taxt {
		color: var(--text-color--black);
		font-weight: bold;
	}

	.header__cta-btn--cta-taxt::after {
		border-top: solid 2px var(--text-color--black);
		transform: rotate(-360deg);
	}
	.header__cta-btn--cta-taxt::before {
		content: "";
		display: inline-block;
		width: 40px;
		height: 40px;
		border-top: solid 2px var(--text-color--black);
		transform: rotate(-395deg);
	}
}
@media (max-width: 767px) {
	.header__wrap {
		display: block;
		padding: 0;
		width: 100%;
	}

	.header__logo {
		display: block;
		object-fit: contain;
		width: 40%;
		margin: 0 auto;
		padding: 10px 0;
	}

	.header__cta-btn--wrap {
		display: none;
	}
}

.down {
	display: inline-block;
	height: auto;
	animation: downanimation 1.5s infinite;
}

@keyframes downanimation {
	0% {
		transform: translateY(-2px);
	}
	60% {
		transform: translateY(2px);
	}
	100% {
		transform: translateY(-2px);
	}
}
/*****************************
main
 *****************************/

html {
	font-size: 10px;
	scroll-behavior: smooth;
	width: 100%;
	margin: 0;
	padding: 0;
	overflow-x: hidden; /* 横スクロールを防ぐ */
}
body {
	background-color: var(--background-gray, #f9f9f9);
	font-family: "Noto Sans JP", sans-serif;
	width: 100%;

	text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%;
}

main {
	display: flex;
}

.content {
	flex-basis: 75vw;
	padding-right: 0%;
	width: 65%;
}
@media (max-width: 1439px) {
	main {
		display: block;
	}

	.content {
		padding-right: 0%;
		width: 100%;
	}
}
h1 {
	font-size: 14rem;
}
@media (min-width: 768px) and (max-width: 1439px) {
	h1 {
		font-size: 1rem;
		line-height: 1;
	}
}
.siraberu {
	position: absolute;
	right: 20px;
}

/*****************************
aside
 *****************************/
aside {
	flex-basis: 25vw;
}
.aside__sticky {
	position: sticky;
	top: 80px;
	z-index: 1000;
}

.aside__wrap {
	margin-top: 300px;
	position: relative;
	height: auto;
}
.aside__wrap ul {
	margin-left: 20%;
}
.aside__wrap ul a:visited {
	color: var(--text-color--darkgray);
}
.aside__wrap ul a:link {
	color: var(--text-color--darkgray);
}

.aside__text {
	color: var(--text-color--darkgray);
	font-size: 1.8rem;
	line-height: 1.3;
	margin-top: 28px;
	text-decoration: underline 2px;
	text-underline-offset: 2px;
	transition: 0.2s;
}

@media (min-width: 768px) {
	.aside__wrap ul li a:hover {
		color: var(--button-color--blue);
		transition-duration: 0.4s;
	}
}
.aside__cta-btn {
	display: block;
	position: absolute;
	border: none;
	border-radius: 5px;
	margin-top: 16px;
	width: 220px;
	height: 47px;
	transition: 0.4s;
}
.aside__cta-btn--text:link {
	font-size: 1.1.8rem;
	color: var(--text-color--darkgray);
	text-decoration: none;
	padding-left: 30px;
}

.aside__cta-btn--text::before {
	content: "";
	display: inline-block;
	z-index: 150;
	width: 150px;
	height: 75px;
	background-image: url("../images/sankokaitorei_logo.png");
	background-size: contain;
	background-repeat: no-repeat;
	position: absolute;
	margin: -10px 0 0 0;
	transition: 0.2s;
}
.aside__cta-btn::after {
	content: "";
	display: inline-block;
	width: 13px;
	height: 99px;
	border-right: solid 2px var(--text-color--black);
	position: absolute;
	bottom: 6px;
	right: 26px;
	transition: 0.2s;

	animation: aside_downAnimation 2s infinite;
}
.aside__cta-btn::before {
	content: "";
	display: inline-block;
	width: 20px;
	height: 20px;
	border-right: solid 2px var(--text-color--black);
	position: absolute;
	bottom: 9px;
	right: 20px;
	transition: 0.2s;
	animation: aside_downAnimation_deg 2s infinite;
}

@keyframes aside_downAnimation {
	0% {
		transform: translateY(0px);
	}
	50% {
		transform: translateY(18px);
	}
	100% {
		transform: translateY(0px);
	}
}
@keyframes aside_downAnimation_deg {
	0% {
		transform: translateY(0px) rotate(30deg);
	}
	50% {
		transform: translateY(18px) rotate(30deg);
	}
	100% {
		transform: translateY(0px) rotate(30deg);
	}
}

@media (min-width: 768px) and (max-width: 1439px) {
	aside {
		display: none;
	}
}
@media (max-width: 767px) {
	aside {
		display: none;
	}
}
/*****************************
article
 *****************************/

.article {
	position: relative;
	contain: "";
	width: auto;
	height: 900px;
	position: relative;
}

.article__container--bg {
	position: absolute;
	width: 100%;
	height: 800px;
	bottom: 0;
	background-image: url(../images/bgPc.jpg);
	background-repeat: no-repeat;
	background-size: contain;
	background-position: bottom left;
	z-index: -1;
	opacity: 1;
	mix-blend-mode: multiply;
}

.article__container--title-wrap {
	z-index: 150;
	position: absolute;
	left: -22%;
	top: 90px;
}
.section__top-container--subtitle {
	font-size: 4.5rem;
	color: var(--title--blue);
	vertical-align: middle;
	position: absolute;
	left: 0%;
	top: -50px;
	font-weight: 900;
}
.summary {
	font-size: 2.6rem;
	line-height: 1.4;
	margin: 20px 0;
	background-color: var(--background-gray);
	width: fit-content;
	padding: 8%;
	transform: translate(500px, 10px);
	position: absolute;
	left: -15%;
}
.comingSoon {
	display: flex;
	align-items: center;
	margin: 0 10%;
	padding: 20px;
}

.summary__btnWrap {
	display: block;
	width: 100%;
	position: relative;
	height: 150px;
	animation: btn_animation 1s infinite;
}
.summary__btn {
	display: block;
	background-image: radial-gradient(50% 95%, #ff6b16, #cd1212);
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.5), 0 2px 10px rgba(230, 35, 21, 0.7),
		inset 0 0 10px #cd1212;

	border-radius: 15px;
	width: 800px;
	font-size: 3rem;
	font-weight: 600;
	letter-spacing: 0.4rem;
	color: var(--primary-white);
	padding: 40px 40px 27px 40px;
	line-height: 1.4;
	position: absolute;
	top: 43px;
	left: 50%;
	transform: translateX(-50%);
}
.summary__btn::after {
	content: "";
	width: 1.25em;
	height: 1.25em;
	margin-left: 8px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M10 6V8H5V19H16V14H18V20C18 20.5523 17.5523 21 17 21H4C3.44772 21 3 20.5523 3 20V7C3 6.44772 3.44772 6 4 6H10ZM21 3V11H19L18.9999 6.413L11.2071 14.2071L9.77689 12.7929L17.5849 5H13V3H21Z' fill='%23fff'%3E%3C/path%3E%3C/svg%3E");
	background-repeat: no-repeat;
	position: absolute;
}

.hightlight {
	display: block;
	background-image: linear-gradient(
		rgba(250, 250, 255, 1) 0%,
		rgba(250, 250, 255, 0.7) 10%,
		rgba(250, 250, 255, 0) 100%
	);
	width: 870px;
	height: 50px;
	border-radius: 15px;
	z-index: 1;
	top: 46px;
	left: 50%;
	transform: translateX(-50%);
	position: absolute;
}
@media (min-width: 426px) and (max-width: 1023px) {
	.hightlight {
		display: block;
		background-image: linear-gradient(
			rgba(250, 250, 255, 1) 0%,
			rgba(250, 250, 255, 0.7) 10%,
			rgba(250, 250, 255, 0) 100%
		);
		width: 95%;
		height: 50px;
		border-radius: 15px;
		z-index: 1;
		top: 46px;
		left: 50%;
		transform: translateX(-50%);
		position: absolute;
	}
}
@media (max-width: 425px) {
	.hightlight {
		display: block;
		background-image: linear-gradient(
			rgba(250, 250, 255, 1) 0%,
			rgba(250, 250, 255, 0.7) 10%,
			rgba(250, 250, 255, 0) 100%
		);
		width: 95%;
		height: 50px;
		border-radius: 15px;
		z-index: 1;
		top: 46px;
		left: 50%;
		transform: translateX(-50%);
		position: absolute;
	}
}

.summaru__btn--sub {
	display: block;
	background-color: var(--primary-white);
	border: 2px solid var(--button-color--orange);
	width: 500px;
	font-size: 2.5rem;
	font-weight: bold;
	letter-spacing: 0.2rem;
	color: var(--button-color--orange);
	padding: 20px 40px;
	line-height: 1.2;
	border-radius: 100vh;
	z-index: 2;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	position: absolute;
}

@media (max-width: 767px) {
	.summary__btn {
		display: block;
		background-image: radial-gradient(50% 95%, #ff6b16, #cd1212);
		box-shadow: 0 2px 6px rgba(0, 0, 0, 0.5),
			0 2px 10px rgba(230, 35, 21, 0.7),
			inset 0 0 10px rgba(126, 44, 33, 0.6);
		border-radius: 15px;
		width: 100%;
		font-size: 3rem;
		font-weight: 600;
		letter-spacing: 0.4rem;
		color: var(--primary-white);
		padding: 40px 40px 27px 40px;
		line-height: 1.4;
		position: absolute;
		top: 43px;
		left: 50%;
		transform: translateX(-50%);
	}

	.index__item a:link {
		color: var(--primary-white);
	}
}
@media (max-width: 425px) {
	.summary__btnWrap {
		height: 210px;
	}
	.summary__btn {
		width: 100%;
		top: 70px;
	}
	.summaru__btn--sub {
		width: 80%;
	}
}

@media (min-width: 768px) and (max-width: 1439px) {
	h1 {
		font-size: 13rem;
		background-position: 0% 5%;
		background-color: rgba(255, 255, 255, 0.15);
		backdrop-filter: blur(9px);
		-webkit-backdrop-filter: blur(9px);
		border: 1px solid rgba(255, 255, 255, 0.2);
		box-shadow: 0 4px 8px rgba(64, 78, 84, 0.2);
	}
}

@media (min-width: 768px) and (max-width: 1439px) {
	.article__container--bg {
		position: absolute;
		width: 100%;
		height: 700px;
		bottom: 0;
		background-image: url("../images/bgPc.jpg");
	}

	.article__container--title-wrap {
		z-index: 150;
		position: absolute;
		left: 20px;
		top: 100px;
	}
	.section__top-container--subtitle {
		font-size: 6rem;
		color: var(--title--blue);
		top: -85px;
		font-weight: 900;
	}
	.summary {
		font-size: 2.6rem;
		line-height: 1.4;
		margin: 20px 0;
		background-color: var(--background-gray);
		width: fit-content;
		padding: 6%;
		transform: translate(380px, 10px);
	}
}
@media (min-width: 1440px) and (max-width: 2559px) {
	.article {
		width: 100%;
		height: 700px;
		position: relative;
		width: auto;
		background-color: rgba(255, 255, 255, 0);
	}
}
@media (min-width: 1024px) and (max-width: 1439px) {
	.article {
		width: 100%;
		height: 700px;
		position: relative;
		width: auto;
		background-color: rgba(255, 255, 255, 0);
	}
}
@media (min-width: 768px) and (max-width: 1023px) {
	.article {
		width: 100%;
		height: 500px;
		position: relative;
		width: auto;
		background-color: rgba(255, 255, 255, 0);
	}
}
@media (min-width: 376px) and (max-width: 767px) {
	.article {
		width: 100%;
		height: 500px;
		position: relative;
		width: auto;
		background-color: rgba(255, 255, 255, 0);
	}
}
@media (min-width: 321px) and (max-width: 375px) {
	.article {
		width: 100%;
		height: 500px;
		position: relative;
		width: auto;
		background-color: rgba(255, 255, 255, 0);
	}
}
@media (max-width: 320px) {
	.article {
		width: 100%;
		height: 450px;
		position: relative;
		width: auto;
		background-color: rgba(255, 255, 255, 0);
	}
}
@media (min-width: 426px) and (max-width: 767px) {
	.article {
		width: 100%;
		position: relative;
		width: auto;
		height: 600px;
		background-color: rgba(255, 255, 255, 0);
	}
	.article__container--bg {
		position: absolute;
		width: 100%;
		height: 100%;
		bottom: 0;
		background-image: url("../images/bgSp.jpg");
		background-repeat: no-repeat;
		background-size: contain;
		background-position: bottom left;
		mix-blend-mode: multiply;
	}
	.comingSoon {
		display: block;
		align-items: center;
		justify-content: center;
		margin: 0 auto;
	}
}
@media (max-width: 425px) {
	.article {
		width: 100%;
		height: 500px;
		position: relative;
	}
	.article__container--bg {
		position: absolute;
		width: 100%;
		height: 100%;
		bottom: 0;
		z-index: -1;
		background-image: url("../images/bgSp.jpg");
		background-repeat: no-repeat;
		background-size: contain;
		background-position: bottom left;
		mix-blend-mode: multiply;
	}
	.comingSoon {
		display: block;
		align-items: center;
		justify-content: center;
		margin: 0 auto;
	}
}

@media (max-width: 767px) {
	.siraberu {
		display: block;
		width: auto;
		height: 150px;
		position: static;
		margin: 0 auto;
	}
	.article__container--title-wrap {
		position: static;
		text-align: center;
		background-color: rgba(255, 255, 255, 0.15);
		backdrop-filter: blur(9px);
		-webkit-backdrop-filter: blur(9px);
		border: 1px solid rgba(255, 255, 255, 0.2);
		box-shadow: 0 4px 8px rgba(64, 78, 84, 0.2);
		width: fit-content;
		margin: 0 auto;
		padding-top: 10px;
	}
	.section__top-container--subtitle {
		font-size: 3.7rem;
		color: var(--title--blue);
		top: -160px;
		line-height: 1;
		position: static;
		font-weight: 900;
	}
	h1 {
		display: inline-block;
		font-size: 9rem;
		text-align: center;
		margin-top: 10px;
	}
	.summary {
		position: static;
		font-size: 1.6rem;
		text-align: center;
		line-height: 1.4;
		margin: 0 auto;
		width: fit-content;
		background-color: var(--primary-white);
		transform: translate(0px, 0px);
	}
}
@media (max-width: 767px) {
	.noneWhenSp {
		display: none;
	}
}
@media (min-width: 768px) {
	.noneWhenTbandPc {
		display: none;
	}
	.visibleWhenTabandPc {
		display: block;
	}
}
@media (max-width: 767px) {
	.iframe {
		display: block;
		justify-content: center;
		margin-top: 30px;
		height: 100%;
		aspect-ratio: 16 / 9;
		width: 100%;
	}
}
@media (min-width: 768px) and (max-width: 1439px) {
	.noneWhenTb {
		display: none;
	}
}
@media (min-width: 1439px) {
	.noneWhenPc {
		display: none;
	}
}
.iframe {
	display: block;
	justify-content: center;
	margin-top: 30px;
	height: 100%;
	aspect-ratio: 16 / 9;
	width: 80vw;
}
/*****************************
index
 *****************************/
.indexBox {
	display: none;
}
.benefitSp {
	display: none;
}

@media (min-width: 768px) and (max-width: 1439px) {
	.indexBox {
		display: flex;
		flex-wrap: nowrap;
		background-color: #1968c3;

		margin: 50px 0 0px;
		padding: 0 10px;
		justify-content: center;
	}
	.index__item {
		width: fit-content;
		height: 100px;
		margin: 0 20px;

		font-size: 2rem;

		text-align: center;
		line-height: 100px;
		color: var(--primary-white);
	}
	.index__item a:visited {
		color: var(--primary-white);
	}
	.index__item a:link {
		color: var(--primary-white);
	}
	.index__item a:hover {
		color: #c7f5e3;
		vertical-align: baseline;
	}
	.benefitSp {
		display: none;
	}
}

@media (max-width: 767px) {
	.indexBox {
		display: grid;
		grid-template-columns: auto auto;
		grid-template-rows: 30px 30px;
		flex-wrap: nowrap;
		background-color: #1968c3;
		gap: 5px 15px;

		margin: 30px auto 0px;
		padding: 10px 0;
		justify-content: center;
	}
	.index__item {
		width: auto;
		height: auto;

		font-size: 1.6rem;

		text-align: center;
		line-height: 30px;
		color: var(--primary-white);
	}
	.index__item a:visited {
		color: var(--primary-white);
	}
}
@media (max-width: 320px) {
	.benefitSp {
		display: block;
		width: 100%;
		height: auto;
		position: fixed;
		bottom: 20px;
		z-index: 1500;
	}
}

/*****************************
X
 *****************************/

.x__maincontent--text {
	font-size: 1.8rem;
	color: var(--text-color--darkgray);
	line-height: 1.5;
	margin-top: 10px;
}

@media (max-width: 767px) {
	.x__maincontent--text {
		font-size: 1.8rem;
		color: var(--text-color--darkgray);
		line-height: 1.5;
		margin-top: 30px;
	}
}

.x__kaitozyoukyouBox {
	display: flex;
	margin: 30px auto 0 auto;
	width: auto;
	overflow: hidden;
	gap: 100px;
	justify-content: center;
}
@media (max-width: 1440px) {
	.x__kaitozyoukyouBox {
		gap: 20px;
	}
}
@media (max-width: 767px) {
	.x__kaitozyoukyouBox {
		display: flex;
		flex-direction: column-reverse;
		margin: 0 auto 0 auto;
	}
}
ol {
	list-style: none;
	position: relative;
	width: 65%;
}
@media (max-width: 767px) {
	ol {
		list-style: none;
		position: relative;
		width: 100%;
	}
}

.x__kaitozyoukyouBox div {
	vertical-align: center;
}
.x__kaitozyoukyouBox div,
.x__kaitozyoukyouBox ol {
	flex-basis: calc(auto / 2);
}

.x__kaitozyoukyouBox--list {
	display: block;
}
/*****************************
 accoedions
 *****************************/
.accordions--lanking {
	max-width: auto;
	width: auto;
	margin-top: 30px;
}

.accordion--lanking {
	width: 100%;
	display: flex;
	flex-direction: column;
	gap: 5px;
	z-index: 1;
}
.accordion__menu--lanking {
	border: 0.5px solid var(--text-color--darkgray);
	position: relative;
	border-radius: 20px;
	max-width: 1000px;
}
.accordion__button--lanking {
	appearance: none;
	text-align: inherit;
	width: 100%;
	border: none;
	background-color: var(--primary-white);
	color: var(--text-color--darkgray);
	padding: 20px;
	border-radius: 20px;
	cursor: pointer;
	font-size: 1.8rem;
}

.buttn__3line {
	font-size: 2rem;
	display: inline-block;
	position: absolute;
	right: 20px;
	top: 21px;
	color: #007bff;
	cursor: pointer;
	pointer-events: auto;
	height: 2rem;
	width: 2rem;
}

.accordion__body--lanking {
	height: 0;
	overflow: hidden;
}
.accordion__text--lanking {
	padding: 20px;
	font-size: 1.4rem;
	line-height: 1.6;
}
@media (max-width: 768px) {
	.accordions--lanking {
		max-width: auto;
		width: 100%;
		margin: 30px 0 0 auto;
	}
	.accordion__button--lanking {
		appearance: none;
		text-align: inherit;
		width: 100%;
		border: none;
		background-color: var(--primary-white);
		color: var(--text-color--darkgray);
		padding: 30px;
		cursor: pointer;
		font-size: 1.8rem;
	}
}

/**********************
pie grath
***********************/

@media (max-width: 767px) {
	.circle__box {
		display: none;
	}
}
.x__link {
	display: block;
	color: var(--text-color--darkgray);
	font-size: 16px;
	text-align: center;
	transition: 0.4s;
}
.x__link::before {
	content: "";
	background-image: url("../images/logo-black.png");
	background-size: contain;
	background-repeat: no-repeat;
	display: inline-block;
	width: 30px;
	height: 30px;
	vertical-align: text-bottom;
	margin-right: 8px;
}
.x__link::after {
	content: "";
	display: inline-block;
	color: var(--text-color--darkgray);
	line-height: 1;
	width: 0;
	height: 0;
	border-style: solid;
	border-color: transparent;
	border-width: 0.375em 0.64952em;
	border-left-color: currentColor;
	border-right: 0;
	margin-left: 6px;
	vertical-align: middle;
	transition: 0.4s;
}
.x__link a {
	text-align: center;
}
.x__link a:visited {
	color: var(--text-color--darkgray);
}
@media (min-width: 768px) {
	.x__link:hover,
	.x__link:hover::after {
		color: var(--button-color--blue);
	}
}
.graph-wrap {
	width: 100%;
	height: 100%;
	margin: auto;
	overflow: hidden;
}
@media (max-width: 767px) {
	.graph-wrap {
		width: 100%;
		height: 100%;
		margin: auto;
	}
}

.circle circle {
	fill: none;
	stroke-width: 5px;
}
.circle {
	transform: rotate(-90deg);
	margin-bottom: 30px;
}
.circle circle:nth-child(1) {
	stroke: var(--color--ranking1);
	stroke-dasharray: 31.7, 68.3;
	stroke-dashoffset: 0;
}
.circle circle:nth-child(2) {
	stroke: var(--color--ranking2);
	stroke-dasharray: 31.1, 68.9;
	stroke-dashoffset: -31.7;
}
.circle circle:nth-child(3) {
	stroke: var(--color--ranking3);
	stroke-dasharray: 19.9, 80.1;
	stroke-dashoffset: -62.8;
}
.circle circle:nth-child(4) {
	stroke: var(--color--ranking4);
	stroke-dasharray: 17.3, 82.7;
	stroke-dashoffset: -82.7;
}

/******************************************
 SOUHYOU
 ******************************************/

.souhyou__article--souhyou {
	display: block;
	margin: 0 auto;
	width: auto;
}

.anser__p {
	color: var(--text-color--darkgray);
	font-size: 1.7rem;
	line-height: 2;
	margin: 40px;
}
.souhyou__point {
	display: block;
	width: var(--width-short);
	margin: 30px 0 0 auto;
	position: relative;
}

@media (max-width: 767px) {
	h3 {
		margin-top: 20px;
		font-size: 2.5rem;
	}
	.souhyou__point {
		display: block;
		width: 100%;
		margin: 30px 0 0 0;
		position: relative;
	}
	.anser__p {
		color: var(--text-color--darkgray);
		font-size: 1.7rem;
		line-height: 1.5;
		margin: 20px 0;
	}
}
/*****************************
 accoedions
 *****************************/
.accordions {
	max-width: auto;
	width: 57vw;
	margin: auto;
}

.accordion {
	width: 100%;
	display: flex;
	flex-direction: column;
	gap: 5px;
}
.accordion__menu {
	border: 0.5px solid var(--text-color--darkgray);
	border-width: 0 0.5px 0.5px 0;
	position: relative;
}
.accordion__button {
	appearance: none;
	text-align: inherit;
	width: 100%;
	border: none;
	background-color: var(--background-gray);
	color: var(--text-color--darkgray);
	padding: 20px 40px 20px 70px;
	cursor: pointer;
	font-size: 1.8rem;
}

.accordion__button::after {
	content: "\039e";
	font-size: 2rem;
	display: inline-block;
	height: 25px;
	position: absolute;
	right: 15px;
	top: 21px;
	color: var(--text-color--darkgray);
}

.icon1::before {
	content: "";
	width: 25px;
	height: 25px;
	z-index: 5;
	background: url("../images/icon1.png") no-repeat left top/contain;
	position: absolute;
	left: 15px;
}
.icon2::before {
	content: "";
	width: 25px;
	height: 25px;
	z-index: 5;
	background: url("../images/icon2.png") no-repeat left top/contain;
	position: absolute;
	left: 15px;
}
.icon3::before {
	content: "";
	width: 25px;
	height: 25px;
	z-index: 5;
	background: url("../images/icon3.png") no-repeat left top/contain;
	position: absolute;
	left: 15px;
}
.icon4::before {
	content: "";
	width: 25px;
	height: 25px;
	z-index: 5;
	background: url("../images/icon4.png") no-repeat left top/contain;
	position: absolute;
	left: 15px;
}
.icon5::before {
	content: "";
	width: 25px;
	height: 25px;
	z-index: 5;
	background: url("../images/icon5.png") no-repeat left top/contain;
	position: absolute;
	left: 15px;
}
.icon6::before {
	content: "";
	width: 25px;
	height: 25px;
	z-index: 5;
	background: url("../images/icon6.png") no-repeat left top/contain;
	position: absolute;
	left: 15px;
}
.icon7::before {
	content: "";
	width: 25px;
	height: 25px;
	z-index: 5;
	background: url("../images/icon7.png") no-repeat left top/contain;
	position: absolute;
	left: 16px;
}

.accordion__body {
	height: 0;
	overflow: hidden;
	transition: all;
}
.accordion__text {
	padding: 20px;
	font-size: 1.7rem;
	line-height: 1.6;
}
@media (max-width: 768px) {
	.accordions {
		max-width: auto;
		width: 100%;
		margin: 30px 0 0 auto;
	}
	.accordion__button {
		appearance: none;
		text-align: inherit;
		width: 100%;
		border: none;
		background-color: var(--background-gray);
		color: var(--text-color--darkgray);
		padding: 20px 40px 20px 50px;
		cursor: pointer;
		font-size: 1.8rem;
	}
}

/*****************************
 SUCHEDULE
 *****************************/
.schedule__frame {
	border-left: solid 1px var(--text-color--darkgray);
	height: 100%;
}
.schedule__grid {
	display: grid;
	gap: 1%;
	grid-template-columns: 180px 42% 42%;
	grid-template-rows: repeat(5, auto);
	grid-template-areas: "a b c" "d e f" "g h i" "j k l" "m n o";
	width: 100%;
	margin: 0 auto 0 0;
}

@media (min-width: 768px) and (max-width: 1439px) {
	.schedule__grid {
		display: grid;
		gap: 1%;
		grid-template-columns: 18% 40% 40%;
		grid-template-rows: repeat(5, auto);
		grid-template-areas: "a b c" "d e f" "g h i" "j k l" "m n o";
		width: 100%;
		margin: 0 auto 0 0;
	}
}
@media (max-width: 767px) {
	.schedule__grid {
		display: block;
		justify-content: center;
		gap: var(--primary-gap--pc);
		margin: 0;
		width: auto;
	}
}

.schedule__date1 {
	display: block;
	background-color: var(--background-gray);
	position: relative;
	font-size: 3rem;
	font-weight: bold;
	color: var(--text-color--darkgray);
	grid-column: 1/2;
	grid-row: 1/2;
	padding-left: 30px;
	padding-top: 20px;
	margin-top: 30px;
}
.schedule__date2 {
	display: none;
}
.schedule__date3 {
	display: block;
	position: relative;
	font-size: 3rem;
	font-weight: bold;
	color: var(--text-color--darkgray);
	grid-column: 1/2;
	grid-row: 2 /3;
	padding-left: 30px;
	padding-top: 20px;
	margin-top: 30px;
}
.schedule__date4 {
	display: none;
}
.schedule__date5 {
	display: block;
	position: relative;
	font-size: 3rem;
	font-weight: bold;
	color: var(--text-color--darkgray);
	grid-column: 1/2;
	grid-row: 3 /4;
	padding-left: 30px;
	padding-top: 20px;
	margin-top: 30px;
}
.schedule__date6 {
	display: block;
	position: relative;
	font-size: 3rem;
	font-weight: bold;
	color: var(--text-color--darkgray);
	grid-column: 1/2;
	grid-row: 4/5;
	padding-left: 30px;
	padding-top: 20px;
	margin-top: 30px;
}
.schedule__date7 {
	display: block;
	position: relative;
	font-size: 3rem;
	font-weight: bold;
	color: var(--text-color--darkgray);
	grid-column: 1/2;
	grid-row: 5/6;
	padding-left: 30px;
	padding-top: 20px;
	margin-top: 30px;
}
.schedule__date1::before {
	content: "";
	background-color: var(--primary-blue);
	width: 20px;
	height: 20px;
	border: 0.5px solid var(--text-color--darkgray);
	border-radius: 50%;

	position: absolute;
	left: -11px;
	top: 28px;
}
.schedule__date2::before {
	content: "";
	background-color: var(--primary-blue);
	width: 20px;
	height: 20px;
	border: 0.5px solid var(--text-color--darkgray);
	border-radius: 50%;

	position: absolute;
	left: -11px;
	top: 28px;
}
.schedule__date3::before {
	content: "";
	background-color: var(--primary-blue);
	width: 20px;
	height: 20px;
	border: 0.5px solid var(--text-color--darkgray);
	border-radius: 50%;

	position: absolute;
	left: -11px;
	top: 28px;
}
.schedule__date4::before {
	content: "";
	background-color: var(--primary-blue);
	width: 20px;
	height: 20px;
	border: 0.5px solid var(--text-color--darkgray);
	border-radius: 50%;

	position: absolute;
	left: -11px;
	top: 28px;
}
.schedule__date5::before {
	content: "";
	background-color: var(--primary-blue);
	width: 20px;
	height: 20px;
	border: 0.5px solid var(--text-color--darkgray);
	border-radius: 50%;

	position: absolute;
	left: -11px;
	top: 28px;
}
.schedule__date6::before {
	content: "";
	background-color: var(--primary-blue);
	width: 20px;
	height: 20px;
	border: 0.5px solid var(--text-color--darkgray);
	border-radius: 50%;

	position: absolute;
	left: -11px;
	top: 28px;
}
.schedule__date7::before {
	content: "";
	background-color: var(--primary-blue);
	width: 20px;
	height: 20px;
	border: 0.5px solid var(--text-color--darkgray);
	border-radius: 50%;

	position: absolute;
	left: -11px;
	top: 28px;
}
.schedule__content1 {
	background-color: var(--primary-white);
	padding: 40px 20px 20px 20px;
	position: relative;
	border-radius: 15px 15px 30px 0;
	border-top: var(--border-top);
	grid-area: b;
}
.schedule__content2 {
	background-color: var(--primary-white);
	padding: 40px 20px 20px 20px;
	position: relative;
	border-radius: 15px 15px 30px 0;
	border-top: var(--border-top);
	grid-area: c;
}
.schedule__content3 {
	background-color: var(--primary-white);
	padding: 40px 20px 20px 20px;
	position: relative;
	border-radius: 15px 15px 30px 0;
	border-top: var(--border-top);
	grid-area: e;
}
.schedule__content4 {
	background-color: var(--primary-white);
	padding: 40px 20px 20px 20px;
	position: relative;
	border-radius: 15px 15px 30px 0;
	border-top: var(--border-top);
	grid-area: f;
}
.schedule__content5 {
	background-color: var(--primary-white);
	padding: 40px 20px 20px 20px;
	position: relative;
	border-radius: 15px 15px 30px 0;
	border-top: var(--border-top);
	grid-area: h i;
	grid-column: 2/4;
}
.schedule__content6 {
	background-color: var(--primary-white);
	padding: 40px 20px 20px 20px;
	position: relative;
	border-radius: 15px 15px 30px 0;
	border-top: var(--border-top);
	grid-column: 2/4;
	grid-area: k l;
}
.schedule__content7 {
	background-color: var(--primary-white);
	padding: 40px 20px 20px 20px;
	position: relative;
	border-radius: 15px 15px 30px 0;
	border-top: var(--border-top);
	grid-column: 2/4;
	grid-area: n o;
}

.schedule__content2 div img {
	width: 100%;
	height: auto;
	margin: auto 0;
	border-radius: 10px;
}

.schedule__content3 div img {
	width: 100%;
	height: auto;
	margin: auto 0;
	border-radius: 10px;
}

@media (max-width: 767px) {
	.schedule__content1 {
		border-radius: 0 30px 0 0;
		margin-top: 10px;
	}
	.schedule__content2 {
		border-radius: 0 30px 0 0;
		margin-top: 10px;
	}
	.schedule__content3 {
		border-radius: 0 30px 0 0;
		margin-top: 10px;
	}
	.schedule__content4 {
		border-radius: 0 30px 0 0;
		margin-top: 10px;
	}
	.schedule__content5 {
		border-radius: 0 30px 0 0;
		margin-top: 10px;
	}
	.schedule__content6 {
		border-radius: 0 30px 0 0;
		margin-top: 10px;
	}
	.schedule__content7 {
		border-radius: 0 30px 0 0;
		margin-top: 10px;
	}
	.schedule__content3 div {
		position: static;
		top: 25px;
		right: 0px;
	}
	.schedule__content3 div img {
		width: 100%;
		max-width: 380px;
		height: auto;
	}
	.schedule__content3 div {
		position: static;
		top: 25px;
		right: 5px;
	}
}

.service {
	display: block;
	z-index: 150;
	width: 70px;
	height: 12%;
	background-image: url("../images/sankokaitorei_logo.png");
	background-size: contain;
	background-repeat: no-repeat;
	position: absolute;
	right: 10px;
	top: 10px;
}

.schedule__p {
	font-size: 1.5rem;
	color: var(--text-color--darkgray);
	line-height: 1.6;
	margin: 30px 15px 15px 0;
}
.schedule__p--herf {
	font-size: 1.5rem;
	color: var(--text-color--darkgray);
	line-height: 1.6;
	margin: 25px 0px 0px 0;
	width: 50%;
}

@media (max-width: 767px) {
	.schedule__p--herf {
		font-size: 1.5rem;
		color: var(--text-color--darkgray);
		line-height: 1.6;
		margin: 30px 15px 15px 0;
		width: 100%;
	}
}

.Web {
	display: block;
	color: red;
	text-shadow: 0 0 3px orange, 0 0 3px orange;
	padding: 10px 0;
	font-size: 1.3rem;
	text-align: center;
	letter-spacing: 0.2em;
	text-align: end;
}
.raikou {
	display: block;
	color: blue;
	text-shadow: 0 0 3px skyblue, 0 0 3px skyblue;
	padding: 10px 0;
	font-size: 1.3rem;
	text-align: center;
	letter-spacing: 0.2em;
	text-align: end;
}
.sent {
	display: block;
	color: green;
	text-shadow: 0 0 3px lightgreen, 0 0 3px lightgreen;
	padding: 10px 0;
	font-size: 1.3rem;
	text-align: center;
	letter-spacing: 0.2em;
	text-align: end;
}
.webraikou {
	display: block;
	color: purple;
	text-shadow: 0 0 3px palevioletred, 0 0 3px skyblue;
	padding: 10px 0;
	font-size: 1.3rem;
	text-align: center;
	letter-spacing: 0.2em;
	text-align: end;
}
/*****************************
 banner
 *****************************/
.banner {
	background-image: repeating-linear-gradient(
		135deg,
		#7b8ead 0,
		#7b8ead 1px,
		transparent 0,
		transparent 50%
	);
	background-size: 9px 9px;
	background-color: #197dc3;
	margin-top: 150px;
	padding: 50px 0;
	font-size: 1.8rem;
	height: 520px;
}
.banner__pickUp {
	width: auto;
	color: var(--primary-white);
	margin: 85px auto 0 auto;
	font-size: 3.8rem;
	font-family: medium;
	color: var(--primary-white);
	line-height: 1;
	text-align: center;
}

.banner__box {
	display: flex;
	width: auto;
	gap: 38px;
	margin: 48px auto 0 auto;
	justify-content: center;
}
.banner__box p {
	color: var(--primary-white);
}
.banner__box--straight {
	width: auto;
	display: flex;
	flex-direction: column-reverse;
}
.banner__box--straight img {
	max-width: 345px;
}

.banner__box--medium {
	width: auto;
	display: flex;
	flex-direction: column-reverse;
}

.banner__box--medium img {
	max-width: 345px;
}
.banner__box--straight p,
.banner__box--medium p {
	font-size: 1.8rem;
	color: var(--primary-white);
	line-height: 1.5;
}
@media (min-width: 768px) and (max-width: 1439px) {
	.banner {
		background-image: repeating-linear-gradient(
			135deg,
			#7b8ead 0,
			#7b8ead 1px,
			transparent 0,
			transparent 50%
		);
		background-size: 9px 9px;
		background-color: #197dc3;
		margin-top: 130px;
		padding: 50px 0;
		font-size: 1.8rem;
		height: 450px;
	}
	.banner__pickUp {
		width: 767px;
		color: var(--primary-white);
		margin: 40px auto 0 auto;
		font-size: 2rem;
		font-family: medium;
		color: var(--primary-white);
		line-height: 1;
	}
	.banner__box {
		display: flex;
		width: 767px;
		gap: 38px;
		margin: 30px auto 0 auto;
	}
}
@media (max-width: 767px) {
	.banner {
		background-image: repeating-linear-gradient(
			135deg,
			#7b8ead 0,
			#7b8ead 1px,
			transparent 0,
			transparent 50%
		);
		background-size: 9px 9px;
		background-color: #197dc3;
		margin-top: 70px;
		padding: 20px 0;
		font-size: 1.8rem;
		height: auto;
	}
	.banner__pickUp {
		padding: 16px;
		color: var(--primary-white);
		margin: auto auto auto 0;
		font-size: 3rem;
		font-family: medium;
		line-height: 1;
	}

	.banner__box {
		display: block;
		gap: 38px;
		margin: 0 5%;
		justify-content: center;
	}
	.banner__box p {
		color: var(--primary-white);
	}
	.banner__box--straight {
		padding: 0;
		display: flex;
		flex-direction: column-reverse;
	}
	.banner__box--straight img {
		width: 90vw;
		height: 200px;
		padding: 16px auto;
		object-fit: contain;
		background-repeat: no-repeat;
		margin-top: 20px;
	}

	.banner__box--medium {
		width: 100%;
		display: flex;
		flex-direction: column-reverse;
	}

	.banner__box--medium img {
		width: 90vw;
		height: 200px;
		padding: 16px auto;
		object-fit: contain;
		background-repeat: no-repeat;
		margin-top: 20px;
	}
	.banner__box--straight p,
	.banner__box--medium p {
		font-size: 1.6rem;
		color: var(--primary-white);
		line-height: 1.5;
		text-align: center;
	}
}
/*****************************
 footer
 *****************************/
.footer {
	background-color: var(--footer-gray, #e8e8e8);
	text-align: center;
	height: 80px;
	display: flex;
	align-items: center;
}

.footer p {
	font-size: 1rem;
	margin: 0 auto;
}

.youtube {
	aspect-ratio: 16 / 9;
}

.fade-in-element {
	opacity: 0;
	transform: translateY(50px); /* 下からスライドイン */
	transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

.fade-in-element.is-visible {
	opacity: 1;
	transform: translateY(0);
}

.survayOngoing {
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	z-index: 10;
	background-color: rgba(255, 255, 255, 0.8);
	width: 100%;
	height: 100%;
}
.ongoing1 {
	background-color: var(--color--ranking1);
	border-radius: 50%;
	width: 20px;
	height: 20px;
	margin: 10px;
	animation: ongoing 1s ease-in-out infinite;
}
.ongoing2 {
	background-color: var(--color--ranking2);
	border-radius: 50%;
	width: 20px;
	height: 20px;
	margin: 10px;
	animation: ongoing 1s 0.1s ease-in-out infinite;
}
.ongoing3 {
	background-color: var(--color--ranking3);
	border-radius: 50%;
	width: 20px;
	height: 20px;
	margin: 10px;
	animation: ongoing 1s 0.2s ease-in-out infinite;
}
.ongoing4 {
	background-color: var(--color--ranking4);
	border-radius: 50%;
	width: 20px;
	height: 20px;
	margin: 10px;
	animation: ongoing 1s 0.3s ease-in-out infinite;
}

@keyframes ongoing {
	0% {
		transform: translateY(0);
	}
	15% {
		transform: translateY(-40px);
	}
	40% {
		transform: translateY(0);
	}
	50% {
		transform: translateY(-3px);
	}
	80% {
		transform: translateY(0px);
	}

	100% {
		transform: translateY(0);
	}
}

/*****************************
 ボタンデザイン
 *****************************/

.button-55 {
	display: flex;
	justify-content: center;
	align-items: center;
	max-width: 350px;
	margin: 0 auto;
	padding: 0.9em 2em;
	border: none;
	border-radius: 5px;
	background-image: radial-gradient(50% 95%, #ff6b16, #cd1212);
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.5), 0 2px 10px rgba(230, 35, 21, 0.7),
		inset 0 0 10px rgba(163, 41, 25, 0.6);
	color: #fff;
	font-weight: 600;
	font-size: 1.8em;
	line-height: 1.5;
	cursor: pointer;
	animation: buruburu 2.4s linear infinite;
	scale: 1;
	transition-duration: 0s;
}

.button-55::after {
	content: "";
	width: 1.25em;
	height: 1.25em;
	margin-left: 8px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M10 6V8H5V19H16V14H18V20C18 20.5523 17.5523 21 17 21H4C3.44772 21 3 20.5523 3 20V7C3 6.44772 3.44772 6 4 6H10ZM21 3V11H19L18.9999 6.413L11.2071 14.2071L9.77689 12.7929L17.5849 5H13V3H21Z' fill='%23fff'%3E%3C/path%3E%3C/svg%3E");
	background-repeat: no-repeat;
}

.button-55:hover {
	background-color: #ef9500;
}

@keyframes buruburu {
	0% {
		transform: translateX(0);
	}
	5% {
		transform: translateX(-10px);
	}
	8% {
		transform: translateX(10px);
	}
	11% {
		transform: translateX(-10px);
	}
	14% {
		transform: translateX(10px);
	}
	17% {
		transform: translateX(0px);
	}
	100% {
		transform: translateX(0);
	}
}

@keyframes btn_animation {
	0% {
		transform: scale(0.8);
	}
	5% {
		transform: scale(0.75);
	}
	95% {
		transform: scale(0.75);
	}
	100% {
		-webkit-transform: scale(0.8);
	}
}

* {
	margin: 0;
}
.confetti canvas {
	height: 100%;
	width: 100%;
	position: absolute;
}

.btnWrap_koshusystem {
	text-align: center;
}

a.btn_11 {
	display: block;
	text-align: center;
	vertical-align: middle;
	text-decoration: none;
	width: 280px;
	margin: 50px auto 20px auto;
	padding: 10px;
	font-weight: bold;
	font-size: 1.5rem;
	line-height: 1.2;
	background-image: linear-gradient(
		to top,
		#d8d9db 0%,
		#fff 80%,
		#fdfdfd 100%
	);
	border-radius: 100vh;
	color: #333;
	border: 1px solid #999;
	text-shadow: 0 1px #fff;
	box-shadow: 0 3px 2px 1px #fcfcfc, 0 4px 6px #cecfd1, 0 -2px 2px #cecfd1,
		0 -4px 2px #eee, inset 0 0 2px 2px #cecfd1;
	transition: 0.5s;
	animation: ankeanimation 1s infinite 0.5s;
}
@keyframes ankeanimation {
	0% {
		opacity: 0.5;
	}
	100% {
		opacity: 1;
	}
}

.sp {
	display: none;
}

.movie_size {
	padding: 20px;
	margin: 0 auto;
	max-width: 900px;
}

@media (max-width: 768px) {
	.pc {
		display: none;
	}

	.sp {
		display: block;
		font-size: 1.6rem;
	}

	.movie_size {
		padding: 0px 0px 0px 0px;
		margin: 0;
	}

	.img{
		width: 100%;
        height: auto;
	}
}
