body {
    font-family: "メイリオ", Meiryo, verdana, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif;
}
h1 span{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: rgba(255, 255, 255, 0.6);
    width: 100%;
    text-align: center;
    font-size: 3em;
    font-weight: bold;
    padding: 10px 0 5px;
}
@media screen and (max-width:767px) {
h1 span {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: rgba(255, 255, 255, 0.6);
    width: 100%;
    text-align: center;
    font-size: clamp(1em, 10vw, 70px);
    font-weight: bold;
    padding: 10px 0 5px;
}
    }

.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 img {
	width: 100%;
	height: auto;
}
.maindesign .menu-btn-list {
	margin: 0 !important;
}
.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 .page--item-leave {
	margin-top: 50px;
}
.maindesign .page--item-leave_02 {
	margin-top: 70px;
}
.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 .title {
	position: relative;
}
.maindesign .title img{
	display: block;
}
.maindesign .title-inner {
	position: absolute;
    font-size: 4.0rem;
    font-weight: bold;
    width: 90%;
    text-align: center;
    padding: 0.2em 0 0.1em 0;
    top: 30%;
    left: 50%;
    transform: translate(-50%);
    background: rgba(255,255,255,0.6);
    background: linear-gradient( 0deg , rgb(255 255 255 / 0%), rgb(255 255 255 / 80%) 15%, rgb(255 255 255 / 80%) 85%, rgb(255 255 255 / 0%));
    background: -moz-linear-gradient( 0deg , rgb(255 255 255 / 0%), rgb(255 255 255 / 80%) 15%, rgb(255 255 255 / 80%) 85%, rgb(255 255 255 / 0%));
    background: -webkit-linear-gradient( 0deg , rgb(255 255 255 / 0%), rgb(255 255 255 / 80%) 15%, rgb(255 255 255 / 80%) 85%, rgb(255 255 255 / 0%));
}

@media screen and (max-width:767px) {
	.maindesign .title-inner {
		font-size: 10vw;
		top: 25%;
		left: 50%;
		transform: translate(-50%);
		line-height: 1.15;
	}
}

.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: 55px;
}

.maindesign .under-text {
	font-size: 1.0rem;
	margin-top: 5px;
	line-height: 1.3;
}

@media screen and (max-width:767px) {
	.maindesign .under-text {
		font-size: 0.85rem;
	}
}

.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%;
	height: auto;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}
.maindesign .category {
	margin-top: 20px;
}
.maindesign .category-item {
	display: flex;
    justify-content: center;
	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% - 20px);
	height: 45px;
	margin: 10px;
	background-color: #808080;
    border-radius: 5px;
    box-sizing: border-box;
}
.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: 48%;
	padding: 10px 20px;
	border-radius: 5px;
	border: 1px solid #333;
	align-items: normal !important;
}
.maindesign .recommendation-group--left {
	position: relative;
	background-color: #767171;
}
.maindesign .recommendation-group--img {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 90%;
	transform: translate(-50%,-50%);
}
.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 {
		height: 200px;
	}
	.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%;
	}
}

.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: 5%;
	border-top: solid 15px #333;
	border-right: solid 15px #333;
	width: 55px;
	height: 55px;
	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 7px #333;
		border-right: solid 7px #333;
		width: 25px;
		height: 25px;
	}
}






/*ブランドロゴ*/
.maindesign .maker-icon{
	display: flex;
	flex-wrap: wrap;
	align-items: start;
	justify-content: space-between;
}
.maindesign .maker-icon li{
	width: calc(100% / 2 - 10px);
	margin-right: 20px;
	margin-top: 20px;
	text-align: center;
}
.maker-p {
	font-family: "Noto Sans JP","游ゴシック", "Yu Gothic",Meiryo,"ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro",verdana,Osaka,Sans-Serif;
	text-align: center;
	margin-top: 10px;
}
.maindesign .maker-icon li a{
	display: block;
	box-shadow: #ccc 4px 4px 5px;
	text-decoration: none;
	color: #333; 
}
.maindesign .maker-icon li a .maker-icon--img {
	display: flex;
	align-items: flex-start;
}
.maindesign .maker-icon li:nth-child(2n){
	margin-right: 0;
}
.maindesign .maker-icon li:nth-child(-n + 2){margin-top: 0;}
.maindesign .maker-icon li p {
	margin: 10px 0;
	font-size: 1.0em;
}

@media screen and (min-width:768px) {
.maindesign .maker-icon li {
	width: calc(100% / 4 - 15px);
	margin-right: calc(60px / 3);
	margin-top: 20px;
}
.maindesign .new-arrival--img {
	width: 120px;
	margin: auto 30px;
}
.maindesign .maker-icon li:nth-child(2n) {
	margin-right: calc(60px / 3);
}
.maindesign .maker-icon li:nth-child(4n) {
	margin-right: 0;
}
.maindesign .maker-icon li:nth-child(-n + 4) {
	margin-top: 0;
}
} 
    @media screen and (min-width:768px) {
    .maindesign .maker-icon li.large-box {
        width: calc(100% / 2 - 10px);
        margin-right: 0;
    }
        .maindesign .maker-icon li.large-box img {
        width: 100%;
        height: auto;
    }
}
    @media screen and (max-width:767px) {
		.maindesign .maker-icon li.large-box {
		width: 100%;
		margin-right: 0;
		}
        .maindesign .maker-icon li.large-box img {
        width: 100%;
        height: auto;
    }
}

.maindesign .goods.sagyougoods .text-box {
    font-weight: bold;
    text-align: center;
}

.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;
	}
}
#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::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;
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;
}

/*240502*/

.maindesign .category-item--size---single span{
    position: absolute;
    color: #fff;
    font-weight: bold;
    font-size: 1.2rem;
    top: 50%;
    left: 50%;
	transform: translate(-50%, -50%);
	white-space: nowrap;
}

.maindesign .category-item--size---single {
	position: relative;
    width: 100%;
    max-width: 230px;
    height: 45px;
    background-color: #808080;
    border-radius: 5px;
}

@media screen and (max-width:767px) {
	.maindesign .category-item--size---single {
		font-size: 1.1rem;
	} 
	.maindesign .recommendation--right{
         display: block;
	     height: auto;
	}
    
	.maindesign .category-item--size---single span {
         font-size: 1.0rem;
}
	.maindesign .side-margin {
		margin: 0 10px;
	}
}

.maindesign .position-relative {
	position: relative;
}

/*240718*/

.maindesign .material-explanation {
	display: flex;
    flex-wrap: wrap;
	justify-content: space-between;
    margin-top: 20px;
}

.maindesign .material-explanation li {
    width: calc(50% - 5px);
    padding: 10px;
    border: solid #ccc 1px;
    margin-bottom: 10px;
    border-radius: 10px;
}

.maindesign .color-title {
    font-size: 1.15em;
    font-weight: bold;
    padding: 0 0 10px 20px;
    position: relative;
}

.maindesign .color-title::before {
    content: "";
    width: 15px;
    height: 15px;
    display: block;
    position: absolute;
    top: 1%;
    left: 0%;
}

.maindesign .color-title.yellow::before {
    background: #f5e520;
}

.maindesign .color-title.green::before {
    background: #3fd50e;
}

.maindesign .color-title.purple::before {
    background: #a433f9;
}

.maindesign .color-title.blue::before {
    background: #38a6d7;
}

.maindesign .c-lead-text {
	font-size: 1em;
	line-height: 1.5;
}

.maindesign .c-komeri-btn__gray {
    display: block;
    margin-bottom: 10px;
    position: relative;
    background-color: #979797;
    cursor: pointer;
    border-radius: 40px;
    opacity: 1.0;
    }

.maindesign .c-komeri-btn--inner {
    font-feature-settings: "palt";
    color: #fff;
    padding: 0.75rem 2rem 0.75rem 1.75rem;
    width: auto;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1.3;
    font-weight: bold;
}

.maindesign .c-komeri-btn--inner::after {
    content: '';
    position: absolute;
    top: 50%;
    right: 18px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    width: 8px;
    height: 8px;
    transform: translateY(-50%) rotate(45deg);
}

.maindesign .sagyougoods2 .btn-box {
	padding: 0 10px;
}

@media screen and (max-width:767px) {
	.maindesign .material-explanation li {
		width: 100%;
	}
 	
	.maindesign .c-komeri-btn--inner {
		font-size: 0.85em;
}
}

/*241121*/
.maindesign .campaign_bnr {
	margin-top: 30px;
}

@media screen and (max-width:767px) {
    .maindesign .campaign_bnr {
	margin-top: 20px;
}
}

/*250430*/
.maindesign .recommendation--text.title-text {
    font-weight: bold;
    line-height: 1.25em;
    font-size: 1.5em;
	margin-bottom: 5px;
}

.maindesign .page--item-leave {
    margin-top: 20px;
}


.maindesign .bnr-container.page--item-leave {
	margin-top: 30px;
}

/*260131*/
.maindesign .cols2bnr {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.maindesign .cols2bnr .img-container{
	width: calc(50% - 5px);
	margin-bottom: 5px;
}

.maindesign .cols2bnr .img-container:not(:last-child){
	margin-bottom: 5px;
}

@media screen and (max-width:767px) {
    .maindesign .cols2bnr .img-container{
	width: 100%;
}
}