@charset "utf-8";
:root{
	--default-color-black: #2c2a29;
    --content-width-pc: 1104px;
	--content-color-blue: #07b0e9;
	--content-color-green: #5ecd2d;
	--content-color-navy: #063a98;
	--content-color-line: #06c755;
	--content-border_yellow: linear-gradient(transparent 70%, #ffe300 0%);
}
.nopc {
  display: none
}
.main {
	-webkit-text-size-adjust: none;
}
.contents {
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 500;
	font-size: 16px;
	line-height: 1.5;
	color: var(--default-color-black);
	a {
		text-decoration: none;
		&:hover {
			opacity: 0.8;
			transition: all 0.6s ease;
		}
	}
	img {
        max-width: 100%;
    }
	.inner {
        width: var(--content-width-pc);
		max-width: 100%;
        margin: 0 auto;
	}
}

/*------------------------------------------------
	メインビジュアル
--------------------------------------------------*/
#mainvisual {
	width: 100%;
	height: 600px;
	text-align: center;
    background: url("../images/main-bg-pc.jpg") no-repeat top center;
	.inner {
		height: 100%;
		position: relative;
	}
	.kikan {
		position: absolute;
		bottom: 24px;
		right: 0;
		left: 0;
		margin: 0 auto;
	}
	.bnr-20bai {
		position: absolute;
		right: 0px;
		bottom: -155px;
		width: 220px;
		z-index: 100;
		a {
			display: block;
			&:hover {
				transform: translate(0,5px);
			}
		}
	}
}
/*------------------------------------------------
	景品
--------------------------------------------------*/
#prize {
    width: 100%;
    padding: 112px 0 96px;
    background: linear-gradient(to right,  var(--content-color-green) 50%, var(--content-color-blue) 50%);
	position: relative;
	&::before {
		content: "";
		width: 100%;
		height: 16px;
		background: url("../images/bg-stripe.png");border-right-width;
		position: absolute;
		top: 0;
		left: 0;
	}
	.prize-box {
		width: 100%;
		background-color: #fff;
		padding: 120px 64px 64px;
		border-radius: 30px;
		position: relative;
		h2 {
			text-align: center;
			position: absolute;
			top: -65px;
			right: 0;
			left: 0;
		}
	}
	.prize-list {
		width: 100%;
		display: flex;
		justify-content: space-between;
		position: relative;
		li {
			width: 46%;
			.title {
				text-align: center;
				margin-bottom: 32px;
			}
			.movie {
				width: 100%;
				height: 290px;
				display: flex;
				justify-content: center;
				align-items: center;
				iframe {
					width: 420px;
					height: 236px;
					border: none;
				}
			 }
			.text {
				width: 100%;
				min-height: 230px;
				padding: 24px 0 0 0;
				font-weight: 900;
				.f-small {
					display: block;
					font-size: 28px;
					line-height: 1.3;
				}
				.f-large {
					display: block;
					font-size: 40px;
					line-height: 1.3;
					margin-bottom: 15px;
					mark {
						background: var(--content-border_yellow);
						color: var(--default-color-black);
					}
				}
				.person {
					display: inline-block;
					font-size: 18px;
					font-weight: 700;
					letter-spacing: 0.05em;
					padding: 0 10px 2px;
					color: #fff;
					.gw & {
						background-color: #3B871B;
					}
					.sm & {
						background-color: #037FA9;
					}
				}
				.dpt {
					font-size: 16px;
					font-weight: 700;
				}
				.note {
					display: block;
					font-size: 14px;
					font-weight: 500;
					padding-top: 20px;
				}
				&.gw {
					background: url("../images/item01-bg.png") no-repeat right top / contain;
				}
				&.sm {
					background: url("../images/item02-bg.png") no-repeat right top / contain;
				}
			}
		}
		&::before {
			content: "";
			position: absolute;
			left: 50%;
			transform: translateX(-50%);
			top: 0;
			bottom: 0;
			width: 0;
			border-left: 2px dashed #ccc;
		}
	}
}

/*------------------------------------------------
	応募方法1
--------------------------------------------------*/
#oubo1 {
    width: 100%;
    padding: 96px 0;
	.oubo-box {
		background-color: #fff;
		padding: 40px;
		border-radius: 30px;
		border: solid 7px var(--content-color-navy);
	}
	h2 {
		color: var(--content-color-navy);
		text-align: center;
		margin-bottom: 30px;
		span {
			font-size: 36px;
			font-weight: 900;
			&::before,&::after {
				content: "";
				display: inline-block;
				width: 45px;
				height: 55px;
				background: url("../images/title-before-blue.png") no-repeat;
				background-size: contain;
				margin: 0 20px;
				background-position: bottom;	
			}
			&::after {
				transform: scaleX(-1);
			}
		}
	}
	.flex-box {
		width: 920px;
		margin: 0 auto;
		display: flex;
		li {
			width: 280px;
			background-color: #f4f4f4;
			border-radius: 20px;
			padding-bottom: 30px;
			margin-right: 40px;
			position: relative;
			&::after {
				content: "▶";
				font-size: 24px;
				position: absolute;
				top: 160px;
				right: -30px;
				color: var(--content-color-navy);
			}
			&:last-child {
				margin-right: 0;
				&::after {
					content: none;
				}
			}
		}
		h3 {
			background-color: var(--content-color-navy);
			color: #fff;
			font-size: 18px;
			letter-spacing: 0.1em;
			line-height: 1.8;
			border-top-left-radius: 20px;
			border-top-right-radius: 20px;
			text-align: center;
			margin-bottom: 30px;
		}
		.icon {
			width: 100px;
			height: 100px;
			margin: 0 auto 30px;
		}
		.text {
			font-size: 16px;
			padding: 0 20px;
		}
		.btn {
			width: 230px;
			margin: 20px auto 0;
			a {
				display: block;
				background-image: linear-gradient(90deg, rgb(255, 122, 0), rgb(222, 0, 175));
				color: #fff;
				font-size: 14px;
				font-weight: 600;
				text-align: center;
				padding: 10px 0;
				border-radius: 30px;
				position: relative;
				&::after {
					font-family: "Material Symbols Rounded";
					font-weight: 400;
					content: "\e5cc";
					position: absolute;
					right: 10px;
					top: 5px;
					font-size: 20px;
				}
			}
		}
	}
}

/*------------------------------------------------
	応募方法2
--------------------------------------------------*/
#oubo2 {
    width: 100%;
    padding: 0 0 96px;
	.oubo-box {
		border-radius: 30px;
		background-color: #fffbdc;
		.title-box {
			background-color: #fde21f;
			border-top-left-radius: 30px;
			border-top-right-radius: 30px;
			padding: 16px 30px;
			text-align: center;
			position: relative;
			h2 {
				text-align: center;
				margin-bottom: 15px;
				span {
					font-size: 36px;
					line-height: 1.3;
					font-weight: 900;
					.strong {
						font-size: 70px;
						vertical-align: -4px;
						color: #ff2511;		
					}
				}
			}
			.note {
				font-size: 14px;
				font-weight: 500;
			}
			.line20bai {
				position: absolute;
				left: 30px;
				top: 20px;
				width: 170px;
			}
		}
	}
	
	.flex-box {
		width: 920px;
		margin: 0 auto;
		padding: 40px 0;
		display: flex;
		flex-wrap: wrap;
		li {
			width: 280px;
			background-color: #fff;
			border-radius: 20px;
			padding-bottom: 30px;
			margin-right: 40px;
			margin-bottom: 30px;
			position: relative;
			&::after {
				content: "▶";
				font-size: 24px;
				position: absolute;
				top: 160px;
				right: -30px;
				color: #06c755;
			}
			&:nth-child(3n),&:last-child {
				margin-right: 0;
				&::after {
					content: none;
				}
			}
		}
		h3 {
			background-color: var(--content-color-line);
			color: #fff;
			font-size: 18px;
			letter-spacing: 0.1em;
			line-height: 1.8;
			border-top-left-radius: 20px;
			border-top-right-radius: 20px;
			text-align: center;
			margin-bottom: 30px;
		}
		.icon {
			width: 100px;
			height: 100px;
			margin: 0 auto 30px;
		}
		.text {
			font-size: 16px;
			padding: 0 20px;
		}
		.btn {
			width: 230px;
			margin: 20px auto 0;
			a {
				display: block;
				background-color: var(--content-color-line);
				color: #fff;
				font-size: 14px;
				font-weight: 600;
				text-align: center;
				padding: 10px 0;
				border-radius: 30px;
				position: relative;
				&::after {
					font-family: "Material Symbols Rounded";
					font-weight: 400;
					content: "\e5cc";
					position: absolute;
					right: 10px;
					top: 5px;
					font-size: 20px;
				}
			}
		}
		.capture {
			width: 220px;
			margin: 15px auto 0;
		}
	}
}

/*------------------------------------------------
	応募要項
--------------------------------------------------*/
#info {
    width: 100%;
    background-color: #f4f4f4;
    padding: 40px 0 96px;
	h2 {
		text-align: center;
		font-size: 32px;
		font-weight: 700;
		line-height: 1.8;
		border-bottom: solid 3px #333;
		margin-bottom: 20px;
		&:not(:first-of-type) {
			padding-top: 40px;
		}
	}
	h3 {
		font-weight: bold;
		border-left: solid 5px #333;
		padding-left: 8px;
		margin: 20px 0 10px;
	}
	h4 {
		margin-top: 8px;
		font-weight: 600;
	}
	ul li {
		position: relative;
		padding-left: 15px;
		&::before {
			font-family: "Material Symbols Rounded";
			font-weight: 400;
			content: "\e5df";
			position: absolute;
			top: -3px;
			left: -3px;
			font-size: 22px;
		}
		.note & {
			padding-left: 0;
			&::before {
				display: none;
			}
		}
	}
	.scroll {
		height: 500px;
		overflow-y: scroll;
		background-color: #fff;
		font-size: 14px;
		padding: 20px;
	}
}


/*------------------------------------------------
	SNS
--------------------------------------------------*/
#footLink {
    width: 100%;
    padding: 40px 0 0;
    text-align: center;
	h2 {
		text-align: center;
		margin-bottom: 16px;
		span {
			font-size: 20px;
			font-weight: 700;
		}
		&::before,&::after {
			content: "";
			display: inline-block;
			width: 26px;
			height: 34px;
			background: url("../images/title-before-black.png") no-repeat;
			background-size: contain;
			margin: 0 10px;
			background-position: bottom;
		}
		&::after {
			transform: scaleX(-1);
		}
	}
	.snslist {
		display: flex;
		justify-content: center;
		li {
			width: 40px;
			height: 40px;
			margin: 0 20px;
			img {
				width: 100%;
			}
		}
	}
}

/*------------------------------------------------
        LINEお友達登録ボタン
--------------------------------------------------*/
.line-wrap-detail {
        padding: 50px 0 0;/*ページによって調整*/
}
.line-inner {
        width: 992px;
        margin: 0 auto;
        text-align: center;
        letter-spacing: 0.1em;
        line-height: 1.5;
}
.line-wrap-detail .line-inner {
        background: #fff;
        border: solid 1px #d3d3d3;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        letter-spacing: 1px;
}
.line-inner .head {
        width: 100%;
        text-align: center;
        background-color: #06C755;
        padding: 8px;
        color: #fff;
        font-size: 20px;
        line-height: 1.5;
        font-weight: bold;
}
.line-inner .textarea {
        width: 76%;
        text-align: left;
        padding: 24px 0 32px 24px;
}
.line-inner .btnarea {
        width: 23.4%;
        padding: 8px 16px 8px 0;
}
.line-inner .text1 {
        font-size: 18px;
        line-height: 1.5;
}
.line-inner .text1 span {
        display: inline-block;
        font-weight: bold;
        color: #DF0D00;
}
.line-inner .text2 {
        font-size: 20px;
        font-weight: bold;
        background: linear-gradient(transparent 60%, #fff231 0%);
        display: inline-block;
        line-height: 1.8;
        padding: 0 4px;
}
.line-button a {
        display: block;
        color: #fff;
        font-size: 14px;
        text-align: center;
        font-weight: bold;
        border-radius: 8vw;
        box-shadow: 0px 3px 0px 0 rgba(0, 0, 0, .14);
        background: url(/kansai/images/icon/icon-linekansai.png) no-repeat;
        background-size: 50px;
        background-position: 12px;
        background-color: #06C755;
        padding: 10px 10px 6px 70px;
        position: relative;
        text-decoration: none;
}
.line-button a:hover {
        opacity: .8;
        transition: all 0.6s ease;        
}
.line-qr {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
}
.line-qr span:nth-child(1) {
        width: 50%;
        font-size: 14px;
        font-weight: bold;
        line-height: 1.3;
        text-align: left;
}
.line-qr img {
        width: 50%;
}
.line-qr span:nth-child(3) {
        width: 100%;
        font-size: 14px;
}
.line-qr a {
        text-decoration: underline;
}

/*----------------------------------------------
ページトップ
------------------------------------------------*/
.goTop {
  display: none;
	position: fixed;
    bottom: 10px;
    right: 10px;
    transform: translateZ(0);
    z-index: 200;
	& a {
		display: flex;
		cursor: pointer;
		align-items: center;
		justify-content: center;
		border-radius: 50%;
		background-color: rgba(105, 113, 128, .5);
		width: 48px;
		height: 48px;
		& img {
				width: 24px;
				height: 24px;
		}
	}
}


/*------------------------------------------------
	終了
--------------------------------------------------*/
#close {
    background-color: #fff2cd;
    padding: 80px 0;
}
#close p {
    width: 940px;
    margin: 0 auto;
    color: #e53442;
    border: solid 3px #e53442;
    background-color: #fff;
    font-size: 20px;
    text-align: center;
    padding: 50px 0;
}