:root {
	--font-mincho: "游明朝", "YuMincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, serif;
	--color-niigata-city: #E60029;
	--color-kaetsu: #F08718;
	--color-chuetsu: #336DB6;
	--color-joetsu: #7FAD2F;
	--color-sado: #E9618F;
	--font-bold: 700;
	--font-extra-bold: 800;
}

#wrapper {
	padding-top: 80px;
}

@media screen and (min-width: 769px) {
	.sp-only {
		display: none;
	}
}

@media screen and (max-width: 768px) {
	.pc-only {
		display: none;
	}

	#wrapper {
		padding-top: 60px;
	}
}

.img-box {
	display: block;
}

html {
	scroll-behavior: smooth;
	scroll-padding-top: 0 !important;
	height: 100vh;
    overflow-y: scroll;
}

#wrapper {
	min-width: initial;
	overflow: hidden;
}

@media screen and (max-width: 768px) {
	#wrapper {
		min-width: initial;
	}
}

.container {
	width: min(100%, 1120px);
	margin: 0 auto;
	padding: 0 20px;
	box-sizing: border-box;
}

.section-mv-top {
	display: flex;
	align-items: center;
	height: 102px;
	background: url(../../images/lp/sakenojin-afterparty/fv_bg_01_pc.png) no-repeat center center / cover;
}

@media screen and (max-width: 768px) {
	.section-mv-top {
		height: 88px;
		background-image: url(../../images/lp/sakenojin-afterparty/fv_bg_01_sp.png);
	}	
}

.section-mv-middle-inner {
	display: flex;
	align-items: flex-end;
	justify-content: center;
	gap: 0;
	margin-inline: -80px -16px;
	padding-block: 24px 40px;
}

.section-mv-middle-inner .img-box:nth-child(2) {
	padding-bottom: 16px;
}

@media screen and (max-width: 1280px) {
	.section-mv-middle-inner {
		margin-inline: 0;
	}
}

@media screen and (max-width: 768px) {
	.section-mv-middle-inner {
		flex-direction: column;
		align-items: center;
		gap: 8px;
		padding-block: 0 56px;
	}

	.section-mv-middle-inner .img-box:nth-child(2) {
		display: none;
	}
}

.section-mv-bottom {
	background: url(../../images/lp/sakenojin-afterparty/fv_bg_02_pc.png) no-repeat center center / cover;
}

.section-mv-bottom-inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 18px;
	height: 284px;
}

.section-mv-bottom-secondary {
	display: flex;
	align-items: center;
	gap: 18px;
}

@media screen and (max-width: 768px) {
	.section-mv-bottom {
		background-image: url(../../images/lp/sakenojin-afterparty/fv_bg_02_sp.png);
	}

	.section-mv-bottom-inner {
		flex-direction: column;
		gap: 16px;
		height: auto;
		padding-block: 24px 32px;
	}

	.section-mv-bottom-secondary {
		flex-direction: column;
	}
}

.section-mv-img {
	aspect-ratio: 1440 / 960;
	background: url(../../images/lp/sakenojin-afterparty/fv_img_01_pc.png) no-repeat center center / cover;
}

@media screen and (max-width: 768px) {
	.section-mv-img {
		aspect-ratio: 375 / 996;
		background-image: url(../../images/lp/sakenojin-afterparty/fv_img_01_sp.png);
	}
}

#section-intro {
	position: relative;
	text-align: center;
}

#section-intro::before {
	display: block;
	content: "";
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
	background: linear-gradient(rgba(239, 235, 226, 0.4) 0%, #efebe2 100%);
}

#section-intro .section-intro-inner {
	position: relative;
	padding-inline: 20px;
	padding-top: 40px;
	padding-bottom: 120px;
}

#section-intro .section-intro-inner::before {
	display: block;
	content: "";
	position: absolute;
	inset: 0;
	bottom: -200px;
	width: 100%;
	height: 1068px;
	background: url(../../images/lp/sakenojin-afterparty/intro_bg_02.png) no-repeat center bottom;
	z-index: 2;
}

#section-intro .section-intro-inner::after {
	display: block;
	content: "";
	position: absolute;
	top: 214px;
	right: 0;
	left: 0;
	width: 100%;
	height: 310px;
	background: url(../../images/lp/sakenojin-afterparty/intro_bg_03.png) no-repeat center center;
	z-index: 3;
}

#section-intro .section-intro-inner > * {
	position: relative;
	z-index: 4;
}

#section-intro .section-intro-title {
	margin: 0 0 16px;
}

@media screen and (max-width: 768px) {
	#section-intro::before {
		aspect-ratio: 375;
		height: 985px;
		background: url(../../images/lp/sakenojin-afterparty/intro_bg_sp.png) no-repeat top center / cover;
	}

	#section-intro::after {
		display: none;
	}

	#section-intro .section-intro-inner {
		padding-top: 50px;
		padding-bottom: 72px;
	}

	#section-intro .section-intro-inner::after {
		top: 170px;
		height: 117px;
		background-image: url(../../images/lp/sakenojin-afterparty/intro_bg_03_sp.png);
	}

	#section-intro .section-intro-title {
		margin: 0 0 10px;
	}
}

.section-area-nav {
	position: relative;
	z-index: 3;
	background: url(../../images/lp/sakenojin-afterparty/nav_bg_ptn_01.png) repeat center center;
	padding: 80px 0;
}

.section-area-nav ul {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 20px;
}

.section-area-nav li a {
	display: block;
	padding: 22px 32px;
	border-radius: 3px;
	color: #fff;
	font-size: 20px;
	line-height: 1;
	font-family: var(--font-mincho);
	font-weight: var(--font-extra-bold);
	background: url(../../images/lp/sakenojin-afterparty/icon_circle_bottom.png) no-repeat right 12px center;
}

.section-area-nav li:nth-child(1) a {
	background-color: var(--color-niigata-city);
}

.section-area-nav li:nth-child(2) a {
	background-color: var(--color-kaetsu);
}

.section-area-nav li:nth-child(3) a {
	background-color: var(--color-chuetsu);
}

.section-area-nav li:nth-child(4) a {
	background-color: var(--color-joetsu);
}

.section-area-nav li:nth-child(5) a {
	background-color: var(--color-sado);
}

#section-area-wrapper {
	padding-bottom: 120px;
	background-color: #EFEBE2;
}

.section-area {
	padding-top: 120px;
}

.section-area-title {
	margin-bottom: 48px;
	padding-bottom: 16px;
	padding-left: 48px;
	border-bottom: 4px solid #9B8A0B;
	font-size: 3.2rem;
	font-family: var(--font-mincho);
	font-weight: var(--font-extra-bold);
	background: url(../../images/lp/sakenojin-afterparty/icon_cup.svg) no-repeat left 0.5em / 24px;
}

.section-area-nav-title {
	font-size: 3.6rem;
	font-family: var(--font-mincho);
	font-weight: var(--font-extra-bold);
	line-height: 1.3;
	color: #fff;
	text-align: center;
}

.section-area-nav-title-sm {
	margin: 16px 0 40px;
	font-size: 2rem;
	font-family: var(--font-mincho);
	font-weight: var(--font-extra-bold);
	line-height: 1;
	color: #fff;
	text-align: center;
}

.section-area-nav-title-sm span {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
}

.section-area-nav-title-sm span::before,
.section-area-nav-title-sm span::after {
	display: block;
	content: "";
	width: 24px;
	height: 1px;
	background-color: #fff;
}

@media screen and (max-width: 768px) {
	.section-area-nav {
		padding: 40px 0;
	}

	.section-area-nav ul {
		grid-template-columns: repeat(2, 1fr);
		gap: 24px;
	}

	.section-area-nav li a {
		padding: 22px 16px;
	}
}

.section-bnr {
	padding: 120px 0;
}

.site-footer {
	padding: 56px 0;
}

.site-footer-inner {
	display: grid;
	grid-template-columns: 50% 50%;
}

.site-footer .footer-logo {
	display: flex;
	align-items: center;
    justify-content: center;
}

.footer-contact {
    display: flex;
	gap: 32px;
}

.site-footer .footer-contact-title {
	display: flex;
    align-items: center;
    justify-content: center;
    writing-mode: vertical-lr;
	font-size: 15px;
	font-weight: var(--font-bold);
	line-height: 1;
	color: #fff;
	background-color: #21110D;
	border-radius: 3px;
	padding: 16px 8px;
}

.site-footer .footer-contact-body {
	font-size: 14px;
	font-family: var(--font-mincho);
	line-height: 1.75;
}

.site-footer .footer-contact-body-title {
	margin-bottom: 20px;
	font-size: 16px;
	font-weight: var(--font-extra-bold);
	line-height: 1;
}

.section-area {
	background: url(../../images/lp/sakenojin-afterparty/area_bg_01.png) no-repeat center 60px;
}

.section-area:nth-child(even) {
	background-image: url(../../images/lp/sakenojin-afterparty/area_bg_02.png);
}

.section-area-list {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 16px;
}

.section-area-list-item {
	display: grid;
	grid-template-rows: subgrid;
	grid-row: span 3;
}

.section-area-list-item-inner {
	display: inherit;
	grid-template-rows: inherit;
	grid-row: inherit;
	gap: 0;
	position: relative;
	border-radius: 5px;
	overflow: hidden;
	color: #fff;
	text-align: center;
	background-color: #10042D;
}

.section-area-list-item-inner::before {
    display: block;
    content: "";
    position: absolute;
    right: 8px;
    bottom: 8px;
    width: 40px;
    height: 40px;
	border-radius: 50%;
    background: var(--color-niigata-city) url(../../images/lp/sakenojin-afterparty/icon_circle_right.png) no-repeat center center / 20px;
}

#section-niigata-city .section-area-list-item-inner::before {
	background-color: var(--color-niigata-city);
}

#section-kaetsu .section-area-list-item-inner::before {
	background-color: var(--color-kaetsu);
}

#section-chuetsu .section-area-list-item-inner::before {
	background-color: var(--color-chuetsu);
}

#section-joetsu .section-area-list-item-inner::before {
	background-color: var(--color-joetsu);
}

#section-sado .section-area-list-item-inner::before {
	background-color: var(--color-sado);
}

.section-area-list-item-image {
	position: relative;
	aspect-ratio: 1 / 1;
}

.section-area-list-item-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.section-area-list-item-coupon {
	position: absolute;
	top: 8px;
	left: 8px;
}

.section-area-list-item-title {
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	padding: 20px;
	font-size: 20px;
	font-family: var(--font-mincho);
	font-weight: var(--font-extra-bold);
	line-height: 1.2;
}

.section-area-list-item-title::before {
	display: block;
	content: "";
	position: absolute;
	right: 16px;
	bottom: 0;
	left: 16px;
	margin: 0 auto;
	height: 1px;
	background-color: #9B8A0B;
}

.section-area-list-item-area {
	padding: 20px 20px 48px;
	font-size: 16px;
	font-family: var(--font-mincho);
}

.section-shop-list {
	margin-bottom: 100px;
}

@media screen and (max-width: 768px) {
	.section-area {
		background-image: url(../../images/lp/sakenojin-afterparty/area_bg_01_sp.png);
		background-position: center 40px;
	}
	
	.section-area:nth-child(even) {
		background-image: url(../../images/lp/sakenojin-afterparty/area_bg_02_sp.png);
	}

	.section-area-list {
		grid-template-columns: repeat(2, 1fr);
		gap: 15px;
	}

	.section-area-list-item-title {
		padding: 12px 10px;
		font-size: 16px;
	}

	.section-area-list-item-area {
		padding: 12px 10px 44px;
		font-size: 14px;
	}

	.section-area-list-item-inner::before {
		width: 25px;
		height: 25px;
		background-size: 12px;
	}

	.section-area {
		padding-top: 80px;
	}

	.section-bnr {
		padding: 80px 0;
	}

	.site-footer {
		padding-block: 64px;
	}

	.site-footer-inner {
		display: flex;
		flex-direction: column;
		gap: 48px;
	}

	.footer-contact {
		justify-content: center;
	}

	.section-shop-list {
		margin-bottom: 40px;
	}

	#section-area-wrapper {
		padding-bottom: 80px;
	}
}

#section-sado {
	position: relative;
	z-index: 2;
}

#section-campaign-detail {
	position: relative;
	padding-block: 100px 120px;
	background: url(../../images/lp/sakenojin-afterparty/campaign_bg.png) no-repeat center center / cover;
}

#section-campaign-detail::before {
	display: block;
	content: "";
	position: absolute;
	z-index: 1;
	top: -130px;
	right: 0;
	left: 0;
	width: 1440px;
	height: 700px;
	margin: 0 auto;
	background: url(../../images/lp/sakenojin-afterparty/campaign_deco_img_01.png) no-repeat center center / contain;
}

#section-campaign-detail .container {
	position: relative;
	z-index: 2;
}

.section-campaign-img-01 {
	margin-bottom: 65px;
}

.section-campaign-ttl {
	margin-bottom: 10px;
	text-align: center;
}

.section-campaign-box {
	margin-bottom: 65px;
	padding-bottom: 40px;
	border-radius: 10px;
	background-color: #EFEBE2;
}

.section-campaign-box-01 {
	padding-bottom: 0;
}

.section-campaign-box-01 .section-campaign-image {
	position: relative;
}

.section-campaign-box-01 .section-campaign-image a {
	display: block;
	position: absolute;
	z-index: 2;
	bottom: 0;
	left: 0;
	width: 100px;
	height: 100px;
}

.section-campaign-subttl {
	margin-bottom: 15px;
	text-align: center;
	transform: translateY(-50%);
}

.section-campaign-box-tweet {
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 0 auto;
	text-align: center;
}

.section-campaign-image {
	text-align: center;
}

.section-campaign-box-03 {
	margin-bottom: 40px;
}

.section-campaign-text {
	text-align: center;
	margin-bottom: 40px;
	font-size: 1.4rem;
}

.section-campaign-btn {
	text-align: center;
}

.section-campaign-btn a {
	display: inline-block;
}

.section-bnr {
	padding-block: 120px;
	background-color: #EFEBE2;
}

@media screen and (max-width: 768px) {
	#section-campaign-detail {
		padding-block: 80px;
	}

	.section-campaign-ttl {
		margin-bottom: 20px;
	}

	.section-campaign-box {
		margin-bottom: 70px;
	}

	.section-campaign-box-01 {
		padding-bottom: 40px;
	}

	.section-campaign-img-01 {
		text-align: center;
	}

	.section-campaign-box-03 {
		margin-bottom: 40px;
	}

	.section-campaign-text {
		margin-bottom: 20px;
	}

	.section-campaign-box-tweet {
		margin-top: -20px;
		padding-inline: 20px;
	}

	.section-bnr {
		padding-block: 80px 70px;
	}
}
