@charset "UTF-8";
body {
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック  Medium', meiryo, sans-serif;
  font-size: 1.2rem;
  line-height: 1.7; }
  @media (max-width: 767px) {
    body {
      font-size: 1rem;
      line-height: 1.75; } }

#copyMessage {
  visibility: hidden;
  color: green;
  margin-top: 5px; }

.small {
  font-size: .8rem;
  display: inline-block; }

.fr-title01 {
  font-size: 1.2rem;
  text-align: center;
  margin-bottom: 1rem; }
.fr-box {
  margin-bottom: 4.5rem; }
  .fr-box h2 {
    font-size: 1.5rem;
    font-weight: bold;
    margin-bottom: 2rem;
    text-align: center; }
    @media (max-width: 575px) {
      .fr-box h2 {
        font-size: 1.2rem; } }
    .fr-box h2 span {
      border-bottom: 1px solid #212529;
      padding-bottom: .5rem; }
    .fr-box h2 + p {
      font-size: 1rem; }
  .fr-box .urlbox {
    font-size: 1.3rem;
    background: #fff;
    margin-bottom: 1rem;
    padding: .7rem 1rem;
    text-align: center; }
    @media (max-width: 575px) {
      .fr-box .urlbox {
        font-size: 1.2rem; } }
  .fr-box .urlbtn {
    font-size: 1.4rem;
    text-align: center;
    width: 100%;
    font-weight: bold;
    background: #faa01e;
    padding: 1rem 0;
    border: 4px solid #fff;
    color: #fff;
    border-radius: 40px; }
    @media (max-width: 575px) {
      .fr-box .urlbtn {
        font-size: 1.3rem;
        padding: .8rem 0; } }
.fr-container {
  width: 620px;
  margin: 0 auto; }
  @media (max-width: 575px) {
    .fr-container {
      width: 100%;
      padding-right: 1.2rem;
      padding-left: 1.2rem; } }
.fr-inner {
  padding: 0 1rem; }
.fr-bg {
  background: #f1edea;
  padding-bottom: 2rem; }
.fr-top {
  margin-bottom: 4rem; }
.fr-imgbox {
  margin-right: -1rem;
  margin-left: -1rem; }
.fr-flowtitle {
  text-align: center;
  font-size: 1.4rem;
  margin-bottom: 2rem; }
  @media (max-width: 575px) {
    .fr-flowtitle {
      font-size: 1.2rem;
      margin-bottom: 1.5rem; } }
  .fr-flowtitle + table {
    background: #fff;
    border-top: 1px solid #c7b3b3;
    border-right: 1px solid #c7b3b3;
    border-left: 1px solid #c7b3b3;
    font-size: 1rem;
    margin-bottom: 2rem; }
    @media (max-width: 575px) {
      .fr-flowtitle + table {
        font-size: .9rem; } }
    .fr-flowtitle + table td {
      border-bottom: 1px solid #c7b3b3;
      padding: 1rem; }
    .fr-flowtitle + table th {
      border-bottom: 1px solid #c7b3b3;
      padding: 1rem 0 1rem 1rem; }
    .fr-flowtitle + table th .step {
      color: #9c8282; }
      .fr-flowtitle + table th .step span {
        font-size: 200%;
        padding-right: 1rem;
        border-right: 1px solid #e8cfcf; }
        @media (max-width: 575px) {
          .fr-flowtitle + table th .step span {
            padding-right: .8rem; } }
.fr-imgbox01 {
  margin-top: 7rem;
  margin-bottom: 3rem; }
  @media (max-width: 575px) {
    .fr-imgbox01 {
      margin-top: 5rem;
      margin-bottom: 2rem; } }
.fr-imgbox02 {
  padding-top: 3rem;
  padding-bottom: 3rem; }
  @media (max-width: 575px) {
    .fr-imgbox02 {
      padding-top: 1rem;
      padding-bottom: 1rem; } }
.fr-rule {
  font-size: 1rem;
  margin-bottom: 2.5rem; }
  @media (max-width: 575px) {
    .fr-rule {
      font-size: .85rem; } }
  .fr-rule h2 {
    text-align: center;
    font-size: 1.2rem;
    margin-bottom: 1.5rem; }
  .fr-rule dl {
    margin: 1.5rem 0; }
  .fr-rule dt {
    margin-bottom: .8rem;
    border-bottom: 1px solid #4d4d4d; }
  .fr-rule dd {
    margin-bottom: 1.5rem; }
    .fr-rule dd li {
      margin-bottom: .5rem; }
  .fr-rule-box {
    overflow-y: auto;
    overflow-x: hidden;
    height: 400px;
    background: #f5f5f5;
    padding: 1.2rem; }

.fr-qa {
  margin-bottom: 4rem;
  padding: 4rem 0 0 0; }
  @media (max-width: 767px) {
    .fr-qa {
      padding: 3rem 0 0 0; } }
  .fr-qa .accordion-body {
    padding: 1.5rem;
    background: #f5f9ff; }
  .fr-qa h2 {
    font-weight: bold;
    font-size: 1.4rem;
    text-align: center;
    margin-bottom: 2rem; }
    @media (max-width: 575px) {
      .fr-qa h2 {
        font-size: 1.2rem;
        margin-bottom: 2rem; } }
    .fr-qa h2 span {
      display: block;
      font-weight: normal;
      text-align: center;
      font-size: 1rem; }
  .fr-qa h3 {
    font-weight: bold;
    font-size: 1.2rem;
    margin-bottom: 1rem;
    border-left: 5px solid #505050;
    padding-left: 1rem;
    color: #505050; }
    @media (max-width: 575px) {
      .fr-qa h3 {
        font-size: 1.1rem; } }
  .fr-qa h4 {
    margin: 0;
    background-color: #fff;
    position: relative;
    line-height: 1.5 !important; }
    .fr-qa h4 button {
      width: 100%;
      text-align: left;
      background: none;
      border: none;
      font-size: 1rem;
      color: #282828;
      padding-left: 2.5rem; }
      .fr-qa h4 button:before {
        content: "Q.";
        position: absolute;
        top: 1rem;
        left: 1rem;
        font-size: 1rem; }
      .fr-qa h4 button:focus {
        outline: none !important; }
  .fr-qa .accordion-body {
    font-size: 1rem;
    padding-left: 2.5rem;
    position: relative; }
    .fr-qa .accordion-body:before {
      content: "A.";
      position: absolute;
      top: 1.5rem;
      left: 1rem;
      font-size: 1rem; }

footer {
  text-align: center;
  font-size: .9rem; }
  @media (max-width: 575px) {
    footer {
      font-size: .85rem; } }

#fixCta {
  position: fixed;
  bottom: 13px;
  right: 10px;
  width: 50px;
  height: 50px;
  z-index: 998; }
  #fixCta a {
    width: 100%;
    height: 100%;
    background-color: #faa01e;
    position: relative;
    display: block;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    -webkit-animation: fuwafuwa 2s infinite linear alternate;
    animation: fuwafuwa 2s infinite linear alternate; }
    #fixCta a:before {
      content: '';
      position: absolute;
      width: 0;
      height: 0;
      border-left: 8px solid transparent;
      border-right: 8px solid transparent;
      border-bottom: 12px solid white; }

@-webkit-keyframes fuwafuwa {
  0% {
    -webkit-transform: translateY(0); }
  50% {
    -webkit-transform: translateY(-10px); }
  100% {
    -webkit-transform: translateY(0); } }
@keyframes fuwafuwa {
  0% {
    transform: translateY(0); }
  50% {
    transform: translateY(-10px); }
  100% {
    transform: translateY(0); } }
