@charset "utf-8";

/*============================================================
	IMPORT
*/
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@500;700&display=swap');

/*============================================================
	ICON
*/
@font-face {
	font-family: 'icon';
	src: url('../fonts/icon.woff') 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%;
	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;
}
.content {
	position: relative;
	flex: 1;
	padding: 80px 0;
}
.container {
	position: relative;
	margin: 0 auto;
	padding: 0 40px;
	max-width: 1260px;
}

/* 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%;
	}
	.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;
}
.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('/assets/images/icon-hint.svg');
	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 */
::-webkit-input-placeholder {
	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-shown {
	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("/assets/images/form-select.svg");
	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("/assets/images/form-checkbox.svg") 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("/assets/images/icon-search.svg");
	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%;
	}
}

/*============================================================
	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-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-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-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('/assets/images/icon-th-music.svg');
}
.table-list table .icon-th-artist {
	background-image: url('/assets/images/icon-th-artist.svg');
}
.table-list table .icon-th-album {
	background-image: url('/assets/images/icon-th-album.svg');
}
.table-list table .icon-th-organization {
	width: 30px;
	background-image: url('/assets/images/icon-th-organization.svg');
}
.table-list table .icon-th-scene {
	background-image: url('/assets/images/icon-th-scene.svg');
}
.table-list table .icon-th-cart-add {
	background-image: url('/assets/images/icon-th-cart-add.svg');
}
.table-list table .icon-th-cart-remove {
	background-image: url('/assets/images/icon-th-cart-remove.svg');
}
.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;
	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;
}
.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('/assets/images/icon-cart.svg');
	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-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: 10px 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;
	}
}
/*
Alert and notifications
*/
.close {
	position: absolute;
	padding: 0.65rem 1.25rem;
	text-shadow: none;
	color: inherit;
	right: 5px !important;
	top: 0px !important;
}
  
.close:hover {
	color: inherit;
	opacity: 1;
}
  
.alert {
	position: relative;
	border-color: inherit;
	padding:.75rem 1.25rem;
	margin-bottom:1rem;
	border:1px solid transparent;
	border-radius:.25rem
}
  
.alert .alert-link {
	color: inherit !important;
	font-weight: 600;
	border-bottom: 1px solid;
	border-bottom-color: rgba(44, 45, 58, 0.1);
}
  
.alert.animated {
	-webkit-animation-duration: 1s !important;
	animation-duration: 1s !important;
	-webkit-animation-fill-mode: both !important;
	animation-fill-mode: both !important;
}
  
.alert a {
	color: inherit;
	font-weight: 700;
}
  
.alert a:hover {
	color: inherit;
	text-decoration: underline;
}
  
.alert.alert-primary {
	background-color: #e5f2ff;
	color: #1072ce;
	border-color: rgba(0, 132, 255, 0.15);
}
  
.alert.alert-primary hr {
	border-top-color: rgba(0, 132, 255, 0.15);
}
  
.alert.alert-warning {
	background-color: #fef8e2;
	color: #dfc14a;
	border-color: rgba(243, 215, 104, 0.15);
}
  
.alert.alert-warning hr {
	border-top-color: rgba(243, 215, 104, 0.15);
}
  
.alert.alert-success {
	background-color: #e5fcd0;
	color: #7dc835;
	border-color: rgba(148, 223, 74, 0.15);
}
  
.alert.alert-success hr {
	border-top-color: rgba(148, 223, 74, 0.15);
}
  
.alert.alert-danger {
	background-color: #fee5e4;
	color: #e3423d;
	border-color: rgba(250, 98, 94, 0.15);
}
  
.alert.alert-danger hr {
	border-top-color: rgba(250, 98, 94, 0.15);
}
  
.alert.alert-info {
	background-color: #e7f7fe;
	color: #69c1e6;
	border-color: rgba(134, 212, 245, 0.15);
}
  
.alert.alert-info hr {
	border-top-color: rgba(134, 212, 245, 0.15);
}
  
.alert.alert-teal {
	background-color: #d9fff8;
	color: #20c7aa;
	border-color: rgba(44, 221, 190, 0.15);
}
  
.alert.alert-teal hr {
	border-top-color: rgba(44, 221, 190, 0.15);
}
  
.alert.alert-secondary {
	background-color: #dfe0e3;
	color: #828897;
	border-color: rgba(168, 173, 185, 0.15);
}
  
.alert.alert-secondary hr {
	border-top-color: rgba(168, 173, 185, 0.15);
}
  
.alert.alert-light {
	background-color: #fff;
	color: #9ba4ae;
	border-color: #e1eaea;
}
  
.alert.alert-dark {
	background-color: #f2f6f8;
	color: #262734;
	border-color: rgba(44, 45, 58, 0.15);
}
  
.alert.alert-dark hr {
	border-top-color: rgba(44, 45, 58, 0.15);
}
  
.alert.alert-purple {
	background-color: #f4daff;
	color: #8f3faf;
	border-color: rgba(169, 94, 199, 0.15);
}
  
.alert.alert-purple hr {
	border-top-color: rgba(169, 94, 199, 0.15);
}
  
.alert.alert-pink {
	background-color: #fde6f3;
	color: #da55a0;
	border-color: rgba(247, 125, 194, 0.15);
}
  
.alert.alert-pink hr {
	border-top-color: rgba(247, 125, 194, 0.15);
}
/**notifications - bootstrap-notify**/
.alert .progress {
	position: absolute;
	width: calc(100% - 2px);
	left: 0;
	right: 0;
	bottom: -1px;
	height: 2px;
	border-radius: 0;
	-webkit-border-radius: 0;
	background-color: transparent;
}
  
.alert .progress>.progress-bar {
	background-color: #0084ff;
	border-radius: 0px;
	height: 2px;
	line-height: 2px;
	border-bottom-left-radius: .25rem;
	-webkit-border-bottom-right-radius: .25rem;
}
  
.alert.alert-info .progress>.progress-bar {
	background-color: #86d4f5;
}
  
.alert.alert-success .progress>.progress-bar {
	background-color: #94df4a;
}
  
.alert.alert-warning .progress>.progress-bar {
	background-color: #f3d768;
}
  
.alert.alert-danger .progress>.progress-bar {
	background-color: #fa625e;
}
  
.alert.alert-light .progress>.progress-bar {
	background-color: #e1eaea;
}
  
.alert.alert-primary .progress>.progress-bar {
	background-color: #0084ff;
}
  
.alert.alert-teal .progress>.progress-bar {
	background-color: #2cddbe;
}
  
.alert.alert-purple .progress>.progress-bar {
	background-color: #a95ec7;
}
  
.alert.alert-dark .progress>.progress-bar {
	background-color: #2c2d3a;
}
  
.alert.alert-pink .progress>.progress-bar {
	background-color: #f77dc2;
}
  
.table-demo-ui tr,
.table-demo-ui th,
.table-demo-ui td,
.table-demo-ui thead,
.table-demo-ui tbody {
	vertical-align: middle;
}
  
  [data-notify="title"] {
	display: block;
	width: 100%;
	font-weight: 500 !important;
}
  
  [data-notify="message"] {
	display: block;
	width: 100%;
}
  
  [data-notify="icon"].alert-thumb,
.alert-thumb [data-notify="icon"] {
	float: left;
	display: inline-flex !important;
	margin-right: 0px;
	text-align: center;
	width: 2.5rem;
	height: 100%;
	line-height: 1;
	position: absolute;
	left: .5rem;
	top: -1px;
	-webkit-box-align: center !important;
	-ms-flex-align: center !important;
	align-items: center !important;
	-webkit-box-pack: center !important;
	-ms-flex-pack: center !important;
	justify-content: center !important;
	overflow: hidden;
	font-size: 16px;
}
  
  [data-notify="icon"].alert-thumb img,
.alert-thumb [data-notify="icon"] img {
	width: 90%;
	display: block;
	height: auto;
	position: relative;
	top: 1px;
	margin-left: auto;
	margin-right: auto;
	border-radius: 50%;
	-webkit-border-radius: 50%;
}
  
.alert-thumb [data-notify="icon"]+*,
  [data-notify="icon"].alert-thumb+*,
.alert-thumb [data-notify="icon"]+*+*,
  [data-notify="icon"].alert-thumb+*+* {
	padding-left: 2rem;
}

/* トップタブ */
.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;
	/*表示*/
	animation-name: displayAnime;
	/*ふわっと表示させるためのアニメーション*/
	animation-duration: .5s;
	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;
	}
}

@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;
	}
}

@charset "utf-8";

/*============================================================
	BODY
*/
.content {
	padding: 0;
}

/*============================================================
	BUTTON REGISTER
*/
.content .btn-gradation {
	margin: 0 auto;
	max-width: 390px;
	width: 100%;
	font-size: 16px;
}

@media screen and (max-width: 767px) {
	.content .btn-gradation {
		max-width: 100%;
	}
}

/*============================================================
	HEADLINE
*/
.headline {
	margin: 0 auto;
	max-width: 320px;
	text-align: center;
	line-height: 1.5;
}
.headline h2 {
	font-size: 40px;
	color: #239d86;
}
.headline h3::before {
	content: '';
	display: block;
	margin: 0 0 10px 0;
	height: 2px;
	background-color: #239d86;
}
.headline h3 {
	padding: 20px 0 0 0;
	font-size: 18px;
}

@media screen and (max-width: 767px) {
	.headline {
		max-width: 240px;
	}
	.headline h2 {
		font-size: 24px;
	}
	.headline h3::before {
		margin: 0 0 10px 0;
	}
	.headline h3 {
		padding: 15px 0 0 0;
		font-size: 12px;
	}
}

/*============================================================
	MAIN
*/
.main {
	padding: 40px 0 50px 0;
	background: rgb(94,227,201);
	background: linear-gradient(90deg, rgba(94,227,201,1) 0%, rgba(101,180,165,1) 100%);
}
.main .outer {
	background-color: rgba(255,255,255,0.8);
}
.main .row {
	display: flex;
	align-items: center;
	margin: 0 -35px;
	padding: 20px 0;
}
.main .head {
	padding: 0 35px;
	flex-basis: 50%;
}
.main .head h2 {
	margin: 0 auto;
	max-width: 348px;
}
.main .head h2 img {
	margin-left: -15px;
}
.main .head h3 {
	margin: 30px 0 45px 0;
	padding: 15px 0;
	border-top: 1px solid #2c2c2c;
	border-bottom: 1px solid #2c2c2c;
	text-align: center;
	font-weight: 700;
	font-size: 30px;
	line-height: 1.7;
}
.main .head h3 span{
	font-size: 20px;
}
.main .detail {
	padding: 0 35px;
	flex-basis: 50%;
}
.main .detail ul {
	display: flex;
	flex-wrap: wrap;
	margin: 0 -15px;
}
.main .detail ul li {
	padding: 15px;
	flex-basis: 50%;
}
.main .detail ul li div {
	position: relative;
	padding: 30px 0;
	height: 100%;
	background-color: #fff;
	box-shadow: 0 3px 6px rgba(0,0,0,0.16);
}
.main .detail ul li div::before {
	content: '';
	display: block;
	position: absolute;
	right: 0;
	bottom: 0;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 0 0 32px 32px;
	border-color: transparent transparent #239d86 transparent;
}
.main .detail ul li img {
	display: block;
	/* margin: 0 auto;
	width: 160px; */
	margin: 0 auto 16px;
	width: 100px;
}
.main .detail ul li img.--streaming {
	width: 130px;
    margin: 0 auto -10px;
}
.main .detail ul li h4 {
	display: flex;
	justify-content: center;
	align-items: center;
	min-height: 70px;
	text-align: center;
	font-weight: 700;
	font-size: 17px;
	line-height: 1.7;
	color: #555;
}
.main .btn-register {
	display: none;
	margin: 40px 0 0 0;
}

@media screen and (max-width: 1080px) {
	.main .row {
		display: block;
		margin: 0;
		padding: 60px 0;
	}
	.main .head {
		padding: 0;
	}
	.main .head a {
		display: none;
	}
	.main .detail {
		padding: 0;
	}
	.main .btn-register {
		display: block;
	}
}

@media screen and (max-width: 767px) {
	.main {
		padding: 22px 0 26px 0;
	}
	.main .row {
		padding: 30px 0 30px 0;
	}
	.main .head h2 {
		max-width: 150px;
	}
	.main .head h2 img {
		margin-left: -10px;
	}
	.main .head h3 {
		margin: 20px 0 14px 0;
		padding: 10px 0;
		font-size: 12px;
	}
	.main .head h3 br {
		display: none;
	}
	.main .detail ul {
		margin: 0 -6px;
	}
	.main .detail ul li {
		padding: 6px;
	}
	.main .detail ul li div {
		padding: 15px 0;
	}
	.main .detail ul li div::before {
		border-width: 0 0 16px 16px;
	}
	.main .detail ul li img {
		width: 90px;
	}
	.main .detail ul li h4 {
		min-height: 50px;
		font-size: 12px;
	}
	.main .btn-register {
		margin: 14px 0 0 0;
	}
}

/*============================================================
	ABOUT
*/
.about {
	padding: 80px 0;
	line-height: 2;
}
.about .lead {
	margin: 30px 0 20px 0;
	text-align: center;
	font-size: 100%;
}
.about .lead p {
	margin: 2em 0 0 0;
}
.about .lead p:first-child {
	margin: 0;
}
.about .lead p strong {
	font-weight: 700;
	color: #239d86;
}
.about .notes {
	display: table;
	margin: 0 auto;
	font-size: 12px;
}

@media screen and (max-width: 767px) {
	.about .notes {
		display: block;
		font-size: 11px;
	}
	.about .notes li {
		padding-left: 1em;
		text-indent: -1em;
	}
}

/*============================================================
	HOWTO
*/
.howto {
	padding: 80px 0;
	background-color: #e7f7f4;
}
.howto .step {
	margin: 40px 0 0 0;
}
.howto .step .label {
	display: flex;
}
.howto .step .label span {
	display: block;
	width: 120px;
	background-color: #239d86;
	border-radius: 4px 4px 0 0;
	text-align: center;
	font-size: 24px;
	color: #fff;
}
.howto .step .label span i {
	font-size: 32px;
}
.howto .step .frame {
	display: flex;
	margin: 0 0 40px 0;
	padding: 25px;
	background-color: #fff;
	box-shadow: 10px 10px 0px 0px #9dc6be;
}
.howto .step .frame .row {
	display: flex;
	align-items: center;
	flex-basis: 565px;
	margin: 0;
}
.howto .step .frame .screen {
	flex-basis: 222px;
}
.howto .step .frame .screen img {
	box-shadow: 0 3px 6px rgba(0,0,0,0.16);
}
.howto .step .frame .head {
	flex: 1;
	padding: 0 25px;
}
.howto .step .frame .head p {
	display: flex;
	align-items: center;
	font-size: 18px;
	color: #239d86;
}
.howto .step .frame .head p::before,
.howto .step .frame .head p::after {
	content: '';
	display: block;
	width: 16px;
	height: 2px;
	background-color: #239d86;
}
.howto .step .frame .head p span {
	display: block;
	margin: 0 8px;
	padding: 0 0 2px 0;
}
.howto .step .frame .head h3 {
	margin: 5px 0 0 0;
	font-weight: 700;
	font-size: 24px;
	line-height: 1.5;
}
.howto .step .frame .detail {
	flex: 1;
	display: flex;
	align-items: center;
	position: relative;
	padding: 0 0 0 25px;
	height: 152px;
}
.howto .step .frame .detail::before {
	content: '';
	display: block;
	position: absolute;
	top: 12px;
	bottom: 12px;
	left: 0;
	width: 1px;
	background-color: #585858;
}
.howto .step .frame .detail .inner {
	line-height: 2;
}
.howto .step .frame .detail .inner .notes {
	margin: 5px 0 0 0;
	font-size: 12px;
}

@media screen and (max-width: 1080px) {
	.howto .step .frame {
		display: block;
	}
	.howto .step .frame .head h3 br {
		display: none;
	}
	.howto .step .frame .detail {
		display: block;
		margin: 30px 0 0 0;
		padding: 0;
		height: auto;
	}
	.howto .step .frame .detail::before {
		display: none;
	}
}

@media screen and (max-width: 767px) {
	.howto {
		padding: 80px 0 40px 0;
	}
	.howto .step .label span {
		width: 82px;
		font-size: 16px;
	}
	.howto .step .label span i {
		font-size: 24px;
	}
	.howto .step .frame {
		margin: 0 0 50px 0;
		padding: 16px;
	}
	.howto .step .frame .row {
		display: block;
	}
	.howto .step .frame .head {
		margin: 15px 0 0 0;
		padding: 0;
	}
	.howto .step .frame .head p {
		justify-content: center;
		font-size: 16px;
	}
	.howto .step .frame .head h3 {
		text-align: center;
		font-size: 18px;
	}
	.howto .step .frame .detail {
		margin: 15px 0 0 0;
	}
	.howto .step .frame .detail::before {
		display: block;
		position: static;
		margin: 0 0 15px 0;
		width: 100%;
		height: 1px;
	}
	.howto .step .frame .detail .inner {
		line-height: 1.7;
	}
	.howto .step .frame .detail .inner .notes {
		font-size: 11px;
	}
}

/*============================================================
	REGISTER
*/
.register {
	padding: 35px 0 50px 0;
}
.register .head h2 {
	margin: 0 auto;
	max-width: 238px;
}
.register .head h2 img {
	margin-left: -15px;
}
.register .head h3 {
	margin: 20px auto 25px auto;
	padding: 10px 0;
	max-width: 574px;
	border-top: 1px solid #2c2c2c;
	border-bottom: 1px solid #2c2c2c;
	text-align: center;
	font-weight: 700;
	font-size: 20px;
	line-height: 1.7;
}

@media screen and (max-width: 767px) {
	.register {
		padding: 60px 0 120px 0;
	}
	.register .head h2 {
		max-width: 160px;
	}
	.register .head h2 img {
		margin-left: -10px;
	}
	.register .head h3 {
		margin: 20px auto 35px auto;
		font-size: 12px;
	}
}

/*============================================================
	申請選択ページ
*/
.select {
	display: flex;
    justify-content: center;
    align-items: center;
	padding: 80px 0;
}
.select .frame {
	margin: 0 auto;
    padding: 56px 40px;
    background-color: #fff;
    border-radius: 10px;
    box-shadow: 0 3px 6px rgba(0,0,0,0.16);
}
.select .frame .h {
	padding: 0 0 40px 0;
    text-align: center;
    font-size: 24px;
    color: #239d86;
}
.select__btn {
	margin-bottom: 24px;
}
.select__sup {
	margin-top: 40px;
}
.select__sup-txt {
	display: flex;
	gap: 8px;
}
.select__sup-txt:first-child {
	margin-bottom: 24px;
}
.select__sup-hint {
	width: 16px;
	height: 16px;
	background-color: #239d86;
	background-image: url("/assets/images/icon-hint.svg");
	background-size: contain;
	border-radius: 50%;
	margin-top: 5px;
}
.select__sup p {
	max-width: 100%;
    width: 359px;
	font-size: 14px;
}
@media screen and (max-width: 767px) {
	.select {
		padding: 40px 0 80px 0;
	}
	.select .frame {
		padding: 40px 16px;
		border-radius: 10px;
	}
	.select .frame .h {
		padding: 0 0 24px 0;
	}
	.select__sup {
		margin-top: 24px;
	}
	.select__sup p {
		width: 271px;
	}
}

/*============================================================
	新規申し込み
*/
.new {
	display: flex;
    justify-content: center;
    align-items: center;
	padding: 80px 0;
}
.new .frame {
	margin: 0 auto;
    padding: 52px 40px 43px 34px;
    flex-basis: 1180px;
    background-color: #fff;
}
.new__heading {
	margin-bottom: 40px;
}
.new__heading h1 {
	justify-content: left;
}
.icon-application {
	width: 33px;
	height: 40px;
	margin-right: 16px;
}
.new__head {
	text-align: center;
	font-size: 24px;
	color: #239D86;
	margin-bottom: 32px;
}
.new__head .-br {
	display: none;
}
@media screen and (max-width: 767px) {
	.new {
		padding: 40px 0 80px 0;
	}
	.new .frame {
		padding: 40px 16px;
		flex-basis: 327px;
		border-radius: 10px;
	}
	.new__heading {
		margin-bottom: 24px;
	}
	.new__head {
		font-size: 20px;
	}
	.new__head .-br {
		display: block;
	}
}

/*============================================================
	お客様情報一覧
*/
.list {
	display: flex;
    justify-content: center;
    align-items: center;
	padding: 50px 0;
}
.list .frame {
	margin: 0 auto;
    padding: 40px 40px 56px 40px;
    flex-basis: 1180px;
    background-color: #fff;
}
.list__ttl h1 {
	justify-content: left;
	margin-bottom: 40px;
}
.list__tb table th div {
	justify-content: center;
}
.list__tb table th {
	padding-top: 22px;
	padding-bottom: 22px;
}
.list__tb table th, .list__tb table td {
	border: none;
	text-align: center;
}
.list__tb table .list__tb-tr {
	cursor: pointer;
	transition: .3s;
}
.list__tb table .list__tb-tr:hover {
	background-color: #F1F1F1;
}
.list__tb table .list__tb-tr:nth-child(odd):hover {
	background-color: #C3EBE2;
}
.list__tb table .list__tb-tr[data-href] {
    cursor: pointer;
}
.list__tb table .list__tb-tr:nth-child(odd) {
	background-color: #E4FAF5;
}
.list__tb table td {
	padding: 19px 17px;
}
.list__tb table td .-name {
	width: 316px;
	overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}
@media screen and (max-width: 767px) {
	.list {
		padding: 40px 0 80px 0;
	}
	.list .frame {
		padding: 40px 0 40px 16px;
		flex-basis: 327px;
		border-radius: 10px;
	}
	.table-scroll {
		width: 311px;
		overflow-x: scroll;
		padding-right: 16px;
	}
	.list__tb table td .-name {
		width: 186px;
	}
	.list__tb table td div {
		width: 166px;
	}
}

/*============================================================
	オンライン納品_管理画面ページ
*/
.page {
	display: flex;
    justify-content: center;
    align-items: center;
	padding: 80px 0;
}
.page .frame {
	margin: 0 auto;
    padding: 32px 38px 56px 38px;
    flex-basis: 1180px;
    background-color: #fff;
}
.page__ttl h1 {
	justify-content: left;
	margin-bottom: 40px;
}
.page__ttl h1 .sp {
	display: none;
}
.page__heading {
	font-size: 16px;
	margin-bottom: 40px;
}
.page__info-ttl {
	display: flex;
	gap: 24px;
	align-items: center;
	margin-bottom: 40px;
}
.page__info-ttl h2 {
	font-size: 24px;
	font-weight: bold;
}
.page__info-btn a {
	width: 88px;
	height: 40px;
	font-size: 14px;
}
.page__hr {
	margin-top: 56px;
	margin-bottom: 56px;
}
.page__setting h2 {
	font-size: 24px;
	font-weight: bold;
}
.page__setting-form {
	width: 100%;
    line-height: 1.5;
	margin-bottom: 56px;
}
.page__setting-form dl {
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 60px;
}
.page__setting-form dl:last-child {
	margin-bottom: 0;
}
.page__setting-form dt {
	width: 267px;
	padding-top: 11px;
	font-size: 16px;
	font-weight: bold;
}
.page__form-inline {
	display: flex;
	align-items: center;
}
.page__form-control {
	/* width: 500px; */
	width: 470px;
}
.page__form-entered {
	padding-top: 11px;

}
input[type="file"] {
    display: none;
}
.page__form-file {
	display: block;
	border: 1px dashed #989898;
	border-radius: 4px;
	background-color: #FAFAFA;
	width: 500px;
	height: 300px;
    cursor: pointer;
	transition: .3s;
	font-size: 14px;
	color: #2C2C2C;
	margin-bottom: 8px;
	position: relative;
}
.page__form-file:hover {
	opacity: .6;
}
.page__form-file.-uploaded:hover {
	opacity: 1;
	cursor: auto;
}
.page__form-file .-upload {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	display: grid;
	gap: 16px;
}
.icon-upload {
	width: 48px;
	height: 48px;
	margin: 0 auto;
}
.page__setting-form .page__form-id {
	display: block;
}
.page__form-mail {
	display: flex;
	margin-bottom: 8px;
}
.page__form-mail:last-child {
	margin-bottom: 0;
}
.page__form-file.-icon {
	height: 200px;
	padding: 61px 120px;
}
.page__form-file.-thumb {
	width: 184px;
	height: 138px;
	border-radius: 0;
}
.page__form-file.-thumb .-upload {
	gap: 8px;
	font-size: 12px;
	width: 100%;
	text-align: center;
}
.page__form-url {
	display: flex;
	align-items: center;
	gap: 16px;
}
.page__form-link {
	display: flex;
	align-items: center;
	gap: 4px;
	color: #239D86;
}
.page__form-link:hover {
	color: #239D86 !important;
}
.icon-share {
	width: 16px;
	height: 16px;
}
.page__form-btn {
	display: flex;
	align-items: center;
	gap: 16px;
}
.page__form-btn a {
	font-size: 14px;
	height: 40px;
	padding: 14px 16px 12px 16px;
}
.page__form-btn.only-pc {
	display: flex;
}
.page__form-btn.only-sp {
	display: none;
}
.page__upload-ttl {
	display: flex;
	gap: 24px;
	align-items: center;
	margin-bottom: 40px;
}
.page__upload-ttl h2 {
	font-size: 24px;
	font-weight: bold;
}
.page__upload-layout {
	display: flex;
	justify-content: end;
	gap: 20px;
}
.page__upload-btn a {
	padding: 30px 24px;
}
.page__upload-btn a br {
	display: none;
}
.page__upload-img {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 240px;
	height: 240px;
	overflow: auto;
	display: flex;
    align-items: center;
}
.page__upload-logo {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	height: 180px;
    overflow: auto;
    display: flex;
    align-items: center;
}
.btn-layout .outer.page__outer {
	max-width: 588px;
}
.page__outer .-sp {
	display: none;
}
.page__form-layout .page__form-ttl {
	width: 247px;
	font-weight: bold;
	padding-top: 0 !important;
}
.page__file-btn {
	width: 144px;
	height: 40px;
	font-size: 14px;
	transition: .3s;
	margin-bottom: 8px;
}
.page__file-btn:hover {
	opacity: .6;
}
.page__movie {
	width: 615px;
	row-gap: 24px;
}
.page__movie-up label {
	transition: .3s;
}
.page__movie-up label:hover {
	opacity: .6;
}
.page__up-thumb {
	width: 184px;
	/* height: 138px; */
	margin-bottom: 8px;
}
.page__up-radio {
	display: block !important;
}
.file-message {
	position: relative;
	padding-left: 30px;
}
.file-message::before {
	content: "";
	display: block;
	background-image: url("/assets/images/icon_movie.svg");
	width: 24px;
	height: 24px;
	margin-right: 8px;
	position: absolute;
	top: 0;
	left: 0;
}
.page__file-wrap {
	display: flex;
	align-items: center;
	gap: 16px;
}
.file-delete {
	width: 88px;
	height: 40px;
	font-size: 14px;
	transition: .3s;
}
.file-delete:hover {
	opacity: .6;
}
.page__upload-thumb {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 184px;
    height: 138px;
    overflow: auto;
    display: flex;
    align-items: center;
}
.page__upload-thumb {
	position: relative;
}
.-iconEdit::before {
	content: "";
	display: block;
	background-image: url("/assets/images/icon_edit.svg");
	width: 24px;
	height: 24px;
	position: absolute;
	top: 4px;
	right: 4px;
}
.hidden {
    display: none;
}
.page__form-ttl.-thumb {
	display: flex;
	align-items: center;
}
.page__form-layout .page__form-ttl {
	margin-top: 5px;
}
.page__attention {
	margin-bottom: 24px;
}
.page__attention-ttl {
	font-size: 20px;
	font-weight: bold;
	color: #2C2C2C;
	margin-bottom: 8px;
}
.page__attention-txt {
	font-size: 16px;
	font-weight: bold;
	color: #2C2C2C;
}
.page__attention-txt span {
	color: #EA1C1C;
}
.page__checkarea {
	display: grid;
    gap: 8px;
}
.page__checkarea li {
	font-size: 14px;
	color: #2C2C2C;
}
.page__checkarea .-checkbox span::before {
	border: 1px solid #707070;
	border-radius: 3px;
}
.page__form-up {
	width: 40px;
}
.page__form-up:hover {
	background-color: #239d86;
    border-color: #239d86;
    color: #fff !important;
}
.page__form-up .icon-arrow-prev {
	transform: rotate(90deg);
}
.page__form-down {
	width: 40px;
}
.page__form-down:hover {
	background-color: #239d86;
    border-color: #239d86;
    color: #fff !important;
}
.page__form-down .icon-arrow-next {
	transform: rotate(90deg);
}
.-disabled {
	border: 1px solid #CCCCCC;
	background-color: transparent;
	color: #CCCCCC !important;
	pointer-events: none;
}
.page__apply {
	margin-top: 56px;
}
.page__apply-warp {
	display: flex;
	gap: 40px;
	margin-bottom: 24px;
}
.page__apply-img {
	width: 320px;
	/* height: 240px; */
	position: relative;
}
.page__apply-img::before {
	content: "";
	display: block;
	background-image: url("images/icon_edit.svg");
	width: 24px;
	height: 24px;
	position: absolute;
	top: 0;
	right: 0;
}
.page__apply-cart dl {
	display: flex;
    flex-wrap: wrap;
	margin-bottom: 16px;
}
.page__apply-cart dt {
	width: 180px;
	font-weight: bold;
}
.page__apply-cart dd {
	margin-bottom: 0;
    flex: 1;
}
.page__apply-edit {
	display: flex;
	align-items: center;
	gap: 8px;
}
.page__apply-edit a {
	width: 18px;
	height: 18px;
}
.page__table-total {
	margin-top: 16px;
}
.page__table-total dl {
	display: flex;
    flex-wrap: wrap;
	margin-bottom: 8px;
}
.page__table-total dt {
	width: 140px;
	font-weight: bold;
}
.page__table-total dd {
	margin-bottom: 0;
    flex: 1;
}
.page__apply-head {
	background-color: #E4FAF5;
	padding: 24px 0;
	text-align: center;
}
.page__apply-head p {
	color: #2C2C2C;
	font-size: 15px;
}
.page__back-btn {
	margin-top: 80px;
}
.page__back-btn .outer {
	display: flex;
    justify-content: center;
    flex-direction: row-reverse;
    margin: 0 auto;
    max-width: 186px;
}
.page__back-btn .outer .btn-action {
	height: 40px;
	font-size: 14px;
	padding: 5px 14px;
}
@media screen and (min-width:768px) and ( max-width:1024px) {
	.page .frame {
		margin: 0 20px;
		flex-basis: auto;
	}
	.page__setting-form dl {
		display: block;
		margin-bottom: 24px;
	}
	.page__form-inline {
		display: block;
	}
	.page__form-url.page__form-inline {
		display: flex;
	}
	.page__form-mail {
		display: block;
	}
}
@media screen and (max-width: 767px) {
	.page {
		padding: 40px 0 80px;
	}
	.page .frame {
		padding: 40px 16px 65px 16px;
		flex-basis: 327px;
		border-radius: 10px;
	}
	.page__ttl h1 {
		text-align: left;
		margin-bottom: 24px;
	}
	.page__ttl h1 .sp {
		display: block;
	}
	.page__info-ttl {
		margin-bottom: 24px;
	}
	.page__heading {
		margin-bottom: 24px;
	}
	.page__hr {
		margin-top: 40px;
		margin-bottom: 40px;
	}
	.page__setting-form {
		margin-bottom: 40px;
	}
	.page__setting-form dl {
		display: block;
		margin-bottom: 24px;
	}
	.page__setting-form dt {
		margin-bottom: 16px;
		padding-top: 0;
	}
	.page__form-control {
		width: 295px;
		margin-bottom: 8px;
	}
	.page__form-inline {
		display: block;
	}
	.page__form-mail {
		display: block;
	}
	.page__form-file {
		width: 295px;
		height: 177px;
		padding: 48px 50px;
		font-size: 12px;
	}
	.page__form-file .-upload {
		gap: 0;
		width: 100%;
		text-align: center;
	}
	.icon-upload {
		margin-bottom: 12px;
	}
	.page__form-file.-icon {
		height: 177px;
		padding: 48px 50px;
	}
	.page__form-link {
		margin-bottom: 16px;
	}
	.page__form-btn {
		margin-bottom: 12px;
	}
	.page__form-btn.only-pc {
		display: none;
	}
	.page__form-btn.only-sp {
		display: flex;
		justify-content: flex-end;
		margin-top: 16px;
	}
	.page__upload-ttl h2 {
		font-size: 20px;
	}
	.page__upload-layout {
		display: block;
	}
	.page__upload-btn {
		margin-bottom: 24px;
	}
	.page__upload-btn:last-child {
		margin-bottom: 0;
	}
	.page__upload-btn a {
		font-size: 15px;
		padding: 16px 10px;
		height: auto;
	}
	.page__upload-btn a br {
		display: block;
	}
	.page__upload-img {
		width: 150px;
		height: 150px;
	}
	.page__upload-logo {
		height: 160px;
	}
	.btn-layout .outer.page__outer {
		max-width: 100%;
	} 
	.btn-layout .outer.page__outer a {
		padding: 12px 0;
		height: auto;
	}
	.page__outer .-sp {
		display: block;
	}
	.form-layout-cart.page__form-layout dl {
		display: block;
	}
	.page__form-layout.form-layout-cart dt {
		padding-bottom: 16px;
	}
	.page__form-layout.form-layout-cart dd {
		padding-bottom: 12px;
	}
	.page__form-dom.form-inline {
		display: block;
	}
	.page__form-dom.form-inline .-mb {
		margin-bottom: 16px;
	}
	.page__movie {
		margin-top: 16px;
		width: 100%;
	}
	.page__file-wrap {
		display: block;
	}
	.file-delete {
		margin-top: 16px;
	}
	.page__attention-ttl {
		font-size: 18px;
		margin-bottom: 8px;
	}
	.page__checkarea .-checkbox.-only-sp span::before {
		top: 15%;
	}
	.page__apply {
		margin-top: 24px;
	}
	.page__apply h2 {
		font-size: 16px;
	}
	.page__apply-warp {
		display: block;
	}
	.page__apply-img {
		display: block;
		width: 100%;
		height: 100%;
		margin-bottom: 16px;
	}
	.page__apply-cart dl {
		display: block;
	}
	.page__apply-cart dt {
		width: 100%;
		margin-bottom: 8px;
	}
	.page__back-btn {
		margin-top: 32px;
	}
}

/*============================================================
	オンライン納品_申請楽曲選択ページ
*/
.music {
	display: flex;
    justify-content: center;
    align-items: center;
    padding: 80px 0;
}
.music .frame {
    width: 100%;
}
.music__ttl {
	margin-bottom: 58px;
}
@media screen and (max-width: 767px) {
	.music {
		padding: 0 0 80px 0;
	}
	.music__ttl {
		margin-bottom: 24px;
	}
	.music .frame {
		max-width: 100%;
		overflow-x: scroll;
	}

	.table-list-sp table td {
		padding: 8px 5px;
		min-width: 200px;
	}
}


.order-change {
    list-style: none;
    padding: 10px;
}
.order-change li {
    user-select: none;
    cursor: grab;
    max-width: 500px;
    transition: box-shadow .3s;
}
.order-change li.onGrab {
    cursor: grabbing;
    box-shadow: 0 0 10px 2px rgba(0, 0, 0, .15);
    position: absolute;
    z-index: 1;
}
.order-change li:not(:last-child) {
    margin-bottom: 10px;
}
.hidden {
    visibility: hidden;
}