@charset "utf-8";
/*
Theme Name: TATSUKEN'theme 2024
Theme URI: 
Version: 2024
Description: TATSUKEN official theme
Author: functions starman
*/


* {
	margin: 0;
	padding: 0;
}


:root {
  --main-color: #ffd500;
  --sub-color: #2ea9d0;
}

html {
	width: 100%;
	height: 100%;
}

.grecaptcha-badge {
	visibility: hidden;
}

body {
	font-size :62.5% ;
	font-family: "Oswald", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-style: normal;
	width: 100%;
	height: 100%;	
	text-align: left;
	color: #000;
	overflow-x: hidden;
	position: relative;
}

.noto-serif-jp-extralight {
	font-family: "Noto Serif JP", serif;
	font-weight: 200;
	font-style: normal;
  }
  
  .noto-serif-jp-light {
	font-family: "Noto Serif JP", serif;
	font-weight: 300;
	font-style: normal;
  }
  
  .noto-serif-jp-regular {
	font-family: "Noto Serif JP", serif;
	font-weight: 400;
	font-style: normal;
  }
  
  .noto-serif-jp-medium {
	font-family: "Noto Serif JP", serif;
	font-weight: 500;
	font-style: normal;
  }
  
  .noto-serif-jp-semibold {
	font-family: "Noto Serif JP", serif;
	font-weight: 600;
	font-style: normal;
  }
  
  .noto-serif-jp-bold {
	font-family: "Noto Serif JP", serif;
	font-weight: 700;
	font-style: normal;
  }
  
  .noto-serif-jp-black {
	font-family: "Noto Serif JP", serif;
	font-weight: 900;
	font-style: normal;
  }
  

img {
	display: block;
	border-style: none;
	max-width: 100%;
	height: auto;
	image-rendering: -webkit-optimize-contrast;
}

li {
	list-style-type: none;
}	

a {
	text-decoration: none;
	color: #000;
}

a:focus {
	outline: none;
}

h1,h2,h3 {
	font-weight: normal;
}

.n {
	position: absolute !important;
	top: 0!important;
	left: 0!important;
	height: 0!important;
	width: 0!important;
	overflow: hidden !important;
}

.w100 {
	width: 100%;
}

.pcPage .pn {
	display: none;
}

.l {
	float: left;
}

.r {
	float: right;
}

.full {
	width: 100%;
}

.db {
	display: block;
	width: 100%;
	height: 100%;
}

.tac {
	text-align: center;
}

.ma {
	margin: 0 auto;
}

.mbs {
	display: none;
}

#wrapper {
	width: 100%;
	max-width: 100vw;
}

#header {
	display: flex;
	justify-content: space-between;
	width: 100%;
	height: 100px;
	z-index: 1000;
	position: relative;
}

#topPage #siteTitle {
	width: 18%;
	height: 120px;
	padding: 0 0 0 5px;
	box-sizing: border-box;
}

.page #siteTitle {
	width: 18%;
	height: 100px;
	padding: 5px;
	box-sizing: border-box;
}

#siteTitle a {
	display: block;
	width: 100%;
	height: 100%;
}

#siteTitle img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

#navWrapper {
	display: flex;
	justify-content: flex-end;
	width: 80%;
	float: right;
}

#mainNav {
	display: flex;
	justify-content: space-between;
	width: 70%;
}

#mainNav ul {
	width: 100%;
	display: flex;
	justify-content: space-between;
	justify-items: center;
}

#mainNav li {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	height: 100%;
	width: calc(100% / 6);

}

#mainNav li a {
	display: block;
	color: #FFF;
	width: 100%;
	text-align: center;
	font-size: 1rem;
}

#topPage #mainNav li a {
	text-shadow: 2px 2px 4px rgba(0,0,0,0.3);
}

.page #mainNav li a {
	color: #000;
}

.list_name_en {
	display: block;
	width: 100%;
	font-weight: bold;
}

.list_name_jp {
	display: block;
	width: 100%;
	font-size: .8rem;
}

#contactNav {
	display: flex;
	justify-content: space-between;
	width: 23%;
}

.to_tel {
	display: block;
	width: 100%;
	color: #FFF;
	padding: 5px;
	box-sizing: border-box;
	background: rgba(0, 0, 0, .5);
}

.tel_title {
	display: block;
	text-align: center;
	font-size: 1rem;
	font-weight: bold;
	border-bottom: 1px solid var(--main-color);
}

.tel_num {
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 2rem;
	font-weight: bold;
}

.to_tel img {
	width: 30px;
	margin: 10px 10px 10px 0;
}

.tel_business_hour {
	display: block;
	width: 100%;
	font-size: .8rem;
	text-align: center;
	margin-top: -5px;
}

#contactInfo {
	width: 63px;
	position: fixed;
	right: 0;
	top: calc(50% - 200px);
	display: flex;
	flex-wrap: wrap;
	justify-items: center;
	justify-content: center;
}

#contactInfo li {
	width: 100%;
	height: 200px;
	font-size: 1rem;
	text-align: center;
		display: flex;
	justify-content: center;
}

#contactInfo li span {
	display: inline-block;
	text-align: center;
	padding-top: 10px;
}

.to_catalog {
	background: var(--sub-color);
	color: #FFF;
}

.to_catalog a {
	display: flex;
		flex-wrap: wrap;
	justify-content: center;
	height: 100%;
	width: 100%;
	text-align: center;
	padding: 5px 0;
	box-sizing: border-box;
	color: #FFF;
	writing-mode: vertical-rl;
	align-items:center;
}

.to_contact {
	background: var(--main-color);
	color: var(--sub-color);
}

.to_contact a {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	height: 100%;
	width: 100%;
	text-align: center;
	padding: 5px 0;
	box-sizing: border-box;
	color: var(--sub-color);
	writing-mode: vertical-rl;
	align-items:center;
}

.to_catalog img {
	width: 50%;
	margin: 5px 0 0 3%;
}

.to_contact img {
	width: 45%;
	margin: 5px 0 0 5%;
}

#topMainFigure {
	position: absolute;
	width: 100%;
	height: calc(100% - 200px);
	display: flex;
	overflow: hidden;
	top: 0;
	z-index: -1;
}

.main_figure_wrapper {
	width: 100%;
}

.main_figures {
	position: absolute;
	width: 84%;
	top: -200px;
	right: 0;
}

.main_figures::after {
	content: "";
	display: block;
	position: absolute;
	width: 500px;
	height: 200px;
	background: rgb(255, 255, 255);
	transform: rotate(204deg);
	left: -100px;
	bottom: 0;
}


.main_figures img {
	width: 100%;
	object-fit: cover;
}

#mainImgFig .main_img {
	display: none;
	position: absolute;
}

.currentFigure {
	display: block;
}

.starFigure {
	display: block;
}

.main_figure_wrapper h2 {
	position: absolute;
	left: 2%;
	top: 26%;
}

.main_figure_wrapper h2 span {
	display: inline-block;
	background: rgba(255,255,255,.8);
	color: var(--sub-color);
	font-size: 4rem;
	font-weight: bold;
	padding: 20px 20px 13px 20px;
	line-height: 100%;
	box-sizing: border-box;
	margin-bottom: 10px;
	border-radius: 10px;
}

#topCotalogAnnounce {
	position: absolute;
	left: 30px;
	bottom: 10px;
	background: url(./images/garage.png) no-repeat;
	background-size: contain;
	width: 500px;
	height: 300px;
}

.catalog_offer_img {
	display: block;
	position: absolute;
	bottom: 30px;
	left: -6px;
	z-index: 5000;
}

.catalog_offer_img img {
	width: 230px;
	height: auto;
}

#topImgIndex {
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100%;
	position: absolute;
	bottom: 0;
	right: 0;
	height: 200px;
	padding: 0 10px;
	box-sizing: border-box;
	background: #FFF;
}

#leftNav {
	display: flex;
	width: 16%;
	padding: 60px 20px;
	box-sizing: border-box;
}

#leftNav ul {
	display: flex;
	flex-wrap: wrap;
}

#leftNav ul li {
	width: 100%;
}

#leftNav ul li a {
	display: flex;
	align-items: center;
	width: 100%;
	height: 50px;
	color: #FFF;
	background: #2ea9d0;
	font-size: 1rem;
	padding: 0 10px;
	box-sizing: border-box;
}

#leftNav ul li:not(:last-child) a{
	border-bottom: 1px dotted #FFF;
}

.kakuichi_banner {
	width: 10%;
	margin: 50px 0 0 50px;
}

.kakuichi_banner span {
	font-size: 1.2rem;
	font-weight: bold;
}

#topVisitToSiteAnnounce {
	width: 14%;
	background: #f08b08;
	border-radius: 5px;
	padding: 20px;
	box-sizing: border-box;
	margin: 40px 1%;
}

#topVisitToSiteAnnounce a {
	color: #FFF;
}

#topVisitToSiteAnnounce h3 {
	font-size: 1rem;
	font-weight: bold;
	width: 100%;
text-align: center;
}

.visit_detail>span {
	display: flex;
	font-size: 2rem;
	align-items: center;
	justify-content: center;
}

#topVisitToSiteAnnounce span.w100 {
	display: block;
}

.visit_arrow {
	display: inline-block;
	font-size: 1.2rem !important;
	background: rgb(17, 179, 31);
	border-radius: 50px;
	padding: 0 10px;
	box-sizing: border-box;
	margin: 10px 0;
}

#topVisitToSiteAnnounce .visit_description {
	font-size: 1rem;
}

.top_message {
	width: 60%;
	font-size: 4rem;
	font-weight: bold;
	position: absolute;
	right: 0;
	bottom: 0;
	color: rgba(255, 213, 0,1);
	background: rgba(255, 255, 255, .9);
	padding: 20px 40px;
	box-sizing: border-box;
}

#topImgIndex li {
	width: calc(100% / 6);
}

#topImgIndex li img {
	width: 100%;
	height: 150px;
	object-fit: cover;
}

#pageFigure {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 300px;
	position: relative;
}

#pageFigure::before {
	content: "";
	display: block;
	position: absolute;
	width: 300px;
	height: 200px;
	background: rgb(255, 255, 255);
	transform: rotate(204deg);
	left: -100px;
	bottom: -150px;
}


.page #header {
	background: #FFF;
	box-shadow: 2px 2px 4px -2px #000;
}

#catalogPage #pageFigure {
	background: url(./images/items/index_27.jpg) no-repeat;
	background-position: bottom -330px center;
	background-size: cover;
}

#pageFigure h1 {
	display: flex;
	justify-content: center;
	align-items: center;
	background: rgba(46, 169, 208, .85);
	color: #FFF;
	padding: 10px 50px;
	box-sizing: border-box;
	font-size: 2rem;
	height: 100%;
	font-weight: bold;
	min-width: 300px;
	text-align: center;
}

main {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}

.sections {
	width: 1126px;
	max-width: 100vw;
	position: relative;
}

.page_section_header {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	padding: 100px 0;
	position: relative;
}

.page_section_header p {
	width: 100%;
	text-align: center;
	font-size: 2rem;
}

/* catalog */
#catalogPage .sections h1 {
	text-align: center;
	margin: 50px 0;
	font-size: 1.2rem;
}

#catalogSection::before {
	content: "CATALOG";
	display: inline-block;
	line-height: 100%;
	font-size: 12rem;
	transform: rotate(90deg);
	transform-origin: left top;
	position: absolute;
	left: -140px;
	top: -100px;
	color: var(--main-color);
}


/* contact */
#contactPage .sections h1 {
	text-align: center;
	margin: 50px 0 20px;
	font-size: 2rem;
	font-weight: bold;
	color: var(--sub-color);
}

#contactSection::before {
	content: "CONTACT";
	display: inline-block;
	line-height: 100%;
	font-size: 12rem;
	transform: rotate(90deg);
	transform-origin: left top;
	position: absolute;
	left: -140px;
	top: -100px;
	color: var(--main-color);
}

#contactPage .sections .to_tel {
	width: 100%;
	background: none;
	color: var(--sub-color);
	text-align: center;
}

#contactPage .sections .to_tel .tel_icon {
	width: 50px;
	margin-right: 20px;
}

#contactPage .sections .tel_num {
	font-size: 4rem;
}

#contactPage .sections .to_tel .operator_img {
	width: 150px;
	margin-left: 20px;
	margin-top: -10px;
}


#contactPage .sections .tel_business_hour {
	width: 60%;
	border-top: 1px dotted var(--sub-color);
	border-bottom: 1px dotted var(--sub-color);
	color: var(--sub-color);
	font-size: 1.6rem;
	margin: 20px auto 50px;
}

#companyPage #pageFigure {
	background: url(./images/items/index_25.jpg) no-repeat;
	background-position: bottom -300px center;
	background-size: cover;
}

#companySection {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	padding: 50px 0;
	box-sizing: border-box;
}


#companySection::before {
	content: "COMPANY";
	display: inline-block;
	line-height: 100%;
	font-size: 12rem;
	transform: rotate(90deg);
	transform-origin: left top;
	position: absolute;
	left: -140px;
	top: -100px;
	color: var(--main-color);
}

#companySection header::before {
	content: "";
	display: block;
	position: absolute;
	width: 460px;
	height: 310px;
	background: url(./images/company_01.png) no-repeat;
	background-size: contain;
	left: -90px;
	bottom: 10px;
}

#companySection header::after {
	content: "";
	display: block;
	position: absolute;
	width: 220px;
	height: 310px;
	background: url(./images/company_02.png) no-repeat;
	background-size: contain;
	right: 50px;
	bottom: -100px;
	z-index: 1;
}

.company_figure {
	width: 50%;
	position: relative;
}

.company_hello_img {
	margin-left: 20px;
	width: 100%;
	height: 800px;
	object-fit: cover;
}

.hello {
	width: 80%;
	margin: 0 auto;
	padding: 30px 50px 50px 0;
	box-sizing: border-box;
	line-height: 200%;
	font-size: 1rem;
}

.hello h1 {
	display: none;
	margin-bottom: 30px;
}

.hello img {
	margin: 30px 80px 0 0;
	width: 200px;
	float: right;
}

.hello_caption {
	font-size: 3.5rem;
	writing-mode: vertical-rl;
	position: absolute;
	right: 6%;
	top: 5%;
	color: #FFF;
	height: 800px;
}

.remarkable {
	display: inline-block;
	width: 100%;
	font-size: 2rem;
	padding: 20px 0;
}

#companyInfo {
	display: flex;
	flex-wrap: wrap;
}

#companyInfo h1 {
	width: 100%;
	text-align: center;
}

.company_table{
	flex:1;
	padding: 15px 25px;
	line-height: 2;
	letter-spacing: .03rem;
	font-size: 1rem;
}

.company_table dl{
	display: flex;
	padding: 6px 0;
	width: 100%; 
	border-top: 1px solid #C8C8C8;
}

.company_table dt{
	width: 26%;
	background-color: #f6f6f6;padding: 25px;
	font-weight: 500;
}

.company_table dd{
	padding: 25px;flex:1;
}

.section_title span {
	display: inline-block;
	width: 40%;
	font-weight: bold;
	font-size: 2rem;
	padding: 10px 0;
	border-radius: 10px;
}

/* qa */
#qaPage #pageFigure {
	background: url(./images/items/index_30.jpg) no-repeat;
	background-position: bottom -300px center;
	background-size: cover;
}


#qaSection::before {
	content: "Q&A";
	font-size: 12rem;
	display: inline-block;
	line-height: 100%;
	transform: rotate(90deg);
	transform-origin: left top;
	position: absolute;
	left: -140px;
	top: -100px;
	color: var(--main-color);
}

#qaSection header::before {
	content: "";
	display: block;
	position: absolute;
	width: 160px;
	height: 310px;
	background: url(./images/qa_01.png) no-repeat;
	background-size: contain;
	left: 90px;
	bottom: -40px;
}

#qaSection header::after {
	content: "";
	display: block;
	position: absolute;
	width: 220px;
	height: 310px;
	background: url(./images/qa_02.png) no-repeat;
	background-size: contain;
	right: 50px;
	bottom: -100px;
	z-index: 1;
}

section.faq{
	max-width: 1100px;
	margin: 50px auto;
	text-align: right;
}

.accordion_area{
	text-align:left;
    list-style: none;
    width: 100%;
    max-width: 1100px;
    margin:2rem auto;
}

.accordion_area li{
    margin: 10px 0;
}

.accordion_area section {
  border-bottom: 1px solid #ccc;

  position: relative;
}

/*アコーディオンタイトル*/
.accordion_area .title {
    position: relative;/*+マークの位置基準とするためrelative指定*/
    cursor: pointer;
    font-weight: 500;
	font-size: 1.3rem;
    padding: 2% 50px 2% calc(2% + 35px);
    transition: all .5s ease;
	font-weight: bold;
}

.accordion_area section:before{
	content: "Q";
	padding-top: 1%;
	padding-left: 1rem;
	padding-right: 1rem;
	position: absolute;
	top: -.2em;
	color: var(--sub-color);
	font-size: 2.5rem;
	font-weight: 700;
}

/*アイコンの＋と×*/
/* .accordion_area .title::before,
.accordion_area .title::after{
    position: absolute;
    content:'';
    width: 20px;
    height: 2px;
    background-color: #009fe8;
    
}
.accordion_area .title::before{
    top:48%;
    right: 15px;
    transform: rotate(0deg);
    
}
.accordion_area .title::after{    
    top:48%;
    right: 15px;
    transform: rotate(90deg);

} */
/*　closeというクラスがついたら形状変化　*/
/* .accordion_area .title.close::before{
  transform: rotate(45deg);
}

.accordion_area .title.close::after{
  transform: rotate(-45deg);
} */

/*アコーディオンで現れるエリア*/
.accordion_area .box {
    background: #f6f6f6;
  	margin:0 2% 2% 2%;
    padding: 2%;
}

.accordion_area .box p{
	font-size: 1rem;
	line-height:2;
    padding: 0;
}

.accordion_area .box a{
	font-weight: 700;
	padding: 0 .5rem;
	border-bottom: 2px dotted var(--sub-color);
	transition: .2s;
	
}

.accordion_area .box a:hover{
	color: var(--sub-color);
}

/* product */
#worksPage #pageFigure {
	background: url(./images/items/index_08.jpg) no-repeat;
	background-position: bottom -240px center;
	background-size: cover;
}

#worksSection::before {
	content: "WORKS";
	display: inline-block;
	line-height: 100%;
	font-size: 12rem;
	transform: rotate(90deg);
	transform-origin: left top;
	position: absolute;
	left: -140px;
	top: -100px;
	color: var(--main-color);
}

#worksNav {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
	align-items: center;
	margin: 50px 0 0 0;
	padding: 10px 0;
	border-top: 1px solid var(--main-color);
	border-bottom: 1px solid var(--main-color);

}

#worksNav li {
	font-size: 1rem;
	font-weight: bold;
	text-align: center;
}

#worksNav .current_list {
	background: var(--main-color);
	padding: 5px 15px;
	border-radius: 20px;
}

#worksSection header {
	font-size: 1rem;
	text-align: center;
	padding: 40px 0;
}

.works_list {
	display: none;
}

.works_list.current_list {
	display: flex;
	width: 100%;
	flex-wrap: wrap;
	justify-content: space-between;
	margin-top: 0;
}

.works_list li {
	width: 31%;
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 30px;
}

.products_img {
	height: 316px;
	width: 100%;
	object-fit: cover;
	margin: 10px 0 30px 0;
}

.works_list div {
	width: 100%;	
}

.works_list li.rank_1 {
	position: relative;
 }

.works_list li.rank_1::after {
  content: "";
  width: 52px;
  height: 72px;
  background: url(./images/rank_01.png) center top/contain no-repeat;
  display: block;
  position: absolute;
  top: -3px;
  right: 6px;
  z-index: 2;
}

.works_list h3 {
	font-size: 1rem;
	font-weight: bold;
	width: 100%;
	margin: 10px 0;
}

.works_cat {
	background: rgba(46, 169, 208, .85);
	color: #FFF;
	padding: 5px 10px;
	box-sizing: border-box;
}

.works_name {
	padding: 5px 10px;
	box-sizing: border-box;
}

.works_list p {
	font-size: 1rem;
}

.works_list a {
	width: 100%;
	padding: 10px 10px 40px 10px;
	box-sizing: border-box;
	font-size: 1rem;
	background: var(--main-color);
	float: right;
	margin: 0 0 30px 0;
	position: relative;
}

.works_list a::after {
	content: "";
	display: block;
	width: 100px;
	height: 1px;
	border-bottom: 1px solid #000;
	position: absolute;
	right: 10px;
	bottom: 10px;
}

.works_list a::before {
	content: "";
	display: block;
	width: 20px;
	height: 1px;
	border-bottom: 1px solid #000;
	position: absolute;
	right: 10px;
	bottom: 15px;
	transform: rotate(-150deg);
}

.works_list img {
	width: 100%;
	height: 200px;
	object-fit: cover;
}

.works_list .post_cat {
	display: inline-block;
	background: var(--sub-color);
	color: #FFF;
	padding: 5px;
	box-sizing: border-box;
	margin-top: 10px;
}

.works_list .post_size {
	font-size: .8rem;
}

.work_main_img_wrapper {
	display: flex;
	width: 100%;
}

.work_main_img_wrapper img {
	width: 100%;
}

.post_wrapper {
	margin: 60px 0;
	border-bottom: 2px solid var(--main-color);
}

.post_wrapper header {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
}

.post_wrapper header h1 {
	width: 100%;
	padding: 10px 20px;
	box-sizing: border-box;
	font-size: 1.5rem;
	font-weight: bold;
	background: var(--main-color);
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.works_product {
	background: #000;
	color: #FFF;
	padding: 5px 15px;
	box-sizing: border-box;
	border-radius: 25px;
	font-size: 1rem;
}


.header_table_wrapper {
	width: 100%;
}

.works_info_table {
	width: 100%;
	margin: 20px 0;
	font-size: 1rem;
}

.works_info_table th {
	background: var(--main-color);
	padding: 5px 10px;
	box-sizing: border-box;
}

.works_info_table td {
	padding: 10px;
	box-sizing: border-box;
}

.work_images {
	display: flex;
	width: 100%;
	justify-content: center;
	gap: 10px;
	margin: 30px 0 60px 0;
}

.work_images li {
	width: 20%;
}

.pc_page #worksPreview {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
}

#worksPreview h1 {
	font-size: 1.6rem;
	width: 100%;
	padding: 40px 0 80px 0;
	text-align: center;
	font-weight: bold;
}

#worksPreview h1 span {
	padding: 5px 20px 5px 20px;
	box-sizing: border-box;
	background: var(--main-color);
	color: var(--sub-color);
}

#topPage.pc_page #worksPreview {
	/*display: none;*/
	width: 1200px;
	max-width: 100%;;
	margin: 400px auto 0;
}

.pc_page #worksPreview h2 {
	font-size: 2rem;
	font-weight: bold;
	color: #FFF;
}

.pc_page #worksPreview .works_list {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.pc_page #worksPreview .works_list li {
	width: 31%;
}

#voiceSection {
	background: var(--sub-color);
	padding: 40px 0;
}

#voiceSection h1 {
	width: 100%;
	font-size: 1.6rem;
}

#voiceSection h1 span {
	padding: 5px 20px 5px 20px;
	box-sizing: border-box;
	background: var(--main-color);
	color: var(--sub-color);
}

#voiceSection picture {
	padding: 40px 0;
	box-sizing: border-box;
	display: flex;
	justify-content: center;
}

.voice_box {
	width: 60%;
	margin: 40px auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.voice_box iframe {
	width: 45%;
	aspect-ratio: 16 / 9;
	margin: 20px;
}



/* about */
#aboutPage #pageFigure {
	background: url(./images/items/index_19.jpg) no-repeat;
	background-position: bottom -300px center;
	background-size: cover;
}

#aboutSection::before {
	content: "ABOUT";
	display: inline-block;
	line-height: 100%;
	font-size: 12rem;
	transform: rotate(90deg);
	transform-origin: left top;
	position: absolute;
	left: -140px;
	top: -100px;
	color: var(--main-color);
}

#aboutSection header::before {
	content: "";
	display: block;
	position: absolute;
	width: 360px;
	height: 210px;
	background: url(./images/about_01.png) no-repeat;
	background-size: contain;
	left: -90px;
	bottom: 10px;
}

#aboutSection header::after {
	content: "";
	display: block;
	position: absolute;
	width: 220px;
	height: 310px;
	background: url(./images/about_02.png) no-repeat;
	background-size: contain;
	right: 50px;
	bottom: -100px;
	z-index: 1;
}

section.about{
	max-width: 1100px;margin: 0px auto;text-align: right;}

.top_about_flex,
.about_flex{
	display: flex;
	justify-content: space-around;
	flex-wrap:wrap;
	padding: 60px 0;
	gap:60px;
}

.about_box{
	max-width: 50%;
	padding: 15px 25px 45px;
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}

.about_box .about_no{
	display: flex;
	align-items: baseline;
	justify-content: flex-end;
	font-family: 'Barlow', sans-serif;font-size: 72px;
	font-weight: bold;
	color: var(--sub-color);
	line-height: 50px; width: 72px;
	margin-right:  30px;
}


.about_info h3{
	font-size: 25px;
	font-weight: 600;
	line-height: 1;
	padding: 5px 0 16px;
	border-bottom: 2px solid #101010;
	text-align: left;
}

.about_info p{
	padding-top: 10px;
	text-align: justify;
	line-height:1.8;
	font-size: 1rem;
}

.about_info .pic{
	line-height: 0;
	padding-top: 5px;
}

.about_flex .about_box{
	max-width: calc(50% - 30px);
	padding: 15px 0px 50px;
}

#aboutMessage {
	background:  rgba(241, 241, 241, 0.6);
	position: relative;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}

.content {
	width: 1012px;
	max-width: 100vw;
	position: relative;
	display: flex;
	flex-wrap: wrap;
}

#aboutMessageContent{
	padding: 50px 0;
}

#aboutMessageContent h2 {
	text-align: center;
	font-size: 2rem;
}

#aboutMessageContent h2 span {
	display: inline-block;
	position: relative;
}

#aboutMessageContent h2 span::before {
	content: "";
	display: block;
	position: absolute;
	height: 1px;
	width: 30px;
	border-bottom: 1px solid #000;
	transform: rotate(-60deg);
	bottom: .8em;
	right: -40px;
}

#aboutMessageContent h2 span::after {
	content: "";
	display: block;
	position: absolute;
	height: 1px;
	width: 30px;
	border-bottom: 1px solid #000;
	transform: rotate(60deg);
	bottom: .8em;
	left: -40px;
}


.about_img_01 {
	position: absolute;
	width: 400px;
	top: -50px;
	left: -200px;
}

.about_img_02 {
	position: absolute;
	width: 200px;
	right: -20px;
	bottom: 0;
}

#aboutMessageDescription h3 {
	font-size: 1.5rem;
	margin-bottom: 30px;
}

#aboutMessageDescription {
	margin: 30px 0 30px 21%;
	width: 600px;
	font-size: 1rem;
	line-height: 180%;
}

/* flow */


#flowPage #pageFigure {
	background: url(./images/items/index_26.jpg) no-repeat;
	background-position: bottom -400px center;
	background-size: cover;
}

#flowSection::before {
	content: "FLOW";
	display: inline-block;
	line-height: 100%;
	font-size: 12rem;
	transform: rotate(90deg);
	transform-origin: left top;
	position: absolute;
	left: -140px;
	top: -100px;
	color: var(--main-color);
}

#flowSection header::before {
	content: "";
	display: block;
	position: absolute;
	width: 360px;
	height: 210px;
	background: url(./images/flow_01.png) no-repeat;
	background-size: contain;
	left: -50px;
	bottom: 10px;
}

#flowSection header::after {
	content: "";
	display: block;
	position: absolute;
	width: 280px;
	height: 380px;
	background: url(./images/flow_02.png) no-repeat;
	background-size: contain;
	right: 20px;
	bottom: -150px;
	z-index: 1;
}


.flows {
	display: flex;
	flex-wrap: wrap;
	padding: 0 15%;
	box-sizing: border-box;
	font-size: 1rem;
}

.flows h2 {
	font-size: 1.4rem;
	font-weight: bold;
	width: 60%;
	text-align: center;
	margin: 0 auto;
	background: var(--main-color);
	padding: 20px 50px;
	box-sizing: border-box;
	border-radius: 40px;
}

.flows {
	padding-top: 60px;
	width: 100%;
}


.flows ul {
	width: 100%;
	margin-top: 60px;
}

.flows li {
	width: 100%;
	display: flex;
	align-items: start;
	padding: 20px 0;
	position: relative;
}

.flows li::before {
	content: "";
	display: block;
	height: 160px;
	width: 1px;
	background: #000;
	position: absolute;
	top: 120px;
	left: calc(20% - .5px);
}



.flows li div:first-child {
	width: 40%;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
}

.flows li h3 {
	width: 100%;
	font-size: 1.4rem;
	font-weight: bold;
	text-align: center;
	padding-left: 20%;
	background: var(--main-color);
	padding: 10px 0;
	position: relative;
}

.flows li h3::after {
	content: "";
	display: block;
	position: absolute;
	bottom: -20px;
	left: calc(50% - 30px);
	background: var(--main-color);
	width: 60px;
	aspect-ratio: 1.5/cos(30deg);
	clip-path: polygon(50% 100%,100% 0,0 0);
} 


.flows li div:last-child {
	width: 50%;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	box-sizing: border-box;
	position: relative;
	margin-left: 60px;
}

.flows li img {
	width: 80%;
	height: 250px;
	object-fit: contain;
	margin: 0 auto;
}

.flows li img.flow_step_img_04 {
	width: 70%;
}

.flows li p {
	width: 100%;
	position: absolute;
	background: rgba(255,213,0,1);
	bottom: 0;
	left: 0;
	padding: 10px;
	box-sizing: border-box;
}


.flow_02 h2 {
	background: var(--sub-color);
	color: #FFF;
}

.flow_02 li p {
	width: 100%;
	position: absolute;
	background: var(--sub-color);
	bottom: 0;
	left: 0;
	padding: 10px;
	box-sizing: border-box;
	color: #FFF;
}

.flow_02 li h3 {
	background: var(--sub-color);
	color: #FFF;
}

.flow_02 li h3::after {
	background: var(--sub-color);
} 


/* form */

#form {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	padding: 50px;
	box-sizing: border-box;
	background: #efefef;
}

#form h2 {
	width: 100%;
	text-align: center;
	font-size: 1.8rem;
	font-weight: bold;
	margin-bottom: 50px;
}

#form .require {
	font-size: .8rem;
	font-weight: normal;
	margin-left: 10px;
	color: var(--sub-color);
}

#catalogImgSet {
	max-width: 1000px;
	margin: 30px auto 0;
	display: flex;
}


#catalogImgSet .wpcf7-form-control {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

#catalogImgSet .wpcf7-list-item label{display:flex;align-items: center;}
#catalogImgSet .wpcf7-list-item .wpcf7-list-item-label::before {
	display: block;
	position:absolute;
	content: "";
	width:200px;
	height:138px;
	left:0;top:0;
	margin-right:15px;
	background-repeat:no-repeat;
	background-size: contain !important;
	border:1px solid #ccc;
}

#catalogImgSet .wpcf7-list-item .wpcf7-list-item-label {
position:relative;
	width:100%;
	display:flex;flex-direction:column;
	padding-left:215px;
	height:150px;
	font-size: 16px;
	text-align: left;
	font-weight: bold;
}
#catalogImgSet .wpcf7-list-item {
	cursor: pointer;
	position: relative;
	width:48%;
	margin:0 0 30px 0!important;
}

#catalogImgSet .wpcf7-list-item:last-child {
	margin:0 0 0 0!important;
}

#catalogImgSet .wpcf7-list-item input {
	z-index: 10;
	width: 40px;
	height: 40px;
	margin-right: 10px;
}
#catalogImgSet .wpcf7-list-item .wpcf7-list-item-label:after {
	position:relative;
	border-top:solid 2px var(--sub-color);
	font-weight:normal;
	padding-top:5px;
	margin-top:5px;
	font-size: 11.5px;
	line-height:1.4;text-align:justify;
}

#catalogImgSet .wpcf7-list-item:nth-of-type(1) .wpcf7-list-item-label::before {
	background: url(./images/03-shop_sg.png) no-repeat;
	
}
#catalogImgSet .wpcf7-list-item:nth-of-type(1) .wpcf7-list-item-label::after {
	content:"バイク1台用のおしゃれなガレージから、小規模な店舗やマルシェなどにも活用いただけるデザイン性優れたガレージをご用意。\A テンションの上がる秘密基地的要素も非常に人気です。";
	white-space: pre-wrap;
}

/*2番目*/
#catalogImgSet .wpcf7-list-item:nth-of-type(2) .wpcf7-list-item-label::before  {
	background: url(./images/02-garage_sg.png) no-repeat;
}
#catalogImgSet .wpcf7-list-item:nth-of-type(2) .wpcf7-list-item-label::after {
	content:"ガレージ・倉庫としての活用ならコレ！\A 車1台～農機具4台以上対応可能な大型なものまでご用意。様々な高さ、奥行、幅の商品を取り揃えておりますので、無駄のないガレージ・倉庫をお選びいただけます。";
	white-space: pre-wrap;
}

/*3番目*/
#catalogImgSet .wpcf7-list-item:nth-of-type(3) .wpcf7-list-item-label::before {
	background: url(./images/05-jigyouyou_sg.png) no-repeat;
}
#catalogImgSet .wpcf7-list-item:nth-of-type(3) .wpcf7-list-item-label::after {
	content:"弊社の倉庫・ガレージの事業用途での活用についてまとめております！\A 倉庫や作業場、ガレージだけでなく、事務所や店舗などにも活用できます。とってもおしゃれな商品なので是非見てみて下さい！";
	white-space: pre-wrap;
}

/*4番目*/
#catalogImgSet .wpcf7-list-item:nth-of-type(4) .wpcf7-list-item-label::before  {
	background: url(./images/01-carport_sg.png) no-repeat;
}

#catalogImgSet .wpcf7-list-item:nth-of-type(4) .wpcf7-list-item-label::after {
	content:"ガレージとカーポートが一体化した商品が登場！複数台車を止めたり、車庫＋物置として活用したり、幅広い用途で活用いただけます！おしゃれなだけでなく、頑丈さもそのまま引き継いだ一押し商品です！";
	white-space: pre-wrap;
}

input {
	font-size: 1.5rem;
	padding: 5px;
	box-sizing: border-box;
}

.personal_data {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	width: 100%;
}

.form_item {
  border-bottom: 1px dashed #ddd;
  padding:15px 0;
  width: 80%;
  display: flex;
  align-items: center;
}

.form_item_label {
  width: 100%;
  max-width: 248px;
  letter-spacing: 0.05em;
  font-weight: bold;
  font-size: 18px;
}

.form_set{ 
	margin-left: 40px;
	font-size: 1rem;
}

.form_item_input {
	border: 1px solid #ccc;
	border-radius: 6px;
	margin-left: 40px;
	padding-left: 10px;
	padding-right: 10px;
	height: 40px;
	flex: 1;
	width: 100%;
	max-width: 410px;
	background: #FFF;
	font-size: 18px;
}

.form_set .form_item_input_short {
	border: 1px solid #ccc;
	border-radius: 6px;
	padding-left: 10px;
	padding-right: 10px;
	height: 30px;
	margin-left: 10px;
	flex: 1;
	width: 5rem;
	max-width: 410px;
	background: #FFF;
	font-size: 16px;
	margin-bottom:10px;
	font-weight: normal;
}

.form_set .address {
	margin-top: 10px;
}

.form_item_textarea {
	border: 1px solid #ccc;
	border-radius: 6px;
	margin-left: 40px;
	padding-left: 1em;
	padding-right: 1em;
	height: 120px;
	flex: 1;
	width: 100%;
	max-width: 410px;
	background: #FFF;
	font-size: 18px;
}

.form_item_select{
	border: 1px solid #ccc;
    height: 40px;
    width: 410px;
    padding: 0.4em 0.8em;
    margin-left: 40px;
    border-radius: 6px;
    color: #333;
    font-size: 18px;
}

.form_btn {
	border-radius: 6px;
	margin-top: 32px;
	margin-left: auto;
	margin-right: auto;
	padding-top: 20px;
	padding-bottom: 20px;
	width: 300px;
	display: block;
	letter-spacing: 0.05em;
	background: rgba(46, 169, 208, 1);
	color: #fff;
	font-weight: 500;
	font-size: 20px;
	border: none;
	transition:.3s;
}

.form_btn:hover{
	background: rgba(18, 188, 240, 1);
	transition:.3s;
}

#contactPage #pageFigure {
	background: url(./images/items/index_28.png) no-repeat;
	background-position: bottom -100px center;
	background-size: cover;
}

.works_preview_container h2 {
	display: none;
}

@media (max-width: 1023px) {

	.mbs {
		display: block !important;
	}

	.mbn {
		display: none !important;
	}

	#wrapper {
		position: relative;
	}

	#header {
		position: fixed;
		top: 0;
		left: 0;
		background: rgba(255, 255, 255, .9);
	}

	#header.scrolled {
		height: 50px;
		animation: smallerHeader .5s ease-out forwards;
	}

	@keyframes smallerHeader {
		0% {
			height: 100px;
		}
		100% {
			height: 50px;
		}
	}

	#navWrapper {
		display: none;
	}

	#topPage #siteTitle {
		width: 70%;
		height: auto;
	}

	#header.scrolled #siteTitle {
		width: 40%;
		height: auto;
	}

	#navButton {
		position: fixed;
		top: 10px;
		right: 10px;
		height: 50px;
		width: 50px;
		border: none;
		background: none;
		color: var(--sub-color);
		font-size: 2rem;
		top: 30px;
		right: 10px;
		z-index: 1000;
	}

	#header.scrolled #navButton {
		top: 2px;
		right: 10px;
	}

    /* メニュー本体 */
    #navWrapper {
        display: block;  /* display:none を上書き */
        position: fixed;
        top: 0;
        right: -100%;    /* 最初は画面外 */
        width: 75%;
        max-width: 300px;
        height: 100%;
        background: #fff;
        z-index: 1000;
        padding: 80px 20px 20px;
        box-sizing: border-box;
        transition: right 0.3s ease-out;
        flex-direction: column;
    }

    #navWrapper.open {
        right: 0;  /* スライドイン */
    }

    #mainNav {
        width: 100%;
    }

    #mainNav ul {
        flex-direction: column;
    }

    #mainNav li {
        width: 100%;
        height: auto;
        border-bottom: 1px solid #eee;
        padding: 15px 0;
    }

    #mainNav li a {
        color: #000;
        font-size: 1.2rem;
    }

    #contactNav {
        width: 100%;
        margin-top: 20px;
    }

    /* ボタンがメニュー開いてる時はXに */
    #navButton.open .fa-bars::before {
        content: "\f00d";  /* fa-times */
		color: var(--sub-color);
    }

	#topPage #mainNav li a {
		text-shadow: inherit;
	}

	.tel_num {
		font-size: 1.5rem;
	}

	.top_message {
		background: none;
		width: 92%;
		height: 100px;
		font-size: 1.2rem;
		font-weight: bold;
		position: absolute;
		right: inherit;
		left: 0;
		top: -10px;
		padding: 20px 20px 20px 10px;
		box-sizing: border-box;
	}

	.top_message span {
		display: inline-block;
		background: rgb(255, 255, 255 ,.9);
		color: var(--sub-color);
		padding: 0 10px;
		box-sizing: border-box;
	}

  	#topCotalogAnnounce {
		width: 50%;
  	}

	#contactInfo {
		display: flex;
		justify-content: space-between;
		width: 100%;
		position: fixed;
		top: inherit;
		right: inherit;
		left: 0;
		bottom: 0;
		height: 60px;
		z-index: 1000;
		animation: slideUpFootButtons 1s ease-out forwards;
		box-shadow: 2px 0 3px 1px rgba(0, 0, 0, .2);
	}

	@keyframes slideUpFootButtons {
		0% {
			bottom: -60px;
		}
		100% {
			bottom: 0;
		}
	}

	#contactInfo li {
		width: 50%;
		height: 100%;
	}

	#contactInfo li span {
		padding-top :0;
	}

	.to_catalog a {
		writing-mode: inherit;
	}

	.to_contact a {
		writing-mode: inherit;
	}

	.to_catalog img {
		width: 12%;
		margin: -7px 5px 0 0;
	}

	.to_contact img {
		width: 10%;
		margin: -7px 1px 0 0;
	}

	.kakuichi_banner {
		width: 20%;
		margin: -30px 0 0 20px;
	}

	.kakuichi_banner span {
		font-weight: bold;
		width: 100%;
		display: inline-block;
		font-size: inherit;
	}

	#topMainFigure {
		width: 100%;
	}
	
	#topVisitToSiteAnnounce {
		position: absolute;
		top: 200px;
		right: 10px;
		width: 50%;
		float: right;
		background: rgba(240, 139, 8, .94);
		margin: 0;
		z-index: 1;
	}
	
	#topVisitToSiteAnnounce h3 {
		font-size: 1rem;
	}

	.visit_detail>span {
		font-size: 1.6rem;
	}

	#topVisitToSiteAnnounce .visit_description {
		font-size: .8rem;
	}

	#topMainFigure {
		margin-top: 100px;
		position: relative;
	}

	.main_figures {
		position: inherit;
		float: right;
	}

	.main_figures::after {
		width: 300px;
		height: 100px;
		transform: rotate(212deg);
		bottom: -50px;
	}

	#topCotalogAnnounce {
		display: flex;
		width: 90%;
		bottom: -200px;
		left: 10px;
		height: inherit;
		background: none;
	}

	.catalog_offer_img {
		position: inherit;
		width: 100%;
		z-index: 1;
	}

	.catalog_offer_img img {
		width: 100%;
	}

	#topWorksSection {
		margin-top: 20px;
		flex-wrap: wrap;
		animation: slideUpSection 1s ease-out forwards;
	}

	@keyframes slideUpSection {
		0% {
			margin-top: 50px;
			opacity: 0;
		}
		100% {
			margin-top: 20px;
			opacity: 1;
		}
	}

	.top_works_list {
		width: 100%;
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}

	.top_works_list li {
		width: 33%;
		z-index: -1;
		margin-bottom: 2px;
	}

	.top_works_li li .img_wrapper {
		height: 100%;
	}

	.top_works_list li img {
		height: 100% !important;
		object-fit: cover;
	}

	#worksPreview {
		position: relative;
	}

	#worksPreview::before {
		content: "";
		display: block;
		width: 45%;
		height: 100%;
		background: var(--sub-color);
		position: absolute;
		left: 0;
		top: 0;
		z-index: -1;
	}

	#worksPreview h1 {
		font-size: 1.6rem;
		width: 100%;
		padding: 40px 0 10px 0;
		text-align: center;
		font-weight: bold;
	}

	#worksPreview h1 span {
		padding: 5px 20px 5px 20px;
		box-sizing: border-box;
		background: var(--main-color);
		color: var(--sub-color);
	}

	.works_preview_container {
		padding: 20px 0 0 0 ;
	}

	.works_preview_container h2 {
		font-size: 1.2rem;
		font-weight: bold;
		color: #FFF;
		width: 100%;
		padding: 0 10px;
		box-sizing: border-box;
		display: block;
	}

	.works_list_wrapper {
		overflow-x: auto;
  		-webkit-overflow-scrolling: touch; /* iOSでなめらかにスクロール */
  		white-space: nowrap; /* 中身を折り返さない */
		margin-left: 50px;
		scrollbar-color: var(--main-color) var(--sub-color);
	}

	.works_others_box .works_list,
	.works_list_wrapper ul {
		display: flex;
		flex-wrap: nowrap;
		gap: 10px;
		padding: 10px;
		list-style: none;
	}

	.works_list_wrapper ul li {
		flex: 0 0 70vw; /* ビューポート幅の70% */
		width: 70vw;    /* 念のため併記 */
		margin-bottom: 10px;
	}

	.works_list_wrapper ul li a {
		margin-bottom: 0;
	}
	.works_list_wrapper .post_info {
		display: flex;
		flex-wrap: wrap;
	}

	.works_list_wrapper .post_title {
		white-space: wrap;
	}

	.works_list_wrapper .post_size {
		white-space: wrap;
	}

	.works_list a {
		padding: 10px 10px 30px 10px;
	}

	.voice_box {
		width: 100%;
		justify-content: center;
		margin: 0 auto 40px auto;
	}

	#voiceSection h1 {
		font-size: 1.2rem;
	}
	

	.voice_box iframe {
		width: 80%;
		aspect-ratio: 16 / 9;
	}


	/*page*/

	.page #siteTitle {
		width: 70%;
	}

	.post_wrapper {
		width: 100%;
		display: flex;
		flex-wrap: wrap;
		padding: 0 20px;
		box-sizing: border-box;
	}

	.post_wrapper header h1 {
		padding: 10px;
		flex-wrap: wrap;
		position: relative;
	}

	#worksPage .work_title {
		width: 100%;
		font-size: 1rem;
		text-align: left;
	}

	.works_product {
		font-size: .7rem;
		float: right;
		margin-top: 3px;
		padding: 2px 5px;
	}

	.works_info_table th,
	.works_info_table td {
		display: block;
		width: 100%;
	}

	.works_info_table th {
		background: none;
		text-align: left;
		border-bottom: 1px solid #000;
		padding: 0 10px;
	}

	.works_info_table td {
		text-align: left;
	}

	#pageFigure {
		height: 80px;
		margin-top: 100px;
		background-position: center !important;
	}
	
	#pageFigure::before {
		display: none;
	}

	#pageFigure h1 {
		font-size: 1.5rem;
		min-width: inherit;
	}

	.post_wrapper {
		margin: 20px 0 40px 0;
	}

	.single_page #worksSection header {
		padding: 0;
	}

	.works_others_box h2 {
		width: 100%;
		padding: 20px;
		box-sizing: border-box;
		font-size: 1.2rem;
	}

	.sections_header {
		width: 100%;
		display: flex;
		flex-wrap: wrap;
		padding: 0 20px;
		box-sizing: border-box;
	}

	#contactPage .sections h1 {
		font-size: 1.2rem;
	}

	#contactPage .sections .tel_num {
		font-size: 2rem;
	}

	#contactPage .sections .tel_business_hour {
		width: 100%;
		font-size: 1.2rem;
	}

	#form {
		width: 100%;
		padding: 40px 20px;
		box-sizing: border-box;
	}

	#form h2 {
		font-size: 1.5rem;
		margin-bottom: 20px;
	}

	.form_item{
		flex-wrap: wrap;
		width: 100%;
	}

	.form_item p {
		width: 100%;
		display: flex;
	}

	#contactPage form {
		width: 100%;
		padding: 0 20px;
		box-sizing: border-box;
	}

	.form_item_label {
		font-size: 1rem;
	}

	.wpcf7-form-control-wrap {
		width: 100%;
		display: flex;
		flex-wrap: wrap;
	}

	#form input,
	#form select,
	.form_item_textarea,
	.form_item_select,
	.form_item_input,
	.form_set {
		width: 100% !important;
		max-width: 100% !important;
		margin-left: 0;
	}
	
	.form_item_input {
		margin-left: 0;
	}
	
	#catalogSection {
		width: 100%;
		display: flex;
		flex-wrap: wrap;
	}

	#catalogSection .section_header {
		width: 100%;
		padding: 0 20px;
		box-sizing: border-box;
	}

	#catalogPage .sections h1 {
		margin: 30px 0;
		width: 100%;
		font-size: 1rem;
	}

	#catalogImgSet .wpcf7-list-item {
		width: 100%;
	}
	
	#catalogImgSet .wpcf7-list-item>.wpcf7-list-item-label {
		flex-wrap: wrap;
	}

	#catalogImgSet .wpcf7-list-item label {
		flex-wrap: wrap;
	}

	#catalogImgSet .wpcf7-list-item-label {
		width: 100%;
	}

	#catalogImgSet .wpcf7-list-item .wpcf7-list-item-label {
		padding-left: 0;
	}

	.wpcf7-list-item:not(:first-child) {
		padding-top: 40px;
	}
	
	#catalogImgSet .wpcf7-list-item label{display:flex;align-items: center;}
	#catalogImgSet .wpcf7-list-item .wpcf7-list-item-label::before {
		display: block;
		position:absolute;
		content: "";
		width:200px;
		height:138px;
		right:0;
		left: inherit;
		top: -150px;
		margin-right:15px;
		background-repeat:no-repeat;
		background-size: contain !important;
		border:1px solid #ccc;
	}

	#catalogImgSet {
		margin: 70px auto 0;
	}

	#catalogImgSet input {
		width: 10% !important;
		margin-bottom: 50px;
	}

	#catalogImgSet .wpcf7-list-item .wpcf7-list-item-label:after {
		font-size: .9rem;
	}

	#worksNav {
		width: 100%;
		padding: 10px 20px 0 20px;
		box-sizing: border-box;
		margin: 20px 0 0 0;
	}

	#worksNav li {
		width: 45%;
		text-align: center;
		margin-bottom: 10px;
	}

	#worksNav .current_list {
		padding: 2px;
	}

	.archive_page #worksSection header {
		padding: 40px 20px;
		font-size: 1rem;
		box-sizing: border-box;
	}

	.archive_page .works_list {
		padding: 0 20px;
		box-sizing: border-box;
	}

	.archive_page .works_list li {
		width: 100%;
		margin-bottom: 0;
	}

	.page_section_header {
		padding: 30px 20px;
		box-sizing: border-box;
	}

	.page_section_header p {
		font-size: 1.2rem;
	}

	#aboutSection header::before {
		width: 90px;
		height: 100px;
		left: 2px;
		top: -30px;
		bottom: inherit;

	}

	#aboutSection header::after {
		width: 50px;
		height: 100px;
		right: 5px;
		bottom: 0;
	}

	.about_flex {
		width: 100%;
		padding: 0 20px;
		box-sizing: border-box;
	}

	.about_flex .about_box {
		max-width: 100%;
		width: 100%;
	}

	.about_box .about_no{
		font-size: 3rem;
		width: 50px;
		margin: 5px 15px 0 20px;
	}

	.about_flex .about_box{
		padding: 15px 0px;
	}

	.about_info h3 {
		font-size: 1.4rem;
		line-height: 120%;
		padding-bottom: 10px;
	}

	.top_about_flex, .about_flex {
		gap: 10px;
	}

	#flowSection header::before {
		width: 70px;
		height: 50px;
		left: 5px;
		top: -30px;
	}

	#flowSection header::after {
		width: 50px;
		height: 70px;
		right: 0;
		bottom: 0;
	}

	.flows {
		padding: 0 20px;
	}

	.flows h2 {
		width: 100%;
		padding: 10px;
	}

	.flows ul {
		margin-top: 20px;
	}

	.flows li h3 {
		font-size: 1rem;
	}

	.flows li div:first-child {
		width: 45%;
	}

	.flows li div:last-child {
		margin-left: 30px;
	}

	.flow_02 {
		margin-top: 40px;
	}

	#qaSection header::before {
		width: 50px;
		height: 90px;
		left: 15px;
		top: -30px;
		bottom: inherit;
	}

	#qaSection header::after {
		width: 50px;
		height: 80px;
		right: 5px;
		bottom: 0;
	}

	.accordion_area {
		margin: 0;
		padding: 0 20px;
		box-sizing: border-box;
	}

	.accordion_area li {
		margin: 10px 0 30px 0;
	}

	.accordion_area section {
		border: none;
	}

	.accordion_area .title {
		padding: 2% 0 2% calc(2% + 35px);
		line-height: 120%;
	}

	.accordion_area section:before {
		padding-left: 0;
	}

	#companySection {
		padding: 0;
	}

	#companySection header::before {
		width: 80px;
		height: 90px;
		left: 5px;
		top: -35px;
	}

	#companySection header::after {
		width: 80px;
		height: 50px;
		left: inherit;
		right: 3px;
		bottom: 14px;
	}

	.hello {
		width: 90%;
		padding: 0 20px;
	}

	.hello aside {
		margin-top: 40px;
	}

	.hello .remarkable {
		line-height: 120%;
	}

	.hello img {
		width: 30%;
		margin: 20px 10px 0 0;
	}

	#companyInfo {
		margin-top: 40px;
	}

	.company_table dt,
	.company_table dd {
		padding: 15px;
	}

	.company_table {
		line-height: 140%;
		font-size: .9rem;
	}

	main {
		padding-bottom: 100px;
	}
}