@charset "utf-8";

/* +++++++++++++++++++++++++　header */

#common-header{
	font-size:14px;
	line-height:2em;
	position:relative;
}
#common-header .content-area{
	padding-right:60px;
}
#common-header #header-subnavi{
	padding: 8px 0;
	border-bottom: solid 1px #CACACA;
}
#common-header #header-subnavi ul{
	justify-content: flex-end;
}
#common-header #header-subnavi li{
	display:inline-block;
	padding:6px 16px;
	border-left: solid 1px #DCDCDC;
	font-size:12px;
	line-height:1;
	letter-spacing:0.06em;
}
#common-header #header-subnavi li:last-child{
	border-right: solid 1px #DCDCDC;
}
#common-header #header-subnavi li a{
	display:inline-block;
	text-decoration:none;
}

#common-header #header-subnavi li.online-shop{
	background:url(/img/common/icon_cart.png) no-repeat 10px -3px;
	padding: 6px 16px 6px 38px;
}
/* 25.07.07 search add */
#common-header #header-subnavi .megamenu .headerNavList__link {
	padding-right: 20px;
}
#common-header #header-subnavi .megamenu .headerNavList__link::before {
	content: "";
	position: absolute;
	width: 7px;
	height: 7px;
	border-top: solid 1px rgba(0, 0, 0, 0.5);
	border-right: solid 1px rgba(0, 0, 0, 0.5);
	right: 2px;
	top: 50%;
	transform: translate(0, -50%) rotate(135deg);
	margin-top: -2px;
}
#common-header #header-subnavi .megamenu .hover-menu {
	background-color: rgba(255, 255, 255, 0.95);
	left: 0;
	top: 48px;
	height: 0;
	overflow: hidden;
	position: absolute;
	text-align: center;
	transition: height 0.5s;
	width: 100%;
}
#common-header #header-subnavi .megamenu .hover-menu.searchArea {
	display: flex;
	align-items: center;
	width: 100%;
	z-index: 1000;
}
#common-header #header-subnavi .megamenu .hover-menu .search {
	border-bottom: 1px solid #ccc;
}
#common-header #header-subnavi .megamenu .hover-menu .search .mf-search-box .mf-search-bar .mf-search-bar_input {
	height: 50px;
	padding: 0 14px;
	border: none;
}
#common-header #header-subnavi .megamenu .hover-menu .search .mf-search-box .mf-search-bar .mf-search-bar_button {
	width: 50px;
	height: 50px;
	position: relative;
	background-color: transparent;
}
#common-header #header-subnavi .megamenu .hover-menu .search .mf-search-box .mf-search-bar .mf-search-bar_button::before {
	position: absolute;
	content: "";
	background-image: url(/img/common/icon_search.svg);
	background-size: contain;
	background-repeat: no-repeat;
	width: 20px;
	height: 20px;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
}
#common-header #header-subnavi .megamenu .hover-menu .search .mf-search-box .mf-search-bar .mf-search-bar_button svg {
	display: none;
}
#common-header #header-subnavi .megamenu .hover-menu .search .mf-search-box .mf-search-bar .mf-search-bar_button span {
	display: none;
}
#common-header #header-subnavi .megamenu .hover-menu .search .searchButton {
	width: 50px;
	height: 50px;
	position: relative;
}
#common-header #header-subnavi .megamenu .hover-menu .search .searchButton::before {
	position: absolute;
	content: "";
	background-image: url(/img/common/icon_search.svg);
	background-size: contain;
	background-repeat: no-repeat;
	width: 20px;
	height: 20px;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
}

#common-header #header-subnavi .headerNavList.active .hover-menu {
	padding-bottom: 64px;
}
#common-header #header-subnavi .headerNavList.active .hover-menu.searchArea {
	height: 60px;
	padding-bottom: 0;
}
#common-header #header-subnavi .headerNavList.active .hover-menu.searchArea .wrapper {
	max-width: 1136px;
	margin: 0 auto;
	width: 90%;
}
#common-header #header-subnavi .headerNavList + .headerNavList {
	margin-left: 32px;
}
@media screen and (max-width: 1330px) {
	#common-header #header-subnavi .headerNavList + .headerNavList {
		margin-left: 15px;
		padding-left: 15px;
	}
}
#common-header #header-subnavi .headerNavList .headerNavList__link {
	font-size: 13px;
	position: relative;
}
#common-header #header-subnavi .headerNavList .headerNavList__link:hover {
	cursor: pointer;
	opacity: 1;
}
#common-header #header-subnavi .headerNavList .headerNavList__link:hover::after {
	opacity: 1;
	transform: scale(1, 1); /*ホバー後、x軸方向に1（相対値）伸長*/
}
#common-header #header-subnavi .headerNavList .headerNavList__link:after {
	position: absolute;
	content: "";
	width: 100%;
	height: 1px;
	border-radius: 2px;
	bottom: -4px;
	left: 0;
	background-color: #9BA482;
	opacity: 0;
	transform: scale(0, 1);
	transform-origin: left top; /*変形（アンダーラインの伸長）の原点がaタグ（各メニュー）の右端*/
	transition: all 0.3s; /*変形の時間*/
}
#common-header #header-subnavi .headerNavList .headerNavList__link.search {
	width: 20px;
	height: 20px;
	display: block;
}
#common-header #header-subnavi .headerNavList .headerNavList__link.search::before {
	position: absolute;
	content: "";
	background-image: url(/img/common/icon_search.svg);
	background-size: contain;
	background-repeat: no-repeat;
	width: 16px;
	height: 16px;
	top: 0;
	left: 0;
	border: none;
	transform: none;
	margin-top: -2px;
}
#common-header #header-subnavi .headerNavList .headerNavList__link.search::after {
	display: none;
}
/* 25.07.07 search add */

#common-header #header-inner{
	display: flex;
	flex-wrap: nowrap;
	padding-top: 40px;
	padding-bottom: 40px;
	/* padding-right: 100px; */
}
#common-header #header-logo{
}
#common-header #header-logo a{
	display:block;
	text-decoration:none;
}
#common-header #header-logo a .logoText{
	font-size: 14px;
}
#common-header #header-logo img{
	display: block;
	margin-top: -13px;
}
#common-header #header-navi{
	width:960px;
	padding-left: 20px;
}
#common-header #header-navi .flex-ce{
	flex-wrap: nowrap;
}
#common-header #header-navi .flex-ce .otherlink {
	display: flex;
	flex-wrap: nowrap;
}
#common-header #header-navi .flex-ce .otherlink a {
	width: 70px;
	height: 70px;
	font-size: 9px;
	text-align: center;
	border-radius: 3px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: -28px 5px 0;
}
#common-header #header-navi .flex-ce .otherlink a.corp {
	background-color: #F0F0F0;
	color: #282828;
}
#common-header #header-navi .flex-ce .otherlink a.online {
	background-color: #2C2C2C;
	color: #fff;
}
#common-header #header-navi .flex-ce .otherlink a span {
	position: relative;
	padding-top: 25px;
	line-height: 1.2;
}
#common-header #header-navi .flex-ce .otherlink a span::before {
	position: absolute;
	content: "";
	background-size: contain;
	background-repeat: no-repeat;
	top: 0;
	left: 50%;
	transform: translate(-50%, 0);
}
#common-header #header-navi .flex-ce .otherlink a.corp span::before {
	background-image: url(/img/common/icon_corp.svg);
	width: 20px;
	height: 20px;
}
#common-header #header-navi .flex-ce .otherlink a.online span::before {
	background-image: url(/img/common/icon_online.svg);
	width: 24px;
	height: 20px;
}
#common-header #header-navi a{
	display:block;
	text-align:center;
	line-height:1;
	text-decoration:none;
	letter-spacing:0.07em;
}
#common-header #header-navi a .jp{
	display:block;
	font-size:18px;
	margin-top: 4px;
	margin-bottom:8px;
}
#common-header #header-navi a .en{
	display:block;
	font-size:12px;
	font-family: 'Century Gothic', serif;
}

#common-header #favorite-link{
	position:absolute;
	top:0;
	right:50%;
	margin-right:-600px;
}
#common-header #favorite-link a{
	display:block;
	width:70px;
	height:125px;
	padding-top:72px;
	background-color:#EDD8D8;
	font-size:12px;
	line-height:1;
	text-decoration:none;
	text-align:center;
	font-family: 'Century Gothic', "Yu Gothic",YuGothic,"Hiragino Sans","ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","メイリオ", Meiryo,"ＭＳ Ｐゴシック",Osaka,Arial,Verdana, serif,sans-serif;
}
#common-header #favorite-link a span{
	display:inline-block;
	padding-top:30px;
	background: url(https://www.karimoku.co.jp/img/common/icon_favorite.png) no-repeat center top;
}


/* +++++++++++++++++++++++++　footer */

#page-top{
	position:fixed;
	right:0;
	bottom:100px;
}

#common-footer{
	font-size:14px;
	line-height:2em;
	margin-top:150px;
	background-color:#ECEBEA;
}
#common-footer a{
	color:#282828;
}

#common-footer .footer-ttl{
	margin-bottom:30px;
	color:#999397;
	font-size:18px;
	letter-spacing:0.2em;
	text-align:center;
	font-family: 'Century Gothic', serif;
	
}


#common-footer #footer-blog{
	width:600px;
	padding:40px 20px;
	border-right: solid 1px #fff;
}
#footer-blog .blog-list li{
	margin-bottom:10px;
	margin-right: 9px;
}
#footer-blog .blog-list li:nth-of-type(3n){
	margin-right: 0;
}
#common-footer #footer-sns{
	width:600px;
	padding:40px 10px 40px 40px;
}
#footer-sns .sns-list li{
	padding:0 5px;
	text-align:center;
	font-size:11px;
	line-height:1.3;
}
#footer-sns .sns-list li img{
	margin-bottom:5px;
}
#footer-sns .sns-list li a{
	text-decoration:none;
}


#common-footer #footer-sitemap{
	border-top: solid 1px #fff;
	padding-top:50px;
	margin-bottom:40px;
}
#common-footer #footer-sitemap .content-area .footer-logo {
	position: relative;
	display: block;
	text-decoration: none;
}
#common-footer #footer-sitemap .content-area .footer-logo .logoText {
	font-size: 14px;
	margin-left: 5px;
}
#common-footer #footer-sitemap .sitemap{
	margin-bottom:50px;
}
#common-footer #footer-sitemap .sitemap ul{
	margin-right:50px;
}
#common-footer #footer-sitemap .sitemap li{
	margin-bottom:10px;
	font-weight:bold;
}
#common-footer #footer-sitemap .sitemap li.second a{
	font-weight: normal;
	text-decoration:none;
}
#common-footer #footer-lang{
	justify-content: flex-end;
}
#common-footer #footer-lang li{
	margin-left:5px;
}
#common-footer #footer-lang a{
	display:inline-block;
	min-width:145px;
	padding:3px 10px 3px 50px;
	font-weight: normal;
	letter-spacing:0.2em;
	text-decoration:none;
	color:#fff;
	background: url(https://www.karimoku.co.jp/img/common/icon_lang.png) no-repeat left 10px center #A29D95;
}

#common-footer #footer-subnavi{
	padding-bottom:50px;
}
#common-footer #footer-subnavi ul{
}
#common-footer #footer-subnavi ul li{
	margin-right:30px;
}
#common-footer #footer-subnavi ul a{
	text-decoration:none;
}

/* ドロップダウンメニュー */
#common-header #header-navi .dropdown-menu {
	position: relative;
}

#common-header #header-navi .dropdown-submenu {
	transform: translateX(-50%) scaleY(0);
	transform-origin: center top;
	transition: transform 0.3s ease;
	position: absolute;
	top: 100%;
	left: 50%;
	width: 160px;
	background-color: #E9EDED;
	z-index: 1000;
	padding: 0;
	list-style: none;
	margin: 0;
	margin-top: 2px;
}

/* ホバー時の表示 - 重要 */
#common-header #header-navi .dropdown-menu:hover .dropdown-submenu,
#common-header #header-navi .dropdown-submenu:hover {
	transform: translateX(-50%) scaleY(1);
}

#common-header #header-navi .dropdown-submenu li {
	width: 100%;
	margin: 0;
	padding: 0;
	border-bottom: 1px solid #DCDCDC;
	position: relative;
	transition: all 0.3s ease;
}

#common-header #header-navi .dropdown-submenu li:last-child {
	border-bottom: none;
}

#common-header #header-navi .dropdown-submenu li:hover {
	background-color: #f8f9fa;
}

#common-header #header-navi .dropdown-submenu a {
	display: block;
	padding: 20px 20px !important;
	font-size: 14px;
	line-height: 1.4;
	color: #333;
	text-align: center;
	transition: background-color 0.3s ease;
	text-decoration: none;
	font-weight: normal;
	letter-spacing: 0.05em;
	box-sizing: border-box;
}

#common-header #header-navi .dropdown-submenu a:hover {
	color: #333;
	background-color: transparent;
}

/* ドロップダウンメニューのリンクに確実にpaddingを適用 */
#common-header #header-navi ul.dropdown-submenu li a {
	padding: 20px 20px !important;
	margin: 0 !important;
	border: none !important;
	color: #333 !important;
}


