﻿@import"https://fonts.googleapis.com/css2?family=Caveat:wght@400..700&family=Kaisei+Opti:wght@400;500;700&display=swap";
@import"https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700&family=Noto+Serif+JP:wght@400;500;600;700&display=swap";
@import"https://fonts.googleapis.com/css2?family=Caveat:wght@400..700&display=swap";
@import"https://fonts.googleapis.com/icon?family=Material+Icons";
@import"https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.3.0/css/all.min.css";
@import"https://cdnjs.cloudflare.com/ajax/libs/animate.css/3.5.2/animate.css";
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, dialog, figure, footer, header, hgroup, menu, nav, section, time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: rgba(0, 0, 0, 0);
	line-height: 1;
	-ms-word-wrap: break-word;
	word-wrap: break-word;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
	font-weight: 400
}
article, aside, dialog, figure, footer, header, hgroup, nav, section {
	display: block
}
span {
	display: inline-block
}
br {
	line-height: 0
}
ul li {
	list-style: none
}
a {
	text-decoration: none !important;
	color: inherit;
	font-size: inherit;
	display: inline-block
}
input {
	margin: 0;
	padding: 0;
	border: 0;
	-webkit-box-shadow: none;
	box-shadow: none;
	-webkit-border-radius: 0;
	border-radius: 0
}
input:focus {
	outline: none
}
select, textarea {
	margin: 0;
	padding: 0;
	border: 0;
	-webkit-box-shadow: none;
	box-shadow: none;
	-webkit-border-radius: 0;
	border-radius: 0
}
button {
	margin: 0;
	padding: 0;
	border: 0;
	-webkit-box-shadow: none;
	box-shadow: none;
	-webkit-border-radius: 0;
	border-radius: 0;
	cursor: pointer
}
img {
	vertical-align: middle
}
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box
}
*::before, *::after {
	box-sizing: border-box
}
article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {
	display: block
}
h1, h2, h3, h4, h5, h6 {
	font: inherit
}
table {
	border-collapse: collapse;
	border-spacing: 0
}
ul, ol {
	list-style: none
}
@supports(-ms-ime-align: auto) {
	ul, ol {
		list-style-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAQAAAC1HAwCAAAAC0lEQVR42mNkYAAAAAYAAjCB0C8AAAAASUVORK5CYII=)
	}
}
img, iframe {
	border: 0;
	vertical-align: middle
}
svg, video {
	vertical-align: middle
}
input, select, textarea, button {
	font: inherit;
	color: inherit;
	letter-spacing: inherit;
	vertical-align: middle
}
input[type=file], input[type=checkbox], input[type=radio] {
	cursor: pointer
}
select, button {
	cursor: pointer
}
blockquote, q {
	quotes: none
}
blockquote::after, blockquote::before {
	content: "";
	content: none
}
q::after, q::before {
	content: "";
	content: none
}
pre, code {
	font: inherit
}
html {
	-webkit-text-size-adjust: 100%;
	-moz-text-size-adjust: 100%;
	text-size-adjust: 100%
}
body {
	font-family: "Noto Sans JP", sans-serif;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-size: 1.6em;
	line-height: 1.6;
	letter-spacing: .05em
}
body * {
	box-sizing: border-box
}
a {
	text-decoration: none;
	outline: none
}
.wrapper {
	display: block;
	margin: 0px auto;
	padding: 0px;
	min-height: 100vh
}
img, picture {
	width: 100%
}
a:hover img {
	opacity: .6;
	filter: alpha(opacity=60);
	-moz-opacity: .6;
	-webkit-transition: .3s ease-in-out;
	-moz-transition: .3s ease-in-out;
	-o-transition: .3s ease-in-out;
	transition: .3s ease-in-out
}
.is-fixed {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 9999;
	width: 100%;
	margin-top: 0 !important
}
.mb12 {
	margin-bottom: 12px
}
iframe {
	vertical-align: bottom
}
input[type=text], input[type=search], select, textarea {
	font-size: 16px
}
@keyframes menu-container-appeared {
	0% {
		transform: translateX(100%)
	}
	100% {
		transform: translateX(0)
	}
}
@keyframes menu-container-leaved {
	0% {
		transform: translateX(0)
	}
	100% {
		transform: translateX(100%)
	}
}
@keyframes menu-overlay-appeared {
	0% {
		opacity: 0
	}
	100% {
		opacity: 1
	}
}
@keyframes menu-overlay-leaved {
	0% {
		opacity: 1
	}
	100% {
		opacity: 0
	}
}
@keyframes modal-photo-open {
	0% {
		opacity: 0
	}
	100% {
		opacity: 1
	}
}
@keyframes modal-photo-close {
	0% {
		opacity: 1
	}
	100% {
		opacity: 0
	}
}

* {
	-webkit-tap-highlight-color: rgba(0, 0, 0, 0)
}
::selection {
	background: #ddd;
	color: #000
}
.pc {
	display: block
}
@media screen and (max-width: 800px) {
	.pc {
		display: none
	}
}
.sp {
	display: none
}
@media screen and (max-width: 800px) {
	.sp {
		display: block
	}
}
input {
	outline: none;
	appearance: none;
	-webkit-appearance: none;
	-ms-appearance: none
}
a {
	display: block;
	transition: all .3s
}
img {
	width: 100%
}
.inner {
	width: 1070px;
	margin: 0 auto;
	padding: 0 16px;
	max-width: 100%
}
@media screen and (max-width: 800px) {
	.inner {
		width: 100%;
		margin: 0 auto;
		padding: 0 26px
	}
}
.inner_2 {
	width: 1070px;
	margin: 0 auto;
	padding: 0 120px;
	max-width: 100%
}
@media screen and (max-width: 800px) {
	.inner_2 {
		width: 100%;
		margin: 0 auto;
		padding: 0 32px
	}
}
.u-margin__bottom--100 {
	margin-bottom: 0;
}
.u-margin__top--60 {
	margin-top: 0;
}
main.l-container {
	background: #f5f3ea url(https://d2w53g1q050m78.cloudfront.net/northcolorscom/uploads/images/pages/concept/bg_pc.png) center top/110% no-repeat fixed;
	max-width: 100%;
}
@media screen and (max-width: 800px) {
	main.l-container {
		padding: 0;
	}
}
.main {
	margin: 0;
	width: 100%
}

.sec-ttl {
	margin-bottom: 20px
}
.list-btn {
	width: 292px;
	margin: 40px auto 0 auto;
	padding: 6px 0;
	border: 2px solid #b49586;
	border-radius: 10px;
	background: #b49586;
	color: #fff;
	font-size: 20px;
	line-height: 1.4;
	text-align: center
}
@media screen and (max-width: 800px) {
	.list-btn {
		width: 236px;
		padding: 4px 0;
		font-size: 17px
	}
}
.list-btn:hover {
	border: 2px solid #b49586;
	background: rgba(0, 0, 0, 0);
	color: #b49586
}
.f-sb {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: flex-start
}
.f-s {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: flex-start
}
.f-e {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	align-items: flex-end
}
.f-ss {
	display: flex;
	justify-content: flex-start;
	align-items: flex-start
}
.block {
	display: block !important
}
.grid {
	display: grid !important
}
.none {
	display: none !important
}
.tablet-block {
	display: none !important
}
@media screen and (max-width: 800px) {
	.tablet-block {
		display: block !important
	}
}
.tablet-none {
	display: block !important
}
@media screen and (max-width: 800px) {
	.tablet-none {
		display: none !important
	}
}
@media screen and (max-width: 600px) {
	.sp-block {
		display: block !important
	}
	.sp-none {
		display: none !important
	}
}
.only-pc {
	display: block !important
}
@media screen and (max-width: 800px) {
	.only-pc {
		display: none !important
	}
}
.only-sp {
	display: none !important
}
@media screen and (max-width: 800px) {
	.only-sp {
		display: flex !important
	}
}
body, p {
	font-size: 16px;
	color: #333;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 400;
	line-height: 1.8;
	letter-spacing: .08em;
	text-align: justify
}
h1, h1 span, h2, h3, .logo-blk span {
	font-family: "Kaisei Opti", serif !important;
	font-weight: 700;
	font-style: normal;
	color: #694626;
	letter-spacing: .12em
}
.fv {
	position: relative
}
.fv h1 {
	position: absolute;
	top: 120px;
	left: 50%;
	transform: translateX(-50%);
	text-align: center;
	font-size: clamp(1.875rem, 1.458rem + 2.08vw, 2.5rem);
	color: #fff;
	width: 100%;
	line-height: 1.6;
	text-shadow: 2px 2px 6px rgba(0, 0, 0, .3), -2px -2px 6px rgba(0, 0, 0, .3)
}
.fv h1 span {
	display: block;
	font-size: clamp(1.25rem, 1.083rem + .83vw, 1.5rem);
	color: #fff;
	width: fit-content;
	background: #f47822;
	border-radius: 80px;
	padding: 12px 80px;
	margin: 0 auto 16px;
	text-shadow: none;
	position: relative
}
.fv h1 span:after {
	content: "";
	position: absolute;
	bottom: -15px;
	left: 50%;
	transform: translateX(-50%);
	width: 0;
	height: 0;
	border-left: 16px solid rgba(0, 0, 0, 0);
	border-right: 16px solid rgba(0, 0, 0, 0);
	border-top: 16px solid #f47822
}
.grad {
	position: relative
}
.grad:after {
	content: "";
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}
.grad-w:after {
	background: linear-gradient(0deg, rgb(255, 255, 255) 0%, rgba(255, 255, 255, 0) 35%)
}
.grad-w-2:after {
	background: linear-gradient(180deg, rgb(255, 255, 255) 0%, rgba(255, 255, 255, 0) 35%)
}
.grad-g:after {
	background: linear-gradient(180deg, rgb(236, 242, 226) 0%, rgba(236, 242, 226, 0) 35%)
}
.n-margin {
	margin-top: -280px;
	z-index: 10;
	position: relative
}
@media screen and (max-width: 800px) {
	.n-margin {
		margin-top: -55vw;
	}
}
.n-margin-2 {
	margin-top: -200px
}
.n-margin-3 {
	margin-top: -120px;
	max-height: 400px
}
h2 {
	font-size: clamp(2rem, 1.333rem + 3.33vw, 3rem) !important;
	text-align: center;
	padding-bottom: .5em;
	padding-top: 2em;
	position: relative;
	margin-bottom: 1em !important;
}
h2::before {
	content: "Concept";
	font-family: "Caveat", cursive;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
	font-size: clamp(1rem, .667rem + 1.67vw, 1.5rem);
	color: #dbc5b0;
	position: absolute;
	top: 2.4em;
	left: 50%;
	transform: translateX(-50%)
}
h2::after {
	content: "";
	width: 88px;
	height: 1px;
	background: #dbc5b0;
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%)
}
.bg {
	padding: 28px 0 63px 0;
	background: #fff1eb
}
@media screen and (max-width: 800px) {
	.bg {
		padding: 32px 0 116px 0
	}
}
.page-content {
	margin: 0 auto;
	max-width: 800px;
	background: #fff;
	box-shadow: 0px 0px 56px rgba(0, 0, 0, .1)
}
.page-content2 {
	background: #ece5d8;
}
@media screen and (max-width: 800px) {
	.page-content {
		margin: 0 auto
	}
}
section {
	padding: 0 4vw;
}
@media screen and (max-width: 800px) {
	section {
		padding: 0;
	}
	.p-page_content{
		padding: 0;
	}
}
.sec {
	position: relative
}
.sec-1:after {
	content: "";
	width: 80px;
	height: 80px;
	background: url(https://d2w53g1q050m78.cloudfront.net/northcolorscom/uploads/images/pages/concept/img_1.png);
	background-size: contain;
	background-repeat: no-repeat;
	position: absolute;
	top: 5.4em;
	left: 50%;
	transform: translateX(-320%)
}
@media screen and (max-width: 800px) {
	.sec-1 {
		padding: 80px 4vw;
	}
	.sec-1:after {
		width: 13%;
		top: 9.4em;
		left: 3%;
		transform: translateX(0)
	}
}
.sec-2:after {
	content: "";
	width: 80px;
	height: 80px;
	background: url(https://d2w53g1q050m78.cloudfront.net/northcolorscom/uploads/images/pages/concept/img_3.png);
	background-size: contain;
	background-repeat: no-repeat;
	position: absolute;
	top: 5.4em;
	left: 50%;
	transform: translateX(-390%)
}
@media screen and (max-width: 800px) {
	.sec-2 {
		padding: 80px 4vw;
	}
	.sec-2:after {
		width: 17%;
		top: 5.8em;
		left: 3%;
		transform: translateX(0)
	}
}
.sec-3:after {
	content: "";
	width: 120px;
	height: 240px;
	background: url(https://d2w53g1q050m78.cloudfront.net/northcolorscom/uploads/images/pages/concept/img_5.png);
	background-size: contain;
	background-repeat: no-repeat;
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(200%)
}
@media screen and (max-width: 800px) {
	.sec-3 {
		padding: 80px 4vw;
	}
	.sec-3:after {
		width: 23%;
		top: -2.6em;
		left: auto;
		right: 3%;
		transform: translateX(0)
	}
}
@media screen and (max-width: 480px) {
	.sec-3:after {
		width: 33%
	}
}
.img-1 {
	display: block;
	max-width: 440px;
	margin: 0 auto 2em
}
.img-2 {
	display: block;
	max-width: 560px;
	margin: 2em auto 0;
	z-index: 20;
	position: relative
}
@media screen and (max-width: 800px) {
	.img-3 {
		height: 640px;
		object-fit: cover
	}
}
p:not(.logo-blk) {
	font-size: clamp(.875rem, .792rem + .42vw, 1rem);
	max-width: 496px;
	margin: 0 auto
}
.img-box {
	position: relative
}
.img-box-1::after {
	content: "";
	width: 160px;
	height: 160px;
	background: url(https://d2w53g1q050m78.cloudfront.net/northcolorscom/uploads/images/pages/concept/img_2.png);
	background-size: contain;
	background-repeat: no-repeat;
	position: absolute;
	top: 13.4em;
	right: 50%;
	transform: translateX(200%);
	z-index: 21
}
@media screen and (max-width: 800px) {
	.img-box-1::after {
		width: 30%;
		top: 11.4em;
		right: 0;
		transform: translateX(0)
	}
}
@media screen and (max-width: 480px) {
	.img-box-1::after {
		top: 8.4em
	}
}
.list li img {
	transition: all .5s
}
.list li:hover img {
	opacity: .6
}
.sec-mv {
	padding-top: 20px;
	padding-left: 248px
}
@media screen and (max-width: 800px) {
	.sec-mv {
		padding-left: 0
	}
}
.sec-topic {
	margin-bottom: 88px
}
@media screen and (max-width: 800px) {
	.sec-topic {
		margin-bottom: 73px
	}
}
.sec-topic .list li {
	width: 31.6%;
	max-width: 332px;
	margin-right: 2%
}
.sec-topic .list li:nth-child(3n) {
	margin-right: 0
}
.sec-ranking {
	background: #f5f3ea;
	padding-bottom: 60px
}
.sec-ranking .slider {
	counter-reset: rank
}
.sec-ranking .slider li {
	border-radius: 8px;
	background: #fff;
	box-shadow: 3px 3px 6px rgba(0, 0, 0, .09)
}
.sec-ranking .slider .slick-list {
	padding: 0 15% 0 0 !important
}
@media screen and (max-width: 800px) {
	.sec-ranking .slider .slick-list {
		padding: 0 30% 0 0 !important
	}
}
.sec-ranking .slider .d-box {
	display: flex;
	justify-content: space-around;
	margin: 16px 8px 24px
}
.sec-ranking .slider .slick-arrow {
	position: absolute;
	width: 42px;
	height: 42px;
	top: 50%;
	transform: translateY(-50%);
	z-index: 1;
	color: rgba(0, 0, 0, 0)
}
.sec-ranking .slider .slick-next {
	background: url("../images/slide-arrow-next.svg") center top no-repeat;
	background-size: cover;
	right: -15px
}
.sec-ranking .slider .slick-prev {
	background: url("../images/slide-arrow-prev.svg") center top no-repeat;
	background-size: cover;
	left: -10px
}
.sec-ranking .slider .rank-container {
	font-weight: bold;
	font-size: 44px;
	text-align: left;
	color: #f47822
}
.sec-ranking .slider .rank-container::before {
	counter-increment: rank;
	content: counter(rank)
}
.sec-ranking .slider .rank-text {
	font-size: 16px
}
.sec-ranking .slider .p-name {
	font-weight: bold;
	font-size: 16px;
	text-align: left;
	color: #000
}
.products-bg {
	position: relative;
	overflow: hidden;
	height: 1700px;
	background: #f5f3ea
}
.products-bg::after {
	display: block;
	content: "";
	background-image: url(https://d2w53g1q050m78.cloudfront.net/northcolorscom/uploads/images/pages/concept/bg_4.svg);
	background-size: cover;
	background-repeat: no-repeat;
	width: 100%;
	height: 700px;
	position: absolute;
	top: 80%;
	transform: translateY(-50%);
	z-index: 1
}
@media screen and (max-width: 800px) {
	.products-bg::after {
		height: 600px
	}
}
.products-bg iframe {
	position: relative;
	z-index: 2;
	width: 100%
}
.sec-products {
	padding-bottom: 60px
}
.sec-products ul {
	display: grid;
	gap: 32px 16px;
	grid-template-columns: repeat(2, 1fr)
}
.sec-products li {
	border-radius: 8px;
	background: #fff;
	box-shadow: 3px 3px 6px rgba(0, 0, 0, .09)
}
.sec-products li img {
	border-radius: 8px 8px 0 0
}
.sec-products .products-box {
	padding: 24px
}
.sec-products .products-name {
	font-weight: bold;
	font-size: 16px;
	text-align: left;
	color: #000
}
.sec-products .products-text {
	font-weight: 500;
	font-size: 16px;
	letter-spacing: -0.02em;
	text-align: left;
	color: #1a1a1a;
	line-height: 1.5;
	margin-top: 16px
}
.category-bg {
	position: relative;
	top: -3.9em;
	z-index: 1
}
@media screen and (max-width: 800px) {
	.category-bg {
		top: -5.9em
	}
}
.category-bg::before {
	display: inline-block;
	content: "";
	background-image: url(https://d2w53g1q050m78.cloudfront.net/northcolorscom/uploads/images/pages/concept/section-bk_1.svg);
	background-size: 100%;
	background-repeat: no-repeat;
	width: 100%;
	vertical-align: bottom;
	aspect-ratio: 248/19
}
.category-bg-2::before {
	background-image: url(https://d2w53g1q050m78.cloudfront.net/northcolorscom/uploads/images/pages/concept/section-bk_3.svg)
}
.category-bg-3 {
	top: -7.9em
}
@media screen and (max-width: 800px) {
	.category-bg-3 {
		top: -9.9em
	}
}
.sec-category {
	background: #ece5d8;
	padding-bottom: 60px
}
.sec-category ul {
	display: grid;
	gap: 0 14px;
	grid-template-columns: repeat(3, 1fr)
}
@media screen and (max-width: 800px) {
	.sec-category ul {
		gap: 0 11px
	}
}
.sec-category li {
	border-radius: 8px;
	background: #fff;
	box-shadow: 3px 3px 6px rgba(0, 0, 0, .09)
}
.sec-category li img {
	border-radius: 8px 8px 0 0
}
.sec-category .category-box {
	padding: 25px 35px
}
.sec-category .category-name {
	font-weight: bold;
	font-size: 19px;
	text-align: center;
	color: #000
}
.ranking-slider .slick-list {
	padding: 1.5em 0 1em
}
.series-bg {
	position: relative;
	background: #ecf2e2;
	top: -4em;
	z-index: 1;
	padding-bottom: 0
}
.series-bg h2 {
	color: #5e6926
}
.series-bg h2::before {
	color: #d1dbb0
}
.series-bg h2::after {
	background: #d1dbb0
}
.series-bg-2 {
	background: #ece5d8;
	margin-top: -4em;
	padding-bottom: 6em
}
.series-bg-2 h2 {
	color: #694626
}
.series-bg-2 h2::before {
	color: #dbc5b0
}
.series-bg-2 h2::after {
	background: #dbc5b0
}
.series-bg p {
	margin-top: 3em;
	margin-bottom: 2em
}
.series-bg > img {
	display: block;
	max-width: 560px;
	margin: 2em auto 0;
	z-index: 20;
	position: relative
}
@media screen and (max-width: 800px) {
	.series-bg {
		top: -6em
	}
}
.series-bg iframe {
	position: relative;
	z-index: 2;
	width: 100%
}
.flex {
	display: flex;
	position: relative
}
.flex-1 {
	justify-content: end;
	max-width: 560px;
	margin: 0 auto
}
.flex-1 img:first-of-type {
	transform: translate(6vw, -26px)
}
@media screen and (max-width: 480px) {
	.flex-1 img:first-of-type {
		transform: translate(39vw, -26px);
		z-index: -1
	}
}
h3 {
	font-size: clamp(1.5rem, 1.167rem + 1.67vw, 2rem);
	padding: 3em 0 .5em;
	text-align: center
}
.series-bg-2 {
	background: #ece5d8
}
.series-bg .ranking-slider {
	padding: 0 4vw;
	z-index: 11
}
.series-bg .ranking-slider li {
	box-shadow: 3px 3px 8px rgba(0, 0, 0, .15);
	border-radius: 8px 8px 0 0
}

.series-bg .slider .slick-prev {
	background: url(https://d2w53g1q050m78.cloudfront.net/northcolorscom/uploads/images/pages/concept/slide-arrow-prev.svg) center top no-repeat;
	background-size: cover;
	left: 5vw
}
.series-bg .slider .slick-next {
	background: url(https://d2w53g1q050m78.cloudfront.net/northcolorscom/uploads/images/pages/concept/slide-arrow-next.svg) center top no-repeat;
	background-size: cover;
	right: 5vw
}
.series-bg .slider .slick-arrow {
	width: 44px;
	height: 44px;
	top: -9%
}
.series-bg .slider .slick-prev:before {
	content: none;
}
.series-bg .slider .slick-next:before {
	content: none;
}
.b-rad {
	border-radius: 8px
}
.d-box {
	background: #fff;
	padding: 1em .5em;
	border-radius: 0 0 8px 8px;
	min-height: 86px
}
.d-box div {
	line-height: 1.6;
	font-weight: 700;
	letter-spacing: 0
}
.sec-series {
	padding-bottom: 60px
}
.sec-series ul {
	display: grid;
	gap: 0 16px;
	grid-template-columns: repeat(2, 1fr)
}
@media screen and (max-width: 800px) {
	.sec-series ul {
		gap: 0 12px
	}
}
.sec-series li {
	border-radius: 8px;
	background: #fff;
	box-shadow: 3px 3px 6px rgba(0, 0, 0, .09)
}
.sec-series li img {
	border-radius: 8px 8px 0 0
}
.concept-bg {
	position: relative;
	top: -7em;
	z-index: 1
}
@media screen and (max-width: 800px) {
	.concept-bg {
		top: -10.5em
	}
}
.concept-bg::before {
	display: inline-block;
	content: "";
	background-image: url(https://d2w53g1q050m78.cloudfront.net/northcolorscom/uploads/images/pages/concept/section-bk_2.svg);
	background-size: 100%;
	background-repeat: no-repeat;
	width: 100%;
	height: 76px;
	vertical-align: middle
}
@media screen and (max-width: 1220px) {
	.concept-bg::before {
		height: clamp(43px, 2.6vw, 76px)
	}
}
.concept-box {
	position: relative;
	height: 42em;
	background: #fff;
	overflow: hidden
}
.sec-concept {
	position: relative;
	background: #fff;
	padding-bottom: 60px
}
.sec-concept .concept-img-1 {
	text-align: center;
	padding-top: 6px
}
.sec-concept .concept-img-1 img {
	width: 50%
}
.sec-concept .concept-text {
	font-weight: 500;
	font-size: 16px;
	text-align: center;
	color: #1a1a1a;
	line-height: 1.4;
	margin-top: 48px
}
@media screen and (max-width: 800px) {
	.sec-concept .concept-text {
		text-align: left
	}
}
.concept-img-2 {
	position: absolute;
	right: -17em;
	top: 21em
}
.concept-img-2 img {
	width: 70%
}
.review-bg {
	position: relative;
	top: -7em;
	z-index: 1
}
.sec-review {
	background: #fff;
	padding-bottom: 60px
}
.sec-review li + li {
	margin-top: 32px
}
.sec-review .review-box {
	display: grid;
	gap: 0 24px;
	grid-template-columns: 156px 1fr
}
.sec-review .review-inner img {
	width: 156px
}
.sec-review .review-top {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	margin-bottom: 1em
}
.sec-review .rate {
	position: relative;
	display: inline-block;
	width: 125px;
	height: 24px;
	font-size: 24px
}
.sec-review .rate::before, .sec-review .rate::after {
	position: absolute;
	display: inline-block;
	height: 24px;
	content: "★★★★★";
	line-height: 24px
}
.sec-review .rate::before {
	color: #c4c4c4
}
.sec-review .rate::after {
	overflow: hidden;
	width: calc(var(--score)*25px);
	color: #ffb906;
	white-space: nowrap
}
.sec-review .review-user {
	font-weight: bold;
	font-size: 16px;
	text-align: left;
	color: #000;
	margin-left: 1em
}
.sec-review .review-day {
	font-weight: 500;
	font-size: 16px;
	text-align: left;
	color: #5d5d5d;
	margin-left: 1em
}
.sec-review .review-bottom {
	font-weight: 500;
	font-size: 16px;
	line-height: 1.4;
	text-align: left;
	color: #000
}
.sec-review .accordion-item {
	width: 35%;
	margin: 40px auto 0
}
.tab-br {
	display: none
}
@media screen and (max-width: 800px) {
	.tab-br {
		display: block
	}
}
@media screen and (max-width: 480px) {
	.sp-br {
		display: none
	}
}
.section-title {
	text-align: center;
	line-height: 0;
	padding-top: 43px;
	margin-bottom: 50px
}
@media screen and (max-width: 768px) {
	.section-title {
		margin-bottom: 42px
	}
}
.section-title h3 {
	font-weight: bold;
	font-size: 48px;
	letter-spacing: .05em;
	text-align: center;
	color: #694626;
	line-height: 1;
	position: relative;
	padding: .5rem 0 6px;
	margin-top: 0;
	margin-bottom: .5rem
}
.section-title h3::before {
	position: absolute;
	border-bottom: 2px solid #dbc5b0;
	top: 100%;
	left: 50%;
	transform: translateX(-50%);
	width: 70px;
	content: "";
	padding-bottom: 11px
}
@media screen and (max-width: 768px) {
	.section-title h3 {
		margin-top: 11px
	}
}
.section-title h3 span {
	display: block;
	font-family: "Caveat", cursive;
	font-weight: normal;
	font-size: 24px;
	text-align: center;
	color: #dbc5b0;
	margin-bottom: 18px
}
.section-title_2 {
	text-align: center;
	line-height: 0;
	padding-top: 45px;
	margin-bottom: 50px
}
@media screen and (max-width: 768px) {
	.section-title_2 {
		margin-bottom: 42px
	}
}
.section-title_2 h3 {
	font-weight: bold;
	font-size: 48px;
	letter-spacing: .05em;
	text-align: center;
	color: #694626;
	line-height: 1;
	position: relative;
	padding: .5rem 0 6px;
	margin-top: 0;
	margin-bottom: .5rem
}
.section-title_2 h3::before {
	position: absolute;
	border-bottom: 2px solid #fff;
	top: 100%;
	left: 50%;
	transform: translateX(-50%);
	width: 70px;
	content: "";
	padding-bottom: 11px
}
@media screen and (max-width: 768px) {
	.section-title_2 h3 {
		margin-top: 11px
	}
}
.section-title_2 h3 span {
	display: block;
	font-family: "Caveat", cursive;
	font-weight: normal;
	font-size: 24px;
	text-align: center;
	color: #fff;
	margin-bottom: 18px
}

.pagetop {
	position: fixed;
	right: 20px;
	bottom: 20px;
	width: 90px
}
@media screen and (max-width: 800px) {
	.pagetop {
		width: 55px
	}
}
.campaign_main {
	justify-self: center;
	align-self: start;
	max-width: 1080px;
	width: 100%;
	margin: 0 auto;
	padding-top: 86px
}
@media screen and (max-width: 1200px) {
	.campaign_main {
		padding-top: 112px;
		padding-left: 16px;
		padding-right: 16px
	}
}
@media screen and (max-width: 800px) {
	.campaign_main {
		justify-content: center;
		align-items: center;
		padding-left: 20px;
		padding-right: 20px;
		padding-top: 80px
	}
}
@media screen and (max-width: 768px) {
	.campaign_main {
		padding-top: 43px;
		padding-bottom: 40px
	}
}
.campaign_main .sns_post {
	max-width: 1080px;
	width: 100%;
	font-weight: bold
}
.campaign_main .sns_post .title-image {
	padding-bottom: 76px
}
@media screen and (max-width: 800px) {
	.campaign_main .sns_post .title-image {
		width: 91%;
		margin: 0 auto;
		padding-bottom: 50px
	}
}
@media screen and (max-width: 480px) {
	.campaign_main .sns_post .title-image {
		padding-bottom: 20px
	}
}
.campaign_main .sns_post .snstop_banner {
	position: relative
}
@media screen and (max-width: 800px) {
	.campaign_main .sns_post .snstop_banner {
		margin: 0 40px
	}
}
@media screen and (max-width: 480px) {
	.campaign_main .sns_post .snstop_banner {
		margin: 0 10px
	}
}
.campaign_main .sns_post .snstop_banner::before, .campaign_main .sns_post .snstop_banner::after {
	content: "";
	position: absolute;
	top: 0;
	height: 100%;
	width: 139px;
	background-size: cover;
	background-repeat: no-repeat
}
@media screen and (max-width: 800px) {
	.campaign_main .sns_post .snstop_banner::before, .campaign_main .sns_post .snstop_banner::after {
		width: 11.125vw
	}
}
@media screen and (max-width: 480px) {
	.campaign_main .sns_post .snstop_banner::before, .campaign_main .sns_post .snstop_banner::after {
		width: 11.8958333333vw
	}
}
.campaign_main .sns_post .snstop_banner::before {
	left: 0;
	background-image: url("../images/snscampaign/leaf_left.svg");
	object-fit: cover
}
.campaign_main .sns_post .snstop_banner::after {
	right: 0;
	background-image: url("../images/snscampaign/leaf_right.svg");
	object-fit: cover
}
.campaign_main .sns_post .snstop_banner__title {
	position: relative;
	z-index: 1;
	font-weight: bold;
	font-size: 60px;
	letter-spacing: .06em;
	line-height: 90px;
	text-align: center
}
@media screen and (max-width: 800px) {
	.campaign_main .sns_post .snstop_banner__title {
		font-size: 38px;
		letter-spacing: .06em;
		line-height: 57px
	}
}
@media screen and (max-width: 480px) {
	.campaign_main .sns_post .snstop_banner__title {
		font-size: calc(24px + 4*(100vw - 320px)/670);
		line-height: 1.5
	}
}
.campaign_main .sns_post .snstop_banner__text {
	font-weight: bold;
	color: #825b41;
	line-height: 90px
}
@media screen and (max-width: 800px) {
	.campaign_main .sns_post .snstop_banner__text {
		line-height: 57px
	}
}
@media screen and (max-width: 480px) {
	.campaign_main .sns_post .snstop_banner__text {
		line-height: 1.5
	}
}
.campaign_main .sns_post .snstop_banner__highlight {
	font-weight: bold;
	color: #de8c86
}
.campaign_main .sns_post .title-image2 {
	position: relative;
	margin-top: 103px;
	margin-bottom: 61px
}
@media screen and (max-width: 1200px) {
	.campaign_main .sns_post .title-image2 {
		margin-top: 64px;
		margin-bottom: 69px
	}
}
@media screen and (max-width: 800px) {
	.campaign_main .sns_post .title-image2 {
		margin: 104px 40px 77px
	}
}
@media screen and (max-width: 480px) {
	.campaign_main .sns_post .title-image2 {
		margin: 24px 16px 15px
	}
}
.campaign_main .sns_post .subtitle-small h3 {
	background: none;
	background-image: none;
	background-color: rgba(0, 0, 0, 0);
	background-repeat: none;
	background-size: auto;
	background-position: 0 0;
	padding: 0;
	font-size: 39px;
	font-weight: bold;
	text-align: center;
	color: #825b41;
	margin-bottom: 25px
}
@media screen and (max-width: 1200px) {
	.campaign_main .sns_post .subtitle-small h3 {
		margin-bottom: 35px
	}
}
@media screen and (max-width: 800px) {
	.campaign_main .sns_post .subtitle-small h3 {
		font-size: 28px;
		margin-bottom: 10px
	}
}
@media screen and (max-width: 480px) {
	.campaign_main .sns_post .subtitle-small h3 {
		font-size: calc(18px + 4*(100vw - 320px)/670)
	}
}
.campaign_main .sns_post .subtitle-large {
	font-size: 50px;
	line-height: 1.5;
	font-weight: bold;
	text-align: center;
	color: #825b41;
	margin-bottom: 15px
}
@media screen and (max-width: 1200px) {
	.campaign_main .sns_post .subtitle-large {
		margin-bottom: 20px
	}
}
@media screen and (max-width: 800px) {
	.campaign_main .sns_post .subtitle-large {
		font-size: 33px;
		margin-bottom: 16px
	}
}
@media screen and (max-width: 480px) {
	.campaign_main .sns_post .subtitle-large {
		font-size: calc(20px + 4*(100vw - 320px)/670)
	}
}
.campaign_main .sns_post .title h1 {
	font-size: 66px;
	font-weight: bold;
	text-align: center;
	color: #825b41
}
@media screen and (max-width: 800px) {
	.campaign_main .sns_post .title h1 {
		font-size: 51px
	}
}
@media screen and (max-width: 480px) {
	.campaign_main .sns_post .title h1 {
		font-size: calc(30px + 4*(100vw - 320px)/670)
	}
}
.campaign_main .sns_post .image-text {
	display: flex;
	align-items: center;
	margin-top: 76px
}
@media screen and (max-width: 1200px) {
	.campaign_main .sns_post .image-text {
		margin-top: 87px
	}
}
@media screen and (max-width: 800px) {
	.campaign_main .sns_post .image-text {
		margin-top: 32px;
		-webkit-flex-direction: column;
		flex-direction: column
	}
}
@media screen and (max-width: 480px) {
	.campaign_main .sns_post .image-text {
		margin-top: 15px
	}
}
.campaign_main .sns_post .image-text .image {
	flex-basis: 48%;
	margin-right: 43px
}
@media screen and (max-width: 800px) {
	.campaign_main .sns_post .image-text .image {
		-webkit-box-ordinal-group: 2;
		-ms-flex-order: 2;
		-webkit-order: 2;
		order: 2;
		flex: 1
	}
}
.campaign_main .sns_post .image-text .image img {
	display: block;
	max-width: 100%
}
.campaign_main .sns_post .image-text .text {
	flex-basis: 75%;
	font-weight: 500;
	font-size: 25px;
	line-height: 1.9;
	text-align: left;
	color: #444
}
@media screen and (max-width: 800px) {
	.campaign_main .sns_post .image-text .text {
		-webkit-box-ordinal-group: 1;
		-ms-flex-order: 1;
		-webkit-order: 1;
		order: 1;
		text-align: center;
		padding-bottom: 61px;
		flex: 1
	}
}
@media screen and (max-width: 480px) {
	.campaign_main .sns_post .image-text .text {
		font-size: calc(18px + 4*(100vw - 320px)/670);
		padding-bottom: 23px
	}
}
.campaign_main .sns_post .image-text .text p {
	margin: 0
}
@media screen and (max-width: 800px) {
	.campaign_main .sns_post .image-text {
		flex-direction: column
	}
	.campaign_main .sns_post .image-text .image {
		margin-right: 0
	}
	.campaign_main .sns_post .image-text .text {
		margin-top: 20px
	}
}
@media screen and (max-width: 480px) {
	.campaign_main .sns_post .image-text .text {
		margin-top: 0
	}
}
.campaign_main .application_method .element_container .row {
	display: flex;
	flex-wrap: wrap;
	margin: 10px -10px
}
.campaign_main .application_method .element_container .col-md-6, .campaign_main .application_method .element_container .col-lg-6, .campaign_main .application_method .element_container .col-xl-6 {
	width: 50%;
	padding: 10px;
	box-sizing: border-box
}
@media screen and (max-width: 800px) {
	.campaign_main .application_method .element_container .col-md-6, .campaign_main .application_method .element_container .col-lg-6, .campaign_main .application_method .element_container .col-xl-6 {
		width: 100%
	}
}
.campaign_main .application_method .element_container .item {
	position: relative;
	overflow: hidden;
	height: 100%;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat
}
@media screen and (max-width: 800px) {
	.campaign_main .application_method .element_container .item {
		background-size: contain
	}
}
.campaign_main .application_method .element_container .item-1 {
	padding-bottom: 100%;
	background-image: url("../images/snscampaign/step_01_pc.png")
}
@media screen and (max-width: 800px) {
	.campaign_main .application_method .element_container .item-1 {
		background-image: url("../images/snscampaign/step_01_tab.png");
		padding-bottom: 57%
	}
}
.campaign_main .application_method .element_container .btn {
	position: absolute;
	bottom: 10px;
	left: 55%;
	transform: translateX(-50%);
	display: block;
	width: clamp(7.188rem, 3.642rem + 17.73vw, 16.938rem);
	height: auto;
	aspect-ratio: 16/6
}
@media screen and (max-width: 800px) {
	.campaign_main .application_method .element_container .btn {
		left: 76%
	}
}
.campaign_main .application_method .element_container .btn img {
	display: block;
	width: clamp(7.188rem, 3.642rem + 17.73vw, 16.938rem);
	height: auto;
	aspect-ratio: 16/6;
	border: none;
	cursor: pointer
}
@media screen and (max-width: 800px) {
	.campaign_main .application_method .element_container .btn img {
		aspect-ratio: 9/4
	}
}
@media screen and (max-width: 480px) {
	.campaign_main .application_method .element_container .btn img {
		aspect-ratio: 16/6
	}
}
.campaign_main .application_method .element_container .btn1 {
	top: clamp(3.563rem, 1.539rem + 3.95vw, 4.5rem)
}
@media screen and (max-width: 800px) {
	.campaign_main .application_method .element_container .btn1 {
		top: 12.5vw;
		left: 69vw
	}
}
@media screen and (max-width: 480px) {
	.campaign_main .application_method .element_container .btn1 {
		top: 11vw;
		left: 71vw
	}
}
.campaign_main .application_method .element_container .btn2 {
	top: clamp(8.813rem, 1.799rem + 13.68vw, 12.063rem)
}
@media screen and (max-width: 800px) {
	.campaign_main .application_method .element_container .btn2 {
		top: 29vw;
		left: 69vw
	}
}
@media screen and (max-width: 480px) {
	.campaign_main .application_method .element_container .btn2 {
		top: 28vw;
		left: 71vw
	}
}
.campaign_main .application_method .considerations {
	margin-top: 52px;
	padding-bottom: 71px
}
@media screen and (max-width: 1200px) {
	.campaign_main .application_method .considerations {
		margin-top: 66px
	}
}
@media screen and (max-width: 800px) {
	.campaign_main .application_method .considerations {
		margin-top: 84px;
		padding-bottom: 82px
	}
}
@media screen and (max-width: 480px) {
	.campaign_main .application_method .considerations {
		margin-top: 31px;
		padding-bottom: 41px
	}
}
.campaign_main .application_method .considerations .row {
	justify-content: center
}
.campaign_main .application_method .considerations .row .col {
	text-align: center;
	font-weight: bold
}
.campaign_main .application_method .considerations .row .col .title {
	display: inline-block;
	position: relative;
	margin-bottom: 30px;
	font-size: calc(35px + 4*(100vw - 320px)/670);
	letter-spacing: .3em;
	text-align: center;
	color: #707070;
	margin-bottom: 28px
}
.campaign_main .application_method .considerations .row .col .title::before, .campaign_main .application_method .considerations .row .col .title::after {
	content: "";
	position: absolute;
	top: 50%;
	width: 30vw;
	height: 1px;
	background-color: #707070
}
@media screen and (max-width: 480px) {
	.campaign_main .application_method .considerations .row .col .title::before, .campaign_main .application_method .considerations .row .col .title::after {
		width: 20vw
	}
}
.campaign_main .application_method .considerations .row .col .title::before {
	right: 100%;
	margin-right: 10px
}
.campaign_main .application_method .considerations .row .col .title::after {
	left: 100%;
	margin-left: 10px
}
.campaign_main .application_method .considerations .row .col .title span {
	font-weight: bold;
	padding: 0 65px
}
@media screen and (max-width: 800px) {
	.campaign_main .application_method .considerations .row .col .title span {
		padding: 0 11px
	}
}
.campaign_main .application_method .considerations .row .col .list {
	list-style: none;
	margin: 0;
	padding-left: 2em;
	font-size: 20px;
	text-align: left;
	color: #444
}
@media screen and (max-width: 480px) {
	.campaign_main .application_method .considerations .row .col .list {
		font-size: calc(18px + 4*(100vw - 320px)/670)
	}
}
.campaign_main .application_method .considerations .row .col .list li {
	line-height: 1.6
}
.campaign_main .application_method .considerations .row .col .list li:before {
	content: "※";
	display: inline-block;
	width: 1em;
	margin-left: -1em
}
@media screen and (max-width: 480px) {
	.campaign_main .application_method .considerations .row .col .list li {
		line-height: 2
	}
}
.mind {
	background: #f2eadc;
	margin-top: 118px;
	padding-bottom: 50px
}
@media screen and (max-width: 1200px) {
	.mind {
		margin-top: 80px;
		padding-bottom: 35px
	}
}
@media screen and (max-width: 800px) {
	.mind {
		margin-top: 68px;
		padding-bottom: 41px
	}
}
@media screen and (max-width: 480px) {
	.mind {
		margin-top: 0;
		padding-bottom: 0
	}
}
.mind .campaign_main {
	padding-top: 25px
}
@media screen and (max-width: 1200px) {
	.mind .campaign_main {
		padding-top: 18px
	}
}
@media screen and (max-width: 800px) {
	.mind .campaign_main {
		padding-top: 29px
	}
}
@media screen and (max-width: 480px) {
	.mind .campaign_main {
		padding-bottom: 16px
	}
}
.mind .image-title-text-image {
	display: -webkit-flex;
	display: flex;
	-webkit-flex-direction: column;
	flex-direction: column;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center
}
.mind .m-warrp {
	position: relative;
	width: 100%;
	margin-top: 39px
}
@media screen and (max-width: 1200px) {
	.mind .m-warrp {
		margin-top: 10px
	}
}
.mind .m-warrp::before, .mind .m-warrp::after {
	content: "";
	position: absolute;
	top: 50%;
	height: 100%;
	background-size: contain;
	background-repeat: no-repeat;
	transform: translate(-50%, -50%)
}
@media screen and (max-width: 1200px) {
	.mind .m-warrp::before, .mind .m-warrp::after {
		top: 41%
	}
}
@media screen and (max-width: 800px) {
	.mind .m-warrp::before, .mind .m-warrp::after {
		display: none
	}
}
.mind .m-warrp::before {
	margin-left: 10%;
	background-image: url("../images/snscampaign/top_concept_maru_left.svg");
	width: 210px;
	height: 293px;
	object-fit: contain
}
@media screen and (max-width: 1200px) {
	.mind .m-warrp::before {
		width: 239px;
		height: 290px
	}
}
.mind .m-warrp::after {
	margin-right: -10%;
	right: 0;
	background-image: url("../images/snscampaign/top_concept_maru_right.svg");
	width: 210px;
	height: 293px;
	object-fit: contain
}
@media screen and (max-width: 1200px) {
	.mind .m-warrp::after {
		right: -3%;
		width: 239px;
		height: 290px
	}
}
.mind .image {
	flex: 1
}
.mind .title {
	flex: 1;
	font-weight: bold;
	font-size: 41px;
	line-height: 1.6097560976;
	text-align: center;
	color: #825b41;
	margin-bottom: 48px
}
@media screen and (max-width: 1200px) {
	.mind .title {
		margin-bottom: 32px
	}
}
@media screen and (max-width: 800px) {
	.mind .title {
		font-size: 37px;
		line-height: 1.6216216216
	}
}
@media screen and (max-width: 480px) {
	.mind .title {
		font-size: calc(23px + 4*(100vw - 320px)/670);
		margin-bottom: 16px
	}
}
.mind .text {
	flex: 1;
	font-weight: 500;
	font-size: 26px;
	line-height: 50px;
	text-align: center;
	color: #444
}
@media screen and (max-width: 800px) {
	.mind .text {
		font-size: 23px;
		line-height: 44px;
		margin-bottom: 35px
	}
}
@media screen and (max-width: 480px) {
	.mind .text {
		font-size: calc(18px + 4*(100vw - 320px)/670);
		line-height: 2;
		padding-bottom: 0;
		margin-bottom: 9px
	}
}
.mind .image img {
	display: block;
	max-width: 100%;
	height: auto
}
@media screen and (max-width: 1200px) {
	.application {
		padding-top: 75px
	}
}
@media screen and (max-width: 800px) {
	.application {
		padding: 53px 40px 0
	}
}
@media screen and (max-width: 480px) {
	.application {
		padding: 21px 16px 0
	}
}
@media screen and (max-width: 1200px) {
	.application_2 {
		padding-top: 94px
	}
}
@media screen and (max-width: 800px) {
	.application_2 {
		padding-top: 72px
	}
}
.eat {
	background: #f2eadc;
	padding-top: 82px
}
@media screen and (max-width: 800px) {
	.eat {
		padding-top: 49px
	}
}
@media screen and (max-width: 480px) {
	.eat {
		padding-top: 0
	}
}
.eat .campaign_main {
	padding-bottom: 120px
}
@media screen and (max-width: 1200px) {
	.eat .campaign_main {
		padding-top: 100px;
		padding-bottom: 114px
	}
}
@media screen and (max-width: 800px) {
	.eat .campaign_main {
		padding-bottom: 75px
	}
}
@media screen and (max-width: 480px) {
	.eat .campaign_main {
		padding-top: 64px;
		padding-bottom: 36px
	}
}
.eat .eat_titl {
	font-weight: bold;
	font-size: 64px;
	text-align: center;
	color: #825b41;
	position: relative;
	text-align: center
}
@media screen and (max-width: 800px) {
	.eat .eat_titl {
		font-size: 46px
	}
}
@media screen and (max-width: 480px) {
	.eat .eat_titl {
		font-size: calc(25px + 4*(100vw - 320px)/670)
	}
}
.eat .eat_titl:before {
	content: "";
	position: absolute;
	background-repeat: no-repeat;
	background-size: cover;
	top: -10.8333333333vw;
	left: 50%;
	transform: translateX(-50%);
	width: 217px;
	height: 80px;
	background-image: url("../images/snscampaign/mazuha.png")
}
@media screen and (max-width: 1200px) {
	.eat .eat_titl:before {
		top: -16.25vw
	}
}
@media screen and (max-width: 800px) {
	.eat .eat_titl:before {
		top: -12.5vw
	}
}
@media screen and (max-width: 480px) {
	.eat .eat_titl:before {
		width: 21.875vw;
		height: 8.125vw;
		top: -10.4166666667vw
	}
}
.eat_container {
	display: flex;
	justify-content: center;
	margin-top: 64px;
	margin-bottom: 45px
}
@media screen and (max-width: 1200px) {
	.eat_container {
		margin-top: 111px;
		margin-bottom: 64px
	}
}
@media screen and (max-width: 800px) {
	.eat_container {
		margin-top: 40px;
		margin-bottom: 50px
	}
}
.eat .row {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	position: relative
}
@media screen and (max-width: 800px) {
	.eat .row {
		justify-content: center
	}
}
@media screen and (max-width: 800px) {
	.eat .row ul {
		display: none
	}
}
.eat .row ul li:first-child {
	position: absolute;
	top: 11px;
	left: -8%;
	z-index: 3
}
@media screen and (max-width: 1200px) {
	.eat .row ul li:first-child {
		top: -77px;
		left: 2%
	}
}
.eat .row ul li:nth-child(2) {
	position: absolute;
	bottom: -33%;
	right: -9%;
	z-index: 3
}
@media screen and (max-width: 1200px) {
	.eat .row ul li:nth-child(2) {
		right: -3%;
		bottom: -34%
	}
}
.eat .row ul li:last-child {
	position: absolute;
	bottom: -27%;
	left: -7%;
	z-index: 3
}
@media screen and (max-width: 1200px) {
	.eat .row ul li:last-child {
		left: 2%;
		bottom: -29%
	}
}
.eat .col-left {
	flex-basis: 62%;
	margin-right: 20px
}
@media screen and (max-width: 800px) {
	.eat .col-left {
		flex-basis: 75%;
		margin-right: 0
	}
}
.eat .col-right {
	flex-basis: 35%
}
@media screen and (max-width: 800px) {
	.eat .col-right {
		flex-basis: 100%
	}
}
.eat .eat_list {
	position: relative;
	text-align: right
}
@media screen and (max-width: 800px) {
	.eat .eat_list {
		text-align: center;
		margin-top: 17px
	}
}
@media screen and (max-width: 800px) {
	.eat .eat_list img {
		width: 95%
	}
}
.eat .purchase_btn {
	display: inline-block;
	padding: 19px 70px;
	font-weight: bold;
	font-size: 43px;
	letter-spacing: .1em;
	text-align: center;
	color: #fff8f8;
	border-radius: 10px;
	border: 3px solid #405d3b;
	background: #405d3b;
	transition: background-color .3s ease
}
@media screen and (max-width: 1200px) {
	.eat .purchase_btn {
		font-size: calc(25px + 4*(100vw - 320px)/670)
	}
}
@media screen and (max-width: 480px) {
	.eat .purchase_btn {
		padding: 15px;
		font-size: calc(20px + 4*(100vw - 320px)/670)
	}
}
.eat .purchase_btn::after {
	content: "";
	font-family: "Font Awesome 6 Free";
	font-weight: 900;
	color: #fff8f8
}
.eat .purchase_btn:hover {
	color: #405d3b;
	background: #e9ddc7
}
.eat .purchase_btn:hover::after {
	color: #405d3b
}
.eat .center_factor {
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
	width: 57%;
	margin: 0 auto
}
@media screen and (max-width: 800px) {
	.eat .center_factor {
		width: 88%
	}
}
@media screen and (max-width: 480px) {
	.eat .center_factor {
		width: 90%
	}
}
.application_essential_point {
	padding-top: 20px;
	padding-bottom: 207px
}
@media screen and (max-width: 800px) {
	.application_essential_point {
		padding-top: 0;
		padding-bottom: 163px
	}
}
@media screen and (max-width: 480px) {
	.application_essential_point {
		padding-bottom: 50px
	}
}
.application_essential_point .row {
	justify-content: center
}
.application_essential_point .row .col {
	text-align: center;
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
	font-weight: bold
}
.application_essential_point .row .col .title {
	display: inline-block;
	position: relative;
	margin-bottom: 30px;
	font-size: calc(35px + 4*(100vw - 320px)/670);
	letter-spacing: .3em;
	text-align: center;
	color: #707070;
	margin-bottom: 28px
}
.application_essential_point .row .col .title::before, .application_essential_point .row .col .title::after {
	content: "";
	position: absolute;
	top: 50%;
	width: 30vw;
	height: 1px;
	background-color: #707070
}
@media screen and (max-width: 480px) {
	.application_essential_point .row .col .title::before, .application_essential_point .row .col .title::after {
		width: 20vw
	}
}
.application_essential_point .row .col .title::before {
	right: 100%;
	margin-right: 10px
}
.application_essential_point .row .col .title::after {
	left: 100%;
	margin-left: 10px
}
.application_essential_point .row .col .title span {
	font-weight: bold;
	padding: 0 65px
}
@media screen and (max-width: 800px) {
	.application_essential_point .row .col .title span {
		padding: 0 11px
	}
}
.application_essential_point .row .col .campaign-title {
	font-size: 24px;
	font-weight: bold;
	margin-bottom: 20px
}
.application_essential_point .row .col .campaign-info {
	font-size: 20px;
	line-height: 45px;
	text-align: left;
	color: #333
}
@media screen and (max-width: 800px) {
	.application_essential_point .row .col .campaign-info {
		padding: 0 40px
	}
}
@media screen and (max-width: 480px) {
	.application_essential_point .row .col .campaign-info {
		font-size: calc(15px + 4*(100vw - 320px)/670);
		padding: 0;
		line-height: 2
	}
}
.application_essential_point .row .col .campaign-info dt {
	font-weight: bold;
	margin-top: 35px;
	margin-bottom: 1em
}
@media screen and (max-width: 1200px) {
	.application_essential_point .row .col .campaign-info dt {
		margin-top: 29px
	}
}
@media screen and (max-width: 480px) {
	.application_essential_point .row .col .campaign-info dt {
		margin-top: 0
	}
}
.application_essential_point .row .col .campaign-info dd {
	margin-bottom: 20px;
	line-height: 2
}
@media screen and (max-width: 1200px) {
	.application_essential_point .row .col .campaign-info dd {
		line-height: 1.4
	}
}
.application_essential_point .row .col .campaign-info dd ul, .application_essential_point .row .col .campaign-info dd ol {
	margin-top: 10px;
	margin-bottom: 10px;
	list-style-type: disc
}
.application_essential_point .row .col .campaign-info dd ul li, .application_essential_point .row .col .campaign-info dd ol li {
	margin-top: 5px;
	margin-bottom: 5px;
	list-style-type: disc;
	line-height: 45px
}
@media screen and (max-width: 480px) {
	.application_essential_point .row .col .campaign-info dd ul li, .application_essential_point .row .col .campaign-info dd ol li {
		line-height: 2
	}
}
.application_essential_point .row .col .campaign-info dd .custom-list {
	list-style: none
}
.application_essential_point .row .col .campaign-info dd .custom-list li::marker {
	content: "●";
	font-size: 24px
}
@media screen and (max-width: 480px) {
	.application_essential_point .row .col .campaign-info dd .custom-list li::marker {
		font-size: calc(15px + 4*(100vw - 320px)/670)
	}
}
.application_essential_point .row .col .campaign-info dd.ml30 {
	margin-left: 30px
}
.application_essential_point .row .col .campaign-info .attention::marker {
	content: "※";
	font-size: 1em
}
.left-navi {
	position: fixed;
	top: 80px;
	overflow: auto;
	height: 90%;
	-ms-overflow-style: none;
	scrollbar-width: none
}
@media screen and (max-width: 800px) {
	.left-navi {
		display: none
	}
}
.left-navi::-webkit-scrollbar {
	display: none
}
.leftnavi-menu {
	width: 248px;
	padding: 20px 0 127px 0;
	background: #fbf9f4
}
.leftnavi-menu .search-box {
	position: relative;
	width: 200px;
	margin: 50px auto 0 auto
}
.leftnavi-menu .search-box .search_component {
	width: 100%;
	height: 32px;
	display: flex;
	flex-direction: row;
	align-items: center;
	position: relative
}
.leftnavi-menu .search-box .txt {
	font-weight: bold;
	font-size: 20px;
	text-align: center;
	color: #694626;
	margin-top: 32px;
	margin-bottom: 16px
}
.leftnavi-menu .search-box .txt-field {
	width: 100%;
	height: 32px;
	padding: 10px;
	border: 1px solid #333;
	border-radius: 8px 0 0 8px;
	box-sizing: border-box;
	background: #fff;
	color: #333;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 400;
	font-size: 13px;
	text-align: left
}
.leftnavi-menu .search-box .search-btn {
	display: block;
	font-weight: normal;
	font-size: 16px;
	letter-spacing: .1em;
	text-align: center;
	color: #fff;
	width: 35%;
	height: 32px;
	border-radius: 0px 8px 8px 0px;
	background: #1a1a1a;
	border: 1px solid #1a1a1a
}
.leftnavi-menu .menulist {
	margin-top: 32px
}
.leftnavi-menu .menulist li {
	padding: 30px 46px;
	border-bottom: 1px solid #fff
}
.leftnavi-menu .menulist li:hover {
	background: #ffd8d2
}
.leftnavi-menu .menulist li.submenu {
	padding: 11px 46px;
	border-bottom: 0
}
.leftnavi-menu .menulist li.submenu a {
	font-size: 21px;
	padding: 5px 0 5px 9px;
	color: #887268;
	border-left: 6px solid #b49586
}
.leftnavi-menu .deli-estimate {
	overflow: hidden;
	width: 258px;
	margin: 83px auto 45px auto;
	border-radius: 10px;
	background: #fff;
	text-align: center
}
.leftnavi-menu .deli-estimate .txt {
	padding: 9px;
	background: #b49586;
	color: #fff;
	font-size: 15px
}
.leftnavi-menu .deli-estimate .blk {
	display: block;
	padding: 0 33px;
	font-size: 14px;
	line-height: 1.5
}
.leftnavi-menu .deli-estimate .type {
	display: block;
	font-size: 18px;
	line-height: 1.5;
	padding-top: 10px
}
.leftnavi-menu .deli-estimate .days {
	display: block;
	color: #887268;
	font-weight: 500;
	font-size: 22px;
	line-height: 1.5
}
.leftnavi-menu .deli-estimate .remark {
	padding: 10px 0 20px 0;
	font-size: 12px;
	line-height: 1.5
}
.leftnavi-menu .follow {
	width: 230px;
	margin: 0 auto;
	padding: 0 9px
}
.leftnavi-menu .follow .txt {
	font-size: 24px;
	text-align: center
}
.leftnavi-menu .follow .list {
	margin: 26px auto 18px auto
}
.leftnavi-menu .follow .list img {
	width: 83px
}
.categorymenu h2 {
	font-weight: bold;
	font-size: 20px;
	text-align: center;
	color: #694626;
	margin-top: 32px;
	margin-bottom: 16px
}
.accordion {
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 40px;
	max-width: 180px;
	position: relative;
	width: 100%
}
.accordion-title02 a {
	display: -webkit-flex;
	display: flex;
	-webkit-align-items: center;
	align-items: center;
	font-weight: 500;
	font-size: 14px;
	text-align: left;
	color: #1a1a1a;
	cursor: pointer;
	padding: 16px 24px 16px 0;
	position: relative;
	border-bottom: .5px solid #000;
	height: 45px;
	transition: color .3s ease-in-out, background .3s ease-in-out
}
.accordion-title02 a::after {
	border-right: solid 1px #575757;
	border-top: solid 1px #575757;
	content: "";
	display: block;
	width: 10px;
	height: 10px;
	position: absolute;
	right: .5em;
	top: 45%;
	transform: rotate(45deg);
	transition: transform .3s ease-in-out, top .3s ease-in-out, right .3s ease-in-out
}
.accordion-title02 a:hover {
	color: #7a7a7a;
	background: #e9e9e9
}
.accordion-title02 a:hover::after {
	border-right: solid 1px #7a7a7a;
	border-top: solid 1px #7a7a7a;
	right: 1.5em
}
.accordion-content {
	display: none;
	padding: 0
}
.accordion-content li .button02 {
	position: relative;
	display: inline-block;
	width: 100%;
	text-decoration: none;
	font-weight: 500;
	font-size: 12px;
	letter-spacing: .08em;
	line-height: 29px;
	text-align: left;
	color: #272020;
	padding: 9px 24px 9px 0
}
.accordion-content li .button02::after {
	position: absolute;
	top: 50%;
	right: .5em;
	content: "";
	margin-top: -5px;
	border-right: solid 1px #575757;
	border-top: solid 1px #575757;
	width: 10px;
	height: 10px;
	transition: all .2s;
	transform: rotateZ(45deg)
}
.accordion-content li .button02:hover {
	color: #7a7a7a
}
.accordion-content li .button02:hover::after {
	right: 1.5em
}
.accordion-item h3 {
	background: rgba(0, 0, 0, 0);
	padding: 5px 24px
}
.accordion-item02 {
	cursor: pointer;
	font-weight: 500;
	font-size: 13px;
	letter-spacing: .08em;
	line-height: 29px;
	text-align: left;
	color: #272020;
	position: relative;
	border-bottom: .5px solid #000
}
.accordion-item02:hover {
	color: #7a7a7a
}
.sec-hero {
	margin-top: 145px
}
@media screen and (min-width: 1500px) {
	.sec-hero {
		margin-top: 99px
	}
}
@media screen and (max-width: 1200px) {
	.sec-hero {
		margin-top: 91px
	}
}
.sec-hero .grid-container {
	display: grid;
	grid-template-columns: .8fr 1.2fr;
	grid-gap: 0
}
@media screen and (max-width: 1200px) {
	.sec-hero .grid-container {
		grid-template-columns: 1fr
	}
}
.sec-hero .grid-item {
	box-sizing: border-box;
	max-height: 800px
}
.sec-hero .grid-item img {
	width: 100%;
	height: 100%;
	object-fit: cover
}
.sec-hero .grid-item:nth-child(1) {
	background: #e8b2a5
}
@media screen and (max-width: 1200px) {
	.sec-hero .grid-item:nth-child(1) {
		grid-column: 1/span 1;
		grid-row: 2/span 1
	}
}
@media screen and (max-width: 1200px) {
	.sec-hero .grid-item:nth-child(2) {
		grid-column: 1/span 1;
		grid-row: 1/span 1
	}
}
@media screen and (max-width: 1200px)and (min-width: 1920px) {
	.sec-hero .grid-item:nth-child(2) {
		max-width: 1170px
	}
} /*# sourceMappingURL=style.min.css.map */