/*
 * スタイルシートのリセットと基本的な設定
 */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
	overflow-x: hidden;
}

body {
    font-family: "Noto Sans JP", sans-serif;
    line-height: 1.5;
    color: #000;
    background-color: #fff;
    font-size: 24px; /* 基本フォントサイズ */
	overflow-x: clip;
}

a {
    color: #22ac38;
    text-decoration: none;
}

a:hover {
    text-decoration: none;
}

img {
    max-width: 100%;
    height: auto;
    display: block; /* 画像の下に余白ができないように */
}

ul {
    list-style: none;
}

/*
 * ヘルパークラス
 */
.container {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0;
}



.button {
    display: flex;
	justify-content: center;
	align-items: center;
    background: #22ac38;
    color: #fff;
	font-size: 18px;
	font-weight: 400;
    padding: 27px 34px;
	border-right: solid #00913a 4px;
	border-bottom: solid #00913a 4px;
	position: relative;
	width: 348px;
	height: 76px;
	margin: 0 auto;
}

.button::before{
	content: '';
	display: inline-block;
	width: 30px;
	height: 20px;
	background: url("../images/icon-mail.svg");
	background-size: contain;
	background-repeat: no-repeat;
	margin-right: 8px;
}


.button:hover {
    border-left: solid #22ac38 4px;
	border-top: solid #22ac38 4px;
	 border-right: none;
	border-bottom: none;
	text-decoration: none;
}

.sp-image{
	display: none;
    }

.tel{
	pointer-events: none;
}

/*
 * ヘッダー
 */
.site-header {
	width: 100%;
	/*position: sticky;*/
    top: 0;
    left: 0;
	z-index: 999;
	padding: 0 60px;
	background-color: #fff;
	box-shadow: 0px 2px 5px rgba(0, 0, 0, 0.2);
}

.site-header .container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0;
    background-color: #fff;
	height: 130px;
	max-width: 1695px;
	margin: 0 0 0 auto;
}

.site-logo{
	width:clamp(200px,23.18vw,445px);
	aspect-ratio: 445 / 84;
}

.site-header .flex-box{
	gap: 34px;
	align-items: center;
}


.site-header .tel{
	width:clamp(190px,22.81vw,438px);
	aspect-ratio: 438 / 68;
}


/*
 * メインコンテンツのセクション
 */

.flex-box{
	display: flex;
}

.inner-left,
.inner-right{
	width: 50%;
}

.yellow{
	color: #fff100;
}


/* ヒーローセクション */


#hero{
   background-image: url("../images/hero-back.jpg");
	background-size: cover;
    background-position: top center;
    background-repeat: no-repeat;
	position: relative;
	min-height: clamp(360px,70vw,1050px);
	width: 100%;
	/*display: flex;
	justify-content: center;
	align-items: center;*/
	padding: 113px 0 80px;
}
#hero:after{
	content: '';
	background-image: url("../images/hero-03.png");
	background-size: contain;
    background-position: bottom right;
    background-repeat: no-repeat;
	width: 1002px;
	height: auto;
	position: absolute;
	bottom: 0;
	right: 0;
	z-index: 0;
	aspect-ratio: 1002 / 1042;
}

.top-copy{
	position: relative;
	z-index: 1;
}

.top-copy h2{
	width: 820px;
	aspect-ratio: 820 / 849;
	margin-bottom: 0;
	margin-left: 16.35vw;
}

/* コンテンツセクション */

/* top-01 */

#top-01{
	padding: 20px 0;
	background: #fff;
}

.blue-box{
	background: #172a88;
	padding: 46px 60px;
	color: #fff;
	max-width: 960px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
}

.blue-box h3{
	font-size: clamp(20px, 2.5vw, 30px);
	font-weight: bold;
	font-style: italic;
	color: #fff;
	margin-bottom: 10px;
}

.blue-box ul{
	display: flex;
	gap: 2px;
	margin-bottom: 20px;
}
.blue-box ul li{
	background: #fff;
	color: #172a88;
	padding: 5px 8px;
	font-size: 20px;
	font-weight: 500;
	font-style: italic;
}

.blue-box-inner{
	display: flex;
	background: #fff;
	align-items: center;
	padding: 20px 40px;
	gap: 36px;
	justify-content: space-between;
	margin-bottom: 20px;
}

.blue-box-inner .tel{
	width:clamp(320px,22.81vw,379px);
	aspect-ratio: 379 / 60;
}

.blue-box-inner .button{
	margin: 0;
}

.blue-box p{
	font-size: 19px;
}

/* top-02 */

#top-02{
   background-image: url("../images/top-02-back.jpg");
	background-size: cover;
    background-position: top center;
    background-repeat: no-repeat;
	position: relative;
	width: 100%;
	padding-bottom: 13px;
}

#top-02 .container{
	background: rgba(255,255,255,0.6);
	box-shadow: 0px 7px 10px rgba(0, 0, 0, 0.3);
	padding: 80px 60px 98px;
}

#top-02 h3{
	width: 90%;
	max-width: 671px;
	aspect-ratio: 6710 / 106;
	margin: 0 auto;
}


#top-02 ul{
	display: flex;
	gap: 20px;
	flex-wrap: wrap;
	justify-content: center;
	margin-top: 37px;
}

#top-02 ul li{
	width: calc(100% / 4 - 20px);
	background: #fff;
	min-width: 300px;
}

#top-02 ul li h4{
	color: #036eb8;
	font-size: 24px;
	text-align: center;
	margin-top: 30px;
	margin-bottom: 0;
	font-weight: bold;
	font-style: italic;
}
#top-02 ul li p{
	font-size: 16px;
	line-height: 2;
	padding: 10px 20px 30px;
	text-align: center;
}

/* top-03 */
#top-03{
	background-color: #fff;
   background-image: url("../images/top-03-back.png");
	background-size: contain;
    background-repeat: repeat;
	position: relative;
	width: 100%;
	padding-bottom: 13px;
}

#top-03 .container{
	padding-top: 50px;
	padding-bottom: 120px;
}

#top-03 .h-box{
	align-items: flex-end;
	gap: 25px;
	justify-content: center;
	margin-bottom: 50px;
}

#top-03 h3{
	width: 50%;
	max-width: 410px;
	aspect-ratio: 410 / 156;
}
#top-03 .h-sub{
	width: 50%;
	max-width: 361px;
	aspect-ratio: 361 / 48;
}

#top-03 ul{
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 20px;
	max-width: 1200px;
    margin: 0 auto;
}

#top-03 ul li{
	border: solid 2px #000;
	padding: 30px 120px;
	gap: 70px;
	background: #fff;
	width: 100%;
}

#top-03 ul li:nth-child(even){
	flex-direction: row-reverse;
}


#top-03 ul li .image-box{
	max-width: 400px;
	aspect-ratio: 400 / 240;
}

#top-03 ul li h4{
	width: auto;
	margin-bottom: 36px;
}

#top-03 ul li:nth-child(1) h4{
	aspect-ratio: 435 / 60;
	height: 60px;
	max-width: 435px;
}
#top-03 ul li:nth-child(2) h4{
	aspect-ratio: 448 / 61;
	height: 61px;
	max-width: 448px;
}
#top-03 ul li:nth-child(3) h4{
	aspect-ratio: 418 / 61;
	height: 61px;
	max-width: 418px;
}
#top-03 ul li:nth-child(4) h4{
	aspect-ratio: 387 / 60;
	height: 60px;
	max-width: 387px;
}
#top-03 ul li:nth-child(5) h4{
	aspect-ratio: 424 / 60;
	height: 60px;
	max-width: 424px;
}

#top-03 ul li p{
	font-size: 19px;
}



/* top-04 */
#top-04{
	background-color: #fff;
   background-image: url("../images/top-04-back.jpg");
	background-size: cover;
    background-repeat: no-repeat;
	position: relative;
	width: 100%;
}

#top-04 .container{
	background: rgba(255,255,255,0.6);
	/*box-shadow: 0px 7px 10px rgba(0, 0, 0, 0.3);*/
	padding: 115px 100px 100px;
}

#top-04 h3{
	width: 90%;
	max-width: 519px;
	aspect-ratio: 519 / 96;
	margin: 0 auto 46px;
}

#top-04 ul{
	display: flex;
	flex-direction: column;
	gap: 35px;
}
#top-04 ul li{
	background: #fff;
	border-top: solid 2px #172a88;
	padding: 20px;
	align-items: flex-start;
	justify-content: space-between;
	gap: 20px;
	position: relative;
	box-shadow: 0px 0px 4px rgba(0, 41, 66, 0.1);
}

#top-04 ul li::after {
  content: '';
  position: absolute;
  left: 50%;
  bottom: -20px;                
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 25px solid transparent;
  border-right: 25px solid transparent;
  border-top: 20px solid #fff;
}
#top-04 ul li:last-child::after{
	display: none;
}


.step-inner-01{
	display: flex;
	gap: 20px;
	align-items: flex-start;
}

.step-inner-02{
	display: flex;
	flex-direction: column;
}

.step-inner-02 span{
	font-size: 19px;
	display: flex;
	align-items: center;
	position: relative;
	padding-left: 22px;
}
.step-inner-02 span::before{
	content:'';
	display: inline-block;
	width: 17px;
	height: 17px;
	background: #ff6e00;
	border-radius: 50%;
	margin-right: 2px;
	position: absolute;
    left: 0;
    top: 7px;
}

#top-04 ul li h4{
	font-size: 26px;
	font-style: italic;
	margin-top: 13px;
	margin-bottom: 25px;
}

.step{
	width: 160px;
	aspect-ratio: 160 / 54;
	margin-top: 10px;
}

.step-image{
	width: 270px;
	aspect-ratio: 270 / 195;
}



/* top-05 */
#top-05{
	position: relative;
	width: 100%;
	background: #fff;
	padding: 0 20px;
}

#top-05 .container{
	padding: 98px 0 115px;
	max-width: 960px;
}

#top-05 h3{
	width: 90%;
	max-width: 325px;
	aspect-ratio: 325 / 87;
	margin: 0 auto 60px;
}



.qa-item {
  margin: 20px 0;
}

/* summary行のベース */
.qa-summary {
  list-style: none;
  position: relative;
  padding: 30px 28px 30px 88px;
  cursor: pointer;
  user-select: none;
  background: #ff6e00;
	color: #fff;
	font-size: 22px;
}
.qa-summary::-webkit-details-marker { display: none; }
.qa-summary::marker { content: ""; }

/* 左の疑似アイコン */
.qa-summary::before {
  content: "";
  position: absolute;
  left: 22px;
  top: 50%;
  width: 50px;
  height: 50px;
  background:url("../images/icon-q.svg");
  transform: translateY(-50%);
	font-size: 40px;
}

/* 右端のプラス/マイナス */
.qa-summary::after {
  content: "+";
  position: absolute;
  right:28px;
  top: 50%;
  transform: translateY(-50%);
	font-size: 40px;
}
.qa-item[open] .qa-summary::after {
  content: "−";
}

/* コンテンツ */
.qa-content {
  padding: 30px 40px;
	background: #fff3d7;
	font-size: 19px;
}



/* top-06 */

#top-06{
	position: relative;
	width: 100%;
	background-color: #fff;
	padding-top: 93px;
}

#top-06 .bg-wrapper{
	 background-image: url("../images/top-06-back.jpg");
	background-size: cover;
    background-repeat: no-repeat;
	position: relative;
	width: 100%;
	aspect-ratio: 1920 / 910;
}



#top-06 .container{
    /*max-width: none;
    width: 100%;*/
	position: absolute;
  inset: 0;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  transform: translateY(-10.989%);
}


#top-06 .content-image{
	width: 73.6vw;
  max-width: 1414px;
  height: auto;
  max-height: calc(100% + 10.989%);
  object-fit: contain;
}



/* footer */

footer{
	margin-bottom: 90px;
}


#footer-contact-area{
	background: #172a88;
}

#footer-contact-area .blue-box{
	max-width: none;
	padding: 80px 60px;
}

#footer-contact-area .blue-box-inner{
	width: 100%;
	gap: 60px;
	padding: 30px 60px;
}

#footer-contact-area .blue-box-inner .tel {
    width: 50%;
	height: auto;
	max-width: 577px;
    aspect-ratio: 577 / 91;
}
#footer-contact-area .blue-box-inner .button{
	width: 50%;
	height: auto;
	max-width: 530px;
	aspect-ratio: 530 / 116;
	font-size: 24px;
}

#footer-contact-area .blue-box h3{
	font-size: clamp(24px, 3.7vw, 49px);
}
#footer-contact-area .blue-box ul{
	margin-bottom: 30px;
}
#footer-contact-area .blue-box ul li{
	font-size: clamp(18px, 3vw, 30px);
}

#footer-contact-area .blue-box p {
    font-size: clamp(17px, 2.5vw, 25px);
}





.footer-inner{
	width: 100%;
	padding: 0 40px;
    display: flex;
    flex-direction: column;
	align-items:center;
}



.footer-logo{
	margin-bottom: 50px;
	color: #fff;
}


.footer-nav{
	display: flex;
	width: 100%;
	justify-content: center;
	padding: 45px 60px;
}

.footer-nav li{
	padding: 0 25px;
    border-left: 1px solid #898989;
	display: flex;
	align-items: center;
}
.footer-nav li:last-child{
    border-right: 1px solid #898989;
}

.footer-nav li a{
	font-size: 15px;
	color: #000;
	transition: 0.3s all;
}
.footer-nav li a:hover{
	color: #22ac38;
}

.copy-area{
	background: #000;
	color: #fff;
	font-size: 18px;
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 35px 60px;
}



#follow-bar{
	display: none;
}




/* 会社案内 */


#company #content-01{
	padding: 130px 20px 150px;
}

#company h2{
	width: 90%;
    max-width: 250px;
    aspect-ratio: 250 / 98;
    margin: 0 auto 60px;
}

.table-wrap{
	max-width:960px;
	margin:24px auto;
	/*padding:0 16px;*/
}
  .company-table{
	  width:100%;
	  border-collapse:collapse;
	  table-layout:fixed;
	  background:#fff;
	  font-size:16px;
	  line-height:1.7;
	  border:1px solid #c9caca;
}
  .company-table th,
  .company-table td{
	  border:1px solid #c9caca;
	  padding:18px 20px;
	  vertical-align:top;
	  word-break:break-word;
}
  .company-table th{
	  width:247px;
	  background:#efefef;
	  font-weight:600;
	  text-align:left;
	  white-space:nowrap;
	  vertical-align: middle;
}
  .company-table td{
	  background:#fff;
}
  /* サービス内容：オレンジの丸い中黒 */
  .list{
    list-style:none;
	  margin:0;
	  padding:0;
  }
  .list li{
    position:relative;
	  padding-left:28px;
	  margin:6px 0;
  }
  .list li::before{
    content:"";
	  position:absolute;
	  left:8px;
	  top:0.8em;
	  transform:translateY(-50%);
      width:17px;
	  height:17px;
	  border-radius:50%;
	  background: #ff6e00;
  }


	  
	  



/* お問い合わせ */

#contact #content-01{
	padding: 130px 20px 150px;
}

#contact h2{
	width: 90%;
    max-width: 357px;
    aspect-ratio: 357 / 97;
    margin: 0 auto 60px;
}

#contact #content-01 p{
	max-width: 960px;
    margin: 0 auto 70px;
	font-size: 20px;
}

#contact #content-01 .blue-box{
	margin-bottom: 95px;
}

#contact #content-01 .blue-box h3{
    margin-bottom: 30px;
}

#contact #content-01 .blue-box-inner{
	gap: 0;
    justify-content: center;
    margin-bottom: 20px;
    width: 100%;
    max-width: 800px;
    height: 120px;
}
#contact #content-01 .blue-box-inner .tel{
	width: clamp(280px, 27.81vw, 534px); 
	aspect-ratio: 534 / 84;
}

.form-wrap p{
	text-align: center;
	margin-bottom: 60px;
}

.form-wrap{
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 0 0;
}

.form-group {
  display: flex;
  align-items: center;
	color: #000;
	margin: 0 56px 0 30px;
	border-bottom: solid 1px #eaeef2;
}

.form-group:first-of-type {
  border-top: 1px solid #eaeef2;
}

.form-group label {
  display: flex;
  align-items: center;
  font-size: 1rem;
  font-weight: bold;
	border-bottom: solid 2px #172a88;
	padding: 30px 0;
	height: auto;
	min-height: 80px;
}
.form-group:nth-child(1) label{
	border-top: solid 2px #172a88;
}
.form-group.inquiry-details label{
	height: 378px;
	align-items: flex-start;
}

.form-group.text-area{
	align-items: flex-start;
}

.label-name{
	width: 160px;
    display: flex;
    align-items: center;
}

.label-column{
	display: flex;
	flex-direction: column;
	align-items: flex-start;
}

.label-name .mini{
	display: inline-block;
	font-size: 0.8em;
	margin-top: 0.8em;
}


.required {
  font-size: 0.8rem;
  color: #fff;
  background-color: #e60012;
  font-weight: normal;
  padding: 2px 5px;
  white-space: nowrap;
	width: 55px;
	height: 22px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.optional{
	width: 90px;
	height: 30px;
	margin: 0 65px;
}

.form-group > input[type="text"],
.form-group > textarea {
  width: 100%;
  box-sizing: border-box;
  border: none;
  padding: 20px;
  font-size: 1rem;
  min-height: 60px;
	margin-left: 30px;
	background: #efefef;
}

.form-group:nth-of-type(1) > .confirmation-box,
.form-group:nth-of-type(2) > .confirmation-box,
.form-group:nth-of-type(3) > .confirmation-box,
.form-group:nth-of-type(4) > .confirmation-box,
.form-group:nth-of-type(1) > input[type="text"],
.form-group:nth-of-type(2) > input[type="text"],
.form-group:nth-of-type(3) > input[type="text"],
.form-group:nth-of-type(4) > input[type="text"]{
	max-width: 693px;
}

#form input{
	font-family: "Poppins", "Noto Sans JP", sans-serif;
}

.form-group textarea {
  min-height: 348px;
	margin-top: 10px;
	font-family: "Poppins", "Noto Sans JP", sans-serif;
}


::placeholder {
  color: #898989;
  opacity: 1;
}



.form-wrap .button-container{
	margin: 80px 0 0;
}
.form-wrap .button{
    max-width: 481px;
    width: 100%;
    height: 96px;
    border-top: none;
    border-left: none;
	font-size: 22px;
	cursor: pointer;
}



.confirmation .label-name{
	font-size: 0.95em;
}

.confirmation-box{
    max-height: 120px;
    max-width: 100%;
    white-space: pre-wrap;
    overflow-wrap: anywhere;
    overflow-y: auto;
    width: 100%;
    box-sizing: border-box;
    border: none;
    padding: 20px;
    font-size: 1rem;
    min-height: 60px;
    margin-left: 30px;
    background: #efefef;
}

/*.confirmation .form-group.inquiry-details .label-name{
	border-bottom: none;
}*/

.confirmation .form-group.privacy-ex .label-name{
	border-top: 1px solid #000;
}
.confirmation .form-group.privacy-ex .confirmation-box{
	margin-top: 10px;
}

.confirmation .form-group.inquiry-details .confirmation-box {
	margin-top: 10px;
	/*max-height: 120px;*/
    max-width: 100%;
	min-height: 348px;
}

.thanks #form .button-container .button{
	padding: 15px 60px 15px 30px;
}

.error_messe{
	font-size: 16px;
	color: #e75400;
}

#contact.thanks .button::before{
	display: none;
}

.button_area{
	display: flex;
	gap: 0 40px;
}

.button_area .button-container{
	width: 50%;
}


.sp-button{display:none;}


#follow-bar{
		display: block;
        position: fixed;
        left: 0;
        right: 0;
        bottom: 0; /* iOS対応したい場合は calc(env(safe-area-inset-bottom,0px)) に */
        z-index: 9999;
        transform: translateY(100%);
        transition: transform .25s ease; /* “にゅっ” の動き */
        will-change: transform;
      }

      /* 表示時（にゅっと上がる） */
      #follow-bar.is-visible{
        transform: translateY(0%);
      }
	
	#follow-bar .blue-box-inner{
		margin-bottom: 0;
		box-shadow: 0px 2px 5px rgba(0, 0, 0, 0.2);
		height: 90px;
	}
    #follow-bar .blue-box-inner .tel{
        margin: 0 auto;
    }




/*
 * レスポンシブデザイン
 */

@media (max-width: 1640px) {
	#hero:after{
		width: clamp(400px,60vw,900px);
		right: -20vw;
	}
}




@media (max-width: 1430px) {
	.for-sp{display:flex;}
}


@media (max-width: 1280px) {
	.site-header{
		padding: 0 20px;
	}
	
	.top-copy h2{
		margin-left: auto;
        margin-right: auto;
		max-width: 820px;
        width: 98%;
	}
	
}


@media (max-width: 980px) {
	
	#contact #content-01 p{
		font-size: 16px;
		text-align: center;
	}
	
	.form-group:nth-child(1) label{
		border-top: none;
	}
	
	.form-group.inquiry-details label{
		height: auto;
	}
	
  .form-group {
    flex-direction: column;
    align-items: flex-start;
    padding: 15px 0;
    margin: 0;
  }

  .form-group label {
   /* width: 100%;*/
    margin-bottom: 10px;
  }
  
  .form-group .label-name {
    width: 100%;
    border-bottom: none;
	 padding-left: 0;
	  height: auto;
  }

  .required, .optional {
    margin: 0;
  }

  .form-group > input[type="text"],
  .form-group > textarea {
    width: 100%;
    max-width: none;
	  margin-left: 0;
  }
  
  .form-group.text-area {
    align-items: flex-start;
  }
  
  .form-group.text-area label {
    margin-bottom: 10px;
  }
  
  .form-group.text-area textarea {
    width: 100%;
    margin-top: 0;
  }
	
	.button_area{
		flex-direction: column;
		align-items: center;
	}
	
	#footer-contact-area .blue-box-inner .button{
		font-size: 16px;
		width: auto;
	}
	
	.confirmation-box{
		margin-left: 0;
	}
 
	
}

@media (max-width: 960px) {

	
	.pc-button{display:none;}
	
	.sp-button{
		display:flex;
		width: fit-content;
	}
	
	.site-header{
		padding: 0 20px;
	}
	.site-header .container{
		height: 90px;
	}
	.site-header .flex-box{
		gap: 26px;
	}
	
	.site-header .sp-button img{
		width: 30px;
		height: 20px;
	}
	.site-header .sp-button.button::before{
		display: none;
	}
	
	.site-header .tel{
		width: 30px;
		aspect-ratio: 63 / 64;
	}
	
	
	#hero:after{
		display: none;
	}
	
	.blue-box ul{
		flex-wrap: wrap;
	}

	
	.blue-box-inner{
		flex-direction: column;
		width: 100%;
	}
	
	#top-03 .container{
		padding: 40px 20px 120px;
	}
	#top-03 .h-box{
		justify-content: center;
		align-items: center;
    flex-direction: column;
	}
	#top-03 h3,
	#top-03 .h-sub{
		width: 90%;
	}
	#top-03 ul li,
	#top-03 ul li:nth-child(even){
		padding: 30px 20px;
		flex-direction: column;
		width: 100%;
	}
	#top-03 ul li h4{
		width: 100%;
	}
	#top-03 ul li p {
    font-size: 16px;
}
	#top-03 ul li .image-box{
		margin: 0 auto;
	}
	
	#top-04 .container{
		padding: 115px 20px 100px;
	}
	#top-04 ul li{
		flex-direction: column;
	}
	.step-image{
		margin: 0 auto;
	}
	.step-inner-01{
		flex-direction: column;
	}
	
	.site-header .tel {
            width: 30px;
            aspect-ratio: 63 / 64;
        }
	
	#follow-bar{
        display: flex;
		transform: translateY(0%)!important;
    }

	
	#follow-bar .blue-box-inner .tel{
		    margin: initial;
	}

    
	
}


@media (max-width: 768px) {

	
	#top-02 .container{
		padding: 80px 20px 98px;
	}
	
	#top-02 ul li{
		width: 100%;
	}
	
	.blue-box{
		padding: 20px;
	}
	
	.blue-box-inner .button{
		width: 328px;
		font-size: 16px;
	}
	.blue-box ul li{
		font-size: 16px;
	}
	.blue-box p{
		font-size: 16px;
	}
	
	
	.step-inner-02 span{
		font-size: 16px;
	}
	.step-inner-02 span::before{
		    width: 16px;
            height: 16px;
            top: 5px;
	}
	
	#top-04 h3{
		width: 60%;
		margin: 0px auto 30px;
	}
	

	
	#top-06{
		padding-top: 0;
	}
	
	:root {
  --bleed: 5.208333vw; /* = 100 / 1920 * 100vw */
}

  #top-06 .bg-wrapper{
    aspect-ratio: auto;
    min-height: calc(96vw * (1000 / 1414) + var(--bleed));
  }

  #top-06 .container{
    transform: translateY(calc(-1 * var(--bleed)));
    align-items: flex-start;
    justify-content: center;
  }

  #top-06 .content-image{
    width: 96%;
    max-width: none;
    height: auto;
  }
	
	
	.qa-summary{
		font-size: 18px;
		padding: 30px 36px 30px 64px;
	}
	.qa-content{
		padding: 30px 20px;
        font-size: 16px;
        }
	.qa-summary::before{
        width: 26px;
        height: 26px;
	}
	.qa-summary::after{
		right: 10px;
        top: 50%;
        font-size: 30px;
        }
	
	
	#footer-contact-area .blue-box{
		padding: 80px 20px;
	}
	#footer-contact-area .blue-box h3{}
	
	#footer-contact-area .blue-box-inner .button{
		width: 100%;
		font-size: 16px;
        padding: 27px 30px;
	}
	#footer-contact-area .blue-box-inner{
		padding: 30px 20px;
	}
	#footer-contact-area .blue-box-inner .tel{
		width: 90%;
	}

	
	
	.footer-nav{
		padding: 25px 20px;
	}
	.copy-area{
		font-size: 14px;
		padding: 35px 20px;
	}
	
	.tel{
	pointer-events: auto;
    }
	
	/*#company #content-01 {
    padding: 60px 0 80px;
    }*/
	
	#company h2{
		  max-width: 180px;
	  }
	  
    .company-table,
    .company-table thead,
    .company-table tbody,
    .company-table tr,
    .company-table th,
    .company-table td{
		display:block;
		width:100%;
	  }
   /* .company-table tr{
		border-top:1px solid #c9caca;
	  }*/
    .company-table th{
      background:#efefef;
      border-bottom:none;
      padding:14px 16px;
      font-size:15px;
    }
    .company-table td{
      border-top:none;
      padding:14px 16px 18px;
      font-size:15px;
    }
    .company-table{
		border-left:1px solid #c9caca;
		border-right:1px solid #c9caca;
	  }
    .area-cell{
		padding-right:16px;
	  }
	
	#contact h2{
		max-width: 268px;
	}
	#contact p{
		text-align: left;
	}
	
	#footer-contact-area .blue-box-inner{
		gap: 30px;
	}
	#contact #content-01 p{
		text-align: left;
	}
	
	#top-05 h3{
		width: 60%;
	}
	
	
	

	
}

	  
	  
	  
	  
	  
	  
	  

[id]{
	scroll-margin-top: 40px;
}










