@charset "UTF-8";
.kv {
  position: relative;
  margin: 0 auto 0;
  width: 100%;
  background-image: url("../img/bg_kv_sp.png");
  background-position: top center;
  background-repeat: no-repeat;
  background-size: 100% auto;
  padding: calc(88/750 * 100vw) 0 0 0;
  text-align: left; }
  @media only screen and (min-width: 750px) {
    .kv {
      background-image: url("../img/bg_kv_pc.png");
      padding: calc(84/1100 * 100vw) 0 0 0; } }
  @media only screen and (min-width: 1100px) {
    .kv {
      width: 1100px;
      padding: 84px 0 0; } }
  .kv .logo {
    position: absolute;
    width: calc(216/750 * 100vw);
    top: calc(24/750 * 100vw);
    left: calc(56/750 * 100vw); }
    @media only screen and (min-width: 750px) {
      .kv .logo {
        width: calc(265/1100 * 100vw);
        top: calc(24/1100 * 100vw);
        left: calc(78/1100 * 100vw); } }
    @media only screen and (min-width: 1100px) {
      .kv .logo {
        width: 265px;
        top: 24px;
        left: 78px; } }
  .kv h1 {
    width: calc(637/750 * 100vw);
    margin: 0 auto; }
    @media only screen and (min-width: 750px) {
      .kv h1 {
        width: calc(752/1100 * 100vw);
        margin: 0 auto; } }
    @media only screen and (min-width: 1100px) {
      .kv h1 {
        width: 752px;
        margin: 0 auto; } }
  .kv .period_wrap {
    width: calc(632/750 * 100vw);
    margin: calc(160/750 * 100vw) auto 0;
    border-top: solid 1px #00145a;
    padding: calc(30/750 * 100vw) 0 0; }
    @media only screen and (min-width: 750px) {
      .kv .period_wrap {
        width: calc(890/1100 * 100vw);
        margin: calc(142/1100 * 100vw) auto 0;
        padding: 0;
        border: none; } }
    @media only screen and (min-width: 1100px) {
      .kv .period_wrap {
        width: 860px;
        margin: 142px auto 0; } }
    .kv .period_wrap .period {
      width: calc(572/750 * 100vw);
      margin: 0 auto 0; }
      @media only screen and (min-width: 750px) {
        .kv .period_wrap .period {
          width: calc(890/1100 * 100vw);
          margin: 0 auto 0; } }
      @media only screen and (min-width: 1100px) {
        .kv .period_wrap .period {
          width: 890px;
          margin: 0 auto 0; } }
    .kv .period_wrap .period_note {
      width: 38em;
      font-size: calc(17/750 * 100vw);
      line-height: 1.4em;
      padding-left: 1em;
      text-indent: -1em;
      margin: 2em auto 0; }
      @media only screen and (min-width: 750px) {
        .kv .period_wrap .period_note {
          width: calc(890/1100 * 100vw);
          text-align: left;
          font-size: calc(12.2/1100 * 100vw); } }
      @media only screen and (min-width: 1100px) {
        .kv .period_wrap .period_note {
          width: 890px;
          font-size: 1.22rem; } }

.prod {
  background: #FFF;
  width: calc(662/750 * 100vw);
  margin: calc(68/750 * 100vw) auto 0; }
  @media only screen and (min-width: 750px) {
    .prod {
      width: calc(958/1100 * 100vw);
      margin: calc(55/1100 * 100vw) auto 0; } }
  @media only screen and (min-width: 1100px) {
    .prod {
      width: 958px;
      margin: 55px auto 0; } }
  .prod .h2_prod {
    display: flex;
    justify-content: center;
    align-items: center;
    background: #00145a;
    width: 100%;
    height: calc(53/750 * 100vw);
    margin: 0; }
    @media only screen and (min-width: 750px) {
      .prod .h2_prod {
        height: calc(53/1100 * 100vw); } }
    @media only screen and (min-width: 1100px) {
      .prod .h2_prod {
        height: 53px; } }
    .prod .h2_prod img {
      width: calc(153/750 * 100vw);
      margin: 0 auto 0; }
      @media only screen and (min-width: 750px) {
        .prod .h2_prod img {
          width: calc(153/1100 * 100vw); } }
      @media only screen and (min-width: 1100px) {
        .prod .h2_prod img {
          width: 153px; } }
  .prod .prod_wrap {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-wrap: wrap;
    width: calc(556/750 * 100vw);
    margin: calc(58/750 * 100vw) auto 0; }
    @media only screen and (min-width: 750px) {
      .prod .prod_wrap {
        width: calc(840/1100 * 100vw);
        margin: calc(45/1100 * 100vw) auto 0;
        padding: 0;
        border: none; } }
    @media only screen and (min-width: 1100px) {
      .prod .prod_wrap {
        width: 840px;
        margin: 45px auto 0; } }
    .prod .prod_wrap li {
      width: calc(247/750 * 100vw);
      margin: 0 0 calc(58/750 * 100vw); }
      @media only screen and (min-width: 750px) {
        .prod .prod_wrap li {
          width: calc(247/1100 * 100vw);
          margin-bottom: calc(48/1100 * 100vw); } }
      @media only screen and (min-width: 1100px) {
        .prod .prod_wrap li {
          width: 247px;
          margin-bottom: 48px; } }
      .prod .prod_wrap li .detail {
        display: block;
        width: calc(202/750 * 100vw);
        margin: calc(11/750 * 100vw) auto 0; }
        @media only screen and (min-width: 750px) {
          .prod .prod_wrap li .detail {
            width: calc(202/1100 * 100vw);
            margin: calc(11/1100 * 100vw) auto 0; } }
        @media only screen and (min-width: 1100px) {
          .prod .prod_wrap li .detail {
            width: 202px;
            margin: 11px auto 0; } }
      .prod .prod_wrap li.prod_note {
        width: 100%; }
        @media only screen and (min-width: 750px) {
          .prod .prod_wrap li.prod_note {
            align-self: flex-end;
            width: calc(552/1100 * 100vw); } }
        @media only screen and (min-width: 1100px) {
          .prod .prod_wrap li.prod_note {
            width: 552px; } }
        .prod .prod_wrap li.prod_note p {
          width: 100%;
          font-size: calc(17/750 * 100vw);
          line-height: 1.4em;
          padding-left: 1em;
          text-indent: -1em;
          margin: 0.5em auto 0; }
          @media only screen and (min-width: 750px) {
            .prod .prod_wrap li.prod_note p {
              width: 100%;
              text-align: left;
              font-size: calc(15/1100 * 100vw); } }
          @media only screen and (min-width: 1100px) {
            .prod .prod_wrap li.prod_note p {
              font-size: 1.5rem; } }
      .prod .prod_wrap li .not {
        font-size: calc(12/750 * 100vw);
        line-height: 1.2em;
        margin-top: 0.5em; }
        @media only screen and (min-width: 750px) {
          .prod .prod_wrap li .not {
            font-size: calc(12/1100 * 100vw); } }
        @media only screen and (min-width: 1100px) {
          .prod .prod_wrap li .not {
            font-size: 1.2rem; } }

.prize {
  background: #FFF;
  width: calc(662/750 * 100vw);
  margin: calc(68/750 * 100vw) auto 0;
  padding: 0 0 calc(35/750 * 100vw); }
  @media only screen and (min-width: 750px) {
    .prize {
      width: calc(958/1100 * 100vw);
      margin: calc(55/1100 * 100vw) auto 0;
      padding: 0 0 calc(35/1100 * 100vw); } }
  @media only screen and (min-width: 1100px) {
    .prize {
      width: 958px;
      margin: 55px auto 0;
      padding: 0 0 35px; } }
  .prize .h2_prize {
    display: flex;
    justify-content: center;
    align-items: center;
    background: #00145a;
    width: 100%;
    height: calc(53/750 * 100vw);
    margin: 0; }
    @media only screen and (min-width: 750px) {
      .prize .h2_prize {
        height: calc(53/1100 * 100vw); } }
    @media only screen and (min-width: 1100px) {
      .prize .h2_prize {
        height: 53px; } }
    .prize .h2_prize img {
      width: calc(74/750 * 100vw);
      margin: 0 auto 0; }
      @media only screen and (min-width: 750px) {
        .prize .h2_prize img {
          width: calc(74/1100 * 100vw); } }
      @media only screen and (min-width: 1100px) {
        .prize .h2_prize img {
          width: 74px; } }
  .prize .prize_lead {
    width: calc(446/750 * 100vw);
    margin: calc(34/750 * 100vw) auto 0; }
    @media only screen and (min-width: 750px) {
      .prize .prize_lead {
        width: calc(681/1100 * 100vw);
        margin: calc(42/1100 * 100vw) auto 0; } }
    @media only screen and (min-width: 1100px) {
      .prize .prize_lead {
        width: 681px;
        margin: 42px auto 0; } }
  .prize .prize_lineup {
    width: calc(574/750 * 100vw);
    margin: calc(40/750 * 100vw) auto 0;
    border: solid 1px #000;
    border-radius: calc(33/750 * 100vw);
    overflow: hidden; }
    @media only screen and (min-width: 750px) {
      .prize .prize_lineup {
        width: calc(830/1100 * 100vw);
        margin: calc(40/1100 * 100vw) auto 0;
        border-radius: calc(33/1100 * 100vw); } }
    @media only screen and (min-width: 1100px) {
      .prize .prize_lineup {
        width: 830px;
        margin: 40px auto 0;
        border-radius: 33px; } }
  .prize .prize_md {
    width: calc(556/750 * 100vw);
    font-size: calc(20/750 * 100vw);
    margin: 1.5em auto 0; }
    @media only screen and (min-width: 750px) {
      .prize .prize_md {
        width: calc(800/1100 * 100vw);
        text-align: left;
        font-size: calc(18/1100 * 100vw); } }
    @media only screen and (min-width: 1100px) {
      .prize .prize_md {
        width: 800px;
        font-size: 1.8rem; } }
  .prize .prize_note {
    width: calc(556/750 * 100vw);
    margin: calc(10/750 * 100vw) auto 0; }
    @media only screen and (min-width: 750px) {
      .prize .prize_note {
        width: calc(800/1100 * 100vw);
        margin: calc(10/1100 * 100vw) auto 0; } }
    @media only screen and (min-width: 1100px) {
      .prize .prize_note {
        width: 800px;
        margin: 10px auto 0; } }
    .prize .prize_note li {
      list-style: disc;
      font-size: calc(17/750 * 100vw);
      line-height: 1.3em;
      padding-left: 0.2em;
      margin: 0.5em auto 0 1.2em; }
      @media only screen and (min-width: 750px) {
        .prize .prize_note li {
          width: 100%;
          text-align: left;
          font-size: calc(15/1100 * 100vw); } }
      @media only screen and (min-width: 1100px) {
        .prize .prize_note li {
          font-size: 1.5rem; } }

.method {
  background: #FFF;
  width: calc(662/750 * 100vw);
  margin: calc(68/750 * 100vw) auto 0;
  padding: 0 0 0; }
  @media only screen and (min-width: 750px) {
    .method {
      width: calc(958/1100 * 100vw);
      margin: calc(55/1100 * 100vw) auto 0;
      padding: 0 0 0; } }
  @media only screen and (min-width: 1100px) {
    .method {
      width: 958px;
      margin: 55px auto 0;
      padding: 0 0 0; } }
  .method .h2_method {
    display: flex;
    justify-content: center;
    align-items: center;
    background: #00145a;
    width: 100%;
    height: calc(53/750 * 100vw);
    margin: 0; }
    @media only screen and (min-width: 750px) {
      .method .h2_method {
        height: calc(53/1100 * 100vw); } }
    @media only screen and (min-width: 1100px) {
      .method .h2_method {
        height: 53px; } }
    .method .h2_method img {
      width: calc(154/750 * 100vw);
      margin: 0 auto 0; }
      @media only screen and (min-width: 750px) {
        .method .h2_method img {
          width: calc(154/1100 * 100vw); } }
      @media only screen and (min-width: 1100px) {
        .method .h2_method img {
          width: 154px; } }
  .method .method_wrap {
    width: calc(606/750 * 100vw);
    margin: 0 auto 0; }
    @media only screen and (min-width: 750px) {
      .method .method_wrap {
        width: calc(852/1100 * 100vw); } }
    @media only screen and (min-width: 1100px) {
      .method .method_wrap {
        width: 852px; } }
    .method .method_wrap li {
      padding: calc(42/750 * 100vw) calc(20/750 * 100vw) calc(42/750 * 100vw); }
      @media only screen and (min-width: 750px) {
        .method .method_wrap li {
          padding: calc(45/1100 * 100vw) calc(8/1100 * 100vw) calc(35/1100 * 100vw); } }
      @media only screen and (min-width: 1100px) {
        .method .method_wrap li {
          padding: 45px 8px 35px; } }
      .method .method_wrap li .step_no {
        height: calc(41/750 * 100vw); }
        @media only screen and (min-width: 750px) {
          .method .method_wrap li .step_no {
            height: calc(41/1100 * 100vw); } }
        @media only screen and (min-width: 1100px) {
          .method .method_wrap li .step_no {
            height: 41px; } }
        .method .method_wrap li .step_no img {
          width: auto;
          height: 100%; }
      .method .method_wrap li p {
        margin-top: 1.5em;
        font-size: calc(20/750 * 100vw);
        line-height: 1.5em; }
        @media only screen and (min-width: 750px) {
          .method .method_wrap li p {
            font-size: calc(20/1100 * 100vw); } }
        @media only screen and (min-width: 1100px) {
          .method .method_wrap li p {
            font-size: 2rem; } }
      .method .method_wrap li .method_kome li {
        list-style: none;
        background: none;
        margin: 1.2em 0 0 0;
        padding: 0 0 0 1em;
        text-indent: -1em;
        font-size: calc(17/750 * 100vw);
        line-height: 1.3em; }
        @media only screen and (min-width: 750px) {
          .method .method_wrap li .method_kome li {
            font-size: calc(15/1100 * 100vw); } }
        @media only screen and (min-width: 1100px) {
          .method .method_wrap li .method_kome li {
            font-size: 1.5rem; } }
      .method .method_wrap li .method_kome li + li {
        margin-top: 0.5em; }
      .method .method_wrap li .method_notice {
        width: calc(524/750 * 100vw);
        margin: calc(42/750 * 100vw) auto 0; }
        @media only screen and (min-width: 750px) {
          .method .method_wrap li .method_notice {
            width: calc(736/1100 * 100vw);
            margin: calc(35/1100 * 100vw) auto 0; } }
        @media only screen and (min-width: 1100px) {
          .method .method_wrap li .method_notice {
            width: 736px;
            margin: 35px auto 0; } }
      .method .method_wrap li h4 {
        display: flex;
        justify-content: center;
        align-items: center;
        border: solid 1px #787878;
        height: calc(41/750 * 100vw);
        color: #787878;
        font-size: calc(19/750 * 100vw);
        margin-top: 2em; }
        @media only screen and (min-width: 750px) {
          .method .method_wrap li h4 {
            height: calc(41/1100 * 100vw);
            font-size: calc(19/1100 * 100vw); } }
        @media only screen and (min-width: 1100px) {
          .method .method_wrap li h4 {
            height: 41px;
            font-size: 1.9rem; } }
      .method .method_wrap li .method_lead {
        text-align: center;
        margin: calc(21/750 * 100vw) auto 0;
        line-height: 0; }
        @media only screen and (min-width: 750px) {
          .method .method_wrap li .method_lead {
            margin: calc(21/1100 * 100vw) auto 0; } }
        @media only screen and (min-width: 1100px) {
          .method .method_wrap li .method_lead {
            margin: 21px auto 0; } }
        .method .method_wrap li .method_lead img {
          height: calc(21/750 * 100vw);
          width: auto; }
          @media only screen and (min-width: 750px) {
            .method .method_wrap li .method_lead img {
              height: calc(21/1100 * 100vw); } }
          @media only screen and (min-width: 1100px) {
            .method .method_wrap li .method_lead img {
              height: 21px; } }
          .method .method_wrap li .method_lead img.twoline {
            height: calc(48/750 * 100vw);
            width: auto; }
            @media only screen and (min-width: 750px) {
              .method .method_wrap li .method_lead img.twoline {
                height: calc(21/1100 * 100vw); } }
            @media only screen and (min-width: 1100px) {
              .method .method_wrap li .method_lead img.twoline {
                height: 21px; } }
      .method .method_wrap li .receipt {
        text-align: left;
        margin: calc(25/750 * 100vw) auto 0; }
        @media only screen and (min-width: 750px) {
          .method .method_wrap li .receipt {
            margin: calc(25/1100 * 100vw) auto 0; } }
        @media only screen and (min-width: 1100px) {
          .method .method_wrap li .receipt {
            margin: 25px auto 0; } }
      .method .method_wrap li .patern {
        text-align: left;
        margin: calc(25/750 * 100vw) auto 0; }
        @media only screen and (min-width: 750px) {
          .method .method_wrap li .patern {
            margin: calc(25/1100 * 100vw) auto 0; } }
        @media only screen and (min-width: 1100px) {
          .method .method_wrap li .patern {
            margin: 25px auto 0; } }
        .method .method_wrap li .patern img {
          width: calc(526/750 * 100vw); }
          @media only screen and (min-width: 750px) {
            .method .method_wrap li .patern img {
              width: calc(526/1100 * 100vw); } }
          @media only screen and (min-width: 1100px) {
            .method .method_wrap li .patern img {
              width: 526px; } }
    .method .method_wrap li + li {
      background-image: url("../img/dot_sp.svg");
      background-size: 100% auto;
      background-repeat: no-repeat;
      background-position: top center; }
      @media only screen and (min-width: 750px) {
        .method .method_wrap li + li {
          background-image: url("../img/dot_pc.svg"); } }

.inquiry {
  background: #FFF;
  width: calc(662/750 * 100vw);
  margin: calc(68/750 * 100vw) auto 0; }
  @media only screen and (min-width: 750px) {
    .inquiry {
      width: calc(958/1100 * 100vw);
      margin: calc(55/1100 * 100vw) auto 0; } }
  @media only screen and (min-width: 1100px) {
    .inquiry {
      width: 958px;
      margin: 55px auto 0; } }
  .inquiry .h2_inquiry {
    display: flex;
    justify-content: center;
    align-items: center;
    background: #00145a;
    width: 100%;
    height: calc(53/750 * 100vw);
    margin: 0; }
    @media only screen and (min-width: 750px) {
      .inquiry .h2_inquiry {
        height: calc(53/1100 * 100vw); } }
    @media only screen and (min-width: 1100px) {
      .inquiry .h2_inquiry {
        height: 53px; } }
    .inquiry .h2_inquiry img {
      width: calc(153/750 * 100vw);
      margin: 0 auto 0; }
      @media only screen and (min-width: 750px) {
        .inquiry .h2_inquiry img {
          width: calc(153/1100 * 100vw); } }
      @media only screen and (min-width: 1100px) {
        .inquiry .h2_inquiry img {
          width: 153px; } }
  .inquiry .inquiry_wrap {
    width: 100%;
    padding: calc(15/750 * 100vw) 0 calc(25/750 * 100vw); }
    @media only screen and (min-width: 750px) {
      .inquiry .inquiry_wrap {
        padding: calc(30/1100 * 100vw);
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
        align-items: baseline; } }
    @media only screen and (min-width: 1100px) {
      .inquiry .inquiry_wrap {
        padding: 30px; } }
    .inquiry .inquiry_wrap li {
      text-align: center; }
      .inquiry .inquiry_wrap li h3 {
        color: #4b4b4b;
        text-align: center;
        font-size: calc(28/750 * 100vw); }
        @media only screen and (min-width: 750px) {
          .inquiry .inquiry_wrap li h3 {
            font-size: calc(24/1100 * 100vw); } }
        @media only screen and (min-width: 1100px) {
          .inquiry .inquiry_wrap li h3 {
            font-size: 2.4rem; } }
      .inquiry .inquiry_wrap li .freecall {
        width: calc(496/750 * 100vw);
        margin: calc(8/750 * 100vw) auto 0; }
        @media only screen and (min-width: 750px) {
          .inquiry .inquiry_wrap li .freecall {
            width: calc(425/1100 * 100vw);
            margin: 0 0 0 calc(25/750 * 100vw); } }
        @media only screen and (min-width: 1100px) {
          .inquiry .inquiry_wrap li .freecall {
            width: 425px;
            margin: 0 0 0 25px; } }
      .inquiry .inquiry_wrap li.inquiry_receipt {
        width: calc(554/750 * 100vw);
        margin: calc(20/750 * 100vw) auto 0; }
        @media only screen and (min-width: 750px) {
          .inquiry .inquiry_wrap li.inquiry_receipt {
            width: calc(810/1100 * 100vw);
            margin: calc(18/1100 * 100vw) auto 0; } }
        @media only screen and (min-width: 1100px) {
          .inquiry .inquiry_wrap li.inquiry_receipt {
            width: 810px;
            margin: 18px auto 0; } }

.terms_btn {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: calc(68/750 * 100vw) auto 0;
  width: calc(672/750 * 100vw);
  height: calc(53/750 * 100vw);
  background-color: #00145a;
  background-image: url("../img/bt_open.svg");
  background-position: right 3.6vw center;
  background-size: calc(30/750 * 100vw) auto;
  background-repeat: no-repeat;
  text-align: center;
  line-height: 0; }
  @media only screen and (min-width: 750px) {
    .terms_btn {
      margin: calc(40/1100 * 100vw) auto 0;
      width: calc(960/1100 * 100vw);
      height: calc(53/1100 * 100vw);
      padding: calc(10/1100 * 100vw) 0;
      background-position: right calc(30/1100 * 100vw) center;
      background-size: calc(30/1100 * 100vw) auto; } }
  @media only screen and (min-width: 1100px) {
    .terms_btn {
      margin: 40px auto 0;
      width: 960px;
      height: 53px;
      padding: 10px 0;
      background-position: right 30px center;
      background-size: 30px auto; } }
  .terms_btn.active {
    background-image: url("../img/bt_close.svg"); }
  @media only screen and (min-width: 750px) {
    .terms_btn:hover {
      opacity: 1;
      cursor: pointer; } }
  .terms_btn img {
    width: calc(154/750 * 100vw);
    margin: 0 auto; }
    @media only screen and (min-width: 750px) {
      .terms_btn img {
        width: calc(154/1100 * 100vw); } }
    @media only screen and (min-width: 1100px) {
      .terms_btn img {
        width: 154px; } }
.terms_cont {
  display: none;
  background-color: #fff;
  margin: 0 auto 0;
  width: calc(672/750 * 100vw);
  padding: 1.2em; }
  @media only screen and (min-width: 750px) {
    .terms_cont {
      margin: 0 auto 0;
      width: calc(960/1100 * 100vw);
      padding: 2em 3em; } }
  @media only screen and (min-width: 1100px) {
    .terms_cont {
      margin: 0px auto 0;
      width: 960px; } }
  .terms_cont h3 {
    font-size: calc(25/750 * 100vw);
    margin: 1em 0 0.75em 0; }
    @media only screen and (min-width: 750px) {
      .terms_cont h3 {
        font-size: calc(18/1100 * 100vw); } }
    @media only screen and (min-width: 1100px) {
      .terms_cont h3 {
        font-size: 1.8rem; } }
  .terms_cont p, .terms_cont li {
    font-size: calc(23/750 * 100vw);
    line-height: 1.3;
    margin-bottom: 0.5em;
    text-align: justify; }
    @media only screen and (min-width: 750px) {
      .terms_cont p, .terms_cont li {
        font-size: calc(16/1100 * 100vw); } }
    @media only screen and (min-width: 1100px) {
      .terms_cont p, .terms_cont li {
        font-size: 1.6rem; } }
  .terms_cont ul {
    margin-bottom: 1em; }
  .terms_cont li {
    padding-left: 1.25em;
    text-indent: -1.25em; }
  .terms_cont li ul {
    margin: 1em 0 1em 0; }
  .terms_cont .kome {
    padding-left: 1em;
    text-indent: -1em; }

.footer {
  background: #FFF;
  margin: calc(50/750 * 100vw) auto 0;
  width: 100%;
  font-size: calc(19/750 * 100vw);
  padding: 1.2em 0 1.5em; }
  @media only screen and (min-width: 750px) {
    .footer {
      font-size: calc(19/1100 * 100vw);
      margin: calc(50/1100 * 100vw) auto 0; } }
  @media only screen and (min-width: 1100px) {
    .footer {
      font-size: 1.9rem;
      margin: 50px auto 0; } }
  .footer .copy {
    padding: 0;
    margin: 0 auto;
    text-align: center;
    font-size: calc(19/750 * 100vw); }
    @media only screen and (min-width: 750px) {
      .footer .copy {
        font-size: calc(19/1100 * 100vw); } }
    @media only screen and (min-width: 1100px) {
      .footer .copy {
        font-size: 1.9rem; } }
    .footer .copy a {
      text-decoration: none;
      color: #000; }
      .footer .copy a:hover {
        text-decoration: underline; }

html {
  font-size: 62.5%;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", YuGothic, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, "Hiragino Sans", Arial, 'Yu Gothic', "メイリオ", Meiryo, sans-serif;
  word-wrap: break-word; }

body {
  font-size: 1.6rem;
  margin: 0;
  padding: 0;
  background-image: url("../img/bg_sp.jpg");
  background-size: 100% auto; }
  @media only screen and (min-width: 750px) {
    body {
      background-image: url("../img/bg_pc.jpg");
      background-size: calc(2000/1100 * 100vw) auto;
      height: calc(230/1100 * 100vw); } }
  @media only screen and (min-width: 1100px) {
    body {
      height: 230px;
      background-size: 2000px auto; } }
  @media only screen and (min-width: 2000px) {
    body {
      background-size: 100% auto; } }

*,
*::before,
*::after {
  box-sizing: border-box; }

h1, h2, h3, div, p, ul, li {
  margin: 0;
  padding: 0; }

li {
  list-style: none; }

img {
  width: 100%;
  height: auto;
  line-height: 0;
  vertical-align: bottom; }

a:hover img {
  opacity: 0.8; }

.pcOnly {
  display: none; }
  @media only screen and (min-width: 750px) {
    .pcOnly {
      display: inline; } }

.spOnly {
  display: inline; }
  @media only screen and (min-width: 750px) {
    .spOnly {
      display: none; } }

@media only screen and (min-width: 420px) {
  a[href*="tel:"] {
    pointer-events: none;
    cursor: default;
    text-decoration: none; } }
.wrap .apply_bt {
  width: calc(474/750 * 100vw);
  margin: calc(60/750 * 100vw) auto 0; }
  @media only screen and (min-width: 750px) {
    .wrap .apply_bt {
      width: calc(754/1100 * 100vw);
      margin: calc(45/1100 * 100vw) auto 0; } }
  @media only screen and (min-width: 1100px) {
    .wrap .apply_bt {
      width: 754px;
      margin: 45px auto 0; } }
.wrap #ptop {
  position: fixed;
  bottom: -18vw;
  right: 3vw;
  width: 13.2vw;
  transition: all 0.5s ease; }
  @media only screen and (min-width: 750px) {
    .wrap #ptop {
      bottom: calc(-150/1100 * 100%);
      right: calc(15/1100 * 100%);
      width: calc(99/1100 * 100%);
      cursor: pointer; } }
  @media only screen and (min-width: 1100px) {
    .wrap #ptop {
      bottom: -150px;
      right: 30px;
      width: 99px; } }
  .wrap #ptop.active {
    bottom: 3vw; }
    @media only screen and (min-width: 750px) {
      .wrap #ptop.active {
        bottom: calc(25/1100 * 100%); } }
    @media only screen and (min-width: 1100px) {
      .wrap #ptop.active {
        bottom: 25px; } }
