@charset "utf-8";

/* index
-------------------------------------------------------*/
img {
	width: inherit;
}
#module_breadcrumbs {
    padding: 15px 13px 0;
}
.ttl01 {
	font-size: 2rem;
	font-weight: bold;
	text-align: center;
	margin: 0 0 40px;
	padding: 0 0 20px;
	position: relative;
}
.ttl01::after {
	position: absolute;
	display: block;
	content: "";
	background: #c30000;
	width: 60px;
	height: 3px;
	right: 50%;
	bottom: 0;
	transform: translate(50%,0);
}
.ttl02 {
	font-size: 1.875rem;
	text-align: center;
	margin: 0 0 30px;
}
.ttl03 {
	font-size: 1.625rem;
	font-weight: bold;
	text-align: center;
	margin: 0 0 30px;
}


.product_list .arrow_red::before {
	position: absolute;
	display: block;
	content: "";
	background: url("../img/common/arrow_red.png") no-repeat left center/8px 8px;
	width: 8px;
	height: 8px;
	left: 0;
	top: 5px;
}


.index .visual {
	background: url("../img/index/visual_bg.png") no-repeat center/cover;
	/*height: 600px;
	display: flex;
	justify-content: center;
	align-items: center;*/
	padding: 130px 0px;
}
.index .visual img {
	width: 100%;
}
.index .visual .box {
	display: flex;
	flex-flow: row nowrap;
	align-items: flex-start;
	justify-content: center;
	max-width: 1080px;
	margin: 0 auto;
	padding: 0 20px;
    width: 100%;
    box-sizing: border-box;
}
.index .visual .box ul {
	width: 50%;
}
.index .visual .box ul.visual_slider02 {
    position: relative;
}
.index .banner_box {
	background: #e9ebed;
}
.index .banner_box.area {
	padding: 50px 20px;
}

.index .feature ul {
	display: flex;
	flex-flow: row nowrap;
	align-items: flex-start;
	justify-content: space-between;
}

.index .feature ul li {
    max-width: 560px;
    width: 49%;
}
.index .feature ul li a {
    font-size: 1.125rem;
}
.index .feature ul li .img {
	margin: 0 0 20px;
	line-height: 1;
}

.index .feature ul li .img img {
    width: 100%;
}

.index .use {
	background: url("../img/index/bg01.png") no-repeat center/cover;
}
.index .use .top_txt {
	text-align: center;
	margin: 0 0 30px;
}
.index .use ul.top {
	display: flex;
	flex-flow: row nowrap;
	align-items: flex-start;
	justify-content: space-between;
	margin: 0 0 50px;
}
.index .use ul.top li {
	background: #fff;
	box-sizing: border-box;
	width: 19%;
	padding: 30px 10px;
	height: 320px;
}

/*.index .use ul.top li a span {
    display: block;
}

.index .use ul.top li a span:focus {
outline: 1px #ff0000 dashed;
}*/

/*.index .use ul.top li:hover {
    opacity: 0.6;
}*/

.index .use ul.top li:first-child {
	border: 1px solid #fcc80d;
}
.index .use ul.top li:nth-child(2){
	border: 1px solid #ed6d00;
}
.index .use ul.top li:nth-child(3){
	border: 1px solid #11a84e;
}
.index .use ul.top li:nth-child(4){
	border: 1px solid #0092d7;
}
.index .use ul.top li:last-child{
	border: 1px solid #7e308e;
}
.index .use ul.top li a:hover {
	text-decoration: none;
}
.index .use ul.top li .icon {
	text-align: center;
	margin: 0 0 20px;
}
.index .use ul.top li .ttl {
	text-align: center;
	font-size: 1.025rem;
	font-weight: bold;
	color: #333;
	margin: 0 0 10px;
}
.index .use ul.top li .txt {
	text-align: center;
	line-height: 1.3;
}
.index .tool {
	background: url("../img/index/bg02.png") no-repeat center/cover;
}
.index .tool .ttl01 {
	color: #fff;
	text-shadow: 2px 2px 4px rgba(0,0,0,0.7);
}
.index .tool ul.main {
	display: flex;
	flex-flow: row nowrap;
	align-items: unset;
	justify-content: space-between;
}
.index .tool ul.main>li {
	background: #fff;
	width: 49%;
	box-sizing: border-box;
	padding: 30px;
	min-height: 560px;
}
.index .tool ul.main>li .img {
	text-align: center;
	margin: 0 0 15px;
}
.index .tool ul.main>li .ttl {
	font-size: 1.25rem;
	font-weight: bold;
	color: #005e8c;
	margin: 0 0 20px;
}
.index .tool ul.main>li .txt {
	min-height: 150px;
	margin: 0 0 20px;
}
.index .tool .btn_box {
	display: flex;
	flex-flow: row nowrap;
	align-items: flex-start;
	justify-content: space-between;
}
.index .tool .btn_box li {
	width: 47%;
}
.index .tool .btn_box li .cap {
	font-size: 0.875rem;
	margin: 20px 0 0;
}
@media screen and (max-width:1200px) {
    .index .use ul.top li .ttl {
        font-size: 0.9rem;
    }
    .index .use ul.top li .txt {
        font-size: 0.875rem;
    }
}
@media screen and (max-width:1050px) {
    .index .tool .btn_box li .btn_red::before {
        left: 10px;
    }
}
@media screen and (max-width:920px) {
    .index .tool .btn_box li .btn_red {
        font-size: 0.875rem;
    }
}
@media screen and (max-width:768px) {
    .ttl01 {
		font-size: 1.25rem;
		margin: 0 0 20px;
		padding: 0 0 10px;
	}
	.ttl01::after {
		width: 30px;
		height: 2px;
	}
	.ttl02 {
		font-size: 1rem;
		margin: 0 0 20px;
	}
	.ttl03 {
		font-size: 1.06rem;
		margin: 0 0 20px;
	}

	.index .visual {
		background: url("../img/index/visual_bg_sp.png") no-repeat center/cover;
		min-height: 400px;
        height: auto;
        padding-top: 30px;
        padding-bottom: 30px;
	}
	
	.index .visual .box {
		flex-flow: column;
		align-items: center;
	}
	.index .visual .box>* {
		line-height: 1;
	}
	.index .visual .box ul {
		width: 100%;
		padding: 0 10%;
		box-sizing: border-box;
		max-width: 500px;
	}
	.index .banner_box.area {
		padding: 20px;
	}
	.index .banner_box ul {
		justify-content: center;
	}
	.index .banner_box ul li {
		margin: 0 20px;
	}
	.index .banner_box ul img {
		width: 100%;
	}
	.index .feature ul {
		flex-flow: column;
		align-items: center;
		justify-content: center;
	}
	.index .feature ul li {
		width: 100%;
		box-sizing: border-box;
	}
	.index .feature ul li:not(:last-child) {
		margin: 0 0 20px;
	}
    .index .feature ul li a {
        font-size: 0.875rem;
    }
	.index .feature ul li .img {
		margin: 0 0 10px;
	}
	.index .feature ul li .img img {
		width: 100%;
	}
	.index .use .top_txt {
		text-align: left;
		margin: 0 0 20px;
	}
	.index .use ul.top {
		flex-flow: row wrap;
		margin: 0 0 40px;
	}
	.index .use ul.top li {
		width: 49%;
		padding: 10px 10px;
		height: 250px;
	}
	.index .use ul.top li:not(:last-child) {
		margin: 0 0 10px;
	}
	.index .use ul.top li .icon {
		margin: 0 0 10px;
	}
	.index .use ul.top li .icon img {
		max-width: 70px;
	}
	.index .use ul.top li .ttl {
		font-size: 0.875rem;
	}
	.index .use ul.top li .txt {
        font-size: 0.75rem;
    }
	.index .use .map_img {
		text-align: center;
	}
	.index .use .map_img img {
		width: 330px;
		margin: 0 auto;
	}
	.index .tool ul.main {
		flex-flow: column;
		align-items: center;
		justify-content: center;
	}
	.index .tool ul.main>li {
		width: 100%;
		padding: 20px;
		min-height: inherit;
	}
	.index .tool ul.main>li:not(:last-child) {
		margin: 0 0 20px;
	}
	.index .tool ul.main>li .img {
		margin: 0 0 10px;
	}
	.index .tool ul.main>li .img img {
		max-width: 50%;
	}
	.index .tool ul.main>li .ttl {
		font-size: 0.875rem;
		margin: 0 0 20px;
		padding: 0 0 0 15px;
	}
	.index .tool ul.main>li .txt {
		min-height: inherit;
		margin: 0 0 20px;
		font-size: 0.75rem;
		line-height: 1.4;
	}
	.index .tool .btn_box {
		flex-flow: column;
		align-items: center;
		justify-content: center;
	}
	.index .tool .btn_box li {
		width: 80%;
		display: flex;
		flex-flow: column;
		justify-content: center;
		align-items: center;
	}
	.index .tool .btn_box li:not(:last-child) {
		margin: 0 0 20px;
	}
	.index .tool .btn_box li .cap {
		font-size: 0.75rem;
		margin: 10px 0 0;
	}
	.index .map_img.pc {
        display: none;
    }
}

.index .map_img img {
    width: 100%;
    height: auto;
}
@media screen and (max-width:768px) {
.index .use .map_img img {
    width: 100%;
    height: auto;
    }
}

/* 20211011 index.cssの修正 */
.index .visual {
	padding: 50px 0px;
}
.arrow_red::before {
	top: 10px;
}
.arrow_red.size_l::before {
	top: 12px;
}
.product_list .arrow_red::before {
	top: 9px;
}
@media screen and (max-width:768px) {
	.arrow_red::before {
		top: 5px;
	}
	.arrow_red.size_l::before {
		top: 5px;
	}
	.product_list .arrow_red::before {
		top: 7px;
	}
	.index .banner_box ul .slick-list {
		width: 100%;
	}
	.index .banner_box ul .slick-next, .index .banner_box ul .slick-prev {
		width: 30px;
		height: 30px;
		top: 0;
		bottom: 0;
		transform: inherit;
		z-index:5;
	}
	.index .banner_box ul .slick-next {
		background: url("../../../../shared/v0010/img/next01.png")no-repeat center right/30px 30px;
		right: -10px;
	}
	.index .banner_box ul .slick-prev {
		background: url("../../../../shared/v0010/img/prev01.png")no-repeat center right/30px 30px;
		left: -10px;
	}
}

/*---- 0927 fa 追加 ----*/
/* 第4階層メニューsp 表示のために追加 */
.visual_nav_wrap {
	position: relative;
}
/* 第4階層メニュー ドロップダウン  */
.mee_category_nav_4th_more {
	position: relative;
}
.mee_category_nav_4th_more li{
	position: relative;
}
.mee_category_nav_4th_more li a {
	display: block;
	position: relative;
}
.mee_category_nav_4th_more>a::after{
    position: absolute;
    display: block;
    content: "";
    background: url("../img/common/arrow_red.png")no-repeat center/8px 8px;
    width: 8px;
    height: 8px;
    right: 10px;
    top: 50%;
    transform: translate(0,-50%) rotate(90deg);
}
.mee_category_nav_4th_more:hover>a::after {
    background: url("../../../../shared/v0010/img/arrow_white.png")no-repeat center/8px 8px;
}
.mee_category_nav_4th .dropdwn_menu_4th {
	display: inherit;
}
.mee_category_nav_4th .dropdwn_menu_4th li {
	border: none;
	height: auto;
}
.mee_category_nav_4th .dropdwn_menu_4th a {
	font-weight: 300;
    margin: 20px;
    display: block;
    color: #333;
    text-align: left;
    position: relative;
    height: inherit;
    line-height: 1;
    padding: 0 0 0 15px;
	box-sizing: border-box;
}
.mee_category_nav_4th .dropdwn_menu_4th a:hover {
	background: inherit;
	color: inherit;
}
.dropdwn_menu_4th a::before {
    position: absolute;
    display: block;
    content: "";
    background: url("../img/common/arrow_red.png")no-repeat left/8px 8px;
    width: 8px;
    height: 8px;
    left: 0;
    top: 50%;
    transform: translate(0,-50%);
	border: none;
}
.mee_category_nav_4th_more ul{
	position: absolute;
	left: 0;
	top: 65px;
	z-index: 4;
	background: #fff;
	width: 390px;
	visibility: hidden;
	opacity: 0;
	transition: all .3s;
}
.mee_category_nav_4th_more:hover > ul,
.mee_category_nav_4th_more:active > ul{
  visibility: visible;
  opacity: 1;
}

.dropdwn_menu_4th.short {
	width: 195px;
	//height: 92px;
}

@media print,screen and (max-width:955px){
	.mee_category_nav_4th .dropdwn_menu_4th{
		height: 82px!important;
	}
	.mee_category_nav_4th_more ul{
	  width: 300px;
	}
	.dropdwn_menu_4th.short {
		height: 82px;
	}
}
@media print,screen and (max-width:767px){
	.mee_category_nav_4th_more a {
		position: relative;
	}
	.mee_category_nav_4th_more ul{
		width: 100%;
	}
	.dropdwn_menu_4th.short {
		height: auto;
		width: 100%;
	}
	.mee_category_nav_4th_more>a::after{
		background: url("../../../../shared/v0010/img/arr.svg")no-repeat center right/17px 11px;
		width: 17px;
		height: 11px;
		transform: translate(0,-50%) rotate(90deg);
		right: 15px;
		top: 50%;
		transition: .3s;
	}
	.mee_category_nav_4th_more.active>a::after {
		transform: translate(0,-50%) rotate(-90deg);
	}
	.mee_category_nav_4th_more:hover>a::after {
		background: url("../../../../shared/v0010/img/arr_white.svg")no-repeat center right/17px 11px;
	}
	.mee_category_nav_4th .dropdwn_menu_4th {
		height: auto!important;
		padding: 0;
		position: relative;
	}
	.mee_category_nav_4th_more ul{
		position: relative;
		left: 0;
		top: inherit!important;
		width: 100%;
		visibility: visible;
		opacity: 1;
		display: none;
		transition: none;
	}
	.mee_category_nav_4th .dropdwn_menu_4th a {
		font-weight: 700;
		padding: 0 0 0 40px;
		font-size: 1.072em;
		margin: 20px 0;
	}
	.dropdwn_menu_4th a::before {
		display: none;
	}
}

/* 20211004 - FAグッズページの第３階層プルダウン追加に伴う修正（SP時） */
@media print,screen and (max-width:767px){
.mee_category_nav_4th .dropdwn_menu_4th {
	display: none;
}
}

/* 20211011 第4階層メニュー ドロップダウン　シャドー*/
.mee_category_nav_4th .dropdwn_menu_4th {
	box-shadow: 0px 0px 16px -6px rgb(0 0 0 / 60%);
}

@media print,screen and (max-width:767px){
.mee_category_nav_4th .dropdwn_menu_4th {
	box-shadow: none;
}
}

/* 20220520 追記 特集ページスライダー */
.index .feature_box.area {
	padding: 50px 20px;
}

@media screen and (max-width:768px) {
	.index .feature_box.area {
		padding: 20px;
	}
	.index .feature_box ul {
		justify-content: center;
	}

	.index .feature_box ul img {
		width: 100%;
	}
}