@charset "utf-8";
/*
Theme Name:NOEL child
Theme URI:
Description:WordPressテーマ「NOEL」の自作子テーマです。
Template:noel_tcd072
Author:Design Plus
Author URI:http://design-plus1.com/tcd-w/
Version:1.3
Text Domain:tcd-w
*/

/*
.pc #side_col {
	float: right;
}

.pc #main_col {
	float: left;
}
*/

/*ヘッダー*/
#header_button .button a {
	border-radius: 50px;
}

#header_button .button+.button {
	margin-left: 15px;
}

#header_logo img {
	width: auto;
	height: 50px;
}

#header_logo .mobile_logo_image {
    width: auto;
	height: 32px;
}

.header_desc {
	position: absolute;
    left: 250px;
    top: 50%;
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    z-index: 30;
	font-size: 14px;
	color: #727171;
}

#header_button {
	top: 15px;
	transition: transform none;
	-webkit-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0);
}

/*フッター*/
.footer_menu_cnt {
	width: 50%;
	padding: 60px 20px 40px 20px;
	box-sizing: border-box;
}

.footer_menu_cnt .footer_headline {
    font-size: 20px;
    font-weight: bold;
    margin: 0 0 25px 0;
}

.footer_menu_cnt ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -ms-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
}

.footer_menu_cnt li {
	width: 33.33%;
	padding-right: 10px;
    margin: 0 0 20px 0;
    font-size: 14px;
    line-height: 1.5;
    box-sizing: border-box;
}

/*サイド*/
.side_headline {
	line-height: 1.4;	
}

/*共通*/
a.btn {
	-webkit-transition-property: opacity;
    -webkit-transition-duration: 0.2s;
    -webkit-transition-timing-function: ease;
	transition-property: opacity;
    transition-duration: 0.2s;
    transition-timing-function: ease;
}

a.btn:hover {
	opacity: 0.8;
}

#searchform .submit_button:before {
	color: #fa7c92;
}

#post_title_area {
	border-left: none;
	padding-left: 0;
	padding-right: 0;
}

.page_ttl {
	font-size: 24px;
	font-weight: bold;
    margin: 0 0 50px 0;
    border-top: 1px solid #ddd;
    border-bottom: 1px solid #ddd;
    padding: 20px 0;
    color: #fa7c92;
    text-align: center;
}

.top_sub_ttl {
	font-size: 20px;
	font-weight: bold;
    margin: 0 0 40px 0;
    border-top: 1px solid #ddd;
    border-bottom: 1px solid #ddd;
    padding: 20px 0;
    color: #fa7c92;
    text-align: center;
}

.page_sub_ttl {
	font-size: 20px;
    margin: 0 0 40px 0;
    border-left: 3px solid #000;
    padding: 10px 0 10px 15px;
    border-color: #fa7c92;
}

.styled_post_list1 li+li {
	border-top: 1px solid #ddd;
}

.styled_post_list1 a {
	height: auto;
	padding: 10px 0;
}

.styled_post_list1 .image_wrap {
	width: 80px;
	height: 80px;
}

.styled_post_list1 .image {
	height: 80px!important;
}

.styled_post_list1 .title_area {
	width: calc(100% - 80px);
    height: 80px;
	border: none;
}

.styled_post_list1 li:last-child .title_area {
    border-bottom: none;
}

/*トップページ*/
body.home .search {
	background-color: #f2eee2;
	padding: 50px 0;
	margin-bottom: 50px;
}

body.home .search_inner {
	width: 1182px;
    margin: 0 auto;
}

body.home #top-searchform {
    border: 1px solid #ddd;
    background: #fff;
    height: 50px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

body.home #top-searchform label {
    display: none;
}

body.home #top-searchform #s {
    border: none;
    background: none;
    padding: 0 10px;
    margin: 0;
    width: calc(100% - 50px);
    height: 50px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

body.home #top-searchform .submit_button {
    position: relative;
    width: 50px;
    height: 50px;
    float: right;
    top: -1px;
}

body.home #top-searchform .submit_button:before {
    text-indent: 0;
    display: block;
    width: 50px;
    height: 50px;
    line-height: 50px;
    text-align: center;
    cursor: pointer;
    z-index: 1;
    position: absolute;
    font-family: 'design_plus';
    color: #fa7c92;
    font-size: 18px;
    content: '\e915';
    right: 0px;
    top: 1px;
}

body.home #top-searchform #searchsubmit {
    border: none;
    background: none;
    width: 50px;
    height: 50px;
    z-index: 200;
    position: relative;
    cursor: pointer;
    display: block;
    text-indent: -300px;
    overflow: hidden;
}

body.home .search_btn {
	width: 100%;
	margin-top: 30px;
	display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    justify-content: space-between;
}

body.home .search_btn a {
	-webkit-transition-property: opacity;
    -webkit-transition-duration: 0.2s;
    -webkit-transition-timing-function: ease;
    transition-property: opacity;
    transition-duration: 0.2s;
    transition-timing-function: ease;
	display: block;
	width: 30%;
	height: 50px;
	line-height: 50px;
	border-radius: 10px;
	background-color: #fa7c92;
	font-size: 14px;
	text-align: center;
	color: #fff;
}

body.home .search_btn a:hover {
	opacity: 0.8;
}

body.home .top_desc {
	font-size: 16px;
	text-align: center;
	color: #727171;
	margin-bottom: 50px;
}

body.home .related {
	width: 1182px;
    margin: 80px auto 100px;
    padding: 0;
    border: none;
}

body.home .related_block+.related_block {
	margin-top: 50px;
}

body.home .index_cb_button a,
.btn_youtube a {
	-webkit-transition-property: opacity;
    -webkit-transition-duration: 0.2s;
    -webkit-transition-timing-function: ease;
    transition-property: opacity;
    transition-duration: 0.2s;
    transition-timing-function: ease;
    min-width: 350px;
    max-width: 100%;
    height: 50px;
    line-height: 50px;
    margin-top: 30px;
	background: #fa7c92;
	border-radius: 10px;
	font-size: 15px;
}

body.home .index_cb_button a:hover,
.btn_youtube a:hover {
	opacity: 0.8;
}

/*商品一覧*/
#blog_list {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -ms-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
}

#blog_list .item {
    width: calc(25% - 15px);
    margin-left: 20px;
    height: auto;
    float: none;
    position: relative;
}

#blog_list .item:nth-child(4n+1) {
    margin-left: 0;
}

#blog_list .item:nth-child(n+5) {
    margin-top: 25px;
}

#blog_list .title_area {
	height: auto;
	padding: 0;
	margin-top: 15px;
	border: none!important;
}

#blog_list .image_wrap {
    width: 120px;
    height: 0;
    padding-top: 120px;
    display: block;
    position: relative;
    z-index: 1;
    overflow: hidden;
    margin: 0 auto;
}

#blog_list .image {
    width: 100%;
    height: 100%!important;
    display: block;
    overflow: hidden;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
}

#blog_list .title_area .date {
    line-height: 2;
}

#blog_list .title_area .title {
    font-size: 16px;
}

/*商品詳細*/
.product_info {
	width: 100%;
	margin-bottom: 50px;
	display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    justify-content: space-between;
}

.product_info a {
	color: #fa7c92;
	text-decoration: underline;
}

.product_info a:hover {
	text-decoration: none;
}

.product_info .product_info_left {
	width: 180px;
}

.product_info .product_info_right {
	width: calc(100% - 230px);
}

.product_tbl {
	width: 100%;
}

.product_tbl tr+tr {
	border-top: 1px solid #ddd;
}

.product_tbl th {
	width: 120px;
	padding: 10px 0;
	text-align: left;
	vertical-align: top;
	font-size: 14px;
	font-weight: normal;
	line-height: 1.5;
}

.product_tbl td {
	padding: 10px 0;
	text-align: left;
	vertical-align: top;
	font-size: 14px;
	font-weight: normal;
	line-height: 1.5;
}

.item_desc {
	margin: 50px 0;
}

.item_desc .cnt {
	font-size: 16px;
	line-height: 1.5;
}

.btn_sec {
	margin: 50px 0;
}

#btn_sec_2 {
	margin: 80px 0;
}

.btn_sec .btn_buy {
	width: 100%;
	display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    justify-content: space-between;
}

.btn_sec .btn_buy a {
	display: block;
	width: 30%;
	height: 50px;
	line-height: 50px;
	font-size: 14px;
	color: #fff;
	border-radius: 10px;
	text-align: center;
}

.btn_sec .btn_buy a.btn_amazon {
	background: #f9aa46;
}

.btn_sec .btn_buy a.btn_rakuten {
	background: #b31b22;
}

.btn_sec .btn_buy a.btn_yahoo {
	background: #ff2748;
}

.mouth {
	margin-top: 80px;
}

.mouth_info-block {
	width: 100%;
	display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -ms-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
}

.mouth_info-block .mouth_info {
	width: 33.33%;
	padding: 40px 20px;
	box-sizing: border-box;
	border-bottom: 1px solid #ddd;
	border-left: 1px solid #ddd;
}

.mouth_info-block .mouth_info:nth-child(3n+1) {
	border-left: none;
}

.mouth_info-block .mouth_info .name {
	width: 100%;
	height: 100px;
	text-align: center;
	border: 1px solid #fa7c92;
	display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    align-items: center;
    justify-content: center;
}

.mouth_info-block .mouth_info .name p {
	font-size: 16px;
	line-height: 1.5;
	color: #fa7c92;
}

.mouth_info-block .mouth_info .link a {
	display: block;
	width: 100%;
	height: 30px;
	line-height: 30px;
	font-size: 14px;
	color: #fff;
	border-radius: 6px;
	text-align: center;
	background-color: #fa7c92;
	margin-top: 15px;
}

.mouth_info-block .mouth_info .link a.no {
	opacity: 0.4;
	pointer-events: none;
}

.mouth_ave {
	text-align: center;
	padding: 15px 0;
	font-size: 14px;
	border-bottom: 1px solid #ddd;
}

.mouth_ave .mouth_icon {
	display: inline-block;
	font-size: 20px;
	color: #ffd278;
	margin-right: 5px;
}

.mouth_ave .mouth_ave_num {
	display: inline-block;
	font-size: 20px;
	font-weight: bold;
	color: #fa7c92;
}

.news {
	margin-top: 80px;
}

.news > div+div {
	margin-top: 50px;
}

.news .no_date {
	font-size: 14px;
}

.news_list {
	border-top: 1px solid #ddd;
}

.news_list li {
	border-bottom: 1px solid #ddd;
}

.news_list li a {
	display: block;
	padding: 15px 0;
	box-sizing: border-box;
	font-size: 16px;
}

.news_list li .date {
	font-size: 14px;
	color: #999;
	line-height: 1.5;
}

.news_list li .ttl {
	line-height: 1.5;
}

.youtube{
	margin-top: 80px;
}

.youtube .youtube_cnt_block {
	width: 100%;
	display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -ms-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
}

.youtube .youtube_cnt {
	width: calc(50% - 15px);
	margin-left: 30px;
}

.youtube .frame-wrapper {
	position: relative;
	width: 100%;
	height: 0;
	padding-bottom: 56.25%;
	overflow: hidden;
}

.youtube .youtube_cnt:nth-child(2n+1) {
	margin-left: 0;
}

.youtube .youtube_cnt:nth-child(n+3) {
	margin-top: 30px;
}

.youtube .frame-wrapper iframe {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

.youtube .frame-wrapper a {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

.related {
	margin-top: 80px;
	padding-top: 50px;
	border-top: 1px solid #ddd;
}

.related-list {
	width: 100%;
	display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -ms-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
}

.related-list li {
	width: calc(20% - 16px);
	margin-left: 20px;
	display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -ms-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
}

.related-list li:nth-child(5n+1) {
	margin-left: 0;
}

.related-list li a {
    display: block;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.related-list li .image_wrap {
    width: 90px;
    height: 0;
    padding-top: 90px;
    display: block;
    position: relative;
    z-index: 1;
    overflow: hidden;
    margin: 0 auto;
}

.related-list li .image {
    width: 100%;
    height: 100%;
    display: block;
    overflow: hidden;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
}

.related-list li .title_area {
    width: 100%;
    border: none;
    margin-top: 15px;
}

.related-list li a:hover .title_area {
    color: #fa7c92;
}

.related-list li .date {
    font-size: 12px;
    color: #999;
    line-height: 2;
}

.related-list li .title {
    font-size: 14px;
    line-height: 1.6;
    max-height: 4.8em;
    font-weight: 500;
    word-break: break-all;
    overflow: hidden;
    -webkit-transition-property: color;
    -webkit-transition-duration: 0.2s;
    -webkit-transition-timing-function: ease;
    transition-property: color;
    transition-duration: 0.2s;
    transition-timing-function: ease;
}

/*ブランドから探す*/
.brand_cnt+.brand_cnt {
	margin-top: 120px;
}

.brand-list {
	list-style-type: none;
    padding: 0;
    margin: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -ms-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: space-between;
}

.brand-search {
	display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -ms-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-bottom: 50px;
}

.brand-info-ttl {
	font-size: 20px;
    margin: 0 0 0 0;
    border-bottom: 2px solid #ddd;
    padding: 0 0 20px 0;
    font-weight: normal;
}

.brand-search li {
	width: calc((10%-1px));
	height: 30px;
	box-sizing: border-box;
	/*
	margin: 0 5px;
	padding: 0 5px;
	*/
	font-size: 14px;
	border-left: 1px solid #ddd;
}

.brand-search li:nth-child(10n),
.brand-search li:last-child {
	border-right: 1px solid #ddd;
}

.brand-search li:nth-child(n+11) {
	margin-top: 15px;
}

.brand-search li a {
	display: block;
	width: 100%;
	height: 100%;
	line-height: 30px;
	text-align: center;
	font-size: 16px;
}

.brand-list-block div+div {
	margin-top: 80px;
}

.brand-list li {
	width: calc((100% - 20px) / 2);
    border-bottom: 1px solid #ddd;
}

.brand-list li a {
	font-size: 16px;
    display: block;
    width: 100%;
    height: 100%;
    padding: 15px 0;
    box-sizing: border-box;
}

/*カテゴリーから探す*/
.category-list {
	list-style-type: none;
    padding: 0;
    margin: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -ms-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: space-between;
}

.category-list > li {
	width: calc((100% - 20px) / 2);
}

.category-list > li:nth-child(n+3) {
	margin-top: 80px;
}

.category-list li > a {
	font-size: 14px;
    display: block;
    width: 100%;
    padding: 15px 30px 15px 0;
    box-sizing: border-box;
}

.category-list > li > a {
	font-size: 20px;
    margin: 0 0 0 0;
    border-bottom: 2px solid #ddd;
    padding: 0 0 20px 0;
    font-weight: normal;
}

.category-list > li > ul {
}

.category-list > li > ul ul {
	display: none;
    margin-left: 15px;
}

.category-list > li > ul ul li:last-child {
    border-bottom: none;
}

.category-list ul li {
    border-bottom: 1px solid #ddd;
}

.category-list .has-child > a {
	position: relative;
}

.category-list .has-child > a::before,
.category-list .has-child > a::after{
	position: absolute;
	top: -2px;
	bottom: 0;
	right: 0;
	margin: auto;
	content: "";
	vertical-align: middle;
}
.category-list .has-child > a::before{
	right: 15px;
	width: 4px;
	height: 4px;
	border-top: 2px solid #fa7c92;
	border-right: 2px solid #fa7c92;
	-webkit-transform: rotate(135deg);
	transform: rotate(135deg);
}

.category-list .has-child > a.open::before,
.category-list .has-child > a.open::after{
	top: 3px;
}
.category-list .has-child > a.open::before{
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}

.category-list a.no-link {
	pointer-events: none;
}