@charset "UTF-8";
/* [ variable ]
-------------------------------------------------*/
/* element */
/* font */
/* [ font style ]
-------------------------------------------------*/
@import url(https://fonts.googleapis.com/earlyaccess/notosansjp.css);


@font-face {
  font-family: 'NotoSansJPRegular';
  src: url('../fonts/NotoSansJP-Regular.otf');
}

@font-face {
  font-family: 'NotoSerifJPBold';
  src: url('../fonts/NotoSerifJP-Bold.otf');
}

/* [ opacity ]
-------------------------------------------------*/
/* [ display style ]
-------------------------------------------------*/
/* [ easing style ]
-------------------------------------------------*/
/* [ Hover Motion style ]
-------------------------------------------------*/
/* [ icon style ]
-------------------------------------------------*/
/* [ form parts ]
-------------------------------------------------*/
.display_text {
  display: none; }
  .display_text.show {
    display: block; }

.display_text2 {
  display: none; }
  .display_text2.show {
    display: block; }

.display_text3 {
  display: none; }
  .display_text3.show {
    display: block; }

.display_text3_3 {
  display: none; }
  .display_text3_3.show {
    display: block; }

.display_text4 {
  display: none; }
  .display_text4.show {
    display: block; }

.display_text5 {
  display: none; }
  .display_text5.show {
    display: block; }

.display_text6 {
  display: none; }
.display_text6.show {
  display: block; }

.cssdisabled {
  pointer-events: none;
  opacity: 0.6; }

.hide {
  display: none;
}

@media only screen and (min-width: 751px) {
  #step1 {
    color: #3c3931; }
  #step1 .form_dl dt {
    font-size: 16px;
    font-weight: bold;
    padding: 20px 0 10px; }
  #step1 .form_dl .plan_text {
    display: block;
    width: 100%;
    height: 50px;
    position: relative;
    background: #e8e8e5;
    border-radius: 2px;
    box-sizing: border-box;
    padding: 0 25px;
    line-height: 50px;
    font-size: 14px;
    cursor: pointer;

    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
  }
  #step1 .form_dl .plan_text:before {
    content: '';
    display: block;
    position: absolute;
    right: 15px;
    top: 50%;
    width: 15px;
    background: #42332f;
    height: 1px; }
  #step1 .form_dl .plan_text:after {
    content: '';
    display: block;
    position: absolute;
    right: 22px;
    top: 50%;
    width: 1px;
    background: #42332f;
    height: 15px;
    margin-top: -7px; }
  #step1 .form_dl .plan_text.active:after {
    display: none; }
  #step1 .form_dl ul.plan_list {
    background: #f2f2f0;
    border-radius: 2px;
    overflow: hidden;
    height: 0;
    -webkit-transition: height 0.2s cubic-bezier(0.42, 0, 1, 1);
    transition: height 0.2s cubic-bezier(0.42, 0, 1, 1); }
  #step1 .form_dl ul.plan_list.active {
    height: 100%/*1440px*/; }
  #step1 .form_dl ul.plan_list:after {
    display: block;
    content: '';
    clear: both; }
  #step1 .form_dl ul.plan_list li {
    width: 100%;
    height: 95px;
    padding: 7px 10px 8px;
    box-sizing: border-box;
    border-bottom: 1px solid #dcdcdc;
    position: relative;
    cursor: pointer; }
  /*#step1 .form_dl ul.plan_list li:before {
    content: '';
    display: block;
    position: absolute;
    right: 16px;
    top: 0;
    width: 6px;
    background: url(../images/icon_arrow_plan.svg) no-repeat center center;
    background-size: 6px auto;
    height: 95px; }*/
  #step1 .form_dl ul.plan_list li.active:after {
    display: block;
    content: '';
    background: rgba(184, 132, 57, 0.6) url(../images/plan_select.png) no-repeat center center;
    background-size: 36px auto;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0; }
  #step1 .form_dl ul.plan_list li:last-child {
    border-bottom: none; }
  #step1 .form_dl ul.plan_list li .image .text-plan {
    display: block;
    line-height: 12px;
    font-size: 14px;
    padding: 5px 0;
    text-align: center;
  }
  #step1 .form_dl ul.plan_list li .text {
    /*font-size: 16px;
        display: inline-block;
        padding: 10px 0;
        font-weight: bold;
        line-height: 25px;*/
    vertical-align: middle;
    position: absolute;
    left: 90px;
    top: 35px;
    right: 10px;
    bottom: 5px;
    font-size: 14px;
    line-height: 20px;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4;
    overflow: hidden;
    font-family: "NotoSansJPRegular";
  }
  #step1 .form_dl ul.plan_list li .text-name {
    vertical-align: middle;
    position: absolute;
    left: 90px;
    top: 5px;
    right: 10px;
    font-size: 10pt;
    line-height: 20px;
    font-weight: bold;
    font-family: "NotoSerifJPBold";
  }
  #step1 .form_dl ul.plan_list li .text-name-over {
    vertical-align: middle;
    position: absolute;
    left: 90px;
    top: 5px;
    right: 10px;
    font-size: 9pt;
    line-height: 20px;
    font-weight: bold;
    font-family: "NotoSerifJPBold";
  }
  #step1 .form_dl ul.plan_list li .text-name-over-15 {
    vertical-align: middle;
    position: absolute;
    left: 90px;
    top: 5px;
    right: 10px;
    font-size: 7pt;
    line-height: 20px;
    font-weight: bold;
    font-family: "NotoSerifJPBold";
  }
  #step1 .form_dl ul.plan_list li .text-name-sub {
    font-size: 8pt;
  }
  #step1 .form_dl ul.plan_list li .hr-name {
    display: block;
    vertical-align: middle;
    position: absolute;
    left: 90px;
    top: 28px;
    right: 10px;
    font-size: 12pt;
    line-height: 20px;
  }
  #step1 .form_dl ul.plan_list li .image {
    width: 75px;
    height: 75px;
    display: inline-block;
    vertical-align: middle;
    margin-right: 20px; }
  #step1 .form_dl ul.plan_list li .image img {
    width: 100%; }
    #step1 .form_table.input th {
      font-size: 18px;
      font-weight: bold;
      width: 210px; }
    #step1 .form_table.input .validate_section {
      opacity: 0.5;
      pointer-events: none;
      -moz-pointer-events: none;
      -webkit-pointer-events: none;
      -ms-pointer-events: none; }
      #step1 .form_table.input .validate_section.active {
        opacity: 1;
        pointer-events: auto;
        -moz-pointer-events: auto;
        -webkit-pointer-events: auto;
        -ms-pointer-events: auto; }
    #step1 .select {
      display: inline-block;
      margin-right: 25px;
      width: 300px;
      height: 50px;
      position: relative;
      background: #f2f2f0;
      border: 1px solid #e9e8e1;
      border-radius: 2px;
      box-sizing: border-box; }
      #step1 .select:after {
        content: '';
        display: block;
        position: absolute;
        right: 19px;
        top: 0;
        width: 11px;
        background: url(../images/icon_select.svg) no-repeat center center;
        background-size: contain;
        height: 48px;
        pointer-events: none; }
      #step1 .select .display {
        font-size: 14px;
        line-height: 50px;
        padding-left: 20px; }
      #step1 .select select {
        display: block;
        position: absolute;
        left: 0;
        top: 0;
        width: 300px;
        height: 50px;
        border: none;
        padding: 0;
        margin: 0;
        opacity: 0; }
    #step1 .calendar_text {
      display: block;
      width: 300px;
      height: 50px;
      position: relative;
      background: #f2f2f0;
      border: 1px solid #e9e8e1;
      border-radius: 2px;
      box-sizing: border-box;
      padding: 0 20px;
      line-height: 50px;
      font-size: 14px;
      cursor: pointer; }
      #step1 .calendar_text:after {
        content: '';
        display: block;
        position: absolute;
        right: 14px;
        top: 0;
        width: 21px;
        background: url(../images/icon_calender.svg) no-repeat center center;
        background-size: contain;
        height: 48px; }
    #step1 .time_text {
      display: block;
      width: 300px;
      height: 50px;
      position: relative;
      background: #f2f2f0;
      border: 1px solid #e9e8e1;
      border-radius: 2px;
      box-sizing: border-box;
      padding: 0 20px;
      line-height: 50px;
      font-size: 14px;
      cursor: pointer; }
      #step1 .time_text:after {
        content: '';
        display: block;
        position: absolute;
        right: 14px;
        top: 0;
        width: 19px;
        background: url(../images/icon_time.svg) no-repeat center center;
        background-size: contain;
        height: 48px; }
    #step1 p.notice {
      margin-top: 15px;
      color: #716b5b;
      font-size: 14px;
      line-height: 24px; }

  #step4_modal .modal_bg {
    background: rgba(0, 0, 0, 0.4);
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    z-index: 500;
    display: none; }

  #step3_modal .modal_bg {
    background: rgba(0, 0, 0, 0.4);
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    z-index: 500;
    display: none; }

  #step2_modal .modal_bg {
    background: rgba(0, 0, 0, 0.4);
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    z-index: 500;
    display: none; }

  #step1_modal .modal_bg {
    background: rgba(0, 0, 0, 0.4);
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    z-index: 500;
    display: none; }
  #step1_modal .modal_content {
    display: none;
    width: 590px;
    padding-top: 90px;
    position: absolute;
    left: 50%;
    margin-left: -295px;
    z-index: 1000;
    top: 326px; }
    #step1_modal .modal_content .icon_close {
      position: absolute;
      right: 0;
      top: 0;
      width: 70px;
      height: 70px;
      background: #343c48;
      cursor: pointer; }
      #step1_modal .modal_content .icon_close:before {
        content: '';
        display: block;
        position: absolute;
        width: 34px;
        height: 2px;
        background: #fff;
        left: 50%;
        margin-left: -17px;
        top: 50%;
        margin-top: -1px;
        transform: rotate(45deg);
        -webkit-transform: rotate(45deg);
        -moz-transform: rotate(45deg);
        -o-transform: rotate(45deg);
        -ms-transform: rotate(45deg); }
      #step1_modal .modal_content .icon_close:after {
        content: '';
        display: block;
        position: absolute;
        width: 34px;
        height: 2px;
        background: #fff;
        left: 50%;
        margin-left: -17px;
        top: 50%;
        margin-top: -1px;
        transform: rotate(-45deg);
        -webkit-transform: rotate(-45deg);
        -moz-transform: rotate(-45deg);
        -o-transform: rotate(-45deg);
        -ms-transform: rotate(-45deg); }
    #step1_modal .modal_content .modal_inner {
      border-radius: 4px;
      background: #fff;
      padding: 40px 50px; }
    #step1_modal .modal_bg_alert {
        background: rgba(0, 0, 0, 0.4);
        position: fixed;
        top: 0;
        right: 0;
        left: 0;
        bottom: 0;
        z-index: 1001;
        display: none; }
  #step1_modal .modal_content_alert {
    display: none;
    width: 380px;
    position: absolute;
    left: 30%;
    z-index: 1002;
  }
  #step1_modal .modal_content_alert .icon_close_alert {
    position: absolute;
    right: 0;
    width: 40px;
    height: 40px;
    background: #343c48;
    cursor: pointer; }
  #step1_modal .modal_content_alert .icon_close_alert:before {
    content: '';
    display: block;
    position: absolute;
    width: 34px;
    height: 2px;
    background: #fff;
    left: 50%;
    margin-left: -17px;
    top: 50%;
    margin-top: -1px;
    transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    -o-transform: rotate(45deg);
    -ms-transform: rotate(45deg); }
  #step1_modal .modal_content_alert .icon_close_alert:after {
    content: '';
    display: block;
    position: absolute;
    width: 34px;
    height: 2px;
    background: #fff;
    left: 50%;
    margin-left: -17px;
    top: 50%;
    margin-top: -1px;
    transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    -o-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg); }
  #step1_modal .modal_content_alert .modal_inner {
    border-radius: 4px;
    background: #FBE5D6;
    padding: 40px 50px; }

  #step1_modal .calendar_area {
    position: relative; }
    #step1_modal .calendar_area .prev {
      width: 20px;
      height: 30px;
      display: block;
      position: absolute;
      text-indent: -9999px;
      left: 0;
      top: 0;
      background: url(../images/icon_arrow_black_left.svg) no-repeat center left;
      background-size: 14px auto; }
    #step1_modal .calendar_area .next {
      width: 20px;
      height: 30px;
      display: block;
      position: absolute;
      text-indent: -9999px;
      right: 0;
      top: 0;
      background: url(../images/icon_arrow_black_right.svg) no-repeat center right;
      background-size: 14px auto; }
    #step1_modal .calendar_area .date_title {
      text-align: center;
      font-size: 20px;
      line-height: 30px;
      font-weight: bold; }
  #step1_modal .calendar_area .date_subtitle {
      text-align: center;
      font-size: 12.5px;
      line-height: 1em;
      font-weight: bold;}
    #step1_modal .calendar_area table.calendar {
      margin-top: 20px;
      margin-bottom: 25px;
      width: 100%; }
      #step1_modal .calendar_area table.calendar th, #step1_modal .calendar_area table.calendar td {
        border: 1px solid #bfbcb8;
        width: 14.285%;
        line-height: 20px;
        padding: 10px;
        text-align: center;
        font-size: 16px;
        vertical-align: top; }
      #step1_modal .calendar_area table.calendar th {
        background: #d3d3d3;
        font-weight: bold; }
        #step1_modal .calendar_area table.calendar th.sat {
          background: #d9f9ff; }
        #step1_modal .calendar_area table.calendar th.sun {
          background: #ffd9d9; }
      #step1_modal .calendar_area table.calendar td.disabled {
        background: #ececec; }
      #step1_modal .calendar_area table.calendar td.base {
        background: #ffffce; }
      #step1_modal .calendar_area table.calendar .btn {
        margin-top: 7px;
        height: 30px;
        line-height: 30px; }
        #step1_modal .calendar_area table.calendar .btn > * {
          height: 30px;
          border-radius: 2px;
          border-bottom-width: 2px;
          border-bottom-color: #d2d2d2; }
        #step1_modal .calendar_area table.calendar .btn.circle > * {
          background: #ececec url(../images/icon_circle.svg) no-repeat center center;
          background-size: 18px auto; }
        #step1_modal .calendar_area table.calendar .btn.square > * {
          background: #ececec url(../images/icon_square.svg) no-repeat center center;
          background-size: 18px auto; }
        #step1_modal .calendar_area table.calendar .btn.triangle > * {
          background: #ececec url(../images/icon_triangle.svg) no-repeat center center;
          background-size: 19px auto; }
        #step1_modal .calendar_area table.calendar .btn.disabled:hover {
          opacity: 1; }
        #step1_modal .calendar_area table.calendar .btn.disabled > * {
          cursor: default;
          background: #d2d2d2 url(../images/icon_disabled.svg) no-repeat center center;
          background-size: 17px auto; }
  #step1_modal .time_area .date_title {
    text-align: center;
    font-size: 20px;
    line-height: 30px;
    font-weight: bold; }
  #step1_modal .time_area .date_subtitle {
    text-align: center;
    font-size: 12.5px;
    line-height: 1em;
    font-weight: bold;}
  #step1_modal .time_area .timetable {
    margin-top: 20px;
    margin-bottom: 25px;
    width: 100%; }
    #step1_modal .time_area .timetable th, #step1_modal .time_area .timetable td {
      border: 1px solid #bfbcb8;
      width: 50%;
      line-height: 20px;
      text-align: center;
      font-size: 16px;
      vertical-align: middle; }
    #step1_modal .time_area .timetable th {
      padding: 10px 22px;
      background: #d3d3d3;
      font-weight: bold; }
    #step1_modal .time_area .timetable td {
      padding: 5px 22px; }
      #step1_modal .time_area .timetable td.time {
        background: #f1f1f0; }
      #step1_modal .time_area .timetable td.base {
        background: #ffffce; }
    #step1_modal .time_area .timetable .btn {
      height: 30px;
      line-height: 30px; }
      #step1_modal .time_area .timetable .btn > * {
        height: 30px;
        border-radius: 2px;
        border-bottom-width: 2px;
        border-bottom-color: #d2d2d2; }
      #step1_modal .time_area .timetable .btn.circle > * {
        background: #ececec url(../images/icon_circle.svg) no-repeat center center;
        background-size: 18px auto; }
      #step1_modal .time_area .timetable .btn.triangle > * {
        background: #ececec url(../images/icon_triangle.svg) no-repeat center center;
        background-size: 19px auto; }
      #step1_modal .time_area .timetable .btn.disabled:hover {
        opacity: 1; }
      #step1_modal .time_area .timetable .btn.disabled > * {
        cursor: default;
        background: #d2d2d2 url(../images/icon_disabled.svg) no-repeat center center;
        background-size: 17px auto; }
  #step1_modal h3 {
    font-size: 18px;
    font-weight: bold; }
  #step1_modal .shop_list {
    margin-top: 15px;
    margin-bottom: 30px;
    background: #f2f2f2;
    padding: 15px 20px;
    overflow: hidden; }
    #step1_modal .shop_list li {
      float: left;
      width: 50%; }
      #step1_modal .shop_list li:before {
        content: '・'; }
      #step1_modal .shop_list li a {
        text-decoration: underline; }

    #step1_modal .shop_nearby_list {
        margin-top: 5px;
        margin-bottom: 0px;
        /*background: #f2f2f2;
        padding: 15px 20px;*/
        overflow: hidden; }
    #step1_modal .shop_nearby_list li {
        float: left;
        width: 50%; }
    #step1_modal .shop_nearby_list li button {
        width: 90%;
        height: 100%;
        line-height: 40px;
        font-size: 16px;
        margin-top: 8px;
        border-radius: 4px;
        background-color: #FFD9D9; }
  #step1_modal .btn.close {
    width: 180px;
    margin: 0 auto; }
    #step1_modal .btn.close > * {
      text-decoration: none;
      background-color: #585656;
      border-color: #424140;
      color: #fff; }
      #step1_modal .btn.close > *:after {
        right: 20px;
        width: 10px;
        height: 10px;
        background: url(../images/icon_close.svg) left top no-repeat;
        background-size: cover; }

    #step2 .select {
        display: inline-block;
        margin-right: 25px;
        width: 300px;
        height: 50px;
        position: relative;
        background: #f2f2f0;
        border: 1px solid #e9e8e1;
        border-radius: 2px;
        box-sizing: border-box; }
    #step2 .select:after {
        content: '';
        display: block;
        position: absolute;
        right: 19px;
        top: 0;
        width: 11px;
        background: url(../images/icon_select.svg) no-repeat center center;
        background-size: contain;
        height: 48px;
        pointer-events: none; }
    #step2 .select .display {
        font-size: 14px;
        line-height: 50px;
        padding-left: 20px; }
    #step2 .select select {
        display: block;
        position: absolute;
        left: 0;
        top: 0;
        width: 300px;
        height: 50px;
        border: none;
        padding: 0;
        margin: 0;
        opacity: 0; }

  #step2 .select_sub {
    display: inline-block;
    margin-right: 25px;
    width: 100px;
    height: 50px;
    position: relative;
    background: #f2f2f0;
    border: 1px solid #e9e8e1;
    border-radius: 2px;
    box-sizing: border-box; }
  #step2 .select_sub:after {
    content: '';
    display: block;
    position: absolute;
    right: 19px;
    top: 0;
    width: 11px;
    background: url(../images/icon_select.svg) no-repeat center center;
    background-size: contain;
    height: 48px;
    pointer-events: none; }
  #step2 .select_sub .display {
    font-size: 14px;
    line-height: 50px;
    padding-left: 20px; }
  #step2 .select_sub select {
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    width: 100px;
    height: 50px;
    border: none;
    padding: 0;
    margin: 0;
    opacity: 0; }
}
@media only screen and (max-width: 750px) {
  .cssdisabled {
    display: none; }

  #step1 .form_dl dt {
    font-size: 16px;
    font-weight: bold;
    padding: 20px 0 10px; }
  #step1 .form_dl .plan_text {
    display: block;
    width: 100%;
    height: 50px;
    position: relative;
    background: #e8e8e5;
    border-radius: 2px;
    box-sizing: border-box;
    padding: 0 25px;
    line-height: 50px;
    font-size: 14px;
    cursor: pointer;

    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
  }
    #step1 .form_dl .plan_text:before {
      content: '';
      display: block;
      position: absolute;
      right: 15px;
      top: 50%;
      width: 15px;
      background: #42332f;
      height: 1px; }
    #step1 .form_dl .plan_text:after {
      content: '';
      display: block;
      position: absolute;
      right: 22px;
      top: 50%;
      width: 1px;
      background: #42332f;
      height: 15px;
      margin-top: -7px; }
    #step1 .form_dl .plan_text.active:after {
      display: none; }
  #step1 .form_dl ul.plan_list {
    background: #f2f2f0;
    border-radius: 2px;
    overflow: hidden;
    height: 0;
    -webkit-transition: height 0.2s cubic-bezier(0.42, 0, 1, 1);
    transition: height 0.2s cubic-bezier(0.42, 0, 1, 1); }
    #step1 .form_dl ul.plan_list.active {
      height: 100%/*1440px*/; }
    #step1 .form_dl ul.plan_list:after {
      display: block;
      content: '';
      clear: both; }
    #step1 .form_dl ul.plan_list li {
      width: 100%;
      height: 95px;
      padding: 7px 10px 8px;
      box-sizing: border-box;
      border-bottom: 1px solid #dcdcdc;
      position: relative;
      cursor: pointer; }
      /*#step1 .form_dl ul.plan_list li:before {
        content: '';
        display: block;
        position: absolute;
        right: 16px;
        top: 0;
        width: 6px;
        background: url(../images/icon_arrow_plan.svg) no-repeat center center;
        background-size: 6px auto;
        height: 95px; }*/
      #step1 .form_dl ul.plan_list li.active:after {
        display: block;
        content: '';
        background: rgba(184, 132, 57, 0.6) url(../images/plan_select.png) no-repeat center center;
        background-size: 36px auto;
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0; }
      #step1 .form_dl ul.plan_list li:last-child {
        border-bottom: none; }
      #step1 .form_dl ul.plan_list li .image .text-plan {
        display: block;
        line-height: 12px;
        font-size: 14px;
        padding: 5px 0;
        text-align: center;
      }
      #step1 .form_dl ul.plan_list li .text {
        /*font-size: 16px;
            display: inline-block;
            padding: 10px 0;
            font-weight: bold;
            line-height: 25px;*/
        vertical-align: middle;
        position: absolute;
        left: 90px;
        top: 35px;
        right: 10px;
        bottom: 5px;
        font-size: 12px;
        line-height: 13px;
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 4;
        overflow: hidden;
        font-family: "NotoSansJPRegular";
      }
      #step1 .form_dl ul.plan_list li .text-name {
        vertical-align: middle;
        position: absolute;
        left: 90px;
        top: 5px;
        right: 10px;
        font-size: 8pt;
        line-height: 20px;
        font-weight: bold;
        font-family: "NotoSerifJPBold";
      }
      #step1 .form_dl ul.plan_list li .text-name-over {
        vertical-align: middle;
        position: absolute;
        left: 90px;
        top: 5px;
        right: 10px;
        font-size: 9pt;
        line-height: 20px;
        font-weight: bold;
        font-family: "NotoSerifJPBold";
      }
      #step1 .form_dl ul.plan_list li .text-name-over-15 {
        vertical-align: middle;
        position: absolute;
        left: 90px;
        top: 5px;
        right: 10px;
        font-size: 7pt;
        line-height: 20px;
        font-weight: bold;
        font-family: "NotoSerifJPBold";
      }
      #step1 .form_dl ul.plan_list li .text-name-sub {
        font-size: 8pt;
      }
      #step1 .form_dl ul.plan_list li .hr-name {
        display: block;
        vertical-align: middle;
        position: absolute;
        left: 90px;
        top: 28px;
        right: 10px;
        font-size: 12pt;
        line-height: 20px;
      }
      #step1 .form_dl ul.plan_list li .image {
        width: 75px;
        height: 75px;
        display: inline-block;
        vertical-align: middle;
        margin-right: 20px; }
        #step1 .form_dl ul.plan_list li .image img {
          width: 100%; }
  #step1 .validate_section {
    opacity: 0.5;
    pointer-events: none;
    -moz-pointer-events: none;
    -webkit-pointer-events: none;
    -ms-pointer-events: none; }
    #step1 .validate_section.active {
      opacity: 1;
      pointer-events: auto;
      -moz-pointer-events: auto;
      -webkit-pointer-events: auto;
      -ms-pointer-events: auto; }
  #step1 .select {
    display: block;
    width: 100%;
    height: 50px;
    position: relative;
    background: #e8e8e5;
    border-radius: 2px;
    box-sizing: border-box; }
    #step1 .select + .select {
      margin-top: 20px; }
    #step1 .select:after {
      content: '';
      display: block;
      position: absolute;
      right: 19px;
      top: 0;
      width: 13px;
      background: url(../images/icon_select.svg) no-repeat center center;
      background-size: contain;
      height: 48px;
      pointer-events: none; }
    #step1 .select .display {
      font-size: 14px;
      line-height: 50px;
      padding-left: 20px; }
    #step1 .select select {
      display: block;
      position: absolute;
      left: 0;
      top: 0;
      width: 100%;
      height: 50px;
      border: none;
      padding: 0;
      margin: 0;
      opacity: 0; }
  #step1 .calendar_text {
    display: block;
    width: 100%;
    height: 50px;
    position: relative;
    background: #e8e8e5;
    border-radius: 2px;
    box-sizing: border-box;
    padding: 0 20px;
    line-height: 50px;
    font-size: 14px;
    cursor: pointer; }
    #step1 .calendar_text:after {
      content: '';
      display: block;
      position: absolute;
      right: 14px;
      top: 0;
      width: 19px;
      background: url(../images/icon_calender.svg) no-repeat center center;
      background-size: contain;
      height: 48px;
      pointer-events: none; }
  #step1 .time_text {
    display: block;
    width: 100%;
    height: 50px;
    position: relative;
    background: #e8e8e5;
    border-radius: 2px;
    box-sizing: border-box;
    padding: 0 20px;
    line-height: 50px;
    font-size: 14px;
    cursor: pointer; }
    #step1 .time_text:after {
      content: '';
      display: block;
      position: absolute;
      right: 14px;
      top: 0;
      width: 17px;
      background: url(../images/icon_time.svg) no-repeat center center;
      background-size: contain;
      height: 48px; }
  #step1 p.notice {
    margin-top: 7px;
    color: #716b5b;
    font-size: 14px;
    line-height: 24px; }
  #step4_modal .modal_bg {
    display: none;
    background: rgba(0, 0, 0, 0.4);
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    z-index: 500; }
  #step3_modal .modal_bg {
    display: none;
    background: rgba(0, 0, 0, 0.4);
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    z-index: 500; }
  #step2_modal .modal_bg {
    display: none;
    background: rgba(0, 0, 0, 0.4);
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    z-index: 500; }
  #step1_modal .modal_bg {
    display: none;
    background: rgba(0, 0, 0, 0.4);
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    z-index: 500; }
  #step1_modal .modal_content {
    display: none;
    padding-top: 60px;
    position: absolute;
    z-index: 1000;
    top: 40px;
    left: 20px;
    right: 20px; }
    #step1_modal .modal_content .icon_close {
      position: absolute;
      right: 0;
      top: 0;
      width: 45px;
      height: 50px;
      background: #343c48;
      cursor: pointer; }
      #step1_modal .modal_content .icon_close:before {
        content: '';
        display: block;
        position: absolute;
        width: 20px;
        height: 1px;
        background: #fff;
        left: 50%;
        margin-left: -10px;
        top: 50%;
        margin-top: -1px;
        transform: rotate(45deg);
        -webkit-transform: rotate(45deg);
        -moz-transform: rotate(45deg);
        -o-transform: rotate(45deg);
        -ms-transform: rotate(45deg); }
      #step1_modal .modal_content .icon_close:after {
        content: '';
        display: block;
        position: absolute;
        width: 20px;
        height: 1px;
        background: #fff;
        left: 50%;
        margin-left: -10px;
        top: 50%;
        margin-top: -1px;
        transform: rotate(-45deg);
        -webkit-transform: rotate(-45deg);
        -moz-transform: rotate(-45deg);
        -o-transform: rotate(-45deg);
        -ms-transform: rotate(-45deg); }
    #step1_modal .modal_content .modal_inner {
      border-radius: 4px;
      background: #fff;
      padding: 20px 17px; }
    #step1_modal .modal_bg_alert {
        display: none;
        background: rgba(0, 0, 0, 0.4);
        position: fixed;
        top: 0;
        right: 0;
        left: 0;
        bottom: 0;
        z-index: 1001; }
  #step1_modal .modal_content_alert {
    display: none;
    position: absolute;
    z-index: 1002;
    left: 20%;
    right: 20%;
  }
  #step1_modal .modal_content_alert .icon_close_alert {
    position: absolute;
    right: 0;
    width: 22px;
    height: 22px;
    background: #343c48;
    cursor: pointer; }
  #step1_modal .modal_content_alert .icon_close_alert:before {
    content: '';
    display: block;
    position: absolute;
    width: 20px;
    height: 1px;
    background: #fff;
    left: 50%;
    margin-left: -10px;
    top: 50%;
    margin-top: -1px;
    transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    -o-transform: rotate(45deg);
    -ms-transform: rotate(45deg); }
  #step1_modal .modal_content_alert .icon_close_alert:after {
    content: '';
    display: block;
    position: absolute;
    width: 20px;
    height: 1px;
    background: #fff;
    left: 50%;
    margin-left: -10px;
    top: 50%;
    margin-top: -1px;
    transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    -o-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg); }
  #step1_modal .modal_content_alert .modal_inner {
    border-radius: 4px;
    background: #FBE5D6;
    padding: 20px 17px; }
  #step1_modal .calendar_area {
    position: relative; }
    #step1_modal .calendar_area .prev {
      width: 15px;
      height: 27px;
      display: block;
      position: absolute;
      text-indent: -9999px;
      left: 0;
      top: 0;
      background: url(../images/icon_arrow_black_left.svg) no-repeat center center;
      background-size: 9px auto; }
    #step1_modal .calendar_area .next {
      width: 15px;
      height: 27px;
      display: block;
      position: absolute;
      text-indent: -9999px;
      right: 0;
      top: 0;
      background: url(../images/icon_arrow_black_right.svg) no-repeat center center;
      background-size: 9px auto; }
    #step1_modal .calendar_area .date_title {
      text-align: center;
      font-size: 16px;
      line-height: 27px;
      font-weight: bold; }
  #step1_modal .calendar_area .date_subtitle {
      text-align: center;
      font-size: 11.5px;
      line-height: 1em;
      font-weight: bold; }
    #step1_modal .calendar_area table.calendar {
      margin-top: 10px;
      margin-bottom: 25px;
      width: 100%; }
      #step1_modal .calendar_area table.calendar th, #step1_modal .calendar_area table.calendar td {
        border: 1px solid #bfbcb8;
        width: 14.285%;
        line-height: 15px;
        padding: 7px 5px;
        text-align: center;
        font-size: 10px;
        vertical-align: top; }
      #step1_modal .calendar_area table.calendar th {
        background: #d3d3d3;
        font-weight: bold; }
        #step1_modal .calendar_area table.calendar th.sat {
          background: #d9f9ff; }
        #step1_modal .calendar_area table.calendar th.sun {
          background: #ffd9d9; }
      #step1_modal .calendar_area table.calendar td.disabled {
        background: #ececec; }
      #step1_modal .calendar_area table.calendar td.base {
        background: #ffffce; }
      #step1_modal .calendar_area table.calendar .btn {
        margin-top: 7px;
        height: 30px;
        line-height: 30px; }
        #step1_modal .calendar_area table.calendar .btn > * {
          height: 30px;
          border-radius: 2px;
          border-bottom-width: 2px;
          border-bottom-color: #d2d2d2; }
        #step1_modal .calendar_area table.calendar .btn.circle > * {
          background: #ececec url(../images/icon_circle.svg) no-repeat center center;
          background-size: 12px auto; }
        #step1_modal .calendar_area table.calendar .btn.square > * {
          background: #ececec url(../images/icon_square.svg) no-repeat center center;
          background-size: 12px auto; }
        #step1_modal .calendar_area table.calendar .btn.triangle > * {
          background: #ececec url(../images/icon_triangle.svg) no-repeat center center;
          background-size: 14px auto; }
        #step1_modal .calendar_area table.calendar .btn.disabled:hover {
          opacity: 1; }
        #step1_modal .calendar_area table.calendar .btn.disabled > * {
          cursor: default;
          background: #d2d2d2 url(../images/icon_disabled.svg) no-repeat center center;
          background-size: 10px auto; }
  #step1_modal .time_area .date_title {
    text-align: center;
    font-size: 16px;
    line-height: 27px;
    font-weight: bold; }

  #step1_modal .time_area .date_subtitle {
    text-align: center;
    font-size: 11.5px;
    line-height: 1em;
    font-weight: bold; }
  #step1_modal .time_area .timetable {
    margin-top: 10px;
    margin-bottom: 25px;
    width: 100%; }
    #step1_modal .time_area .timetable th, #step1_modal .time_area .timetable td {
      border: 1px solid #bfbcb8;
      width: 50%;
      line-height: 20px;
      text-align: center;
      font-size: 12px;
      line-height: 15px;
      vertical-align: middle; }
    #step1_modal .time_area .timetable th {
      padding: 5px 20px;
      background: #d3d3d3;
      font-weight: bold; }
    #step1_modal .time_area .timetable td {
      padding: 5px 20px; }
      #step1_modal .time_area .timetable td.time {
        background: #f1f1f0; }
    #step1_modal .time_area .timetable .btn {
      height: 20px;
      line-height: 20px;
      max-width: 93px;
      margin: 0 auto; }
      #step1_modal .time_area .timetable .btn > * {
        height: 20px;
        border-radius: 2px;
        border-bottom-width: 2px;
        border-bottom-color: #d2d2d2; }
      #step1_modal .time_area .timetable .btn.circle > * {
        background: #ececec url(../images/icon_circle.svg) no-repeat center center;
        background-size: 12px auto; }
      #step1_modal .time_area .timetable .btn.triangle > * {
        background: #ececec url(../images/icon_triangle.svg) no-repeat center center;
        background-size: 14px auto; }
      #step1_modal .time_area .timetable .btn.disabled:hover {
        opacity: 1; }
      #step1_modal .time_area .timetable .btn.disabled > * {
        cursor: default;
        background: #d2d2d2 url(../images/icon_disabled.svg) no-repeat center center;
        background-size: 10px auto; }
  #step1_modal h3 {
    font-size: 14px;
    font-weight: bold; }
  #step1_modal p {
    font-size: 12px; }
  #step1_modal .shop_list {
    margin-top: 5px;
    margin-bottom: 30px;
    background: #f2f2f2;
    padding: 10px 12px;
    overflow: hidden; }
    #step1_modal .shop_list li {
      font-size: 12px;
      line-height: 15px;
      float: left;
      width: 50%; }
      #step1_modal .shop_list li:before {
        content: '・';
        font-size: 12px;
        line-height: 15px; }
      #step1_modal .shop_list li a {
        text-decoration: underline; }

    #step1_modal .shop_nearby_list {
        margin-top: 5px;
        margin-bottom: 0px;
        /*background: #f2f2f2;
        padding: 10px 12px;*/
        overflow: hidden; }
    #step1_modal .shop_nearby_list li {
        font-size: 12px;
        line-height: 15px;
        float: left;
        width: 50%; }
    #step1_modal .shop_nearby_list li button {
        width: 90%;
        height: 100%;
        line-height: 30px;
        font-size: 12px;
        margin-top: 5px;
        border-radius: 4px;
        background-color: #FFD9D9; }
  #step1_modal .btn.close {
    width: 180px;
    margin: 0 auto; }
    #step1_modal .btn.close > * {
      text-decoration: none;
      background-color: #585656;
      border-color: #424140;
      color: #fff; }
      #step1_modal .btn.close > *:after {
        right: 20px;
        width: 10px;
        height: 10px;
        background: url(../images/icon_close.svg) left top no-repeat;
        background-size: cover; }

    #step2 .select {
        display: block;
        width: 100%;
        height: 50px;
        position: relative;
        background: #e8e8e5;
        border-radius: 2px;
        box-sizing: border-box; }
    #step2 .select + .select {
        margin-top: 20px; }
    #step2 .select:after {
        content: '';
        display: block;
        position: absolute;
        right: 19px;
        top: 0;
        width: 13px;
        background: url(../images/icon_select.svg) no-repeat center center;
        background-size: contain;
        height: 48px;
        pointer-events: none; }
    #step2 .select .display {
        font-size: 14px;
        line-height: 50px;
        padding-left: 20px; }
    #step2 .select select {
        display: block;
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: 50px;
        border: none;
        padding: 0;
        margin: 0;
        opacity: 0; }

  #step2 .select_sub {
    display: block;
    width: 100%;
    height: 50px;
    position: relative;
    background: #e8e8e5;
    border-radius: 2px;
    box-sizing: border-box; }
  #step2 .select_sub + .select {
    margin-top: 20px; }
  #step2 .select_sub + .select_sub {
    margin-top: 20px; }
  #step2 .select_sub:after {
    content: '';
    display: block;
    position: absolute;
    right: 19px;
    top: 0;
    width: 13px;
    background: url(../images/icon_select.svg) no-repeat center center;
    background-size: contain;
    height: 48px;
    pointer-events: none; }
  #step2 .select_sub .display {
    font-size: 14px;
    line-height: 50px;
    padding-left: 20px; }
  #step2 .select_sub select {
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 50px;
    border: none;
    padding: 0;
    margin: 0;
    opacity: 0; }

  #step2 .select_sub_second {
    display: block;
    width: 100%;
    height: 50px;
    position: relative;
    background: #e8e8e5;
    border-radius: 2px;
    box-sizing: border-box;
    margin-top: 25px;
    margin-bottom: 25px;}
}
/* -----------------------------------------------
 [common]
-------------------------------------------------- */
* {
  vertical-align: middle; }

#wrap {
  background-color: #fff; }

@media only screen and (min-width: 751px) {
  .sp {
    display: none !important; }

  .sll_wrap {
    margin: 20px 0 20px; }
    .sll_wrap #sslSeal,
    .sll_wrap > p {
      display: table-cell;
      margin: 0 !important; }
    .sll_wrap > p {
      padding-left: 0px; } }
@media only screen and (max-width: 750px) {
  .pc {
    display: none !important; }

  .w950, .w1024, #content {
    width: inherit !important; }

  .sll_wrap {
    margin: 35px 0 20px; }
    .sll_wrap #sslSeal,
    .sll_wrap > p {
      margin: 0 !important; }
    .sll_wrap > p {
      margin-top: 10px !important; } }
/* table
-------------------------------------------------- */
.form_table.input {
  width: 100%; }
  .form_table.input tr th {
    box-sizing: border-box; }
  .form_table.input tr td p.text {
    color: #716b5b; }

.sub_title {
  font-weight: bold;
  clear: both;
  float: left; }

.sub_title_complete {
    font-weight: bold;
    clear: both;
    float: left; }

.form_table.confirm {
  border-left: 1px solid #ece9e9;
  border-top: 1px solid #ece9e9;
  width: 100%; }
  .form_table.confirm tr th,
  .form_table.confirm tr td {
    border-right: 1px solid #ece9e9;
    border-bottom: 1px solid #ece9e9; }
  .form_table.confirm tr th {
    background-color: #f2f2f0;
    box-sizing: border-box;
    vertical-align: middle; }
  .form_table.confirm tr td a {
    color: #5e8a19;
    text-decoration: underline; }
    .form_table.confirm tr td a:hover {
      text-decoration: none; }

.btn.correction {
  float: right; }

@media only screen and (min-width: 751px) {
  .form_table.input tr {
    border-bottom: 1px solid #ece9e9; }
    .form_table.input tr th {
      width: 400px;
      font-size: 15px;
      font-weight: bold; }
    .form_table.input tr .th_width {
        width: 400px; }
    .form_table.input tr .th_width_third {
    width: 200px; }
    .form_table.input tr .top {
      vertical-align: top;
      padding-top: 42px; }
     .form_table.input tr .top.two_line {
        padding-top: 34px; }
    .form_table.input tr th p.text {
      font-size: 14px;
      color: red;
      line-height: 15px;
      padding-top: 10px;
      padding-right: 20px
    }
    .form_table.input tr td {
      padding: 29px 0 29px 0; }
      .form_table.input tr td input[type="text"],
      .form_table.input tr td input[type="email"],
      .form_table.input tr td input[type="tel"],
      .form_table.input tr td input[type="password"],
      .form_table.input tr td p.error {
        display: inline-block;
        font-size: 14px; }
      .form_table.input tr td input[type="text"],
      .form_table.input tr td input[type="email"],
      .form_table.input tr td input[type="tel"],
      .form_table.input tr td input[type="password"] {
        margin-right: 20px; }
      .form_table.input tr td p.text {
        margin-top: 15px;
        font-size: 14px;
      }
      .form_table.input tr td p.text-title {
        margin-top: 25px;
        font-size: 20px;
        font-weight: bold;
      }
    .form_table.input tr.radio_list_wrap {
      border-bottom: none; }
      .form_table.input tr.radio_list_wrap th {
        padding-top: 16px;
        vertical-align: top; }
      .form_table.input tr.radio_list_wrap td {
        padding-top: 9px;
        padding-bottom: 9px; }
      .form_table.input tr.radio_list_wrap.first th {
        padding-top: 35px; }
      .form_table.input tr.radio_list_wrap.first td {
        padding-top: 29px; }
      .form_table.input tr.radio_list_wrap.last {
        border-bottom: 1px solid #ece9e9; }
        .form_table.input tr.radio_list_wrap.last th {
          padding-top: 17px; }
        .form_table.input tr.radio_list_wrap.last td {
          padding-bottom: 29px; }

  .sub_title {
    font-size: 18px;
    margin-top: 5px;
    margin-bottom: 15px; }

  .sub_title_complete {
    font-size: 18px;
    margin-left: 5px;
    margin-top: 10px;
    margin-bottom: 10px; }

  .form_table.confirm.mb {
    margin-bottom: 65px; }
  .form_table.confirm tr th, .form_table.confirm tr td {
    padding: 10px 25px; }
  .form_table.confirm tr th {
    width: 300px;
    font-weight: bold; }

  .btn.correction {
    margin-top: 10px; }

  .form_table.input_sub tr th {
    width: 80px;
    font-size: 15px;
    font-weight: bold; }
  .form_table.input_sub tr td {
    padding: 10px 0 10px 0; }
  .form_table.input_sub tr td input[type="text"],
  .form_table.input_sub tr td input[type="email"],
  .form_table.input_sub tr td input[type="tel"],
  .form_table.input_sub tr td input[type="password"],
  .form_table.input_sub tr td p.error {
    display: inline-block;
    font-size: 14px; }
  .form_table.input_sub tr td input[type="text"],
  .form_table.input_sub tr td input[type="email"],
  .form_table.input_sub tr td input[type="tel"],
  .form_table.input_sub tr td input[type="password"] {
    margin-right: 20px; }
  .form_table.input_sub tr td p.text {
    margin-top: 15px; }
}
@media only screen and (max-width: 750px) {
  .form_table.input tr th,
  .form_table.input tr td {
    display: block; }
  .form_table.input tr th {
    font-size: 16px;
    font-weight: bold;
    padding: 20px 0 10px; }
  .form_table.input tr td p.text {
    margin-top: 10px;
    font-size: 12px;
  }
  .form_table.input tr td p.text-title {
    margin-top: 20px;
    font-size: 16px;
    font-weight: bold;
  }
  .form_table.input tr th p.text {
    font-size: 12px;
    color: red;
    line-height: 10px;
    padding-top: 5px
  }

  .sub_title {
    font-size: 16px;
    margin-top: 5px;
    margin-bottom: 10px; }
  .sub_title_complete {
    font-size: 16px;
    margin-top: 5px;
    margin-top: 10px;
    margin-bottom: 10px; }

  .form_table.confirm.mb {
    margin-bottom: 45px; }
  .form_table.confirm tr th, .form_table.confirm tr td {
    padding: 10px 15px; }
  .form_table.confirm tr th {
    width: 140px;
    font-weight: bold; }

  .btn.correction {
    margin-top: 10px; }

  .form_table.input_sub tr th,
  .form_table.input_sub tr td {
    display: block; }
  .form_table.input_sub tr th {
    font-size: 16px;
    font-weight: bold;
    padding: 20px 0 10px; }
  .form_table.input_sub tr td p.text {
    margin-top: 10px; }
}
/* Form
-------------------------------------------------- */
.rq_th:after {
  content: "必須";
  display: inline-block;
  background-color: #e56d6d;
  color: #fff;
  margin-left: 3px;
  border-radius: 2px;
  font-weight: normal; }

.rq_sub_th:after {
  content: "必須";
  display: inline-block;
  background-color: #e56d6d;
  color: #fff;
  margin-left: 3px;
  border-radius: 2px;
  font-weight: normal; }

p.error {
  color: #ff0000; }

@media only screen and (min-width: 751px) {
  .rq_th {
    position: relative;
    padding-right: 45px; }
    .rq_th:after {
      position: absolute;
      font-size: 11px;
      height: 18px;
      line-height: 18px;
      padding: 0 6px;
      right: 20px;
      /*top: 45px;*/
      margin: auto; }
  .rq_sub_th {
    position: relative;
    padding-right: 52px; }
  .rq_sub_th:after {
    position: absolute;
    font-size: 11px;
    height: 18px;
    line-height: 18px;
    padding: 0 6px;
    right: 20px;
    top: 35px;
    margin: auto; }
}
@media only screen and (max-width: 750px) {
  .rq_th:after {
    position: relative;
    top: -2px;
    font-size: 10px;
    height: 17px;
    line-height: 17px;
    padding: 0 6px; }

  .rq_sub_th {
    position: relative;
    padding-right: 45px; }
  .rq_sub_th:after {
    position: absolute;
    font-size: 10px;
    height: 17px;
    line-height: 17px;
    padding: 0 6px;
    right: 0px;
    top: 20px;
    margin: auto; }

  p.error {
    margin-top: 5px; } }
/* Input
-------------------------------------------------- */
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="password"] {
  border: 1px solid #ece9e9;
  background-color: #f2f2f0;
  -webkit-appearance: none;
  /* ゴシック */
  font-family: "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", Osaka, Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  box-sizing: border-box;
  border-radius: 2px;
  vertical-align: middle; }
  input[type="text"].error,
  input[type="email"].error,
  input[type="tel"].error,
  input[type="password"].error {
    background-color: #FDEBEB; }

input::-webkit-input-placeholder,
input:-ms-input-placeholder,
input::-moz-placeholder {
  color: #5e686d !important; }

@media only screen and (min-width: 751px) {
  input[type="text"],
  input[type="email"],
  input[type="tel"],
  input[type="password"] {
    width: 300px;
    height: 50px;
    padding: 16px;
    font-size: 13px; }
    input[type="text"].size_s,
    input[type="email"].size_s,
    input[type="tel"].size_s,
    input[type="password"].size_s {
      width: 210px;
      margin-right: 10px; } }
@media only screen and (max-width: 750px) {
  input[type="text"],
  input[type="email"],
  input[type="tel"],
  input[type="password"] {
    width: 100%;
    height: 50px;
    padding: 4%;
    font-size: 14px; } }
/* Textarea
-------------------------------------------------- */
textarea {
  border: 1px solid #ece9e9;
  background-color: #f2f2f0;
  /* ゴシック */
  font-family: "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", Osaka, Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  box-sizing: border-box;
  border-radius: 2px; }

textarea::-webkit-input-placeholder,
textarea:-ms-input-placeholder,
textarea:-moz-placeholder {
  color: #5e686d; }

@media only screen and (min-width: 751px) {
  textarea {
    width: 550px;
    height: 120px;
    padding: 12px;
    font-size: 14px; } }
@media only screen and (max-width: 750px) {
  textarea {
    width: 100%;
    height: 135px;
    padding: 8px;
    font-size: 14px; } }
/* Input Button
-------------------------------------------------- */
input[type="submit"],
input[type="reset"],
input[type="button"],
button {
  border: none;
  background: none;
  -webkit-appearance: none;
  /* ゴシック */
  font-family: "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", Osaka, Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  cursor: pointer;
  transition: all 0.2s ease-in;
  -moz-transition: all 0.2s ease-in;
  -webkit-transition: all 0.2s ease-in;
  -ms-transition: all 0.2s ease-in;
  text-align: center;
  border-radius: 0; }

input[type="submit"],
button[type="reset"],
input[type="button"],
button {
  width: 100%;
  height: 100%; }

/* Select
-------------------------------------------------- */
.customSelect {
  border: 1px solid #dddddd;
  -webkit-appearance: none;
  -moz-appearance: none;
  text-indent: 0.01px;
  text-overflow: '';
  box-sizing: border-box;
  font-size: 14px; }

.customSelectInner {
  width: 100% !important; }

select.short {
  background-position: 85% center; }

select::-ms-expand {
  display: none; }

@media only screen and (min-width: 751px) {
  .customSelect {
    width: 320px;
    height: 40px;
    line-height: 30px;
    padding: 4px 20px 4px 12px; } }
@media only screen and (max-width: 750px) {
  .customSelect {
    border-radius: 0;
    width: 100%;
    height: 40px;
    line-height: 30px;
    padding: 4px 20px 4px 6px; } }
/* checkbox radio
-------------------------------------------------- */
input[type=radio], input[type=checkbox] {
  display: none; }

.radiobox, .checkbox {
  box-sizing: border-box;
  -webkit-transition: background-color 0.2s linear;
  transition: background-color 0.2s linear;
  position: relative;
  display: inline-block;
  margin: 0;
  height: 32px;
  line-height: 32px;
  padding-left: 47px;
  vertical-align: middle;
  cursor: pointer; }
  .radiobox:hover:after, .checkbox:hover:after {
    border-color: #a7a7a7; }
  .radiobox:after, .checkbox:after {
    -webkit-transition: border-color 0.2s linear;
    transition: border-color 0.2s linear;
    position: absolute;
    top: 50%;
    left: 0;
    display: block;
    margin-top: -18px;
    width: 35px;
    height: 35px;
    content: ''; }

.radiobox {
  height: 35px;
  line-height: 35px; }
  .radiobox:before {
    -webkit-transition: opacity 0.2s linear;
    transition: opacity 0.2s linear;
    position: absolute;
    top: 50%;
    left: 8px;
    display: block;
    margin-top: -10px;
    width: 19px;
    height: 19px;
    border-radius: 50%;
    background-color: #b88439;
    content: '';
    opacity: 0;
    z-index: 5; }
  .radiobox:after {
    border-radius: 50%;
    background: #f1f0ec; }

.checkbox {
  height: 28px;
  line-height: 24px; }
  .checkbox:before {
    -webkit-transition: opacity 0.2s linear;
    transition: opacity 0.2s linear;
    position: absolute;
    top: 50%;
    left: 13px;
    display: block;
    margin-top: -9px;
    width: 4px;
    height: 9px;
    border-right: 2px solid #fff;
    border-bottom: 2px solid #fff;
    content: '';
    opacity: 0;
    z-index: 5;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg); }
  .checkbox:after {
    width: 28px;
    height: 28px;
    border-radius: 3px;
    border: 1px solid #ece9e9;
    background-color: #fff; }

.c_on:before {
  opacity: 1; }

.checkbox.c_on:after {
  background-color: #b88439; }

@media only screen and (min-width: 751px) {
  .radio_list {
    padding-left: 45px; }
    .radio_list li {
      display: inline-block;
      width: 135px; } }
@media only screen and (max-width: 750px) {
  .radiobox {
    margin: 0 5px 0 0;
    height: 25px;
    line-height: 15px;
    padding-left: 37px; }
    .radiobox:before {
      width: 15px;
      height: 15px;
      left: 5px;
      margin-top: -13px; }
    .radiobox:after {
      width: 25px;
      height: 25px; }

  .radio_list {
    margin-top: -10px; }
    .radio_list li {
      float: left;
      margin-right: 20px;
      margin-top: 10px; } }
/* -----------------------------------------------
 [button]
-------------------------------------------------- */
.btn {
  height: 46px;
  line-height: 46px;
  box-sizing: border-box;
  transition: all 0.2s ease-in;
  -moz-transition: all 0.2s ease-in;
  -webkit-transition: all 0.2s ease-in;
  -ms-transition: all 0.2s ease-in; }
  .btn > * {
    vertical-align: middle;
    display: block;
    position: relative;
    text-align: center;
    overflow: hidden; }
    .btn > *:after {
      content: "";
      display: block;
      position: absolute;
      top: 0;
      bottom: 0;
      margin: auto; }
  .btn.center {
    margin-left: auto;
    margin-right: auto; }
  .btn.back > * {
    background-color: #cecece; }
    .btn.back > *:after {
      left: 10px;
      width: 6px;
      height: 11px;
      background: url(../images/icon_arrow_black_left.svg) left top no-repeat;
      background-size: cover; }
  .btn.back.correction > *:after {
    display: none; }
  .btn.submit > * {
    background-color: #585656; }
    .btn.submit > * span {
      color: #fff; }
    .btn.submit > *:after {
      right: 20px;
      width: 6px;
      height: 11px;
      background: url(../images/icon_arrow_white_right.svg) left top no-repeat;
      background-size: cover; }
  .btn.disable > * {
    background-color: #E8E8E8;
    cursor: default; }
    .btn.disable > * span {
      color: #fff; }
  .btn.disable:hover {
    opacity: 1; }
  .btn:hover {
    opacity: 0.8; }
    .btn:hover * {
      text-decoration: none; }

.btn.delete > * {
  background-color: #cecece; }
.btn.delete.correction > *:after {
  display: none; }

@media only screen and (min-width: 751px) {
  .btn > * {
    border-radius: 4px; }
  .btn.back {
    width: 180px; }
    .btn.back > * {
      box-shadow: 0 4px 0 #b4b4b4; }
  .btn.correction {
    width: 120px; }

  .btn.submit {
    width: 330px;
    height: 60px;
    line-height: 60px;
    font-size: 16px; }
    .btn.submit > * {
      box-shadow: 0 4px 0 #424140; }
  .btn.submit.sub {
    height: 100px; }
  .btn.disable > * {
    box-shadow: 0 4px 0 #E0E0E0; }

  .btn_list {
    text-align: center;
    margin-top: 50px; }
    .btn_list li {
      display: inline-block;
      margin: 0 20px; }

  .btn_list_sub {
    text-align: center;
    margin-top: 0px; }
  .btn_list_sub li {
    display: inline-block;
    margin: 0 20px; }

  .btn.delete {
    width: 100px; }
  .btn.delete > * {
    box-shadow: 0 4px 0 #b4b4b4; }
}
@media only screen and (max-width: 750px) {
  .btn > * {
    border-radius: 2px; }
  .btn.back {
    width: 205px; }
    .btn.back > * {
      box-shadow: 0 2px 0 #b4b4b4; }
  .btn.correction {
    width: 80px; }
  .btn.submit {
    width: 100%;
    height: 60px;
    line-height: 60px;
    font-size: 16px; }
    .btn.submit > * {
      box-shadow: 0 2px 0 #424140; }
  .btn.disable > * {
    box-shadow: 0 2px 0 #E0E0E0; }

  .btn_list li {
    display: block;
    margin-top: 20px; }

  .btn.delete {
    width: 205px; }
  .btn.delete > * {
    box-shadow: 0 2px 0 #b4b4b4; }}
/* -----------------------------------------------
 [header]
-------------------------------------------------- */
#simpleHeaderBtm p a {
  overflow: hidden;
  text-indent: -9999px;
  display: block; }

@media only screen and (min-width: 751px) {
  #simpleHeaderBtm p a {
    background: url(../images/h_logo.gif) left top no-repeat;
    background-size: 267px 30px;
    width: 267px;
    height: 30px; } }
@media only screen and (max-width: 750px) {
  #simpleHeader {
    opacity: 0;
    margin-bottom: -34px;
    height: 20px;
    overflow: hidden; }
    #simpleHeader h1 {
      width: inherit; }

  #simpleHeaderBtm {
    background: #42332f;
    padding: 17px 0 15px 20px;
    margin-bottom: 35px; }
    #simpleHeaderBtm p a {
      background: url(../images/h_logo_smp.png) left top no-repeat;
      background-size: 140px 15.5px;
      width: 140px;
      height: 15.5px;
      display: inline-block; }
    #simpleHeaderBtm p span {
      display: inline-block;
      color: #fff;
      margin-left: 12px; }
    #simpleHeaderBtm #smp_menu_wrap {
      position: absolute;
      right: 0;
      top: 0; }
      #simpleHeaderBtm #smp_menu_wrap .menu_btn {
        cursor: pointer;
        background-color: #645754;
        color: #fff;
        font-size: 7px;
        text-align: center;
        letter-spacing: 0.1em;
        width: 50px;
        height: 50px;
        padding: 32px 0 0;
        box-sizing: border-box;
        display: block;
        position: relative; }
        #simpleHeaderBtm #smp_menu_wrap .menu_btn .line {
          position: absolute;
          left: 0;
          top: 19px;
          right: 0;
          margin: auto;
          width: 20px; }
          #simpleHeaderBtm #smp_menu_wrap .menu_btn .line span {
            background-color: #fff;
            width: 20px;
            height: 1px;
            display: block;
            position: absolute;
            top: 0px; }
          #simpleHeaderBtm #smp_menu_wrap .menu_btn .line:before, #simpleHeaderBtm #smp_menu_wrap .menu_btn .line:after {
            content: "";
            display: block;
            background-color: #fff;
            width: 20px;
            height: 1px; }
          #simpleHeaderBtm #smp_menu_wrap .menu_btn .line:before {
            margin-top: -7px; }
          #simpleHeaderBtm #smp_menu_wrap .menu_btn .line:after {
            margin-top: 13px; }
        #simpleHeaderBtm #smp_menu_wrap .menu_btn.open .line span {
          display: none; }
        #simpleHeaderBtm #smp_menu_wrap .menu_btn.open .line:before {
          transform: rotate(-45deg);
          -ms-transform: rotate(-45deg);
          -moz-transform: rotate(-45deg);
          -webkit-transform: rotate(-45deg);
          margin-top: 0; }
        #simpleHeaderBtm #smp_menu_wrap .menu_btn.open .line:after {
          transform: rotate(45deg);
          -ms-transform: rotate(45deg);
          -moz-transform: rotate(45deg);
          -webkit-transform: rotate(45deg);
          margin-top: -1px; }
    #simpleHeaderBtm #smp_menu_list {
      position: absolute;
      left: 0;
      top: 50px;
      width: 100%;
      background: rgba(66, 51, 47, 0.9);
      z-index: 10;
      display: none; }
      #simpleHeaderBtm #smp_menu_list li {
        border-top: 1px solid #5C4C49; }
        #simpleHeaderBtm #smp_menu_list li:first-child {
          border: none; }
        #simpleHeaderBtm #smp_menu_list li a {
          color: #fff;
          font-weight: bold;
          padding: 15px 20px;
          display: block;
          text-decoration: none;
          font-size: 16px;
          background: url(../images/icon_arrow_white_right.svg) 93% center no-repeat;
          background-size: 5px 9px; } }
/* -----------------------------------------------
 [footer]
-------------------------------------------------- */
@media only screen and (max-width: 750px) {
  #simpleFooter {
    background: #edeae2;
    padding: 0; }
    #simpleFooter .pageup {
      background: #f9f6ed;
      position: inherit;
      width: 100%;
      height: 50px; }
      #simpleFooter .pageup a {
        display: block;
        width: 100%;
        height: 50px;
        background: url(../images/btn_pagetop.png) center center no-repeat;
        background-size: 31px 17px; }
      #simpleFooter .pageup img {
        display: none; }
    #simpleFooter .mat20 {
      margin-top: 0 !important; }
    #simpleFooter #fNavi {
      float: none; }
      #simpleFooter #fNavi li {
        display: block;
        border-bottom: 1px solid #d5d2c9;
        padding: 0 !important;
        margin: 0 !important; }
        #simpleFooter #fNavi li a {
          display: block;
          height: 50px;
          line-height: 50px;
          color: #3c3931;
          font-size: 16px;
          font-weight: bold;
          padding: 0 20px;
          text-decoration: none;
          background: url(../images/icon_arrow_black_right.svg) 93% center no-repeat;
          background-size: 5px 9px; }
        #simpleFooter #fNavi li:last-child {
          border: none; }
    #simpleFooter address {
      background-color: #fff;
      text-align: center;
      margin: 0 !important;
      height: 25px;
      line-height: 25px; }

  .footer_copyright {
    color: #333;
  }
}
/* -----------------------------------------------
 [content]
-------------------------------------------------- */
#content {
  font-size: 14px; }

@media only screen and (min-width: 751px) {
  #content {
    width: 960px;
    padding-bottom: 100px; }

  .reservation_content {
    margin-bottom: -20px; }

  .footer_copyright {
    color: #fff;
  }
}
@media only screen and (max-width: 750px) {
  .content_inner {
    margin-left: 20px;
    margin-right: 20px; } }
.page_title {
  margin: 60px auto 62px;
  text-align: center; }

/* 予約フォーム
-------------------------------------------------- */
.step_list {
  position: relative; }
  .step_list li {
    position: relative;
    z-index: 1; }
    .step_list li span {
      color: #b5b3b0;
      font-weight: bold; }
      .step_list li span:first-child {
        vertical-align: sub; }
    .step_list li:after {
      content: "";
      display: block;
      position: absolute;
      width: 27px;
      height: 27px;
      background: url(../images/icon_flow.svg) center center no-repeat;
      background-size: 27px 27px !important;
      left: 0;
      right: 0;
      bottom: 0;
      margin: auto;
      z-index: 2; }
    .step_list li.current span {
      color: #3c3931; }
    .step_list li.current:after {
      background: url(../images/icon_flow_active.svg) center center no-repeat; }
  .step_list:after {
    content: "";
    display: block;
    height: 2px;
    width: 100%;
    background: url(../images/line_flow.png) center center repeat-x;
    background-size: contain;
    position: absolute;
    bottom: 13.5px;
    z-index: -1; }

@media only screen and (min-width: 751px) {
  .step_list {
    text-align: center;
    height: 61px;
    margin-bottom: 30px;
    margin-top: 65px; }
    .step_list li {
      display: inline-block;
      width: 160px;
      height: 61px; }
      .step_list li span {
        font-size: 18px; }
        .step_list li span:first-child {
          font-size: 12px;
          margin-right: 2px; } }
@media only screen and (max-width: 750px) {
  .step_list {
    text-align: center;
    height: 61px;
    margin-bottom: 30px; }
    .step_list li {
      display: none;
      height: 61px;
      width: 100%; }
      .step_list li span {
        font-size: 17px; }
        .step_list li span:first-child {
          font-size: 17px; }
      .step_list li.current {
        display: block; }
      .step_list li:first-child {
        position: relative; }
        .step_list li:first-child:before {
          content: "";
          display: block;
          position: absolute;
          width: 50%;
          height: 10px;
          left: 0;
          bottom: 8px;
          background-color: #fff;
          z-index: 1; }
      .step_list li:last-child {
        position: relative; }
        .step_list li:last-child:before {
          content: "";
          display: block;
          position: absolute;
          width: 50%;
          height: 10px;
          right: 0;
          bottom: 8px;
          background-color: #fff;
          z-index: 1; } }
.caution_text_wrap {
  border: 1px solid #ece9e9;
  clear: both; }
  .caution_text_wrap ul li {
    /*list-style-type: disc;*/ }
    .caution_text_wrap ul li span {
      color: #ed2e2e; }

@media only screen and (min-width: 751px) {
  .caution_text_wrap {
    margin-bottom: 50px;
    padding: 15px 0 25px 35px; } }
@media only screen and (max-width: 750px) {
  .caution_text_wrap {
    margin-bottom: 25px;
    padding: 10px 0 15px 30px; } }
.consent_wrap {
  background-color: #f2f2f0; }
  .consent_wrap .text {
    border-bottom: 1px solid #ddddd4; }
    .consent_wrap .text a {
      text-decoration: underline;
      color: #a86a11; }
      .consent_wrap .text a:hover {
        text-decoration: none; }
  .consent_wrap .checkbox {
    font-weight: bold; }

@media only screen and (min-width: 751px) {
  .consent_wrap {
    text-align: center;
    padding-top: 25px;
    padding-bottom: 25px; }
    .consent_wrap .text {
      padding-bottom: 25px;
      margin-bottom: 25px; }
    .consent_wrap .checkbox {
      font-size: 16px; } }
@media only screen and (max-width: 750px) {
  .consent_wrap {
    padding: 12px;
    text-align: center; }
    .consent_wrap .text {
      padding-bottom: 12px;
      margin-bottom: 20px;
      text-align: left; } }
.complete_wrap {
  border-top: 1px solid #ece9e9;
  border-bottom: 1px solid #ece9e9; }
  .complete_wrap h3 {
    font-weight: bold;
    text-align: center; }
  .complete_wrap .num_wrap {
    display: table;
    text-align: center;
    background-color: #f2f2f0; }
    .complete_wrap .num_wrap dt,
    .complete_wrap .num_wrap dd {
      display: inline-block;
      font-weight: bold; }
  .complete_wrap a {
    text-align: center;
    text-decoration: underline;
    color: #a86a11;
    display: inherit; }
    .complete_wrap a:hover {
      text-decoration: none; }

@media only screen and (min-width: 751px) {
  .complete_wrap {
    padding-top: 45px;
    padding-bottom: 45px;
    margin-top: 70px; }
    .complete_wrap h3 {
      font-size: 18px; }
    .complete_wrap .num_wrap {
      width: 590px;
      padding-top: 25px;
      padding-bottom: 25px;
      margin: 25px auto; }
      .complete_wrap .num_wrap dt, .complete_wrap .num_wrap dd {
        font-size: 18px; }
    .complete_wrap .text {
      text-align: center; }
    .complete_wrap a {
      margin-top: 25px; } }
@media only screen and (max-width: 750px) {
  .complete_wrap {
    padding-top: 25px;
    padding-bottom: 25px;
    margin-top: 35px; }
    .complete_wrap h3 {
      font-size: 16px; }
    .complete_wrap .num_wrap {
      padding: 18px 40px;
      margin: 20px auto; }
      .complete_wrap .num_wrap dt, .complete_wrap .num_wrap dd {
        font-size: 16px; }
    .complete_wrap .text {
      margin-left: 20px;
      margin-right: 20px; }
    .complete_wrap a {
      margin-top: 25px; } }
@media only screen and (min-width: 751px) {
  #simpleHeaderBtm p {
    float: left; }
  #simpleHeaderBtm .cancel_btn {
    float: right; }
    #simpleHeaderBtm .cancel_btn a {
      font-size: 14px;
      color: #3c3931;
      font-weight: bold;
      background-color: #f2f2f0;
      border-radius: 3px;
      width: 180px;
      height: 40px;
      line-height: 40px;
      display: block;
      text-align: center;
      padding-left: 20px;
      position: relative; }
      #simpleHeaderBtm .cancel_btn a span {
        width: 19px;
        height: 20px;
        display: inline-block;
        background-image: url(../images/cancel.svg);
        background-repeat: no-repeat;
        position: absolute;
        left: 24px;
        top: 10px; }
    #simpleHeaderBtm .cancel_btn a:hover {
      text-decoration: none;
      opacity: .7; } }
@media only screen and (max-width: 750px) {
  .page_title {
    font-weight: bold;
    font-size: 17px;
    height: 34px;
    border-bottom: solid 1px #dcdcdc;
    line-height: 0px;
    margin: 0px; } }
@media only screen and (min-width: 751px) {
  #email_receive {
    color: #3c3931;
    margin-top: -10px; }
    #email_receive p {
      font-size: 14px;
      line-height: 26px;
      margin-bottom: 20px; }
    #email_receive dl {
      border: solid 1px #ece9e9;
      border-top: none;
      margin-bottom: 60px; }
      #email_receive dl dt {
        padding: 24px 30px 2px 30px;
        font-weight: bold;
        font-size: 16px;
        border-top: solid 1px #ece9e9;
        line-height: 26px; }
      #email_receive dl dd {
        padding: 2px 30px 20px 30px;
        padding-top: 0px;
        line-height: 26px; }
        #email_receive dl dd table th {
          font-weight: bold;
          width: 8%;
          vertical-align: top; }
        #email_receive dl dd a {
          margin-top: 10px;
          display: block;
          color: #a76a11;
          text-decoration: underline; }
          #email_receive dl dd a:hover {
            text-decoration: none; } }
@media only screen and (max-width: 750px) {
  #email_receive {
    margin-bottom: 30px; }
    #email_receive .btn.submit {
      height: 50px;
      line-height: 50px; }
    #email_receive p {
      line-height: 25px;
      margin-top: 18px;
      margin-bottom: 18px; }
    #email_receive dl {
      margin-bottom: 30px; }
      #email_receive dl dt {
        border-top: solid 1px #ece9e9;
        padding-top: 20px;
        font-size: 16px;
        font-weight: bold; }
      #email_receive dl dd {
        padding-top: 8px;
        line-height: 25px; }
        #email_receive dl dd p {
          margin-top: 0px;
          margin-bottom: 20px; }
          #email_receive dl dd p span {
            font-weight: bold; }
        #email_receive dl dd a {
          display: block;
          text-decoration: underline;
          text-align: center;
          color: #a76a11;
          margin-top: 8px; }
          #email_receive dl dd a:hover {
            text-decoration: none; } }
@media only screen and (min-width: 751px) {
  #cancel {
    margin-top: -10px; }
    #cancel p {
      line-height: 26px; }
    #cancel a {
      margin-top: 13px;
      color: #a76a11;
      text-decoration: underline;
      display: block; }
      #cancel a:hover {
        text-decoration: none; }
    #cancel table {
      border-top: 1px solid #ece9e9;
      margin-top: 40px; }
      #cancel table .text {
        margin-top: 10px; } }
@media only screen and (max-width: 750px) {
  #cancel {
    margin-bottom: 30px; }
    #cancel .btn.submit {
      height: 50px;
      line-height: 50px; }
    #cancel p {
      line-height: 25px;
      margin-top: 18px;
      margin-bottom: 18px; }
    #cancel .error {
      margin-bottom: 3px; }
    #cancel a {
      margin-top: 13px;
      color: #a76a11;
      text-decoration: underline;
      display: block;
      text-align: center; }
      #cancel a:hover {
        text-decoration: none; }
    #cancel table {
      margin-top: 20px;
      border-top: 1px solid #ece9e9;
      margin-bottom: 30px; }
      #cancel table p {
        margin-top: 4px;
        margin-bottom: -10px; } }
@media only screen and (min-width: 751px) {
  #cancel_confirm {
    margin-top: -10px; }
    #cancel_confirm h3 {
      font-weight: bold;
      font-size: 18px; }
    #cancel_confirm table {
      width: 100%;
      border-top: solid 1px #dcdcdc;
      border-left: solid 1px #dcdcdc;
      margin-top: 13px;
      margin-bottom: 24px; }
      #cancel_confirm table th {
        background-color: #f2f2f0;
        width: 17%;
        font-weight: bold; }
      #cancel_confirm table th, #cancel_confirm table td {
        border-bottom: solid 1px #dcdcdc;
        border-right: solid 1px #dcdcdc;
        padding: 10px 30px; } }
@media only screen and (max-width: 750px) {
  #cancel_confirm .btn.submit {
    height: 50px;
    line-height: 50px; }
  #cancel_confirm h3 {
    font-weight: bold;
    font-size: 16px;
    margin-top: 20px; }
  #cancel_confirm table {
    width: 100%;
    border-top: solid 1px #dcdcdc;
    border-left: solid 1px #dcdcdc;
    margin-top: 10px;
    margin-bottom: 20px; }
    #cancel_confirm table th {
      background-color: #f2f2f0;
      width: 40%;
      font-weight: bold; }
    #cancel_confirm table th, #cancel_confirm table td {
      border-bottom: solid 1px #dcdcdc;
      border-right: solid 1px #dcdcdc;
      padding: 6px 15px; }
  #cancel_confirm .btn_list {
    margin-top: 54px;
    margin-bottom: 25px; } }
@media only screen and (min-width: 751px) {
  #cancel_complete {
    margin-top: -7px; }
    #cancel_complete .cancel_area {
      text-align: center;
      border: solid 1px #ece9e9;
      padding: 45px 0px;
      margin-top: 58px; }
      #cancel_complete .cancel_area p.tit {
        font-weight: bold;
        font-size: 18px; }
      #cancel_complete .cancel_area p.number {
        background-color: #f2f2f0;
        width: 590px;
        height: 70px;
        line-height: 70px;
        margin: 20px auto 28px;
        font-weight: bold;
        font-size: 18px; }
    #cancel_complete .btn_list {
      margin-top: 53px; } }
@media only screen and (max-width: 750px) {
  #cancel_complete .btn.submit {
    height: 50px;
    line-height: 50px; }
  #cancel_complete .cancel_area {
    text-align: center;
    border: solid 1px #ece9e9;
    padding: 22px 0px;
    margin-top: 25px; }
    #cancel_complete .cancel_area p.tit {
      font-weight: bold;
      font-size: 16px; }
    #cancel_complete .cancel_area p.number {
      background-color: #f2f2f0;
      height: 55px;
      line-height: 55px;
      margin: 17px 20px 20px;
      font-weight: bold;
      font-size: 16px; }
    #cancel_complete .cancel_area p.text {
      text-align: left;
      margin: 0 20px; }
  #cancel_complete .btn_list {
    margin-top: 35px;
    margin-bottom: 25px; } }
@media only screen and (min-width: 751px) {
  #privacy_policy .area {
    margin-top: 70px; }
  #privacy_policy h3 {
    font-size: 16px;
    font-weight: bold;
    margin-bottom: 5px; }
  #privacy_policy ol {
    margin-bottom: 15px; } }
@media only screen and (max-width: 750px) {
  #privacy_policy .btn.submit {
    height: 50px;
    line-height: 50px; }
  #privacy_policy .area {
    margin-top: 20px; }
  #privacy_policy h3 {
    font-size: 16px;
    font-weight: bold;
    margin-bottom: 8px; }
  #privacy_policy ol {
    margin-bottom: 20px; } }
@media only screen and (min-width: 751px) {
  #complete .cancel_area {
    text-align: center;
    border: solid 1px #ece9e9;
    padding: 45px 0px 40px;
    margin-top: 70px; }
    #complete .cancel_area p.tit {
      font-weight: bold;
      font-size: 18px; }
    #complete .cancel_area p.number {
      background-color: #f2f2f0;
      width: 590px;
      height: 70px;
      line-height: 70px;
      margin: 20px auto 28px;
      font-weight: bold;
      font-size: 18px; }
    #complete .cancel_area p.text {
      line-height: 26px; }
    #complete .cancel_area a {
      margin-top: 20px;
      display: block;
      text-decoration: underline;
      color: #a76a11; }
      #complete .cancel_area a:hover {
        text-decoration: none; }
  #complete .btn_list {
    margin-top: 60px; }

  #complete .btn_list_sub {
    margin-top: 0px; }
}
@media only screen and (max-width: 750px) {
  #complete .btn.submit {
    height: 50px;
    line-height: 50px; }
  #complete .cancel_area {
    text-align: center;
    border: solid 1px #ece9e9;
    padding: 22px 0px;
    margin-top: 25px; }
    #complete .cancel_area p.tit {
      font-weight: bold;
      font-size: 16px; }
    #complete .cancel_area p.number {
      background-color: #f2f2f0;
      height: 55px;
      line-height: 55px;
      margin: 17px 20px 20px;
      font-weight: bold;
      font-size: 16px; }
    #complete .cancel_area p.text {
      text-align: left;
      line-height: 25px;
      margin: 0 20px; }
    #complete .cancel_area a {
      margin-top: 10px;
      display: block;
      text-decoration: underline;
      color: #a76a11; }
      #complete .cancel_area a:hover {
        text-decoration: none; }
  #complete .btn_list {
    margin-top: 35px;
    margin-bottom: 30px; }
  #complete .btn_list_sub {
    margin-top: 35px;
    margin-bottom: 30px;
    margin-left: 20px;
    margin-right: 20px;}}
@media only screen and (min-width: 751px) {
  .step_title {
    width: 738px;
    line-height: 30px;
    font-size: 17px;
    text-align: center;
    color: red;
    margin: auto;
    padding: 20px;
    border-style: solid;
    border-width: 1px; }

  .step_title_outside {
    width: 780px;
    line-height: 30px;
    font-size: 24px;
    text-align: center;
    color: red;
    margin: 10px auto;
    padding: 3px;
    border-style: solid; }

  .msg_title {
    width: 580px;
    line-height: 30px;
    font-size: 24px;
    text-align: center;
    color: red;
    margin: 10px auto;
    padding: 3px; } }
@media only screen and (max-width: 750px) {
  .step_title {
    border-radius: 0;
    line-height: 25px;
    font-size: 16px;
    text-align: center;
    color: red;
    margin: auto;
    border-style: solid;
    border-width: 1px;
    padding: 15px; }

  .step_title_outside {
    width: 95%;
    line-height: 30px;
    font-size: 18px;
    text-align: center;
    color: red;
    margin: 10px auto;
    border-style: solid;
    padding: 3px; }

  .msg_title {
    width: 95%;
    line-height: 30px;
    font-size: 18px;
    text-align: center;
    color: red;
    margin: 10px auto;
    padding: 3px; } }
  /* page_title 20171124
-------------------------------------------------- */
.sll_des {
  font-size: 18px; }

.shop_no_category {
  display: none;
  font-size: 16px; }
.shop_no_category.show {
  display: block; }

.sat_color {
  background: #D9F9FF; }

.sun_color {
  background: #FFD9D9; }