@charset "utf-8";

/*
  File Name   : contact.css
*/


/* PC Layout ******************************************************************************************* */
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@400;500;600;700&display=swap');
#header {
  width: 100%;
  height: 95px;
}

#header .inner {
  position: relative;
  width: 1060px;
  margin: 0 auto;
}

#header .head-logo {
  position: absolute;
  top: 20px;
  left: 20px;
}

.h1-title-wrap {
  background: #fff;
  border-top: solid 4px #e5e5e3;
  padding: 35px 0;
}

.h1-title-wrap h1 {
  font-size: 34px;
  font-weight: bold;
  font-family: 'Noto Serif JP', serif;
  color: #000;
}

.flow-wrap {
  width: 100%;
  padding: 12px 0;
  background: #383838;
}

#contact footer {
  background: #3f3f3f;
  text-align: center;
  padding: 5px 0 20px;
  border-top: none;
}

#copy-right {
  font-size: 13px;
  color: #fff;
}

.table-form {
  margin-bottom: 90px;
}

.table-form th,
.table-form td {
  border-top: solid 1px #ccc;
  padding: 20px 0;
  font-size: 16px;
  vertical-align: top;
}

.table-form th {
  width: 210px;
  font-weight: normal;
}

.table-form th .hissu {
  float: right;
}

.table-form td {
  padding-left: 20px;
  padding-right: 20px;
}

.table-form td input,
.table-form td textarea {
  font-size: 14px;
}

.checkbox-list {
  margin-top: -10px;
}

.checkbox-list li {
  margin-right: 20px;
  font-size: 16px;
}

.search-btn {
  display: inline-block;
  background: #ccc;
  border: solid 1px #aaa;
  text-align: center;
  font-size: 14px;
  padding: 8px;
  width: 220px;
  box-sizing: border-box;
  margin-left: 5px;
}

.search-btn:hover {
  text-decoration: none;
}

.btn-wrap {
  text-align: center;
  margin-bottom: 25px;
}

.confirm-btn {
  background: #a0977a url(/assets/img/common/arrow_r_w03.png) right bottom no-repeat;
  box-sizing: border-box;
  box-shadow: 0 0 0 1px #a0977a;
  border: solid 1px #ccc;
  text-align: center;
  font-size: 20px !important;
  font-weight: bold;
  color: #fff;
  display: inline-block;
  padding: 20px 0;
  width: 300px;
}

.link-btn {
  background: #a0977a url(/assets/img/common/arrow_r_w03.png) right bottom no-repeat;
  box-sizing: border-box;
  box-shadow: 0 0 0 1px #a0977a !important;
  border: solid 1px #ccc !important;
  text-align: center;
  font-size: 20px !important;
  font-weight: bold;
  color: #fff !important;
  display: inline-block;
  padding: 20px 0;
  width: 300px;
}

.confirm-btn button,
.back-btn button {
  background: none;
  border-radius: none;
  display: inline-block;
}

.link-btn:hover {
  text-decoration: none;
}

.bottom-text {
  margin: 0 0 35px;
}

.back-btn {
  border: solid 1px #000;
  padding: 10px 20px 10px 25px;
  text-align: center;
  margin: 0 25px 0 0;
}

.thanks-list {
  margin: 0 0 30px;
}

.thanks-list li {
  margin: 0 35px 0 0;
}

.thanks-list li:nth-child(3n) {
  margin: 0 0 0 0;
}

.text-01 {
  text-align: center;
  margin: 0 0 35px;
  font-size: 16px;
}

span.style-03:before {
  left: 10px;
}

td label {
  height: 10px !important;
  cursor: pointer;
}

td label.checkbox span {
  /*margin-top: -20px;*/
  margin-top: 0px;
}

label.checkbox input.checked + .check {
  background: url(/assets/img/search/bg_check_on.png) 0 0 no-repeat;
}

tr.error input[type="text"] {
  border: solid 1px #b20000;
}

tr.error select {
  border: solid 1px #b20000;
}

body.index td select {
  width: 270px !important;
}
body.index td select.time {
    width: 70px !important;
}


body.index .lead {
  margin: 0 0 15px;
  font-size: 16px;
}

.thanks-lead {
  text-align: center;
  margin: 10px auto 65px;
  font-size: 22px;
  font-weight: bold;
  line-height: 2.1;
}

.request-thanks-lead-text {
  text-align: center;
  font: 14px;
  margin-bottom: 65px;
}

.request-thanks-lead {
  text-align: center;
  margin: 10px auto 15px;
  font-size: 22px;
  font-weight: bold;
  line-height: 2.1;
}

.thanks-btn {
  display: inline-block;
  width: 190px !important;
  box-sizing: border-box;
  background: #383838;
  padding: 10px 0;
  text-align: center;
  font-size: 14px;
  font-weight: bold;
  color: #fff !important;
  border: solid 1px #ccc;
  box-shadow: 0 0 0 1px #383838 !important;
}

.thanks-btn:hover {
  text-decoration: none;
}


/*
============================================================ */
.table-lead-text {
  font-size: 20px;
  font-weight: bold;
  color: #383838;
  margin: 0 0 20px;
}

.request-lead {
  font-size: 20px;
  font-weight: bold;
  color: #383838;
  margin: 0 0 20px;
}

.request-area-01 table {
  /*border: solid 3px #cea443;*/
  border-top: none;
  margin-bottom: 40px;
}

.request-area-01 table th,
.request-area-01 table td {
  padding: 15px;
  border-bottom: solid 1px #ccc;
}

.request-area-01 table th {
  border-right: solid 1px #ccc;
  background: #cea443;
  text-align: center;
  color: #fff;
  font-size: 16px;
  font-weight: bold;
}

.request-area-01 table th:nth-child(2) {
  border-right: solid 1px #ccc;
  background: #cf6044;
  text-align: center;
  color: #fff;
  font-size: 16px;
  font-weight: bold;
}
.request-area-01 table th:nth-child(3) {
  background: #646464;
}

/* Start cusstom background hidden column [リモート霊園見学を希望する]*/
.request-area-01 table th:nth-child(2) {
  background: #646464 !important;
}
.request-area-01 table th:nth-child(1),
.request-area-01 table td:nth-child(1) {
  width: 30%;
}

.request-area-01 table td:nth-child(2) {
  text-align: left !important;
  background: #fff !important;
}
.request-area-01 table th:nth-child(2) {
  text-align: left;
  padding-left: 40px;
}

/* End cusstom background hidden column [リモート霊園見学を希望する]*/

.request-area-01 table th:nth-child(3),
.request-area-01 table td:nth-child(3) {
  text-align: left;
  padding-left: 40px;
}

.request-area-01 table td:first-child {
  text-align: center;
  width: 250px;
  background: #eee;
  border-right: solid 1px #ccc;
  padding-left: 0px;
}

.request-area-01 table td:nth-child(2) {
  text-align: center;
  width: 250px;
  background: #eee;
  border-right: solid 1px #ccc;
  padding-left: 40px;
}

.request-area-01 table td:nth-child(3) {
  background: #fff;
}

.request-area-01 table td:first-child label span,
.request-area-01 table td:nth-child(2) label span {
  cursor: default;
  text-align: center;
}

.request-area-01 table td:first-child label,
.request-area-01 table td:nth-child(2) label {
  cursor: default;
}

.request-area-01 table td:first-child label input,
.request-area-01 table td:nth-child(2) label input {
  cursor: default;
}

.request-area-03 {
  padding-bottom: 60px;
}

.request-area-03 li {
  width: 160px;
  border-top: solid 1px #ccc;
  margin-right: 40px;
}

.request-area-03 li:nth-child(5n) {
  margin-right: 0;
}

.request-area-03 h2 {
  margin-bottom: 22px;
  font-size: 20px;
}

.request-area-03 li p {
  margin-bottom: 20px;
  height: 65px;
}

.request-area-03 label {
  cursor: pointer !important;
}

.request-area-03 label.checkbox input + .check {
  display: block;
  background: url(/assets/img/search/bg_check.png) center 0 no-repeat;
  padding-left: 0;
  padding-top: 38px;
  margin-top: -15px;
  text-align: left;
}

.request-area-03 label.checkbox input.checked + .check {
  background: url(/assets/img/search/bg_check_on.png) center 0 no-repeat;
}

.request-area-02 {
  border: solid 1px #d6a327;
  padding: 4px;
}

.request-area-02 .inner-wrap {
  border: solid 1px #ebd193;
  padding: 30px;
  padding-bottom: 10px;
  background: #fff;
}

.request-area-02 .btn-06 {
  width: 190px;
  font-size: 16px;
  border: #fff !important;
  padding: 10px 0;
}

.request-area-02 div > input {
  width: 260px !important;
  padding: 8px 10px !important;
}

.request-area-02 div > select {
  width: 260px !important;
  height: 40px;
  margin-left: 5px;
}

.request-area-02 button {
  margin: 15px 0;
}

.request-area-02 div.input {
  margin-bottom: 23px;
}

.request-area-02 .tel {
  display: inline-block;
  font-size: 34px;
  font-weight: bold;
  font-family: 'Arial', 'Tahoma', sans-serif;
}

.request-area-02 .tel-s {
  display: inline-block;
  margin-left: 10px;
}

.request-area-02 {
  margin-bottom: 65px;
}

.table-time {
  margin: 10px 0;
  border: 1px solid #b3b2ac;
}

.table-time th .hissu {
    float: right;
}

.table-time th,
.table-time td{
  padding: 15px;
  border-bottom: 1px solid #b3b2ac;
  vertical-align: middle;
}
.table-time th {
  background: #f5f5f5;
}

.request-area-02 .table-time td div.input {
    margin-bottom: 0;
}
@media screen and (max-width: 768px) {

.table-time{
  width: 100%;
}

.table-time tbody tr{
  display: block;
}
.table-time th,
.table-time td{
  display: list-item;
  width: 100%;
  list-style: none;
}


}





/*.request-area-02 button {
  display: inline-block;
  text-align: center;
  padding: 15px;
  box-sizing: border-box;
  box-shadow: 0 0 0 1px #A0977A inset, 0 0 0 2px #B3AC95 inset;
  color: #fff;
  background: url(/assets/img/common/arrow_r_w03.png) #A0977A right bottom no-repeat;
}*/

.request-area-03 {
  margin-bottom: 70px;
}

table.confirm {
  border-bottom: solid 1px #ccc;
}

.request-confirm {
  border-bottom: solid 1px #383838;
  border-left: solid 1px #383838;
  border-right: solid 1px #383838;
  margin-bottom: 60px;
}

.request-confirm th {
  background: #383838;
  padding: 13px 20px;
  color: #fff;
  font-size: 16px;
}

.request-confirm td {
  background: #fff;
  border-bottom: solid 1px #ccc;
  padding: 15px 20px;
  font-size: 16px;
}

.request-confirm tr:last-child td,
.request-confirm tr td:nth-child(3) {
  border-bottom: none;
}
.request-confirm tr td:nth-child(2) {
  border-left: solid 1px #fff;
  text-align: right;
  padding-right: 10px;
}

.request-confirm tr td:nth-child(2) span {
  background: #8d5583;
  padding: 5px 15px;
  color: #fff;
  font-size: 14px;
  font-weight: bold;
}



.request-confirm tr td:nth-child(2) span {
  background: #8d5583;
  padding: 5px 15px;
  color: #fff;
  font-size: 14px;
  font-weight: bold;
}

.request-confirm tr td:nth-child(3) {
  border-left: solid 1px #ccc;
  text-align: center;
  background: #fff;
}

table.ui-datepicker-calendar tbody td:first-child a.ui-state-default {
  background: #ebc8be;
}
table.ui-datepicker-calendar tbody td:last-child a.ui-state-default {
  background: #91bed9;
}

.ui-datepicker-calendar th:first-child {
  color: #ebc8be;
}

.ui-datepicker-calendar th:last-child {
  color: #91bed9;
}

.error-block {
  background: #fff;
  border: 1px solid #b20000;
  padding: 10px;
  color: #b20000;
}

.error-block li{
  padding-left: 1em;
  text-indent: -1em;
  font-weight: bold;
}




/* SP Layout ******************************************************************************************* */

/* Index
============================================================ */
@media screen and (max-width: 768px) {
  #contact {
    overflow-x: hidden;
  }
  #header {
    height: 50px;
    width: 100%;
    padding-top: 0;
  }
  #header .head-logo {
    left: 27px;
    position: absolute;
    top: 12px;
  }
  #header .head-logo img {
    width: 100px;
    height: auto;
  }
  .h1-title-wrap h1 {
    font-size: 20px;
  }
  #title-area h2 {
    font-size: 20px;
    height: 60px;
  }
  #title-area h2 {
    font-size: 20px;
    height: 60px;
  }
  #title-area h2 {
    display: table-cell;
    font-size: 3.4rem;
    height: 60px;
    vertical-align: middle;
  }
  .h1-title-wrap {
    background: #fff none repeat scroll 0 0;
    border-top: none;
    padding: 0 0;
    height: 60px;
    vertical-align: middle;
    display: table-cell;
  }
  .flow-wrap {
    padding: 6px 0;
    width: 100%;
  }
  .flow-wrap img {
    width: 100%;
    height: auto;
  }
  body.index .lead {
    font-size: 15px;
    margin: 0 0 15px;
  }
  .table-form th,
  .table-form td {
    font-size: 15px;
    padding: 15px 0;
    display: block;
  }
  .table-form th {
    width: 100%;
  }
  .table-form td {
    padding-top: 5px;
    border-top: none;
  }
  .search-btn {
    background: #ccc none repeat scroll 0 0;
    border: 1px solid #aaa;
    box-sizing: border-box;
    display: inline-block;
    font-size: 12px;
    margin-left: 0;
    margin-top: 10px;
    padding: 6px;
  }
  body#contact input.w-zip {
    width: 100%;
  }
  body#contact input.w-60 {
    width: 100%;
  }
  .table-form {
    margin-bottom: 40px;
  }
  .back-btn {
    margin: 0 0 25px 0;
    text-align: center;
  }
  .thanks-lead {
    font-size: 20px;
    line-height: 1.6;
    margin: 10px auto 30px;
  }
  .bg-wh-area-normal {
    margin: 20px 0 20px;
    padding: 20px 0 20px;
  }
  .text-01 {
    font-size: 14px;
    margin: 0 0 20px;
  }
  .thanks-list li {
    width: 100%;
    margin: 0 0 15px 0;
  }
  .link-btn {
    display: inline-block;
    font-size: 18px !important;
    padding: 15px 0;
    width: 100%;
  }
  .request-lead {
    font-size: 18px;
  }
  .request-area-02 .inner-wrap {
    background: #fff none repeat scroll 0 0;
    border: 1px solid #ebd193;
    padding: 20px 20px 10px;
    font-size: 15px;
  }
  .request-area-02 div > select {
    height: 40px;
    margin-top: 10px;
    margin-left: 0;
    width: 100% !important;
  }
  .request-area-02 .tel-s {
    margin-left: 0;
  }
  .ui-datepicker {
    border-collapse: collapse;
    font-size: 1.25em !important;
  }
  .request-area-03 h2 {
    font-size: 18px;
    margin-bottom: 20px;
    line-height: 1.4;
  }
  .request-area-03 li {
    margin-right: 4%;
    margin-bottom: 10%;
    width: 48%;
  }
  .request-area-03 li:nth-child(2n) {
    margin-right: 0;
  }
  .request-area-03 li img {
    width: 100%;
    height: auto;
  }
  .request-area-03 li p {
    height:80px;
  }
  .request-area-03 label.checkbox input + .check {
    text-align: center;
    font-size:15px;
  }
  .request-confirm tr td:nth-child(2) {
    width: 120px;
  }
  .request-confirm tr td:nth-child(3) {
    width: 30%;
  }
  body.index td select {
    width: 100% !important;
  }
  .request-area-02 .btn-06 {
    font-weight: bold;
  }
  .request-area-01 table {
    /*border: solid 3px #cea443;*/
    border-top: none;
    margin-bottom: 0;
  }
  .request-area-01 table th, .request-area-01 table td {
    font-size: 15px;
  }
  .btn-wrap {
    position: relative;
  }
  .btn-wrap button:first-child {
    position:absolute;
    left: 0;
    right: 0;
    margin: auto;
    bottom: 0;
    text-align: center;
    width: 100%;
  }
  .btn-wrap button:first-child span {
    margin: auto;
  }
  .btn-wrap button:last-child {
    position: static;
    margin-bottom: 70px;
  }
  .request-thanks-lead-text {
    font-size: 15px;
  }

  .request-area-01 table td:first-child,
  .request-area-01 table td:nth-child(2) {
    width: auto;
    padding-left: 45px;
  }

}
/* End media screen */


/* 20251024 td 内 label を flex  */
.request-area-01 table td:first-child label.checkbox {
  display: flex;
  justify-content: center; 
  align-items: center;     
  position: relative;      
  margin: 0;
  padding: 15px;
  cursor: pointer;       
  height: auto;
}

/* input は透明 */
.request-area-01 table td:first-child label.checkbox input {
  position: absolute;
  opacity: 0;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  margin: 0;
  cursor: pointer;
}

/* チェックアイコン */
.request-area-01 table td:first-child label.checkbox .check {
  display: inline-block;
  width: 20px;
  height: 21px;
  background: url(/assets/img/search/bg_check.png) center center no-repeat;
  background-size: contain;
  margin: 0;
  padding: 0;
  z-index: 1; 
	cursor: pointer;
}

/* チェックON */
.request-area-01 table td:first-child label.checkbox input:checked + .check {
  background: url(/assets/img/search/bg_check_on.png) center center no-repeat;
  background-size: contain;
}

/* td 中央揃え */
.request-area-01 table td:first-child {
  text-align: center;
  vertical-align: middle;
  padding: 0; 
  width: 250px; 
  background: #eee;
  border-right: solid 1px #ccc;
}


