@charset "UTF-8";
/* CSS PC/SP共通レイアウト */

#main_contents .ttl_contact {
	height: 360px;
	line-height: 360px;
	background: url(../img/contact/title_back_contact.jpg) no-repeat center center;
	background-size: cover;
	font-size: 6.8rem;
	color: #FFF;
	text-shadow: 1px 2px 3px #333;
	font-weight: 900;
	text-align: center;
}
#main_contents .ttl_second {
	font-size: 4.0rem;
	font-weight: 700;
	text-align: center;
}

/*--------------------------------------------------*
 *   お電話・FAXからお問い合わせ
 *--------------------------------------------------*/
#main_contents .number {
	width: 1000px;
	margin: 100px auto 0px;
}
#main_contents .number .border_a {
	font-size: 2.6rem;
	color: #0967d8;
	font-weight: 700;
	text-align: center;
	border-top: 3px solid #0967d8;
	border-bottom: 3px solid #0967d8;
	margin-top: 60px;
}
#main_contents .number .border_b {
	font-size: 2.6rem;
	color: #01b5d5;
	font-weight: 700;
	text-align: center;
	border-top: 3px solid #01b5d5;
	border-bottom: 3px solid #01b5d5;
	margin-top: 60px;
}
#main_contents .number .number_top {
	width: 100%;
	margin-top: 30px;
	overflow: hidden;
}
#main_contents .number .number_top .box {
	width: 50%;
	float: left;
	text-align: center;
}
#main_contents .number .number_top .box:nth-child(1) {
	border-right: 1px solid #CCC;
}
#main_contents .number .number_top .box p:nth-child(1) {
	font-size: 4.6rem;
	font-weight: 700;
	line-height: 1.0;
	letter-spacing: 2px;
}
#main_contents .number .number_top .box p:nth-child(1) a {
	color: #000;
	background: url(../img/common/icon_freedial_black.png) no-repeat left 16px;
	padding-left: 65px;
}
#main_contents .number .number_top .box p:nth-child(1) span {
	font-size: 2.6rem;
}
#main_contents .number .number_top .box p:nth-child(2) {
	font-size: 1.8rem;
	padding-top: 5px;
}
#main_contents .number .number_list {
	margin-top: 10px;
}
#main_contents .number .number_list ul li {
	padding: 30px 0px 30px 30px;
	border-bottom: 1px solid #CCC;
}
#main_contents .number .number_list ul li:last-child {
	padding-bottom: 0px;
	border-bottom: none;
}
#main_contents .number .number_list ul li dl {
	overflow: hidden;
}
#main_contents .number .number_list ul li dl dt {
	width: 180px;
	float: left;
	font-size: 2.2rem;
	color: #FFF;
	line-height: 1.0;
	background-color: #40c7df;
	text-align: center;
	padding: 8px 0px 12px;
}
#main_contents .number .number_list ul li dl dd {
	width: 790px;
	float: left;
	font-size: 4.0rem;
	font-weight: 700;
	line-height: 1.0;
	letter-spacing: 1px;
	padding-left: 20px;
}
#main_contents .number .number_list ul li dl dd a {
  color: #000;
}
#main_contents .number .number_list ul li dl dd p {
	display: inline-block;
}
#main_contents .number .number_list ul li dl dd p span.piece1 {
	font-size: 2.2rem;
}
#main_contents .number .number_list ul li dl dd p span.piece2 {
	color: #40c7df;
	padding-left: 20px;
}

/*--------------------------------------------------*
 *   フォームからお問い合わせ
 *--------------------------------------------------*/
#main_contents .form_block {
	width: 100%;
	background-color: #e2eef6;
	margin-top: 100px;
	padding: 90px 0px 150px;
}
#main_contents .form_block .inner {
	width: 1000px;
	margin: 60px auto 0px;
}
#main_contents .form_block .inner .select ul li {
	width: 50%;
	float: left;
	text-align: center;
}
#main_contents .form_block .inner .select ul li a {
	display: block;
	font-size: 2.2rem;
	color: #FFF;
	font-weight: 700;
	line-height: 80px;
	background-color: #9dc2ef;
}
#main_contents .form_block .inner .select ul li a:hover {
	background-color: #0967d8;
}
#main_contents .form_block .inner .select ul li .active {
	display: block;
	font-size: 2.2rem;
	color: #FFF;
	font-weight: 700;
	line-height: 80px;
	background-color: #0967d8;
}
#main_contents .form_block .inner table {
	width: 880px;
	margin: 50px auto 0px;
}
#main_contents .form_block .inner table th {
	width: 240px;
	font-size: 2.0rem;
	padding: 15px 0px;
	vertical-align: top;
	text-align: left;
}
#main_contents .form_block .inner table th span {
	display: inline-block;
	vertical-align: middle;
	width: 190px;
}
#main_contents .form_block .inner table th span.hissu {
	font-size: 1.3rem;
	color: #FFF;
	line-height: 1.8;
	width: 50px;
	background-color: #c30d23;
	text-align: center;
}
#main_contents .form_block .inner table td {
	width: 640px;
	padding: 15px 0px 15px 40px;
	vertical-align: top;
}
#main_contents .form_block .inner table td input[type="text"] {
	width: 100%;
	border: none;
	font-size: 100%;
	padding: 12px;
	background-color: #ccdde9;
}
#main_contents .form_block .inner table td .mwform-zip-field {
	display:inline-block;
	margin-bottom:10px;
}
#main_contents .form_block .inner table td .mwform-zip-field input[type="text"] {
	width:auto;
}
#main_contents .form_block .inner table td .kibou_type {
	display:inline-block;
	margin-bottom:10px;
}
#main_contents .form_block .inner table td .kibou_type input[type="text"] {
	width:auto;
}
#main_contents .form_block .inner table td .kibou_time {
	display:inline-block;
	margin-bottom:10px;
}
#main_contents .form_block .inner table td .kibou_time input[type="text"] {
	width:auto;
}
#main_contents .form_block .inner table th.title_2c{
	padding: 10px 0px;
}
#main_contents .form_block .inner table th.title_2c_blue{
	background-color: #071556;
	color: #fff;
	padding: 10px 15px;
}
#main_contents .form_block .inner table td ul.photo_area{
	margin:0px auto;
	width:760px;
}
#main_contents .form_block .inner table td ul.photo_area li{
	display:block;
	float:left;
	width:46%;
	padding:0 2% 2% 2%;
	text-align:center;
}
#main_contents .form_block .inner table td ul.photo_area li img{
	width:100%;
}
#main_contents .form_block .inner table td .photo_select_area{
	margin:0px auto;
	width:760px;
	padding-bottom:20px;
}
#main_contents .form_block .inner table td textarea {
	width: 100%;
	height: 240px;
	border: none;
	font-size: 100%;
	padding: 12px;
	background-color: #ccdde9;
}
#main_contents .form_block .inner .txt_send {
	font-size: 1.8rem;
	text-align: center;
	padding-top: 35px;
}
#main_contents .form_block .inner .bt_send {
	width: 350px;
	margin: 50px auto 0px;
}
#main_contents .form_block .inner .bt_send a {
	display:block;
	font-size: 1.7rem;
	color: #FFF;
	font-weight: 700;
	text-align: center;
	position:relative;
	z-index:0;
	line-height: 64px;
	padding-bottom: 5px;
}
#main_contents .form_block .inner .bt_send a:before {
	content:"";
	width:100%;
	height:100%;
	position:absolute;
	z-index:-1;
	left:0;
	transition:0.5s;
	background-color: #0967d8;
	background: -moz-linear-gradient(left, #0967d8, #01b4d5);
	background: -webkit-linear-gradient(left, #0967d8, #01b4d5);
	background: linear-gradient(to right, #0967d8, #01b4d5);
	border-radius: 40px;
}
#main_contents .form_block .inner .bt_send a:after {
	content:"";
	width:100%;
	height:100%;
	position:absolute;
	z-index:-2;
	left:0;
	background-color: #0967d8;
	background: -moz-linear-gradient(left, #0967d8, #0967d8);
	background: -webkit-linear-gradient(left, #0967d8, #0967d8);
	background: linear-gradient(to right, #0967d8, #0967d8);
	border-radius: 40px;
}
#main_contents .form_block .inner .bt_send a:hover:before {
	opacity:0;
}
#main_contents .form_block .inner .bt_send a span {
	padding-right: 120px;
	padding-left: 110px;
	background: url(../img/common/bt_arrow.png) no-repeat right center;
}
#main_contents .form_block .inner .bt_send input {
	width: 350px;
	display:block;
	font-size: 1.7rem;
	color: #FFF;
	font-weight: 700;
	text-align: center;
	position:relative;
	z-index:0;
	line-height: 64px;
	padding-bottom: 5px;
	border:none;
	padding-right: 120px;
	padding-left: 120px;
	transition:0.5s;
	background-color: #0967d8;
	background: -moz-linear-gradient(left, #0967d8, #01b4d5);
	background: -webkit-linear-gradient(left, #0967d8, #01b4d5);
	background: linear-gradient(to right, #0967d8, #01b4d5);
	border-radius: 40px;
}
#main_contents .form_block .inner .bt_back {
	width: 350px;
	margin: 50px auto 0px;
}
#main_contents .form_block .inner .bt_back input {
	width: 350px;
	display:block;
	font-size: 1.7rem;
	color: #FFF;
	font-weight: 700;
	text-align: center;
	position:relative;
	z-index:0;
	line-height: 64px;
	padding-bottom: 5px;
	border:none;
	padding-right: 120px;
	padding-left: 120px;
	transition:0.5s;
	background-color: #0967d8;
	background: -moz-linear-gradient(left, #0967d8, #01b4d5);
	background: -webkit-linear-gradient(left, #0967d8, #01b4d5);
	background: linear-gradient(to right, #0967d8, #01b4d5);
	border-radius: 40px;
}

/* スマホレイアウト */
@media (max-width: 639px) {
#main_contents .ttl_contact {
	height: 30vw;
	line-height: 30vw;
	font-size: 6vw;
}
#main_contents .ttl_second {
	font-size: 5.4vw;
}

/*--------------------------------------------------*
 *   お電話・FAXからお問い合わせ
 *--------------------------------------------------*/
#main_contents .number {
	width: auto;
	margin: 9vw 6vw 0;
}
#main_contents .number .border_a {
	font-size: 4.6vw;
	border-top: 2px solid #0967d8;
	border-bottom: 2px solid #0967d8;
	margin-top: 6vw;
}
#main_contents .number .border_b {
	font-size: 4.6vw;
	border-top: 2px solid #01b5d5;
	border-bottom: 2px solid #01b5d5;
	margin-top: 6vw;
}
#main_contents .number .number_top {
	margin-top: 6vw;
}
#main_contents .number .number_top .box {
	width: 100%;
	float: none;
  padding: 3vw 0;
}
#main_contents .number .number_top .box:nth-child(1) {
	border-right: none;
  border-bottom: 1px solid #CCC;
}
#main_contents .number .number_top .box p:nth-child(1) {
	font-size: 8.0vw;
}
#main_contents .number .number_top .box p:nth-child(1) a {
	background: url(../img/common/icon_freedial_black.png) no-repeat left 3.4vw;
	background-size: 8vw auto;
	padding-left: 10vw;
}
#main_contents .number .number_top .box p:nth-child(1) span {
	font-size: 5.0vw;
}
#main_contents .number .number_top .box p:nth-child(2) {
	font-size: 4.0vw;
	padding-top: 2vw;
}
#main_contents .number .number_list {
	margin-top: 6vw;
}
#main_contents .number .number_list ul li {
	padding: 3vw 0;
}
#main_contents .number .number_list ul li:last-child {
	padding-bottom: 0px;
	border-bottom: none;
}
#main_contents .number .number_list ul li dl {
  display: table;
  width: 100%;
  padding-left: 3vw;
}
#main_contents .number .number_list ul li dl dt {
  display: table-cell;
  vertical-align: middle;
  float: none;
	width: 30%;
	font-size: 3.6vw;
}
#main_contents .number .number_list ul li dl dd {
  display: table-cell;
  vertical-align: middle;
  float: none;
	width: 70%;
	font-size: 5.6vw;
	padding-left: 3vw;
  line-height: 1.4;
}
#main_contents .number .number_list ul li dl dd p {
	display: inline-block;
}
#main_contents .number .number_list ul li dl dd p span.piece1 {
	font-size: 4vw;
}
#main_contents .number .number_list ul li dl dd p span.piece2 {
  display: none;
}

/*--------------------------------------------------*
 *   フォームからお問い合わせ
 *--------------------------------------------------*/
#main_contents .form_block {
	margin-top: 12vw;
	padding: 9vw 6vw;
}
#main_contents .form_block .inner {
	width: 100%;
	margin: 6vw 0 0;
}
#main_contents .form_block .inner .select {
  padding: 0 6vw;
}
#main_contents .form_block .inner .select ul li {
	width: 100%;
	float: none;
  padding-top: 3vw;
}
#main_contents .form_block .inner .select ul li a {
	font-size: 3.8vw;
	line-height: 16vw;
}
#main_contents .form_block .inner .select ul li .active {
	font-size: 3.8vw;
	line-height: 16vw;
}
#main_contents .form_block .inner table,
#main_contents .form_block .inner table tbody,
#main_contents .form_block .inner table tr,
#main_contents .form_block .inner table th,
#main_contents .form_block .inner table td {
	display: block;
}
#main_contents .form_block .inner table {
	width: 100%;
	margin: 9vw 0 0;
  background-color: #FFF;
}
#main_contents .form_block .inner table th {
	width: 100%;
	font-size: 4.0vw;
	padding: 3vw 6vw 0;
}
#main_contents .form_block .inner table th span {
	width: 80%;
}
#main_contents .form_block .inner table th span.hissu {
	font-size: 3vw;
	width: 20%;
}
#main_contents .form_block .inner table td {
	width: 100%;
	padding: 3vw 6vw 6vw;
  border-bottom: 1px solid #ccdde9;
}
#main_contents .form_block .inner table td input[type="text"] {
	padding: 2.6vw;
}
#main_contents .form_block .inner table td textarea {
	padding: 2.6vw;
}

#main_contents .form_block .inner table td ul.photo_area{
	margin:0px auto;
	width:auto;
}
#main_contents .form_block .inner table td ul.photo_area li{
	float:none;
	width:100%;
	text-align:center;
margin-bottom:20px;
}
#main_contents .form_block .inner table td ul.photo_area li img{
	width:auto;
}
#main_contents .form_block .inner table td .photo_select_area{
	width:100%;
	padding-bottom:20px;
}
#main_contents .form_block .inner table th.title_2c{
	padding: 10px 25px;
}
#main_contents .form_block .inner table th.title_2c_blue{
	background-color: #071556;
	color: #fff;
	padding: 10px 15px;
}

#main_contents .form_block .inner .txt_send {
	font-size: 3.8vw;
	padding-top: 6vw;
}
#main_contents .form_block .inner .bt_send {
	width: 70vw;
	margin: 6vw auto 0px;

}
#main_contents .form_block .inner .bt_send a {
	font-size: 3.8vw;
	line-height: 12vw;
	padding-bottom: 1vw;
}
#main_contents .form_block .inner .bt_send a span {
	vertical-align: middle;
	padding-left: 9vw;
	padding-right: 9vw;
	background-size: 2vw auto;
}

#main_contents .form_block .inner .bt_send input {
	width: 100%;
	font-size: 3.8vw;
	text-align:center;
	padding-right: 0px;
	padding-left: 0px;
}
#main_contents .form_block .inner .bt_back {
	width: 70vw;
	margin: 6vw auto 0px;
}
#main_contents .form_block .inner .bt_back input {
	width: 100%;
	font-size: 3.8vw;
	text-align:center;
	padding-right: 0px;
	padding-left: 0px;
}
/*--------------------------------------------------*
 *   LINE公式（Contactページ）
 *--------------------------------------------------*/
#main_contents .line_block {
  width: 100%;
  background-color: #fff;
  margin-top: 80px;
}
#main_contents .line_block .inner {
  width: 1000px;
  margin: 0 auto;
}
#main_contents .line_block .ttl_line {
  font-size: 4.0rem;
  font-weight: 700;
  text-align: center;
  color: #06C755; /* LINEグリーン系 */
  margin-bottom: 30px;
}

#main_contents .line_block .cols {
  overflow: hidden; /* clearfix 代用 */
}
#main_contents .line_block .cols .col {
  float: left;
}
#main_contents .line_block .cols .qr {
  width: 40%;
  text-align: center;
}
#main_contents .line_block .cols .qr img {
  max-width: 320px;
  width: 100%;
  height: auto;
}
#main_contents .line_block .cols .info {
  width: 60%;
  padding-left: 30px;
}
#main_contents .line_block .lead {
  /* font-size: 1.6rem; */
  font-size: 1.6rem;
  line-height: 1.8;
  margin: 10px 0 20px;
}
#main_contents .line_block .line-url a {
  display: inline-block;
  font-size: 1.8rem;
  color: #0967d8;
  word-break: break-all;
  border-bottom: 1px solid #0967d8;
  padding-bottom: 2px;
}

/* ボタン（既存トーンに合わせつつLINE色） */
#main_contents .line_block .bt_line_go {
  width: 350px;
  margin: 25px 0 0;
}
#main_contents .line_block .bt_line_go a {
  display: block;
  font-size: 1.7rem;
  color: #FFF;
  font-weight: 700;
  text-align: center;
  position: relative;
  z-index: 0;
  line-height: 64px;
  padding-bottom: 5px;
}
#main_contents .line_block .bt_line_go a:before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  z-index: -1;
  left: 0;
  transition: 0.5s;
  background: linear-gradient(to right, #06C755, #32d06d);
  border-radius: 40px;
}
#main_contents .line_block .bt_line_go a:after {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  z-index: -2;
  left: 0;
  background: linear-gradient(to right, #06C755, #06C755);
  border-radius: 40px;
}
#main_contents .line_block .bt_line_go a:hover:before {
  opacity: 0.0;
}
#main_contents .line_block .bt_line_go a span {
  padding-left: 50px;
  padding-right: 60px;
  background: url(../img/contact/L_GW.png) no-repeat right center;
}
/* LINE公式 QRコード中央寄せ */
.line-qr-img {
  display: block;
  margin: 0 auto;       /* 中央寄せ */
  max-width: 150px;     /* 最大幅（必要に応じて変更） */
  height: auto;         /* 縦横比を維持 */
}
/* スマホ（既存に準拠） */
@media (max-width: 639px) {
  #main_contents .line_block {
    margin-top: 12vw;
    padding: 0 6vw;
  }
  #main_contents .line_block .inner {
    width: 100%;
  }
  #main_contents .line_block .ttl_line {
    font-size: 5.4vw;
    margin-bottom: 4vw;
  }
  #main_contents .line_block .cols .qr,
  #main_contents .line_block .cols .info {
    float: none;
    width: 100%;
    padding-left: 0;
  }
  #main_contents .line_block .qr img {
    max-width: 70vw;
  }
  #main_contents .line_block .lead {
    font-size: 3.8vw;
    margin: 4vw 0;
  }
  #main_contents .line_block .line-url a {
    font-size: 4.2vw;
  }
  #main_contents .line_block .bt_line_go {
    width: 70vw;
    margin: 6vw 0 0;
  }
  #main_contents .line_block .bt_line_go a {
    font-size: 3.8vw;
    line-height: 12vw;
    padding-bottom: 1vw;
  }
  #main_contents .line_block .bt_line_go a span {
    vertical-align: middle;
    padding-left: 9vw;
    padding-right: 9vw;
    background-size: 2vw auto;
  }
}

}

/* ===== LINE公式：中央寄せ＆サイズ拡大（上書き） ===== */

/* レイアウトを縦積み中央寄せに変更（PCでも1カラム） */
#main_contents .line_block .cols {
  display: flex;
  flex-direction: column;    /* QR → 説明文 → URL → ボタン の縦並び */
  align-items: center;       /* 全要素を中央に */
  justify-content: center;
  gap: 0;                    /* 間隔は各要素で管理 */
}
#main_contents .line_block .cols .col {
  float: none;               /* 既存のfloatを無効化 */
  width: 100%;
}

/* 見出し「LINE公式アカウント」を中央＆大きめに */
#main_contents .line_block .ttl_line {
  text-align: center;
  font-size: 4.8rem;         /* 4.0rem → 4.8rem にUP（お好みで） */
  margin-bottom: 20px;
}

/* QRコード中央＆サイズ */
#main_contents .line_block .cols .qr { text-align: center; }
#main_contents .line_block .cols .qr a { display: inline-block; }
.line-qr-img {
  display: block;
  margin: 0 auto;
  max-width: 320px;          /* 150 → 320px（見やすいサイズ） */
  width: 100%;
  height: auto;
}

/* 説明文：QRから“数行分”下げて大きく（行間も広め） */
#main_contents .line_block .lead {
  text-align: center;
  font-size: 2.2rem;         /* 1.6rem → 2.2rem */
  line-height: 1.9;
  margin: 32px 0 18px;       /* ← ここで「QRから下へ」距離を確保。増やすなら 40〜56px 程度に */
}

/* URLも中央＆大きく */
#main_contents .line_block .line-url {
  text-align: center;
  margin: 6px 0 20px;	/* 18px ⇒ 20px*/
}
#main_contents .line_block .line-url a {
  font-size: 2.2rem;         /* 1.8rem → 2.2rem */
  border-bottom: 1px solid #0967d8;
  padding-bottom: 3px;
  word-break: break-all;
}

/* ボタンを中央＆少し大きく */
#main_contents .line_block .bt_line_go {
  width: auto;               /* 固定幅 → 自然幅 */
  margin: 10px auto 0;       /* 中央寄せ */
}
#main_contents .line_block .bt_line_go a {
  display: inline-block;
  font-size: 2.0rem;         /* 1.7rem → 2.0rem */
  line-height: 64px;
  padding: 0 48px 5px;       /* 横パディングでボタン幅を調整 */
}
/* 矢印アイコンの背景（※QRではなく矢印画像を推奨） */
#main_contents .line_block .bt_line_go a span {
  padding-left: 50px;
  padding-right: 60px;
  background: url(../img/common/bt_arrow.png) no-repeat right center;
  /* ↑ もし矢印画像の場所が違えばパスを調整してください */
}

/* スマホ：大きさ維持＋余白だけ少し調整 */
@media (max-width: 639px) {
  #main_contents .line_block { margin-top: 12vw; padding: 0 6vw; }
  #main_contents .line_block .ttl_line { font-size: 6.2vw; margin-bottom: 3vw; }
  .line-qr-img { max-width: 70vw; }
  #main_contents .line_block .lead {
    font-size: 4.2vw; 
    margin: 5vw 0 3vw;       /* QRの下の余白 */
    line-height: 1.8;
  }
  #main_contents .line_block .line-url a { font-size: 4.6vw; }
  #main_contents .line_block .bt_line_go a {
    font-size: 4.4vw; line-height: 12vw; padding: 0 8vw 1vw;
  }
  #main_contents .line_block .bt_line_go a span {
    vertical-align: middle; background-size: 2.4vw auto;
  }
}
