@charset "utf-8";
/* ----------------------------------------------------
* contactContents style
* -------------------------------------------------- */
#contactContents article .flow {
  display: table;
  table-layout: fixed;
  margin: 0 auto 30px;
  width: 80%;
  border: solid 1px #cccccc;
  border-radius: 10px;
  border-radius: .625rem;
  box-shadow: 0 0 10px 0 rgba( 0, 0, 0, .15);
  overflow: hidden;
  text-align: center;
}
#contactContents article .flow li {
  display: table-cell;
  vertical-align: middle;
  padding: .7em 1em .7em 2em;
  text-decoration: none;
  position: relative;
  text-shadow: 0 1px 1px rgba( 255, 255, 255, .35);
  background: #bfbfbf;
}
#contactContents article .flow.en li {
  padding: .4em 1em .4em 2em;
  line-height: 1.2;
  font-size: 14px;
  font-size: .875rem;
}
#contactContents article .flow li:first-child {
  border-radius: 8px 0 0 8px;
  border-radius: .5rem 0 0 .5rem;
}
#contactContents article .flow li:last-child {
  border-radius: 0 8px 8px 0;
  border-radius: 0 .5rem .5rem 0;
}
#contactContents article .flow .done {
  background: #ffffff;
}
#contactContents article .flow li::after, #contactContents article .flow li::before {
  content: "";
  position: absolute;
  top: 50%;
  margin-top: -1.5em;
  border-top: 1.5em solid transparent;
  border-bottom: 1.5em solid transparent;
  border-left: 1em solid;
  right: -1em;
}
#contactContents article .flow li::after {
  z-index: 2;
  border-left-color: #bfbfbf;
}
#contactContents article .flow li::before {
  border-left-color: #e5e5e5;
  right: -1.1em;
  z-index: 1;
}
#contactContents article .flow .done::after {
  border-left-color: #ffffff;
}
#contactContents article .flow li:last-child::after, #contactContents article .flow li:last-child::before {
  content: normal;
}
#contactContents article p {
  line-height: 1.7;
}
#contactContents article .formInner {
  margin: 30px auto;
  padding: 30px 20px 10px;
  border: solid 5px #e5e5e5;
  border-radius: 3px;
  border-radius: .1875rem;
  text-align: left;
  box-sizing: border-box;
}
#contactContents article .formInner table {
  width: 100%;
}
#contactContents article .formInner th, #contactContents article .formInner td {
  padding: 0 0 30px;
  font-size: 14px;
  font-size: .875rem;
  line-height: 1.7;
  vertical-align: top;
}
#contactContents article .formInner th {
  width: 28%;
  box-sizing: border-box;
}
#contactContents article .formInner th span {
  font-size: 11px;
  font-size: .6875rem;
  color: #1E1E1E;
}
#contactContents article .formInner th span.noreq {
  font-size: 14px;
  font-size: .875rem;
  color: #2a201d;
  font-weight: bold;
}
#contactContents article .formInner th span.req {
  position: relative;
  margin-right: 1em;
  font-size: 14px;
  font-size: .875rem;
  color: #2a201d;
  font-weight: bold;
}
#contactContents article .formInner th span.req::before {
  position: absolute;
  top: 0;
  right: -1em;
  content: "＊";
  color: #e7141a;
  font-weight: bold;
}
#contactContents article .formInner td {
  box-sizing: border-box;
}
#contactContents article .formInner td textarea, #contactContents article .formInner td input[type^="text"] {
  padding: 10px;
  width: 100%;
  box-sizing: border-box;
}
#contactContents article .formInner td textarea {
  min-height: 10em;
}
#contactContents article .formInner td select, #contactContents article .formInner td textarea, #contactContents article .formInner td input[type^="text"] {
  padding: 15px;
  border: solid 1px #cccccc;
  border-radius: 3px;
  border-radius: .1875rem;
}
#contactContents article .formInner td select {
  margin-bottom: 15px;
}
#contactContents article .buttonWrap {
  margin: 0 auto;
  max-width: 600px;
  text-align: center;
}
#contactContents article #back {
  margin: 40px 20px 40px 0;
  width: 250px;
}
#contactContents article #send {
  margin: 40px 0 40px 20px;
  width: 250px;
}
#contactContents article #back {
  float: left;
  padding: 11px 10px;
  background: #999999;
  box-shadow: 0 0 15px 0 rgba( 0, 0, 0, .2);
  border: solid 1px #949494;
  border-bottom: solid 1px #808080;
  border-radius: 10px;
  border-radius: .625rem;
  color: #231815;
  font-weight: bold;
  font-size: 20px;
  font-size: 1.25rem;
  line-height: 1.3;
  text-align: center;
  box-sizing: border-box;
}
#contactContents article #send {
  float: right;
  padding: 11px 10px;
  background: #fcfcfc;
  box-shadow: 0 0 15px 0 rgba( 0, 0, 0, .2);
  border: solid 1px #cccccc;
  border-bottom: solid 1px #8c8c8c;
  border-radius: 10px;
  border-radius: .625rem;
  color: #231815;
  font-weight: bold;
  font-size: 20px;
  font-size: 1.25rem;
  line-height: 1.3;
  text-align: center;
  box-sizing: border-box;
}
@media screen and all and (-webkit-min-device-pixel-ratio:0) and (min-resolution: .001dpcm) {
#contactContents article #back, #contactContents article #send {
transition: all .3s ease 0s;
}
}
@-moz-document url-prefix() {
#contactContents article #back, #contactContents article #send {
transition: all .3s ease 0s;
}
}
@media screen and screen and (-webkit-min-device-pixel-ratio:0) {
::i-block-chrome, #contactContents article #back {
transition: all .3s ease 0s;
}
::i-block-chrome, #contactContents article #send {
transition: all .3s ease 0s;
}
}
#contactContents article .consent {
  margin: 30px auto;
  text-align: center;
}
#contactContents article .consent a {
  position: relative;
  padding-right: 1.7em;
  text-decoration: underline;
}
#contactContents article .consent a::after {
  position: absolute;
  bottom: 3px;
  right: 2px;
  display: block;
  content: "　";
  background: url(../img/ico_opwin.png) no-repeat left bottom;
  background-size: 100% auto;
  width: 1.3em;
  height: 1.3em;
}
#contactContents article .consent br {
  display: none;
}
textarea:disabled, input:not([type]):disabled, input[type="color" i]:disabled, input[type="date" i]:disabled, input[type="datetime" i]:disabled, input[type="datetime-local" i]:disabled, input[type="email" i]:disabled, input[type="month" i]:disabled, input[type="password" i]:disabled, input[type="number" i]:disabled, input[type="search" i]:disabled, input[type="tel" i]:disabled, input[type="text" i]:disabled, input[type="time" i]:disabled, input[type="url" i]:disabled, input[type="week" i]:disabled {
background: #e5e5e5;
}
#contactContents article input:disabled, #contactContents article textarea:disabled {
  color: rgb(84, 84, 84);
}
#contactContents article .formInner p {
  margin-bottom: 15px;
  padding: 0 15px;
  font-size: 15px;
  font-size: .9375rem;
  line-height: 1.7;
}

/* tablet */
@media screen and (max-width: 59.9375em) {
#contactContents article .formInner th {
  width: 35%;
}
#contactContents article .buttonWrap {
  margin: 0 auto;
  width: 80%;
  text-align: center;
}
#contactContents article #back {
  margin: 40px 5% 40px 0;
  width: 45%;
}
#contactContents article #send {
  margin: 40px 0 40px 5%;
  width: 45%;
}
}

/* SP */
@media screen and (max-width: 37.5em) {
#contactContents article .flow {
  margin-bottom: 25px;
  width: 85%;
}
#contactContents article .flow li {
  padding: .6em 0.5em .6em 1em;
  font-size: 12px;
  font-size: .75rem;
  line-height: 1.3;
}
#contactContents article .flow.en li {
  padding: .2em 0em .2em 1em;
  font-size: 11px;
  font-size: .6875rem;
}
#contactContents article p {
  padding-left: 5%;
  padding-right: 5%;
  font-size: 16px;
  font-size: 1rem;
  line-height: 1.8;
}
#contactContents article .formInner {
  margin: 25px auto;
  padding: 20px 15px 10px;
  border: solid 4px #e5e5e5;
}
#contactContents article .formInner th {
  display: block;
  padding-bottom: 15px;
  width: 100%;
  box-sizing: border-box;
  line-height: 1.3;
}
#contactContents article .formInner td {
  width: 100%;
  display: block;
  line-height: 1.8;
}
#contactContents article .formInner th br {
  display: none;
}
#contactContents article .formInner th span.req {
  margin-right: 1.5em;
}
#contactContents article .formInner td select, #contactContents article .formInner td textarea, #contactContents article .formInner td input[type^="text"] {
  padding: 10px;
  line-height: 1.8;
}
#contactContents article .formInner td input[type^="text"] {
  min-height: 50px;
}
#contactContents article .formInner td select {
  padding: 14px 10px;
  min-height: 50px;
}
#contactContents article .consent br {
  display: block;
}
#contactContents article .buttonWrap {
  margin: 0 auto;
  width: 90%;
  text-align: center;
}
#contactContents article #back {
  margin: 0 3.5% 30px 0;
  width: 46.5%;
}
#contactContents article #send {
  margin: 0 0 30px 3.5%;
  width: 46.5%;
}
}
