
.mv{
    margin: 0 auto;
    max-width: 1100px;
    padding: 20px 20px 0;
}
.mv h1{
    font-size: 1.75rem;
    font-weight: bold;
}
.mv h1 span{
	font-size: 1.25rem;
	border: 1px solid #707070;
	padding: 3px 10px;
	display: inline-block;
	margin-bottom: 10px;
}
.mv div.visual_img{
    display: block;
    position: relative;
    margin: 20px 0 0;
}
.mv div.visual_img > div{
    position: absolute;
    top: calc(-1.75rem - 27px);
    right: 0;
    z-index: 1;
    background-color: #333333;
    border-radius: 5px;
    color: #ffffff;
    padding: 5px 20px;
    margin: 0;
}
.mv div.visual_img figure{
  position: relative;
  width: 100%;
  padding-top: 800px;
  margin: 0;
    border-radius: 10px;
    overflow: hidden;
}
.mv div.visual_img figure img{
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  object-fit: cover;
}
/*↓↓↓下基準上トリミング（.bottom_fit）↓↓↓*/
.mv div.visual_img figure img.bottom_fit{
    object-position: 50% 100%;
}
/*↑↑↑下基準上トリミング（.bottom_fit）↑↑↑*/
.article_wrap{
    margin: 0 auto;
    max-width: 1100px;
    padding: 0 20px 80px;
}
.article_wrap:last-child{
    border-bottom: none;
}
.article_wrap .col1:has(+ .col1){
    margin-bottom: 40px;
}
.article_wrap .col2{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
	align-items: center;
}
.article_wrap .col2 figure{
    width: 52%;
}
.article_wrap .col2 > div{
    width: 40%;
}
.article_wrap figure{
    border-radius: 10px;
    overflow: hidden;
}
.article_wrap figure.w60{
    width: 60%;
    margin: 0 auto;
}
.article_wrap h2{
    font-size: 1.5rem;
    font-weight: bold;
    margin: 40px 0 20px;
}
.article_wrap p{
    margin: 40px 0;
    font-size: 1rem;
    line-height: 2;
}
.article_wrap h2 + p,.article_wrap p + p{
    margin: 20px 0 40px;
}
.article_wrap h2 span {
    display: inline-block;
    background-color: #de0303;
    color: #ffffff;
    font-size: 1rem;
    padding: 4px 9px 3px;
    margin-right: 3px;
    line-height: 1.2;
}
.info_box{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: center;
    margin: 40px 0;
}
.info_box:last-child{
    margin-bottom: 0;
}
.info_box > div:nth-child(1){
    width: 33%;
}
.info_box > div:nth-child(2){
    width: 65%;
}
.info_box h3{
    font-size: 1.25rem;
    font-weight: bold;
}
.article_wrap .info_box p{
    margin: 20px 0;
}
/*-------------------------------*/
.read_box{
	font-size: 1.125rem;
}
.read_box ul{
	margin: 10px 0;
}
.read_box ul li{
	font-size: 1rem;
	padding-left: 1em;
	text-indent: -1em;
	margin-bottom: 5px;
	line-height: 1.7;
}
.read_bottom_img{
	margin: 60px 0;
	padding: 20px;
    border: 1px solid #BDBDBD;
    border-radius: 10px;
}
.read_bottom_img img{
	width: 60%;
	margin: 0 auto;
	display: block;
}
/*-------------------------------*/
#content_box02 h2{
	text-align: center;
	margin: 0 auto 40px;
	font-size: 1.75rem;
}
.content_box01_img02{
	padding: 20px;
	border: 1px solid #BDBDBD;
	border-radius: 10px;
}
/*-------------------------------*/
.board_cassette{
	background-color: #FFFFFF;
	border-radius: 10px;
	padding: 30px;
	margin: 40px 0;
}
.board_cassette h3{
	font-size: 1.5rem;
	font-weight: bold;
	margin-bottom: 20px;
}
.board_cassette h3 span{
	font-size: 2.75rem;
	color: #BFBFBF;
	font-weight: bold;
	margin-right: 10px;
}
.board_cassette p{
	margin: 20px 0;
}
.board_cassette.pattern01 > div a {
    display: block;
    background-color: #333333;
    color: #ffffff;
    padding: 11px;
    text-align: center;
    border-radius: 100px;
    max-width: 450px;
    font-weight: bold;
	font-size: 1.25rem;
	transition: all 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.board_cassette.pattern01 > div a:hover{
	opacity: 0.8;
}


.board_cassette.pattern01{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.board_cassette.pattern01 > div{
	width: 57%;
}
.board_cassette.pattern01 > figure{
	width: 40%;
}

.board_cassette.pattern02 h4{
	margin: 20px 0;
	font-size: 1.25rem;
	font-weight: bold;
}
.board_cassette.pattern02 p{
	margin: 20px 0;
}
.board_cassette.pattern02 div.main_btn a{
    display: block;
    background-color: #333333;
    color: #ffffff;
    padding: 11px;
    text-align: center;
    border-radius: 100px;
    max-width: 450px;
    font-weight: bold;
	font-size: 1.25rem;
	transition: all 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
	margin: 20px auto;
}
.board_cassette.pattern02 > div.main_btn a:hover{
	opacity: 0.8;
}
.board_cassette.pattern02 div.main_btn + h4{
	    border-top: 1px solid #cfcfcf;
	margin-top: 40px;
	padding-top: 40px;
}

/*-------------------------------*/
.btn_box{
    width: 70%;
    max-width: 550px;
    margin: 60px auto 0;
}
.btn_box a{
    display: block;
    background-color: #333333;
    border-radius: 100px;
    color: #ffffff;
    font-size: 1.2rem;
    font-weight: bold;
    text-align: center;
    padding: 11px 40px;
    position: relative;
    opacity: 1;
    transition: all 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.btn_box a:hover{
    opacity: 0.8;
}
.btn_box a span{
    display: inline-block;
    background-color: #de0303;
    color: #ffffff;
    font-size: 0.85rem;
    padding: 4px 5px 3px;
    margin-right: 3px;
    line-height: 1.2;
}

#includeFooter{
    margin-top: 0;
    background-color: #ffffff;
}
/*-------------------------------*/


/*-------------------------------*/
#content_box02{
	background-color: #F7F7F7;
	padding: 80px 0 0;
}
.link-detail{
	text-align: right;
	margin-top: 20px;
}
.link-detail a{
	margin-left: auto;
}
/*-------------------------------*/
.cassette02_list{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin-top: 40px;
}
.cassette02_list > li{
	width: 32%;
	margin-bottom: 20px;
	display: flex;
	flex-direction: column;
}
.cassette02_list h4{
	font-size: 1.25rem;
	font-weight: bold;
	color: #3C3C43;
	padding-bottom: 10px;
	border-bottom: 2px solid #707070;
	line-height: 1.2;
	margin-bottom: 15px;
}
.cassette02_list > li p{
	margin: 10px 0;
	line-height: 1.6;
}

.cassette02_list li div{
	margin-top: auto;
}
.cassette02_list li div a{
	display: block;
	background-color: #333333;
	color: #ffffff;
	padding: 5px 0;
	text-align: center;
	border-radius: 100px;
	width: 70%;
	font-weight: bold;
	margin: 20px auto;
	font-size: 1rem;
}
/*-------------------------------*/
.Tseries_list{
	display: flex;
	justify-content: flex-start;
	flex-wrap: wrap;
	margin: 20px 0 40px;
}
.Tseries_list > li{
	width: 32%;
	margin-bottom: 20px;
	display: flex;
	flex-direction: column;
	margin-right: 2%;
}
.Tseries_list > li:nth-child(3n){
	margin-right: 0;
}
.board_cassette.pattern02 .Tseries_list li p{
	font-weight: bold;
	font-size: 1rem;
	margin: 10px 0;
}
.Tseries_list li div{
	margin-top: auto;
}
.Tseries_list li div a{
	display: block;
	background-color: #333333;
	color: #ffffff;
	padding: 5px 0;
	text-align: center;
	border-radius: 100px;
	width: 70%;
	font-weight: bold;
	margin: 0 auto;
	font-size: 1rem;
	transition: all 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.Tseries_list li div a:hover{
	opacity: 0.8;
}
/*------------------------------*/
.anchor_box{
    margin: 20px auto 0;
    max-width: 1100px;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.anchor_box > div{
	width: 24%;
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 1px 1px 4px rgb(0 0 0 / 20%);
    margin-bottom: 20px;
    transition: all 0.4s ease 0s;
    position: relative;
    background-color: #ffffff;
    height: 6.5rem;
    display: flex;
    align-items: center;
}
.anchor_box >div:hover{
    box-shadow: 3px 3px 6px rgb(0 0 0 / 28%);
}
.anchor_box > div a{
	display: block;
	width: 100%;
	text-align: center;
}
.anchor_box > div p{
    padding: 15px 10px 45px;
    position: relative;
	line-height: 1.4;
	font-feature-settings: "palt";
    font-size: 1.125rem;
    font-weight: bold;
    color: #000000;
    text-align: left;
	display: flex;
	align-items: center;
}
.anchor_box > div::before{
    content: "";
    position: absolute;
	width: calc(100% - 4px);
	height: 30px;
	background-color: #EAEAEA;
	border-radius: 0 0 8px 8px;
    bottom: 2px;
	left: 2px;
}
.anchor_box > div::after{
    content: "";
    margin: auto;
    position: absolute;
    bottom: 15px;
    right: calc(50% - 6px);
    width: 13px;
    height: 13px;
    border-top: 2px solid #9B9B9B;
    border-right: 2px solid #9B9B9B;
    transform: rotate(135deg);
    pointer-events: none;
}
.anchor_box > div p span{
	font-size: 1.5rem;
	font-weight: bold;
	color: #BFBFBF;
	margin-right: 10px;
}


@media screen and (max-width: 767px) {
    .mv{
        padding: 0;
    }
    .mv h1{
        font-size: 1.38rem;
        padding: 10px;
    }
	.mv h1 span{
		font-size: 1rem;
	}
    .mv div.visual_img{
        margin: 0;
    }
    .mv div.visual_img figure{
        border-radius: 0;
        padding-top: 290px;
    }
    .mv div.visual_img > div{
        top: 10px;
        right: 10px;
        padding: 5px 10px;
    }
	
	.read_bottom_img img{
		width: 100%;	
	}
	.read_bottom_img{
		margin: 30px 0;
	}
    .article_wrap{
        padding: 10px 10px 30px;
    }
    .article_wrap h2{
        margin: 20px 0;
        font-size: 1.38rem;
    }
    .article_wrap .col2{
        display: block;
    }
    .article_wrap .col2 figure{
        width: calc(100% - 40px);
        margin-bottom: 10px;
    }
	.article_wrap .col2 > div{
		width: 100%;
	}
    .article_wrap figure.w60{
    width: 100%;
    }
    .info_box{
        flex-direction: column-reverse;
    }
    .info_box > div:nth-child(1),.info_box > div:nth-child(2){
        width: 100%;
    }
    .info_box h3{
        font-size: 1.15rem;
    }
    .article_wrap .info_box p{
        margin: 10px 0;
    }
    .btn_box{
        width: auto;
        margin: 30px 10px 0;
    }
    .btn_box a{
        font-size: 1.05rem;
        font-feature-settings: "palt";
		padding: 10px 20px;
    }
    .btn_box a span{
        display: block;
        width: 40px;
        margin: 0 auto;
        padding: 2px 5px 1px;
    }
    .article_wrap h2 span{
        display: block;
        width: 50px;
        text-align: center;
    }
    .article_wrap h2{
        font-feature-settings: "palt";
    }

	.cassette02_list,.cassette02_list > li.w2clm ul.fragment_product{
		display: block;
	}
	.cassette02_list > li,.cassette02_list > li.w2clm,.cassette02_list > li.w2clm ul.fragment_product li{
		width: 100%;
	}
	.fragment_product li figure{
		width: 35%;
	}
	.cassette02_list > li.w2clm ul.fragment_product li{
		margin-bottom: 20px;
	}
	#content_box02{
		padding-top: 40px;
		margin-bottom: 20px;
	}

	.article_wrap p{
		margin: 20px 0;
	}
	.article_wrap h2 + p,.article_wrap p + p{
		margin: 20px 0 20px;
	}
	.graph-txt {
		display: flex;
		box-sizing: border-box;
		justify-content: center;
		text-align: center;
		align-items: center;
		padding: 0 15px 0 15px;
	}
	.graph-txt > span {
		display: inline-block;
		padding: 0 0 0 24px;
		position: relative;
		color: #666666;
		margin-top: 10px;
	}
	.graph-txt > span:before {
		position: absolute;
		top: 50%;
		left: 0;
		transform: translate(0,-50%);
		width: 16px;
		height: 17px;
		content: "";
		background: url(/jp/space-design/img/concept/icon.svg) no-repeat center center / contain;
	}
	
	#content_box02 h2{
		font-size: 1.5rem;
	}
	.board_cassette{
		padding: 20px 10px 10px;
	}
	.board_cassette.pattern01{
		display: block;

	}
	.board_cassette.pattern01 > div,.board_cassette.pattern01 > figure{
		width: 100%;
	}
	.board_cassette.pattern01 > div a{
		font-size: 1rem;
		margin: 20px 0;
	}
	.board_cassette h3 {
		font-size: 1.375rem;
		display: flex;
		align-items: center;
	}
	.board_cassette h3 span{
		font-size: 2.5rem;
	}
	.board_cassette.pattern02 h4{
		font-size: 1.125rem;
	}
	.board_cassette.pattern02 div.main_btn a{
		font-size: 1rem;
	}
	
	.Tseries_list{
		justify-content: space-between;
		margin: 20px 0;
	}
	.Tseries_list > li{
		width: 48%;
		margin: 0 0 20px;
	}
	.board_cassette.pattern02 .Tseries_list li p{
		font-size: 0.875rem;
		line-height: 1.4;
	}
	.Tseries_list li div a{
		width: 90%;
		font-size: 0.875rem;
	}
	.anchor_box{
		display: block;
	}
	.anchor_box > div{
		width: 100%;
	}
}


/*------------------------------*/
/*-----Anchor-----*/
.sf-fixedAnchor {
    position: fixed;
    width: 100%;
    top: 60px;
    left: 50%;
    z-index: 60;
    transform: translateY(-100%) translateX(-50%);
    background-color: #fff;
    border-bottom: 1px solid #ebebec;
}
.sf-fixedAnchor[data-display-status] {
    transition: transform .3s
}
.sf-fixedAnchor[data-display-status=show] {
    transform: translateY(0) translateX(-50%)
}
.sf-fixedAnchor_container{
    max-width: 1200px;
    margin: 0 auto;
}
.sf-fixedAnchor_list {
    display: flex;
    margin: 0 auto;
    padding-right: 16px;
    background-color: #fff;
    width: 100%;
    overflow-x: scroll;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch
}
.sf-fixedAnchor_list::-webkit-scrollbar {
    display: none
}
.sf-fixedAnchor_list a{
    display: block;
    width: 100%;
    text-align: center;
}

.sf-fixedAnchor_item {
    margin-left: 16px;
    width: calc(50% - 16px);
    flex-shrink: 0
}
[data-mobile-column="5"] .sf-fixedAnchor_item {
    width: calc(25% - 16px);
}
.sf-fixedAnchor_itemLink {
    padding: 4px 0;
    color: #3c3c43;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    min-height: 42px;
    height: 100%;
    width: 100%;
    position: relative;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    background-color: #ffffff;
}
.sf-fixedAnchor_itemLink:before {
    background-color: #fff;
    content: "";
    display: block;
    height: 2px;
    width: 100%;
    position: absolute;
    bottom: 1px;
    left: 0;
    transition: background-color .3s ease-in-out
}
.sf-fixedAnchor_itemLink.-current:before {
    background-color: #3c3c43;
}
@media screen and (max-width: 850px) {
    .sf-fixedAnchor_item:last-child .sf-fixedAnchor_itemLink a{
        padding: 8px 10px 8px 40px;
    }
}
@media screen and (max-width: 767px) {
	.sf-fixedAnchor{
		top: -2px;
	}
    .sf-fixedAnchor_item:last-child .sf-fixedAnchor_itemLink a{
        padding: 5px;
        font-feature-settings: "palt";
    }
}
.sf-fixedAnchor_movingButton {
    width: 16px;
    height: calc(100% - 1px);
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background-color: #f5f5f5;
    transition: .2s
}
.sf-fixedAnchor_movingButton.-hidden {
    opacity: 0;
    visibility: hidden
}
.sf-fixedAnchor_movingButton:after,.sf-fixedAnchor_movingButton:before {
    content: "";
    width: 8px;
    height: 2px;
    display: inline-block;
    border-radius: 2px;
    background: #9d9da0;
    position: absolute
}
.sf-fixedAnchor_movingButton.-prev {
    left: 0
}
.sf-fixedAnchor_movingButton.-prev:before {
    top: calc(50% - 3px);
    transform: translateX(-50%) rotate(-45deg);
    left: 50%
}
.sf-fixedAnchor_movingButton.-prev:after {
    bottom: calc(50% - 3px);
    transform: translateX(-50%) rotate(45deg);
    left: 50%
}
.sf-fixedAnchor_movingButton.-next {
    background-position-x: -4em;
    right: 0
}
.sf-fixedAnchor_movingButton.-next:before {
    top: calc(50% - 3px);
    transform: translateX(-50%) rotate(45deg);
    left: 50%
}
.sf-fixedAnchor_movingButton.-next:after {
    bottom: calc(50% - 3px);
    transform: translateX(-50%) rotate(-45deg);
    left: 50%
}
@media screen and (max-width: 767px) {
    .sf-fixedAnchor_list{
        padding-right: 10px;
    }
    [data-mobile-column="4"] .sf-fixedAnchor_item {
        width: calc(27% - 10px);
    }
    .sf-fixedAnchor_itemLink a{
        font-size: 0.65rem;
		font-feature-settings: "palt";
    } 
    .sf-fixedAnchor[data-display-status=show] {
        transform: translateY(118%) translateX(-50%)
    }
    [data-mobile-column="5"] .sf-fixedAnchor_item {
        width: calc(27% - 6px);
    }
}
/*------------------------------*/