@charset "UTF-8";
/****************************************************
 * リセット
 ****************************************************/
/****************************************************
 * リセット
 ****************************************************/
/*
 html5doctor.com Reset Stylesheet
 v1.6.1
 Last Updated: 2010-09-17
 Author: Richard Clark - http://richclarkdesign.com
 Twitter: @rich_clark
 */
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent; }

body {
  min-width: 300px;
  line-height: 1; }

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block; }

nav ul {
  list-style: none; }

blockquote, q {
  quotes: none; }

blockquote:before, blockquote:after, q:before, q:after {
  content: '';
  content: none; }

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent; }

ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none; }

mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold; }

del {
  text-decoration: line-through; }

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0; }

input, select {
  vertical-align: middle; }

/****************************************************
 * 共通
 ****************************************************/
*, *:before, *:after {
  box-sizing: border-box; }

html {
  background-color: transparent;
  background-image: none;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 10px;
  font-weight: 400;
  font-optical-sizing: auto;
  color: #05161a;
  scroll-behavior: smooth; }
  @media screen and (max-width: 1000px) and (min-width: 781px) {
    html {
      font-size: 9px; } }
  @media screen and (max-width: 780px) {
    html {
      height: 100%; } }

body {
  font-size: 1.6rem;
  line-height: 1.6;
  word-wrap: break-word;
  background-color: #f7f7f7; }
  @media screen and (max-width: 780px) {
    body {
      -webkit-text-size-adjust: 100%; } }

.wrap {
  overflow: hidden; }

@media screen and (min-width: 781px) {
  .pcNone {
    display: none !important; } }

@media screen and (max-width: 780px) {
  .spNone {
    display: none !important; } }

input, textarea {
  font-family: inherit;
  outline: none; }
  input:focus, textarea:focus {
    outline: none; }
  input[type="submit"], textarea[type="submit"] {
    -webkit-appearance: none; }

img {
  width: auto;
  max-width: 100%;
  height: auto;
  vertical-align: bottom; }

ul, ol {
  list-style: none; }

a {
  color: #05161a;
  text-decoration: none;
  outline: none; }
  a:focus {
    outline: none; }
  a:hover {
    text-decoration: underline; }
  a[href^="tel:"] {
    cursor: default; }
    a[href^="tel:"]:hover {
      text-decoration: none; }
  a img {
    transition: opacity 0.3s; }
    a img:hover {
      opacity: 0.6; }

.inner {
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 1rem; }

section:not(.no_animation), aside:not(.no_animation), .fadeIn {
  opacity: 0;
  visibility: hidden;
  animation: fadeIn 1s ease-out 0.5s forwards; }

@keyframes fadeIn {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
.acc .acc_body {
  display: none; }
.acc.open .acc_body {
  display: block; }

.midashi01 {
  margin-bottom: 4rem;
  padding: 0.75em;
  font-size: 2.8rem;
  text-align: center;
  position: relative; }
  .midashi01:before, .midashi01:after {
    width: 100%;
    height: 0.6rem;
    content: '';
    position: absolute;
    left: 0; }
  .midashi01:before {
    border-top: 2px solid #222222;
    border-bottom: 1px solid #222222;
    top: 0; }
  .midashi01:after {
    border-top: 1px solid #222222;
    border-bottom: 2px solid #222222;
    bottom: 0; }
  .midashi01 span {
    font-size: 0.57em;
    display: block; }

/****************************************************
 * テンプレート
 ****************************************************/
#header {
  padding: 2rem 0; }
  #header h1 {
    font-size: 2.8rem;
    font-weight: 700; }

#footer {
  padding: 4rem 0 8rem 0; }
  @media screen and (max-width: 780px) {
    #footer .fix_contact {
      width: 100%;
      text-align: center;
      display: flex;
      position: fixed;
      bottom: 0;
      left: 0;
      z-index: 90; }
      #footer .fix_contact .line {
        width: 50%; }
        #footer .fix_contact .line a {
          padding: 0.5em 1em;
          font-size: 1.8rem;
          text-decoration: none !important;
          color: #ffffff;
          background-color: #9dd219;
          display: block; }
      #footer .fix_contact .mail {
        width: 50%; }
        #footer .fix_contact .mail a {
          padding: 0.5em 1em;
          font-size: 1.8rem;
          text-decoration: none !important;
          color: #ffffff;
          background-color: #caa317;
          display: block; } }
  #footer .copyright {
    text-align: center; }

#main section {
  padding: 4rem 0; }
#main .pagetitle {
  margin-bottom: 2rem;
  padding: 5rem 0;
  color: #ffffff;
  background-color: #caa317; }
  #main .pagetitle h2 {
    font-size: 3.2rem;
    font-weight: 700; }

/****************************************************
 * コンテンツスタイル
 ****************************************************/
#main .sec_mv {
  padding-top: 0;
  padding-bottom: 0;
  text-align: center; }
#main .sec_order01 p {
  margin-bottom: 4rem;
  font-size: 2.8rem;
  text-align: center;
  overflow: hidden; }
  @media screen and (max-width: 780px) {
    #main .sec_order01 p {
      padding: 0 3em;
      font-size: 2rem; } }
  #main .sec_order01 p span {
    display: inline-block;
    position: relative; }
    #main .sec_order01 p span:before, #main .sec_order01 p span:after {
      width: 999px;
      height: 0.2rem;
      content: '';
      background-color: #222222;
      position: absolute;
      top: 50%; }
    #main .sec_order01 p span:before {
      right: 105%; }
    #main .sec_order01 p span:after {
      left: 105%; }
#main .sec_order01 .btn {
  display: flex;
  justify-content: space-between;
  align-items: center; }
  #main .sec_order01 .btn a {
    padding: 0.6em 1.5em;
    font-size: 2.8rem;
    font-weight: 700;
    text-align: center;
    text-decoration: none !important;
    color: #fff;
    border-radius: 1rem;
    border-bottom: 0.2em solid rgba(0, 0, 0, 0.2);
    overflow: hidden;
    position: relative;
    display: block;
    transition: opacity 0.3s; }
    @media screen and (max-width: 780px) {
      #main .sec_order01 .btn a {
        font-size: 1.6rem; } }
    #main .sec_order01 .btn a:after {
      position: absolute;
      display: block;
      top: 0;
      left: -100px;
      width: 30px;
      height: 100%;
      background-color: #fff;
      opacity: 0;
      transform: rotate(45deg);
      content: "";
      pointer-events: none;
      animation: anim-reflection 3s infinite; }
    #main .sec_order01 .btn a:hover {
      opacity: 0.6; }
@keyframes anim-reflection {
  0% {
    transform: scale(0) rotate(45deg);
    opacity: 0; }
  50% {
    transform: scale(0) rotate(45deg);
    opacity: 0.5; }
  75% {
    transform: scale(0) rotate(45deg);
    opacity: 0.75; }
  100% {
    transform: scale(100) rotate(45deg);
    opacity: 0; } }
  #main .sec_order01 .btn .line {
    width: 48%; }
    #main .sec_order01 .btn .line a {
      background-color: #9dd219; }
  #main .sec_order01 .btn .mail {
    width: 48%; }
    #main .sec_order01 .btn .mail a {
      background-color: #caa317; }
#main .sec_service {
  padding-bottom: 2rem; }
  #main .sec_service .img {
    text-align: center; }
#main .sec_flow {
  padding-bottom: 0;
  background-color: #eeeeee; }
  #main .sec_flow .img {
    text-align: center;
    background-color: #e8e8e8; }
#main .sec_order02 .inner {
  max-width: 80rem; }
#main .sec_order02 .box {
  padding: 2rem;
  background-color: #ffffff;
  -webkit-box-shadow: 0 2px 1px rgba(0, 0, 0, 0.04);
  box-shadow: 0 2px 1px rgba(0, 0, 0, 0.04);
  background-image: -webkit-linear-gradient(45deg, #222 25%, transparent 25%, transparent 50%, #222 50%, #222 75%, transparent 75%, transparent);
  background-image: linear-gradient(45deg, #222 25%, transparent 25%, transparent 50%, #222 50%, #222 75%, transparent 75%, transparent);
  background-size: 2rem 2rem; }
  @media screen and (max-width: 780px) {
    #main .sec_order02 .box {
      padding: 1rem; } }
  #main .sec_order02 .box .in {
    padding: 4rem 4rem 2rem;
    text-align: center;
    background-color: #ffffff; }
    @media screen and (max-width: 780px) {
      #main .sec_order02 .box .in {
        padding: 2rem 2rem 1rem; } }
#main .sec_order02 h2 {
  margin-bottom: 2rem;
  font-size: 2.8rem; }
  @media screen and (max-width: 780px) {
    #main .sec_order02 h2 {
      font-size: 2rem; } }
#main .sec_order02 p {
  margin-bottom: 2rem;
  font-size: 2rem; }
  @media screen and (max-width: 780px) {
    #main .sec_order02 p {
      font-size: 1.6rem; } }
#main .sec_order02 .btn {
  display: flex;
  justify-content: space-between;
  align-items: center; }
  @media screen and (max-width: 780px) {
    #main .sec_order02 .btn {
      display: block; } }
  #main .sec_order02 .btn .line {
    width: 48%; }
    @media screen and (max-width: 780px) {
      #main .sec_order02 .btn .line {
        width: 100%; } }
    #main .sec_order02 .btn .line a {
      padding: 0.8em 1.8em;
      font-size: 2.8rem;
      text-align: center;
      text-decoration: none !important;
      color: #ffffff;
      background-color: #9dd219;
      border-radius: 300px;
      display: block;
      transition: opacity 0.3s; }
      @media screen and (max-width: 780px) {
        #main .sec_order02 .btn .line a {
          font-size: 2rem; } }
      #main .sec_order02 .btn .line a:hover {
        opacity: 0.8; }
  #main .sec_order02 .btn .mail {
    width: 48%; }
    @media screen and (max-width: 780px) {
      #main .sec_order02 .btn .mail {
        width: 100%;
        margin-top: 2rem; } }
    #main .sec_order02 .btn .mail a {
      padding: 0.8em 1.8em;
      font-size: 2.8rem;
      text-align: center;
      text-decoration: none !important;
      color: #ffffff;
      background-color: #caa317;
      border-radius: 300px;
      display: block;
      transition: opacity 0.3s; }
      @media screen and (max-width: 780px) {
        #main .sec_order02 .btn .mail a {
          font-size: 2rem; } }
      #main .sec_order02 .btn .mail a:hover {
        opacity: 0.8; }
#main .sec_riyuu {
  padding-bottom: 0;
  background-color: #d2d0d0; }
  #main .sec_riyuu .img {
    text-align: center;
    background-color: #e8e8e8; }
#main .sec_voice .img {
  text-align: center;
  background-color: #e8e8e8; }
  #main .sec_voice .img img {
    display: block;
    margin: 0 auto; }
#main .sec_faq h2 {
  margin-bottom: 1em;
  font-size: 2.8rem;
  text-align: center; }
#main .sec_faq ul li + li {
  margin-top: 4rem; }
#main .sec_faq ul li .faq_q {
  padding: 1rem 0 1rem 5rem;
  position: relative;
  z-index: 1; }
  #main .sec_faq ul li .faq_q:before {
    width: 4rem;
    height: 100%;
    padding-top: 1rem;
    content: 'Q';
    text-align: center;
    background-color: #cccccc;
    position: absolute;
    top: 0;
    left: 0; }
#main .sec_faq ul li .faq_a {
  padding: 1rem 0 1rem 5rem;
  position: relative; }
  #main .sec_faq ul li .faq_a:before {
    width: 4rem;
    height: 100%;
    padding-top: 1rem;
    content: 'A';
    text-align: center;
    color: #ffffff;
    background-color: #222222;
    position: absolute;
    top: 0;
    left: 0; }
#main .sec_company .flex {
  max-width: 74rem;
  margin: 0 auto;
  display: flex; }
  @media screen and (max-width: 780px) {
    #main .sec_company .flex {
      max-width: none;
      display: block; } }
  #main .sec_company .flex .img {
    width: 50%; }
    @media screen and (max-width: 780px) {
      #main .sec_company .flex .img {
        width: 100%;
        margin-bottom: 1rem; } }
  #main .sec_company .flex .text {
    width: 50%;
    padding-left: 2rem; }
    @media screen and (max-width: 780px) {
      #main .sec_company .flex .text {
        width: 100%;
        padding-left: 0; } }
    #main .sec_company .flex .text p {
      margin-bottom: 2rem;
      font-size: 1.8rem;
      font-weight: 500; }
    #main .sec_company .flex .text table {
      width: 100%;
      margin-bottom: 2rem;
      font-size: 1.4rem; }
      #main .sec_company .flex .text table th {
        width: 30%;
        padding-right: 1em;
        padding-bottom: 0.25em;
        text-align: left;
        font-weight: 400;
        vertical-align: top;
        position: relative; }
        #main .sec_company .flex .text table th:after {
          content: ':';
          position: absolute;
          top: 0;
          right: 0; }
      #main .sec_company .flex .text table td {
        padding-left: 1em;
        padding-bottom: 0.25em;
        vertical-align: top; }
    #main .sec_company .flex .text .btn {
      display: flex;
      justify-content: space-between;
      align-items: center; }
      @media screen and (max-width: 780px) {
        #main .sec_company .flex .text .btn {
          display: block; } }
      #main .sec_company .flex .text .btn .line {
        width: 48%; }
        @media screen and (max-width: 780px) {
          #main .sec_company .flex .text .btn .line {
            width: 100%; } }
        #main .sec_company .flex .text .btn .line a {
          padding: 0.8em 1.8em;
          font-size: 1.5rem;
          text-align: center;
          text-decoration: none !important;
          color: #ffffff;
          background-color: #9dd219;
          display: block;
          transition: opacity 0.3s; }
          @media screen and (max-width: 780px) {
            #main .sec_company .flex .text .btn .line a {
              font-size: 2rem; } }
          #main .sec_company .flex .text .btn .line a:hover {
            opacity: 0.8; }
      #main .sec_company .flex .text .btn .mail {
        width: 48%; }
        @media screen and (max-width: 780px) {
          #main .sec_company .flex .text .btn .mail {
            width: 100%;
            margin-top: 2rem; } }
        #main .sec_company .flex .text .btn .mail a {
          padding: 0.8em 1.8em;
          font-size: 1.5rem;
          text-align: center;
          text-decoration: none !important;
          color: #ffffff;
          background-color: #caa317;
          display: block;
          transition: opacity 0.3s; }
          @media screen and (max-width: 780px) {
            #main .sec_company .flex .text .btn .mail a {
              font-size: 2rem; } }
          #main .sec_company .flex .text .btn .mail a:hover {
            opacity: 0.8; }

/****************************************************
 * フォーム
 ****************************************************/
#main .sec_form form {
  padding: 2rem 4rem;
  background-color: #ffffff;
  display: block; }
  #main .sec_form form ul {
    margin-bottom: 3rem; }
    #main .sec_form form ul li {
      padding: 2rem 0;
      border-bottom: solid 1px #cccccc; }
      #main .sec_form form ul li + li {
        margin-top: 2rem; }
      #main .sec_form form ul li .label {
        margin-bottom: 1rem;
        font-weight: 500; }
      #main .sec_form form ul li .input input[type="text"], #main .sec_form form ul li .input input[type="email"], #main .sec_form form ul li .input input[type="tel"], #main .sec_form form ul li .input textarea {
        width: 100%;
        padding: 1rem;
        border: solid 2px #eeeeee; }
        #main .sec_form form ul li .input input[type="text"]:focus, #main .sec_form form ul li .input input[type="email"]:focus, #main .sec_form form ul li .input input[type="tel"]:focus, #main .sec_form form ul li .input textarea:focus {
          border-color: #caa317; }
        #main .sec_form form ul li .input input[type="text"].w20r, #main .sec_form form ul li .input input[type="email"].w20r, #main .sec_form form ul li .input input[type="tel"].w20r, #main .sec_form form ul li .input textarea.w20r {
          width: 20rem; }
      #main .sec_form form ul li .input textarea {
        height: 10rem; }
      #main .sec_form form ul li select {
        padding: 1rem;
        background-color: #ffffff;
        border: solid 2px #eeeeee; }
        #main .sec_form form ul li select:focus {
          border-color: #caa317; }
  #main .sec_form form .kiyaku {
    margin-bottom: 3rem; }
    #main .sec_form form .kiyaku iframe {
      width: 100%;
      height: 30rem;
      margin-bottom: 1rem;
      border: solid 1px #eeeeee; }
      @media screen and (max-width: 780px) {
        #main .sec_form form .kiyaku iframe {
          height: 20rem; } }
    #main .sec_form form .kiyaku p {
      font-size: 1.4rem;
      text-align: center; }
      #main .sec_form form .kiyaku p .color_red {
        color: #ff0000; }
  #main .sec_form form .submit {
    text-align: center; }
    #main .sec_form form .submit input[type="submit"] {
      padding: 1rem 4rem;
      font-size: 2rem;
      font-weight: 500;
      letter-spacing: 0.1em;
      color: #ffffff;
      background-color: #caa317;
      border: none; }

/****************************************************
 * ログイン要素
 ****************************************************/
.login_block {
  padding: 2rem 0;
  background-color: #d2d0d0;
  text-align: right; }
  @media screen and (max-width: 780px) {
    .login_block {
      padding: 1rem 0;
      text-align: left; } }
  .login_block .box {
    font-size: 1.4rem;
    display: inline-flex;
    align-items: center; }
    @media screen and (max-width: 780px) {
      .login_block .box {
        display: flex;
        flex-wrap: wrap; } }
    .login_block .box .ttl {
      margin-right: 1em;
      font-weight: 600;
      color: #ffffff; }
      @media screen and (max-width: 780px) {
        .login_block .box .ttl {
          width: 100%;
          margin: 0 0 0.5em 0; } }
    .login_block .box .input {
      margin-right: 1em; }
      @media screen and (max-width: 780px) {
        .login_block .box .input {
          width: 40%;
          margin: 0; } }
      .login_block .box .input input[type="password"], .login_block .box .input input[type="tel"] {
        width: 10em;
        padding: 0.5rem;
        border: solid 1px #ddd; }
        @media screen and (max-width: 780px) {
          .login_block .box .input input[type="password"], .login_block .box .input input[type="tel"] {
            width: 100%;
            padding: 0.25em; } }
    @media screen and (max-width: 780px) {
      .login_block .box .submit {
        width: 20%; } }
    .login_block .box .submit input[type="submit"] {
      padding: 0.5em 2em;
      text-align: center;
      letter-spacing: normal;
      color: #ffffff;
      background-color: #caa317;
      border: none;
      display: inline-block;
      transition: opacity 0.3s; }
      @media screen and (max-width: 780px) {
        .login_block .box .submit input[type="submit"] {
          padding: 0.25em; } }
      .login_block .box .submit input[type="submit"]:hover {
        text-decoration: none;
        opacity: 0.6; }

/****************************************************
 * フォーム無し調整
 ****************************************************/
@media screen and (max-width: 780px) {
  .no_form #footer .fix_contact .line {
    width: 100%; } }
.no_form #main .sec_order01 .btn .line {
  width: 100%; }
.no_form #main .sec_order02 .btn .line {
  width: 100%; }

/****************************************************
 * 規約ページ
 ****************************************************/
.kiyaku_page #main .sec_kiyaku .kiyaku {
  margin-bottom: 3rem; }
  .kiyaku_page #main .sec_kiyaku .kiyaku iframe {
    width: 100%;
    height: 40rem;
    margin-bottom: 1rem;
    border: solid 1px #eeeeee; }
    @media screen and (max-width: 780px) {
      .kiyaku_page #main .sec_kiyaku .kiyaku iframe {
        height: 30rem; } }
.kiyaku_page #main .sec_kiyaku .acceptance {
  margin-bottom: 5rem;
  font-size: 1.4rem;
  text-align: center; }
  .kiyaku_page #main .sec_kiyaku .acceptance .color_red {
    color: #ff0000; }
.kiyaku_page #main .sec_kiyaku .apply h3 {
  margin-bottom: 2rem;
  padding: 2rem 0;
  font-size: 2.8rem;
  text-align: center;
  border-top: double 0.4rem #caa317;
  border-bottom: double 0.4rem #caa317; }
.kiyaku_page #main .sec_kiyaku .apply p {
  margin-bottom: 2rem;
  font-size: 1.8rem;
  text-align: center; }
.kiyaku_page #main .sec_kiyaku .apply .btn_area {
  text-align: center; }
  .kiyaku_page #main .sec_kiyaku .apply .btn_area a {
    width: 60rem;
    max-width: 100%;
    padding: 2rem;
    font-size: 2.8rem;
    text-align: center;
    text-decoration: none !important;
    color: #ffffff;
    background-color: #9dd219;
    display: inline-block; }

/****************************************************
 * サンクスページ
 ****************************************************/
.thanks_page .sec_thanks_message h3 {
  margin-bottom: 1em;
  font-size: 2.8rem;
  text-align: center; }
.thanks_page .sec_thanks_message p {
  margin-bottom: 5rem; }
.thanks_page .sec_thanks_message .btn {
  text-align: center; }
  .thanks_page .sec_thanks_message .btn a {
    width: 40rem;
    max-width: 100%;
    padding: 2rem;
    font-size: 2rem;
    text-align: center;
    text-decoration: none !important;
    color: #ffffff;
    background-color: #222222;
    display: inline-block; }
