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

/****************************************************
 * 共通
 ****************************************************/
* {
  font-weight: 500; }

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

html {
  background-color: transparent;
  background-image: none;
  font-family: "Zen Maru Gothic","Hiragino Maru Gothic ProN","Hiragino Kaku Gothic ProN","Yu Gothic UI","Meiryo","Noto Sans JP",sans-serif;
  font-size: 10px;
  font-weight: 500;
  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%;
      font-size: 9px; } }

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;
  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 0.5s ease-out 0.5s forwards; }

@keyframes fadeIn {
  0% {
    opacity: 0;
    transform: translateY(50px); }
  100% {
    opacity: 1;
    transform: translateY(0); } }
.acc .acc_body {
  display: none; }
.acc.open .acc_body {
  display: block; }

.midashi01 {
  margin-bottom: 2.2em;
  font-size: 1.8rem;
  text-align: center; }
  .midashi01 b {
    font-size: 1.77em;
    font-weight: 500;
    line-height: 0.56; }
  .midashi01 > span {
    margin-bottom: 1em;
    display: block; }
    .midashi01 > span span {
      padding-bottom: 0.5em;
      font-size: 1.55em;
      border-bottom: 2px solid #28c3d4;
      display: inline-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; }
  @media screen and (max-width: 780px) {
    #header {
      height: 8rem; } }
  #header .inner {
    max-width: 1280px; }
    #header .inner:after {
      width: 0;
      height: 0;
      content: '';
      clear: both;
      display: block; }
  #header .logo {
    width: 8.9rem;
    float: left; }
    @media screen and (max-width: 780px) {
      #header .logo {
        width: 7.5rem; } }
  #header .header_right {
    padding-top: 1rem;
    float: right;
    display: flex;
    justify-content: flex-end;
    align-items: center; }
    @media screen and (max-width: 780px) {
      #header .header_right {
        padding-top: 0; } }
    #header .header_right .tel {
      margin-right: 2rem;
      font-size: 2rem; }
      #header .header_right .tel .time {
        font-size: 0.7em;
        text-align: right;
        display: block; }
      @media screen and (max-width: 780px) {
        #header .header_right .tel a {
          width: 6rem;
          height: 6rem;
          background-color: #b1080b;
          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: #4c2505;
      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: #4c2505;
          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: #4b2304; }
    #main .pagetitle h2 {
      font-size: 3.2rem; }

/****************************************************
 * コンテンツスタイル
 ****************************************************/
#main .sec_mv {
  padding-top: 0; }
#main .sec_order01 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_order01 dl dt {
    margin-bottom: 10px;
    font-size: 1.8rem;
    font-weight: 700;
    text-align: center;
    color: #ffffff; }
  #main .sec_order01 dl dd {
    padding: 10px;
    text-align: center;
    background-color: #ffffff;
    display: flex; }
    @media screen and (max-width: 780px) {
      #main .sec_order01 dl dd {
        display: block; } }
    #main .sec_order01 dl dd .tel {
      width: 50%;
      padding: 10px;
      border-right: solid 1px #cccccc; }
      @media screen and (max-width: 780px) {
        #main .sec_order01 dl dd .tel {
          width: 100%;
          border-right: none;
          border-bottom: solid 1px #cccccc; } }
      #main .sec_order01 dl dd .tel p {
        margin-bottom: 2rem; }
      #main .sec_order01 dl dd .tel a {
        font-size: 3rem;
        line-height: 1.2;
        display: inline-block; }
        @media screen and (max-width: 780px) {
          #main .sec_order01 dl dd .tel a {
            font-size: 3.6rem; } }
      #main .sec_order01 dl dd .tel .time {
        margin-top: 1rem;
        font-size: 1.2rem; }
        @media screen and (max-width: 780px) {
          #main .sec_order01 dl dd .tel .time {
            font-size: 1.6rem; } }
    #main .sec_order01 dl dd .message {
      width: 50%;
      padding: 10px;
      background-color: #ffffff; }
      @media screen and (max-width: 780px) {
        #main .sec_order01 dl dd .message {
          width: 100%; } }
      #main .sec_order01 dl dd .message p {
        margin-bottom: 2rem; }
      #main .sec_order01 dl dd .message .btn {
        display: flex;
        justify-content: center; }
        #main .sec_order01 dl dd .message .btn .line {
          margin-right: 1rem; }
          #main .sec_order01 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_order01 dl dd .message .btn .line a {
                font-size: 1.8rem; } }
            #main .sec_order01 dl dd .message .btn .line a:hover {
              opacity: 0.8; }
        #main .sec_order01 dl dd .message .btn .mail a {
          padding: 0.5em 1em;
          font-size: 2rem;
          text-decoration: none !important;
          color: #ffffff;
          background-color: #4c2505;
          transition: opacity 0.3s ease;
          display: block; }
          @media screen and (max-width: 780px) {
            #main .sec_order01 dl dd .message .btn .mail a {
              font-size: 1.8rem; } }
          #main .sec_order01 dl dd .message .btn .mail a:hover {
            opacity: 0.8; }
      #main .sec_order01 dl dd .message .annotation {
        margin-top: 1rem;
        font-size: 1.2rem; }
#main .sec_service {
  background-color: #f9c270; }
  #main .sec_service .inner {
    max-width: 940px; }
  #main .sec_service .midashi01 {
    margin-bottom: 0; }
#main .sec_tuyomi .inner {
  max-width: 1800px; }
#main .sec_flow {
  padding-top: 0; }
  #main .sec_flow .inner {
    max-width: 940px; }
  #main .sec_flow ol {
    margin-bottom: 4rem; }
    @media screen and (max-width: 780px) {
      #main .sec_flow ol {
        margin-bottom: 2rem; } }
    #main .sec_flow ol li {
      display: flex; }
      @media screen and (max-width: 780px) {
        #main .sec_flow ol li {
          display: block; } }
      #main .sec_flow ol li + li {
        margin-top: 4rem; }
        @media screen and (max-width: 780px) {
          #main .sec_flow ol li + li {
            margin-top: 2rem; } }
      #main .sec_flow ol li .num {
        width: 25%;
        padding-right: 2rem;
        font-size: 3rem;
        color: #28c3d4;
        border-right: solid 1px #28c3d4; }
        @media screen and (max-width: 780px) {
          #main .sec_flow ol li .num {
            width: 100%;
            padding-right: 0;
            font-size: 2rem;
            border-right: none; } }
      #main .sec_flow ol li .text {
        width: 75%;
        padding-left: 2rem; }
        @media screen and (max-width: 780px) {
          #main .sec_flow ol li .text {
            width: 100%;
            padding-left: 0; } }
        #main .sec_flow ol li .text h3 {
          margin-bottom: 0.18em;
          font-size: 2.8rem;
          color: #28c3d4; }
          @media screen and (max-width: 780px) {
            #main .sec_flow ol li .text h3 {
              font-size: 2.4rem; } }
  #main .sec_flow .annotation {
    padding-left: 25%; }
    @media screen and (max-width: 780px) {
      #main .sec_flow .annotation {
        padding-left: 0; } }
#main .sec_voice {
  padding-top: 0; }
  #main .sec_voice ul {
    max-width: 70rem;
    margin: 0 auto;
    position: relative; }
    @media screen and (max-width: 780px) {
      #main .sec_voice ul {
        max-width: none; } }
    #main .sec_voice ul li {
      padding: 2rem;
      border: 1px solid #ccc;
      border-radius: 6px;
      display: flex;
      position: relative; }
      @media screen and (max-width: 780px) {
        #main .sec_voice ul li {
          display: block; } }
      #main .sec_voice ul li + li {
        margin-top: 4rem;
        position: relative; }
        @media screen and (max-width: 780px) {
          #main .sec_voice ul li + li {
            margin-top: 2rem; } }
      #main .sec_voice ul li .img {
        width: 33.3333%;
        padding-right: 2rem;
        overflow: hidden; }
        @media screen and (max-width: 780px) {
          #main .sec_voice ul li .img {
            width: 100%;
            height: auto;
            margin-bottom: 2rem;
            padding-top: 2rem;
            padding-right: 0;
            aspect-ratio: 1/1; } }
        #main .sec_voice ul li .img img {
          width: 100%;
          height: 100%;
          object-fit: cover; }
      #main .sec_voice ul li .text {
        width: 66.6667%;
        padding-left: 2rem; }
        @media screen and (max-width: 780px) {
          #main .sec_voice ul li .text {
            width: 100%;
            padding-left: 0; } }
        #main .sec_voice ul li .text .headding {
          margin-bottom: 1rem; }
          #main .sec_voice ul li .text .headding .tag {
            font-size: 1.2rem;
            padding: 3px 20px;
            color: #ffffff;
            background-color: #28c3d4;
            position: absolute;
            top: -1rem;
            right: -1rem; }
        #main .sec_voice ul li .text .comment h3 {
          margin-bottom: 0.5em;
          font-size: 2rem; }
        #main .sec_voice ul li .text .comment p {
          font-size: 1.4rem; }
@media screen and (max-width: 780px) {
  #main .sec_order2 {
    padding-top: 0; } }
#main .sec_order2 .inner {
  max-width: 940px; }
#main .sec_order2 dl {
  padding: 2rem;
  background-color: #07376c;
  border: 1px solid #052b54;
  border-radius: 1rem; }
  #main .sec_order2 dl dt {
    margin-bottom: 2rem;
    font-size: 2.8rem;
    text-align: center;
    color: #ffffff; }
  #main .sec_order2 dl dd:nth-of-type(1) {
    padding: 2rem 2rem 1rem 2rem;
    background-color: #ffffff;
    border-radius: 1rem 1rem 0 0;
    display: flex;
    align-items: center; }
    @media screen and (max-width: 780px) {
      #main .sec_order2 dl dd:nth-of-type(1) {
        display: block; } }
    #main .sec_order2 dl dd:nth-of-type(1) p {
      width: 60%;
      padding-right: 1rem; }
      @media screen and (max-width: 780px) {
        #main .sec_order2 dl dd:nth-of-type(1) p {
          width: 100%;
          margin-bottom: 1rem;
          padding-right: 0;
          text-align: center; } }
    #main .sec_order2 dl dd:nth-of-type(1) .tel {
      width: 40%;
      padding-left: 1rem; }
      @media screen and (max-width: 780px) {
        #main .sec_order2 dl dd:nth-of-type(1) .tel {
          width: 100%;
          padding-left: 0;
          text-align: center; } }
      #main .sec_order2 dl dd:nth-of-type(1) .tel a {
        font-size: 3rem;
        font-weight: 700;
        color: #B1080B; }
        #main .sec_order2 dl dd:nth-of-type(1) .tel a:before {
          width: 1.5em;
          height: 1.5em;
          margin-right: 0.5em;
          content: '';
          background-image: url("../img/ic_tel.svg");
          -webkit-background-size: cover;
          background-size: cover;
          display: inline-block;
          vertical-align: -0.4em; }
  #main .sec_order2 dl dd:nth-of-type(2) {
    padding: 1rem 2rem 2rem 2rem;
    background-color: #e1e1e1;
    border-radius: 0 0 1rem 1rem; }
    #main .sec_order2 dl dd:nth-of-type(2) .btn {
      display: flex;
      justify-content: space-between; }
      @media screen and (max-width: 780px) {
        #main .sec_order2 dl dd:nth-of-type(2) .btn {
          display: block; } }
      #main .sec_order2 dl dd:nth-of-type(2) .btn .line {
        width: 48%; }
        @media screen and (max-width: 780px) {
          #main .sec_order2 dl dd:nth-of-type(2) .btn .line {
            width: 100%;
            margin-bottom: 1rem; } }
        #main .sec_order2 dl dd:nth-of-type(2) .btn .line a {
          padding: 0.5em 1em;
          font-size: 2rem;
          text-decoration: none !important;
          text-align: center;
          color: #ffffff;
          background: linear-gradient(to bottom, #b9df5a 0%, #b9df5a 50%, #81ac15 51%, #9cd119 100%);
          border: 1px solid #aaa;
          border-radius: 0.5rem;
          text-shadow: -1px -1px rgba(0, 0, 0, 0.4);
          transition: opacity 0.3s ease;
          display: block; }
          @media screen and (max-width: 780px) {
            #main .sec_order2 dl dd:nth-of-type(2) .btn .line a {
              font-size: 1.8rem; } }
          #main .sec_order2 dl dd:nth-of-type(2) .btn .line a:hover {
            opacity: 0.8; }
      #main .sec_order2 dl dd:nth-of-type(2) .btn .mail {
        width: 48%; }
        @media screen and (max-width: 780px) {
          #main .sec_order2 dl dd:nth-of-type(2) .btn .mail {
            width: 100%; } }
        #main .sec_order2 dl dd:nth-of-type(2) .btn .mail a {
          padding: 0.5em 1em;
          font-size: 2rem;
          text-decoration: none !important;
          text-align: center;
          color: #ffffff;
          background: linear-gradient(to bottom, #7e370e 0%, #7e370e 50%, #000000 51%, #7e370e 100%);
          border: 1px solid #aaa;
          border-radius: 0.5rem;
          text-shadow: -1px -1px rgba(0, 0, 0, 0.4);
          transition: opacity 0.3s ease;
          display: block; }
          @media screen and (max-width: 780px) {
            #main .sec_order2 dl dd:nth-of-type(2) .btn .mail a {
              font-size: 1.8rem; } }
          #main .sec_order2 dl dd:nth-of-type(2) .btn .mail a:hover {
            opacity: 0.8; }
#main .sec_faq .inner {
  max-width: 940px; }
#main .sec_faq ul li .acc_head {
  padding: 2.4rem 3.6rem 2.4rem 2.4rem;
  font-size: 2rem;
  border-bottom: solid 2px #28c3d4;
  position: relative; }
  #main .sec_faq ul li .acc_head:after {
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f078";
    color: #28c3d4;
    position: absolute;
    top: 50%;
    right: 1rem;
    transform: translateY(-50%); }
#main .sec_faq ul li .acc_body {
  padding: 2.4rem; }
#main .sec_faq ul li.open .acc_head:after {
  transform: translateY(-50%) rotate(180deg); }
#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%; }
  #main .sec_company table tr th, #main .sec_company table tr td {
    padding: 1rem;
    text-align: left;
    vertical-align: top;
    border: solid 1px #cccccc; }
  #main .sec_company table tr th {
    width: 40%; }

/****************************************************
 * フォーム
 ****************************************************/
#main .sec_form {
  padding-bottom: 0; }
  #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: #4c2505; }
            #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: #4c2505; }
    #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: #4c2505;
        border: none; }

/****************************************************
 * ログイン要素
 ****************************************************/
.login_block {
  padding: 2rem 0;
  text-align: right;
  color: #ffffff;
  background-color: #f9c270; }
  @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; }
      @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: #4b2203;
      border: none;
      display: inline-block;
      transition: opacity 0.3s; }
      @media screen and (max-width: 780px) {
        .login_block .box .submit input[type="submit"] {
          width: 100%;
          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 dl dd .message .btn .line {
  margin-right: 0; }
  .no_form #main .sec_order01 dl dd .message .btn .line a {
    padding: 0.5em 4em; }
.no_form #main .sec_order2 dl dd:nth-of-type(2) {
  padding-top: 2rem; }
  .no_form #main .sec_order2 dl dd:nth-of-type(2) .btn .line {
    width: 100%; }
    @media screen and (max-width: 780px) {
      .no_form #main .sec_order2 dl dd:nth-of-type(2) .btn .line {
        margin-bottom: 0; } }
    .no_form #main .sec_order2 dl dd:nth-of-type(2) .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 #4b2204;
  border-bottom: double 0.4rem #4b2204; }
.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: #4b2304;
    display: inline-block; }
