@charset "UTF-8";
#body { 
  background: #fff8cc url("../img/news/taiyo@2x.png") no-repeat center 60px / 100% auto;
}
@media only screen and (max-width: 560px) {#body { background-size: auto 200px;}}

main { padding-bottom: 230px; position: relative; z-index: 1;}
.floatingMessage {
  position: absolute;
  left: 0;
  bottom: -40px;
  width: 100%;
  height: 100%;
  z-index: 1;
  font-size: 25vw;
  line-height: 1;
  pointer-events: none;
  color: #ff490f;
}
@media only screen and (min-width: 1600px) {
  .floatingMessage {bottom: -3vw;}
}
.floatingMessage p {
  position: absolute;
  overflow: hidden;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
}
.floatingMessage p span {
  white-space: nowrap;
  position: absolute;
  bottom: 0;
  padding-left: 80px;
  display: inline-block;
}

h2.h201 {
  padding: 70px 120px;
  text-align: center;
}
h2.h201 .en {
  color: #ff490f;
  font-size: 90px;
  line-height: 1.2;
  display: block;
}
h2.h201 .jp {
  color: #000;
  font-size: 40px;
  display: block;
  line-height: 1.2;
}
@media only screen and (max-width: 782px) {
  #body { 
    background-position: center 50px;
  }
  main { padding-bottom: 60px; }
  h2.h201 {
    padding: 50px 5%;
  }
  h2.h201 .en {
    font-size: 40px;
  }
  h2.h201 .jp {
    font-size: 20px;
  }
}

#status {
  display: flex;
  margin-top: 70px;
}
#status li {
  background: #ececec;
  color: #ff490f;
  font-size: 1.8rem;
  text-align: center;
  height: 60px;
  line-height: 60px;
  width: 33.3333%;
  position: relative;
   z-index: 1;
}
#status li:first-child { border-radius: 7px 0 0 7px;}
#status li:last-child { border-radius: 0 7px 7px 0;}
#status.status1 li:first-child,
#status.status2 li:nth-child(2),
#status.status3 li:last-child{
  background: #ff490f;
  color: #fff;
  z-index: 3;
}
#status.status1 li:nth-child(2) {
  z-index: 2;
}
#status.status1 li:first-child::before,
#status.status1 li:nth-child(2)::before,
#status.status1 li:nth-child(2)::after,
#status.status2 li:nth-child(2)::before,
#status.status2 li:nth-child(2)::after,
#status.status3 li:nth-child(2)::before,
#status.status3 li:nth-child(2)::after,
#status.status3 li:last-child::before {
  content: "";
  width: 34px;
  height: 60px;
  position: absolute;
  top: 0;
  right: -34px;
  box-sizing: border-box;
  border: transparent 30px solid;
  border-right: transparent 17px solid;
  border-left: #ff490f 17px solid;
}
#status.status1 li:nth-child(2)::before {
  border-left: #fff 17px solid;
  z-index: 2;
  transform: scale(1.05);
}
#status.status1 li:nth-child(2)::after {
  border-left: #ececec 17px solid;
  right: -33px;
  z-index: 3;
}
#status.status2 li:nth-child(2):before {
  right: auto;
  left: 0;
  border-left: #ececec 17px solid;
}
#status.status3 li:nth-child(2)::before {
  right: auto;
  left: 0;
  border-left: #fff 17px solid;
  z-index: 2;
  transform: scale(1.05);
}
#status.status3 li:nth-child(2)::after {
  border-left: #ececec 17px solid;
  right: auto;
  left: -1px;
  z-index: 3;
}
#status.status3 li:last-child::before {
  right: auto;
  left: 0;
  border-left: #ececec 17px solid;
  z-index: 3;
}
@media only screen and (max-width: 782px) {
  #status {
    margin-top: 30px;
    flex-direction: column;
  }
  #status li {
    font-size: 1.3rem;
    height: 60px;
    line-height: 60px;
    width: auto;
  }
  #status li:first-child { border-radius: 0px;}
  #status li:last-child { border-radius: 0;}
  #status.status1 li:first-child::before,
  #status.status1 li:nth-child(2)::before,
  #status.status1 li:nth-child(2)::after,
  #status.status2 li:nth-child(2)::before,
  #status.status2 li:nth-child(2)::after,
  #status.status3 li:first-child::before,
  #status.status3 li:nth-child(2)::before,
  #status.status3 li:nth-child(2)::after,
  #status.status3 li:last-child::before {
    content: "";
    width: 40px;
    height: 20px;
    top: auto;
    bottom: -20px;
    right: auto;
    left: calc(50% - 20px);
    border: transparent 20px solid;
    border-bottom: transparent 10px solid;
    border-top: #ff490f 10px solid;
  }
  #status.status1 li:nth-child(2)::before {
    border-top: #ff490f 10px solid;
    z-index: 2;
    transform: scale(1);
  }
  #status.status1 li:nth-child(2)::after {
    border-top: #ececec 10px solid;
    bottom: -19px;
    z-index: 3;
  }
  #status.status2 li:nth-child(2):before {
    bottom: auto;
    top: 0;
    border-top: #ececec 10px solid;
  }
  #status.status3 li:first-child::before {
    position: absolute;
    box-sizing: border-box;
    border-top: #ececec 10px solid;
    bottom: -19px;
    z-index: 3;
  }
  #status.status3 li:nth-child(2)::before {
    top: 0;
    bottom: auto;
    border-top: #ff490f 10px solid;
    z-index: 2;
  }
  #status.status3 li:nth-child(2)::after {
    border-top: #ececec 10px solid;
    bottom: -19px;
    z-index: 3;
  }
  #status.status3 li:last-child::before {
    border-top: #ff490f 10px solid;
    z-index: 3;
  }
  
  #status.status3 li:first-child::after,
  #status.status3 li:last-child::after,
  #status.status1 li:last-child::after{
    content: "";
    width: 100%;
    height: 1px;
    background: #ff490f;
    position: absolute;
    top: 0;
    left: 0;
  }
  #status.status3 li:first-child::after { top: auto; bottom: 0;}
  
  #status.status3 li:first-child { z-index: 3;}

  #status.status3 li:nth-child(2) { z-index: 2;}
  #status.status3 li:last-child { z-index: 1;}
}

main a { text-decoration: underline; color: #000;}

.contents { position: relative; margin: 0px auto; width: 1360px; max-width:90%; background: #fff; padding:80px 0 0 0; z-index: 2;}
.contents .content {
  padding: 0 0px 90px;
  width: 920px;
  max-width: 90%;
  margin: 0 auto;
  box-sizing: border-box;
}

.contents .content.phoning {
  background: #ececec;
  color: #ff490f;
  padding: 40px;
  margin-bottom: 60px;
}
h4.h401 { font-size: 20px; text-align: center;position: relative;}

h4.h401 span {
  display: inline-block;
  height: 46px;
  position: relative;
  z-index: 2;
  color: #ff490f;
  line-height: 1.3;
  font-weight: bold;
}
.phoning h4.h401 span {
  padding-left: 40px;
  background: #ececec url("../img/contact/phone@2x.png") no-repeat left 50% / 35px auto;
}
.mailing h4.h401 span {
  padding-left: 111px;
  padding-right: 47px;
  background: #fff url("../img/contact/mail@2x.png") no-repeat 40px 50% / 45px auto;
  line-height: 2;
}
.mailing h4.h401::before {
  position: absolute;
  z-index: 1;
  width: 100%;
  height: 2px;
  background: #ff490f;
  content: "";
  left: 0;
  top: 23px;
}

h4.h402 { font-size: 20px; text-align: center; margin: 4rem 0;}
.small { font-size: 13px;}
.callto { text-align: center;}
.callto strong.tel { font-size: 60px; display: block; font-style: normal; line-height: 1.1;}
.callto strong.tel .black { color: #000;}
.callto strong.tel .orange { color: #ff490f !important;}
@media only screen and (max-width: 1480px) {
  .contents .content { }
}
.pc-center { text-align: center;}
@media only screen and (max-width: 782px) {
  .contents {margin: 0 3.33%;
    padding: 30px 3.33%;
    max-width: inherit;
    width: auto; padding-top: 30px;}
  .contents .content {
    padding-bottom: 30px;
    width: auto;
    max-width: inherit;
  }
  .phoning h4.h401 span {
    padding-left: 30px;
    height: auto;
    min-height: 35px;
    background: #ececec url("../img/contact/phone@2x.png") no-repeat left 50% / 25px auto;
  }
  .mailing h4.h401 span {
    padding-left: 20px;
    padding-right: 20px;
    padding-top: 20px;
    height: auto;
    background: #fff url("../img/contact/mail@2x.png") no-repeat center top / 25px auto;
    letter-spacing: 0;
  }
  .mailing h4.h401::before {
    position: absolute;
    z-index: 1;
    width: 100%;
    height: 2px;
    background: #ff490f;
    content: "";
    left: 0;
    top: calc(50% + 10px);
  }
  h4.h401 { font-size: 16px;}
  h4.h402 { font-size: 16px;}
  .small { font-size: 11px;}
  .callto a.sp{ display: inline-block; color: #ff490f; text-decoration: none;}
  .callto strong.tel { font-size: 20px;}
  .pc-center { text-align: left;}
}


span.must { color: #ff490f;}

.tb-contact {
  margin: 5rem 0 0 0 !important;
  border-collapse: collapse;
  padding: 0;
  width: 100%;
}
.tb-contact th {
  font-weight: normal;
  text-align: left;
  padding: 1.2rem 4rem 1.2rem 1.5rem;
  position: relative;
  white-space: nowrap;
  vertical-align: top;
  width: 18rem;
  color: #ff490f;
}
.tb-contact th::before { content: "◇"; color: #ff490f; position: absolute; left: 0; font-size: 1rem; top: 1.8rem;}
.tb-contact .must th::before { content: "◆"; color: #ff490f;}
.tb-contact td { padding: 0.6rem 0;color: #ff490f;}
.confirm .tb-contact td { color: #000;}
.confirm .tb-contact td {padding: 1.2rem 0 1.2rem 0;}
td .flex { display: flex; align-items: center;}
td .note { white-space: nowrap; margin-left: 2rem;}
p.check { text-align: center;}
p.btn {
  display: flex;
  justify-content: center;
  margin: 8rem 0 0 0;
}

.h301 {
  margin-top: 5rem;
  font-size: 2.4rem !important;
  text-align: center;
}

@media only screen and (max-width: 782px) {
  .tb-contact {
    margin: 2rem 0 0 !important;
    display: block;
    width: auto;
  }
  .tb-contact tbody, .tb-contact tr, .tb-contact th, .tb-contact td { display: block;}
  .tb-contact th {
    font-weight: bold;
    padding: 2rem 0 0 1.5rem;
    width: auto;
  }
  .tb-contact th::before { top: 2.3rem;}
  .tb-contact .must th::before { top: 2.3rem;}
  .tb-contact th .small { padding-left: 10px; font-weight: normal;}
  .tb-contact td { padding: 0.6rem 0;}
  .confirm .tb-contact td {padding: 1.2rem 0 1.2rem 0;}
  td .flex { display: flex; align-items: center;}
  th .note {  margin-left: 2rem; font-weight: normal;}
  p.check { text-align: left;}
  p.check + p.check { text-align: center;}
  p.btn {
    display: flex;
    justify-content: center;
    margin: 8rem 0 0 0;
  }
  p.btn input { margin: 0;}

}

/* ------ form ------ */

input, select {
  vertical-align: middle;
}

input {
	line-height: normal;
}


button,
button[disabled]:hover,
button[disabled]:focus,
input[type="button"],
input[type="button"][disabled]:hover,
input[type="button"][disabled]:focus,
input[type="reset"],
input[type="reset"][disabled]:hover,
input[type="reset"][disabled]:focus,
input[type="submit"],
input[type="submit"][disabled]:hover,
input[type="submit"][disabled]:focus,
.go2top a {
	background: #000;
	border: #000 1px solid;
	color: #fff;
	letter-spacing: 0.1rem;
	box-shadow: none;
	border-radius: 3px;
	height: 80px;
	line-height: 80px;
	padding:0 9rem;
	/*text-shadow: 1px 1px 2px #13AA00, -1px -1px 2px #13AA00;*/
	-webkit-appearance: none;
	appearance: none;
  box-sizing: border-box;
  position: relative;
  z-index: 1;
  font-size: 18px;
  font-family: YakuHanJP, 'Noto Sans JP', YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
}

.go2top a { text-decoration: none; display: inline-block; overflow: hidden; }


.btnWrap, .btnWrapBack { position: relative; display: inline-block; overflow: hidden; margin: 0 0.6vw;}

.btnWrap::before, .btnWrapBack::before, .go2top a::after {
  content: "";
  width: 10px;
  height: 10px;
  border-top: #fff 1px solid;
  border-right: #fff 1px solid;
  transform: rotate(45deg);
  position: absolute;
  right: 20px;
  top: calc(50% - 5px);
  z-index: 2;
  pointer-events: none;
}



label { display: inline-block}
label:not(:last-child) { margin-right: 2rem;}
input[type="button"],
  input[type="submit"],
  .go2top a {
    background: #000;
    color: #fff;
    border: none;
    transition: background 0.5s ease;
    cursor: pointer;
  }
input[type="button"]:hover,
input[type="submit"]:hover,
.go2top a:hover {
  animation: flash 0.5s ease;
}

@media only screen and (max-width: 782px) {
	button,
	button[disabled]:hover,
	button[disabled]:focus,
	input[type="button"],
	input[type="button"][disabled]:hover,
	input[type="button"][disabled]:focus,
	input[type="reset"],
	input[type="reset"][disabled]:hover,
	input[type="reset"][disabled]:focus,
	input[type="submit"],
	input[type="submit"][disabled]:hover,
	input[type="submit"][disabled]:focus,
  .go2top a {
		height: 6rem;
		line-height: 6rem;
		padding:0 11vw;
    font-size: 13px;
	}
  .confirm .btnWrap, .confirm .btnWrapBack { width: auto; text-align: center;}

}
input[type="button"].back {
  background: #ff490f;
  border: #ff490f 1px solid;
  color: #fff;
}



button:focus,
input[type="button"]:focus,
input[type="reset"]:focus,
input[type="submit"]:focus {
	outline: thin dotted;
	outline-offset: -4px;
}

input[type="date"],
input[type="time"],
input[type="datetime-local"],
input[type="week"],
input[type="month"],
input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="tel"],
input[type="number"],
textarea {
	background: #ececec !important;
	border: #ececec 1px solid;
	padding: 2rem 2.8rem;
	width: 100%;
  max-width: 100%;
	box-sizing: border-box;
	font-size: 1.6rem;
  border-radius: 7px;
  font-family: YakuHanJP, 'Noto Sans JP', YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
  color: #000;
  box-shadow: 0 0 0 1000px #ececec inset !important;
}
input[type="text"]:-webkit-autofill {
	box-shadow: 0 0 0px 1000px #ececec inset;
  border: #ececec 1px solid;
  background: #ececec !important;
  -webkit-text-fill-color: #000 !important;
}
@media only screen and (max-width: 782px) {
  input[type="date"],
  input[type="time"],
  input[type="datetime-local"],
  input[type="week"],
  input[type="month"],
  input[type="text"],
  input[type="email"],
  input[type="url"],
  input[type="password"],
  input[type="search"],
  input[type="tel"],
  input[type="number"],
  textarea {
    padding: 1.6rem 1.8rem;
    font-size: 1.2rem;
  }
}
input[type="date"]:focus,
input[type="time"]:focus,
input[type="datetime-local"]:focus,
input[type="week"]:focus,
input[type="month"]:focus,
input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="tel"]:focus,
input[type="number"]:focus,
textarea:focus {
	border-color: #ececec;
	color: #000;
	outline: 0;box-shadow: 0 0 5px 5px rgba(255,255,255,0.05);
}



.cp_ipselect {
	overflow: hidden;
	width: 90%;
	margin: 0;
  position: relative;
  border-radius: 2px;
	background: #ffffff;
}
#maintitle .cp_ipselect,
#result-header .cp_ipselect,
#maintitle-scene .cp_ipselect { width: 200px;}
.cp_ipselect select {
	width: 100%;
	padding-right: 1em;
	cursor: pointer;
	text-indent: 0.01px;
	text-overflow: ellipsis;
	border: none;
	outline: none;
	background: transparent;
	background-image: none;
	box-shadow: none;
	-webkit-appearance: none;
	appearance: none;
}
.cp_ipselect select::-ms-expand {
  display: none;
}
#result-header .cp_ipselect,
.cp_ipselect.cp_sl02 { border: 1px solid #d2d2d2;}

.cp_ipselect::before {
	position: absolute;
	top: 1em;
	right: 0.9em;
	width: 0;
	height: 0;
	padding: 0;
	content: '';
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
	border-top: 6px solid #666666;
	pointer-events: none;
}

input[type="checkbox"] {
  /*transform: scale(1.5);*/
  box-shadow: none;
  border: #d9d9d9 1px solid;
  margin-top: 0;
}
input[name="check_must"] {
  opacity: 0;
}
p.check label { display: flex; align-items: center; justify-content: center; flex-wrap: wrap; color: #ff490f;}
p.check label a { color: #ff490f;}
i.icon-check {
  width: 25px;
  height: 25px;
  box-sizing: border-box;
  position: relative;
  background: #fff;
  border: #d9d9d9 2px solid;
  border-radius: 5px;
  display: inline-block;
  margin-right: 20px;
}
input:checked + i.icon-check::before {
  content: "";
  width: 11px;
  height: 22px;
  border-right: #ff490f 5px solid;
  border-bottom: #ff490f 5px solid;
  transform: rotate(45deg);
  left: 8px;
  top: -11px;
  display: block;
  z-index: 2;
  position: absolute;
}
input.err + i.icon-check {
  background-color: #fff;
	border-color: #ff490f;
}
@media only screen and (max-width: 782px) {
	input[type="radio"] {
	  margin-top: 0;
	}
  td label { padding-top: 0.3rem; padding-bottom: 0.3rem; align-items: center;}
  i.icon-check { transform: scale(0.8);}
}
input::placeholder {
  color: #666666;
}

/* IE */
input:-ms-input-placeholder {
  color: #666666;
}

/* Edge */
input::-ms-input-placeholder {
  color: #666666;
}
input:focus::placeholder {
  color: #9c9c9c;
}

/* IE */
input:focus:-ms-input-placeholder {
  color: #9c9c9c;
}

/* Edge */
input:focus::-ms-input-placeholder {
  color: #9c9c9c;
}

input[type="text"].err,
input[type="email"].err,
textarea.err {
	background-color: #6a354c;
	color: #000;
	border: #ff490f 3px solid;
}




input[name='tel'],input[name='fax'] { width: 20rem;}
input[name='mail_must'],input[name='mail_confirm'] { width: 40rem;}
input[name='zip'] { width: 15rem; margin-left: 1rem;}
input[name='address'] { margin-top: 0.7rem;}
input + span { margin-left: 10px;}
