@charset "UTF-8";

/* 競合解消・共通スタイル
---------------------------------------------------------- */
sup {
	vertical-align: 0;
}
.btn {
	width: auto;
}

.btn a {
	min-height: auto;
}

.firefox .btn a {
	min-height: 70px;
	height: 70px;
}

.btn01 {
	background-color: transparent;
}
.breadcrumb {
	font-family: "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "游ゴシック", "Yu Gothic", "メイリオ", "Meiryo", sans-serif;
}
#footer {
	background: #FFF;
	font-family: "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "游ゴシック", "Yu Gothic", "メイリオ", "Meiryo", sans-serif;
}

@media screen and (max-width: 750px) {
	.btn {
		width: 100%;
	}
}


/* スライダースタイル調整
---------------------------------------------------------- */
.slick-track {
	margin: 0 !important;
}
.mainv {
	width: 1000px;
	margin: 0 auto;
}
.mainv .mainv_slide {
	line-height: 0 !important;
}
.mainv_thumb .slick-list {
	padding: 0 !important;
}
.mainv_thumb img {
	width: 100% !important;
}
.mainv .slick-dots {
	bottom: 8px !important;
}
.slide_block .mainv_slide .slick-active img {
	opacity: 1;
}

@media screen and (max-width: 750px) {
	.mainv {
		width: 100%;
	}
	.mainv .mainv_thumb li {
		padding: 4% !important;
	}
	.slick-track {
		/*transform: translate3d(0px, 0px, 0px) !important;*/
	}
}


/* パンクズ
---------------------------------------------------------- */
.breadcrumb {
	width: 1000px;
	margin: 0 auto;
	padding: 40px 0 15px;
}
#topic_path {
	width: 1000px;
	margin: 0 auto;
	padding: 40px 0 15px;
}
#topic_path + .breadcrumb {
	margin-top: -55px;
}
.order_num_entry_btn {
	top: 15px;
}


@media screen and (max-width: 750px) {
	.breadcrumb,
	#topic_path {
		width: 94%;
		padding-top: 15px;
	}
	#topic_path + .breadcrumb {
		margin-top: -30px;
	}
}



/* コンテンツ幅
---------------------------------------------------------- */
.contents_products {
	/*width: 1000px;*/
	margin: 0 auto;
	padding: 30px 0 0;
}


@media screen and (max-width: 750px) {
	.breadcrumb,
	#topic_path {
		width: 94%;
		padding-top: 15px;
	}
	#topic_path + .breadcrumb {
		margin-top: -30px;
	}
}



/* 価格エリア
---------------------------------------------------------- */
.kakaku_block {
	background: #f7f7f7;
	margin-top: 45px;
	padding:40px;
}

.kakaku_block .kakaku_item {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	align-items: center;
}

.kakaku_block .kakaku_item .icon {
	margin: 0 5px 5px 0;
	padding: 3px 15px;
	background: #C00;
	display: inline-block;
	color: #FFF;
	font-size: 1.2rem;
	font-weight: bold;
}

.kakaku_block .kakaku_item .favorite_btn {
	margin-left: auto;
}

.kakaku_block .kakaku_item .favorite_btn a {
	display: inline-block;
	border: 1px solid #72af2d;
	color: #72af2d;
	font-size: 1.2rem;
	font-weight: bold;
	width: 210px;
	padding: 14px 10px;
	transition: 0.3s;
	position: relative;
	text-decoration: none;
	box-sizing: border-box;
	text-align: center;
	background-position: right 15px center;
	background-repeat: no-repeat;
}

.kakaku_block .kakaku_item .favorite_btn a.btn_favorite_add {
	padding: 10px 40px 10px 10px;
	background-image: url(../../img/common/icon_favolite_add.png) ;
	background-size: 24px auto;
}

.kakaku_block .kakaku_item .favorite_btn a.btn_favorite_check {
	background-image: url(../../img/common/ico-arrow_bl.png) ;
}

.kakaku_block_inner {
	margin-top: 15px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	align-items: center;
}

.kakaku_block .col_txt {
	flex: 1;
}

.kakaku_block .col_txt .select_num {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	align-items: center;
	margin-left: 30px;
}

.kakaku_block .col_txt .matome_block {
	margin-top: 10px;
}

.kakaku_block .col_txt .matome_block .ttl {
	color: #b40d1d;
	font-weight: bold;
}
.kakaku_block .col_btn .btn {
	width: 370px;
}
.kakaku_block .col_btn .btn a {
	text-decoration: none;
}
.kakaku_block .col_btn .btn01 {
	color: #FFF;
	background-color: #ff7f01;
}

.kakaku_block .price {
	margin: 5px 0;
}

.kakaku_block .teiki:before {
	display: none !important;
}

.kakaku_block .price p {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	align-items: center;
	position: relative;
}

.kakaku_block .price span {
	font-size: 1.8rem !important;
}

.kakaku_block .price .icon_price {
	margin-right: 10px;
	padding: 3px 15px;
	border: 1px solid #333;
	display: inline-block;
	font-size: 1.6rem !important;
	font-weight: bold;
}

.kakaku_block .price .txt_price {
	margin-right: 5px;
	font-size: 2.8rem !important;
}

/*.kakaku_block .price p.discount::before {
	width: 100%;
	height: 1px;
	display: block;
	border-top: 1px solid #000;
	position: absolute;
	top: 50%;
	left: -3%;
	content: "";
}*/

.kakaku_block .discount span {
	font-size: 1.8rem !important;
	text-decoration: line-through;
}
.kakaku_block .discount .icon_price {
	font-size: 1.3rem !important;
	text-decoration: none;
}
.kakaku_block .discount .txt_price {
	margin: 0;
	font-size: 2rem !important;
}

.kakaku_block .teiki {
	color: #b40d1d;
}

.kakaku_block .price .member, 
.kakaku_block .price .special {
	color: #b40d1d;
}
.kakaku_block .price .special .icon_price,
.kakaku_block .price .member .icon_price,
.kakaku_block .price .teiki .icon_price {
	border: 1px solid #b40d1d;
}

/* 色・サイズ違い */
.ttl_other {
	margin-top: 40px;
	font-size: 2rem;
	font-weight: bold;
}

.aojiru_contents .ttl_other {
	color: #72af2d;
}

.cola-rich_contents .ttl_other {
	color: #c90567;
}

.health_contents .ttl_other {
	color: #3d62b0;
}

.other_contents .ttl_other {
	color: #d09b60;
}

.kakaku_table .icon {
	margin-bottom: 5px;
	padding: 3px 15px;
	background: #FFF;
	border: 1px solid #C00;
	display: inline-block;
	color: #c00;
	font-size: 1.3rem;
	font-weight: bold;
}

.kakaku_table a {
	text-decoration: none;
}
.kakaku_table .btn01 {
	background-color: #ff7f01;
}

.aojiru_contents .kakaku_table thead th {
	color: #f4f9e8 !important;
}

.cola-rich_contents .kakaku_table thead th {
	background: #fef1f5 !important;
}

.health_contents .kakaku_table thead th {
	color: #f3f6fd !important;
}

.other_contents .kakaku_table thead th {
	color: #f7ede2 !important;
}

.kakaku_table p {
	margin-bottom: 0;
}

.kakaku_table p.member, 
.kakaku_table p.special {
	color: #b40d1d;
}


@media screen and (max-width: 750px) {
	
	.kakaku_block {
		padding: 20px !important;
	}
	
	.kakaku_block .kakaku_item .icon {
		margin-bottom: 0;
		min-height: 39px;
		padding: 0 10px;
		font-size: 1.1rem;
		line-height: 39px;
	}
	
	.kakaku_block .kakaku_item .favorite_btn {
		flex: 1;
	}
	
	.kakaku_block .kakaku_item .favorite_btn a {
		width: 100%;
		max-width: 180px;
		min-height: 39px;
		background-position: right 10px center;
		font-size: 1.1rem;
	}
	
	.kakaku_block .kakaku_item .favorite_btn a.btn_favorite_add {
		padding: 10px 34px 10px 10px;
		background-size: 20px auto;
	}
	
	.kakaku_block .kakaku_item .favorite_btn a.btn_favorite_check {
		padding: 10px 15px 10px 5px;
		background-position: right 5px center;
	}
	
	.kakaku_block_inner {
		display: block;
	}
	
	.kakaku_block .price span {
		font-size: 1.6rem !important;
	}

	.kakaku_block .price .icon_price {
		font-size: 1.4rem !important;
	}

	.kakaku_block .price .txt_price {
		font-size: 2.4rem !important;
	}

	.kakaku_block .discount span {
		font-size: 1.6rem !important;
	}
	
	.kakaku_block .discount .icon_price {
		font-size: 1.1rem !important;
	}
	
	.kakaku_block .discount .txt_price {
		font-size: 1.8rem !important;
	}
	.kakaku_block .col_btn .btn {
		width: 100%;
	}
	.kakaku_block .price p {
		margin: 5px 0;
	}
	
	.kakaku_block .price p.discount::before {
		width: 88%;
		left: -3%;
	}
	
	.kakaku_block .col_txt .select_num {
		margin: 0 0 5px 0;
	}
	
	.kakaku_block .col_txt .matome_block {
		margin: 0 0 10px;
	}

	
	.ttl_other {
		margin-top: 0 !important;
		padding: 20px 10px;
		background: url(/excludes/dmlite/img/contents/cola-rich/ico-arrow_down_pink.png) no-repeat;
		background-position: right 15px center;
		border: 1px solid #c90567;
		font-size: 1.5rem;
		text-align: center;
	}

	.aojiru_contents .kakaku_table td::before {
		color: #f4f9e8 !important;
	}

	.cola-rich_contents .kakaku_table td::before {
		background: #fef1f5 !important;
	}

	.health_contents .kakaku_table td::before {
		color: #f3f6fd !important;
	}

	.other_contents .kakaku_table td::before {
		color: #f7ede2 !important;
	}
	
	.kakaku_table .td_product .ph,
	.kakaku_table .td_product .txt {
		margin: 0 auto !important;
		text-align: center !important;
		color: #c00 !important;
	}
	.kakaku_table .td_product .icon {
		margin: 10px 0 5px 0;
		width: 90px;
	}
	.kakaku_table .td_none::before {
		display: none;
	}
}



/*テーブル（レスポンシブカスタム）
----------------------------------------*/
.table_list_res01 {
	width:100%;
	border-collapse: collapse;
}

.table_list_res01 thead th {
	padding: 15px;
	text-align: center;
	border: 1px solid #dcdcdc;
	background: #f1f8f3;
	font-size: 1.5rem;
}

.table_list_res01 tbody th {
	padding: 15px;
	text-align: center;
	border: 1px solid #dcdcdc;
	background: #f1f8f3;
	font-size: 1.5rem;
}

.table_list_res01 tbody td {
	padding: 15px;
	text-align: center;
	font-size: 1.5rem;
	border: 1px solid #dcdcdc;
	background: #fff;
	word-break: break-all;
}

.table_list_res01 .flex {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	align-items: center;
}

.table_list_res01 .ph {
	width: 90px;
	margin: 0 15px 0 0;
	border: 1px solid #dcdcdc;
}

.table_list_res01 .ph .img_background {
	padding-top: 100%;
	background-position: center center;
	background-repeat: no-repeat;
	-webkit-background-size: contain;
	background-size: contain;
}

.table_list_res01 .txt {
	flex: 1;
	-ms-flex: 1;
	text-align: left;
}

.table_list_res01 .caution_list li {
	margin: 10px 0 0;
}

.table_list_res01 .caution_list li:first-child {
	margin: 0;
}

.table_list_res01 .caution_txt {
	padding: 5px;
	color: #C00;
	font-size: 1.3rem;
	border: 1px solid #C00;
	background-color: #ffe8e8;
}

.table_list_res01 .caution_txt span:before {
	content: "";
	display: inline-block;
	vertical-align: middle;
	width: 16px;
	height: 16px;
	margin: 0 3px 0 0;
	background: url(../img/common/error_img.gif) left center no-repeat;
	-webkit-background-size: 16px auto;
	-moz-background-size: 16px auto;
	-o-background-size: 16px auto;
	background-size: 16px auto;
}

.table_list_res01 .block-btn p {
	margin: 10px 0;
}

.table_list_res01 .btn a {
	text-decoration: none;
}

.table_list_res01 .btn a.btn01 {
	color: #FFF;
}



@media screen and (max-width: 750px) {
	
	.table_list_res01 thead {
		display:none;
	}
	
	.table_list_res01 tbody tr::after {
		width: 100%;
		height: 30px;
		display: block;
		content: "";
	}
	
	.table_list_res01 tbody tr + tr {
		border-top: 1px solid #dcdcdc;
	}
	
	.table_list_res01 tbody th {
		display:block;
		font-size: 1.3rem;
	}
	
	.table_list_res01 tbody td {
		width: 100%;
		display: table;
		padding: 0;
		position: relative;
	}
	
	.table_list_res01 tbody td::before {
		width: 90px;
		content: attr(label);
		display: table-cell;
		vertical-align: middle;
		padding: 15px;
		font-size: 1.3rem;
		border-bottom: 1px solid #dcdcdc;
		border-right: 1px solid #dcdcdc;
		background: #f1f8f3;
	}
	
	.table_list_res01 tbody td.td_must::before {
		padding-top: 30px;
	}
	
	.table_list_res01 tbody .td_must::after {
		margin-right: 3px;
		width: 40px;
		height: 20px;
		background: #C00;
		border-radius: 3px;
		display: inline-block;
		color: #FFF;
		font-weight: bold;
		font-size: 1.1rem;
		letter-spacing: .2rem;
		text-align: center;
		vertical-align: middle;
		line-height: 20px;
		position:absolute;
		top: 10px;
		left: 23px;
		content: "必須";
	}
	
	.table_list_res01 tbody td .td {
		display: table-cell;
		vertical-align: middle;
		padding: 15px;
		text-align: left;
		font-size: 1.3rem;
	}
	
	.table_list_res01 tbody {
		border-top: 1px solid #dcdcdc;
	}
	
	.table_list_res01 tbody td {
		border-top: none;
	}
	
	.table_list_res01 tbody td.th-none::before {
		display: none !important;
	}
	
	.table_list_res01 .product .ph {
		width: 150px;
	}
	
	.table_list_res01 td.sp_ttl {
		border-left:none;
		border-right:none;
		display: block;
		color: #008030;
		font-weight: bold;
	}
	.table_list_res01 td.sp_ttl::before {
		width: 100%;
		padding: 0;
		display: block;
		font-size: 1.4rem;
		border: none;
		background: none;
		text-align: left;
	}
	.table_list_res01 td.sp_ttl .td {
		padding: 0 0 10px 0;
	}
}

/*ポップアップ
--------------------------------------------------------- */
#popup,
#popup_favorite {
	padding: 0;
	z-index: 10;
}

.popup_inner {
	padding: 100px;
	position: relative;
	min-width: 250px;
	max-width: 900px;
	background: #fff;
	text-align: center;
}

.popup_inner h3 {
	margin-bottom:40px;
	font-size: 22px;
}

.popup_inner .btn01 {
	width: 370px;
	text-decoration: none;
	background-color: #ff7f01 !important;
	color: #FFF;
}

.popup_close {
	position: absolute;
	top: -12px;
	right: -12px;
	display: none;
}
#cboxOverlay {
	width: 100%;
	min-height: 100%;
	background: #000;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 10001;
}

#colorbox {
	padding-top: 30px;
	z-index: 10002;
	left: 0 !important;
	right: 0 !important;
	overflow: visible !important;
}

#colorbox,
#colorbox,
#cboxWrapper,
#cboxContent,
#cboxLoadedContent {
	margin: auto;
}

.fwCmsColorbox #cboxContent {
margin-top: 30px !important;
} 

#cboxLoadedContent {
	padding: 0;
	overflow: auto;
	max-width: 1100px !important;
}

#cboxClose {
	width:24px;
	height:24px;
	display: block !important;
	position:absolute;
	top: -30px !important;
	right: 0 !important;
	background:url(/excludes/dmlite/img/common/ico-btn_close_02.png) no-repeat;
	text-indent: -9999px;
	z-index: 100;
}

/* カートレコメンド商品表示 */
.box_recommend {
	margin-top: 50px;
	border-top: 1px solid #CCC;
}
.box_recommend h4 {
	margin: 45px 0;
	font-size: 34px;
	font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", serif;
	text-align: center;
}
.box_recommend .recommend_inner {
	margin-top: 40px;
	display: flex;
}
.box_recommend .recommend_inner .ph {
	width: 228px;
	height: 228px;
	margin: 0 30px 0 0;
	border: 1px solid #dcdcdc;
}

.box_recommend .recommend_inner .ph .img_background {
	padding-top: 100%;
	background-position: center center;
	background-repeat: no-repeat;
	-webkit-background-size: contain;
	background-size: contain;
}
.box_recommend .recommend_inner .txt {
	margin-left: 20px;
	text-align: left;
	flex: 1;
}
.box_recommend .recommend_inner .txt .ttl_recommend {
	margin-bottom: 20px;
	font-size: 22px;
}
.box_recommend .recommend_inner .txt p {
	font-size: 16px;
	font-weight: normal;
}
.box_recommend .recommend_inner .txt .btn {
	margin: 30px 0 0;
}
.box_recommend .recommend_inner .txt .btn .btn_line01 {
	color: #72af2d;
	text-decoration: none;
}

/* iframe用 */
#container_modal {
	width: 100%;
}
#container_modal #wrapper {
	width: 90%;
	margin: 0 auto;
}
#container_modal .pager01 a {
	padding: 0 10px;
}
#colorbox iframe {
	width: 100%;
	height: 100%;
	display: block;
}
/*
body.scroll_fix {
	overflow: hidden;
}*/
	
@media screen and (min-width: 751px) {
	/*#cboxLoadedContent {
		overflow: hidden !important;
	}*/
}
@media screen and (max-width: 750px) {
	/*body.scroll_fix {
		position: fixed;
	}*/
	
	#colorbox {
		min-width: initial;
	}
	
	#cboxLoadedContent {
		overflow: auto !important;
		-webkit-overflow-scrolling: touch;
	}
	
	.popup_inner {
		padding: 25px;
	}

	.popup_inner .btn,
	.popup_inner .btn a {
		width: 100%;
		min-height: 45px !important;
		height: 45px !important;
	}
	
	.popup_inner .btn01 {
		width: 100%;
	}
	
	.popup_inner h3 {
		margin-bottom:20px;
		font-size: 16px;
	}

	.popup_inner .btn a {
		width: 100%;
		height: 45px;
	}
	
	.box_recommend {
		margin-top: 20px;
	}

	.box_recommend h4 {
		margin: 12px 0;
		font-size: 18px;
	}

	.box_recommend .recommend_inner {
		margin: 0;
		align-items: center;
	}

	.box_recommend .recommend_inner .ph {
		width: 90px;
		height: 90px;
		margin: 0 auto;
	}

	.box_recommend .recommend_inner .txt {
		
	}

	.box_recommend .recommend_inner .txt .ttl_recommend {
		margin-bottom: 10px;
		font-size: 14px;
	}

	.box_recommend .recommend_inner .txt p {
		font-size: 14px;
		font-weight: normal;
	}
	
	.box_recommend .recommend_inner .txt .btn {
		margin: 0;
		min-height: auto !important;
		height: auto !important;
		background: url(/excludes/dmlite/img/common/link_icon_03.gif) 0 50% no-repeat;
		padding-left: 17px;
		border: none;
		color: #2B1D13;
	}
	.box_recommend .recommend_inner .txt .btn .btn_line01 {	
		padding: 0;
		height: auto !important;
		min-height: auto !important;
		background: none;
		border: none !important;
		color: #2B1D13;
		text-align: left !important;
	}

	#cboxClose {
		width: 100%;
		height: 50px;
		position: relative;
		background: rgba(0,0,0,.8) url(/excludes/dmlite/img/common/ico-btn_close_03.png) center no-repeat;
		background-size: auto 14px;
		top: auto !important;
		bottom: 0 !important;
		right: 0 !important;
		text-align: center;
	}
}


/*バナー
--------------------------------------------------------- */
/* ボトムバナー */
.bottom_banner_recommend {
	position: fixed;
	right: 0;
	bottom: 0;
	z-index: 1;
}
.bottom_banner_recommend .banner_inner {
	padding: 20px;
	background: #FFF;
	box-shadow:0px 0px 15px 3px rgba(0,0,0,.3);
}
.bottom_banner_recommend .banner_inner p {
	margin-top: 10px;
	font-weight: normal;
}
.bottom_banner_recommend .btn_close {
	width: 24px;
	height: 24px;
	background: url(/excludes/dmlite/img/common/ico-btn_close_02.png) no-repeat;
	position: absolute;
	top: -35px;
	right: 10px;
	cursor: pointer;
}
@media screen and (max-width: 750px) {
	.bottom_banner_recommend .banner_inner {
		padding: 15px 15px 65px;
		background: rgba(0,0,0,.8);
		box-shadow: none;
		color: #FFF;
	}
	.bottom_banner_recommend .btn_close {
		width: 100%;
		height: 50px;
		top: auto;
		bottom: 0;
		right: 0;
		background: rgba(0,0,0,.6) url(/excludes/dmlite/img/common/ico-btn_close_03.png) center no-repeat;
		background-size: auto 14px;
	}
}



/*お知らせ
--------------------------------------------------------- */
.important_block {
	width: 1000px;
	margin: 30px auto;
	background: #f2f2f2;
	padding: 20px;
}

.news_list {
	overflow: hidden;
	font-weight: bold;
}

.news_list dt {
	margin-right: 12px;
	float: left;
}

.news_list dd {
	overflow: hidden;
}

.news_list .date {
	vertical-align:middle;
}

.news_list .cate {
	margin-right: 10px;
	padding: 3px 0 2px;
	width: 90px;
	display: inline-block;
	color: #FFF;
	font-size: 1.2rem;
	text-align: center;
	vertical-align:middle;
}

.news_list .cate.icon_01 {
	background: #02b9a2;
}

.news_list .cate.icon_02 {
	background: #dc0606;
}

.news_list .cate.icon_03 {
	background: #f9bd03;
}

.news_list .cate.icon_04 {
	background: #008030;
}



@media screen and (max-width: 750px) {
	
	.important_block {
		width: 91%;
		margin: 10px auto 15px;
		padding: 10px;
	}
	.news_list dt {
		float: none;
	}
	.news_list .cate {
		padding: 3px 0;
	}
	
	.news_list a {
		/*margin-top: 5px;*/
		display: block;
	}
	
}




ul.news_list {
	border-top: 1px solid #d2d2d2;
}

.news_list li {
	padding: 20px 0;
	border-bottom: 1px solid #d2d2d2;
	font-size: 1.6rem;
}

.news_list li .date {
	margin-right: 12px;
	vertical-align:middle;
}

.news_list .cate.icon_01 {
	background: #02b9a2;
}

.news_list .cate.icon_02 {
	background: #dc0606;
}

.news_list .cate.icon_03 {
	background: #f9bd03;
}

.news_list .cate.icon_04 {
	background: #008030;
}



@media screen and (max-width: 750px) {
	
	.news_list li {
		padding: 15px 0;
		font-size: 1.4rem;
	}
	.news_list a {
		margin-top: 5px;
		display: block;
	}
	
}