@charset "utf-8";
/* CSS Document */

/* import common.css */
@import url(/hello-chocolate/common/css/common.css);

/*====================
reset
====================*/
figure {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
}
ol {
	margin: 0;
	padding: 0;
}
div:after, dl:after, ul:after {
	content: none;
}
*:focus {
	outline: none;
}
p, h1, h2, h3, h4, h5, h6, a, li, caption, td, th, dt, dd, input, textarea, select, address {
    font-family: "NotoSansCJKjp","メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", sans-serif;
	font-weight: normal;
}
/*====================
FONT読み込み
====================*/
@font-face {
	font-family: 'NotoSansCJKjp';
	font-style: normal;
	font-weight: 400;
	src: url(/hello-chocolate/common/font/NotoSansCJKjp-Regular.woff)format('woff');
}
@font-face {
	font-family: 'NotoSansCJKjp';
	font-style: bold;
	font-weight: 700;
	src: url(/hello-chocolate/common/font/NotoSansCJKjp-Bold.woff)format('woff');
}

/*====================
basic
====================*/
* {
	box-sizing: border-box;
}
.contents_wrap,
.mfp-content{
	-webkit-text-size-adjust: 100%;
	font-size: 15px;
	line-height: 1.6;
	color: #3d3d3d;
	position: relative;
	-webkit-font-smoothing: antialiased;
}
.contents_wrap img,
.mfp-content img{
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
	display: block;
	-webkit-backface-visibility: hidden;
}
#foot .sns {
	display: flex;
	justify-content: center;
}
.scroll_pagetop{
	position: fixed;
	right: 0;
	bottom: 40px;
	z-index: 99;
}
img{
	max-width: 100%;
}

/* ～640px For SP
====================================================*/

@media screen and (max-width: 640px), print {
.isPC {
	display: none !important;
}
.contents_wrap,
.mfp-content{
	font-size: 14px;
	line-height: 1.7;
}

/*====================
ヘッダーナビ
====================*/
.contents_wrap header {
	position: relative;
	background: #4b2300;
	height: 50px;
	width: 100%;
	z-index: 999;
}
.contents_wrap header .header_inner {
	position: relative;
	height: 50px;
}
.contents_wrap header .nav_logo {
	padding: 14px 20px;
}
.contents_wrap header .nav_logo img {
	height: 20px;
}

.contents_wrap header nav {
	/*display: none;*/
	background: #4b2300;
}
.contents_wrap header nav .menu_con li a {
	position: relative;
	display: block;
	padding: 7.9vw 0;
}
.contents_wrap header nav .menu_con li + li a::after {
	position: absolute;
	display: block;
	content: "";
	width: 13.3vw;
	height: 1px;
	top: 0px;
	left: 50%;
	margin-left: -6.66vw;
	background: #fff;
}
.contents_wrap header nav .menu_con li a img {
	width: 25.5vw;
	margin: 0 auto;
}
.contents_wrap header nav .menu_sns {
	position: relative;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	padding: 7.9vw 0 13.3vw;
}
.contents_wrap header nav .menu_sns li {
	margin: 0 3.3vw;
	width: 8.7vw;
}
.contents_wrap header nav .menu_sns li::after {
	position: absolute;
	display: block;
	content: "";
	width: 13.3vw;
	height: 1px;
	top: 0px;
	left: 50%;
	margin-left: -6.66vw;
	background: #fff;
}
.contents_wrap header nav .menu_sns img {
	width: 100%;
}

/*ハンバーガーメニュー*/
#nav_toggle, #nav_toggle span {
	display: inline-block;
	transition: all .4s;
	box-sizing: border-box;
}
#nav_toggle {
	position: absolute;
	width: 25px;
	height: 20px;
	top: 15px;
	right: 18px;
	cursor: pointer;
}
#nav_toggle span {
	position: absolute;
	left: 0;
	width: 100%;
	height: 1px;
    background-color: #fff;
}
#nav_toggle span:nth-of-type(1) {
	top: 0;
}
#nav_toggle span:nth-of-type(2) {
	top: 9px;
}
#nav_toggle span:nth-of-type(3) {
	bottom: 0;
}
#nav_toggle.active span:nth-of-type(1) {
	-webkit-transform: translateY(20px) rotate(-45deg);
	transform: translateY(9px) rotate(-45deg);
}
#nav_toggle.active span:nth-of-type(2) {
	opacity: 0;
}
#nav_toggle.active span:nth-of-type(3) {
	-webkit-transform: translateY(-20px) rotate(45deg);
	transform: translateY(-10px) rotate(45deg);
}

/*====================
official_social
====================*/
#official_social{
	background: #4b2300;
	padding-bottom: calc(100%*68/768);
}
#official_social ul{
	display: flex;
}

/*====================
foot
====================*/
#foot .sns_area {
	background: url(/hello-chocolate/images/bg_sns_sp.png) no-repeat top center /cover;
	padding-top: calc(100%*336/768);
	position: relative;
}
#foot .sns {
	position: absolute;
	top: 18.5vw;
	width: 100%;
}
#foot .sns li {
	width: 12vw;
}
#foot .sns li:not(:first-child) {
	margin-left: 6vw;
}
#foot .banner {
	background: url(/hello-chocolate/images/bg_foot_sp.png) no-repeat top center /100% auto;
	padding-top: calc(100%*860/768);
	position: relative;
}
#foot .banner .factory a {
position: absolute;
top: 9vw;
left: 13.2vw;
width: calc(100%*560/768);
}
#foot .banner .with_cacao a {
position: absolute;
top: 65vw;
left: 13.2vw;
width: calc(100%*560/768);
}

/*====================
scroll_pagetop
====================*/
.scroll_pagetop {
		bottom: 40px!important;
    right: 5vw;
}
.scroll_pagetop img {
	width: 13.3vw;
}
/*.scroll_pagetop.scroll_cmp {
	right: 5vw;
}
.scroll_pagetop.scroll_cmp img {
	width: 37vw;
}*/
}


/* 641px～ For PC
====================================================*/

@media screen and (min-width: 641px), print {
.isSP {
	display: none !important;
}
body {
	min-width: 950px;
	position: relative;
}

/*====================
ヘッダーナビ
====================*/
.contents_wrap header {
	background: #4b2300;
	height: 100px;
}
.contents_wrap header .header_inner {
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	max-width: 1366px;
	margin: 0 auto;
}
.contents_wrap header .nav_logo {
	padding: 30px 40px 0;
}
.contents_wrap header .nav_logo img {
	height: 40px;
}

.contents_wrap header nav {
	display: block !important;
	opacity: 1 !important;
}
.contents_wrap header nav .nav_inner {
	display: -webkit-flex;
	display: flex;
}
.contents_wrap header nav .menu_con li a {
	position: relative;
	display: block;
	padding: 0 20px;
}
.contents_wrap header nav .menu_con {
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: flex-end;
	justify-content: flex-end;
	padding: 0;
	width: 100%;
	margin: 40px auto;
	overflow: hidden;
}

.contents_wrap header nav .menu_con li + li a::after {
	position: absolute;
	display: block;
	content: "";
	width: 1px;
	height: 20px;
	top: 0px;
	left: 0;
	margin-left: 0;
	background: #fff;
}
.contents_wrap header nav .menu_con li a img {
	width: 90px;
}
.contents_wrap header nav .menu_sns {
	position: relative;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	margin: 34px auto;
	padding: 0;
}
.contents_wrap header nav .menu_sns li {
	position: relative;
	margin: 0px 35px;
	/*width: 32px;*/
	}
.contents_wrap header nav .menu_sns li::after {
	position: absolute;
	display: block;
	content: "";
	width: 1px;
	height: 20px;
	top: 5px;
	left: -35px;
	margin-left: 0;
	background: #fff;
}
.contents_wrap header nav .menu_sns img {
	width: 100%;
}

/*ハンバーガーメニュー*/
#nav_toggle span {
    background: #4b2300;
}

/*====================
official_social
====================*/
#official_social {
	background: #4b2300 url(/hello-chocolate/images/bg_official_social.png) no-repeat top center;
	height: 235px;
	padding-top: 32px;
	text-align: center;
}
#official_social p.official_social_ttl {
	margin-bottom: 32px;	
}
#official_social img {
	display: inline-block;
}
#official_social ul{
	display: flex;
	justify-content: center;
}
#official_social ul li:first-child{
	margin-right: 50px;
}

/*====================
foot
====================*/
#foot {
	height: 473px;
	/* background: #fff url(/hello-chocolate/images/bg_sns_pc.png) no-repeat top center; */
	padding-top: 110px;
}
#foot .sns {
	margin-bottom: 76px;
}
#foot .sns li {
	width: 50px;
}
#foot .sns li:not(:first-child) {
	margin-left: 27px;
}
#foot .banner {
	height: 237px;
	display: -webkit-flex;
  display: flex;
	-webkit-justify-content: center;
	justify-content: center;
  /* background: #fff url(/hello-chocolate/images/bg_foot_pc.png) no-repeat top center; */
  padding-top: 30px;
}
#foot .banner li:nth-of-type(2n) {
	padding-left: 148px;
}
#foot .banner img {
	display: inline-block;
	width: 323px;
}
#foot .banner a:not(.not_hover):hover {
    opacity: 0.8;
}

/*====================
scroll_pagetop
====================*/
.scroll_pagetop a img{
	-webkit-transition: 0.3s;
	transition: 0.3s;
}
.scroll_pagetop a:hover img{
	opacity: 0.7;
}
.scroll_pagetop {
	bottom: 40px;
	right: 40px;
}
.scroll_pagetop img {
	width: 70px;
}
/*.scroll_pagetop.scroll_cmp {
	bottom: 40px;
	right: 40px;
}
.scroll_pagetop.scroll_cmp img {
	width: auto;
}*/
}
