@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; }
  @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; }

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; }

/****************************************************
 * テンプレート
 ****************************************************/
#header {
  width: 100%;
  height: 10rem;
  padding-top: 1rem;
  background-color: #ffffff;
  box-shadow: 0 1px 2px rgba(194, 194, 194, 0.5);
  position: fixed;
  top: 0;
  left: 0;
  z-index: 99; }
  #header .inner {
    max-width: 1280px; }
    #header .inner:after {
      width: 0;
      height: 0;
      content: '';
      clear: both;
      display: block; }
  #header .logo {
    width: 8rem;
    float: left; }
  #header .header_right {
    float: right;
    display: flex;
    justify-content: flex-end;
    align-items: center; }
    @media screen and (max-width: 780px) {
      #header .header_right {
        padding-top: 1rem; } }
    #header .header_right .tel {
      margin-right: 2rem;
      font-size: 1.8rem; }
      #header .header_right .tel .time {
        font-size: 0.7em;
        display: block; }
      @media screen and (max-width: 780px) {
        #header .header_right .tel a {
          width: 6rem;
          height: 6rem;
          background-color: #ffc000;
          display: block;
          position: relative; }
          #header .header_right .tel a i {
            font-size: 3rem;
            color: #ffffff;
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%); } }
    #header .header_right .line {
      margin-right: 2rem; }
      #header .header_right .line a {
        padding: 0.5em 1em;
        font-size: 2.4rem;
        text-decoration: none !important;
        color: #ffffff;
        background-color: #9dd219;
        transition: opacity 0.3s ease;
        display: block; }
        #header .header_right .line a:hover {
          opacity: 0.8; }
        @media screen and (max-width: 780px) {
          #header .header_right .line a {
            width: 6rem;
            height: 6rem;
            display: block;
            position: relative; }
            #header .header_right .line a i {
              font-size: 4rem;
              color: #ffffff;
              position: absolute;
              top: 50%;
              left: 50%;
              transform: translate(-50%, -50%); } }
    #header .header_right .mail a {
      padding: 0.5em 1em;
      font-size: 2.4rem;
      text-decoration: none !important;
      color: #ffffff;
      background-color: #e87332;
      transition: opacity 0.3s ease;
      display: block; }
      #header .header_right .mail a:hover {
        opacity: 0.8; }
      @media screen and (max-width: 780px) {
        #header .header_right .mail a {
          width: 6rem;
          height: 6rem;
          display: block;
          position: relative; }
          #header .header_right .mail a i {
            font-size: 3rem;
            color: #ffffff;
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%); } }

#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: #e87332;
          display: block; } }
  #footer .copyright {
    text-align: center; }

#main {
  padding-top: 10rem; }
  @media screen and (max-width: 780px) {
    #main {
      padding-top: 8rem; } }
  #main section {
    padding: 4rem 0; }
  #main .pagetitle {
    margin-bottom: 2rem;
    padding: 5rem 0;
    color: #ffffff;
    background-color: #ffc000; }
    #main .pagetitle h2 {
      font-size: 3.2rem;
      font-weight: 700; }

/****************************************************
 * コンテンツスタイル
 ****************************************************/
#main .sec_mv {
  padding-top: 0;
  text-align: center; }
#main .sec_flow {
  text-align: center; }
#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: 300px;
    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: #e87332; }
#main .sec_use {
  text-align: center; }
#main .sec_voice {
  max-width: 1500px;
  margin: 0 auto; }
  #main .sec_voice h2 {
    text-align: center; }
    #main .sec_voice h2 span {
      font-size: 2.8rem;
      display: inline-block;
      position: relative; }
      #main .sec_voice h2 span:before, #main .sec_voice h2 span:after {
        position: absolute;
        bottom: 0;
        content: "";
        width: 2px;
        height: 120%;
        background-color: #000;
        -webkit-transform-origin: center;
        -ms-transform-origin: center;
        transform-origin: center; }
      #main .sec_voice h2 span:before {
        left: -30px;
        transform: rotate(-30deg); }
      #main .sec_voice h2 span:after {
        right: -30px;
        transform: rotate(30deg); }
  #main .sec_voice .img {
    text-align: center; }
#main .sec_point {
  max-width: 1500px;
  margin: 0 auto;
  padding-top: 0;
  text-align: center; }
#main .sec_chance {
  max-width: 1100px;
  margin: 0 auto;
  padding-top: 0;
  text-align: center; }
  @media screen and (max-width: 780px) {
    #main .sec_chance {
      max-width: 80%; } }
#main .sec_order02 {
  padding-top: 0; }
  #main .sec_order02 dl {
    max-width: 80rem;
    margin: 0 auto;
    padding: 10px;
    background-color: #28c3d4;
    box-shadow: 0 0 3px rgba(0, 0, 0, 0.6); }
    #main .sec_order02 dl dt {
      margin-bottom: 10px;
      font-size: 1.8rem;
      font-weight: 700;
      text-align: center;
      color: #ffffff; }
    #main .sec_order02 dl dd {
      padding: 10px;
      text-align: center;
      background-color: #ffffff;
      display: flex; }
      @media screen and (max-width: 780px) {
        #main .sec_order02 dl dd {
          display: block; } }
      #main .sec_order02 dl dd .tel {
        width: 50%;
        padding: 10px;
        border-right: solid 1px #cccccc; }
        @media screen and (max-width: 780px) {
          #main .sec_order02 dl dd .tel {
            width: 100%;
            border-right: none;
            border-bottom: solid 1px #cccccc; } }
        #main .sec_order02 dl dd .tel p {
          margin-bottom: 2rem; }
        #main .sec_order02 dl dd .tel a {
          font-size: 3rem;
          line-height: 1.2;
          display: inline-block; }
          @media screen and (max-width: 780px) {
            #main .sec_order02 dl dd .tel a {
              font-size: 3.6rem; } }
        #main .sec_order02 dl dd .tel .time {
          margin-top: 1rem;
          font-size: 1.2rem; }
          @media screen and (max-width: 780px) {
            #main .sec_order02 dl dd .tel .time {
              font-size: 1.6rem; } }
      #main .sec_order02 dl dd .message {
        width: 50%;
        padding: 10px;
        background-color: #ffffff; }
        @media screen and (max-width: 780px) {
          #main .sec_order02 dl dd .message {
            width: 100%; } }
        #main .sec_order02 dl dd .message p {
          margin-bottom: 2rem; }
        #main .sec_order02 dl dd .message .btn {
          display: flex;
          justify-content: center; }
          #main .sec_order02 dl dd .message .btn .line {
            margin-right: 1rem; }
            #main .sec_order02 dl dd .message .btn .line a {
              padding: 0.5em 1em;
              font-size: 2rem;
              text-decoration: none !important;
              color: #ffffff;
              background-color: #9dd219;
              transition: opacity 0.3s ease;
              display: block; }
              @media screen and (max-width: 780px) {
                #main .sec_order02 dl dd .message .btn .line a {
                  font-size: 1.6rem; } }
              #main .sec_order02 dl dd .message .btn .line a:hover {
                opacity: 0.8; }
          #main .sec_order02 dl dd .message .btn .mail a {
            padding: 0.5em 1em;
            font-size: 2rem;
            text-decoration: none !important;
            color: #ffffff;
            background-color: #e87332;
            transition: opacity 0.3s ease;
            display: block; }
            @media screen and (max-width: 780px) {
              #main .sec_order02 dl dd .message .btn .mail a {
                font-size: 1.6rem; } }
            #main .sec_order02 dl dd .message .btn .mail a:hover {
              opacity: 0.8; }
        #main .sec_order02 dl dd .message .annotation {
          margin-top: 1rem;
          font-size: 1.2rem; }
#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;
    background-color: #28c3d4;
    position: absolute;
    top: 0;
    left: 0; }
#main .sec_company .inner {
  max-width: 940px; }
#main .sec_company h2 {
  margin-bottom: 1em;
  font-size: 2.8rem;
  text-align: center; }
#main .sec_company table {
  width: 100%;
  font-size: 1.4rem; }
  #main .sec_company table tr th, #main .sec_company table tr td {
    padding: 1rem;
    text-align: left;
    vertical-align: top;
    border-bottom: solid 1px #cccccc; }
  #main .sec_company table tr th {
    width: 45%;
    font-weight: 500; }

/****************************************************
 * フォーム
 ****************************************************/
#main .sec_form h2 {
  margin-bottom: 1em;
  font-size: 2.8rem;
  text-align: center; }
#main .sec_form form {
  max-width: 940px;
  margin: 0 auto;
  display: block; }
  #main .sec_form form ul {
    margin-bottom: 3rem; }
    #main .sec_form form ul li {
      padding-bottom: 2rem;
      border-bottom: solid 1px #eee;
      display: flex; }
      @media screen and (max-width: 780px) {
        #main .sec_form form ul li {
          display: block; } }
      #main .sec_form form ul li + li {
        margin-top: 2rem; }
      #main .sec_form form ul li .label {
        width: 35%;
        padding-right: 1rem; }
        @media screen and (max-width: 780px) {
          #main .sec_form form ul li .label {
            width: 100%;
            margin-bottom: 1rem;
            padding-right: 0; } }
      #main .sec_form form ul li .input {
        width: 70%;
        padding-left: 1rem; }
        @media screen and (max-width: 780px) {
          #main .sec_form form ul li .input {
            width: 100%;
            padding-left: 0; } }
        #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: #e87332; }
          #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: #e87332; }
  #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: 2.8rem;
      font-weight: 500;
      letter-spacing: 0.1em;
      color: #ffffff;
      background-color: #e87332;
      border: none; }

/****************************************************
 * ログイン要素
 ****************************************************/
.login_block {
  padding: 2rem 0;
  background-color: #ffc000;
  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: #e87331;
      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 (min-width: 781px) {
  .no_form #header .header_right .line a {
    padding: 0.5em 5em; } }
@media screen and (max-width: 780px) {
  .no_form #footer .fix_contact .line {
    width: 100%; } }
.no_form #main .sec_order01 .btn {
  display: block; }
  .no_form #main .sec_order01 .btn .line {
    width: 100%; }
.no_form #main .sec_order02 dl dd .message .btn .line {
  margin-right: 0; }
  .no_form #main .sec_order02 dl dd .message .btn .line a {
    padding: 0.5em 4em; }

/****************************************************
 * 規約ページ
 ****************************************************/
.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 #ffc000;
  border-bottom: double 0.4rem #ffc000; }
.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: #e87331;
    display: inline-block; }
