@import url(https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@500;700&display=swap);
@charset "utf-8";

/*============================================================
	IMPORT
*/

/*============================================================
	ICON
*/
@font-face {
	font-family: 'icon';
	src: url(/fonts/icon.woff?502cfdcc56b195247b5fc691728f6182) format('woff');
	font-weight: normal;
	font-style: normal;
	font-display: block;
}
[class^="icon-"],
[class*=" icon-"] {
	font-family: 'icon' !important;
	speak: never;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	text-transform: none;
	line-height: 1;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
.icon-arrow-next:before {
	content: "\e900";
}
.icon-arrow-prev:before {
	content: "\e901";
}
.icon-arrow-up:before {
	content: "\e902";
}
.icon-calendar:before {
	content: "\e903";
}
.icon-doc-comp:before {
	content: "\e904";
}
.icon-doc:before {
	content: "\e905";
}
.icon-faq:before {
	content: "\e906";
}
.icon-history:before {
	content: "\e907";
}
.icon-logout:before {
	content: "\e908";
}
.icon-mail-comp:before {
	content: "\e909";
}
.icon-mail:before {
	content: "\e90a";
}
.icon-music:before {
	content: "\e90b";
}
.icon-note:before {
	content: "\e90c";
}
.icon-search:before {
	content: "\e90d";
}
.icon-security:before {
	content: "\e90e";
}
.icon-user:before {
	content: "\e90f";
}

/*============================================================
	RESET
*/
body * {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	background-color: transparent;
	background-image: none;
	background-position: 0 0;
	background-repeat: no-repeat;
	text-decoration: none;
	text-indent: 0;
	text-transform: none;
	font-style: normal;
	font-size: inherit;
	font-family: inherit;
	font-weight: inherit;
	line-height: inherit;
	color: inherit;
}
html,
body {
	margin: 0;
	padding: 0;
	width: 100%;
	height: 100%;
}
body {
	-webkit-text-size-adjust: 100%;
	-moz-text-size-adjust: 100%;
	     text-size-adjust: 100%;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-smoothing: antialiased;
}
ul {
	list-style-type: none;
}
table {
	border-collapse: collapse;
}
a,
button {
	cursor: pointer;
}
img {
	vertical-align: top;
	width: 100%;
}
input,
select,
textarea,
button {
	-moz-appearance: none;
	-webkit-appearance: none;
	appearance: none;
	background-color: transparent;
	background-image: none;
	border: 0;
	border-radius: 0;
	outline: 0;
	resize: none;
}

/*============================================================
	HTML
*/
body {
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 500;
	font-size: 16px;
	line-height: 1.6;
	color: #2c2c2c;
}
a {
	color: #0052c3;
	/* text-decoration: underline; */
	transition: opacity 0.3s ease, background-color 0.3s ease, border-color 0.3s ease, color 0.3s ease;
}
button {
	transition: opacity 0.3s ease, background-color 0.3s ease, border-color 0.3s ease, color 0.3s ease;
	cursor: pointer;
}
.os-pc a:hover,
.os-pc button:hover {
	opacity: 0.6;
	color: inherit;
}
label {
	position: relative;
	margin: 0;
	padding: 0;
}

@media screen and (max-width: 767px) {
	body {
		font-size: 15px;
		line-height: 1.8;
	}
}

/*============================================================
	BODY
*/
body.lock {
	overflow: hidden;
}
.body {
	overflow: hidden;
	display: flex;
	flex-direction: column;
	min-height: 100%;
	padding: 88px 0 0 0;
}
.background-grey{
	background: #F5F5F5;
}
.app-layout-set{
	background: #fff;
}
.content {
	position: relative;
	flex: 1;
	padding: 80px 0;
}
.container {
	position: relative;
	margin: 0 auto;
	/* padding: 88px; */
	padding: 40px;
	/* max-width: 1260px; */
	max-width: 1300px;
}

/* MYPAGE */
.body-mypage {
	background-color: #f5f5f5;
}
.body-mypage .content-frame {
	padding: 40px 40px 60px 40px;
	background-color: #fff;
}

@media screen and (max-width: 767px) {
	.body {
		padding: 64px 0 0 0;
	}
	.content {
		padding: 40px 0 120px 0;
	}
	.container {
		/* padding: 0 24px;
		max-width: 100%; */
		padding: 24px;
		max-width: 90%;
	}
	.body-mypage .content-frame {
		padding: 25px 16px 40px 16px;
		border-radius: 10px;
		margin-top: 20px;
	}
}

/*============================================================
	VISIBLE
*/
@media screen and (min-width: 768px) {
	.visible-sp {
		display: none;
	}
}
@media screen and (max-width: 767px) {
	.visible-pc {
		display: none;
	}
}

/*============================================================
	HIDDEN
*/
@media screen and (min-width: 768px) {
	.hidden-pc {
		display: none;
	}
}
@media screen and (max-width: 767px) {
	.hidden-sp {
		display: none;
	}
}

/*============================================================
	PAGETOP
*/
.pagetop {
	display: none;
	position: fixed;
	z-index: 10;
	bottom: 40px;
	right: 24px;
}
#register_iframe {
    height: 1250px;
}
.pagetop-limit .pagetop {
	position: absolute;
}
.pagetop a {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 0 0 2px 0;
	width: 48px;
	height: 48px;
	background-color: #239d86;
	border-radius: 4px;
	text-decoration: none;
	font-size: 32px;
	color: #fff;
}
@media screen and (min-width: 768px) {
	.pagetop {
		display: none !important;
	}
}

/*============================================================
	ICON HINT
*/
.icon-hint {
	position: relative;
	top: 0.14em;
	display: inline-block;
	margin-left: 5px;
	width: 16px;
	height: 16px;
	background-color: #239d86;
	background-image: url(/images/icon-hint.svg?ef4dbcebb476c026c7a9e214565e862c);
	background-size: contain;
	border-radius: 50%;
}

@media screen and (max-width: 767px) {
	.icon-hint {
		top: 0.2em;
	}
}

/*============================================================
	TIP
*/
.tip-balloon {
	position: absolute;
	z-index: 9998;
	padding: 3px 6px 4px 6px;
	background-color: #239d86;
	border-radius: 4px;
	color: #fff;
}
.tip-balloon::before {
	content: '';
	display: block;
	position: absolute;
	left: 30px;
	bottom: 100%;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 0 8px 14px 8px;
	border-color: transparent transparent #239d86 transparent;
}

@media screen and (max-width: 767px) {
	.tip-balloon {
		margin-top: -5px;
		padding: 5px 6px;
		width: 200px;
		line-height: 1.3;
	}
}

/*============================================================
	BLOCK LAYOUT
*/
.block-center {
	margin: 0 auto;
}

/*============================================================
	FORM
*/
/* PLACEHOLDER */

::-moz-placeholder {
	font-weight: 400;
	color: #989898 !important;
	opacity: 1;
}

::-moz-placeholder-shown {
	font-weight: 400;
	color: #989898 !important;
	opacity: 1;
}

:-ms-input-placeholder-shown {
	font-weight: 400;
	color: #989898 !important;
	opacity: 1;
}

::placeholder-shown {
	font-weight: 400;
	color: #989898 !important;
	opacity: 1;
}

::-moz-placeholder {
	font-weight: 400;
	color: #989898 !important;
	opacity: 1;
}

:-ms-input-placeholder {
	font-weight: 400;
	color: #989898 !important;
	opacity: 1;
}

::placeholder {
	font-weight: 400;
	color: #989898 !important;
	opacity: 1;
}

/* INPUT */
.form-control {
	display: block;
	padding: 10px 15px 11px 15px;
	width: 100%;
	min-width: 50px;
	height: auto;
	background-color: #fafafa;
	border: 1px solid #989898;
	border-radius: 4px;
	font-weight: 400;
	font-size: 1rem;
	line-height: normal;
	color: inherit;
	transition: background-color 0.3s ease;
	opacity: 1;
}
.form-control:focus {
	background-color: #fff;
}
.form-control.is-value {
	border-color: #2c2c2c;
}
.form-control.is-invalid {
	padding: 10px 15px 11px 15px;
	background-image: none;
	background-color: #ffcccc;
	border-color: #2c2c2c;
}
.form-control:disabled {
	background-color: #d5d5d5;
	color: #2c2c2c;
	opacity: 1;
}

/* TEXTAREA */
textarea.form-control {
	height: 240px;
}
textarea.form-control+.invalid {
	margin-top: 5px;
}

/* SELECT */
select.form-control {
	padding: 10px 22px 11px 10px;
	height: auto;
	background-color: #fff;
	background-image: url(/images/form-select.svg?be82f3cb56dafac76173ff9bb1e9f60c);
	background-position: 100% 50%;
	background-repeat: no-repeat;
	background-size: 20px 20px;
	font-weight: 500;
	font-size: 100%;
	line-height: normal;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	cursor: pointer;
}
select.form-control.is-invalid {
	padding: 10px 22px 11px 10px;
}
.custom-select {
	position: relative;
	padding: 0;
}
.custom-select .current {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	opacity: 0;
	cursor: pointer;
}
.custom-select ul {
	display: none;
	overflow: hidden;
	position: absolute;
	z-index: 5;
	top: 0;
	left: 0;
	right: 0;
	border: 1px solid #707070;
	border-radius: 4px;
	box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
	cursor: pointer;
}
.custom-select.opened ul {
	display: block;
}
.custom-select ul li {
	padding: 10px 10px 11px 10px;
	background-color: #fff;
	border-bottom: 1px solid #707070;
	line-height: normal;
	transition: background-color 0.3s ease, color 0.3s ease;
}
.custom-select ul li:last-child {
	border-bottom: 0;
}
.os-pc .custom-select ul li:hover {
	background-color: #239d86;
	color: #fff;
}

/* CHECKBOX */
input[type="checkbox"] {
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	width: 16px;
	height: 16px;
	opacity: 0;
}
input[type="checkbox"]+span {
	position: relative;
	display: inline-block;
	padding-left: 22px;
}
input[type="checkbox"]+span::before {
	content: '';
	position: absolute;
	transform: translateY(-50%);
	top: 50%;
	left: 0;
	display: block;
	margin-top: 0.1em;
	width: 16px;
	height: 16px;
	background: #fff url(/images/form-checkbox.svg?847099bd1d5c8b8cdc972baf245011f4) 50% 50% no-repeat;
	background-size: contain;
	border: 1px solid #000;
	box-sizing: border-box;
	cursor: pointer;
}
input[type="checkbox"]:checked+span::before {
	background-color: #239d86;
	border-color: #239d86;
}

/* RADIO */
input[type="radio"] {
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	width: 16px;
	height: 16px;
	opacity: 0;
}
input[type="radio"]+span {
	position: relative;
	display: inline-block;
	padding-left: 22px;
}
input[type="radio"]+span::before,
input[type="radio"]+span::after {
	content: '';
	position: absolute;
	transform: translateY(-50%);
	top: 50%;
	left: 0;
	display: block;
	margin-top: 0.05em;
	box-sizing: border-box;
	border-radius: 50%;
}
input[type="radio"]+span::before {
	width: 16px;
	height: 16px;
	border: 1px solid #707070;
}
input[type="radio"]+span::after {
	display: none;
	left: 3px;
	width: 10px;
	height: 10px;
	background-color: #239d86;
}
input[type="radio"]:checked+span::after {
	display: block;
}

/* SEARCH */
.form-search {
	padding: 10px 15px 10px 35px;
	background-image: url(/images/icon-search.svg?cea169934f63060ef463ad6287183bed);
	background-position: 10px 50%;
	background-repeat: no-repeat;
	background-size: 20px 20px;
}

/* KEYWORD */
.input-keyword {
	position: relative;
}
.input-keyword .form-search {
	position: relative;
}
.input-keyword .clear {
	display: none;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	width: 46px;
	cursor: pointer;
}
.input-keyword.is-value .clear {
	display: block;
}
.input-keyword .clear::before,
.input-keyword .clear::after {
	content: '';
	display: block;
	position: absolute;
	top: 50%;
	left: 14px;
	margin-top: -1px;
	width: 18px;
	height: 2px;
	background-color: #2c2c2c;
}
.input-keyword .clear::before {
	transform: rotate(45deg);
}
.input-keyword .clear::after {
	transform: rotate(-45deg);
}

/* LABEL */
.form-label-must,
.form-label-opt {
	position: relative;
	top: -1px;
	display: inline-block;
	margin: 0 0 0 8px;
	padding: 0 5px 1px 5px;
	font-size: 12px;
	line-height: 18px;
	color: #fff;
}
.form-label-must {
	background-color: #ea1c1c;
}
.form-label-opt {
	background-color: #747474;
}

/* LIMIT */
.form-limit {
	margin-right: 10px;
	font-size: 12px;
}

/* INVALID */
.invalid {
	color: #ea1c1c;
}

@media screen and (max-width: 767px) {
	.invalid {
		margin: 5px 0 0 0;
	}
	.form-control {
		padding: 10px 10px 11px 10px;
		font-size: 16px;
	}
	.form-control.is-invalid {
		padding: 10px 10px 11px 10px;
	}
	select.form-control {
		padding: 7px 22px 8px 6px;
		font-size: 14px;
	}
	select.form-control.is-invalid {
		padding: 7px 22px 8px 6px;
	}
	.custom-select ul li {
		padding: 8px 6px 8px 6px;
		font-size: 14px;
	}
	.form-search {
		padding: 10px 35px 11px 35px;
		line-height: normal;
	}
}

/*============================================================
	FORM INLINE
*/
.form-inline {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
}
.form-inline>li {
	margin-right: 1.2em;
}
.form-inline>li:last-child {
	margin-right: 0;
}
.form-inline .invalid {
	margin: 5px 0;
}
@media screen and (max-width: 767px) {
	.form-inline .invalid {
		margin: 5px 0 0 0;
		width: 100%;
	}
}

.movie_thumbnail .form-inline label {
	display: block;
}

/*============================================================
	FORM VERTICAL
*/
.form-vertical>li {
	margin-bottom: 10px;
}
.form-vertical>li:last-child {
	margin-bottom: 0;
}

/*============================================================
	FORM LAYOUT PRIMARY
*/
.form-layout-primary {
	margin: 30px 0;
	line-height: 1.5;
}
.form-layout-primary dl {
	margin-bottom: 30px;
}
.form-layout-primary dl:last-child {
	margin-bottom: 0;
}
.form-layout-primary dl dt {
	margin: 0 0 10px 0;
}
.form-layout-primary .form-inline .form-control {
	margin-right: 20px;
	width: 50%;
}
.form-layout-primary .form-block {
	align-items: flex-start;
}
.form-layout-primary .form-block .block {
	margin-right: 20px;
	width: 50%;
}
.form-layout-primary .form-block .block .form-control {
	margin-right: 0;
	width: 100%;
}
.form-layout-primary .note {
	margin: 5px 0 0 0;
	font-size: 12px;
}
.form-layout-primary .form-block .invalid {
	margin: 10px 0 0 0;
}

@media screen and (max-width: 767px) {
	.form-layout-primary dl {
		margin-bottom: 15px;
	}
	.form-layout-primary .form-inline {
		display: block;
	}
	.form-layout-primary .form-inline .form-control {
		margin-right: 0;
		width: 100%;
	}
	.form-layout-primary .form-block .block {
		margin-right: 0;
		width: 100%;
	}
	.form-layout-primary .form-block .invalid {
		margin: 5px 0 0 0;
	}
}

/*============================================================
	FORM LAYOUT CART
*/
.form-layout-cart {
	margin: 20px 0 40px 0;
	width: 100%;
	line-height: 1.5;
}
.form-layout-cart dl {
	display: flex;
	flex-wrap: wrap;
}
.form-layout-cart dt,
.form-layout-cart dd {
	padding-bottom: 25px;
}
.form-layout-cart dl:last-child dt,
.form-layout-cart dl:last-child dd {
	padding-bottom: 0;
}
.form-layout-cart dt {
	width: 110px;
}
.form-layout-cart .has-child-input dt {
	padding-top: 11px;
}
.form-layout-cart dd {
	margin-bottom: 0;
	flex: 1;
}
.form-layout-cart .form-name {
	margin-right: 5px;
	width: 50%;
}
.form-layout-cart .form-date {
	margin-right: 5px;
	width: 120px;
}
.form-layout-cart .form-income {
	margin-right: 5px;
	width: 120px;
}
.form-layout-cart .form-url {
	margin-right: 10px;
	width: 50%;
}
.form-layout-cart .datepicker {
	margin-right: 10px;
	text-decoration: none;
	font-size: 26px;
	line-height: 1;
	color: #4b4b4b;
}

@media screen and (max-width: 767px) {
	.form-layout-cart {
		margin: 15px 0 30px 0;
	}
	.form-layout-cart.break-sp dl {
		display: block;
	}
	.form-layout-cart.break-sp dt {
		padding-bottom: 10px !important;
	}
	.form-layout-cart dt {
		width: 100px;
	}
	.form-layout-cart .form-layout-name {
		align-items: flex-start;
	}
	.form-layout-cart .form-layout-name dt {
		padding-top: 12px;
	}
	.form-layout-cart .form-layout-name .form-inline {
		display: block;
	}
	.form-layout-cart .form-name {
		margin: 0 0 5px 0;
		width: 100%;
	}
	.form-layout-cart .form-date {
		width: 110px;
	}
	.form-layout-cart .form-income {
		width: 110px;
	}
	.form-layout-cart .form-url {
		margin-right: 0;
		width: 100%;
	}
}

/*============================================================
	BUTTON
*/
.btn-action,
.btn-action-outline,
.btn-search-outline,
.btn-disabled,
.btn-cancel,
.btn-close,
.btn-menu,
.btn-gradation {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 5px;
	width: 100%;
	height: 80px;
	border-width: 2px;
	border-style: solid;
	border-radius: 4px;
	text-align: center;
	font-weight: 700;
	font-size: 20px;
	line-height: 1.5;
	text-decoration: none;
}
.btn-gradation {
	height: 84px;
	border-width: 0;
	background: rgb(94, 227, 201);
	background: linear-gradient(90deg, rgba(94, 227, 201, 1) 0%, rgba(15, 136, 113, 1) 100%);
	color: #fff;
}
.btn-action {
	background-color: #239d86;
	border-color: #239d86;
	color: #fff !important;
}
.btn-action-outline {
	background-color: #fff;
	border-color: #239d86;
	color: #239d86 !important;
}
.btn-search-outline {
	background-color: #fff;
	border-color: #239d86;
	color: #239d86 !important;
	margin-bottom: 20px;
}
.btn-disabled {
	background-color: #989898;
	border-color: #989898;
	color: #fff !important;
	opacity: 1 !important;
	cursor: default !important;
}
.btn-cancel {
	background-color: #fff;
	border-color: #ea1c1c;
	color: #ea1c1c !important;
}
.btn-close {
	background-color: #fff;
	border-color: #239d86;
	color: #239d86 !important;
}
.btn-menu {
	min-height: 64px;
	background-color: #fff;
	border-width: 1px;
	border-color: #2c2c2c;
	color: #2c2c2c;
	opacity: 1 !important;
}
.os-pc .btn-menu:hover {
	background-color: #239d86;
	border-color: #239d86;
	color: #fff;
}
.btn-menu.current {
	background-color: #e4faf5 !important;
	border-color: #239d86 !important;
	color: #239d86 !important;
	cursor: default;
}
.btn-gradation {
	color: #fff !important;
}

@media screen and (max-width: 980px) {
	.btn-menu {
		font-size: 18px;
	}
}

@media screen and (max-width: 767px) {
	.btn-action,
	.btn-action-outline,
	.btn-search-outline,
	.btn-disabled,
	.btn-cancel,
	.btn-close,
	.btn-menu,
	.btn-gradation {
		width: 100%;
		height: 48px;
		font-size: 16px;
	}
	.btn-menu {
		min-height: 48px;
		font-size: 14px;
	}
}

/*============================================================
	BUTTON LAYOUT
*/
.btn-layout {
	margin: 55px -40px;
}
.btn-layout:last-child {
	margin-bottom: 0;
}
.btn-layout .outer {
	display: flex;
	justify-content: center;
	flex-direction: row-reverse;
	margin: 0 auto;
	max-width: 880px;
}
.btn-layout .outer>div {
	flex-basis: 50%;
	padding: 0 40px;
}

@media screen and (max-width: 980px) {
	.btn-layout {
		margin: 40px -20px;
	}
	.btn-layout .outer>div {
		padding: 0 20px;
	}
}

@media screen and (max-width: 767px) {
	.btn-layout {
		margin: 20px 0;
	}
	.btn-layout .outer {
		display: block;
	}
	.btn-layout .outer>div {
		margin-bottom: 25px;
		padding: 0;
	}
	.btn-layout .outer>div:last-child {
		margin-bottom: 0;
	}
}

/*============================================================
	BUTTON LAYOUT MENU
*/
.btn-layout-menu {
	margin-top: 40px;
	margin-bottom: 40px;
	max-width: 1080px;
}
.btn-layout-menu .outer {
	display: flex;
	flex-wrap: wrap;
	margin-left: -15px;
	margin-right: -15px;
	margin-bottom: -25px;
}
.btn-layout-menu .outer>div {
	flex-basis: 33.333%;
	margin: 0 0 25px 0;
	padding: 0 15px;
}

@media screen and (max-width: 767px) {
	.btn-layout-menu {
		margin-top: 20px;
		margin-bottom: 20px;
	}
	.btn-layout-menu .outer {
		margin-left: -5px;
		margin-right: -5px;
		margin-bottom: -10px;
	}
	.btn-layout-menu .outer>div {
		flex-basis: 50%;
		margin: 0 0 10px 0;
		padding: 0 5px;
	}
	.btn-layout-menu .outer>div a {
		height: 100%;
	}
}

/*============================================================
	HEADING
*/
.heading {
	margin-top: 100px;
	margin-bottom: 20px;
	text-align: center;
}
.heading:first-child {
	margin-top: 0;
}
.heading h1 {
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 40px;
	line-height: 1.2;
	color: #239d86;
}
.heading h1 i {
	display: block;
	margin: 5px 5px 0 0;
	font-size: 48px;
}
.content-frame .heading h1 {
	justify-content: flex-start;
}
.subhead {
	margin: 40px 0 15px 0;
	font-weight: 700;
	font-size: 24px;
	line-height: 1.5;
}
.subhead:first-child {
	margin-top: 0;
}
.heading+.subhead {
	margin-top: 30px;
}

@media screen and (max-width: 767px) {
	.heading {
		margin-top: 60px;
		margin-bottom: 15px;
	}
	.heading h1 {
		font-size: 24px;
	}
	.heading h1 i {
		margin: 2px 5px 0 0;
		font-size: 32px;
	}
	.subhead {
		margin: 30px 0 10px 0;
		font-size: 20px;
	}
	.heading+.subhead {
		margin-top: 10px;
	}
}

/*============================================================
	MESSAGE
*/
.message {
	margin: 30px 0 60px 0;
	text-align: center;
	line-height: 2;
}
.message span {
	display: inline-block;
}

@media screen and (max-width: 767px) {
	.message {
		margin: 30px 0;
	}
}

/*============================================================
	HORIZONTAL RULE
*/
.hr {
	margin: 40px 0;
	border-top: 2px solid #239d86;
}

@media screen and (max-width: 767px) {
	.hr {
		margin: 40px 0 35px 0;
	}
}

/*============================================================
	TABLE PRIMARY
*/
.table-primary {
	width: 100%;
}
.table-primary th,
.table-primary td {
	padding-bottom: 16px;
	vertical-align: top;
}
.table-primary th {
	text-align: left;
	white-space: nowrap;
}

@media screen and (max-width: 767px) {
	.table-primary,
	.table-primary>tbody,
	.table-primary>tbody>tr,
	.table-primary>tbody>tr>th,
	.table-primary>tbody>tr>td {
		display: block;
	}
	.table-primary tr {
		margin: 0 0 15px 0;
	}
	.table-primary th,
	.table-primary td {
		padding-bottom: 0;
	}
	.table-primary th {
		margin: 0 0 5px 0;
		font-weight: 700;
	}
}

/*============================================================
	TABLE LIST
*/
.table-list table {
	width: 100%;
	line-height: 1.5;
}
.table-list table th,
.table-list table td {
	border: 1px solid #989898;
}
.table-list table th {
	padding: 10px 10px;
	background-color: #239d86;
	font-weight: 700;
	color: #fff;
	white-space: nowrap;
	font-size: 15px;
}
.table-list table th div {
	display: flex;
	align-items: center;
}
.table-list table th.action {
	width: 10px;
}
.table-list table td {
	padding: 16px 10px;
	font-size: 14px;
}
.table-list table th i {
	display: block;
	margin-right: 3px;
	width: 20px;
	height: 20px;
	background-repeat: no-repeat;
	background-position: 50% 50%;
	background-size: contain;
}
.table-list table .icon-th-music {
	width: 14px;
	background-image: url(/images/icon-th-music.svg?e0510106527bfbc8e57bc6cddf759de6);
}
.table-list table .icon-th-artist {
	background-image: url(/images/icon-th-artist.svg?f5481abf203a72c44c310c7169216b8d);
}
.table-list table .icon-th-album {
	background-image: url(/images/icon-th-album.svg?94f77aba0a4971f7d0c1d49b9b3fc215);
}
.table-list table .icon-th-organization {
	width: 30px;
	background-image: url(/images/icon-th-organization.svg?0662c1a6f6f22336bdea05e93eb3d9e9);
}
.table-list table .icon-th-scene {
	background-image: url(/images/icon-th-scene.svg?c4880deaf5a1e9884f9da461decc540c);
}
.table-list table .icon-th-cart-add {
	background-image: url(/images/icon-th-cart-add.svg?cf5b4446d165d151aa42fa12ac3fdd78);
}
.table-list table .icon-th-cart-remove {
	background-image: url(/images/icon-th-cart-remove.svg?519b3c3c4f3feb6e8ca320ca22eb753f);
}
.table-list table .type-badge {
	display: inline-block;
	padding: 0 0 1px 0;
	width: 24px;
	border: 1px solid #2c2c2c;
	border-radius: 4px;
	text-align: center;
	line-height: 22px;
}
.table-list table .use-badge1,
.table-list table .use-badge2 {
	display: block;
	padding: 0 0.3em 1px 0.3em;
	border: 1px solid #000;
	border-radius: 4px;
	text-align: center;
	line-height: 22px;
	white-space: nowrap;
}
.table-list table .use-badge1 {
	background-color: #e4faf5;
	border-color: #1e816e;
	color: #1e816e;
}
.table-list table .use-badge2 {
	background-color: #e6f1ff;
	border-color: #1d67cc;
	color: #1d67cc;
}
.table-list table .ivt-disabled {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 5px;
	border-width: 2px;
	border-style: solid;
	border-radius: 4px;
	background-color: #989898;
	border-color: #989898;
	color: #fff;
	text-align: center;
	font-weight: 700;
	font-size: 14px;
	line-height: 1.5;
	text-decoration: none;
}
.table-list .empty {
	padding: 8px 0;
	text-align: center;
}
.table-list-notes {
	margin: 10px 0 0 0;
	font-size: 12px;
}

/* PC LAYOUT */
.table-list-pc {}
.table-list-pc table tr:nth-child(odd) td {
	background-color: #fafafa;
}
.table-list-pc table .no,
.table-list-pc table .type {
	padding-left: 5px;
	padding-right: 5px;
	width: 10px;
	text-align: center;
	white-space: nowrap;
}
.table-list-pc table .btn-action,
.table-list-pc table .btn-disabled,
.table-list-pc table .btn-cancel {
	height: 40px;
	font-size: 14px;
	white-space: nowrap;
}
.table-list-pc table.has-scene td:last-child {
	width: 26%;
}
.table-list-pc table .scene {
	width: 270px !important;
}
.table-list-pc table .ivt-disabled {
	width: 100%;
	height: 40px;
}
@media screen and (max-width: 1120px) {
	.table-list-pc table th {
		padding-left: 5px;
		padding-right: 5px;
		font-size: 14px;
	}
	.table-list-pc table td {
		padding-left: 5px;
		padding-right: 5px;
	}
}

/* SP LAYOUT */
.table-list-sp {
	display: none;
	overflow-x: scroll;
}
.table-list-sp .block {
	margin-bottom: 25px;
}
.table-list-sp .block:last-child {
	margin-bottom: 0;
}
.table-list-sp table th {
	padding: 8px 5px;
	/* width: 10px; */
	width: 38%;
	font-size: 14px;
}
.table-list-sp table th i {
	margin-right: 3px;
	width: 16px;
	height: 16px;
}
.table-list-sp table .icon-th-music {
	width: 12px;
}
.table-list-sp table .icon-th-organization {
	width: 24px;
}
.table-list-sp table td {
	padding: 8px 5px;
}
.table-list-sp table td.action {
	padding: 15px 5px;
	text-align: center;
}
.table-list-sp table td.action [class^="btn-"] {
	margin: 0 auto;
	width: 150px;
	height: 48px;
	font-size: 16px;
}
.table-list-sp table tr:nth-child(even) td {
	background-color: #fafafa;
}
.table-list-sp .empty {
	padding: 12px 5px;
	border: 1px solid #989898;
	text-align: center;
}
.table-list-sp table .use-badge1,
.table-list-sp table .use-badge2 {
	display: inline-block;
}
.table-list-sp table .ivt-disabled {
	display: inline-block;
	padding: 6px 10px;
	border-width: 1px;
}
.table-list-sp table .custom-select {
	display: inline-block;
}
.table-list-sp table .form-control {
	width: auto;
}
.table-list-sp table .scene .custom-select {
	display: block;
}
.table-list-sp table .scene .form-control {
	width: 100%;
}

@media screen and (max-width: 980px) {
	.table-list-pc {
		display: none;
	}
	.table-list-sp {
		display: block;
		overflow-x: scroll;
	}
}

/*============================================================
	RESULT HEAD
*/
.result-head {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	margin: 20px 0;
}
.result-head .h {
	font-weight: 700;
	font-size: 20px;
}

@media screen and (max-width: 767px) {
	.result-head {
		margin: 30px 0 15px 0;
		font-size: 12px;
	}
	.result-head .h {
		font-size: 16px;
	}
}

/*============================================================
	LAYOUT LEAD
*/
.layout-lead {
	margin: 60px 0;
	line-height: 2;
}
.layout-lead .subhead {
	margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
	.layout-lead {
		margin: 30px 0;
	}
}

/*============================================================
	LAYOUT KEYWORD
*/
.layout-keyword {
	margin: 40px 0;
}
.layout-keyword dt {
	margin: 0 0 10px 0;
}

@media screen and (max-width: 767px) {
	.layout-keyword {
		margin: 30px 0;
	}
}

/*============================================================
	LAYOUT COMPLETE
*/
.layout-complete .complete-outer {
	display: flex;
	justify-content: center;
	align-items: center;
	min-height: 240px;
	height: calc(94vh - 440px);
}
.layout-complete .complete-inner {
	width: 100%;
}
@media screen and (max-width: 767px) {
	.layout-complete .complete-outer {
		min-height: 200px;
		height: calc(94vh - 400px);
	}
}

/*============================================================
	PAGINATION
*/
.pagination {
	display: block;
	margin: 40px 0 0 0;
}
.pagination ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	margin: 0 -5px;
}
.pagination li {
	padding: 0 5px;
}
.pagination li a,
.pagination li span {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 0 2px 0.1em 2px;
	min-width: 32px;
	height: 32px;
	border: 1px solid #707070;
	text-decoration: none;
	color: #2c2c2c;
}
.pagination li.current span {
	background-color: #239d86;
	border-color: #239d86;
	color: #fff;
}
.pagination li.ellipsis {
	padding: 0;
	font-size: 12px;
}
.pagination li.ellipsis span {
	min-width: initial;
	background-color: transparent;
	border-color: transparent;
	color: #2c2c2c;
	text-indent: -0.5em;
	letter-spacing: -0.5em;
}
.os-pc .pagination li a:hover {
	background-color: #239d86;
	border-color: #239d86;
	color: #fff;
}
.pagination li i {
	margin-top: 2px;
}

@media screen and (max-width: 767px) {
	.pagination {
		margin: 30px 0 0 0;
	}
	.pagination ul {
		margin: 0 -3px;
	}
	.pagination li {
		padding: 0 3px;
	}
	.pagination li a,
	.pagination li span {
		min-width: 30px;
		height: 30px;
	}
}

/*============================================================
	HISTORY
*/
.history {
	margin: 20px 0 0 0;
}
.history .block {
	margin: 0 0 40px 0;
	border: 1px solid #239d86;
}
.history .block:last-child {
	margin: 0;
}
.history .block .head {
	display: flex;
	padding: 15px 20px;
	background-color: #239d86;
	font-weight: 700;
	color: #fff;
}
.history .block .head>div {
	margin-right: 20px;
}
.history .block .detail {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	padding: 20px;
}
.history .block .detail .form-layout-cart {
	flex: 1;
	margin: 0;
}
.history .block .detail .action {
	display: flex;
}
.history .block .detail .action>div {
	margin-left: 20px;
}
.history .block .detail .action [class^="btn-"] {
	padding: 0 20px;
	height: 40px;
	border-width: 1px;
	font-size: 14px;
}

@media screen and (max-width: 980px) {
	.history .block .detail .action {
		display: block;
	}
	.history .block .detail .action > div {
		margin-top: 15px;
	}
}

@media screen and (max-width: 767px) {
	.history .block {
		margin: 0 0 25px 0;
	}
	.history .block .head {
		display: block;
		padding: 10px 10px;
	}
	.history .block .head > div {
		margin-right: 0;
	}
	.history .block .detail {
		display: block;
		padding: 10px 10px 12px 10px;
	}
	.history .block .detail .form-layout-cart {
		margin: 0 0 5px 0;
	}
	.history .block .detail .form-layout-cart dt,
	.history .block .detail .form-layout-cart dd {
		padding-bottom: 10px;
	}
	.history .block .detail .form-layout-cart dt {
		width: 80px;
	}
	.history .block .detail .action {
		display: flex;
		justify-content: center;
		margin: 0 -4px;
	}
	.history .block .detail .action > div {
		flex-basis: 50%;
		margin: 0;
		padding: 0 4px;
	}
	.history .block .detail .action .single {
		flex-basis: 100%;
	}
	.history .block .detail .action [class^="btn-"] {
		padding: 0;
		font-size: 12px;
	}
	.history .block .detail .action .single [class^="btn-"] {
		font-size: 14px;
	}
	.pc-delete-warning-text {
		display:none;
	}
	.sp-delete-warning-text {
		display:block;
	}
}
.sp-delete-warning-text {
	display:none;
}
/*============================================================
	FAQ
*/
.faq-lead {
	margin: 30px 0;
}
.faq-lead .lead {
	position: relative;
	padding-left: 20px;
	line-height: 1.5;
}
.faq-lead .lead > i {
	position: absolute;
	top: 0;
	left: 0;
	font-weight: 700;
}
.faq-lead .lead-q {
	margin-bottom: 10px;
	font-weight: 700;
}

@media screen and (max-width: 767px) {
	.subhead + .faq-lead {
		margin-top: 15px;
	}
}

/*============================================================
	LOGIN
*/
.login {
	display: flex;
	justify-content: center;
	align-items: center;
	/* padding: 80px 0px; */
	/* padding: 295px 0px; */
	padding: 180px 0px;
}
.login .frame {
	margin: 0 auto;
	padding: 40px;
	flex-basis: 480px;
	background-color: #fff;
	border-radius: 10px;
	box-shadow: 0 3px 6px rgba(0,0,0,0.16);
}
.login .frame .h {
	padding: 0 0 10px 0;
	text-align: center;
	font-size: 24px;
	color: #239d86;
}
.login .frame .invalid {
	text-align: center;
	font-size: 14px;
}
.login .frame .input {
	padding: 10px 0 0 0;
}
.login .frame .input > div {
	margin: 0 0 40px 0;
}
.login .frame .input > div:last-child {
	margin: 0;
}
.login .frame .label {
	display: table;
	margin: 20px auto 0 auto;
}
.login .frame .btn {
	display: block;
	margin: 35px 0 0 0;
	cursor: default;
}
.login .frame .btn-action {
	margin: 0 auto;
	max-width: 160px;
	height: 40px;
	font-size: 16px;
}

@media screen and (max-width: 767px) {
	.login {
		padding-left: 24px;
		padding-right: 24px;
	}
	.login .frame {
		padding: 16px;
		flex-basis: 100%;
	}
	.login .frame .input > div {
		margin: 0 0 20px 0;
	}
	.login .frame .btn {
		margin: 20px 0 0 0;
	}
	.login .frame .btn-action {
		max-width: 100%;
		height: 48px;
	}
}

/*============================================================
	MODAL
*/
.modal {
	display: none;
	position: fixed;
	z-index: 999;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	overflow-y: auto;
	background-color: rgba(0,0,0,0.7);
}
.modal .modal-outer {
	display: table;
	width: 100%;
	height: 100%;
}
.modal .modal-inner {
	display: table-cell;
	vertical-align: middle;
	padding: 40px;
}
.modal .modal-frame {
	margin: 0 auto;
	padding: 70px 40px;
	/* max-width: 1180px; */
	max-width: 1205px;
	background-color: #fff;
}

@media screen and (max-width: 767px) {
	.modal .modal-inner {
		padding: 24px;
	}
	.modal .modal-frame {
		padding: 30px 16px;
		border-radius: 10px;
	}
	.modal .modal-frame .subhead {
		font-size: 16px;
	}
}

/*============================================================
	HEADER
*/
header {
	position: fixed;
	z-index: 100;
	top: 0;
	left: 0;
	width: 100%;
	background-color: #fff;
	line-height: 1.5;
	color: #239d86;
}
header .cart a {
	color: #239d86;
}
header a {
	text-decoration: none;
}
header::after {
	content: '';
	display: block;
	height: 8px;
	background: rgb(94,227,201);
	background: linear-gradient(90deg, rgba(94,227,201,1) 0%, rgba(101,180,165,1) 100%);
}
header .cart {
	display: flex;
	align-items: center;
	font-weight: 700;
}
header .cart .icon {
	position: relative;
	display: flex;
	align-items: center;
	margin-right: 5px;
	padding: 0 18px 0 0;
	height: 44px;
}
header .cart .icon::before {
	content: '';
	position: relative;
	display: block;
	width: 28px;
	height: 28px;
	background-image: url(/images/icon-cart.svg?b3d408a573529baf4e41c7669fc689e4);
	background-repeat: no-repeat;
	background-position: 50% 50%;
	background-size: contain;
}
header .cart .icon span {
	display: block;
	position: absolute;
	top: 3px;
	right: 0;
	padding: 0 2px 2px 2px;
	min-width: 20px;
	background-color: #000;
	text-align: center;
	font-size: 10px;
	line-height: 15px;
	border-radius: 3px;
	color: #fff;
	white-space: nowrap;
}
header .cart .icon.active {
	padding: 0 10px 0 0;
}
header .cart .icon.active span {
	top: 0;
	background-color: #ea1c1c;
	font-size: 12px;
	line-height: 18px;
	border-radius: 10px;
}
header .header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0 24px 0 40px;
	height: 80px;
}
header .header .nav {
	display: flex;
	align-items: center;
}
header .header .nav .logo {
	margin-bottom: 0;
	width: 112px;
}
header .header .nav .logo img {
	display: block;
}
header .header .nav .label {
	margin-left: 5px;
	font-weight: 700;
	font-size: 20px;
	line-height: 1.3;
}
header .header .nav ul {
	display: flex;
	font-size: 14px;
	line-height: 1.3;
}
header .header .nav ul li {
	margin: 0 0 0 25px;
}
header .header .nav ul li a {
	color: #000;
}
header .header .action {
	display: flex;
	align-items: center;
	font-weight: 700;
}
header .header .action .cart {
	margin-right: 20px;
}
header .header .action nav ul {
	display: flex;
}
header .header .action nav ul li {
	margin-left: 10px;
}
header .header .action nav ul li a {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 0 1em 2px 1em;
	height: 40px;
	background-color: #239d86;
	border-radius: 4px;
	color: #fff;
}
header .header .action nav ul li a.btn-search{
	border: 2px solid #239d86;
    background-color: white;
    color: #239d86;
    /* padding: 14px 28px; */
    font-size: 16px;
    cursor: pointer;
}
header .header .action nav ul li a.btn-login {
	background-color: #fff;
	color: #239d86;
}
header .header .switch {
	position: relative;
	z-index: 110;
	display: block;
	width: 60px;
	height: 60px;
}
header .header .switch::before,
header .header .switch::after {
	content: '';
}
header .header .switch::before,
header .header .switch::after,
header .header .switch i {
	display: block;
	position: absolute;
	top: 16px;
	left: 14px;
	width: 32px;
	height: 4px;
	border-radius: 2px;
	background-color: #239d86;
	transition: all 0.4s;
}
header .header .switch i {
	margin-top: 12px;
}
header .header .switch::after {
	margin-top: 24px;
}
header .header .switch-menu-sp {
	display: none;
}
header .menu-overlay {
	position: fixed;
	z-index: 101;
	top: 0;
	right: 0;
	height: 100%;
	background-color: rgba(0,0,0,0.7);
	opacity: 0;
	transition: opacity 0.4s;
}
header .menu {
	position: fixed;
	z-index: 102;
	top: 0;
	right: 0;
	height: 100%;
}
header .menu nav {
	position: fixed;
	top: 0;
	left: 100%;
	padding: 100px 20px 0 20px;
	width: 316px;
	height: 100%;
	background-color: #fff;
	transition: transform 0.4s;
	font-size: 16px;
}
header .menu .cart {
	display: none;
}
header .menu .nav li {
	display: flex;
	margin: 0 0 30px 0;
}
header .menu .nav li a {
	display: flex;
	align-items: center;
	color: #2c2c2c;
}
header .menu .nav li a i {
	display: block;
}
header .menu .nav li a i:first-child {
	margin: 2px 5px 0 0;
	font-size: 22px;
	color: #239d86;
}
header .menu .nav li a i.icon-arrow-next {
	margin: 2px 0 0 3px;
	font-size: 17px;
	color: #2c2c2c;
}
header .menu .action li {
	padding: 6px 0;
}

/* OPEN */
.menu-opened header .header .switch::before {
	margin-top: 12px;
	transform: rotate(45deg);
}
.menu-opened header .header .switch i {
	opacity: 0;
}
.menu-opened header .header .switch::after {
	margin-top: 12px;
	transform: rotate(-45deg);
}
.menu-active header .menu-overlay {
	width: 100%;
}
.menu-opened header .menu-overlay {
	opacity: 1;
}
.menu-opened header .menu nav {
	transform: translateX(-100%);
}

@media screen and (max-width: 767px) {
	header::after {
		height: 4px;
	}
	header .header {
		padding: 0 5px 0 15px;
		height: 60px;
	}
	header .header .nav .logo {
		width: 80px;
	}
	header .header .nav .label {
		font-size: 12px;
	}
	header .header .nav ul {
		display: none;
	}
	header .header .action nav {
		display: none;
	}
	header .header .action .cart {
		margin: 5px 0 0 0;
	}
	header .header .action .cart .name {
		display: none;
	}
	header .header .switch-menu-sp {
		display: block;
	}
	header .menu nav {
		padding: 70px 25px 0 25px;
		width: 92%;
	}
	header .menu .nav {
		display: block;
	}
	header .menu .cart {
		display: flex;
		margin: 0 0 25px 0;
		line-height: 1.3;
	}
	header .menu .cart .icon {
		margin-top: 5px;
	}
}

/*============================================================
	FOOTER
*/
footer {
	padding: 20px;
	background-color: #239d86;
	text-align: center;
	font-size: 12px;
	line-height: 1.5;
	color: #fff;
}
footer a {
	text-decoration: none;
	color: #fff;
}
footer ul {
	display: flex;
	justify-content: center;
}
footer ul li::before {
	content: '|';
	padding: 0 15px;
}
footer ul li:first-child::before {
	content: none;
}
footer small {
	display: block;
	margin: 20px 0 0 0;
	font-size: 10px;
}

@media screen and (max-width: 767px) {

}

/*============================================================
	SYSTEM
*/
.body-system header::after {
	display: none;
}
.body-system .code {
	text-align: center;
	font-size: 40px;
	color: #239d86;
}

@media screen and (max-width: 767px) {
	.body-system .code {
		font-size: 24px;
	}
	.body-system .message span {
		display: inline-block;
	}
}

/*============================================================
	CALENDAR
*/
.js-date {
	position: relative;
}
.js-date .form-date-wrap {
	position: relative;
}
.js-date .form-date {
	position: relative;
}
.js-date .form-date-wall {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	cursor: pointer;
}
.calendar-wall {
	position: fixed;
	z-index: 9998;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.calendar {
	position: absolute;
	z-index: 9999;
	top: 0;
	left: 180px;
	width: 340px;
	background-color: #239d86;
	padding: 0 5px 5px 5px;
	border-radius: 4px;
	box-shadow: 0 0 8px rgba(0,0,0,0.2);
}
.calendar .head {
	position: relative;
	padding: 15px;
	text-align: center;
	font-size: 18px;
	line-height: 1.2;
	color: #fff;
}
.calendar .head i {
	font-style: normal;
}
.calendar .head i.month-str {
	display: none;
}
.calendar .ctr {
	position: absolute;
	top: 50%;
	margin-top: -10px;
	width: 30px;
	cursor: pointer;
	font-size: 20px;
}
.calendar .clndr-previous-button {
	left: 0;
}
.calendar .clndr-next-button {
	right: 0;
}
.calendar table {
	width: 100%;
	background-color: #fff;
	text-align: center;
	font-size: 15px;
}
.calendar table td {
	border: 1px solid #239d86;
}
.calendar table .week {
	background-color: #eee;
}
/*.calendar table .today {
	background-color: #eee;
}*/
.calendar table .selected {
	background-color: #239d86;
	color: #fff;
}
.calendar .day-contents {
	display: block;
	margin: 0 auto;
	height: 38px;
	line-height: 38px;
	cursor: pointer;
}
.calendar .last-month .day-contents,
.calendar .next-month .day-contents {
	display: none;
}
.calendar .inactive .day-contents {
	color: #c2c2c2
}

@media screen and (max-width: 767px) {
	.calendar {
		left: 0;
		top: 54px;
		width: 340px;
	}
}
@media screen and (max-width: 500px) {
	.calendar {
		left: -100px;
		right: 0;
		width: auto;
	}
}

/* トップタブ */
.tab {
	display: flex;
	/* flex-wrap: wrap; */
	justify-content: center;
	margin: 60px 0;
}

.tab li {
	max-width: 590px;
	width: 100%;
	text-align: center;
}

.tab li a {
	display: block;
	background: #fff;
	padding: 0;
	font-size: 30px;
	height: 127px;
	font-weight: bold;
	text-decoration: none;
	padding: 38px 0 0;
}

.tab li a {
	color: #239D86;
}

.tab li a:hover {
	color: #239D86;
}

/*liにactiveクラスがついた時の形状*/
.tab li.active a {
	background: #239D86;
	color: #fff;
}


/*エリアの表示非表示と形状*/
.area {
	display: none;
	/*はじめは非表示*/
	opacity: 0;
	/*透過0*/

}

/*areaにis-activeというクラスがついた時の形状*/
.area.is-active {
	display: block;
	/*表示*/
	-webkit-animation-name: displayAnime;
	        animation-name: displayAnime;
	/*ふわっと表示させるためのアニメーション*/
	-webkit-animation-duration: .5s;
	        animation-duration: .5s;
	-webkit-animation-fill-mode: forwards;
	        animation-fill-mode: forwards;
}

@media screen and (max-width: 767px) {
	.tab {
		flex-wrap: nowrap;
	}

	.tab li a {
		font-size: 16px;
		padding: 15px 0 0;
		height: 60px;
	}
}

@-webkit-keyframes displayAnime {
	from {
		opacity: 0;
	}

	to {
		opacity: 1;
	}
}

@keyframes displayAnime {
	from {
		opacity: 0;
	}

	to {
		opacity: 1;
	}
}

/* トップ追加セクション */

.worries{
	background-color: #F2FFFD;
	padding: 120px 0 0;
	color: #555555;
}
@media screen and (max-width: 767px) {
	.worries{
		padding: 40px 0 0;
	}
}
.worries__head h2{
	font-size: 40px;
	font-weight: bold;
	text-align: center;
}
@media screen and (max-width: 767px) {
	.worries__head h2{
		font-size: 24px;
	}
}
.worries__pic{
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
	gap: 0px;
	max-width: 1720px;
	margin: 60px auto 90px;
	padding: 0 20px;
}

@media screen and (max-width: 767px) {
	.worries__pic{
		grid-template-columns: 1fr;
	}
}
.worries__pic .items{
	display: flex;
	flex-direction: column;
	align-items: center;
}
@media screen and (max-width: 767px) {
	.worries__pic .items{
		flex-direction: row;
		text-align: left;
		margin: 0px auto 20px;
		width: 100%;
	}
}

.worries__pic .items img{
	width: 12.5vw;
	height: auto;
	border-radius: 9999px;
	margin: 20px 0 24px;
}
@media screen and (max-width: 767px) {
	.worries__pic .items img{
		margin: 0 16px 0 0;
		width: 60px;
	}
}
.worries__pic .items p{
	text-align: center;
	/* font-size: 18px; */
	font-size: 16px;
	font-weight: bold;
}
@media screen and (max-width: 767px) {
	.worries__pic .items p{
		text-align: left;
		font-size: 16px;
	}
}


.solution{
	background-color: #fff;
	padding: 80px 20px 90px;
}
@media screen and (max-width: 767px) {
	.solution{
		padding: 40px 20px 40px;
	}
}
.solution__tit{
	margin: 0 auto;
	text-align: center;
}
.solution h2{
	font-size: 40px;

	border-bottom: 2px solid #555;
	display: inline-block;
}
@media screen and (max-width: 767px) {
	.solution h2{
		font-size: 24px;
	}
}
.solution__point{
	max-width: 1440px;
	margin: 80px auto 0;
}
@media screen and (max-width: 767px) {
	.solution__point{
		margin: 40px auto 0;
	}
}
.solution .points{
	display: flex;
	justify-content: start;
	align-items: center;
	/* margin: 0 0 60px; */
	margin: 0 50px 20px 50px;
}
@media screen and (max-width: 767px) {
	.solution .points{
		margin: 0 0 20px;
	}
}
.solution .points img{
	width: 76px;
	height: auto;
	margin: 0 35px 0 0;
}

@media screen and (max-width: 767px) {
	.solution .points img{
		width:30px;
		height: auto;
		margin: 0 20px 0 0;
	}
}
.solution .points p{
	/* font-size: 30px; */
	font-size: 24px;
	text-align: left;
}
@media screen and (max-width: 767px) {
	.solution .points p{
		font-size: 15px;
		text-align: left;
	}
}



.sp-br{
	display: none;
}
@media screen and (max-width: 768px) {
	
	.sp-br{
		display: block;
	}
}
.pc-br{
	display: block;
}
@media screen and (max-width: 768px) {
	
	.pc-br{
		display: none;
	}
}
.use-way-label div:not(:first-child){
	margin-top: 10px;
}

