@charset "utf-8";

/***************************************************
 * apply
 */

.dot {
  padding-left: 1.2em !important;
  position: relative;
}

.dot::before {
  content: "・";
  position: absolute;
  left: 0;
}

.pos_error {
  background-color: #ffe6e6;
}

p.est-title {
  margin: 0;
  font-weight: bold;
  margin-top: 30px;
  margin-bottom: 10px;
}
table.estimate {
  width: 100%;
  table-layout: fixed;
  border-collapse: collapse;
  border-top: 2px solid #d0dce4;
  border-bottom: 1px solid #d0dce4;
  font-size: 14px;
}

table.estimate tr:not(.sub),
table.estimate tr.sub.first {
  border-top: 1px solid #d0dce4;
}

table.estimate th,
table.estimate td {
  padding: 16px 0px;
  font-weight: normal;
  text-align: left;
  vertical-align: top;
}

table.estimate th {
  padding-left: 20px;
  width: 350px;
}

table.estimate td span.qty {
  text-align: right;
  padding-right: 30px;
}

table.estimate tr.sub span {
  display: inline-block;
  width: 50%;
}

table.estimate tr.sub span.s_name .-opt {
  padding-left: 1em;
}

table.estimate tr.sub span:nth-child(1) {
  width: 62%;
}

table.estimate tr.sub span:nth-child(1) span {
  width: auto;
}

table.estimate tr.sub span:nth-child(2) {
  width: 38%;
}

table.estimate tr.sub span:nth-child(2) span {
  width: auto;
  font-size: 100%;
}

table.estimate tr.sub.monthly span.label span,
table.estimate tr.sub.cp span.label span{
  width: auto;
  font-size: 100%;
}

table.estimate tr.sub.first td {
  padding-top: 16px;
}


table.estimate tr.sub.last td {
  padding-bottom: 16px;
}

table.estimate tr.total th {
  vertical-align: middle;
}

table.estimate tr.total td {
  font-weight: bold;
  font-size: 24px;
  vertical-align: middle;
}

table.estimate span {
  font-size: 90%;
}

.apply-ttl {
  font-weight: bold;
  font-size: 28px;
  text-align: center;
  margin-bottom: 30px;
  margin-top: 10px;
}

.legal.notes {
  margin-bottom: 20px;
}

/*override*/
.important,.minus {
    color: red !important
}

section.form > .item .input .notes.top {
    margin-left: 0;
    margin-bottom: 6px;
}

section.form > .item .input .notes.top.dot {
    margin-bottom: 0;
}

section.form > .item .input .notes.top.dot.bottom {
    margin-bottom: 6px;
}


section.form .item.-lantype {
  margin-bottom: 50px;
}

section.form > .item.-startdate {
  margin-top: 40px;
}

section.form > .item.-startdate .input .error_message {
    padding: 10px 0 0 0;
}

.item.-startdate select {
    width: 140px;
}

.item.-startdate select + span {
    margin-left: 0.5em;
}

.item.-startdate .input {
    display: inline-block;
    vertical-align: top;
}

section.form > .item.-startdate .notes {
  font-size: 12px;
  margin-left: 30px;
  padding: 5px;
  margin-bottom: 0;
}

.asterisk.txt-sm {
  font-size: 12px;
  margin: 0;
  margin-bottom: 5px;
}

input.floor {
  width: 110px;
}

.send_unit input.floor {
  width: 280px;
}

section.form > .item .notes + .notes {
    margin-top: 0;
}

section.form > .item.-address .wrap {
    flex: 1 1 0%;
    padding-right: 10px;
}

section.form > .item.-address .wrap .input .inner {
    display: flex;
    align-items: center;
    margin-bottom: 20px;
}

section.form > .item.-address .wrap .input .inner .label-sm {
    flex: 0 1 140px;
}

section.form > .item.-address .wrap .input .inner .label-sm::after {
    content: "*";
    color: #f74141;
    margin-left: 0.1em;
}

section.form > .item.-address .wrap .input .inner .input-sm {
    flex: 1 1 0%;
}

section.form > .item .postal input {
  width: 130px;
}

section.form .item.-info_select label {
    border: 1px solid #d0dce4;
    padding: 10px 12px;
    border-radius: 6px;
    display: inline-block;
}

section.form > .item .label-title {
  flex: 0 1 350px;
  height: 50px;
  line-height: 50px;
  padding-left: 20px;
  font-size: 15px;
}

section.form > .item.required .label-title::after {
  content: "*";
  color: #f74141;
  margin-left: 0.1em;
}

section.form > .item .-multi {
    flex: auto;
    margin-bottom: 20px;
}

section.form > .item .-multi .wrap {
    display: flex;
    flex: auto;
    align-items: center;
    padding-right: 0;
}

section.form > .item .-multi .wrap .label-sm {
    flex: 0 0 170px;
}

section.form > .item .-multi .wrap .label-sm::after {
    content: "*";
    color: #f74141;
    margin-left: 0.1em;
}

section.form > .item .-multi .wrap .label-sm.no_requ::after {
    display: none;
}

section.form > .item .-multi .wrap .label-sm.label {
    padding-left: 0;
}

section.form .item.-info_select label:not(:last-child) {
    margin-right: 10px;
}

section.form .item.-info_select .wrapper {
    flex: 1 1 0%;
    padding-right: 10px;
}

section.form .item.-info_select .wrapper .input {
    display: inline-block;
    vertical-align: top;
}


section.form > .item.-info_select .notes {
  font-size: 12px;
  margin-left: 30px;
  padding: 5px;
  margin-bottom: 0;
}


section.legal .container + .container {
    margin-top: 30px;
}

section.form > .item.-off {
    display: none;
}

.icon-link:not([target="_blank"]) {
  /*  display: flex;*/
  padding-left: 20px;
  position: relative;
}

.icon-link:not([target="_blank"])::before {
  content: '';
  display: inline-block;
  width: 20px;
  height: 20px;
  border-radius: 10px;
  background: #333 url(../img/icon_arrow.png) no-repeat center/cover;
  background-size: 10px 10px;
  margin-right: 5px;
  transform: scale(.8);
  position: absolute;
  top: -2px;
  left: 0;
}

.icon-link[target="_blank"] {
  /*  display: flex;*/
  padding-right: 25px;
  position: relative;
}

.icon-link[target="_blank"]::after {
  content: '';
  display: inline-block;
  width: 16px;
  height: 16px;
  background: url(../img/icon_blank.png) no-repeat center/contain;
  margin-right: 5px;
  position: absolute;
  top: 0px;
  right: 0;
}


/*送付先部分　CSS追加*/


section.form .send_unit .item {
  display: flex;
  margin-bottom: 20px;
}

section.form .send_unit .item .label {
  flex: 0 1 350px;
  height: 50px;
  line-height: 50px;
  padding-left: 20px;
  font-size: 15px;
}

section.form .send_unit .item.required .label::after {
  content: "*";
  color: #f74141;
  margin-left: 0.1em;
}

section.form .send_unit .item .input,
section.form .send_unit .item .value {
  flex: 1 1 0%;
  padding-right: 10px;
}

section.form .send_unit .item .input.flex {
  display: flex;
  flex-wrap: wrap;
}

section.form .send_unit .item .value {
  line-height: 50px;
}

section.form .send_unit .item .value.multiline {
  line-height: 1.4;
  margin-top: 12px;
  overflow-wrap: anywhere;
}

section.form .send_unit .item .input .error_message {
  color: #ff3c28;
  font-size: 13px;
  padding: 10px 30px 0 30px;
  width: 100%;
}

section.form .send_unit .item .input .notes {
  font-size: 12px;
  margin-left: 30px;
  padding: 5px;
  margin-bottom: 0;
}

section.form .send_unit .item .input .notes.top {
  margin-top: 0;
}

section.form .send_unit .item .input .notes.red {
  color: #f74141;
}

section.form .send_unit .item .input .send_numerror {
  margin-top: 5px;
  margin-left: 0;
}

section.form .send_unit .item .input.flex .notes.asterisk {
  margin: 12px 0 0 10px;
}

section.form .send_unit .item.postal input {
  width: 130px;
}

section.form .send_unit .item.name input {
  width: 195px;
  margin-right: 10px;
}

section.form .send_unit .item.quantity .input {
  margin-left: 20px;
  font-size: 15px;
}


section.form .send_unit .item.quantity .input input {
  width: 270px;
  margin-right: 30px;
}

section.form .send_unit .item.date .input .suffix {
  margin: 0 5px;
}

section.form .send_unit .item.date .input select {
  width: 80px;
}

section.form .send_unit .item.date .input select.year {
  width: 100px;
}

section.form .send_unit .item.plan > .input > .wrapper,
section.form .send_unit .item.plan-option > .input > .wrapper {
  display: flex;
  align-items: center;
  margin-left: 20px;
}

section.form .send_unit .item.plan > .input .name,
section.form .send_unit .item.plan-option > .input .name {
  flex: 1 0 0%;
}

section.form .send_unit .item.plan > .input .price,
section.form .send_unit .item.plan-option > .input .price {
  flex: 0 1 270px;
  font-size: 14px;
}

section.form .send_unit .item.plan > .input .price:last-child,
section.form .send_unit .item.plan-option > .input .price:last-child {
  margin-right: 270px;
}

section.form .send_unit .item.plan > .input .ordernum,
section.form .send_unit .item.plan-option > .input .ordernum {
  flex: 0 0 270px;
}

section.form .send_unit .item input[type=radio] {
  display: none;
}

section.form .send_unit .item input[type=radio] + span {
  position: relative;
  padding-left: 30px;
}

section.form .send_unit .item input[type=radio] + span::before {
  content: '';
  display: block;
  width: 22px;
  height: 22px;
  background-image: url(../../common/img/radio.png);
  position: absolute;
  top: 50%;
  left: 0;
  margin-top: -11px;
}

section.form .send_unit .item input[type=radio]:checked + span::before {
  background-image: url(../../common/img/radio_checked.png);
}

section.form .send_unit .item input[type=checkbox] {
  display: none;
}

section.form .send_unit .item input[type=checkbox] + span {
  display: inline-block;
  position: relative;
  padding-left: 30px;
}

section.form .send_unit .item input[type=checkbox] + span::before {
  content: '';
  display: block;
  width: 22px;
  height: 22px;
  background-image: url(../img/checkbox.png);
  position: absolute;
  top: 50%;
  left: 0;
  margin-top: -11px;
}

section.form .send_unit .item input[type=checkbox]:checked + span::before {
  background-image: url(../img/checkbox_checked.png);
}


section.form .send_unit .item .input .notes.top {
    margin-left: 0;
    margin-bottom: 6px;
}

section.form .send_unit .item .input .notes.top.dot {
    margin-bottom: 0;
}

section.form .send_unit .item .input .notes.top.dot.bottom {
    margin-bottom: 6px;
}

section.form .send_unit .item.-startdate .input .error_message {
    padding: 10px 0 0 0;
}


.item.-startdate select {
    width: 140px;
}

.item.-startdate select + span {
    margin-left: 0.5em;
}

.item.-startdate .input {
    display: inline-block;
    vertical-align: top;
}

section.form .send_unit .item.-startdate .notes {
  font-size: 12px;
  margin-left: 30px;
  padding: 5px;
  margin-bottom: 0;
}

section.form .send_unit .item .notes + .notes {
    margin-top: 0;
}

section.form .send_unit .item.-address .wrap {
    flex: 1 1 0%;
    padding-right: 10px;
}


section.form .send_unit .item.-address .wrap .input .inner {
    display: flex;
    align-items: center;
    margin-bottom: 20px;
}

section.form .send_unit .item.-address .wrap .input .inner .label-sm {
    flex: 0 1 140px;
}

section.form .send_unit .item.-address .wrap .input .inner .label-sm::after {
    content: "*";
    color: #f74141;
    margin-left: 0.1em;
}

section.form .send_unit .item.-address .wrap .input .inner .input-sm {
    flex: 1 1 0%;
}

section.form .send_unit .item .postal input {
  width: 130px;
}

section.form .item.-info_select label,
section.form .item.-radio label,
section.form .send_unit .item .input label{
    border: 1px solid #d0dce4;
    padding: 10px 12px;
    border-radius: 6px;
    display: inline-block;
}

section.form label + label {
  margin-left: 10px;
}

@media only screen and (max-width: 599px) {
    section.form label + label {
      margin-left: 0;
    }
}

section.form .send_unit .item .label-title {
  flex: 0 1 350px;
  height: 50px;
  line-height: 50px;
  padding-left: 20px;
  font-size: 15px;
}

section.form .send_unit .item.required .label-title::after {
  content: "*";
  color: #f74141;
  margin-left: 0.1em;
}

section.form .send_unit .item .-multi {
    flex: auto;
    margin-bottom: 20px;
}

section.form .send_unit .item .-multi .wrap {
    display: flex;
    flex: auto;
    align-items: center;
    padding-right: 0;
}

section.form .send_unit .item .-multi .wrap .inner {
  width: 100%;
}

section.form .send_unit .item .-multi .wrap .inner .input + .input {
  margin-top: 20px;
}

section.form .send_unit .item .-multi .wrap .label-sm {
    flex: 0 0 170px;
}


section.form > .item.contact .-multi .wrap .label-sm {
  flex: 0 0 195px;
}

section.form .send_unit .item .-multi .wrap .label-sm::after {
    content: "*";
    color: #f74141;
    margin-left: 0.1em;
}

section.form .send_unit .item .-multi .wrap .label-sm.no_requ::after {
    display: none;
}

section.form .send_unit .item .-multi .wrap .label-sm.label {
    padding-left: 0;
}


/*送付先の詳細*/

#sendnum {
  font-size: 24px;
  font-weight: bold;
  padding: 0 6px;
  color: #f74141;
}

#sendtoral {
  font-size: 24px;
  font-weight: bold;
  padding: 0 6px;
  color: #f74141;
}

.send_unit {
  margin-top: 40px;
}

.send_unit.base {
  display: none;
}

.send_unit.base.show {
  display: block;
}


.send_unit > h3 {
  background-color: #666;
  color: #FFF;
  font-size: 16px;
  padding: 12px 10px;
  margin: 0;
  display: flex;
  justify-content:space-between;
  align-items: center;
  line-height: 1.2;
  border-radius: 4px;
  border-bottom: none;
}

.send_unit.on > h3 {
  border-radius: 4px 4px 0 0;
}
 
.send_unit > h3:hover {
  cursor: pointer;
}

.send_unit > h3 > .btn {
  background-color: #FFF;
  text-align: center;
  color: #4579e8;
  padding: 6px;
  font-size: 13px;
  border-radius: 4px;
  border: 1px solid #CCC;
}

.send_unit > h3 > .btn .edit { display: inline; }
.send_unit > h3 > .btn .close { display: none; }
.send_unit.on > h3 > .btn .edit { display: none; }
.send_unit.on > h3 > .btn .close { display: inline; }

.send_unit > h3 > .btn .icon {
  font-size: 15px;
  padding-left: 0.2em;
}

.send_unit > .content {
  padding-top: 20px;
  border: 1px solid #CCC;
  border-top: none;
  display: none;
}

.send_unit.on > .content {
  display: block;
}

section.form .send_unit .item.send_count .input input {
  width: 134px;
}

.send_intro { text-align: center; }

.sm { font-size: 13px;}

.send_select {
  display: flex;
  justify-content: center;
  margin-top: 40px;
}

.send_select > .item {
  display: flex;
  align-items: center;
}

.send_select > .item .label {
  font-size: 15px;
  padding-right: 20px;
}

.send_select > .item.required .label::after {
  content: "*";
  color: #f74141;
  margin-left: 0.1em;
}

.send_select > .item .input {
  padding-right: 20px;
}


.num_error {
  text-align: center;
  font-weight: bold;
  color: #f74141;
  margin-top: 30px;
}

.send_unit.clone.on {
  display: block;
}

.input.send_error .error_message {
    color: #ff3c28;
    font-size: 13px;
    padding: 10px 30px 0 30px;
    padding: 0;
    margin-top: 20px;
    text-align: center;
    width: 100%;
}

.postal_error {
  color: #ff3c28;
  font-size: 13px;
  padding: 0;
  width: 100%;
  margin-bottom: 20px;
}


/*緊急連絡先の詳細*/

.-emergency > .intro {
  margin-bottom: 40px;
}

@media only screen and (min-width: 600px) {
    section.form > .item .input.-phone input,
    section.form .send_unit .item .input.-phone input{
        width: 130px
    }
}
@media only screen and (max-width: 599px) {
    section.form > .item .input.-phone input,
    section.form .send_unit .item .input.-phone input{
        width: 76px
    }
}



/* - 2023 チェック項目追加
------------------------------------------------------------ */

.apply_c_contnt {
  margin-top: 40px;
}

.check_block {
  background-color: #f7f7f7;
  padding: 20px;
  margin-top: 40px;
}

.check_block .title {
  font-size: 16px;
  font-weight: bold;
}


.apply_check {
  margin: 0;
  padding: 0;
  margin-top: 25px;
}

.apply_check li {
  list-style: none;
}

.apply_check li + li {
  margin-top: 20px;
}

.apply_check li input[type="checkbox"] {
  display: none;
}

.apply_check li span {
  /*padding-left: 20px;*/
  position: relative;
  /*margin-right: 20px;*/
}

.apply_check li span.inner {
  display: table;
}

.apply_check li span.inner span.box {
  display: table-cell;
  width: 22px;
  vertical-align: top;
}

.apply_check li span.inner span.txt {
  display: table-cell;
  vertical-align: top;
  font-size: 14px;
  font-weight: bold;
}

.apply_check li span.inner span.txt .opt {
  display: block;
  font-weight: normal;
  font-size: 13px;
  margin-top: 7px;
  text-indent: -1em;
  padding-left: 1em;
}

.apply_check li span.inner span.box::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: -8px;
  width: 22px;
  height: 22px;
  background-image: url(../../common/img/cb.png);
}

.apply_check li input:checked + span.inner span.box::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: -8px;
  width: 22px;
  height: 22px;
  background-image: url(../../common/img/cb.png);
  background-position: 0px -22px;
}



.flowImg {
  text-align: center;
  margin-top: 40px;
}

.flowImg img {
  max-width: 800px;
  border: 1px solid #DDD;
}

p.-caption {
  margin-bottom: 40px;
  font-size: 14px;
}

.section_top p.-caption {
  padding-left: 20px;
}

@media only screen and (max-width: 599px) {

  .flowImg{
    overflow-x: scroll;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 10px;
    margin-bottom: 20px;
  }

  .flowImg img{
    max-width: 680px;
    width: auto;
    height: auto;
    display: block;
  }
  
  .section_top p.-caption {
    padding-left: 0;
  }

}


.-operator h3 {
  border-bottom: 1px dotted #CCC;
  font-size: 18px;
  padding-bottom: 4px;
}

.-operator .item + h3 {
  margin-top: 40px;
}

.pdfLink {
  text-align: center;
  font-size: 14px;
  margin-top: 40px;
}

.pdfLink section.control.sub {
  justify-content: center;
}

.billnum_wrap {
  display: flex;
  align-items: baseline;
}

.billnum_wrap .-head{
  padding-right: 10px;
}

