@charset "UTF-8";
/*
Theme Name: DOMORI
Description: DOMORI
Version: 2021.09
Author: YH
*/

/* ------------------------------------------
   Reset
------------------------------------------ */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-style: normal;
  font-weight: normal;
  font-size: 100%;
  vertical-align: baseline; }

* {
  outline: none; }

body {
  line-height: 1; }

h1, h2, h3, h4, h5, h6 {
  font-weight: normal; }

ol, ul {
  list-style: none; }

blockquote {
  quotes: none; }

blockquote:before, blockquote:after {
  content: '';
  content: none; }

del {
  text-decoration: line-through; }

/* tables still need 'cellspacing="0"' in the markup */
table {
  border-collapse: collapse;
  border-spacing: 0; }

caption, th {
  text-align: left; }

a:focus {
  outline: none; }

a img {
  border: none; }

input, button, select, textarea {
  border-radius: 0; }

@media screen and (max-width: 767px) {
  input, button, select, textarea {
  }
}

/* ------------------------------------------
   Utility Class
------------------------------------------ */
.clearfix::after {
	content: ".";
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
}

/*
Web Fonts

font-family: 'Noto Sans JP', sans-serif;
font-family: 'Noto Serif JP', serif;

font-family: semplicitapro,sans-serif;
font-weight: 500;
font-style: normal;

font-family: semplicitapro,sans-serif;
font-weight: 600;
font-style: normal;

font-family: sorts-mill-goudy, serif;
font-weight: 500;
font-style: normal;
*/

/* Style
-------------------------------------------------------------- */
body {
	height: 100%;
	font-size: 16px;
	line-height: 2em;
  letter-spacing: 0.05em;
	color: #0B0E12;
	-webkit-text-size-adjust: none;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 500;
	transition: opacity 0.6s ease;
	-webkit-print-color-adjust: exact;
	opacity: 0;
}
body.show {
	opacity: 1;
}
body p {
  color: inherit;
  font-size: inherit;
  line-height: 2em; }

a, a img {
  text-decoration: none;
  font-weight: 500;
  color: #0B0E12;
  transition: all 0.3s ease }

.pc_view a:hover {
	opacity: 0.75;
}

span {
	font-size: inherit;
	font-weight: inherit;
	color: inherit;
}
img {
  display: block;
  max-width: 100%;
  height: auto; }

h1, h2, h3, h4, h5, h6 {
  line-height: inherit; }

.non_pc {
  display: none !important; }

.f_min {
  font-family: 'Noto Serif JP', serif;
  letter-spacing: 0.1em;
}
.f_en {
  font-family: sorts-mill-goudy, serif;
  font-weight: 500;
  font-style: normal;
	letter-spacing: 0.1em;
}
.f_en2 {
  font-family: semplicitapro,sans-serif;
  font-weight: 500;
  font-style: normal;
	letter-spacing: 0.1em;
}

/* ===========================================================================================

	Common

=========================================================================================== */
.outline {
  position: relative;
  min-width: 980px;
  /* max-width: 1920px; */
  overflow: hidden;
  margin: 0 auto;
}
.main {
  z-index: 100;
  margin: 0 auto;
  position: relative;
  transition: opacity 0.3s ease;
  z-index: 100;
  /* overflow: hidden; */
}


/* Header *******************************/
header {
	position: absolute;
	width: 100%;
	left: 0;
	height: 123px;
	z-index: 10000;
	top: 0;
	transition: background 0.3s ease;
}
header > .inner {
	display: flex;
	justify-content: space-between;
	align-items: start;
	max-width: 1440px;
	margin: 0 auto;
}
header h1 {
	width: 144px;
}
header .gmenu {
	margin-right: 4%;
}
.pc_view header .gmenu {
	opacity: 1 !important;
	display: block !important;
} 
header .gmenu ul {
	display: flex;
	margin-top: 38px;
}
header .gmenu ul li:last-child {
	margin-left: 20px;
}
header .gmenu ul li a {
	display: block;
	font-size: 18px;
	letter-spacing: 0.2em;
	line-height: 46px;
	padding: 0 15px;
	box-sizing: border-box;
	text-indent: 0.2em;
}
header .gmenu ul li a.current {
	color: #92193a;
}
header .gmenu ul li a.bt_contact {
	background: #92193a;
	color: #fff;
	width: 150px;
	text-align: center;
	position: relative;
}
header .gmenu ul li a.bt_contact::before {
	position: absolute;
	display: block;
	content: "";
	width: 10px;
	height: 10px;
	background: #e4cb76;
	right: 0;
	bottom: 0;
}
header.fixed {
	background: #fff;
	position: fixed;
	height: 78px;
}
header.fixed h1 {
	width: 91px;
}
header.fixed .gmenu {
	margin-right: 2%;
}
header.fixed .gmenu ul {
	margin-top: 16px;
}


/* Footer *******************************/
footer {
	background: url(../images/bg_footer.png) no-repeat center bottom,  url(../images/index/img_footer.jpg) no-repeat center center;
	background-size: auto 350px, 100% auto;
	height: 810px;
	position: relative;
	box-sizing: border-box;
	padding-top: 660px;
	z-index: 100;
	margin: 0 auto;
	text-align: center;
}
#inner.about footer {
	background: url(../images/bg_footer.png) no-repeat center bottom,  url(../images/about/img_footer.jpg) no-repeat center center;
	background-size: auto 350px, 100% auto;
}
#inner.story footer {
	background: url(../images/bg_footer.png) no-repeat center bottom,  url(../images/story/img_footer.jpg) no-repeat center center;
	background-size: auto 350px, 100% auto;
}
#inner.quality footer {
	background: url(../images/bg_footer.png) no-repeat center bottom,  url(../images/quality/img_footer.jpg) no-repeat center center;
	background-size: auto 350px, 100% auto;
}
#inner.product footer {
	background: url(../images/bg_footer.png) no-repeat center bottom,  url(../images/product/img_footer.jpg) no-repeat center center;
	background-size: auto 350px, 100% auto;
}
footer .gmenu ul {
	display: flex;
	justify-content: center;
	position: relative;
}
footer .gmenu ul li a {
	display: block;
	font-size: 18px;
	letter-spacing: 0.2em;
	line-height: 46px;
	padding: 0 15px;
	box-sizing: border-box;
	text-indent: 0.2em;
}
footer .gmenu ul li a.current {
	color: #92193a;
}
/*
footer .gmenu ul li:last-child {
	margin-left: 20px;
	position: absolute;
	width: 24px;
	height: 24px;
	margin: 0;
	left: 50%;
	top: 12px;
	margin-left: 390px;
}
footer .gmenu ul li:last-child a {
	width: 24px;
	height: 24px;
	padding: 0;
}
*/
footer .pp {
	display: inline-block;
	font-size: 14px;
	margin-top: 18px;
}
footer .copyright {
	text-align: center;
	font-size: 11px;
	line-height: 2em;
	margin-top: 5px;
}
footer .bt_pagetop {
	display: block;
	position: absolute;
	width: 110px;
	height: 110px;
	bottom: 0;
	right: 0;
	text-indent: -9999px;
	overflow: hidden;
	transition: none;
	background: #92193a;
	z-index: 100;
	transition: all ease 0.3s;
}
footer .bt_pagetop:hover {
	opacity: 1;
	background: #bf3358;
}
footer .bt_pagetop::after {
	display: block;
	position: absolute;
	width: 30px;
	height: 30px;
	left: 50%;
	top: 45px;
	content: "";
	border-top: 2px solid #E4CB76;
	border-right: 2px solid #E4CB76;
	margin: 0 0 0 -16px;
	transform: rotate(-45deg);
}

/* ===========================================================================================

  Index

=========================================================================================== */


/* Visual *********************************/
#index .visual {
	height: 640px;
	box-sizing: border-box;
	padding-top: 10px;
	margin-bottom: 440px;
	position: relative;
}
#index .visual .slider {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}
#index .visual .slider .slick-track,
#index .visual .slider .slick-list {
	height: 100%;
}
#index .visual .slider .slick-slide {
	background: url(../images/index/img_visual.jpg) no-repeat center center;
	transition: background-size 3s ease;
	background-size: 105% auto;
}
#index .visual .slider .slide2 {
	background-image: url(../images/index/img_visual2.jpg);
}
#index .visual .slider .slide3 {
	background-image: url(../images/index/img_visual3.jpg);
}
#index .visual.active .slider .slick-slide {
	background-size: 100% auto;
}
@media screen and (max-width: 1440px) {
    #index .visual .slider .slick-slide {
		background-size: auto 110%;
	}
    #index .visual.active .slider .slick-slide {
		background-size: auto 100%;
	}
}

#index .visual > .inner {
	width: 1080px;
	margin: 0 auto;
	margin-top: 440px;
	position: relative;
}
#index .visual > .inner::before {
	display: block;
	position: absolute;
	content: "Scroll Down";
	font-family: semplicitapro,sans-serif;
	font-weight: 500;
	font-style: normal;
	letter-spacing: 0.2em;
	font-size: 13px;
	line-height: 1em;
	transform: rotate(90deg);
	transform-origin: 0 0;
	left: -100px;
	top: 25px;
}
#index .visual > .inner::after {
	display: block;
	content: "";
	position: absolute;
	width: 1px;
	height: 200px;
	background: #92193a;
	left: -108px;
	top: 150px;
}
#index .visual .copy {
	font-size: 100px;
	line-height: 1.2em;
	transition: left ease 1.5s, opacity ease 1.5s;
	left: 20px;
	opacity: 0;
	position: relative;
}
#index .visual.active .copy {
	left: 0px;
	opacity: 1;
}
#index .visual .copy2 {
	margin-top: 34px;
	position: relative;
	display: inline-block;
}
#index .visual .copy2::before {
	display: block;
	content: "";
	position: absolute;
	width: 0;
	height: 100%;
	background: #92193a;
	transition: width ease 1.5s +0.6s;
}
#index .visual.active .copy2::before {
	width: 100%;
}
#index .visual .copy2 span {
	display: inline-block;
	position: relative;
	z-index: 100;
	font-size: 46px;
	line-height: 90px;
	padding: 0 15px 0 20px;
	color: #fff;
	position: relative;
	top: -4px;
	letter-spacing: 0.13em;
}


/* Sec *********************************/
.main .sec > .inner {
	width: 1080px;
	margin: 0 auto;    
	position: relative;
}
.main .sec > .inner::after {
	position: absolute;
	content: "";
	display: block;
	background: #F3F1EE;
	width: 210px;
	height: 525px;
	top: 115px;
	right: 0px;
}
.main .sec .bg {
	position: absolute;
	display: flex;
	align-items: start;
	top: 188px;
	left: -180px;
}
.main .sec h2,
.main .sec h3 {
	font-size: 120px;
	position: relative;
	color: #921a3a;
	line-height: 1em;
}
#index .main .sec h2 {	
	transition: ease opacity 1.5s, ease filter 1.5s;
	opacity: 0;
	filter: blur(10px);
}
#index .main .sec.active h2 {
	opacity: 1;
	filter: blur(0px);
}
.main .sec h2 span,
.main .sec h3 span {
	display: block;
	color: #E4CB76;
	line-height: 1em;
	margin-left: 140px;
	margin-top: 10px;
}
.main .sec .info {
	position: relative;
	margin-left: 600px;
	z-index: 100;
	margin-top: 20px;
}
.main .sec .info .title {
	font-size: 46px;
	font-weight: bold;
	letter-spacing: 0.12em;
}
.main .sec .info .text {
	width: 105%;
	margin-top: 10px;
	font-size: 18px;
	line-height: 3em;
	letter-spacing: 0em;
}
.main .sec .info .text.f_en2 {
	width: 105%;
	margin-top: 30px;
	font-size: 18px;
	line-height: 2em;
	letter-spacing: 0.1em;
}
.main .sec .bt_more {
	font-size: 24px;
	font-weight: bold;
	width: 285px;
	display: block;
	margin-top: 37px;
	background: url(../images/icon_arrow.png) no-repeat right center;
	background-size: 96px auto;
	line-height: 40px;
	letter-spacing: 0.2em;
}
#index .main .sec > .inner::after {
	display: none;
}
#index .obj.rect {
	position: absolute;
	content: "";
	display: block;
	background: #F3F1EE;
	width: 210px;
	height: 525px;
	top: 115px;
	right: 0px;
}
/* About *****/
#index .about {

}
#index .about .obj.cacao {
	position: absolute;
	content: "";
	display: block;
	background: url(../images/index/img_cacao.png) no-repeat right center;
	background-size: 100% auto;
	width: 373px;
	height: 533px;
	top: -341px;
	right: -125px;
	z-index: 10;
}
#index .about .bg img {
	width: 210px;
	margin-right: 2px;
	transition: ease all 1.5s;
	opacity: 0;
	top: -30px;
	position: relative;
}
#index .about .bg img:nth-child(1) {
	margin-top: 80px;
	top: 30px;
}
#index .about .bg img:nth-child(3) {
	margin-top: 196px;
	top: 30px;
}
#index .about.active .bg img {
	opacity: 1;
	top: 0;
}

/* Story *****/
#index .story {
	margin-top: 100px;
}
#index .story .obj.rect {
	width: 1080px;
	height: 690px;
	top: 245px;
	right: auto;
	left: -180px;
}
#index .story .info {
	margin-left: 0;
	margin-top: 15px;
}
#index .story .bg {
	width: 680px;
	left: auto;
	top: 60px;
	right: -180px;
	z-index: 50;
	transition: ease all 1.5s;
	opacity: 0;
	top: 30px;
}
#index .story.active .bg {
	top: 0;
	opacity: 1;
}
#index .story .bg::before {
	position: absolute;
	content: "";
	display: block;
	background: url(../images/index/txt_story.png) no-repeat right center;
	background-size: 100% auto;
	width: 408px;
	height: 243px;
	bottom: -170px;
	left: 85px;
	z-index: 10;
}
#index .story .bg img {
	width: 100%;
}
#index .story .info .title {
	letter-spacing: -0.15em;
}
#index .story .info .text {
	margin-top: 50px;
} 
#index .story .info .text.f_en2 {
	margin-top: 30px;
} 

/* Quality *****/
#index .quality {
	margin-top: 180px;
}
#index .quality .obj.rect {
	top: 45px;
}
#index .quality .bg {
	width: 680px;
	left: -180px;
	transition: ease all 1.5s;
	opacity: 0;
	top: 218px;
}
#index .quality.active .bg {
	top: 188px;
	opacity: 1;
}
#index .quality .info::before {
	position: absolute;
	content: "";
	display: block;
	background: url(../images/index/img_quality_more.jpg) no-repeat right center;
	background-size: 100% auto;
	width: 360px;
	height: 220px;
	bottom: -183px;
	right: -180px;
	z-index: 10;
}
#index .quality .bg img {
	width: 100%;
}
#index .quality .info {
	margin-left: 560px;
}
#index .quality .info .title {
	letter-spacing: 0.3em;
}

/* Product *****/
#index .product {
	margin-top: 195px;
}
#index .product  .obj.rect {
	width: 1080px;
	height: 1164px;
	top: 60px;
	right: -180px;
}
#index .product h2 {
	z-index: 50;
}
#index .product .info {
	margin-left: 0;
	margin-top: 15px;
}
#index .product .bg {
	width: 1345px;
	top: 545px;
	left: 0px;
	z-index: 50;
	display: flex;
	justify-content: space-between;
}
#index .product .bg img {
	width: 415px;
	transition: ease all 1.5s;
	opacity: 0;
	top: 30px;
	position: relative;
}
#index .product .bg.active img {
	top: 0;
	opacity: 1;
}
#index .product .bg.active img:nth-child(2) {
	transition-delay: 0.3s;
}
#index .product .bg.active img:nth-child(3) {
	transition-delay: 0.6s;
}
#index .product .info .title {
	letter-spacing: 0.3em;
}
#index .product .info .text.f_en2 {
	margin-bottom: 635px;
} 

/* Voice *********************************/
#index .voice {
	margin-top: 100px;
	padding-top: 70px;
}
#index .voice > .inner {
	position: relative;
	padding: 85px 0 90px 0;
	background: url(../images/bg_pattern.jpg) repeat center top;
	background-size: 512px auto;
}
#index .voice h2 {
	text-align: center;
	font-size: 60px;
	letter-spacing: 0.2em;
	text-indent: 0.2em;
	line-height: 1em;
}
#index .voice .info {
	width: 960px;
	margin: 55px auto 0 auto;
}
#index .voice .face {
	width: 820px;
	margin: 0 auto 0 auto;
	position: relative;
	left: 55px;
	transition: ease all 1.5s;
	opacity: 0;
	top: 15px;
}
#index .voice.active .face {
	top: 0;
	opacity: 1;
}
#index .voice .text {
	margin-top: 50px;
	font-size: 18px;
	column-count: 2;
	column-gap: 2em;
	text-align: justify;
}
#index .voice .photo {
	margin-top: 50px;
	transition: ease all 1.5s;
	opacity: 0;
	top: 15px;
	position: relative;
}
#index .voice .photo.active {
	top: 0;
	opacity: 1;
}

/* Contact *********************************/
#index .contact {
	padding-top: 150px;
	margin-top: -50px;
}
#index .contact > .inner {
	width: 960px;
	margin: 0 auto;
	position: relative;
	text-align: center;
	padding-bottom: 90px;
}
#index .contact > .inner::before {
	position: absolute;
	content: "";
	display: block;
	background: url(../images/img_footer.png) no-repeat right center;
	background-size: 100% auto;
	width: 900px;
	height: 600px;
	bottom: -333px;
	right: -450px;
	z-index: 10;
}
#index .contact h2 {
	font-size: 60px;
	letter-spacing: 0.2em;
	text-indent: 0.2em;
	line-height: 1em;
}
#index .contact .lead {
	font-size: 18px;
	margin-top: 45px;
	position: relative;
	z-index: 10;
}
#index .contact a {
	display: inline-block;
	font-size: 28px;
	margin-top: 50px;
	position: relative;
	z-index: 10;
}
#index .contact a span {
	display: inline-block;
	margin-left: 115px;
	position: relative;
}
#index .contact a span::before {
	display: block;
	content: "";
	position: absolute;
	width: 78px;
	height: 1px;
	bottom: 3px;
	left: -98px; 
	background: #92193a;
}



/* ===========================================================================================

  Inner

=========================================================================================== */
#inner .main {
	position: relative;
}
#inner header .gmenu ul li a {
	color: #fff;
}
#inner.product header .gmenu ul li a,
#inner header.fixed .gmenu ul li a {
	color: #0B0E12;
}
#inner.product header .gmenu ul li a.bt_contact,
#inner header.fixed .gmenu ul li a.bt_contact {
	color: #fff;
}
#inner header .gmenu ul li a.current {
	color: #921a3a;
}
#inner .main .sec .info {
	margin-left: 560px;
}
#inner .main .sec .info .text {
	width: 105%;
	margin-top: 10px;
	font-size: 18px;
	line-height: 2.2em;
}

/* Visual *********************************/
#inner .visual {
	box-sizing: border-box;
	padding-top: 10px;
	margin-bottom: 40px;
	position: relative;
}
#inner .visual::after {
	position: absolute;
	content: "";
	display: block;
	background: url(../images/index/img_cacao.png) no-repeat right center;
	background-size: 100% auto;
	width: 373px;
	height: 533px;
	z-index: 100;
	top: 735px;
	left: 50%;
	margin-left: 290px;
}
#inner .visual .bg {
	position: absolute;
	width: calc(100% - 340px);
	left: 50%;
	margin-left: -380px;
	min-width: 1100px;
	top: 0;
	height: 826px;
	overflow: hidden;
	background: #000;
}
#inner.quality .visual .bg {
	background: #D1C5C5;
}
#inner.product .visual .bg {
	background: #F9FBFE;
}
#inner .visual .bg::before {
	display: block;
	content: "";
	position: absolute;
	background: url(../images/bg_inner_visual.png) no-repeat top left;
	background-size: 100% auto;
	width: 2814px;
	height: 267px;
	bottom: -42px;
	left: 0;
	z-index: 100;
}
#inner .visual .bg img {
	position: relative;
	top: 50%;
	transform: translate(0, -50%);
	width: 100%;
	max-width: 1340px;
}
#inner .visual > .inner {
	width: 1080px;
	margin: 0 auto;
	padding-top: 670px;
	position: relative;
}
#inner.story .visual > .inner {
	padding-top: 488px;
}
#inner.quality .visual > .inner {
	padding-top: 582px;
}
#inner.product .visual > .inner {
	padding-top: 597px;
}
#inner .visual > .inner::before {
	display: block;
	position: absolute;
	content: "Scroll Down";
	font-family: semplicitapro,sans-serif;
	font-weight: 500;
	font-style: normal;
	letter-spacing: 0.2em;
	font-size: 13px;
	line-height: 1em;
	transform: rotate(90deg);
	transform-origin: 0 0;
	left: -100px;
	top: 455px;
}
#inner .visual > .inner::after {
	display: block;
	content: "";
	position: absolute;
	width: 1px;
	height: 200px;
	background: #92193a;
	left: -108px;
	top: 580px;
}
#inner .visual h2 {
	position: absolute;
	font-size: 120px;
	line-height: 1em;
	color: #921a3a;
	transform: rotate(90deg);
	transform-origin: 0% 100%;
	left: 8px;
	top: -128px;
	z-index: 200;
	width: 800px;
}
#inner.about .visual h2 {
	letter-spacing: 0;
}
#inner.story .visual h2 {
	top: 0px;
}
#inner.quality .visual h2 {
	top: -120px;
	letter-spacing: 0.05em;
}
#inner.product .visual h2 {
	top: 0px;
	letter-spacing: 0.05em;
}
#inner .visual .copy {
	margin-top: 10px;
	position: relative;
	display: inline-block;
	z-index: 200;
}
#inner .visual .copy::before {
	display: block;
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	background: #92193a;
}
#inner .visual .copy span {
	display: inline-block;
	position: relative;
	z-index: 100;
	font-size: 46px;
	line-height: 90px;
	padding: 0 15px 0 20px;
	color: #fff;
	position: relative;
	top: -4px;
	letter-spacing: 0.13em;
}
#inner.quality .visual .copy span {
	letter-spacing: 0.2em;
}
#inner .visual .text {
	position: relative;
	z-index: 200;
	font-size: 18px;
	line-height: 3em;
	margin-top: 45px;
}

#inner .submenu {
	width: 1080px;
	margin: 0 auto;
	height: 90px;    
}
#inner .submenu ul {
	display: flex;
	padding: 34px 0;
	float: left;
	position: relative;
}
#inner .submenu ul::before {
	display: block;
	content: "";
	position: absolute;
	height: 100%;
	width: 5000px;
	background: #921a3a;
	right: 0;
	top: 0;
}
#inner .submenu ul li {
	border-left: 1px solid #fff;
	position: relative;
	z-index: 
}
#inner .submenu ul li:first-child {
	border-left: none;
}
#inner .submenu ul li a {
	font-size: 22px;
	padding: 0 70px;
	display: block;
	line-height: 1em;
	color: #fff;
}
#inner .submenu ul li:first-child a {
	padding-left: 40px;
}
#inner.quality .submenu ul li a {
	padding: 0 100px;
}
#inner.quality .submenu ul li:first-child a {
	padding-left: 100px;
}

/* About *********************************/
#inner.about .founding {
	padding-top: 80px;
	padding-bottom: 580px;
}
#inner.about .founding > .inner {
	position: relative;
}
#inner.about .founding > .inner::after {
	position: absolute;
	content: "";
	display: block;
	background: #F3F1EE;
	width: 1080px;
	height: 800px;
	top: 385px;
	right: -180px;
	z-index: -1;
}
#inner.about .founding .bg img:nth-child(1) {
	width: 680px;
}
#inner.about .founding .bg img:nth-child(2) {
	position: absolute;
	width: 460px;
	top: 894px;
	left: 80px;
}
#inner.about .founding .bg img:nth-child(3) {
	position: absolute;
	width: 415px;
	top: 742px;
	left: 120%;
}
#inner.about .founding .info .text {
	margin-top: 60px;
}

#inner.about .history {
	padding-top: 80px;
	padding-bottom: 50px;
}
#inner.about .history .bg {
	right: -180px;
	left: auto;
	width: 680px;
	top: 50px;
}
#inner.about .history .info {
	margin-left: 0;
}
#inner.about .history > .inner::after {
	position: absolute;
	content: "";
	display: block;
	background: #F3F1EE;
	width: 900px;
	height: 740px;
	top: 265px;
	left: -180px;
	right: auto;
	z-index: 0;
}
#inner.about .history dl {
	margin-top: 85px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	position: relative;
}
#inner.about .history dl::before {
	display: block;
	content: "";
	position: absolute;
	width: 2px;
	height: 98%;
	top: 1%;
	left: 44px;
	background: #92193a;
}
#inner.about .history dl dt {
	width: 86px;
	line-height: 86px;
	border: 2px solid #92193a;
	text-align: center;
	font-size: 16px;
	font-family: 'Noto Serif JP', serif;
	letter-spacing: 0.1em;
	color: #92193a;
	font-weight: bold;
	border-radius: 100px;
	margin-top: 20px;
	background: #f3f1ed;
	position: relative;
}
#inner.about .history dl dd {
	width: calc(100% - 120px);
	font-size: 18px;
	margin-top: 18px;
	line-height: 1.6em;
	letter-spacing: 0;
}
#inner.about .history dl dt:first-child,
#inner.about .history dl dt:first-child + dd {
	margin-top: 0;
}

#inner.about .award {
	padding-top: 80px;
	padding-bottom: 60px;
	margin-top: 40px;
	position: relative;
}
#inner.about .award::after {
	position: absolute;
	content: "";
	display: block;
	background: url(../images/img_footer.png) no-repeat right center;
	background-size: 100% auto;
	width: 900px;
	height: 600px;
	top: 11px;
	left: 50%;
	z-index: 10;
	margin-left: -15px
}
#inner.about .award::before {
	display: block;
	content: "";
	position: absolute;
	width: 100%;
	height: calc(100% - 320px);
	top: 320px;
	background: url(../images/bg_pattern2.png) repeat center top;
	background-size: 60px auto;
	z-index: 50;
}
#inner.about .award > .inner::after {
	display: none;
}
#inner.about .award .info {
	margin: 0;
}
#inner.about .award .info dl {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: start;
	position: relative;
	width: 960px;
	margin: 90px auto 0 auto;
}
#inner.about .award .info dl dt {
	font-family: 'Noto Serif JP', serif;
	letter-spacing: 0.1em;
	font-size: 30px;
	font-weight: bold;
	color: #F3F1EE;
	line-height: 60px;
	margin-top: 25px;
	position: relative;
}
#inner.about .award .info dl dt::before {
	display: block;
	position: absolute;
	content: "";
	width: 56px;
	height: 1px;
	background: #fff;
	transform: rotate(-45deg);
	left: 90px;
	top: 30px;
}
#inner.about .award .info dl dd {
	width: 800px;
	font-size: 18px;
	margin-top: 25px;
	line-height: 1.6em;
	letter-spacing: 0;
}
#inner.about .award .info dl dd p {
	background: #F3F1EE;
	padding: 12px 20px;
	margin-top: 10px;
}
#inner.about .award .info dl dd p:first-child {
	margin-top: 0;
}
#inner.about .award dl dt:first-child,
#inner.about .award dl dt:first-child + dd {
	margin-top: 0;
}
#inner.about .award .info dl .hide {
	display: none;
}
#inner.about .award .bt_more {
	margin: 50px 0 0 220px;
	color: #fff;
	background-image: url(../images/icon_arrow2.png);
}


/* Story *********************************/
#inner.story .gianluca {
	padding-top: 80px;
	padding-bottom: 136px;
}
#inner.story .gianluca > .inner {
	position: relative;
}
#inner.story .gianluca > .inner::after {
	position: absolute;
	content: "";
	display: block;
	background: #F3F1EE;
	width: 1080px;
	height: 860px;
	top: 385px;
	right: -180px;
	z-index: -1;
}
#inner.story .visual .bg::after {
	position: absolute;
	content: "";
	display: block;
	background: url(../images/story/txt_name.png) no-repeat right center;
	background-size: 100% auto;
	width: 377px;
	height: 80px;
	bottom: 219px;
	left: 50%;
	margin-left: -15px;
}
#inner.story .gianluca .bg img:nth-child(1) {
	width: 680px;
}
#inner.story .gianluca .bg img:nth-child(2) {
	position: absolute;
	width: 460px;
	top: 930px;
	left: 80px;
}
#inner.story .gianluca .info .text {
	margin-top: 60px;
	letter-spacing: -0.02em;
}
#inner.story .philosophy {
	padding-top: 80px;
	padding-bottom: 230px;
	margin-top: -45px;
}
#inner.story .philosophy::before {
	position: absolute;
	content: "";
	display: block;
	background: url(../images/img_footer.png) no-repeat right center;
	background-size: 100% auto;
	width: 900px;
	height: 600px;
	bottom: -391px;
	left: 50%;
	margin-left: -15px;
}
#inner.story .philosophy h3 {
	margin: 0 0 0 400px;
}
#inner.story .philosophy h3 span {
	margin-left: -138px;
}
#inner.story .philosophy .bg {
	right: -180px;
	left: auto;
	width: 680px;
	top: 188px;
}
#inner.story .philosophy .bg img:nth-child(2) {
	position: absolute;
	width: 340px;
	top: 605px;
	left: 259px;
}
#inner.story .philosophy .info {
	margin-left: 0;
}
#inner.story .philosophy > .inner::after {
	position: absolute;
	content: "";
	display: block;
	background: #F3F1EE;
	width: 960px;
	height: 505px;
	top: 637px;
	left: -180px;
	right: auto;
	z-index: 0;
}
#inner.story .philosophy .lead {
	margin-top: 20px;
}
#inner.story .philosophy .lead .line {
	margin-top: 10px;
	position: relative;
	display: inline-block;
	z-index: 200;
}
#inner.story .philosophy .lead .line::before {
	display: block;
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	background: #92193a;
}
#inner.story .philosophy .lead .line span {
	display: inline-block;
	position: relative;
	z-index: 100;
	font-size: 46px;
	line-height: 90px;
	padding: 0 15px 0 20px;
	color: #fff;
	position: relative;
	top: -4px;
	letter-spacing: 0.13em;
}
#inner.story .philosophy .info .text {
	width: 720px;
	margin-top: 35px;
}

/* Quality *********************************/
#inner.quality .sec .hbox {
	position: relative;
}
#inner.quality .sec .hbox:before {
	position: absolute;
	display: block;
	content: "";
	width: 1100px;
	height: 460px;
	background: url(../images/quality/img_recipe1.jpg?v=1) no-repeat center center;
	background-size: cover;
	left: 160px;
	top: 68px;
}
#inner.quality .sec .hbox .title {
	width: 300px;
	line-height: 300px;
	background: #921a3a;
	color: #fff;
	text-align: center;
	font-size: 46px;
	letter-spacing: 0.4em;
	text-indent: 0.4em;
	position: relative;
	margin-top: 100px;
}
#inner.quality .recipe .hbox .title {
	margin-top: 108px;
}
#inner.quality .sec .hbox .title:before {
	position: absolute;
	display: block;
	content: "";
	width: 30px;
	height: 30px;
	left: 100%;
	top: 100%;
	background:#e4cb76;
}
#inner.quality .sec > .inner::after {
	display: none;
}
#inner.quality .sec .info {
	margin-left: 0;
}
#inner.quality .sec .info .text {
	margin-top: 50px;
	width: auto;
}
#inner.quality .recipe {
	padding-top: 80px;
}
#inner.quality .recipe h3 span {
	margin-left: 0;
}
#inner.quality .recipe .fbox {
	display: flex;
	justify-content: space-between;
	margin-top: 70px;
}
#inner.quality .recipe .fbox .text {
	margin-top: 0;
	width: 510px;
}
#inner.quality .recipe .fbox img {
	margin-top: 0;
	width: 510px;
}
#inner.quality .recipe .cacao {
	display: flex;
	justify-content: center;
	margin-top: 50px;
	background: #F3F1EE;
	padding: 45px 0;
}
#inner.quality .recipe .cacao .box {
	width: 220px;
	margin: 0 50px;
	text-align: center;
}
#inner.quality .recipe .cacao .box img {
	border-radius: 200px;
}
#inner.quality .recipe .cacao .box .name {
	font-size: 20px;
	letter-spacing: 0.15em;
	text-indent: -0.15em;
	line-height: 1em;
	margin-top: 18px;
}
#inner.quality .recipe .cacao .box .name.f_en {
	font-size: 30px;
	color: #E4CB76;
	margin-top: 30px;
}
#inner.quality .recipe .img3 {
	margin-top: 50px;
}
#inner.quality .recipe .img4 {
	margin-top: 60px;
}

#inner.quality .country {
	padding-top: 80px;
	margin-top: 50px;
	padding-bottom: 120px;
}
#inner.quality .country::before {
	position: absolute;
	content: "";
	display: block;
	background: url(../images/img_footer.png) no-repeat right center;
	background-size: 100% auto;
	width: 900px;
	height: 600px;
	bottom: -331px;
	left: 50%;
	margin-left: -15px;
}
#inner.quality .country h3 {
	margin-left: 140px;
}
#inner.quality .country h3 span {
	margin-left: -140px
}
#inner.quality .country .hbox::before {
	top: 190px;
	background-image: url(../images/quality/img_country1.jpg);
}
#inner.quality .country .img2,
#inner.quality .country .img3,
#inner.quality .country .img4 {
	margin-top: 50px;
}

/* Product *********************************/
#inner.product .visual .text.comingsoon {
	position: relative;
	margin-top: 150px;
	margin-bottom: 200px;
	margin-left: 30px;
    font-size: 30px;
}


/* Privacy policy *********************************/
#inner.privacypolicy .main {
	padding-bottom: 120px;	
}
#inner.privacypolicy .visual > .inner {
	padding-top: 270px;
}
#inner.privacypolicy .visual::after {
	display: none;
}
#inner.privacypolicy .visual .bg {
	background: #D1C5C5;
	height: 510px;
}
#inner.privacypolicy .visual h2 {
	transform: none;
	top: 200px;
	font-size: 50px;
	left: 0;
}
#inner.privacypolicy .visual .copy span {
	display: inline-block;
	position: relative;
	z-index: 100;
	font-size: 30px;
	line-height: 70px;
	padding: 0 15px 0 20px;
	color: #fff;
	position: relative;
	top: -2px;
	letter-spacing: 0.13em;
}
#inner.privacypolicy .text {
	position: relative;
	width: 1080px;
	margin: 95px auto 0 auto;
	z-index: 100;
}

/**************************************************************/
/**************************************************************/
/** SP ********************************************************/
/**************************************************************/
/**************************************************************/
@media screen and (max-width: 767px) {

	/* style
	-------------------------------------------------------------- */
	body {
		min-width: 320px;
		overflow: visible !important;
		letter-spacing: 0;
		font-size: 13px;
		line-height: 1.8em;
	}
	body.busy {
		overflow: hidden !important;
	}
	body p {
		color: inherit;
		font-size: 13px;
		line-height: 1.8em;
	}
	a:hover {
		opacity: 1;
	}
	.non_pc {
		display: block !important;
	}
	.non_sp {
		display: none !important;
	}

	/* ===========================================================================================

		Common

	=========================================================================================== */
	.outline {
		position: relative;
		min-width: 320px;
		padding-bottom: 0 !important;
	}
	.main {
		width: auto;
		margin: 0 auto;
		position: relative;
		padding-top: 94px;
	}


	/* Header *******************************/
	header {
	  position: fixed;
	  width: 100%;
	  height: 80px;
	  z-index: 10000;
	  background: #fff;
	}
	header > .inner {
	  width: auto;
	  margin: 0 auto;
	  height: 100%;
	}
	header h1 {
		width: 94px;
		z-index: 1000;
		position: relative;
	}
	header .bt {
		display: flex;
		align-items: center;
		justify-content: flex-end;
		height: 100%;
		position: relative;
		z-index: 1000;
	}

	header .bt_facebook {
		width: 24px;
		margin-right: 15px;
	}
	header .bt_menu {
		display: block;
		width: 60px;
		height: 60px;
		text-align: center;
		box-sizing: border-box;
		position: relative;
		margin: 10px 10px 0 0;
	}
	header.show .bt_menu,
	#inner header .bt_menu {
		transition: margin 0.3s ease;
		margin-bottom: 3px;
	}
	header .bt_menu span {
		display: block;
		width: 100%;
		height: 100%;
		text-indent: -9999px;
		overflow: hidden;
	}
	header .bt_menu::before,
	header .bt_menu::after,
	header .bt_menu span::before {
		display: block;
		position: absolute;
		content: "";
		width: 40px;
		height: 2px;
		background: #92193a;
		top: 50%;
		left: 10px;
		transition: all 0.3s ease;
	}
	header .bt_menu::before {
		margin-top: -8px;
	}
	header .bt_menu::after {
		margin-top: 8px;
	}
	header.open .bt_menu::before {
		transform: rotate(155deg);
		margin-top: 0;
	}
	header.open .bt_menu::after {
		transform: rotate(-155deg);
		margin-top: 0;
	}
	header.open .bt_menu span::before {
		opacity: 0;
	}
	header .gmenu {
		position: absolute;
		top: 78px;
		left: 0;
		width: 100%;
		height: 1200px !important;
		background: #fff;
		z-index: 900;
		display: none;
		padding-top: 35px;
	}
	header .gmenu ul {
		position: relative;
		left: auto;
		top: auto;
		transform: none;
		display: block;
		width: 90%;
		margin: 0 auto;
		border-top: 1px solid #F3F1EE;
	}
	header .gmenu ul li {
		border-bottom: 1px solid #F3F1EE;
		height: auto;
	}
	header .gmenu ul li:last-child {
		border-bottom: none;
	}
	header .gmenu ul li a {
		display: block;
		text-align: center;
	}
	header .gmenu ul li a span {
		font-size: 14px;
		display: block;
		float: none;
		width: auto;
		line-height: 50px;
		padding: 0;
		box-sizing: border-box;
	}
	header .gmenu ul li:last-child {
		/* display: none; */
		border-bottom: 1px solid #F3F1EE;
		margin: 0;
	}
	header .gmenu ul li a.bt_contact {
		font-size: 18px;
		letter-spacing: 0.2em;
		line-height: 46px;
		padding: 0 15px;
		box-sizing: border-box;
		text-indent: 0.2em;
		background: none;
		width: auto;
		color: #000;
		margin: 0;
		padding-top: 0;
	}
	header .gmenu ul li a.bt_contact::before {
        display: none;
	}
	/* Footer *******************************/
	footer {
		background: url(../images/bg_footer.png) no-repeat center 140px,  url(../images/index/img_footer.jpg) no-repeat center top;
		background-size: 1500px auto, 120% auto;
		height: auto;
		position: relative;
		box-sizing: border-box;
		padding-top: 245px;
		z-index: 100;
		margin: 0 auto;
		text-align: center;
		padding-bottom: 10px;
	}
	#inner.about footer {
		background: url(../images/bg_footer.png) no-repeat center 140px,  url(../images/about/img_footer.jpg) no-repeat center top;
		background-size: 1500px auto, 120% auto;
	}
	#inner.story footer {
		background: url(../images/bg_footer.png) no-repeat center 140px,  url(../images/story/img_footer.jpg) no-repeat center top;
		background-size: 1500px auto, 140% auto;
	}
	#inner.quality footer {
		background: url(../images/bg_footer.png) no-repeat center 140px,  url(../images/quality/img_footer.jpg) no-repeat center top;
		background-size: 1500px auto, 120% auto;
	}
	#inner.product footer {
		background: url(../images/bg_footer.png) no-repeat center 140px,  url(../images/product/img_footer.jpg) no-repeat center top;
		background-size: 1500px auto, 120% auto;
	}
	footer .gmenu {
		margin-bottom: 30px;
		background: #fff;
	}
	footer .gmenu ul {
		display: flex;
		justify-content: center;
		position: relative;
		flex-wrap: wrap;
		width: 90%;
		margin: 0 auto;
	}
	footer .gmenu ul::before {
		display: block;
		position: absolute;
		content: "";
		height: 300px;
		width: 120%;
		left: -10%;
		top: 100%;
		background: #fff;
 }
	footer .gmenu ul li {
		width: 50%;
		border-top: 1px solid #F3F1EE;
		position: relative;
	}
	footer .gmenu ul li::before {
		display: block;
		content: "";
		position: absolute;
		width: 1px;
		height: 20px;
		background: #f3f1ed;
		right: 0;
		top: 14px;
	}
	footer .gmenu ul li:nth-child(2n)::before {
		display: none;
	}
	footer .gmenu ul li:nth-child(1),
	footer .gmenu ul li:nth-child(2) {
		border-top: none;
	}
	footer .gmenu ul li a {
		display: block;
		font-size: 14px;
		letter-spacing: 0.2em;
		line-height: 46px;
		padding: 0 15px;
		box-sizing: border-box;
		text-indent: 0.2em;
	}
	footer .gmenu ul li a.current {
		color: #92193a;
	}
	footer .gmenu ul li:last-child {
        width: 100%;
	}
	footer .gmenu ul li:last-child::before {
		display: none;
	}
	/*
	footer .gmenu ul li:last-child {
		margin-left: 20px;
		border: none;
	}
	footer .gmenu ul li:last-child::before {
		display: none;
	}
	footer .gmenu ul li:last-child {
		position: absolute;
		width: 24px;
		height: 24px;
		margin: 0;
		left: 50%;
		top: auto;
		bottom: -45px;
		margin-left: -12px;
	}
	footer .gmenu ul li:last-child a {
		width: 24px;
		height: 24px;
		padding: 0;
	}
	*/
	footer .pp {
		display: inline-block;
		font-size: 12px;
		margin-top: 8px;
		position: relative;
	}
	footer .copyright {
		text-align: center;
		font-size: 11px;
		line-height: 2em;
		margin-top: 35px;
		margin-bottom: 10px;
		position: relative;
	}
	footer .bt_pagetop {
		display: block;
		position: absolute;
		width: 55px;
		height: 55px;
		bottom: 0;
		right: 0;
		text-indent: -9999px;
		overflow: hidden;
		transition: none;
		background: #92193a;
		z-index: 100;
		transition: all ease 0.3s;
	}
	footer .bt_pagetop:hover {
		opacity: 1;
		background: #bf3358;
	}
	footer .bt_pagetop::after {
		display: block;
		position: absolute;
		width: 15px;
		height: 15px;
		left: 50%;
		top: 23px;
		content: "";
		border-top: 2px solid #E4CB76;
		border-right: 2px solid #E4CB76;
		margin: 0 0 0 -8px;
		transform: rotate(-45deg);
	}

	/* ===========================================================================================

	  Index

	=========================================================================================== */


	/* Visual *********************************/
	#index .visual {
		height: 320px;
		box-sizing: border-box;
		padding-top: 10px;
		margin-bottom: 190px;
		position: relative;
	}
	#index .visual .slider .slick-track,
	#index .visual .slider .slick-list {
		height: 100%;
	}
	#index .visual .slider .slick-slide {
		background: url(../images/index/img_visual.jpg) no-repeat center center;
		transition: background-size 3s ease;
		background-size: 105% auto;
	}
	#index .visual .slider .slide2 {
		background-image: url(../images/index/img_visual2.jpg);
	}
	#index .visual .slider .slide3 {
		background-image: url(../images/index/img_visual3.jpg);
	}
	#index .visual.active .slider .slick-slide {
		background-size: 100% auto;
	}
	@media screen and (max-width: 1440px) {
		#index .visual .slider .slick-slide {
			background-size: auto 110%;
		}
		#index .visual.active .slider .slick-slide {
			background-size: auto 100%;
		}
	}
	#index .visual::before {
		position: absolute;
		content: "";
		display: block;
		background: url(../images/index/img_cacao.png) no-repeat right center;
		background-size: 100% auto;
		width: 148px;
		height: 213px;
		top: 237px;
		right: 3%;
		z-index: 10;
	}
	#index .visual > .inner {
		width: 90%;
		margin: 0 auto;
		margin-top: 207px;
		position: relative;
		z-index: 100;
	}
	#index .visual > .inner::before,
	#index .visual > .inner::after {
		display: none;
	}
	#index .visual .copy {
		font-size: 36px;
		line-height: 1.2em;
	}
	#index .visual .copy2 {
		margin-top: 20px;
		position: relative;
	}
	#index .visual .copy2.non_pc + br + .copy2.non_pc {
		margin-top: 5px;
	}
	#index .visual .copy2.non_pc {
		display: inline-block !important;
	}
	#index .visual .copy2::before {
		display: block;
		content: "";
		position: absolute;
		height: 100%;
		background: #92193a;
	}
	#index .visual .copy2.non_pc + br + .copy2.non_pc::before {
		transition-delay: 1.25s;
	}
	#index .visual .copy2 span {
		display: inline-block;
		position: relative;
		z-index: 100;
		font-size: 23px;
		line-height: 45px;
		padding: 0 10px 0 10px;
		color: #fff;
		position: relative;
		top: -1px;
		letter-spacing: 0.13em;
	}


	/* Sec *********************************/
	.main .sec > .inner {
		width: 90%;
		margin: 0 auto;
		position: relative;
	}
	.main .sec > .inner::after {
		position: absolute;
		content: "";
		display: block;
		background: #F3F1EE;
		width: 105px;
		height: 263px;
		top: 485px;
		right: 0px;
	}
	.main .sec .bg {
		position: absolute;
		display: flex;
		align-items: start;
		top: 70px;
		left: 50%;
		width: 335px;
		margin-left: -167px;
		justify-content: space-between;
	}
	.main .sec h2,
	.main .sec h3 {
		font-size: 48px;
		position: relative;
		color: #921a3a;
		line-height: 1em;
		z-index: 100;
	}
	.main .sec h2 span,
	.main .sec h3 span {
		display: block;
		color: #E4CB76;
		line-height: 1em;
		margin-left: 52px;
		margin-top: 5px;
	}
	.main .sec .info {
		position: relative;
		z-index: 100;
		margin: 0 auto;
		margin-top: 20px;
		max-width: 400px;
	}
	.main .sec .info .title {
		font-size: 30px;
		width: 110%;
		font-weight: bold;
		letter-spacing: 0.1em;
	}
	.main .sec .info .text {
		width: auto;
		margin-top: 15px;
		font-size: 14px;
		line-height: 2em;
		letter-spacing: 0em;
	}
	.main .sec .info .text.f_en2 {
		width: auto;
		margin-top: 15px;
		font-size: 14px;
		line-height: 2em;
		letter-spacing: 0.05em;
	}
	.main .sec .bt_more {
		font-size: 18px;
		font-weight: bold;
		width: 215px;
		display: block;
		margin-top: 22px;
		background: url(../images/icon_arrow.png) no-repeat right center;
		background-size: 72px auto;
		line-height: 30px;
		letter-spacing: 0.2em;
	}
	#index .obj.rect {
		position: absolute;
		content: "";
		display: block;
		background: #F3F1EE;
		width: 105px;
		height: 263px;
		top: 485px;
		right: 0px;    	
	}
	/* About *****/
	#index .about {

	}
	#index .about .obj.cacao {
		display: none;
	}
	#index .about .bg img {
		width: 111px;
		margin-right: 0;
	}
	#index .about .bg img:nth-child(1) {
		margin-top: 43px;
	}
	#index .about .bg img:nth-child(3) {
		margin-top: 104px;
	}
	#index .about .info {
		margin-top: 366px;
	}

	/* Story *****/
	#index .story {
		margin-top: 60px;
		padding-bottom: 30px;
	}
	#index .story .obj.rect {
		width: 120%;
		height: 505px;
		top: 629px;
		right: auto;
		left: -10%;
	}
	#index .story .info {
		margin-left: auto;
		margin-top: 15px;
	}
	#index .story .bg {
		width: 335px;
		left: 50%;
		top: 100px;
		right: auto;
		z-index: 50;
		margin-left: -147px;
	}
	#index .story.active .bg {
		top: 70px;
	}
	#index .story .bg::before {
		position: absolute;
		content: "";
		display: block;
		background: url(../images/index/txt_story.png) no-repeat right center;
		background-size: 100% auto;
		width: 204px;
		height: 122px;
		bottom: -85px;
		left: 40px;
		z-index: 10;
	}
	#index .story .bg img {
		width: 100%;
	}
	#index .story .info {
		margin-top: 508px;
	}
	#index .story .info .title {
		letter-spacing: -0.15em;
	}
	#index .story .info .text {
		margin-top: 50px;
	} 
	#index .story .info .text.f_en2 {
		margin-top: 30px;
	} 

	/* Quality *****/
	#index .quality {
		margin-top: 60px;
		padding-bottom: 194px;
	}
	#index .quality .obj.rect {
		top: -5px;
		right: -6%;
	}
	#index .quality .bg {
		width: 335px;
		left: 50%;
		top: 100px;
		right: auto;
		z-index: 50;
		margin-left: -189px;
	}
	#index .quality.active .bg {
		top: 70px;
	}
	#index .quality .info::before {
		position: absolute;
		content: "";
		display: block;
		background: url(../images/index/img_quality_more.jpg) no-repeat right center;
		background-size: 100% auto;
		width: 270px;
		height: 165px;
		bottom: -193px;
		right: 0;
		z-index: 10;
	}
	#index .quality .bg img {
		width: 100%;
	}
	#index .quality .info {
		margin-left: auto;
		margin-top: 385px;
	}
	#index .quality .info .title {
		letter-spacing: 0.3em;
	}

	/* Product *****/
	#index .product {
		margin-top: 60px;
		padding-bottom: 25px;
	}
	#index .product .obj.rect {
		width: 275px;
		height: 839px;
		top: 20px;
		right: auto;
		left: 50%;
		margin-left: -137px;
	}
	#index .product h2 {
		z-index: 50;
	}
	#index .product .info {
		margin-left: 0;
		margin-top: 15px;
	}
	#index .product .bg {
		width: 674px;
		top: 510px;
		left: 0;
		z-index: 50;
		display: flex;
		justify-content: space-between;
		margin: 0;
	}
	#index .product .bg img {
		width: 207px;
	}
	#index .product .info .title {
		letter-spacing: 0.3em;
	}
	#index .product .info .text {
		width: 337px;
 }
	#index .product .info .text.f_en2 {
		margin-bottom: 322px;
	} 

	/* Voice *********************************/
	#index .voice {
		margin-top: 0px;
		padding-top: 80px;
	}
	#index .voice > .inner {
		background-size: 256px auto;
		margin: 0 auto;
		position: relative;
		padding: 45px 0 40px 0;
	}
	#index .voice h2 {
		text-align: center;
		font-size: 30px;
		letter-spacing: 0.2em;
		text-indent: 0.2em;
		line-height: 1em;
	}
	#index .voice .info {
		margin-top: 30px;
		width: 90%;
	}
	#index .voice .face {
		width: 330px;
		margin: 0 auto 0 auto;
		position: relative;
		left: 7px;
	}
	#index .voice .text {
		margin-top: 30px;
		font-size: 14px;
		column-count: 1;
		column-gap: 0;
		text-align: justify;
	}
	#index .voice .photo {
		margin-top: 25px;
	}


	/* Contact *********************************/
	#index .contact {
		margin-top: -55px;
		padding-top: 110px;
	}
	#index .contact > .inner {
		width: 90%;
		margin: 0 auto;
		position: relative;
		text-align: center;
		padding-bottom: 90px;
	}
	#index .contact > .inner::before {
		position: absolute;
		content: "";
		display: block;
		background: url(../images/img_footer.png) no-repeat right center;
		background-size: 100% auto;
		width: 450px;
		height: 300px;
		bottom: -173px;
		right: auto;
		left: 50%;
		z-index: 10;
		margin-left: -80px;
	}
	#index .contact h2 {
		font-size: 30px;
		letter-spacing: 0.2em;
		text-indent: 0.2em;
		line-height: 1em;
	}
	#index .contact .lead {
		font-size: 14px;
		margin-top: 21px;
	}
	#index .contact a {
		display: inline-block;
		font-size: 15px;
		margin-top: 20px;
	}
	#index .contact a span {
		display: inline-block;
		margin-left: 63px;
		position: relative;
	}
	#index .contact a span::before {
		display: block;
		content: "";
		position: absolute;
		width: 40px;
		height: 1px;
		bottom: 6px;
		left: -52px;
		background: #92193a;
	}



	/* ===========================================================================================

	  Inner

	=========================================================================================== */
	#inner .main {
		position: relative;
	}
	#inner header .gmenu ul li a {
		color: #0B0E12;
	}
	#inner header.fixed .gmenu ul li a {
		color: #0B0E12;
	}
	#inner header.fixed .gmenu ul li a.bt_contact {
		color: #0B0E12;
	}
	#inner header .gmenu ul li a.current {
		color: #921a3a;
	}
	#inner .main .sec .info {
		margin-left: auto;
		margin-top: 390px;
	}
	#inner .main .sec .info .text {
		width: auto;
		margin-top: 10px;
		font-size: 14px;
		line-height: 2em;
	}

	/* Visual *********************************/
	#inner .visual {
		box-sizing: border-box;
		padding-top: 10px;
		margin-bottom: 40px;
		position: relative;
	}
	#inner .visual::after {
		position: absolute;
		content: "";
		display: block;
		background: url(../images/index/img_cacao.png) no-repeat right center;
		background-size: 100% auto;
		width: 150px;
		height: 222px;
		z-index: 100;
		top: 218px;
		left: 50%;
		margin-left: 30px;
	}
	#inner .visual .bg {
		position: absolute;
		width: 100%;
		left: 0;
		margin-left: 0;
		min-width: 0;
		top: 0;
		height: 275px;
		overflow: hidden;
		background: #000;
	}
	#inner.quality .visual .bg {
		background: #D1C5C5;
	}
	#inner .visual .bg::before {
		display: block;
		content: "";
		position: absolute;
		background: url(../images/bg_inner_visual.png) no-repeat top left;
		background-size: 100% auto;
		width: 994px;
		height: 126px;
		bottom: -42px;
		left: 0;
		z-index: 100;
	}
	#inner.story .visual .bg::after {
		position: absolute;
		content: "";
		display: block;
		background: url(../images/story/txt_name.png) no-repeat right center;
		background-size: 100% auto;
		width: 200px;
		height: 80px;
		bottom: 55px;
		left: auto;
		margin-left: 0;
		right: 5%;
	}
	#inner .visual .bg img {
		position: relative;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
		width: 110%;
	}
	#inner .visual > .inner {
		width: 90%;
		margin: 0 auto;
		padding-top: 350px;
		position: relative;
	}
	#inner.story .visual > .inner {
		padding-top: 350px;
	}
	#inner.quality .visual > .inner {
		padding-top: 350px;
	}
	#inner.product .visual > .inner {
		padding-top: 350px;
	}
	#inner .visual > .inner::before {
		display: block;
		position: absolute;
		content: "Scroll Down";
		font-family: semplicitapro,sans-serif;
		font-weight: 500;
		font-style: normal;
		letter-spacing: 0.2em;
		font-size: 13px;
		line-height: 1em;
		transform: rotate(90deg);
		transform-origin: 0 0;
		left: -100px;
		top: 455px;
	}
	#inner .visual > .inner::after {
		display: block;
		content: "";
		position: absolute;
		width: 1px;
		height: 200px;
		background: #92193a;
		left: -108px;
		top: 580px;
	}
	#inner .visual h2 {
		position: absolute;
		font-size: 60px;
		line-height: 1em;
		color: #921a3a;
		transform: none;
		left: 0;
		top: 207px;
		z-index: 200;
		width: 800px;
	}
	#inner.about .visual h2 {
		letter-spacing: 0;
	}
	#inner.story .visual h2 {
		top: 267px;
	}
	#inner.quality .visual h2 {
		top: 207px;
		letter-spacing: 0.05em;
	}
	#inner.product .visual h2 {
		top: 267px;
	}
	#inner .visual .copy {
		margin-top: 10px;
		position: relative;
		display: inline-block;
		z-index: 200;
	}
	#inner .visual .copy::before {
		display: block;
		content: "";
		position: absolute;
		width: 100%;
		height: 100%;
		background: #92193a;
	}
	#inner .visual .copy span {
		display: inline-block;
		position: relative;
		z-index: 100;
		font-size: 23px;
		line-height: 45px;
		padding: 0 9px 0 10px;
		color: #fff;
		position: relative;
		top: -1px;
		letter-spacing: 0.13em;
	}
	#inner.quality .visual .copy span {
		letter-spacing: 0.2em;
	}
	#inner .visual .text {
		position: relative;
		z-index: 200;
		font-size: 14px;
		line-height: 2em;
		margin-top: 25px;
	}

	#inner .submenu {
		width: 1080px;
		margin: 0 auto;
		height: 90px;    
	}
	#inner .submenu ul {
		display: flex;
		padding: 22px 0;
		float: left;
		position: relative;
	}
	#inner .submenu ul::before {
		display: block;
		content: "";
		position: absolute;
		height: 100%;
		width: 5000px;
		background: #921a3a;
		right: 0;
		top: 0;
	}
	#inner .submenu ul li {
		border-left: 1px solid #fff;
		position: relative;
		z-index: 
	}
	#inner .submenu ul li:first-child {
		border-left: none;
	}
	#inner .submenu ul li a {
		font-size: 16px;
		padding: 0px 30px;
		display: block;
		line-height: 1em;
		color: #fff;
		letter-spacing: 0.1em;
	}
	#inner .submenu ul li:first-child a {
		padding-left: 22px;
	}
	#inner.quality .submenu ul li a {
		padding: 0px 60px;
	}
	#inner.quality .submenu ul li:first-child a {
		padding-left: 65px;
	}

	/* About *********************************/
	#inner.about .founding {
		padding-top: 100px;
		padding-bottom: 272px;
		margin-top: -80px;
	}
	#inner.about .founding > .inner {
		position: relative;
	}
	#inner.about .founding > .inner::after {
		position: absolute;
		content: "";
		display: block;
		background: #F3F1EE;
		width: 112%;
		height: 440px;
		top: 561px;
		right: auto;
		left: -6%;
		z-index: -1;
	}
	#inner.about .founding .bg {
		width: 335px;
		left: 50%;
		top: 73px;
		right: auto;
		z-index: 50;
		margin-left: -189px;
	}
	#inner.about .founding .bg img:nth-child(1) {
		width: 680px;
	}
	#inner.about .founding .bg img:nth-child(2) {
		position: absolute;
		width: 206px;
		top: 998px;
		left: 50%;
		margin-left: -167px;
	}
	#inner.about .founding .bg img:nth-child(3) {
		position: absolute;
		width: 186px;
		top: 887px;
		left: 50%;
		margin-left: 24px;
	}
	#inner.about .founding h3 {
		width: 110%;
		letter-spacing: 0.05em;
	}
	#inner.about .founding h3 span {
		margin-left: 65px;
	}
	#inner.about .founding .info .text {
		margin-top: 40px;
		line-height: 1.8em;
	}

	#inner.about .history {
		padding-top: 110px;
		padding-bottom: 50px;
		margin-top: -50px;
	}
	#inner.about .history .bg {
		width: 335px;
		left: 50%;
		top: 73px;
		right: auto;
		z-index: 50;
		margin-left: -147px;
	}
	#inner.about .history .info {
		margin-left: auto;
		margin-top: 435px;
	}
	#inner.about .history > .inner::after {
		position: absolute;
		content: "";
		display: block;
		background: #F3F1EE;
		width: 112%;
		height: 630px;
		top: 555px;
		left: -6%;
		right: auto;
		z-index: 0;
	}
	#inner.about .history dl {
		margin-top: 45px;
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		align-items: center;
		position: relative;
	}
	#inner.about .history dl::before {
		display: block;
		content: "";
		position: absolute;
		width: 2px;
		height: 98%;
		top: 1%;
		left: 35px;
		background: #92193a;
	}
	#inner.about .history dl dt {
		width: 68px;
		line-height: 68px;
		border: 2px solid #92193a;
		text-align: center;
		font-size: 12px;
		font-family: 'Noto Serif JP', serif;
		letter-spacing: 0.1em;
		color: #92193a;
		font-weight: bold;
		border-radius: 100px;
		margin-top: 25px;
		background: #f3f1ed;
		position: relative;
	}
	#inner.about .history dl dd {
		width: calc(100% - 85px);
		font-size: 14px;
		margin-top: 25px;
		line-height: 1.6em;
		letter-spacing: 0;
	}
	#inner.about .history dl dt:first-child,
	#inner.about .history dl dt:first-child + dd {
		margin-top: 0;
	}

	#inner.about .award {
		padding-top: 110px;
		padding-bottom: 30px;
		margin-top: -70px;
		position: relative;
	}
	#inner.about .award::after {
		position: absolute;
		content: "";
		display: block;
		background: url(../images/img_footer.png) no-repeat right center;
		background-size: 100% auto;
		width: 900px;
		height: 600px;
		top: 11px;
		left: 50%;
		z-index: 10;
		margin-left: -15px;
	}
	#inner.about .award::before {
		display: block;
		content: "";
		position: absolute;
		width: 100%;
		height: calc(100% - 230px);
		top: 232px;
		background: url(../images/bg_pattern2.png) repeat center top;
		background-size: 30px auto;
		z-index: 50;
	}
	#inner.about .award > .inner::after {
		display: none;
	}
	#inner.about .award .info {
		margin: 0 auto 0 auto;
	}
	#inner.about .award .info dl {
		display: block;
		flex-wrap: wrap;
		justify-content: space-between;
		align-items: start;
		position: relative;
		width: auto;
		margin: 35px auto 0 auto;
	}
	#inner.about .award .info dl dt {
		font-family: 'Noto Serif JP', serif;
		letter-spacing: 0.1em;
		font-size: 23px;
		font-weight: bold;
		color: #F3F1EE;
		line-height: 50px;
		margin-top: 15px;
		position: relative;
	}
	#inner.about .award .info dl dt::before {
		display: block;
		position: absolute;
		content: "";
		width: 40px;
		height: 1px;
		background: #fff;
		transform: rotate(-45deg);
		left: 70px;
		top: 25px;
	}
	#inner.about .award .info dl dd {
		width: auto;
		font-size: 18px;
		margin-top: 0;
		line-height: 1.6em;
		letter-spacing: 0;
	}
	#inner.about .award .info dl dd p {
		background: #F3F1EE;
		padding: 10px 15px;
		margin-top: 7px;
	}
	#inner.about .award .info dl dd p:first-child {
		margin-top: 0;
	}
	#inner.about .award dl dt:first-child,
	#inner.about .award dl dt:first-child + dd {
		margin-top: 0;
	}
	#inner.about .award .bt_more {
		margin: 30px 0 0 0;
		color: #fff;
		background-image: url(../images/icon_arrow2.png);
	}


	/* Story *********************************/
	#inner.story .gianluca {
		padding-top: 110px;
		padding-bottom: 136px;
		margin-top: -80px;
	}
	#inner.story .gianluca > .inner {
		position: relative;
	}
	#inner.story .gianluca > .inner::after {
		position: absolute;
		content: "";
		display: block;
		background: #F3F1EE;
		width: 112%;
		height: 750px;
		top: 610px;
		right: auto;
		z-index: -1;
		left: -6%;
	}
	#inner.story .gianluca .bg {
		width: 335px;
		left: 50%;
		top: 73px;
		right: auto;
		z-index: 50;
		margin-left: -189px;

	}
	#inner.story .gianluca .bg img:nth-child(1) {
		width: 680px;
	}
	#inner.story .gianluca .bg img:nth-child(2) {
		position: absolute;
		width: 206px;
		top: 1240px;
		left: 20px;
	}
	#inner.story .gianluca .info .text {
		margin-top: 40px;
		letter-spacing: 0;
	}
	#inner.story .philosophy {
		padding-top: 120px;
		padding-bottom: 80px;
		margin-top: -65px;
	}
	#inner.story .philosophy::before {
		position: absolute;
		content: "";
		display: block;
		background: url(../images/img_footer.png) no-repeat right center;
		background-size: 100% auto;
		width: 450px;
		height: 300px;
		bottom: -168px;
		left: 50%;
		margin-left: -80px;
	}
	#inner.story .philosophy h3 {
		margin: 0px 0 0 55px;
	}
	#inner.story .philosophy h3 span {
		margin-left: -53px;
	}
	#inner.story .philosophy .bg {
		width: 335px;
		left: 50%;
		top: 73px;
		right: auto;
		z-index: 50;
		margin-left: -147px;
	}
	#inner.story .philosophy .bg img:nth-child(2) {
		position: absolute;
		width: 170px;
		top: 230px;
		left: 193px;
	}
	#inner.story .philosophy .info {
		margin-left: auto;
	}
	#inner.story .philosophy > .inner::after {
		position: absolute;
		content: "";
		display: block;
		background: #F3F1EE;
		width: 112%;
		height: 545px;
		top: 682px;
		left: -6%;
		right: auto;
		z-index: 0;
	}
	#inner.story .philosophy .lead {
		margin-top: 10px;
	}
	#inner.story .philosophy .lead .line {
		margin-top: 5px;
		position: relative;
		display: inline-block;
		z-index: 200;
	}
	#inner.story .philosophy .lead .line::before {
		display: block;
		content: "";
		position: absolute;
		width: 100%;
		height: 100%;
		background: #92193a;
	}
	#inner.story .philosophy .lead .line span {
		display: inline-block;
		position: relative;
		z-index: 100;
		font-size: 23px;
		line-height: 45px;
		padding: 0 10px 0 10px;
		color: #fff;
		position: relative;
		top: -1px;
		letter-spacing: 0.13em;
	}
	#inner.story .philosophy .info .text {
		width: auto;
		margin-top: 25px;
	}

	/* Quality *********************************/
	#inner.quality .sec .hbox {
		position: relative;
		max-width: 338px;
		margin: 0 auto;
	}
	#inner.quality .sec .hbox:before {
		position: absolute;
		display: block;
		content: "";
		width: 295px;
		height: 230px;
		background: url(../images/quality/img_recipe1.jpg?v=1) no-repeat center center;
		background-size: cover;
		left: 61px;
		top: 18px;
	}
	#inner.quality .sec .hbox .title {
		width: 150px;
		line-height: 150px;
		background: #921a3a;
		color: #fff;
		text-align: center;
		font-size: 23px;
		letter-spacing: 0.4em;
		text-indent: 0.4em;
		position: relative;
		margin-top: 50px;
		left: -5.5%;
	}
	#inner.quality .sec .hbox .title:before {
		position: absolute;
		display: block;
		content: "";
		width: 15px;
		height: 15px;
		left: 100%;
		top: 100%;
		background:#e4cb76;
	}
	#inner.quality .sec > .inner::after {
		display: none;
	}
	#inner.quality .sec .info {
		margin-left: auto;
		margin-top: 0;
	}
	#inner.quality .sec .info .text {
		margin-top: 25px;
		width: auto;
	}
	#inner.quality .sec .info > .text:first-child {
		margin-top: 40px;
	}
	#inner.quality .recipe {
		padding-top: 110px;
		margin-top: -95px;
	}
	#inner.quality .recipe h3 span {
		margin-left: 0;
	}
	#inner.quality .recipe .fbox {
		display: flex;
		justify-content: start;
		margin-top: 25px;
		flex-wrap: wrap;
	}
	#inner.quality .recipe .fbox .text {
		margin-top: 0;
		width: auto;
	}
	#inner.quality .recipe .fbox img {
		margin-top: 25px;
		width: auto;
	}
	#inner.quality .recipe .cacao {
		display: block;
		justify-content: center;
		margin-top: 25px;
		background: #F3F1EE;
		padding: 15px 0;
	}
	#inner.quality .recipe .cacao .box {
		width: auto;
		margin: 0 5px 0 15px;
		height: 110px;
		text-align: center;
		display: flex;
		flex-direction: column;
		flex-wrap: wrap;
		margin-top: 15px;
	}
	#inner.quality .recipe .cacao .box:first-child {
		margin-top: 0;
	}
	#inner.quality .recipe .cacao .box img {
		border-radius: 200px;
		width: 110px;
	}
	#inner.quality .recipe .cacao .box .name {
		font-size: 14px;
		letter-spacing: 0.15em;
		text-indent: -0.15em;
		line-height: 1em;
		margin-top: 13px;
		width: calc(100% - 120px);
		margin-left: auto;
	}
	#inner.quality .recipe .cacao .box .name.f_en {
		font-size: 22px;
		color: #E4CB76;
		margin-top: 30px;
		left: 0;
	}
	#inner.quality .recipe .img3 {
		margin-top: 25px;
	}
	#inner.quality .recipe .img4 {
		margin-top: 15px;
	}

	#inner.quality .country {
		padding-top: 110px;
		margin-top: -50px;
		padding-bottom: 40px;
	}
	#inner.quality .country::before {
		position: absolute;
		content: "";
		display: block;
		background: url(../images/img_footer.png) no-repeat right center;
		background-size: 100% auto;
		width: 450px;
		height: 300px;
		bottom: -166px;
		left: 50%;
		margin-left: -77px;
	}
	#inner.quality .country h3 {
		margin-left: 50px;
	}
	#inner.quality .country h3 span {
		margin-left: -52px;
	}
	#inner.quality .country .hbox::before {
		top: 71px;
		background-image: url(../images/quality/img_country1.jpg);
	}
	#inner.quality .country .img2,
	#inner.quality .country .img3,
	#inner.quality .country .img4 {
		margin-top: 25px;
	}

	/* Product *********************************/
	#inner.product .visual .text.comingsoon {
		position: relative;
		margin-top: 120px;
		margin-bottom: 130px;
		margin-left: 0;
		font-size: 20px;
		text-align: center;
	}
	
	/* Privacy policy *********************************/
	#inner.privacypolicy .main {
		padding-bottom: 50px;
	}
	#inner.privacypolicy .visual > .inner {
		padding-top: 110px;
	}
	#inner.privacypolicy .visual::after {
		display: none;
	}
	#inner.privacypolicy .visual .bg {
		background: #D1C5C5;
		height: 210px;
	}
	#inner.privacypolicy .visual h2 {
		transform: none;
		top: 70px;
		font-size: 30px;
		left: 0;
	}
	#inner.privacypolicy .visual .copy span {
		display: inline-block;
		position: relative;
		z-index: 100;
		font-size: 18px;
		line-height: 45px;
		padding: 0 10px 0 10px;
		color: #fff;
		position: relative;
		top: -1px;
		letter-spacing: 0.13em;
	}
	#inner.privacypolicy .text {
		position: relative;
		width: 90%;
		margin: 35px auto 0 auto;
		z-index: 100;
		font-size: 13px;
		line-height: 2em;
	}


}