@charset "utf-8";
/* CSS Document */

/*-- header -------------------------------------------------------------*/
header { background: #fff; }
header .in-head-flex .hL .logo a:link    { color:#000; text-decoration: none; }
header .in-head-flex .hL .logo a:visited { color:#000; text-decoration: none; }
header .in-head-flex .hL .logo a:hover   { color:#000; text-decoration: none; opacity: 0.7; }
header .in-head-flex .hL .logo a:active  { color:#000; text-decoration: none; }

@media screen and (max-width: 899px) {	
	header .in-head-flex .hL { width: 70%; }
	header .in-head-flex .hL h1 { color: #000; }
	header .in-head-flex .hL .logo-mark .logo-bk { display: block; }
	header .in-head-flex .hL .logo-mark .logo-wh { display: none; }
	header .in-head-flex .hL .company-name p { color: #000; }
}
@media screen and (max-width: 599px) {
}
@media screen and (min-width: 900px) {
	header .in-head-flex .hL h1 { color: #000; }
	header .in-head-flex .hL .logo-mark .logo-bk { display: block; }
	header .in-head-flex .hL .logo-mark .logo-wh { display: none; }
	header .in-head-flex .hL .company-name p {color: #000; }

	header .in-head-flex .hR nav ul li a:link    { color:#000; text-decoration: none; }
	header .in-head-flex .hR nav ul li a:visited { color:#000; text-decoration: none; }
	header .in-head-flex .hR nav ul li a:hover   { color:#000; text-decoration: none; opacity: 0.7; }
	header .in-head-flex .hR nav ul li a:active  { color:#000; text-decoration: none; }
	
	nav li a::after { background: #000; }
} 

/*-- headline ------------------------------------------------------------*/
#headline { padding: 2% 4% 1%; }
#headline h2 { color: #000; line-height: 1.5; letter-spacing: .2em; }
#headline h6 { display:block; letter-spacing: 0em; color: var(--sub-color); }

.headline-image { position: relative; }
.headline-image .inner { position: absolute; top: 0; left: 0; width: 100%; height: 100%; clip-path: inset(0); }
.headline-image .bg { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-size: cover; background-position: center; z-index: -1; }
.headline-image .bg { background-image: url("../img/second/headline.jpg"); } 
.headline-image.headline-image-about .bg { background-image: url("../img/second/headline-about.jpg"); } 
.headline-image.headline-image-service .bg { background-image: url("../img/second/headline-service.jpg"); } 
.headline-image.headline-image-request .bg { background-image: url("../img/second/headline-request.jpg"); } 
.headline-image.headline-image-blog .bg { background-image: url("../img/second/headline-column.jpg"); }
.headline-image.headline-image-privacy .bg { background-image: url("../img/second/headline-privacy.jpg"); }
.headline-image.headline-image-contact .bg { background-image: url("../img/second/headline-contact.jpg"); }
.headline-image.headline-image-news .bg { background-image: url("../img/second/headline-news.jpg"); }
@media screen and (max-width: 599px) {
	.headTtl { margin-bottom: 20px; }
	#headline h2 { font-size: 1.5rem; line-height: 1.2; }
	#headline h6 { font-size: 0.7rem;}
	.headline-image { height: 120px; width: 100%; }
}
@media screen and (min-width: 600px) {
	#headline { display: flex; justify-content: space-between; align-items: center;}
}
@media screen and (min-width: 600px) and (max-width: 899px)  {
	#headline h2 { font-size: 1.6rem;}
	#headline h6 { font-size: 0.7rem;}
	.headline-image { height: 150px; width: 70%; }
}
@media screen and (min-width: 900px) and (max-width: 1089px)  {
	#headline h2 { font-size: 1.7rem;}
	#headline h6 { font-size: 0.75rem;}
	.headline-image { height: 160px; width: 70%; }
}
@media screen and (min-width: 1090px) and (max-width: 1289px)  {
	#headline h2 { font-size: 1.8rem;}
	#headline h6 { font-size: 0.8rem;}
	.headline-image { height: 170px; width: 70%; }
}
@media screen and (min-width: 1290px) and (max-width: 1489px)  {
	#headline h2 { font-size: 1.9rem;}
	#headline h6 { font-size: 0.85rem;}
	.headline-image { height: 180px; width: 70%; }
}
@media screen and (min-width: 1490px) {
	#headline h2 { font-size: 2.0rem;}
	#headline h6 { font-size: 0.9rem;}
	.headline-image { height: 200px; width: 70%; }
}

/*-- header ------------------------------------------------------------*/
@media screen and (max-width: 899px) {
	header .in-head-flex .hL h1 { color: #000; }
	header .in-head-flex .hR nav ul li a { position: relative; }
}
@media screen and (max-width: 599px) {
	.menu-trigger span { background-color: var(--base-color); }
}
@media screen and (min-width: 600px) and (max-width: 899px) {
	.menu-trigger span { background-color: var(--base-color); }
}
/*-- breadcrumbs ------------------------------------------------------------*/
#breadcrumbs { display: flex; justify-content: flex-end; align-items: center; margin-bottom: 20px; padding: 0 4%; }
#breadcrumbs li { font-size: 0.8rem; margin-right: 5px; display: inline-block; }
#breadcrumbs li:after { content: ">"; margin-left: 10px; }
#breadcrumbs li:last-child { margin-right: 0px; }
#breadcrumbs li:last-child:after { display: none; }
@media screen and (max-width: 599px) {
	#breadcrumbs { margin-bottom: 0px; }
	#breadcrumbs li { font-size: 0.7rem; }
}

/*-- content ------------------------------------------------------------*/
#content section { padding: 5vh 4%; }
#content section .in-center { max-width: 1100px; margin: 0 auto; }
.txtTtl { font-size: 1.05rem; font-weight: bold; margin-bottom: 10px; margin-top: 20px; }
address { font-style: normal; }
@media screen and (max-width: 599px) {	
	#content section { padding: 6%; }
	#content section .in-flex .in-flex-L h3 { font-size: 1.5rem; text-align: center; }
	#content section .in-flex .in-flex-L h6 { font-size: 0.8rem; color:var(--sub-color); text-align: center; margin-bottom: 20px; }
}
@media screen and (min-width: 600px) and (max-width: 899px)  {	
	#content section { padding: 5vh 4%; }
	#content section .in-flex .in-flex-L h3 { font-size: 1.6rem; text-align: center; }
	#content section .in-flex .in-flex-L h6 { font-size: 0.8rem; color:var(--sub-color); text-align: center; margin-bottom: 20px; }
}
@media screen and (min-width: 900px) {
	#content section { margin-bottom: 60px; }
	#content section .in-flex { display: flex; justify-content: space-between; max-width: 1400px; margin: 0 auto; }
	#content section .in-flex .in-flex-L { width: 20%; padding: 0 2%; min-width: 200px; }
	#content section .in-flex .in-flex-L h3 { font-size: 1.8rem; text-align: center; }
	#content section .in-flex .in-flex-L h6 { font-size: 0.9rem; color:var(--sub-color); text-align: center;}
	#content section .in-flex .in-flex-L .stcy { position: sticky; top: 10%; }
	#content section .in-flex .in-flex-R { width: 72%; }
	#content section .bar-ttl { width: 50px; height: 2px; background: var(--base-color); margin: 0 auto 60px; }		
}
@media screen and (min-width: 900px) and (max-width: 1089px)  {
	#content section .in-flex .in-flex-L { width: 20%; }
	#content section .in-flex .in-flex-L h3 { font-size: 1.5rem; }
	#content section .in-flex .in-flex-L h6 { font-size: 0.80rem; }
}
@media screen and (min-width: 1090px) and (max-width: 1189px)  {
	#content section .in-flex .in-flex-L { width: 18%; }
	#content section .in-flex .in-flex-L h3 { font-size: 1.5rem; }
	#content section .in-flex .in-flex-L h6 { font-size: 0.80rem; }
}
@media screen and (min-width: 1190px) and (max-width: 1289px)  {
	#content section .in-flex .in-flex-L h3 { font-size: 1.6rem; }
	#content section .in-flex .in-flex-L h6 { font-size: 0.85rem; }
}
@media screen and (min-width: 1290px) and (max-width: 1389px)  {
	#content section .in-flex .in-flex-L h3 { font-size: 1.6rem; }
	#content section .in-flex .in-flex-L h6 { font-size: 0.85rem; }
}
@media screen and (min-width: 1390px) and (max-width: 1489px)  {
	#content section .in-flex .in-flex-L h3 { font-size: 1.7rem; }
	#content section .in-flex .in-flex-L h6 { font-size: 0.9rem; }
}
@media screen and (min-width: 1490px) and (max-width: 1589px)  {
}
@media screen and (min-width: 1590px) and (max-width: 1689px)  {
}
@media screen and (min-width: 1480px)  {
}

/*-- company ------------------------------------------------------------*/
@media screen and (max-width: 599px) {
	.tbl01 { width: 100%; border-top: 1px solid #dedede; }
	.tbl01 th,.tbl01 td { padding: 10px; text-align: left; display: block; }
	.tbl01 th { text-align: center; border-bottom: 1px dotted #dedede; background: #dedede; }
	.tbl01 td { border-bottom: 1px solid #dedede; }
}
@media screen and (min-width: 600px) {
	.tbl01 { width: 100%;  }
	.tbl01 th,.tbl01 td { padding: 20px; text-align: left; }
	.tbl01 th { width: 20%; text-align: left; border-bottom: 3px solid #dedede; }
	.tbl01 td { width: 80%; border-bottom: 1px solid #dedede; }
}

/*-- in-flex-half ------------------------------------------------------------*/
@media screen and (max-width: 767px) {
	.in-flex-half { margin-bottom: 20px; }
	.in-flex-half:last-child { margin-bottom: 0px; }
	.flexHigh .gmap { height: 300px; }
}
@media screen and (min-width: 768px) {
	.flex-half { display: flex; justify-content: space-between; align-items: center; }
	.in-flex-half { width: 48%; }
	
	.gmapContainer { position: relative; padding-bottom: 66.25%; /* 16:9 の場合。縦横比に合わせて調整 */ width: 100%; overflow: hidden; /* はみ出しを隠す */ }
	.gmapContainer iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
}

/*-- img_flex ------------------------------------------------------------*/
@media screen and (max-width: 599px) {
	.img_y_flex { display: flex; flex-direction: column; }
	.img_y_flex_Txt { order: 2; } 
	.img_y_flex_Img { order: 1; width: 80%; margin: 0 auto 20px; }
	.img_y_flex_Img img { border-radius: 6px; }
}
@media screen and (min-width: 600px) {
	.img_y_flex { display: flex; justify-content: space-between; align-items: center; }
	.img_y_flex_Txt {} 
	.img_y_flex_Img { max-width: 360px; margin-left: 4%; }
	.img_y_flex_Img img { border-radius: 6px; }
}
@media screen and (min-width: 900px) and (max-width: 1089px) {
	.img_y_flex { display: flex; justify-content: space-between; align-items: flex-start; }
	.img_y_flex_Img { max-width: 270px; }
}
@media screen and (min-width: 1090px) and (max-width: 1189px) {
	.img_y_flex_Img { max-width: 300px; }
}
@media screen and (min-width: 1190px) and (max-width: 1289px) {
	.img_y_flex_Img { max-width: 320px; }
}
/*-- flow ------------------------------------------------------------*/
@media screen and (max-width: 599px) {
	.flowStep li { margin-bottom: 20px; padding-bottom: 20px ;border-bottom: 1px solid #dedede; position: relative; }
	.flowStep li:after { content: ""; position: absolute; bottom: -10px; left: 0; right: 0; margin: 0 auto; width: 0; height: 0; border-style: solid; border-width: 10px 25px 0 25px; border-color: #dedede transparent transparent transparent; }
	.flowStep li:last-child:after { display: none; }
	.flowStep li p.numberStep { font-family: 'Roboto Condensed', sans-serif; font-weight: bold; font-size: 2.0rem; text-decoration: underline; text-align: center; line-height: 1.0; margin-bottom: 10px; }
	.flowStep li .flowTtl { margin-bottom: 20px; }
	.flowStep li .flowTtl h4 { font-size: 1.3rem; font-weight: bold; margin-bottom: 10px; text-align: center;}
	/*.flowStep li .img-radius { width: 80%; margin: 0 auto; }*/
	.flowStep li .flowTtl p { margin-bottom: 20px; }
	.flowStep li .flowImg { text-align: center; }
}
@media screen and (min-width: 600px) {
	.flowStep { max-width: 960px; margin: 0 auto; }
	.flowStep li { margin-bottom: 20px; padding-bottom: 20px ;border-bottom: 1px solid #dedede; display: flex; justify-content: flex-start; align-items: center; position: relative; }
	.flowStep li:after { content: ""; position: absolute; bottom: -10px; left: 0; right: 0; margin: 0 auto; width: 0; height: 0; border-style: solid; border-width: 10px 25px 0 25px; border-color: #dedede transparent transparent transparent; }
	.flowStep li:last-child:after { display: none; }
	.flowStep li p.numberStep { font-family: 'Roboto Condensed', sans-serif; font-weight: bold; font-size: 3.0rem; margin-right: 2%; text-decoration: underline; width: 20%; text-align: center; }
	.flowStep li .flowTtl { width: 78%; }
	.flowStep li .flowTtl h4 { font-size: 1.8rem; font-weight: bold; margin-bottom: 10px; }
	/*.flowStep li .img-radius { width: 24%; }*/
	.flowStep li .flowImg { margin-left: 4%; }
}
@media screen and (min-width: 600px) and (max-width: 899px) {
	.flowStep li .flowTtl h4 { font-size: 1.2rem; }
}
@media screen and (min-width: 900px) and (max-width: 1089px) {
	.flowStep li .flowTtl h4 { font-size: 1.3rem; }
}
@media screen and (min-width: 1090px) and (max-width: 1189px) {
	.flowStep li .flowTtl h4 { font-size: 1.4rem; }
}
@media screen and (min-width: 1190px) and (max-width: 1289px)  {
	.flowStep li .flowTtl h4 { font-size: 1.5rem; }
}
@media screen and (min-width: 1290px) and (max-width: 1389px)  {
	.flowStep li .flowTtl h4 { font-size: 1.6rem; }
}
@media screen and (min-width: 1390px) and (max-width: 1489px)  {
	.flowStep li .flowTtl h4 { font-size: 1.7rem; }
}

/*-- faq -------------------------------------------------------------*/
@media screen and (max-width: 899px) {
	.faqDl { margin-bottom: 20px; }
	.faqDl dt { margin-bottom: 10px; font-weight: bold; font-size: 1.0rem;  }
	.faqDl dt span { color:var(--base-color); margin-right: 10px; font-weight:bold; font-size: 1.5em; }
	.faqDl dd { font-size: 0.9rem;}
}
@media screen and (min-width: 900px) {
	.faqDl { margin-bottom: 20px; }
	.faqDl dt { margin-bottom: 10px; font-weight: bold; font-size: 1.2rem;  }
	.faqDl dt span { color:var(--base-color); margin-right: 10px; font-weight:bold; font-size: 1.2em; }	
	.faqDl dd:last-child { margin-bottom: 40px; }
}

/*-- blog -------------------------------------------------------------*/
@media screen and (max-width: 599px) {
	.blogTtl { font-weight: bold; margin-bottom: 10px; }
	.blg-border { margin-bottom: 20px; border-bottom: 1px solid #dedede; margin-top: 20px; }
	
	.blgList li { margin-bottom: 20px; padding-bottom: 20px; border-bottom: 1px dotted #dedede; }
	.blL { width: 80%; margin: 0 auto 20px; }
	.blgDl { display: flex; justify-content: flex-start; align-items: center; margin-bottom: 10px; }
	.blgDl dt { font-size: 12px; font-family:'Roboto Condensed', sans-serif; font-weight:bold; color: #fff; border: 1px solid #333; background: #333; padding: 1px 10px; }
	.blgDl dd { font-size: 12px; color: #333; border: 1px solid #333; background: #fff; padding: 1px 10px; }
	.blgList li p { margin-bottom: 0px; }
	
	.themeList li { font-size: 0.9rem; margin-bottom: 10px; padding-left: 1em; text-indent: -1.5em;  }
	.themeList li:before { content: "├"; margin-right: 10px; }
}
@media screen and (min-width: 600px) {
	.blogTtl { font-weight: bold; margin-bottom: 10px; font-size: 1.5rem; }
	.blg-border { margin-bottom: 20px; border-bottom: 1px solid #dedede; margin-top: 20px; }
	
	.blgList li { display: flex; justify-content: flex-start; align-items: center; margin-bottom: 20px; }
	.blL { width: 100%; max-width: 180px; margin-right: 4%; }
	.blgDl { display: flex; justify-content: flex-start; align-items: center; margin-bottom: 10px; }
	.blgDl dt { font-size: 12px; font-family:'Roboto Condensed', sans-serif; font-weight:bold; color: #fff; border: 1px solid #333; background: #333; padding: 1px 10px; }
	.blgDl dd { font-size: 12px; color: #333; border: 1px solid #333; background: #fff; padding: 1px 10px; }
	.blgList li p { margin-bottom: 0px; }
	
	.themeList li { font-size: 0.9rem; margin-bottom: 10px; padding-left: 1em; text-indent: -1.5em;  }
	.themeList li:before { content: "├"; margin-right: 10px; }
	
	.blgScroll { margin-top: 20px; }
}

/*-- Line -------------------------------------------------------------*/
.oneArea { display: flex; flex-wrap: wrap; justify-content: flex-start; max-width: 1024px; margin: 50px auto; padding: 0 10px; }
.oneArea .onebox { width: 100%; display: flex; flex-wrap: wrap; justify-content: flex-start; }
.oneArea .onebox:nth-child(even) { flex-direction: row-reverse; margin-top: 20px; margin-bottom: 20px; }
.oneArea .onebox .imgArea { width: 16%; position: relative; }
.oneArea .onebox .imgArea img { width: 100%; max-width: 130px; position: absolute; top: 0; }
.oneArea .onebox:nth-child(odd) .imgArea img { left: 0; padding-right: 30px; }
.oneArea .onebox:nth-child(even) .imgArea img { right: 0; padding-left: 30px; }
.oneArea .onebox .fukiArea { width: 63%; }
.oneArea .onebox .fukidasi { width: 100%; position: relative; padding: 25px; background-color: #f2f3f7; font-size: 18px; color: #231815; border-radius: 12px; box-sizing: border-box; }
.oneArea .onebox .fukidasi::before { content: ''; position: absolute; display: block; top: 22px; width: 0; height: 0; border-style: solid; border-width: 15px 30px 15px 0; border-color: transparent #f2f3f7 transparent transparent; }
.oneArea .onebox:nth-child(odd) .fukidasi::before { left: -20px; }
.oneArea .onebox:nth-child(even) .fukidasi { background-color: #f5f0e6; }
.oneArea .onebox:nth-child(even) .fukidasi::before { right: -20px; border-color: transparent #f5f0e6 transparent transparent; transform: rotate(180deg); }
@media screen and (max-width: 1024px) {
  .oneArea .onebox .imgArea img { max-width: 70%; }
  .oneArea .onebox .fukidasi { padding: 15px; font-size: 14px; }
  .oneArea .onebox .fukidasi::before { top: 8px; } 
}
@media screen and (min-width: 1025px) and (max-width: 1289px) {
  .oneArea .onebox .imgArea img { max-width: 70%; }
}
@media screen and (max-width: 599px) {
  .oneArea { margin: 30px auto; }
  .oneArea .onebox:nth-child(even) { margin-top: 15px; margin-bottom: 15px; }
  .oneArea .onebox .imgArea { width: 20%; }
  .oneArea .onebox .fukidasi { padding: 10px 15px; font-size: 12px; }
}

/*-- Line -------------------------------------------------------------*/
.lineTalk { max-width: 1024px; margin: 50px auto; padding: 0 10px; }
.lineTalk p.th { position: relative; padding: 25px; background-color: #f2f3f7; color: #231815; border-radius: 12px; box-sizing: border-box; width: 70%; margin-left: 10%; margin-bottom: 25px; }
.lineTalk p.st { position: relative; padding: 25px; background-color: #f5f0e6; color: #231815; border-radius: 12px; box-sizing: border-box; margin-right: 10%; margin-left: 20%; width: 70%; margin-bottom: 25px; }
.lineTalk p.th:before { content: ""; background-image: url("../img/second/icon01.png"); background-size:cover; width: 100px; height: 100px; position: absolute; top: 0; left: -20%; }
.lineTalk p.st:before { content: ""; background-image: url("../img/second/icon02.png"); background-size:cover; width: 100px; height: 100px; position: absolute; top: 0; right: -20%; }

.lineTalk p.th:after { content: ''; position: absolute; display: block; top: 22px; left: -3%; width: 0; height: 0; border-style: solid; border-width: 15px 30px 15px 0; border-color: transparent #f2f3f7 transparent transparent; }
.lineTalk p.st:after { content: ''; position: absolute; display: block; top: 22px; right: -3%; width: 0; height: 0; border-style: solid; border-width: 15px 30px 15px 0; border-color: transparent #f5f0e6 transparent transparent; transform: rotate(180deg); }

@media screen and (max-width: 599px) {
	.lineTalk p.th { width: 85%; margin-left: 15%; }
	.lineTalk p.th:before { width: 50px; height: 50px; }
	.lineTalk p.st { width: 85%; margin-right: 10%; margin-left: 5%; }
	.lineTalk p.st:before { width: 50px; height: 50px; }
	.lineTalk p.th:after { top: 10px; }
	.lineTalk p.st:after { top: 10px; }
}
@media screen and (min-width: 600px) and (max-width: 889px) {
	.lineTalk p.th { width: 70%; margin-left: 15%; }
	.lineTalk p.st { margin-left: 15%; width: 70%; }
	.lineTalk p.th:before { width: 80px; height: 80px; }
	.lineTalk p.st:before { width: 80px; height: 80px; }
}
@media screen and (min-width: 900px) and (max-width: 1089px) {
	.lineTalk p.th { width: 75%; margin-left: 20%; }
	.lineTalk p.st { margin-left: 5%; width: 75%; }
	.lineTalk p.th:before { width: 80px; height: 80px; left: -25%; }
	.lineTalk p.st:before { width: 80px; height: 80px; right: -25%; }
}
@media screen and (min-width: 1090px) and (max-width: 1289px) {
	.lineTalk p.th { width: 70%; margin-left: 15%; }
	.lineTalk p.st { margin-left: 15%; width: 70%; }
	.lineTalk p.th:before { width: 90px; height: 90px; }
	.lineTalk p.st:before { width: 90px; height: 90px; }
}





