@charset "UTF-8";

header {
	border-bottom: 1px solid #bdbdbd;
	background: #fff;
	box-sizing: border-box;
	height: 64px;

	h1 {
		width: 18%;
		height: 3.4em;

		&::after {
			content: none;
		}
	}

	nav ul {
		padding-right: 10px;

		li:nth-of-type(n) a {
			background: none;
			border-radius: 0;
			padding: 0;
			display: block;
			width: 40px;
			height: 40px;
			display: flex;
			justify-content: center;
			align-items: center;

			&::before {
				content: none;
			}
		}
	}

	nav ul li:nth-of-type(1) a img {
		width: 13px;
		height: 23px;
	}

	nav ul li:nth-of-type(2) a img {
		width: 22px;
		height: 20px;
	}

	.menu-dialog {
		display: none;
		position: fixed;
		top: 0;
		bottom: 0;
		left: 0;
		right: 0;
		margin: auto;
		background: #fff;
		padding: 10px 16px;
		z-index: 10;

		.closer {
			width: 26px;
			height: 26px;
			background: url(../images/icon/close.png) no-repeat center / 20px 20px;
			margin-left: auto;
			margin-bottom: 20px;
		}

		.logo {
			text-align: center;
			font-size: 0;
			margin-bottom: 22px;

			img {
				height: 30px;
				width: auto;
			}
		}

		.find {
			width: 298px;
			margin-inline: auto;
			margin-bottom: 25px;
			list-style-type: none;
			display: flex;
			flex-flow: row wrap;
			justify-content: center;
			align-items: flex-start;
			gap: 8px;

			li {
				width: 100%;

				a {
					display: block;
					background: #ebebeb;
					font-size: 13px;
					line-height: 18px;
					letter-spacing: 0.075em;
					color: #000;
					padding-block: 11px;
					padding-left: calc(50% - 75px);
					text-decoration: none;
					text-align: left;

					&::before {
						content: '';
						display: inline-block;
						background: url(../images/icon/top_tab_01.png) no-repeat center / 15px 15px;
						width: 15px;
						height: 15px;
						margin-right: 16px;
						vertical-align: -2px;
					}
				}

				&:nth-child(2) a::before {
					background-image: url(../images/icon/top_tab_11.png);
				}

				&:nth-child(3) a::before {
					background-image: url(../images/icon/top_tab_21.png);
				}

				&:nth-child(4) a::before {
					background-image: url(../images/icon/top_tab_31.png);
				}
			}
		}

		.use {
			list-style-type: none;
			display: flex;
			flex-flow: row nowrap;
			justify-content: space-between;
			align-items: stretch;

			li {
				width: 50%;

				a {
					box-sizing: border-box;
					font-size: 13px;
					line-height: 18px;
					letter-spacing: 0.075em;
					color: #000;
					text-align: center;
					padding: 11px;
					display: block;
					text-decoration: none;
				}

				&:first-child {
					border-right: 1px solid #000;
				}
			}
		}
	}

	ul.subnavi {
		display: none;
	}
}

main {
	padding-top: 66px;
}

#ticket-login {
	width: 100%;
	margin: 50px auto 0;
	padding: 0 3.5% 20%;

	div.login_box {
		width: 100%;
		margin: 0;
		padding: 0;
		border-radius: 1em;
		box-shadow: 2px 2px 5px 2px rgba(0, 0, 0, 0.2);

		&:nth-of-type(n+2) {
			margin-top: 10%;
		}

		h3 {
			width: 100%;
			height: 3em;
			margin: 0;
			padding: 0 5%;
			font-size: 4.0vw;
			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: 0.8em 0.8em 0 0;
			display: flex;
			align-items: center;
		}

		&>.form_cont {
			width: 100%;
			margin: 0;
			padding: 1em 5%;
			font-size: 3.6vw;
			line-height: 180%;
			text-align: left;

			h4 {
				margin: 0;
				padding: 0;
				font-size: 3.6vw;
				line-height: 180%;
				font-weight: var(--weight-nomal);
			}

			dl {
				margin: 0;
				padding: 0;

				dt {
					margin: 0.5em 0 0;
					padding: 0;
					font-size: 3.6vw;
					line-height: 180%;
					font-weight: var(--weight-bold2);
				}

				dd {
					margin: 3px 0 0;
					padding: 0;

					input[type=password],
					input[type=email],
					input[type=text] {
						width: 100%;
						padding: 0.5em;
						font-size: 3.6vw;
						line-height: 160%;
						font-family: "Noto Sans JP", sans-serif;
						border: 1px solid #888;
					}
				}
			}

			div.btn {
				margin: 1.5em 0 0;
				padding: 0;

				button,
				a {
					width: 90%;
					height: 3em;
					font-size: 3.8vw;
					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 100%);
					border-radius: 0.5em;
					display: flex;
					justify-content: center;
					align-items: center;
				}
			}
		}
	}
}

#add-mail {
	width: 100%;
	margin: 50px auto 0;
	padding: 0 3.5%;
	text-align: left;

	h3 {
		margin: 0;
		padding: 0;
		font-size: 4.0vw;
		line-height: 180%;
		font-weight: var(--weight-bold2);
	}

	p {
		margin: 0.5em 0 0;
		padding: 0;
		font-size: 3.6vw;
		line-height: 160%;
	}

	h3+p+p,
	h3+p+p+p {
		margin: 1.5em 0 0;
		color: #f00;
	}

	.back_page {
		margin: 1.5em 0 20%;
		font-size: 3.6vw;
		line-height: 160%;

		a {
			color: #f00;
		}
	}
}

#add-mail-form {
	margin: 50px 3.5% 20%;
	padding: 8% 3%;
	background: #EEEEEE;
	border-radius: 0.5em;

	form {
		width: 100%;
		margin: 0;
		padding: 0;
		font-size: 3.6vw;
		line-height: 160%;

		dl {
			width: 100%;
			margin: 0;
			padding: 0;

			dt {
				width: 100%;
				margin: 0;
				padding: 0;
				text-align: left;
			}

			dd {
				width: 100%;
				margin: 0.5em 0 0;
				padding: 0;

				input[type=email] {
					width: 100%;
					padding: 0.5em;
					font-size: 3.6vw;
					line-height: 160%;
					font-family: "Noto Sans JP", sans-serif;
					border: 1px solid #888;
				}
			}

			div.btn {
				width: 100%;
				margin: 2em 0 0;
				padding: 0;
				text-align: center;

				button {
					width: 90%;
					height: 3em;
					font-size: 3.8vw;
					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 100%);
					border-radius: 0.5em;
					display: flex;
					justify-content: center;
					align-items: center;
				}
			}
		}
	}
}

#regist-flow {
	margin: 50px 3.5% 0;
	padding: 0;
	padding: 0;
	list-style: none;
	display: flex;
	justify-content: space-between;

	li {
		width: 31%;
		height: 3em;
		margin: 0;
		padding: 0 1em 0 0;
		font-size: 2.8vw;
		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: 2em;
			height: 2em;
			background: #fff;
			transform: rotate(45deg);
			right: -0.98em;
		}

		&:before {
			top: -1.0em;
		}

		&:after {
			bottom: -1.0em;
		}

		&:last-of-type {
			padding: 0;
		}

		&:last-of-type:before,
		&:last-of-type:after {
			display: none;
		}

		&.active {
			background: #cc0000;
			color: #fff;
		}
	}
}

#regist-inform {
	width: 100%;
	margin: 5% auto 0;
	padding: 0 3.5%;
	text-align: left;

	h3 {
		margin: 0;
		padding: 0;
		font-size: 4.0vw;
		line-height: 180%;
		font-weight: var(--weight-bold2);
	}

	p {
		margin: 0.5em 0 0;
		padding: 0;
		font-size: 3.6vw;
		line-height: 160%;

		span {
			display: block;
			margin: 0;
			padding: 0 0 0 1em;
		}
	}

	h3+p+p {
		margin: 1.5em 0 0;
		color: #f00;
	}
}

#regist-form {
	width: 100%;
	margin: 0 auto;
	padding: 3% 3.5% 20%;

	.from_top {
		margin: 0;
		padding: 0;
		font-size: 3.6vw;
		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;

		dt {
			width: 100%;
			margin: 0;
			padding: 5% 0 0;
			font-size: 3.8vw;
			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: 3em !important;
			}
		}

		&.confirm dt {
			padding: 3% 0 0;
		}

		&.confirm2 {
			border-bottom: none;
		}

		dd {
			width: 100%;
			margin: 0;
			padding: 0 0 7%;
			font-size: 3.6vw;
			line-height: 150%;
			display: flex;
			flex-wrap: wrap;
			align-items: center;

			select,
			input[type=text],
			input[type=email],
			input[type=tel],
			input[type=password] {
				width: 100%;
				height: 2.8em;
				margin: 3px 0 0;
				padding: 5px 10px;
				font-size: 3.6vw;
				line-height: 180%;
				font-family: 'Noto Sans JP', sans-serif;
				border: 1px solid #CCCCCC;
				background: #fff;
				border-radius: 5px;
				-webkit-text-security: disc;
				text-security: disc;

				&.size_L {
					width: 100%;
				}

				&.size_M {
					width: 100%;
				}

				&.size_S {
					width: 60%;
				}
			}

			input:nth-of-type(2) {
				margin-top: 0.2em;
			}

			textarea {
				width: 100%;
				height: 15em;
				margin: 3px 0 0;
				padding: 5px 10px;
				font-size: 3.6vw;
				line-height: 180%;
				font-family: 'Noto Sans JP', sans-serif;
				border: 1px solid #CCCCCC;
				background: #fff;
				border-radius: 5px;
			}

			div {
				width: 100%;
				margin: 2% 0 0;
				padding: 0;
				font-size: 3.6vw;
				line-height: 180%;
			}

			span {
				display: inline-block;
				margin: 0 0.5em 0 0;
				padding: 0;
				font-size: 3.6vw;
				line-height: 160%;
			}
		}

		&.confirm2 dd {
			margin: 3px 0 0;
			padding: 5px 10px;
			font-size: 3.6vw;
			line-height: 180%;
			border: 1px solid #CCCCCC;
		}
	}

	div.btn {
		margin: 10% auto 0;
		padding: 0;

		div.btn1 {
			margin: 5px auto;
			padding: 0;

			a,
			button {
				width: 90%;
				height: 4em;
				font-size: 4vw;
				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 100%);
				border-radius: 0.5em;
				display: flex;
				justify-content: center;
				align-items: center;
			}
		}

		div.btn2 {
			margin: 5px auto;
			padding: 0;

			button {
				width: 90%;
				height: 4em;
				font-size: 4vw;
				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) 100%);
				border-radius: 0.5em;
				display: flex;
				justify-content: center;
				align-items: center;
			}
		}
	}
}

#regist-form dl.confirm dd {
	padding: 0 0 3%;
}

#send-btn {
	width: 100%;
	margin: 0 auto;
	padding: 3% 3.5% 20%;

	a {
		width: 90%;
		height: 3.5em;
		font-size: 3.8vw;
		line-height: 120%;
		margin: 2% 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 100%);
		border-radius: 0.5em;
		display: flex;
		justify-content: center;
		align-items: center;
	}
}


/* マイページ関連 */
#mypage-read,
#password-change {
	width: 100%;
	margin: 50px auto 0;
	padding: 0 3.5%;
	text-align: left;

	h3 {
		margin: 0;
		padding: 0;
		font-size: 4.0vw;
		line-height: 180%;
		font-weight: var(--weight-bold2);
	}

	h4 {
		margin: 1em 0 0;
		padding: 0;
		font-size: 3.6vw;
		line-height: 180%;
		font-weight: var(--weight-bold2);
	}

	p {
		margin: 0.5em 0 0;
		padding: 0;
		font-size: 3.6vw;
		line-height: 160%;

		span {
			display: block;
			margin: 0;
			padding: 0;
			text-indent: 0;
		}

		strong {
			margin: 0 1em;
			padding: 0;
			font-weight: var(--weight-nomal);
		}

		b {
			font-weight: var(--weight-bold2);
		}

		a {
			display: block;
			margin: 0;
		}

		&.red {
			margin: 10px 0 0;
			padding: 0 0 0 1em;
			text-indent: -1em;
			color: #f00;
		}

		&.red2 {
			margin-top: 0;
		}
	}

	.withdrawal {
		margin: 1em 0 0;
		padding: 1em;
		background: #ffebf2;
		text-align: left;

		h5 {
			margin: 0;
			padding: 0;
			font-size: 3.6vw;
			line-height: 180%;
			font-weight: var(--weight-bold2);
		}

		p {
			margin: 0.5em 0 0;
			padding: 0;
			font-size: 3.6vw;
			line-height: 180%;
		}
	}
}

#password-change {
	padding: 0 !important;
}

#mypage-welcome {
	margin: 30px auto 0;
	padding: 0 3.5% 20%;

	.friendship {
		margin: 0 0 20px;
		padding: 5%;
		font-size: 3.6vw;
		line-height: 180%;
		text-align: left;
		background: #eee;

		dt {
			width: 100%;
			margin: 0;
			padding: 0;
			word-break: break-all;
		}

		dd {
			width: 100%;
			margin: 0.5em 0 0;
			padding: 3% 5%;
			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;

		li {
			width: 100%;
			margin: 5% auto 0;
			padding: 0;

			a {
				width: 100%;
				margin: 0 auto;
				padding: 5%;
				text-decoration: none;
				display: flex;
				align-items: center;
				border-radius: 1.0em;
				box-shadow: 2px 2px 5px 2px rgba(0, 0, 0, 0.2);

				img {
					width: 25%;
					height: auto;
					margin: 0;
					padding: 0;
				}

				span {
					width: 75%;
					margin: 0;
					padding: 0 0 0 10%;
					font-size: 3.8vw;
					line-height: 180%;
					text-align: left;
				}
			}
		}
	}

	.txt_link {
		margin: 30px auto 0;
		padding: 0;
		display: flex;
		flex-direction: column;
		align-items: flex-end;

		a {
			display: block;
			margin: 0.5em 0 0;
			padding: 0;
		}
	}
}

#ticket-block-mypage {
	margin: 0 auto;
	padding: 15px 3.5% 20%;

	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;

						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;

						p {
							margin: 0 2em 0 0;
							padding: 0;
							font-size: 14px;
							font-weight: var(--weight-nomal);
						}
					}
				}

				div.summary-body {
					width: 100%;
					height: 40px;
					margin: 0;
					padding: 16px 5px 20px;
					display: flex;
					justify-content: center;
					align-items: center;
					position: relative;

					&.none {
						display: none;
					}

					p.number {
						display: none;
					}

					div {
						width: 200px;

						a {
							position: absolute;
							bottom: 0;
							left: 36px;
							right: 36px;
							border-radius: 5px;
							background: #fff;
							text-align: center;
							font-size: 13px;
							line-height: 23px;
							height: 30px;
							text-decoration: none;
							box-sizing: border-box;

							&::before {
								content: '';
								display: inline-block;
								vertical-align: 0;
								background: url(../images/icon/arrow_down.png) no-repeat center / contain;
								width: 16px;
								height: 9px;
								margin-right: 12px;
							}
						}
					}
				}
			}
		}
	}

	div.btn {
		margin: 10% auto 0;
		padding: 0;

		div.btn1 {
			margin: 5px auto;
			padding: 0;

			a,
			button {
				width: 90%;
				height: 4em;
				font-size: 4vw;
				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 100%);
				border-radius: 0.5em;
				display: flex;
				justify-content: center;
				align-items: center;
			}
		}

		div.btn2 {
			margin: 5px 0 0;
			padding: 0;

			a,
			button {
				width: 90%;
				height: 4em;
				font-size: 4vw;
				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) 100%);
				border-radius: 0.5em;
				display: flex;
				justify-content: center;
				align-items: center;
			}
		}
	}

	div.ditail {
		margin: 0;
		padding: 10px 0 0;

		div.ditail_box {
			margin: 10px 0 0;
			padding: 10px;
			display: flex;
			flex-direction: column;

			&.dep {
				background: #fef8f8;
			}

			&.total {
				background: #eee;
			}

			div {
				width: 100%;
				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: 3.6vw;
					font-weight: var(--weight-nomal);
				}
			}
		}
	}

	#mypage-welcome {
		padding-bottom: 0;
	}
}

#friendship {
	margin: 0 auto;
	padding: 30px 3.5% 20%;

	div.box {
		margin: 15px auto 0;
		padding: 5%;
		background: #eee;

		h6 {
			margin: 0 auto 1em;
			padding: 0;
			font-size: 3.6vw;
			line-height: 180%;
			font-weight: var(--weight-bold2);
		}

		ul {
			width: 100%;
			margin: 0 auto;
			padding: 0;
			font-size: 3.6vw;
			line-height: 180%;
			font-weight: var(--weight-nomal);
			list-style: none;

			li {
				width: 100%;
				margin: 15px auto 0;
				padding: 5%;
				text-align: left;
				background: #fff;
				box-shadow: 2px 2px 5px 2px rgba(0, 0, 0, 0.2);

				a {
					word-break: break-all;
				}

				&:first-of-type {
					margin-top: 0;
				}

				strong {
					font-weight: var(--weight-bold2);
				}
			}
		}

		p.btm {
			margin: 10px 0 0;
			padding: 0 0 0 1em;
			text-indent: -1em;
			font-size: 3.6vw;
			line-height: 180%;
			text-align: left;
		}
	}

	div.txt_cont {
		margin: 20px auto 0;
		text-align: left;

		h5 {
			margin: 0;
			padding: 2em 0 0;
			font-size: 3.8vw;
			line-height: 180%;
			font-weight: var(--weight-bold2);
		}

		strong {
			display: block;
			margin: 1.5em 0 0;
			padding: 0;
			font-size: 3.6vw;
			line-height: 180%;
			font-weight: var(--weight-bold2);
		}

		span {
			display: block;
			margin: 1em 0 0;
			padding: 0;
			font-size: 3.6vw;
			line-height: 180%;
		}

		p {
			margin: 0.5em 0 0;
			padding: 0;
			font-size: 3.6vw;
			line-height: 180%;
		}

		ul {
			margin: 0.5em 0 0;
			padding: 0;
			font-size: 3.6vw;
			line-height: 180%;
			list-style: none;

			li {
				margin: 0;
				padding: 0 0 0 1em;
				text-indent: -1em;
			}
		}

		p+ul {
			margin-top: 0;
		}

		.btm {
			margin: 2em 0 0;
			padding: 0;
			font-size: 3.6vw;
			line-height: 180%;
			text-align: right;
		}
	}
}