.maindesign *, 
.maindesign *:before, 
.maindesign *:after {
	box-sizing: border-box;
	}
#main {
	margin-bottom: 100px;
	overflow: hidden;
}
@media screen and (max-width:767px) {
	#main {
		margin-bottom: 50px;
	}
}

.maindesign .page--item-leave {
	margin-top: 50px;
}
.maindesign .page--item-moderate {
	margin-top: 30px;
}
.maindesign .page--item-close {
	margin-top: 30px;
}
@media screen and (max-width:767px) {
	.maindesign .page--item-leave {
		margin-top: 30px;
	}
	.maindesign .page--item-close {
		margin-top: 15px;
	}
}


.maindesign img {
	width: 100%;
	height: auto;
}
.maindesign .menu-btn-list a {
	color: #fff !important;
	display: flex !important;
}
.maindesign .breadcrumb {
	margin-bottom: 5px !important;
}
.maindesign .breadcrumb,
.maindesign .breadcrumb a {
	color: #83838f;
	text-decoration: none;
}
@media screen and (max-width:767px) {
	.maindesign .breadcrumb {
		margin-left: 5px !important;
	}
}

.maindesign .title {
	position: relative;
}
.maindesign .title--inner  {
	position: absolute;
    top: 50%;
    left: 5%;
    transform: translateY(-50%);
    text-align: center;
    color: #fff;
    display: flex;
    flex-direction: column;
}
.maindesign .title--heading01 {
    font-size: 1.5rem;
    font-weight: bold;
}
.maindesign .title--heading02 {
	font-size: 4.5rem;
    font-weight: bold;
    text-shadow: 2px 2px 5px rgb(0 0 0 / 50%);
	margin-top: 10px;
}
.maindesign .title--heading03 {
    font-size: 1.5rem;
    font-weight: bold;
	margin-top: 15px;
}

@media screen and (max-width:767px) {
	.maindesign .title--inner {
		left: 0%;
        width: 55%;
	}
	.maindesign .title--heading01 {
		font-size: clamp(0.7em, 2vw, 20px);
	}
	.maindesign .title--heading02 {
		font-size: clamp(1em, 9vw, 70px);
		margin-top: 5px;
	}
	.maindesign .title--heading03 {
		font-size: 6.0vw;
		margin-top: 10px;
	}
}

.maindesign .topBtn ul::before,
.maindesign .topBtn ul::after {
	content: '';
	display: block;
	width: 24%;
	height: 0;
}
.maindesign .topBtn ul::before {
	order: 1;
}
.maindesign .topBtn a {
	display: flex !important;
	align-items: center;
	height: 65px;
	line-height: 1.15;
	background-position: right 0.6em center !important;
}

.maindesign .messageBox {
    border: 1px #B70B17 solid;
    padding: 0.5em;
    box-sizing: border-box;
    line-height: 2;
}
.maindesign .messageBox p {
    color: #B70B17;
    font-size: 1em;
    font-weight: bold;
}
.maindesign .messageBox p:nth-child(2) {
    font-size: 1em;
    font-weight: normal;
}

@media screen and (max-width:767px) {
	.maindesign .messageBox {
		margin-right: 10px;
		margin-left: 10px;
	}
	.maindesign .messageBox p:nth-child(2) {
		line-height: 1.2;
	}
}

.maindesign .solvic {
	display: flex;
	justify-content: flex-start;
	align-items: center;
}
.maindesign .solvic--left {
	width: 45%;
	margin-right: 15px;
}
.maindesign .solvic--right {
	width: 50%;
}
.maindesign .solvic--img {
	width: 70%;
}
.maindesign .solvic--text {
	font-weight: bold;
	margin-top: 15px;
	line-height: 1.25;
}

@media screen and (max-width:767px) {
	.maindesign .solvic {
		flex-wrap: wrap;
	}
	.maindesign .solvic--left {
		margin-right: 0;
		width: 100%;
	}
	.maindesign .solvic--right {
		width: 100%;
		margin-top: 20px;
	}
	.maindesign .solvic--text {
		margin-top: 10px;
		font-size: 0.9rem;
	}
}

.maindesign h3.checkPoint {
    position: relative;
    font-size: 1.25em;
    font-weight: bold;
    margin: 60px 0 20px 0;
    padding: 0 0 10px 0;
    text-align: left;
    border-bottom: #aaaaaa 2px solid;
    display: flex;
    align-items: center;
}
.maindesign h3.checkPoint .st0{
	fill:#aaaaaa;
}
.maindesign h3.checkPoint .st1{
	fill:none;stroke:#ffffff;stroke-width:3;stroke-miterlimit:10;
}
.maindesign h3.checkPoint span {
    margin: 0 0 0 20px;
}


.maindesign .recommendation {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}
.maindesign .recommendation--left {
    width: 48%;
    padding: 0 14px 0 0;
}
.maindesign .recommendation--right {
	width: 52%;
}
.maindesign .category {
	margin-top: 20px;
}
.maindesign .category-item {
	display: flex;
    justify-content: space-evenly;
	margin-top: 15px;
	flex-wrap: wrap;
}
.maindesign .category--name {
	font-weight: bold;
	font-size: 1.35rem;
	text-align: center;
}
.maindesign .category-item--img {
	width: 30%;
    max-width: 120px;
	padding-right: 10px;
	text-align: center;
}
.maindesign .category-item--img > span {
	display: inline-block;
	margin-top: 5px;
}
.maindesign .category-item--size {
	position: relative;
	width: calc(20% - 10px);
	height: 45px;
	margin-right: 10px;
	margin-top: 10px;
	background-color: #808080;
	border-radius: 10px;
}
.maindesign .category-item--size > span {
	position: absolute;
	color: #fff;
	font-weight: bold;
	font-size: 1.75rem;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}
.maindesign .category-item--color {
	text-align: center;
	margin-right: 15px;
}
.maindesign .category-item--color > span {
	display: inline-block;
	margin-top: 5px;
}
.maindesign .category-item--color::before {
	content: '';
	width: 85px;
	height: 60px; 
	display: block;
	border-radius: 10px;
}
.maindesign .category-item--color__black::before {
	background-color: #000;
}
.maindesign .category-item--color__gray::before {
	background-color: #808080;
}
.maindesign .category-item--color__navy::before {
	background-color: #000080;
}
.maindesign .category-item--color__beige::before {
	background-color: #F4B183;
}

@media screen and (max-width:767px) {
	.maindesign .recommendation {
		flex-wrap: wrap;
	}
	.maindesign .recommendation--left {
		width: 100%;
        padding: 0;
	}
	.maindesign .recommendation--right {
		width: 100%;
		margin-top: 15px;
	}
}

.maindesign .recommendation-group {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.maindesign .recommendation-group--item {
	width: calc(50% - 10px);
    padding: 10px 10px;
    border-radius: 5px;
    border: 1px solid #333;
    box-sizing: border-box;
    align-items: center;
}
.maindesign .recommendation-group--left {
	width: 54%;
    padding: 0 5px 0 0;
}
.maindesign .recommendation-group--img {
	max-width: 200px;
}
.maindesign .recommendation-group--right {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
.maindesign .recommendation-group .maindesign .recommendation-group--item:nth-child(n+3) {
	margin-top: 30px;
}
.maindesign .recommendation--name {
	font-weight: bold;
	font-size: 1.0rem;
}
.maindesign .recommendation--lead {
	font-size: 0.85rem;
	margin-top: 10px;
}
.maindesign .group-category {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	margin-top: 15px;
}
.maindesign .category-item--img > svg {
	width: 100%;
}
.maindesign .group-category--name {
	width: 25%;
	font-size: 1.0rem;
	font-weight: bold;
	margin-right: 10px;
}
.maindesign .group-category--item {
	width: 70%;
	display: flex;
	justify-content: flex-start;
	flex-wrap: wrap;
}
.maindesign .group-category-item--img {
	width: 18%;
	margin-right: 10px;
}
.maindesign .group-category--item .group-category-item--size:nth-child(n+3) {
	margin-top: 5px;
}
.maindesign .group-category-item--size {
	position: relative;
    width: calc(45% - 10px);
    height: 25px;
    background-color: #808080;
    border-radius: 10px;
	margin-right: 10px;
}
.maindesign .group-category-item--size > span {
	position: absolute;
    color: #fff;
    font-weight: bold;
    font-size: 1.0rem;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
}
.maindesign .group-btn ul {
	margin: 15px 0 0 0 !important;
}
.maindesign .group-btn li {
	width: 100% !important;
}
.maindesign .group-btn a {
	font-size: 0.95rem !important;
	padding: 0.45rem 1.0rem !important;
	min-height: 2.0rem !important;
}

@media screen and (max-width:767px) {
	.maindesign .recommendation-group--item {
		width: 100%;
	}
	.maindesign .recommendation-group--left {
		width: 100%;
	}
	.maindesign .recommendation-group .maindesign .recommendation-group--item:not(:first-child) {
		margin-top: 30px;
	}
	.maindesign .recommendation--lead {
		margin-top: 5px;
	}
	.maindesign .group-category-item--img {
		width: 13%;
	}
    .maindesign .recommendation-group--img {
    margin: auto;
}
}

.heater-nav a {
	text-decoration: none !important;
	color: #000 !important;
}
.heater-nav--inner {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	position: relative;
	padding: 15px 30px;
	border: 1px solid #333;
}
/*.heater-nav--inner::before {
	content: '';
	position: absolute;
	top: 50%;
	right: 5%;
	width: 25px;
	height: 80px;
	transform: translate(-100%,-50%);
	z-index: 10;
	background-color: #fff;
}*/
.heater-nav--inner::after {
	content: '';
    position: absolute;
    top: 50%;
    right: 3%;
    border-top: solid 5px #333;
    border-right: solid 5px #333;
    width: 20px;
    height: 20px;
    transform: translateY(-50%) rotate(45deg);
    z-index: 1;
}
.heater-nav--img {
	width: 20%;
	padding-right: 15px;
}
.heater-nav--text {
	width: 70%;
	font-weight: bold;
	font-size: 1.75rem;
}

@media screen and (max-width:767px) {
	.heater-nav--inner {
		padding: 7px 15px;
	}
	.heater-nav--img {
		width: 25%;
		padding-right: 10px;
	}
	.heater-nav--text {
		font-size: 4.8vw;
		width: 60%;
	}
	.heater-nav--inner::before {
		width: 25px;
    	height: 45px;
		transform: translate(-50%,-50%);
	}
	.heater-nav--inner::after {
		border-top: solid 5px #333;
    border-right: solid 5px #333;
    width: 15px;
    height: 15px
	}
}


.maindesign .btnstyle {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.maindesign .btnstyle li {
    width: calc(50% - 5px);
    margin-bottom: 10px;
    border-radius: 5px;
    border: 1px solid #ababab;
    background: #f1f1f1;
    display: flex;
    overflow: hidden;
}
.maindesign .btnstyle a {
    display: flex !important;
    align-items: center;
    width: 100%;
}
.maindesign .btnstyle .images {
    height: 6em;
    background: #fff;
    border-right: 1px solid #ababab;
    display: flex;
    align-items: flex-start;
    padding: 5px;
    box-sizing: border-box;
}
.maindesign .btnstyle .images img {
    height: 100%;
    width: auto;
    /*align-items: flex-start;*/
    /*flex-shrink: 0;*/
    /*max-width: initial;*/
}
.maindesign .btnstyle .textBox {
    padding: 0.5em;
    font-weight: 700;
    line-height: 1.3em;
}
.maindesign .btnstyle .arrow {
    background: #aaa;
    height: 100%;
    width: 2em;
    display: flex;
    color: #fff;
    align-items: center;
    justify-content: center;
}



@media screen and (max-width: 767px){
	.maindesign .btnstyle li {
		width: 100%;
	}
	.maindesign .btnstyle .images {
		width: 28%;
		height: auto;
	}
	.maindesign .btnstyle .textBox {
		width: 70%;
	}
}


.maindesign .relation-items {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin-top: 30px;
}
.maindesign .relation-items .relation--item:nth-of-type(n + 3) {
	margin-top: 15px;
}
.maindesign .relation--item {
	width: 49%;
	box-sizing: border-box;
	border-radius: 5px;
	border: 1px solid #ccc;
}
.maindesign .relation--item > a {
	display: block;
	color: #000 !important;
	text-decoration: none;
	height: 100%;
}
.maindesign .relation-inner {
	display: flex;
	padding: 20px 15px;
	justify-content: space-between;
	align-items: flex-start;
}
.maindesign .relation-text {
	width: 70%;
	order: 1;
}
.maindesign .relation-text--title {
	font-size: 1.15em;
	font-weight: bold;
	white-space: wrap;
	margin-bottom: 10px;
    font-feature-settings: "palt" 1;
}
.maindesign .relation-text > span {
	line-height: 1.15;
} 
.maindesign .relation-img {
	width: 140px;
	max-width: 25%;
	order: 2;
}
.maindesign .relation-img > img {
	width: 100%;
	height: auto;
}

@media screen and (max-width:767px) {
	.maindesign .relation-items .relation--item:not(:first-child) {
	margin-top: 15px;
}
	.maindesign .relation--item {
		width: 100%;
	}
	.maindesign .relation-inner {
		padding: 15px 10px;
		align-items: center;
	}
	.maindesign .relation-text--title {
		white-space: wrap;
	}
	.maindesign .relation-text {
		order: 2;
	}
	.maindesign .relation-img {
		order: 1;
	}
}

.maindesign .w-btn-container a {
	font-size: 1.0rem !important;
}
#main .tab-menu-nav {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
#main .tab-menu-nav .fs-medium {
font-size: 1.0em;
padding: 0.5rem 2rem 0.5rem 1rem;
font-feature-settings: "palt";
min-height: 3rem;
line-height: 1.3; 
}
#main .tab-menu-nav.winter_c .fs-medium {
    font-size: 0.8em;
}
#main .tab-menu-nav::after,
#main .tab-menu-nav::before {
content: "";
display: block;
width: calc(25% - 15px);
height: 0;
}
#main .tab-menu-nav::before {
order: 1;
}
#main .tab-menu-nav li{
width: calc(25% - 15px);
margin-top:1.25rem;
position: relative
}
#main .tab-menu-nav li:nth-child(-n+4) {
margin-top: 0 
}
/* ----ページ内リンクボタン---- */
/* ----pc3列表示 sp2列表示---- */
#main .tab-menu-nav.col-3::after {
content: "";
display: block;
width: calc( 33.3% - 10px);
height: 0;
}
#main .tab-menu-nav.col-3 li {
width: calc( 33.3% - 10px);
margin-top:1.25rem; 
}
#main .tab-menu-nav.col-3 li:nth-child(-n+3) {
margin-top: 0 
}
/* ----ページ内リンクボタン---- */


@media screen and (max-width:767px) {
/* ----ページ内リンクボタン---- */
/* ----pc4列表示 sp2列表示　pc3列表示 sp2列表示---- */
#main .tab-menu-nav {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
#main .tab-menu-nav .fs-medium {
padding: 0.5rem 1.8rem 0.5rem 1rem;
font-feature-settings: "palt";
min-height: 3rem;
line-height: 1.3; 
}
#main .tab-menu-nav li {
width: calc(50% - 0.4rem);
margin-bottom: 1.25em;
margin-top:0;
font-size: 0.85rem;
}
/* ----ページ内リンクボタン---- */
/* ----pc4列表示 sp1列表示　pc3列表示 sp1列表示---- */ 
#main .tab-menu-nav.col-1 li {
width: 100%
}
/* ----ページ内リンクボタン---- */
/* ----画像付き pc3列表示 sp1列表示---- */
#main .feature__items li a .feature__items--txt.sp-title {
display: flex;
align-items: center; 
}
#main .feature__items.col-31 li a .feature__items--txt .tab-menu--txt__title {
font-weight: bold;
font-size: 1.2rem;
line-height: 1.3;
}
#main .feature__items.col-31.border-none li a {
border-radius: 0;
}
/* -- ページ内リンクボタン end --  */
}
#main li a.flatbtn {
    box-sizing: border-box;
    text-align: center;
    border-radius: 40px;
    color: #333;
    display: flex;
    opacity: 1.0;
    width: auto;
    height: 100%;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

#main .fw__b {
    font-weight: bold;
    text-align: center;
}

#main ul.kanrengoods.workwear {
	margin-top: 20px;
}

@media screen and (max-width:767px) {
#main .goods.cols3-2.workwear li {
        width: calc(50% - 5px) !important;
        margin-right: calc(10px / 1) !important;
        margin-bottom: 20px !important;
    }

#main .goods.cols3-2.workwear li:nth-child(2n) {
        margin-right: 0px !important;
    }
	
#main .fw__b {
	font-size: 0.9em;
}
}