@charset "UTF-8";
/* ====================================================
Font
==================================================== */
@import url("https://fonts.googleapis.com/css?family=Noto+Sans+JP:100,300,400,500,700&subset=japanese");
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200;300;400;500;600;700;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Oswald:wght@200;300;400;500;600;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Crimson+Text:ital,wght@0,400;0,600;0,700;1,400;1,600;1,700&display=swap");
/* ====================================================
Media Quary
==================================================== */
.inner, .inner-1400 {
  display: block;
  max-width: 1245px;
  padding: 0 25px;
  margin: 0 auto;
}

.inner-1400 {
  max-width: 1450px;
}

.clearfix {
  *zoom: 1;
}

.clearfix:before {
  content: "";
  display: table;
}

.clearfix:after {
  clear: both;
  content: "";
  display: table;
}

a {
  text-decoration: none;
  -webkit-backface-visibility: hidden;
  -webkit-transition: all .3s ease;
  -o-transition: all .3s ease;
  transition: all .3s ease;
}

a:hover {
  opacity: 0.7;
}

@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
  a {
    display: inline-block;
  }
}

@media screen and (min-width: 835px) {
  a[href^="tel"] {
    pointer-events: none;
  }
}

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

@media screen and (max-width: 1024px) {
  .pc-ipd {
    display: none !important;
  }
}

@media screen and (max-width: 990px) {
  .pc-lg {
    display: none !important;
  }
}

@media screen and (max-width: 640px) {
  .pc-sm {
    display: none !important;
  }
}

@media screen and (max-width: 374px) {
  .pc-xs {
    display: none !important;
  }
}

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

@media screen and (min-width: 1025px) {
  .sp-ipd {
    display: none !important;
  }
}

@media screen and (min-width: 991px) {
  .sp-lg {
    display: none !important;
  }
}

@media screen and (min-width: 641px) {
  .sp-sm {
    display: none !important;
  }
}

.ttlcomp-01 {
  display: block;
  text-align: center;
  margin-bottom: 66px;
}

@media screen and (max-width: 1024px) {
  .ttlcomp-01 {
    margin-bottom: 35px;
  }
}

.ttlcomp-01 span {
  display: block;
}

.ttlcomp-01 span.jp {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: 30px;
  color: #2e2c2b;
}

@media screen and (max-width: 1024px) {
  .ttlcomp-01 span.jp {
    font-size: 20px;
  }
}

.ttlcomp-01 span.en {
  line-height: 1;
  font-size: 120px;
  font-weight: 400;
  margin-bottom: -8px;
}

@media screen and (max-width: 1024px) {
  .ttlcomp-01 span.en {
    font-size: 70px;
  }
}

.btn-comp01 {
  max-width: 330px;
  width: 100%;
  height: 53px;
  border-radius: 7px;
  background: #b07121;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-family: "Noto Serif JP", serif;
  font-size: 21px;
  font-weight: 500;
  color: #fff;
  margin: 0 auto 28px;
}

@media screen and (max-width: 1245px) {
  .btn-comp01 {
    font-size: 16px;
  }
}

@media screen and (max-width: 1024px) {
  .btn-comp01 {
    font-size: 14px;
    border-radius: 3px;
    height: 40px;
    max-width: 260px;
  }
}

.txt-basic {
  font-size: 16px;
  letter-spacing: -1px;
  color: #343434;
  font-weight: 500;
}

@media screen and (max-width: 1024px) {
  .txt-basic {
    letter-spacing: 0;
    font-size: 12px;
    text-align: justify;
  }
}

.txt-center {
  text-align: center;
}

.txt-right {
  text-align: right;
}

.txt-left {
  text-align: left;
}

.color-orange {
  color: #b07121 !important;
}

.color-white {
  color: white !important;
}

.bg-gray {
  background: #f5f1ef;
}

#contents .txt-basic p {
  line-height: 1.875;
}

.en {
  font-family: "Crimson Text", serif;
}

#contents img {
  max-width: 100%;
}

.about-block {
  position: relative;
  padding: 140px 0 0;
  margin-bottom: 57px;
}

@media screen and (max-width: 1024px) {
  .about-block {
    padding: 50px 0 0;
    margin-bottom: 30px;
  }
}

@media screen and (max-width: 640px) {
  .about-block {
    padding: 0;
    margin-bottom: 30px;
  }
}

.about-block .img {
  position: absolute;
  top: 0;
  left: 0;
  width: 55%;
}

@media screen and (max-width: 1024px) {
  .about-block .img {
    width: 45%;
  }
}

@media screen and (max-width: 640px) {
  .about-block .img {
    width: 70%;
    position: static;
    margin: 0 0 -10px;
  }
}

.about-block .inner, .about-block .inner-1400 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  position: relative;
  z-index: 1;
}

.about-block .inner .txt-basic, .about-block .inner-1400 .txt-basic {
  width: 57%;
}

@media screen and (max-width: 1024px) {
  .about-block .inner .txt-basic, .about-block .inner-1400 .txt-basic {
    width: 60%;
  }
}

@media screen and (max-width: 640px) {
  .about-block .inner .txt-basic, .about-block .inner-1400 .txt-basic {
    width: 100%;
  }
}

.about-block .inner .txt-basic .ttl, .about-block .inner-1400 .txt-basic .ttl {
  display: block;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: 24px;
  margin-bottom: 42px;
}

@media screen and (max-width: 1024px) {
  .about-block .inner .txt-basic .ttl, .about-block .inner-1400 .txt-basic .ttl {
    font-size: 18px;
    margin-bottom: 25px;
  }
}

@media screen and (max-width: 640px) {
  .about-block .inner .txt-basic .ttl, .about-block .inner-1400 .txt-basic .ttl {
    margin-bottom: 20px;
  }
}

.about-block .inner .txt-basic .ttl span, .about-block .inner-1400 .txt-basic .ttl span {
  font-size: 30px;
  background-image: -o-linear-gradient(left, #cee1f1 50%, transparent 50%);
  background-image: -webkit-gradient(linear, left top, right top, color-stop(50%, #cee1f1), color-stop(50%, transparent));
  background-image: linear-gradient(to right, #cee1f1 50%, transparent 50%);
  background-size: 200% 28px;
  background-repeat: no-repeat;
  background-position: 0 33px;
}

@media screen and (max-width: 1024px) {
  .about-block .inner .txt-basic .ttl span, .about-block .inner-1400 .txt-basic .ttl span {
    font-size: 20px;
    background-position: 0 22px;
  }
}

.about-block .inner .txt-basic p, .about-block .inner-1400 .txt-basic p {
  margin-bottom: 30px;
}

@media screen and (max-width: 1024px) {
  .about-block .inner .txt-basic p, .about-block .inner-1400 .txt-basic p {
    margin-bottom: 20px;
  }
  .about-block .inner .txt-basic p:last-child, .about-block .inner-1400 .txt-basic p:last-child {
    margin-bottom: 0;
  }
}

@media screen and (max-width: 640px) {
  .about-block .inner .txt-basic p, .about-block .inner-1400 .txt-basic p {
    margin-bottom: 15px;
  }
}

.strength-block {
  position: relative;
  z-index: 1;
}

.strength-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin: 0 -26px;
}

@media screen and (max-width: 1024px) {
  .strength-list {
    margin: 0 -10px;
  }
}

.strength-list .item {
  width: 33.333%;
  padding: 0 26px;
}

@media screen and (max-width: 1024px) {
  .strength-list .item {
    padding: 0 10px;
  }
}

@media screen and (max-width: 640px) {
  .strength-list .item {
    width: 100%;
    margin-bottom: 30px;
  }
  .strength-list .item:last-child {
    margin-bottom: 0;
  }
}

.strength-list .item .img img {
  width: 100%;
}

.strength-list .item .txt-basic {
  background: white;
  padding: 27px 34px 30px;
}

@media screen and (max-width: 1024px) {
  .strength-list .item .txt-basic {
    padding: 10px 15px;
  }
}

.strength-list .item .txt-basic .ttl {
  display: block;
  font-size: 21px;
  line-height: 1.71;
  text-align: center;
  border-bottom: 1px solid #ccc;
  letter-spacing: 0;
  padding: 0 0 15px 0;
  margin-bottom: 22px;
  font-weight: bold;
}

@media screen and (max-width: 1024px) {
  .strength-list .item .txt-basic .ttl {
    font-size: 14px;
    padding: 0 0 10px;
    margin-bottom: 10px;
  }
}

.achievements-block {
  display: block;
  text-align: center;
}

.achievements-heading {
  position: relative;
  margin-bottom: 110px;
  overflow: hidden;
}

@media screen and (max-width: 1024px) {
  .achievements-heading {
    margin-bottom: 40px;
  }
}

.achievements-heading span {
  display: inline-block;
  font-family: "Noto Serif JP", serif;
  font-size: 30px;
  font-weight: 500;
  position: relative;
}

@media screen and (max-width: 1024px) {
  .achievements-heading span {
    font-size: 20px;
  }
}

.achievements-heading span:before, .achievements-heading span:after {
  content: "";
  width: 500%;
  height: 1px;
  background: white;
  position: absolute;
  top: 18px;
}

@media screen and (max-width: 1024px) {
  .achievements-heading span:before, .achievements-heading span:after {
    top: 10px;
  }
}

.achievements-heading span:after {
  left: calc(100% + 26px);
}

@media screen and (max-width: 1024px) {
  .achievements-heading span:after {
    left: calc(100% + 10px);
  }
}

.achievements-heading span:before {
  right: calc(100% + 26px);
}

@media screen and (max-width: 1024px) {
  .achievements-heading span:before {
    right: calc(100% + 10px);
  }
}

.achievements-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 0 -10px;
}

.achievements-list .item {
  width: 25%;
  padding: 0 10px;
  margin-bottom: 89px;
}

@media screen and (max-width: 1024px) {
  .achievements-list .item {
    margin-bottom: 50px;
  }
}

@media screen and (min-width: 641px) {
  .achievements-list .item:nth-child(1), .achievements-list .item:nth-child(4n) {
    padding-left: 0;
  }
  .achievements-list .item:nth-child(3n) {
    padding-right: 0;
  }
  .achievements-list .item:nth-child(2), .achievements-list .item:nth-child(5) {
    width: 50%;
  }
}

@media screen and (max-width: 640px) {
  .achievements-list .item {
    width: 50%;
  }
  .achievements-list .item:nth-child(odd) {
    margin: 0;
  }
  .achievements-list .item:nth-child(even) {
    padding-right: 0;
  }
}

.achievements-list .item .status {
  display: block;
  font-size: 18px;
  margin-bottom: 12px;
  font-weight: bold;
}

@media screen and (max-width: 1024px) {
  .achievements-list .item .status {
    font-size: 14px;
    margin-bottom: 5px;
  }
}

@media screen and (max-width: 640px) {
  .achievements-list .item .status {
    font-size: 12px;
  }
}

.achievements-list .item .list-counter {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  margin-bottom: 12px;
}

.achievements-list .item .list-counter .counter, .achievements-list .item .list-counter .counter-02 {
  display: inline-block;
  font-size: 80px;
  position: relative;
}

@media screen and (max-width: 1024px) {
  .achievements-list .item .list-counter .counter, .achievements-list .item .list-counter .counter-02 {
    font-size: 60px;
  }
}

@media screen and (max-width: 767px) {
  .achievements-list .item .list-counter .counter, .achievements-list .item .list-counter .counter-02 {
    font-size: 40px;
  }
}

@media screen and (max-width: 640px) {
  .achievements-list .item .list-counter .counter, .achievements-list .item .list-counter .counter-02 {
    font-size: 30px;
  }
}

.achievements-list .item .list-counter .counter-small, .achievements-list .item .list-counter .counter-02-small {
  font-size: 64px;
  margin-left: 44px;
}

@media screen and (max-width: 1024px) {
  .achievements-list .item .list-counter .counter-small, .achievements-list .item .list-counter .counter-02-small {
    font-size: 47px;
    margin-left: 27px;
  }
}

@media screen and (max-width: 767px) {
  .achievements-list .item .list-counter .counter-small, .achievements-list .item .list-counter .counter-02-small {
    font-size: 33px;
  }
}

@media screen and (max-width: 640px) {
  .achievements-list .item .list-counter .counter-small, .achievements-list .item .list-counter .counter-02-small {
    font-size: 25px;
    margin-left: 22px;
  }
}

.achievements-list .item .list-counter .counter-small:before, .achievements-list .item .list-counter .counter-02-small:before {
  content: "";
  width: 24px;
  height: 58px;
  background: url(../images/line.png) no-repeat;
  background-size: 100%;
  position: absolute;
  top: 3px;
  left: -33px;
}

@media screen and (max-width: 1024px) {
  .achievements-list .item .list-counter .counter-small:before, .achievements-list .item .list-counter .counter-02-small:before {
    width: 15px;
    height: 50px;
    top: 4px;
    left: -18px;
  }
}

@media screen and (max-width: 767px) {
  .achievements-list .item .list-counter .counter-small:before, .achievements-list .item .list-counter .counter-02-small:before {
    width: 10px;
  }
}

@media screen and (max-width: 640px) {
  .achievements-list .item .list-counter .counter-small:before, .achievements-list .item .list-counter .counter-02-small:before {
    width: 8px;
    left: -16px;
  }
}

.achievements-list .item .list-counter .counter-small + small, .achievements-list .item .list-counter .counter-02-small + small {
  font-size: 24px;
}

@media screen and (max-width: 1024px) {
  .achievements-list .item .list-counter .counter-small + small, .achievements-list .item .list-counter .counter-02-small + small {
    font-size: 14px;
  }
}

.achievements-list .item .list-counter .counter-other {
  margin-left: -18px;
}

@media screen and (max-width: 1024px) {
  .achievements-list .item .list-counter .counter-other {
    margin-left: -16px;
  }
}

@media screen and (max-width: 767px) {
  .achievements-list .item .list-counter .counter-other {
    margin-left: 9px;
  }
}

@media screen and (max-width: 640px) {
  .achievements-list .item .list-counter .counter-other {
    margin-left: -7px;
  }
}

.achievements-list .item .list-counter small {
  display: inline-block;
  font-size: 30px;
  position: relative;
  top: -14px;
  font-weight: 500;
}

@media screen and (max-width: 1024px) {
  .achievements-list .item .list-counter small {
    font-size: 16px;
    top: -6px;
  }
}

@media screen and (max-width: 640px) {
  .achievements-list .item .list-counter small {
    font-size: 12px;
    top: -4px;
  }
}

.achievements-list .item .note {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 14px;
  font-weight: 500;
}

@media screen and (max-width: 1024px) {
  .achievements-list .item .note {
    font-size: 10px;
  }
}

.achievements-list .item .note span {
  display: block;
  padding: 4px 19px;
  border: 1px solid white;
  margin: 0 25px;
  position: relative;
  top: -4px;
}

@media screen and (max-width: 1024px) {
  .achievements-list .item .note span {
    padding: 2px 10px;
    margin: 0 15px;
  }
}

@media screen and (max-width: 767px) {
  .achievements-list .item .note span {
    margin: 0 10px;
  }
}

@media screen and (max-width: 640px) {
  .achievements-list .item .note span {
    padding: 2px 4px;
    margin: 0 3px;
  }
}

@media screen and (max-width: 374px) {
  .achievements-list .item .note span {
    font-size: 8px;
  }
}

@media screen and (min-width: 1025px) {
  .achievements-list .item .note span:nth-child(1) {
    padding: 4px 31px;
  }
}

.heading {
  line-height: 2;
  text-align: center;
  font-family: "Noto Serif JP", serif;
}

@media screen and (max-width: 1024px) {
  .heading {
    line-height: 1.6;
  }
}

.heading .note {
  display: block;
  font-size: 24px;
  font-weight: 500;
  letter-spacing: -1.5px;
  margin-bottom: 17px;
  color: #343434;
}

@media screen and (max-width: 1024px) {
  .heading .note {
    letter-spacing: 0;
    font-size: 18px;
    margin-bottom: 20px;
  }
}

@media screen and (max-width: 640px) {
  .heading .note {
    font-size: 16px;
    margin-bottom: 15px;
  }
}

.heading .note span {
  position: relative;
}

.heading .note span:before {
  content: "・";
  position: absolute;
  top: -27px;
  left: 0;
  right: 0;
  text-align: center;
}

@media screen and (max-width: 1024px) {
  .heading .note span:before {
    top: -19px;
  }
}

.heading .ttl {
  font-size: 30px;
  font-weight: 500;
  color: #2e2c2b;
}

@media screen and (max-width: 1024px) {
  .heading .ttl {
    font-size: 20px;
  }
}

.compare-note {
  display: block;
  margin: 0 auto 67px;
  padding: 12px 0;
  max-width: 700px;
}

@media screen and (max-width: 1024px) {
  .compare-note {
    margin-bottom: 30px;
  }
}

.compare-note .ttl {
  display: block;
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-size: 30px;
  font-weight: 500;
  letter-spacing: 0;
  margin-bottom: 44px;
  color: #141618;
}

@media screen and (max-width: 1024px) {
  .compare-note .ttl {
    font-size: 20px;
    margin-bottom: 20px;
    line-height: 1.5;
  }
}

.compare-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin: 0 -55px;
}

@media screen and (max-width: 1024px) {
  .compare-list {
    margin: 0 -10px;
  }
}

.compare-list .item {
  width: 25%;
  padding: 0 55px;
}

@media screen and (max-width: 1024px) {
  .compare-list .item {
    padding: 0 10px;
  }
}

@media screen and (max-width: 640px) {
  .compare-list .item {
    width: 50%;
    margin-bottom: 30px;
  }
}

.compare-list .item .img {
  margin-bottom: 18px;
}

.compare-list .item .img img {
  width: 100%;
}

.compare-list .item .txt-basic {
  text-align: center;
  color: #333333;
}

.compare-list .item .txt-basic .ttl {
  display: block;
  font-weight: bold;
  font-size: 18px;
  letter-spacing: 0;
  margin-bottom: 6px;
}

.compare-list .item .txt-basic.color-orange {
  color: #b72a3b !important;
}

.practice-block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.practice-block img {
  width: 100%;
}

.practice-block .img {
  width: 48%;
}

@media screen and (max-width: 640px) {
  .practice-block .img {
    width: 100%;
    margin-bottom: 15px;
  }
}

.practice-block .txt-basic {
  width: 52%;
  padding: 59px 0 0 62px;
}

@media screen and (max-width: 1024px) {
  .practice-block .txt-basic {
    padding: 0 0 0 15px;
  }
}

@media screen and (max-width: 640px) {
  .practice-block .txt-basic {
    width: 100%;
    padding: 0;
  }
}

.practice-block .txt-basic .ttl {
  display: block;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: 48px;
  letter-spacing: 2px;
  margin-bottom: 38px;
}

@media screen and (max-width: 1024px) {
  .practice-block .txt-basic .ttl {
    font-size: 34px;
    letter-spacing: 1px;
    margin-bottom: 15px;
  }
}

@media screen and (max-width: 640px) {
  .practice-block .txt-basic .ttl {
    font-size: 26px;
    text-align: center;
  }
}

.practice-block .txt-basic .note {
  display: block;
  font-weight: 500;
  font-family: "Noto Serif JP", serif;
  line-height: 2;
  font-size: 30px;
  letter-spacing: 0;
  margin-bottom: 28px;
  color: #141618;
}

@media screen and (max-width: 1024px) {
  .practice-block .txt-basic .note {
    font-size: 22px;
    margin-bottom: 15px;
    line-height: 1.4;
  }
}

@media screen and (max-width: 640px) {
  .practice-block .txt-basic .note {
    text-align: center;
  }
}

.practice-block .txt-basic p {
  margin-bottom: 31px;
}

@media screen and (max-width: 1024px) {
  .practice-block .txt-basic p {
    margin-bottom: 15px;
  }
}

.practice-block .txt-basic p:last-child {
  margin-bottom: 0;
}

.practice-block .show-img {
  display: block;
  overflow: hidden;
  margin: 36px -25px;
}

@media screen and (max-width: 1024px) {
  .practice-block .show-img {
    margin: 30px -7px;
  }
}

@media screen and (max-width: 640px) {
  .practice-block .show-img {
    margin: 0 0 20px;
  }
}

.practice-block .show-img img {
  width: 100%;
}

.practice-block .show-img li {
  width: 50%;
  padding: 0 25px;
  float: left;
}

@media screen and (max-width: 1024px) {
  .practice-block .show-img li {
    padding: 0 7px;
  }
}

.sec-heading {
  padding: 0 0 52px;
}

@media screen and (max-width: 1024px) {
  .sec-heading {
    padding: 0 0 35px;
  }
}

.sec-about {
  padding: 0 0 112px;
}

@media screen and (max-width: 1024px) {
  .sec-about {
    padding: 0 0 50px;
  }
}

.sec-achievements {
  background: url(../images/bg-01.png) no-repeat;
  background-size: cover;
  background-position: center center;
  padding: 144px 0 76px;
  color: white;
}

@media screen and (max-width: 1024px) {
  .sec-achievements {
    padding: 40px 0 0;
  }
}

.sec-achievements .inner, .sec-achievements .inner-1400 {
  max-width: 1025px;
}

@media screen and (max-width: 640px) {
  .sec-achievements .inner, .sec-achievements .inner-1400 {
    padding: 0 10px;
  }
}

.sec-compare {
  padding: 122px 0 53px;
}

@media screen and (max-width: 1024px) {
  .sec-compare {
    padding: 45px 0 50px;
  }
}

@media screen and (max-width: 640px) {
  .sec-compare {
    padding-bottom: 0;
  }
}

.sec-practice {
  padding: 73px 0 100px;
}

@media screen and (max-width: 1024px) {
  .sec-practice {
    padding: 35px 0 50px;
  }
}

@media screen and (min-width: 1025px) {
  .sec-practice .btn-comp01 {
    max-width: 275px;
    margin-bottom: 61px;
  }
}

/*# sourceMappingURL=maps/uniq.css.map */
