@charset "UTF-8";
html, body {
  height: 100%; }

body > #container {
  height: auto;
  margin-right: auto;
  margin-left: auto; }

#container {
  height: 100%;
  min-height: 100%;
  position: relative; }

body {
  color: #000000;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  line-height: 1;
}

a:link {
  color: #1a77c5;
  text-decoration: underline; }

a:hover {
  color: #3399CC;
  text-decoration: none; }

a:visited {
  color: #663366;
  text-decoration: none; }

a[href*="tel:"] {
  cursor: default; }

p:not(:last-child) {
  margin-bottom: 1em; }

img {
  max-width: 100%;
  width: auto;
  height: auto; }

/*----------------------------------------
■レイアウト
----------------------------------------*/
header {
  margin-bottom: 20px; }

header > .inner {
  max-width: 1100px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding: 10px 0px;
  display: flex;
  justify-content: space-between; }

header .logo a:link,
header .logo a:visited {
  display: block;
  background-image: url(../img/common/help_logo.png);
  background-repeat: no-repeat;
  background-size: contain;
  text-indent: -9999px;
  width: 218px;
  height: 65px;
}

.smp_sch_img,
.smp_sch_sw,
.smp_menu_img,
.smp_menu_sw{
	display: none;
}

header nav.bns ul {
  display: flex; }

header nav.bns .bn {
  width: 190px;
  border-top: solid 1px #d6d6d6;
  border-left: solid 1px #d6d6d6;
  border-bottom: solid 1px #d6d6d6;
  padding: 8px;
  text-align: center; }


header nav.bns .bn .lead {
  display: block;
  font-size: 14px;
  margin-bottom: 7px; }

header nav.bns .bn a:link,
header nav.bns .bn a:visited {
  text-decoration: none;
  color: inherit; }

header nav.bns .bn.qa .title {
  color: #15a6d6;
  font-weight: bold;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px; }

header nav.bns .bn.qa .title:before {
  content: "";
  background-image: url(../img/common/head_q.png);
  background-size: contain;
  width: 24px;
  height: 24px;
  margin-right: 3px; }

header nav.bns .bn.tel .title {
  color: #d61518;
  font-weight: bold;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px; }

header nav.bns .bn.tel .title:before {
  content: "";
  background-image: url(../img/common/head_tel.png);
  background-size: contain;
  width: 24px;
  height: 24px;
  margin-right: 3px; }

header nav.bns .bn.mail{
	border-right: solid 1px #d6d6d6;
}


header nav.bns .bn.mail .title {
  display: block;
  text-indent: -9999px;
  height: 24px;
  background-image: url(../img/common/head_mail.png);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center top; }

header li.global{
	display: none;
}

header .search {
  background-color: #454545; }

header .search .inner {
  width: 1100px;
  margin-left: auto;
  margin-right: auto;
  padding: 8px 0px;
  display: flex; }

header .search .inner .input {
  margin-right: 5px; }

header .search .inner .submit_btn {
  border: solid 2px #fff;
  background: #4b4b4b;
  border-radius: 5px;
  padding: 5px;
  width: 100px;
}

footer > .inner{
	width: 1100px;
	padding: 10px;
	margin-left: auto;
  margin-right: auto;
	text-align: center;
	font-size: 12px;
}

#breadcrumb ul.breadlist{
	display: flex;
	width: 1100px;
	margin-left: auto;
  margin-right: auto;
	margin-bottom: 20px;
}
#breadcrumb ul.breadlist li{
	font-size: 14px;
}
#breadcrumb ul.breadlist li:not(:last-child):after{
content: "\f054";
	font-family: "Font Awesome 5 Free";
	font-weight: bold;
	color: #A4A4A4;
	margin-right: 0.5em;
	margin-left: 0.5em;
}

main > section {
  margin-bottom: 40px;
}
main section > .inner {
  max-width: 1100px;
  margin: auto;
}
/*----------------------------------------
■汎用クラス
----------------------------------------*/

.title_1 {
	display: block;
  background: #0f9105;
  color: #fff;
  font-size: 24px;
  font-weight: bold;
  text-align: center;
  padding: 15px 10px;
  margin-bottom: 15px;
width: 100%;
}
aside .title_1 {
	font-size: 18px;
}

.title_2 {
  font-size: 20px;
  font-weight: bold;
  margin-bottom: 15px;
}
.title_3 {
	font-size: 26px;
	font-weight: bold;
	margin-bottom: 15px;
	background-image: url(../img/common/title_bg_1.gif);
	padding: 20px;
	color: #fff;
	text-align: center;
	border-top-left-radius: 5px;
	border-top-right-radius: 5px;
}
.ul_list_1 li{
	margin-bottom: 7px;
	text-indent: -1em;
	padding-left: 1em;
}
.ul_list_1 li:last-child{
	margin-bottom: 0px;
}
.ul_list_1 li:before{
	content: "・";
}



.menus_1 {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between; }

.menus_1 li {
  width: 49%;
  margin-bottom: 10px; }

.menus_1 li a:link,
.menus_1 li a:visited {
  color: inherit;
  text-decoration: none;
  display: flex;
  padding: 10px;
  background: #f0f0f0;
  border-radius: 5px; }

.menus_1 li a:before {
  content: "\f0da";
  font-family: "Font Awesome 5 Free";
  font-weight: bold;
  margin-right: 3px; }



main.page_top .device_boxs{
	display: flex;
	justify-content: space-between;
}
main.page_top .device_boxs .box{
	max-width: 540px;
	width: 49%;
	
}
main.page_top .device_boxs .box .img{
	background: #f4f4f4;
	text-align: center;
	padding: 20px;
	border-radius: 10px;
	margin-bottom: 15px;
}
main.page_top .device_boxs .box a:link,
main.page_top .device_boxs .box a:visited{
	display: block;
	width: 60%;
	background: #df1010;
	border-radius: 30px;
	padding: 15px;
	margin-left: auto;
	margin-right: auto;
	color: #fff;
	font-weight: bold;
	text-decoration: none;
	text-align: center;
}

main.page_top .device_boxs .box a:hover{
	background-color: #B50000;
}

/*----------------------------------------
■カテゴリアーカイブ
----------------------------------------*/
main.category_archive section .boxs .box .about_text {
  margin-bottom: 15px;
  line-height: 140%;
  padding-bottom: 15px;
  border-bottom: solid 2px #cfcfcf;
}
main.category_archive section .boxs {
  display: flex;
  justify-content: space-between;
}
main.category_archive section .boxs .box .title {
  display: flex;
  align-items: center;
}

main.category_archive section.sec_sale .boxs .box {
  width: 49%;
  border: solid 2px #e8e8e8;
  padding: 20px; }

main.category_archive section.sec_sale .boxs .box.market-shop .title:before {
  content: "";
  background-image: url(../img/common/shop.svg);
  width: 31px;
  height: 25px;
  margin-right: 5px;
}

main.category_archive section.sec_sale .boxs .box.original-shop .title:before {
  content: "";
  -webkit-mask-image: url(../img/common/shop.svg);
  mask-image: url(../img/common/shop.svg);
  width: 31px;
  height: 25px;
  margin-right: 5px;
  background-color: #d61518;
}

main.category_archive section.sec_design .box.designtool {
  width: 100%;
  border: solid 2px #e8e8e8;
  padding: 20px;
}
main.category_archive section.sec_design .box.designtool .title:before {
	content: "";
	background-image: url(../img/common/palette.svg);
	width: 30px;
	height: 27px;
	margin-right: 5px;
}
/*----------------------------------------
■サイドバー
----------------------------------------*/
aside{
	margin-right: 20px;
}
aside .side_block {
	margin-bottom: 20px;
}

aside ul.side_menulist > li > a:link,
aside ul.side_menulist > li > a:visited{
	text-decoration: none;
	color: #000;
	font-size: 18px;
	font-weight: bold;
	display: flex;
	align-items: center;
	border-bottom: solid 1px #e0e0e0;
	padding-bottom: 5px;
}
aside ul.side_menulist > li.market-shop > a:before{
	content: "";
  -webkit-mask-image: url(../img/common/shop.svg);
  mask-image: url(../img/common/shop.svg);
  width: 31px;
  height: 25px;
  margin-right: 5px;
  background-color: #000;
}
aside ul.side_menulist > li.original-shop > a:before{
	content: "";
  -webkit-mask-image: url(../img/common/shop.svg);
  mask-image: url(../img/common/shop.svg);
  width: 31px;
  height: 25px;
  margin-right: 5px;
   background-color: #d61518;
}

aside ul.side_menulist > li.designtool > a:before{
	content: "";
  -webkit-mask-image: url(../img/common/palette.svg);
  mask-image: url(../img/common/palette.svg);
  width: 30px;
  height: 27px;
  margin-right: 5px;
   background-color: #009acd;
}


aside ul.side_menulist > li{
	position: relative;
}
aside ul.side_menulist > li:not(:last-child){
	margin-bottom: 5px;
}
aside ul.side_menulist > li .sub_menu_img{
	position: absolute;
	width: 20px;
	height: 20px;
	right: 0;
	top: 5px;
	text-indent: -9999px;
	display: block;
}
aside ul.side_menulist > li .sub_menu_img:before{
	font-size: 20px;
	text-indent: 0px;
	height: 100%;
	position: absolute;
	display: flex;
	justify-content: center;
	align-items: center;
	content: "\f055";
	font-family: "Font Awesome 5 Free";
	font-weight: bold;
}


aside ul.side_menulist > li .sub_menu_sw{
	display: none;
}
aside ul.side_menulist > li .sub_menu_sw:checked ~ ul {
display: block;
}
aside ul.side_menulist > li .sub_menu_sw:checked ~ .sub_menu_img:before {
content: "\f056";
}
aside ul.side_menulist > li > ul{
	display: none;
}

aside ul.side_menulist > li > ul > li > a:link,
aside ul.side_menulist > li > ul > li > a:visited{
	text-decoration: none;
	color: #000;
	font-size: 16px;
	display: flex;
	align-items: center;
	border-bottom: dotted 1px #e0e0e0;
	padding-bottom: 15px;
	padding-top: 15px;
}

aside ul.side_menulist > li > ul > li > a:before{
	content: "\f0da";
  font-family: "Font Awesome 5 Free";
  font-weight: bold;
  margin-right: 3px;
}

aside ul.side_menulist > li > ul > li:last-child a{
	margin-bottom: 30px;
	border-bottom: none;
}

/*----------------------------------------
■サブページ
----------------------------------------*/
.sub_page_wrap{
	max-width: 1100px;
	margin-left: auto;
	margin-right: auto;
	display: flex;
	flex-direction: row-reverse;
	justify-content: space-between;
}
.sub_page_wrap main{
	max-width: 800px;
	width: 100%;
}
.sub_page_wrap main section > .inner{
	width: 100%;
}
.sub_page_wrap aside{
	max-width: 270px;
	width: 100%;
}
.sub_page_wrap main .step_boxs{
	counter-reset: number 0;
	margin-bottom: 50px;
}

.sub_page_wrap main .step_boxs .box{
	background: #ebebeb;
	padding: 30px;
	position: relative;
}
.sub_page_wrap main .step_boxs .box .step_title{
	font-size: 18px;
	font-weight: bold;
	display: flex;
	align-items: center;
	margin-bottom: 20px;
}
.sub_page_wrap main .step_boxs .box .step_title:before{
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	counter-increment: number 1;
  content:"STEP" counter(number);
	background: #323232;
	font-size: 12px;
	color: #fff;
	width: 50px;
	height: 50px;
	margin-right: 10px;
}
.sub_page_wrap main .step_boxs .box .img{
	text-align: center;
}
.sub_page_wrap main .step_boxs .box:not(:last-child){
	margin-bottom: 50px;
}
.sub_page_wrap main .step_boxs .box:not(:last-child):after{
	content: "\f0d7";
	font-family: "Font Awesome 5 Free";
	text-align: center;
	font-weight: bold;
	position: absolute;
	margin-left: auto;
	margin-right: auto;
	font-size: 40px;
	line-height: 0;
	left: 0;
	right: 0;
	bottom: -25px;
}

.sub_page_wrap main .boxs_divided{
	display: grid;
    grid-gap: 10px;
    grid-template-columns: repeat(auto-fit,minmax(250px, 1fr));
    justify-content: space-between;
}
.sub_page_wrap main .boxs_divided .box{
	border: 1px solid #dcdcdc;
}
.sub_page_wrap main .boxs_divided .box:nth-child(3n){
	margin-right: 0px;
}
.sub_page_wrap main .boxs_divided .box .title{
	background: #f7f7f7;
	padding: 15px;
	text-align: center;
	font-weight: bold;
}
.sub_page_wrap main .boxs_divided .box .body{
	padding: 15px;
}
.sub_page_wrap main h2{
	font-size: 24px;
	font-weight: bold;
	border-left: 6px solid #000000;
	padding-left: 5px;
	padding-top: 3px;
	padding-bottom: 3px;
	margin-bottom: 20px;
}

/*----------------------------------------
■検索結果
----------------------------------------*/
main.page_searchresult .result_header{
	font-weight: bold;
	margin-bottom: 1em;
}

main.page_searchresult .results_boxs .box{
	width: 100%;
  border: solid 2px #e8e8e8;
  padding: 15px;
	position: relative;
	margin-bottom: 10px;
}

main.page_searchresult .results_boxs .box .subinfo .title{
	font-weight: bold;
	display: block;
	margin-bottom: 5px;
}
main.page_searchresult .results_boxs .box .subinfo .text{
	line-height: 140%;
}
main.page_searchresult .results_boxs .box a{
	text-indent: -9999px;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
main.page_searchresult .results_boxs .box a:hover:after{
	content: "";
	background-color: rgba(255,255,255,0.40);
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

/*----------------------------------------
■アーカイブ
----------------------------------------*/
main.archive_page .article_list li{
	margin-bottom: 10px;
}
main.archive_page .article_list li a:link,
main.archive_page .article_list li a:visited{
	padding: 10px;
	border: 2px solid #ECECEC;
	display: block;
	text-decoration: none;
}
main.archive_page .article_list li a:before{
	content: "\f138";
	font-family: "Font Awesome 5 Free";
	font-weight: bold;
	margin-right: 5px;
}

