@charset "UTF-8";

main {
	width: 1084px;
	padding-top: 180px;
	padding-bottom: 70px;
}

.menu-dialog {
	display: none;
}

#ticket-login {
	width: 850px;
	margin: 50px auto 0;
	padding: 0;
	display: flex;
	justify-content: space-between;
	align-items: flex-start;

	div.login_box {
		width: 400px;
		margin: 0;
		padding: 0;
		border-radius: 10px;
		box-shadow: 2px 2px 5px 2px rgba(0, 0, 0, 0.2);

		h3 {
			width: 100%;
			height: 50px;
			margin: 0;
			padding: 0 25px;
			font-size: 16px;
			line-height: 180%;
			font-weight: var(--weight-bold2);
			text-align: left;
			background: linear-gradient(to right, rgba(204, 0, 1, 0.2) 0%, rgba(228, 20, 140, 0.2) 100%);
			border-radius: 10px 10px 0 0;
			display: flex;
			align-items: center;
		}

		&>.form_cont {
			width: 100%;
			margin: 0;
			padding: 25px;
			font-size: 14px;
			line-height: 180%;
			text-align: left;

			h4 {
				margin: 0;
				padding: 0;
				font-size: 12px;
				line-height: 180%;
				font-weight: var(--weight-nomal);
			}

			dl {
				margin: 0;
				padding: 0;

				dt {
					margin: 10px 0 0;
					padding: 0;
					font-size: 14px;
					line-height: 180%;
					font-weight: var(--weight-bold2);
				}

				dd {
					margin: 3px 0 0;
					padding: 0;

					input[type=text],
					input[type=email],
					input[type=date],
					input[type=password] {
						width: 100%;
						padding: 5px 10px;
						font-size: 14px;
						line-height: 160%;
						font-family: "Noto Sans JP", sans-serif;
						border: 1px solid #888;
					}
				}
			}

			div.btn {
				margin: 20px 0 0;
				padding: 0;

				button,
				a {
					width: 280px;
					height: 40px;
					font-size: 15px;
					line-height: 120%;
					margin: 0 auto;
					padding: 0;
					font-family: "Noto Sans JP", sans-serif;
					color: #fff;
					font-weight: var(--main-font-bold2);
					text-decoration: none;
					cursor: pointer;
					border: 1px solid #fff;
					background: linear-gradient(to right, #CC0001 0%, #E4148B 50%, #CC0001 100%);
					background-size: 200% auto;
					background-position: left center;
					border-radius: 5px;
					display: flex;
					justify-content: center;
					align-items: center;
					transition: 0.2s linear;

					&:hover {
						background-position: right center;
					}
				}
			}
		}
	}
}

#add-mail {
	width: 850px;
	margin: 50px auto 0;
	padding: 0;
	text-align: left;

	h3 {
		margin: 0;
		padding: 0;
		font-size: 16px;
		line-height: 180%;
		font-weight: var(--weight-bold2);
	}

	p {
		margin: 10px 0 0;
		padding: 0;
		font-size: 14px;
		line-height: 160%;
	}

	h3+p+p,
	h3+p+p+p {
		margin: 20px 0 0;
		color: #f00;
	}

	.back_page {
		margin: 30px 0 0;
		font-size: 14px;
		line-height: 160%;

		a {
			color: #f00;
		}
	}
}

#add-mail-form {
	width: 800px;
	margin: 50px auto 0;
	padding: 50px;
	background: #EEEEEE;
	border-radius: 10px;

	form {
		width: 100%;
		margin: 0;
		padding: 0;
		font-size: 16px;
		line-height: 160%;

		dl {
			width: 100%;
			margin: 0;
			padding: 0;
			display: flex;
			flex-wrap: wrap;
			align-items: center;

			dt {
				width: 8em;
				margin: 0;
				padding: 0;
			}

			dd {
				width: calc(100% - 8em);
				margin: 0;
				padding: 0;

				input[type=email] {
					width: 100%;
					padding: 5px 10px;
					font-size: 14px;
					line-height: 160%;
					font-family: "Noto Sans JP", sans-serif;
					border: 1px solid #888;
				}
			}

			div.btn {
				width: 100%;
				margin: 30px 0 0;
				padding: 0;
				text-align: center;

				button {
					width: 280px;
					height: 40px;
					font-size: 15px;
					line-height: 120%;
					margin: 0 auto;
					padding: 0;
					font-family: "Noto Sans JP", sans-serif;
					color: #fff;
					font-weight: var(--main-font-bold2);
					text-decoration: none;
					cursor: pointer;
					border: 1px solid #fff;
					background: linear-gradient(to right, #CC0001 0%, #E4148B 50%, #CC0001 100%);
					background-size: 200% auto;
					background-position: left center;
					border-radius: 5px;
					display: flex;
					justify-content: center;
					align-items: center;
					transition: 0.2s linear;

					&:hover {
						background-position: right center;
					}
				}
			}
		}
	}
}

#regist-flow {
	width: 850px;
	margin: 50px auto 0;
	padding: 0;
	list-style: none;
	display: flex;
	justify-content: space-between;

	li {
		width: 30%;
		height: 46px;
		margin: 0;
		padding: 0 1em 0 0;
		font-size: 16px;
		line-height: 180%;
		font-weight: var(--weight-bold2);
		background: #EEEEEE;
		display: flex;
		justify-content: center;
		align-items: center;
		position: relative;

		&:before,
		&:after {
			position: absolute;
			content: '';
			display: block;
			width: 50px;
			height: 50px;
			background: #fff;
			transform: rotate(45deg);
			right: -24px;
		}

		&:before {
			top: -38px;
		}

		&:after {
			bottom: -38px;
		}

		&:last-of-type {
			padding: 0;
		}

		&:last-of-type:before,
		&:last-of-type:after {
			display: none;
		}

		&.active {
			background: #cc0000;
			color: #fff;
		}
	}
}

#regist-inform {
	width: 850px;
	margin: 30px auto 0;
	padding: 0;
	text-align: left;

	h3 {
		margin: 0;
		padding: 0;
		font-size: 16px;
		line-height: 180%;
		font-weight: var(--weight-bold2);
	}

	p {
		margin: 10px 0 0;
		padding: 0;
		font-size: 14px;
		line-height: 160%;

		span {
			display: block;
			margin: 0;
			padding: 0 0 0 1em;
		}
	}

	h3+p+p {
		margin: 20px 0 0;
		color: #f00;
	}
}

#regist-form {
	width: 800px;
	margin: 0 auto;
	padding: 20px 0 0;

	.from_top {
		margin: 0;
		padding: 0;
		font-size: 16px;
		line-height: 160%;
		text-align: left;

		span {
			color: #f00;
		}
	}

	dl {
		width: 100%;
		margin: 0 auto;
		padding: 0;
		text-align: left;
		border-bottom: 1px solid #ccc;
		display: flex;
		flex-wrap: wrap;

		&.confirm {
			align-items: flex-start;
		}

		&.confirm2 {
			align-items: center;
			border-bottom: none;
		}

		dt {
			width: 200px;
			margin: 5px 0 0;
			padding: 20px 0;
			font-size: 16px;
			line-height: 150%;
			border-top: 1px solid #ccc;

			&:first-of-type {
				border-top: none;
			}

			span {
				margin-left: 0.5em;
				color: #f00;
			}

			&.pd_top {
				padding-top: 50px !important;
			}
		}

		&.confirm dt {
			padding: 15px 0;
		}

		&.confirm2 dt {
			padding: 0;
			border-top: none;
		}

		dd {
			width: 600px;
			margin: 5px 0 0;
			padding: 10px 0;
			font-size: 14px;
			line-height: 150%;
			border-top: 1px solid #ccc;
			display: flex;
			flex-wrap: wrap;
			align-items: center;

			&.pd_top {
				padding-top: 50px !important;
			}

			select,
			input[type=text],
			input[type=date],
			input[type=email],
			input[type=tel],
			input[type=password] {
				height: 40px;
				margin: 5px 0 0;
				padding: 5px 10px;
				font-size: 14px;
				line-height: 180%;
				font-family: 'Noto Sans JP', sans-serif;
				border: 1px solid #CCCCCC;
				background: #fff;
				border-radius: 5px;

				&.size_L {
					width: 100%;
				}

				&.size_M {
					width: 48%;
				}

				&.size_S {
					width: 35%;
				}
			}

			textarea {
				width: 100%;
				height: 160px;
				margin: 5px 0 0;
				padding: 5px 10px;
				font-size: 14px;
				line-height: 180%;
				font-family: 'Noto Sans JP', sans-serif;
				border: 1px solid #CCCCCC;
				background: #fff;
				border-radius: 5px;
			}

			input:nth-of-type(2) {
				margin-left: 4%;
			}

			&:first-of-type {
				border-top: none;
			}

			div {
				width: 100%;
				margin: 10px 0 0;
				padding: 0;
				font-size: 14px;
				line-height: 180%;
			}

			span {
				display: inline-block;
				margin: 0 10px 0 0;
				padding: 0;
				font-size: 16px;
				line-height: 160%;
			}
		}

		&.confirm dd {
			padding: 15px 0;
		}

		&.confirm2 dd {
			padding: 5px 10px;
			font-size: 14px;
			line-height: 180%;
			border: 1px solid #CCCCCC;
		}
	}

	div.btn {
		margin: 50px auto 0;
		padding: 0;

		div.btn1 {
			margin: 5px auto;
			padding: 0;

			a,
			button {
				width: 320px;
				height: 60px;
				font-size: 18px;
				line-height: 120%;
				margin: 0 auto;
				padding: 0;
				font-family: "Noto Sans JP", sans-serif;
				color: #fff;
				font-weight: var(--main-font-bold2);
				text-decoration: none;
				cursor: pointer;
				border: 1px solid #fff;
				background: linear-gradient(to right, #CC0001 0%, #E4148B 50%, #CC0001 100%);
				background-size: 200% auto;
				background-position: left center;
				border-radius: 5px;
				display: flex;
				justify-content: center;
				align-items: center;
				transition: 0.2s linear;

				&:hover {
					background-position: right center;
				}
			}
		}

		div.btn2 {
			margin: 5px auto;
			padding: 0;

			button {
				width: 320px;
				height: 60px;
				font-size: 18px;
				line-height: 120%;
				margin: 0 auto;
				padding: 0;
				font-family: "Noto Sans JP", sans-serif;
				color: #333;
				font-weight: var(--main-font-bold2);
				text-decoration: none;
				cursor: pointer;
				border: 1px solid #fff;
				background: linear-gradient(to right, rgba(0, 131, 137, 0.2) 0%, rgba(18, 179, 0, 0.2) 50%, rgba(0, 131, 137, 0.2) 100%);
				background-size: 200% auto;
				background-position: left center;
				border-radius: 5px;
				display: flex;
				justify-content: center;
				align-items: center;
				transition: 0.2s linear;

				&:hover {
					background-position: right center;
				}
			}
		}
	}
}

#regist-form dl.confirm dt,
#regist-form dl.confirm dd {
	padding: 10px 0;
	font-size: 16px;
	line-height: 150%;
}

#send-btn {
	width: 850px;
	margin: 0 auto;
	padding: 30px 0 0;

	a {
		width: 280px;
		height: 50px;
		font-size: 15px;
		line-height: 120%;
		margin: 10px auto 0;
		padding: 0;
		font-family: "Noto Sans JP", sans-serif;
		color: #fff;
		font-weight: var(--main-font-bold2);
		text-decoration: none;
		cursor: pointer;
		border: 1px solid #fff;
		background: linear-gradient(to right, #CC0001 0%, #E4148B 50%, #CC0001 100%);
		background-size: 200% auto;
		background-position: left center;
		border-radius: 5px;
		display: flex;
		justify-content: center;
		align-items: center;
		transition: 0.2s linear;

		&:hover {
			background-position: right center;
		}
	}
}


/* マイページ関連 */
#mypage-read,
#password-change {
	width: 850px;
	margin: 50px auto 0;
	padding: 0;
	text-align: left;

	h3 {
		margin: 0;
		padding: 0;
		font-size: 20px;
		line-height: 180%;
		font-weight: var(--weight-bold2);
	}

	h4 {
		margin: 20px 0 0;
		padding: 0;
		font-size: 16px;
		line-height: 180%;
		font-weight: var(--weight-bold2);
	}

	p {
		margin: 10px 0 0;
		padding: 0;
		font-size: 14px;
		line-height: 160%;

		span {
			display: block;
			margin: 0;
			padding: 0 0 0 1em;
		}

		strong {
			margin: 0 1em;
			padding: 0;
			font-weight: var(--weight-nomal);
		}

		b {
			font-weight: var(--weight-bold2);
		}

		a {
			display: inline-block;
			margin: 0 2em 0 0;
		}

		&.red {
			margin: 10px 0 0;
			color: #f00;
		}

		&.red2 {
			margin-top: 0;
		}
	}

	.withdrawal {
		margin: 20px 0 0;
		padding: 20px;
		background: #ffebf2;
		text-align: left;

		h5 {
			margin: 0;
			padding: 0;
			font-size: 14px;
			line-height: 180%;
			font-weight: var(--weight-bold2);
		}

		p {
			margin: 5px 0 0;
			padding: 0;
			font-size: 14px;
			line-height: 180%;
		}
	}
}

#mypage-welcome {
	width: 800px;
	margin: 30px auto 0;
	padding: 0;

	.friendship {
		margin: 0 0 20px;
		padding: 20px;
		font-size: 14px;
		line-height: 180%;
		text-align: left;
		background: #eee;
		display: flex;
		align-items: center;

		dt {
			margin: 0 30px 0 0;
			padding: 0;
			white-space: nowrap;
		}

		dd {
			width: calc(100% - 250px);
			margin: 0;
			padding: 5px 20px;
			background: #fff;
			box-shadow: 2px 2px 5px 2px rgba(0, 0, 0, 0.2);

			a {
				display: inline-block;
				word-break: break-all;
			}
		}
	}

	ul {
		width: 100%;
		margin: 0 auto;
		padding: 0;
		list-style: none;
		display: flex;
		justify-content: space-between;

		li {
			width: 30%;
			margin: 0 auto;
			padding: 0;

			a {
				width: 100%;
				height: 250px;
				margin: 0 auto;
				padding: 0;
				text-decoration: none;
				display: flex;
				flex-direction: column;
				justify-content: center;
				align-items: center;
				border-radius: 10px;
				box-shadow: 2px 2px 5px 2px rgba(0, 0, 0, 0.2);

				&:hover {
					background: #ffebf2;
				}

				img {
					width: 110px;
					height: auto;
					margin: 0;
					padding: 0;
				}

				span {
					height: 3.2em;
					margin: 10px 0 0;
					padding: 0;
					font-size: 16px;
					line-height: 180%;
					display: flex;
					align-items: center;
				}
			}
		}
	}

	.txt_link {
		margin: 30px auto 0;
		padding: 0;
		display: flex;
		justify-content: flex-end;

		a {
			display: inline-block;
			margin: 0 10px 0 10px;
			padding: 0;
		}
	}
}

#ticket-block-mypage {
	width: 800px;
	margin: 0 auto;
	padding: 15px 0 0;

	ul.list {
		width: 100%;
		margin: 0;
		padding: 0;
		list-style: none;
		text-align: left;

		li {
			width: 100%;
			margin: 15px 0 0;
			padding: 0;

			div.summary {
				width: 100%;
				margin: 0;
				padding: 0;
				border: 2px solid #d41e1d;

				div.summary-head {
					width: 100%;
					margin: 0;
					padding: 16px 10px 20px 15px;
					background: #fef8f8;
					display: flex;
					justify-content: space-between;
					align-items: center;

					div:first-of-type {
						width: 52%;
						margin: 0;
						padding: 0;
						display: flex;
						align-items: center;

						figure {
							margin: 0 12px 0 0;
							font-size: 0;

							img {
								max-width: 100%;
								height: auto;
							}
						}

						h3 {
							font-size: 16px;
							font-weight: var(--weight-bold2);
							letter-spacing: 0.075em;
						}
					}

					div:last-of-type {
						width: 48%;
						margin: 0;
						padding: 0;
						display: flex;
						align-items: center;

						p {
							margin: 0 2em 0 0;
							padding: 0;
							font-size: 14px;
							font-weight: var(--weight-nomal);
						}

						p.number {
							display: none;
						}
					}
				}

				div.summary-body {
					width: 100%;
					margin: 0;
					padding: 16px 10px 20px 15px;
					display: flex;
					justify-content: space-between;
					align-items: center;

					p {
						margin: 0;
						padding: 0;
						font-size: 14px;
						font-weight: var(--weight-nomal);
					}

					div {
						width: 200px;

						a {
							display: block;
							text-align: center;
							padding: 5px;
							box-sizing: border-box;
							color: #fff;
							font-size: 16px;
							letter-spacing: 0.075em;
							font-weight: 600;
							text-decoration: none;
							background: url(../images/ticket/arrow_white.png) no-repeat right 12px center, linear-gradient(90deg, rgb(205, 1, 5) 0%, rgb(228, 20, 139) 100%);
							border-radius: 18px;
							cursor: pointer;
						}
					}
				}
			}
		}
	}

	div.btn {
		margin: 30px auto 0;
		padding: 0;

		div.btn1 {
			margin: 5px auto;
			padding: 0;

			a,
			button {
				width: 320px;
				height: 60px;
				font-size: 18px;
				line-height: 120%;
				margin: 0 auto;
				padding: 0;
				font-family: "Noto Sans JP", sans-serif;
				color: #fff;
				font-weight: var(--main-font-bold2);
				text-decoration: none;
				cursor: pointer;
				border: 1px solid #fff;
				background: linear-gradient(to right, #CC0001 0%, #E4148B 50%, #CC0001 100%);
				background-size: 200% auto;
				background-position: left center;
				border-radius: 5px;
				display: flex;
				justify-content: center;
				align-items: center;
				transition: 0.2s linear;

				&:hover {
					background-position: right center;
				}
			}
		}

		div.btn2 {
			margin: 5px 0 0;
			padding: 0;

			a,
			button {
				width: 320px;
				height: 60px;
				font-size: 18px;
				line-height: 120%;
				margin: 0 auto;
				padding: 0;
				font-family: "Noto Sans JP", sans-serif;
				color: #333;
				font-weight: var(--main-font-bold2);
				text-decoration: none;
				cursor: pointer;
				border: 1px solid #fff;
				background: linear-gradient(to right, rgba(0, 131, 137, 0.2) 0%, rgba(18, 179, 0, 0.2) 50%, rgba(0, 131, 137, 0.2) 100%);
				background-size: 200% auto;
				background-position: left center;
				border-radius: 5px;
				display: flex;
				justify-content: center;
				align-items: center;
				transition: 0.2s linear;

				&:hover {
					background-position: right center;
				}
			}
		}
	}

	div.ditail {
		margin: 0;
		padding: 10px 0 0;

		div.ditail_box {
			margin: 10px 0 0;
			padding: 10px;
			display: flex;
			align-items: center;

			&.dep {
				background: #fef8f8;
			}

			&.total {
				background: #eee;
			}

			div {
				width: 50%;
				margin: 0;
				padding: 0;
				display: flex;
				align-items: center;

				figure {
					width: 20px;
					margin: 0 5px 0 0;
					padding: 0;

					img {
						width: 100%;
						height: auto;
					}
				}

				p {
					display: inline-block;
					margin: 0;
					padding: 8px 0 0;
					font-size: 14px;
					font-weight: var(--weight-nomal);
				}
			}
		}
	}
}

#friendship {
	width: 800px;
	margin: 30px auto 0;
	padding: 0;

	div.box {
		margin: 15px auto 0;
		padding: 20px;
		background: #eee;

		h6 {
			margin: 0 auto 10px;
			padding: 0;
			font-size: 14px;
			line-height: 180%;
			font-weight: var(--weight-bold2);
		}

		ul {
			width: 100%;
			margin: 0 auto;
			padding: 0;
			font-size: 14px;
			line-height: 180%;
			font-weight: var(--weight-nomal);
			list-style: none;

			li {
				width: 100%;
				margin: 15px auto 0;
				padding: 20px;
				background: #fff;
				box-shadow: 2px 2px 5px 2px rgba(0, 0, 0, 0.2);

				p {
					display: inline-block;
					margin-right: 5px;
				}

				&:first-of-type {
					margin-top: 0;
				}

				strong {
					font-weight: var(--weight-bold2);
				}
			}
		}

		p.btm {
			margin: 10px 0 0;
			padding: 0;
			font-size: 14px;
			line-height: 180%;
			text-align: right;
		}
	}

	div.txt_cont {
		margin: 30px auto 0;
		text-align: left;

		h5 {
			margin: 0;
			padding: 50px 0 0;
			font-size: 16px;
			line-height: 180%;
			font-weight: var(--weight-bold2);
		}

		strong {
			display: block;
			margin: 15px 0 0;
			padding: 0;
			font-size: 14px;
			line-height: 180%;
			font-weight: var(--weight-bold2);
		}

		span {
			display: block;
			margin: 15px 0 0;
			padding: 0;
			font-size: 14px;
			line-height: 180%;
		}

		p {
			margin: 5px 0 0;
			padding: 0;
			font-size: 14px;
			line-height: 180%;
		}

		ul {
			margin: 5px 0 0;
			padding: 0;
			font-size: 14px;
			line-height: 180%;
			list-style: none;

			li {
				margin: 0;
				padding: 0 0 0 1em;
				text-indent: -1em;
			}
		}

		p+ul {
			margin-top: 0;
		}

		.btm {
			margin: 20px 0 0;
			padding: 0;
			font-size: 14px;
			line-height: 180%;
			text-align: right;
		}
	}
}