@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;
	flex-wrap: wrap;
	justify-content: space-between;
	width: 100%;
	height: 100px;
	z-index: 1000;
	position: relative;
}

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

#siteTitle img {
	width: 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;
}

.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: -150px;
}


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

.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;
}

.top_message {
	font-size: 5rem;
	font-weight: bold;
	color: var(--main-color);
	position: absolute;
	right: 0;
	bottom: 0;
	background: rgb(255, 255, 255, .8);
	padding: 20px 40px;
	box-sizing: border-box;
	border-radius: 40px 0 0 40px;
}

#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_08.jpg) no-repeat;
	background-position: bottom -250px 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_12.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_13.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);
}


/* about */
#aboutPage #pageFigure {
	background: url(./images/items/index_14.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_03.jpg) no-repeat;
	background-position: bottom -200px 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 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;
}

#pcatalogImgSet .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_09.jpg) no-repeat;
	background-position: bottom -550px center;
	background-size: cover;
}