@charset "UTF-8";
html {
  scroll-behavior: smooth;
}

body {
  font-family: "Yu Gothic Medium", "Yu Gothic", "YuGothic", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Meiryo", sans-serif;
  box-sizing: border-box;
}

main {
  position: relative;
}

.container {
  padding: 0 100px;
  max-width: 1080px;
  margin: 0 auto;
}
@media screen and (max-width: 1024px) {
  .container {
    padding: 0 20px;
  }
}
.container--concept {
  padding: 0 111px;
}
@media screen and (max-width: 1024px) {
  .container--concept {
    padding: 0 20px;
  }
}
.container--flow {
  padding-left: 162px;
  padding-right: 162px;
}
@media screen and (max-width: 1024px) {
  .container--flow {
    padding: 0 20px;
  }
}

p {
  font-weight: 500;
  font-size: 18px;
  line-height: 30px;
}
@media screen and (max-width: 576px) {
  p {
    font-size: 16px;
  }
}

h1,
h2,
h3 {
  font-weight: 700;
}

.back-to-top {
  position: absolute;
  right: 116px;
  bottom: 91px;
}
@media screen and (max-width: 768px) {
  .back-to-top {
    right: 20px;
    bottom: 79px;
  }
}
.back-to-top--contact {
  bottom: 30px;
}
@media screen and (max-width: 768px) {
  .back-to-top--contact {
    bottom: 18px;
  }
}

@media screen and (max-width: 768px) {
  .pc-only {
    display: none;
  }
}

.sp-only {
  display: none;
}
@media screen and (max-width: 576px) {
  .sp-only {
    display: block;
  }
}

.sp-only--inline {
  display: none;
}
@media screen and (max-width: 768px) {
  .sp-only--inline {
    display: inline;
  }
}

.sr-only {
  position: absolute;
  width: 0.01px;
  height: 0.01px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

summary {
  display: block;
  list-style: none;
  cursor: pointer;
}
summary::-webkit-details-marker {
  display: none;
}

picture {
  display: inline-block;
}

.img__heading {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 0;
  left: 0;
  background-color: rgb(203, 0, 0);
  color: white;
  font-size: 15px;
  line-height: 25px;
  height: 30px;
}
.img__heading--result-list {
  width: 100px;
}

.fv {
  background-repeat: no-repeat;
  background-size: cover;
  text-align: center;
  position: relative;
}
@media screen and (max-width: 768px) {
  .fv {
    height: 300px;
  }
}
.fv::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.34);
}
.fv h2,
.fv h1 {
  color: white;
  font-size: 25px;
  line-height: 60px;
  position: relative;
  z-index: 1;
}
.fv--lower {
  padding-top: 74px;
  padding-bottom: 66px;
}
@media screen and (max-width: 768px) {
  .fv--lower {
    padding-top: 124px;
    padding-bottom: 116px;
  }
}
.fv--index {
  background-image: url(images/photo/index__fv.jpg);
  padding-top: 185px;
  padding-bottom: 165px;
}
@media screen and (max-width: 768px) {
  .fv--index {
    padding-top: 208px;
    padding-bottom: 192px;
  }
}
.fv--index h2 {
  font-size: 40px;
  line-height: 60px;
}
@media screen and (max-width: 768px) {
  .fv--index {
    background-image: url(images/photo/index__fv--sp.jpg);
    height: 550px;
  }
  .fv--index h2 {
    font-size: 30px;
    line-height: 50px;
  }
}
.fv--blog-list {
  background-image: url(images/photo/blog-list__fv.jpg);
}
@media screen and (max-width: 768px) {
  .fv--blog-list {
    background-image: url(images/photo/blog-list__fv--sp.jpg);
  }
}
.fv--plan {
  background-image: url(images/photo/plan__fv.jpg);
}
@media screen and (max-width: 768px) {
  .fv--plan {
    background-image: url(images/photo/plan__fv--sp.jpg);
  }
}
.fv--contact {
  background-image: url(images/photo/contact__fv.jpg);
}
@media screen and (max-width: 768px) {
  .fv--contact {
    background-image: url(images/photo/contact__fv--sp.jpg);
  }
}
.fv--result-list {
  background-image: url(images/result/result-list__fv.jpg);
}
@media screen and (max-width: 768px) {
  .fv--result-list {
    background-position: 50%;
  }
}
.fv--error {
  background-image: url(images/photo/404__fv.jpg);
}
@media screen and (max-width: 768px) {
  .fv--error {
    background-image: url(images/photo/404__fv--sp.jpg);
  }
}

.section-title {
  text-align: center;
  font-size: 25px;
  line-height: 38px;
}
.section-title--blog-list {
  margin-bottom: 38px;
}
@media screen and (max-width: 768px) {
  .section-title--blog-list {
    margin-bottom: 39px;
  }
}
.section-title--price-struct {
  margin-bottom: 40px;
}
@media screen and (max-width: 768px) {
  .section-title--price-struct {
    margin-bottom: 39px;
  }
}
.section-title--pricing-plan {
  margin-bottom: 50px;
}
@media screen and (max-width: 768px) {
  .section-title--pricing-plan {
    margin-bottom: 6px;
  }
}
.section-title--result-list {
  margin-bottom: 40px;
}
@media screen and (max-width: 768px) {
  .section-title {
    line-height: 40px;
  }
}

.index__title {
  font-size: 30px;
  line-height: 50px;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .index__title {
    font-size: 25px;
    line-height: 40px;
  }
}
.index__title--appeal {
  color: white;
  margin-bottom: 30px;
}
@media screen and (max-width: 768px) {
  .index__title--appeal {
    margin-bottom: 14px;
  }
}
.index__title--reasons {
  margin-bottom: 28px;
}
@media screen and (max-width: 768px) {
  .index__title--reasons {
    margin-bottom: 36px;
  }
}
.index__title--testimonial {
  color: white;
  margin-bottom: 36px;
}
@media screen and (max-width: 768px) {
  .index__title--testimonial {
    margin-bottom: 39px;
  }
}
.index__title--flow {
  margin-bottom: 53px;
}
@media screen and (max-width: 768px) {
  .index__title--flow {
    margin-bottom: 36px;
  }
}
.index__title--faq {
  margin-bottom: 36px;
}
@media screen and (max-width: 768px) {
  .index__title--faq {
    margin-bottom: 39px;
  }
}
.index__title--blog {
  line-height: 45px;
  margin-bottom: 38px;
}
@media screen and (max-width: 768px) {
  .index__title--blog {
    margin-bottom: 39px;
    line-height: 40px;
  }
}

.btn {
  background-color: rgb(203, 0, 0);
  color: white;
  display: flex;
  text-align: center;
  justify-content: center;
  align-items: center;
  font-weight: 700;
  line-height: 33px;
}
.btn--price-struct {
  width: 210px;
  height: 60px;
  font-size: 20px;
}
.btn--contact-send, .btn--error {
  margin: 0 auto;
}
.btn--submit, .btn--contact-send, .btn--error {
  font-size: 25px;
  line-height: 33px;
  width: 250px;
  height: 50px;
}
@media screen and (max-width: 576px) {
  .btn--submit, .btn--contact-send, .btn--error {
    font-size: 20px;
    width: 100%;
  }
}

.contact-cta {
  position: absolute;
  right: 0;
  bottom: 0;
  font-size: 20px;
  letter-spacing: 20%;
  width: 300px;
  height: 60px;
}
@media screen and (max-width: 768px) {
  .contact-cta {
    right: 50%;
    transform: translateX(50%);
    width: 335px;
  }
}
@media screen and (max-width: 576px) {
  .contact-cta {
    width: calc(100% - 40px);
  }
}

.nav-links {
  padding-bottom: 210px;
}
@media screen and (max-width: 768px) {
  .nav-links {
    padding-bottom: 203px;
  }
}
.nav-links ul {
  display: flex;
  justify-content: center;
  gap: 10px;
  list-style: none;
  font-size: 18px;
  line-height: 30px;
}
@media screen and (max-width: 768px) {
  .nav-links ul {
    gap: 5px;
    font-size: 16px;
    line-height: 28px;
  }
}
.nav-links li {
  text-decoration: none;
  color: black;
  background-color: white;
  transition: 0.3s;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .nav-links li {
    width: 44px;
    height: 44px;
  }
}
.nav-links li:hover {
  background-color: #f0f0f0;
}
.nav-links li .current {
  background-color: black;
  color: white;
}
.nav-links li .dots {
  border: none;
  outline: none;
}
.nav-links li span,
.nav-links li a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  border: 1px solid black;
}

.header__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 16px;
  padding-bottom: 14px;
}
@media screen and (max-width: 768px) {
  .header__inner {
    padding-top: 9.89px;
    padding-bottom: 8.82px;
  }
}

.header__logo a {
  display: flex;
  align-items: center;
  gap: 10px;
}
@media screen and (max-width: 768px) {
  .header__logo a {
    gap: 6.32px;
  }
}

.logo__img {
  transform: translateY(-2px);
}

.logo__text {
  font-weight: 700;
  display: flex;
  flex-direction: column;
  line-height: 23px;
}
@media screen and (max-width: 768px) {
  .logo__text {
    flex-direction: row;
    line-height: 14px;
  }
}

.logo__text--main {
  font-size: 20px;
}
@media screen and (max-width: 768px) {
  .logo__text--main {
    font-size: 13px;
  }
}

.logo__text--sub {
  font-size: 15px;
  transform: translateY(2px);
}
@media screen and (max-width: 768px) {
  .logo__text--sub {
    font-size: 13px;
    transform: translateY(0);
  }
}

.header__nav-list {
  display: flex;
  align-items: center;
  gap: 33px;
  font-weight: 700;
  font-size: 17px;
  line-height: 33px;
  transform: translateY(1px);
}
@media screen and (max-width: 768px) {
  .header__nav-list {
    position: fixed;
    top: 50px;
    right: -100%;
    flex-direction: column;
    align-items: flex-start;
    gap: 25px;
    font-size: 18px;
    background-color: rgb(203, 0, 0);
    color: white;
    padding-top: 15px;
    padding-bottom: 10px;
    padding-left: 20px;
    width: 300px;
    transition: 0.3s;
    z-index: 100;
  }
  .header__nav-list.open {
    right: 0;
  }
}

.header__btn {
  width: 150px;
  padding-top: 7px;
  padding-bottom: 5px;
  font-size: 15px;
  transform: translateY(-1.5px);
}
@media screen and (max-width: 768px) {
  .header__btn {
    display: none;
  }
}

.hamburger {
  display: none;
}
@media screen and (max-width: 768px) {
  .hamburger {
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    cursor: pointer;
    width: 71px;
    height: 50px;
    z-index: 10;
    background-color: rgb(203, 0, 0);
  }
  .hamburger span {
    transition: all 0.3s;
    position: absolute;
    height: 4px;
    background-color: white;
    width: 33px;
    z-index: 10;
    margin: 0 auto;
    left: 50%;
    transform: translateX(-50%);
  }
  .hamburger span:nth-child(1) {
    top: 11px;
  }
  .hamburger span:nth-child(2) {
    top: 23px;
  }
  .hamburger span:nth-child(3) {
    bottom: 11px;
  }
  .hamburger.open span:nth-child(1) {
    top: 50%;
    transform: translateX(-50%) rotate(45deg);
  }
  .hamburger.open span:nth-child(2) {
    opacity: 0;
  }
  .hamburger.open span:nth-child(3) {
    top: 50%;
    transform: translateX(-50%) rotate(-45deg);
  }
}

.breadcrumbs {
  background-color: rgb(232, 232, 232);
}

.breadcrumbs__inner {
  padding-top: 10px;
  padding-bottom: 6px;
}

.breadcrumbs__list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 20px;
}
@media screen and (max-width: 768px) {
  .breadcrumbs__list {
    row-gap: 5px;
  }
}

.breadcrumbs__item {
  height: 33px;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 768px) {
  .breadcrumbs__item {
    height: auto;
  }
}

.breadcrumbs__item a {
  display: inline-block;
  font-weight: 500;
  font-size: 16px;
  line-height: 33px;
}
@media screen and (max-width: 768px) {
  .breadcrumbs__item a {
    line-height: 1;
  }
}

.breadcrumbs__item:not(:last-child)::after {
  content: "";
  display: inline-block;
  width: 12px;
  height: 33px;
  background-image: url("images/icons/矢印.svg");
  background-repeat: no-repeat;
  background-position: center;
  vertical-align: middle;
  margin-left: 21px;
  margin-top: 3.5px;
}
@media screen and (max-width: 768px) {
  .breadcrumbs__item:not(:last-child)::after {
    height: 16px;
  }
}

.concept {
  padding-top: 66px;
  padding-bottom: 55px;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .concept {
    padding-top: 46px;
    padding-bottom: 34px;
  }
}
.concept__title {
  color: #CB0000;
  font-size: 35px;
  line-height: 50px;
  margin-bottom: 17px;
}
@media screen and (max-width: 768px) {
  .concept__title {
    font-size: 25px;
    line-height: 40px;
    margin-bottom: 7px;
  }
}
.concept__desc {
  margin-bottom: 34px;
}
@media screen and (max-width: 768px) {
  .concept__desc {
    font-size: 18px;
    margin-bottom: 20px;
  }
}
.concept__semicircle {
  width: 100%;
  height: auto;
  margin-bottom: 20px;
}
.concept__semicircle img {
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 768px) {
  .concept__semicircle {
    margin-bottom: 32px;
  }
}

.concept-flow {
  position: relative;
}
.concept-flow::before {
  position: absolute;
  top: -24px;
  left: 50%;
  content: "";
  width: 25px;
  height: 25px;
  transform: translateX(-50%) rotate(-135deg);
  border-bottom: 3px solid #CB0000;
  border-right: 3px solid #CB0000;
}
.concept-flow::after {
  position: absolute;
  left: 50%;
  bottom: 15px;
  top: -25px;
  transform: translateX(-50%);
  content: "";
  background-color: #CB0000;
  width: 3px;
}
.concept-flow__item {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 79.88px;
  position: relative;
}
.concept-flow__item::before {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translateX(-50%) translateY(-50%);
  content: "";
  background-color: #CB0000;
  width: 20px;
  height: 20px;
  border-radius: 50%;
}
.concept-flow__item.is-middle {
  margin-top: 17px;
  margin-bottom: 20px;
}
.concept-flow dt {
  color: #CB0000;
  font-size: 25px;
  line-height: 50px;
  font-weight: bold;
  text-align: right;
}
@media screen and (max-width: 768px) {
  .concept-flow dt {
    font-size: 20px;
  }
}
.concept-flow dd {
  text-align: left;
  font-size: 23px;
  line-height: 50px;
}
@media screen and (max-width: 768px) {
  .concept-flow dd {
    font-size: 20px;
  }
}
.concept-flow__img {
  position: absolute;
  bottom: 15px;
  left: 50%;
  transform: translateX(-50%);
}

.appeal {
  background-color: #CB0000;
  padding-top: 68px;
  padding-bottom: 60px;
}
@media screen and (max-width: 768px) {
  .appeal {
    padding-top: 49px;
    padding-bottom: 40px;
  }
}
.appeal__desc {
  color: white;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .appeal__desc {
    font-size: 18px;
  }
}

.reasons {
  padding-top: 64px;
  padding-bottom: 90px;
}
@media screen and (max-width: 768px) {
  .reasons {
    padding-top: 49px;
    padding-bottom: 39px;
  }
}
.reasons__list {
  display: flex;
  flex-direction: column;
  gap: 50px;
}
@media screen and (max-width: 768px) {
  .reasons__list {
    gap: 39px;
  }
}
.reasons__item {
  display: flex;
  gap: 50px;
}
@media screen and (max-width: 576px) {
  .reasons__item {
    flex-direction: column;
    gap: 30px;
  }
}
.reasons__img {
  width: 350px;
  height: 247px;
  flex-shrink: 0;
}
@media screen and (max-width: 576px) {
  .reasons__img {
    width: 100%;
    height: auto;
    aspect-ratio: 67/40;
  }
}
.reasons__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.reasons__title {
  font-size: 22px;
  line-height: 33px;
  padding-bottom: 12px;
  margin-bottom: 37px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .reasons__title {
    font-size: 20px;
    line-height: 30px;
    padding-bottom: 10px;
    margin-bottom: 17px;
  }
}
.reasons__title::after {
  position: absolute;
  content: "";
  background-color: #CB0000;
  bottom: 0;
  left: -50px;
  height: 2px;
  width: calc(100% + 50px);
}
@media screen and (max-width: 768px) {
  .reasons__title::after {
    left: 0;
    right: 0;
    width: 100%;
  }
}
.reasons__desc {
  line-height: 33px;
}
@media screen and (max-width: 768px) {
  .reasons__desc {
    line-height: 30px;
  }
}

.reasons__item:nth-child(1) .reasons__title {
  padding-top: 7px;
}
@media screen and (max-width: 768px) {
  .reasons__item:nth-child(1) .reasons__title {
    padding-top: 0;
  }
}

.reasons__item:nth-child(2) .reasons__title,
.reasons__item:nth-child(3) .reasons__title {
  margin-top: -4px;
}
@media screen and (max-width: 768px) {
  .reasons__item:nth-child(2) .reasons__title,
  .reasons__item:nth-child(3) .reasons__title {
    margin-top: 0;
  }
}

.testimonial {
  background-color: #CB0000;
  padding-top: 44px;
  padding-bottom: 80px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .testimonial {
    padding-top: 46px;
    padding-bottom: 50px;
  }
}
.testimonial__list {
  display: flex;
  gap: 35px;
  width: -moz-max-content;
  width: max-content;
  flex-wrap: nowrap;
}
.testimonial__item {
  flex: 0 0 calc((100cqw - 70px) / 3);
}
@media screen and (max-width: 768px) {
  .testimonial__item {
    flex: 0 0 calc((100cqw - 35px) / 2);
  }
}
@media screen and (max-width: 576px) {
  .testimonial__item {
    flex: 0 0 100cqw;
  }
}
.testimonial__img {
  width: 100%;
  aspect-ratio: 27/19;
}
@media screen and (max-width: 768px) {
  .testimonial__img {
    aspect-ratio: 67/40;
  }
}
.testimonial__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.testimonial__text {
  color: white;
}
.testimonial__title {
  font-size: 22px;
  line-height: 33px;
  text-align: center;
  margin-top: 17px;
  margin-bottom: 10px;
}
@media screen and (max-width: 768px) {
  .testimonial__title {
    margin-top: 27px;
  }
}
.testimonial__desc {
  font-size: 18px;
  line-height: 30px;
}
.testimonial__viewport {
  overflow: hidden;
  width: 100%;
  container-type: inline-size;
}

.slider-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  .slider-btn {
    top: 51%;
    transform: translateY(-51%);
  }
}
.slider-btn.prev {
  left: 61px;
}
@media screen and (max-width: 768px) {
  .slider-btn.prev {
    left: 25px;
  }
}
.slider-btn.next {
  right: 61px;
}
@media screen and (max-width: 768px) {
  .slider-btn.next {
    right: 25px;
  }
}

.flow {
  padding-top: 34px;
}
@media screen and (max-width: 768px) {
  .flow {
    padding-top: 46px;
  }
}
.flow__list {
  display: flex;
  flex-direction: column;
  gap: 58px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .flow__list {
    gap: 36px;
  }
}
.flow__list::before {
  content: "";
  position: absolute;
  left: -2px;
  top: 18px;
  bottom: -19px;
  width: 3px;
  background-color: #CB0000;
}
@media screen and (max-width: 768px) {
  .flow__list::before {
    left: 16px;
    bottom: 11px;
  }
}
.flow__list::after {
  content: "";
  position: absolute;
  left: -13px;
  bottom: -15px;
  width: 26px;
  height: 26px;
  border-right: 3px solid #CB0000;
  border-bottom: 3px solid #CB0000;
  transform: rotate(45deg);
}
@media screen and (max-width: 768px) {
  .flow__list::after {
    left: 4px;
    bottom: 12px;
  }
}
.flow__item {
  display: grid;
  grid-template-columns: 154px 1fr;
  gap: 38px;
  padding-left: 59.7px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .flow__item {
    display: block;
    padding-left: 48px;
  }
}
.flow__item::before {
  content: "";
  position: absolute;
  left: -10px;
  top: 13%;
  transform: translateY(-12%);
  width: 20px;
  height: 20px;
  background-color: #CB0000;
  border-radius: 50%;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .flow__item::before {
    top: 8%;
    left: 7px;
  }
}
.flow__title {
  color: #CB0000;
  font-size: 22px;
  line-height: 33px;
}
@media screen and (max-width: 768px) {
  .flow__title {
    margin-bottom: 9px;
  }
}

.faq {
  padding-top: 107.2px;
}
@media screen and (max-width: 768px) {
  .faq {
    padding-top: 55px;
  }
}
.faq__item {
  position: relative;
}
.faq__item::before {
  content: "";
  height: 1px;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  background-color: black;
}
.faq__item:last-child::after {
  content: "";
  height: 1px;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: black;
}
.faq__item[open] .faq__icon {
  transform: translateY(-5px) rotate(180deg);
}
.faq__question {
  position: relative;
  padding-top: 20px;
  padding-bottom: 15px;
  padding-left: 65px;
  font-size: 17px;
  line-height: 30px;
}
@media screen and (max-width: 768px) {
  .faq__question {
    padding-top: 17px;
    padding-bottom: 9px;
    font-size: 16px;
    padding-left: 55px;
    padding-right: 47px;
  }
}
.faq__question::before {
  position: absolute;
  left: 20px;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  justify-content: center;
  align-items: center;
  content: "Q";
  font-size: 20px;
  line-height: 30px;
  width: 35px;
  height: 35px;
  color: white;
  background-color: black;
  border-radius: 50%;
}
@media screen and (max-width: 768px) {
  .faq__question::before {
    left: 0;
  }
}
.faq__icon {
  position: absolute;
  bottom: 23.5px;
  right: 27.8px;
  width: 16.62px;
  height: 12.24px;
  display: inline-block;
  transition: all 0.3s ease;
}
@media screen and (max-width: 768px) {
  .faq__icon {
    top: 50%;
    transform: translateY(-50%);
    right: 13px;
  }
}
.faq__answer {
  color: #CB0000;
  background-color: rgba(203, 0, 0, 0.098);
  position: relative;
  padding-top: 19px;
  padding-bottom: 16px;
  padding-left: 65px;
}
@media screen and (max-width: 768px) {
  .faq__answer {
    padding-top: 17px;
    padding-bottom: 9px;
    padding-right: 47px;
    padding-left: 55px;
  }
}
.faq__answer::before {
  content: "A";
  position: absolute;
  left: 20px;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 20px;
  line-height: 30px;
  width: 35px;
  height: 35px;
  color: white;
  background-color: #CB0000;
  border-radius: 50%;
}
@media screen and (max-width: 768px) {
  .faq__answer::before {
    left: 0;
  }
}
.faq__text {
  font-weight: 700;
  font-size: 17px;
}
@media screen and (max-width: 768px) {
  .faq__text {
    font-size: 16px;
  }
}

.index-blog {
  padding-top: 70.45px;
  padding-bottom: 205px;
}
@media screen and (max-width: 768px) {
  .index-blog {
    padding-top: 50px;
    padding-bottom: 191px;
  }
}
.index-blog__list {
  display: flex;
  gap: 50px;
  flex-wrap: wrap;
}
@media screen and (max-width: 576px) {
  .index-blog__list {
    flex-direction: column;
    gap: 41px;
  }
}
.index-blog__item {
  width: calc((100% - 100px) / 3);
}
@media screen and (max-width: 768px) {
  .index-blog__item {
    width: calc((100% - 50px) / 2);
  }
}
@media screen and (max-width: 576px) {
  .index-blog__item {
    width: 100%;
  }
}
.index-blog__img {
  position: relative;
  width: 100%;
  aspect-ratio: 13/10;
}
@media screen and (max-width: 768px) {
  .index-blog__img {
    aspect-ratio: 67/40;
  }
}
.index-blog__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.index-blog__title {
  font-size: 20px;
  line-height: 25px;
  margin-top: 20px;
  margin-bottom: 11px;
}
@media screen and (max-width: 768px) {
  .index-blog__title {
    margin-top: 30px;
    margin-bottom: 6px;
    line-height: 30px;
  }
}
.index-blog__time {
  display: block;
  text-align: end;
  font-size: 17px;
  line-height: 30px;
}
.index-blog .img__heading {
  width: 80px;
}
@media screen and (max-width: 768px) {
  .index-blog .img__heading {
    width: 90px;
  }
}
.index-blog .link-blog {
  display: block;
  text-align: end;
  font-size: 18px;
  line-height: 30px;
  text-decoration: underline;
  margin-top: 37px;
}
@media screen and (max-width: 768px) {
  .index-blog .link-blog {
    text-align: center;
  }
}

.price-struct {
  padding-top: 67px;
}
@media screen and (max-width: 768px) {
  .price-struct {
    padding-top: 46px;
  }
}

.price-struct__formula {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 30px;
  margin-bottom: 48px;
}
@media screen and (max-width: 576px) {
  .price-struct__formula {
    flex-direction: column;
    gap: 19px;
    margin-bottom: 47px;
  }
}

.price-struct__plus {
  width: 18.5px;
  height: 18.5px;
}
.price-struct__plus img {
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 576px) {
  .price-struct__plus {
    width: 19px;
    height: 19px;
  }
}

.pricing-plan {
  padding-top: 57px;
  padding-bottom: 223px;
}
@media screen and (max-width: 768px) {
  .pricing-plan {
    padding-top: 38px;
    padding-bottom: 186px;
  }
}

.pricing-table {
  width: 880px;
  border-bottom: 0.5px solid black;
}
@media screen and (max-width: 768px) {
  .pricing-table {
    width: 674.5px;
    margin-bottom: 17.5px;
  }
}
.pricing-table tbody tr:nth-child(even) {
  background-color: rgba(80, 80, 80, 0.149);
}
.pricing-table tbody td {
  border-left: 0.5px solid black;
}
.pricing-table__line {
  display: inline-block;
  vertical-align: middle;
  height: 0.5px;
  width: 30px;
  background-color: black;
}
.pricing-table__note {
  font-size: 17px;
  line-height: 25px;
  margin-top: 28px;
}
@media screen and (max-width: 768px) {
  .pricing-table__note {
    font-size: 16px;
    line-height: 30px;
    margin-top: 17px;
  }
}
.pricing-table__wrapper {
  overflow-x: auto;
  pointer-events: auto;
  width: 100%;
  -webkit-overflow-scrolling: touch;
}
.pricing-table__wrapper::-webkit-scrollbar {
  height: 23px;
}
.pricing-table__wrapper::-webkit-scrollbar-track {
  background-color: rgba(80, 80, 80, 0.149);
}
.pricing-table__wrapper::-webkit-scrollbar-thumb {
  background-color: #707070;
  border-radius: 0;
}

.pricing-table__label {
  font-size: 17px;
  line-height: 25px;
  font-weight: 500;
  padding-top: 32px;
  padding-bottom: 28px;
  padding-left: 20px;
}
@media screen and (max-width: 768px) {
  .pricing-table__label {
    font-size: 16px;
  }
  .pricing-table__label--community {
    padding-top: 19px;
    padding-bottom: 16px;
  }
}
.pricing-table__label--sub {
  font-size: 17px;
  line-height: 33px;
  display: block;
  padding-left: 0;
}
.pricing-table__label--plan {
  text-align: center;
  vertical-align: bottom;
  width: 220px;
  font-weight: bold;
  font-size: 20px;
  line-height: 27px;
  color: white;
  background-color: black;
  padding-top: 11px;
  padding-bottom: 9px;
  padding-left: 0;
  position: relative;
}
@media screen and (max-width: 768px) {
  .pricing-table__label--plan {
    line-height: 25px;
    width: 169px;
    padding-top: 6px;
    padding-bottom: 8px;
  }
}
.pricing-table__label--price {
  font-weight: bold;
  font-size: 17px;
  line-height: 30px;
  padding-top: 30px;
  padding-bottom: 25px;
  border-top: 0.5px solid black;
}
@media screen and (max-width: 768px) {
  .pricing-table__label--price {
    font-size: 16px;
  }
}

.pricing-table__data {
  text-align: center;
  font-size: 17px;
  line-height: 25px;
}
.pricing-table__data .circle {
  display: block;
  font-size: 15px;
  line-height: 1;
}
.pricing-table__data .circle--only {
  padding: 35px 0;
}
.pricing-table__data--inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding-top: 22px;
  padding-bottom: 15px;
}
.pricing-table__data--price {
  font-size: 22px;
  line-height: 33px;
  padding-top: 29px;
  padding-bottom: 23px;
}

.is-popular--label {
  background-color: #CB0000;
}
.is-popular--data {
  color: #CB0000;
}

.nothing-inner {
  padding: 28px 0;
}

.pricing-table__label--plan:not(.is-popular--label)::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 30px;
  background-color: white;
  z-index: 1;
}

.blog-list__content {
  padding-top: 67px;
  padding-bottom: 70px;
}
@media screen and (max-width: 768px) {
  .blog-list__content {
    padding-top: 46px;
    padding-bottom: 59px;
  }
}

.blog-list__content ul {
  display: flex;
  flex-direction: column;
  gap: 70px;
}
@media screen and (max-width: 768px) {
  .blog-list__content ul {
    gap: 39px;
    padding: 0 50px;
  }
}
@media screen and (max-width: 576px) {
  .blog-list__content ul {
    padding: 0;
  }
}

.blog-list__item a {
  display: flex;
  gap: 50px;
}
@media screen and (max-width: 768px) {
  .blog-list__item a {
    gap: 30px;
    flex-direction: column;
  }
}
.blog-list__item h3 {
  font-size: 20px;
  line-height: 25px;
}
@media screen and (max-width: 768px) {
  .blog-list__item h3 {
    line-height: 30px;
  }
}
.blog-list__item time {
  display: block;
  font-size: 17px;
  line-height: 30px;
  margin-top: 3px;
  margin-bottom: 11px;
}
@media screen and (max-width: 768px) {
  .blog-list__item time {
    text-align: end;
    margin-top: 6px;
    margin-bottom: 8px;
  }
}

.blog-list__img {
  position: relative;
  flex-shrink: 0;
  width: 29.5454545455%;
  aspect-ratio: 260/184;
}
.blog-list__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.blog-list__img .img__heading {
  width: 80px;
}
@media screen and (max-width: 768px) {
  .blog-list__img .img__heading {
    width: 90px;
  }
}
@media screen and (max-width: 768px) {
  .blog-list__img {
    width: 100%;
    height: auto;
  }
}

.blog-details__wrapper {
  padding-top: 70px;
  padding-bottom: 187px;
}
@media screen and (max-width: 768px) {
  .blog-details__wrapper {
    padding-top: 50px;
    padding-bottom: 197px;
  }
}

.blog-details--flex {
  display: flex;
  gap: 31px;
}
@media screen and (max-width: 768px) {
  .blog-details--flex {
    flex-direction: column;
    gap: 30.1px;
  }
}

article {
  flex: 1;
}

aside {
  flex: 0 0 250px;
}

.post__thumbnail {
  width: 100%;
  aspect-ratio: 60/35;
  position: relative;
}
.post__thumbnail img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.post__thumbnail .img__heading {
  width: 80px;
}
@media screen and (max-width: 768px) {
  .post__thumbnail {
    aspect-ratio: 335/200;
  }
  .post__thumbnail .img__heading {
    width: 90px;
  }
}

.post h1 {
  font-size: 25px;
  line-height: 40px;
  margin-top: 46px;
  margin-bottom: 5px;
}
@media screen and (max-width: 768px) {
  .post h1 {
    font-size: 20px;
    line-height: 30px;
    margin-top: 30px;
    margin-bottom: 6px;
  }
}

.post__time {
  display: inline-block;
  font-weight: 500;
  font-size: 17px;
  line-height: 30px;
  margin-bottom: 21px;
}

.blog-details__sns-list {
  display: flex;
  gap: 3px;
  margin-bottom: 53px;
}
.blog-details__sns-list a {
  display: flex;
  align-items: center;
}
.blog-details__sns-list .sns__item {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  font-weight: 700;
  font-size: 10px;
  line-height: 1;
  color: white;
}
.blog-details__sns-list .sns__item--facebook {
  background-color: #425893;
  width: 105px;
}
.blog-details__sns-list .sns__item--facebook a {
  gap: 13.5px;
}
@media screen and (max-width: 768px) {
  .blog-details__sns-list .sns__item--facebook {
    width: 65px;
  }
}
.blog-details__sns-list .sns__item--twitter {
  background-color: #4A9FEB;
  width: 88px;
}
.blog-details__sns-list .sns__item--twitter a {
  gap: 10px;
}
@media screen and (max-width: 768px) {
  .blog-details__sns-list .sns__item--twitter {
    width: 65px;
  }
}
.blog-details__sns-list .sns__item--hatena {
  background-color: #4A9FEB;
  width: 93px;
}
.blog-details__sns-list .sns__item--hatena a {
  gap: 11px;
}
@media screen and (max-width: 768px) {
  .blog-details__sns-list .sns__item--hatena {
    width: 65px;
  }
}
.blog-details__sns-list .sns__item--line {
  background-color: #52B534;
  width: 81px;
}
.blog-details__sns-list .sns__item--line a {
  gap: 8.4px;
}
@media screen and (max-width: 768px) {
  .blog-details__sns-list .sns__item--line {
    width: 65px;
  }
}
.blog-details__sns-list .sns__item--pocket {
  background-color: #DC4F5A;
  width: 91px;
}
.blog-details__sns-list .sns__item--pocket a {
  gap: 9.24px;
}
@media screen and (max-width: 768px) {
  .blog-details__sns-list .sns__item--pocket {
    width: 65px;
  }
}
@media screen and (max-width: 768px) {
  .blog-details__sns-list {
    margin-bottom: 27px;
  }
  .blog-details__sns-list span {
    display: none;
  }
}

.post__content h2,
.post__content h3 {
  font-size: 20px;
  line-height: 40px;
}
@media screen and (max-width: 768px) {
  .post__content h2,
  .post__content h3 {
    line-height: 30px;
  }
}
.post__content h2 {
  margin-top: 28px;
  margin-bottom: 15px;
}
@media screen and (max-width: 768px) {
  .post__content h2 {
    margin-top: 39px;
    margin-bottom: 17px;
  }
}
.post__content h3 {
  margin-top: 43.5px;
  margin-bottom: 17px;
  padding-left: 9.5px;
  position: relative;
}
.post__content h3::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 60%;
  transform: translateY(60%);
  height: 100%;
  width: 3px;
  background-color: black;
}
@media screen and (max-width: 768px) {
  .post__content h3 {
    margin-top: 50px;
    margin-bottom: 19.5px;
  }
}
.post__content ul {
  position: relative;
  font-weight: 500;
  font-size: 18px;
  line-height: 30px;
  padding-bottom: 40.5px;
}
.post__content ul::after {
  position: absolute;
  content: "";
  height: 1px;
  width: 100%;
  background-color: black;
  right: 0;
  left: 0;
  bottom: 0;
}
@media screen and (max-width: 768px) {
  .post__content ul {
    font-size: 16px;
    padding-bottom: 38.5px;
  }
  .post__content ul::after {
    height: 0;
  }
}
.post__content blockquote {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  background-color: rgb(232, 232, 232);
  padding-left: 67px;
  padding-right: 30px;
  padding-top: 18px;
  padding-bottom: 10px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .post__content blockquote {
    padding-top: 17px;
    padding-bottom: 11px;
    padding-left: 70px;
    padding-right: 20px;
    gap: 17.5px;
  }
}
.post__content blockquote::before {
  content: "";
  position: absolute;
  z-index: 100;
  top: 20px;
  left: 30px;
  width: 27px;
  height: 23.8px;
  background-image: url(images/icons/icon-blockquote.svg);
  background-repeat: no-repeat;
  background-size: contain;
}
.post__content a {
  display: inline-block;
  text-decoration: underline;
  color: rgb(203, 0, 0);
  font-weight: 700;
  font-size: 20px;
  line-height: 33px;
  margin-top: 27px;
  margin-bottom: 54px;
}
@media screen and (max-width: 768px) {
  .post__content a {
    margin-bottom: 45px;
  }
}
.post__content figure {
  width: 335px;
  height: 200px;
  margin-top: 17px;
  margin-bottom: 28px;
}
.post__content figure img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
@media screen and (max-width: 768px) {
  .post__content figure {
    margin-top: 39px;
    margin-bottom: 27px;
  }
}
@media screen and (max-width: 576px) {
  .post__content figure {
    width: 100%;
    aspect-ratio: 335/200;
  }
}

.post__nav {
  display: flex;
  gap: 78px;
}
.post__nav a {
  flex: 1;
}
.post__nav span {
  display: block;
  color: white;
  background-color: black;
  padding-top: 4px;
  padding-bottom: 3px;
  padding-left: 20px;
  padding-right: 150px;
  margin-bottom: 15px;
  font-weight: 500;
  font-size: 17px;
  line-height: 30px;
}
@media screen and (max-width: 768px) {
  .post__nav span {
    padding-right: 46px;
  }
}
.post__nav a:nth-child(2) span {
  padding-left: 152px;
  padding-right: 18px;
}
@media screen and (max-width: 768px) {
  .post__nav a:nth-child(2) span {
    padding-left: 48px;
  }
}
.post__nav-info {
  display: flex;
  gap: 16px;
  margin-bottom: 93px;
}
.post__nav-info p {
  font-weight: 700;
  font-size: 16px;
  line-height: 25px;
}
@media screen and (max-width: 768px) {
  .post__nav-info {
    margin-bottom: 64px;
  }
}
@media screen and (max-width: 768px) {
  .post__nav {
    gap: 22px;
  }
}

.post__nav-img {
  width: 98px;
  height: 68px;
  flex-shrink: 0;
  flex-grow: 0;
}
.post__nav-img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 768px) {
  .post__nav-img {
    display: none;
  }
}

.related-posts h2 {
  background-color: black;
  color: white;
  font-size: 18px;
  line-height: 33px;
  padding: 9px;
  padding-bottom: 8px;
  padding-left: 30px;
  margin-bottom: 30px;
}
@media screen and (max-width: 768px) {
  .related-posts h2 {
    margin-bottom: 20.6px;
    padding-left: 0;
    text-align: center;
  }
}

.related-posts__list {
  display: flex;
  flex-direction: column;
  gap: 30px;
}
@media screen and (max-width: 768px) {
  .related-posts__list {
    gap: 20.7px;
  }
}

.related-posts__item a {
  display: flex;
  gap: 30px;
}
@media screen and (max-width: 768px) {
  .related-posts__item a {
    gap: 20px;
  }
}

.related-posts__img {
  position: relative;
  width: 200px;
  height: 140px;
  flex-shrink: 0;
}
.related-posts__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.related-posts__img .img__heading {
  width: 80px;
}
@media screen and (max-width: 768px) {
  .related-posts__img {
    width: 160px;
    height: 110px;
  }
}

.related-posts__text p {
  font-weight: 700;
  font-size: 20px;
  line-height: 25px;
  margin-bottom: 13px;
}
@media screen and (max-width: 768px) {
  .related-posts__text p {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    font-size: 17px;
    line-height: 28px;
    margin-top: 8px;
    margin-bottom: 3.9px;
  }
}
.related-posts__text time {
  font-weight: 500;
  font-size: 17px;
  line-height: 30px;
  padding-left: 5px;
}
@media screen and (max-width: 768px) {
  .related-posts__text time {
    padding-left: 0;
  }
}

.sidebar__list {
  display: flex;
  flex-direction: column;
  gap: 30px;
}

.sidebar__widget h2 {
  background-color: black;
  color: white;
  font-size: 18px;
  line-height: 33px;
  padding-top: 9px;
  padding-bottom: 8px;
  text-align: center;
}

.sidebar__newsletter,
.sidebar__search-form {
  padding: 15px;
  position: relative;
  border-right: 1px solid black;
  border-left: 1px solid black;
}
.sidebar__newsletter::after,
.sidebar__search-form::after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 1px;
  background-color: black;
}
@media screen and (max-width: 768px) {
  .sidebar__newsletter,
  .sidebar__search-form {
    padding: 20px;
  }
}

.sidebar__newsletter-img {
  display: inline-block;
  background-color: rgb(232, 232, 232);
  text-align: center;
  font-weight: 700;
  font-size: 18px;
  line-height: 33px;
  width: 100%;
  height: 170px;
}
.sidebar__newsletter-img span {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
@media screen and (max-width: 768px) {
  .sidebar__newsletter-img {
    height: 228px;
  }
}
.sidebar__newsletter-img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.sidebar__search-input {
  display: flex;
  height: 40px;
}
.sidebar__search-input input {
  background-color: rgb(232, 232, 232);
  flex: 1;
}
.sidebar__search-input button {
  background-color: black;
  padding-left: 10px;
  padding-right: 10.2px;
}
.sidebar__search-input button img {
  width: 19.8px;
  height: 23.32px;
}
@media screen and (max-width: 768px) {
  .sidebar__search-input button img {
    width: 26.23px;
    height: 31.07px;
    flex-shrink: 0;
  }
}
@media screen and (max-width: 768px) {
  .sidebar__search-input button {
    padding-left: 14px;
    padding-right: 13.77px;
  }
}
@media screen and (max-width: 768px) {
  .sidebar__search-input {
    height: 54px;
  }
}

.sidebar__wpp-list {
  margin-top: 15px;
  display: flex;
  flex-direction: column;
  gap: 15px;
}
@media screen and (max-width: 768px) {
  .sidebar__wpp-list {
    gap: 20.7px;
    margin-top: 18px;
  }
}

.sidebar__wpp-item {
  display: flex;
  gap: 15px;
}
@media screen and (max-width: 768px) {
  .sidebar__wpp-item {
    gap: 20px;
  }
}
.sidebar__wpp-item h3 {
  font-weight: 500;
  font-size: 17px;
  line-height: 28px;
}
@media screen and (max-width: 768px) {
  .sidebar__wpp-item h3 {
    margin-top: 10px;
  }
}

.sidebar__wpp-img {
  width: 95px;
  height: 75px;
  flex-shrink: 0;
}
.sidebar__wpp-img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 768px) {
  .sidebar__wpp-img {
    width: 160px;
    height: 110px;
  }
}

.sidebar__category-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 12px;
  font-weight: 500;
  font-size: 17px;
  line-height: 28px;
}

.cat-item {
  padding-bottom: 7px;
  position: relative;
}
.cat-item::after {
  content: "";
  position: absolute;
  height: 1px;
  width: 100%;
  background-color: black;
  bottom: 0;
  left: 0;
}

.contact {
  padding-top: 68px;
  padding-bottom: 100px;
}
@media screen and (max-width: 768px) {
  .contact {
    padding-top: 47px;
    padding-bottom: 108px;
  }
}

.contact-form__text {
  text-align: center;
  margin-bottom: 65px;
  padding: 0 50px;
}
@media screen and (max-width: 768px) {
  .contact-form__text {
    text-align: start;
    padding: 0;
    margin-bottom: 32px;
  }
}
.contact-form__list {
  display: flex;
  flex-direction: column;
}
.contact-form__item {
  display: flex;
  gap: 29px;
  margin-bottom: 30px;
}
@media screen and (max-width: 768px) {
  .contact-form__item {
    flex-direction: column;
    gap: 2px;
    margin-bottom: 13px;
  }
}
.contact-form__item--purpose {
  margin-bottom: 26px;
}
@media screen and (max-width: 768px) {
  .contact-form__item--purpose {
    margin-bottom: 4px;
  }
}
.contact-form__item:last-child {
  margin-bottom: 0;
}
.contact-form__label {
  width: 140px;
  font-size: 20px;
  line-height: 33px;
  font-weight: 500;
  padding-top: 7px;
}
@media screen and (max-width: 768px) {
  .contact-form__label {
    width: auto;
    font-size: 16px;
    padding-top: 0;
  }
}
.contact-form__label--message {
  letter-spacing: 20px;
}
@media screen and (max-width: 768px) {
  .contact-form__label--message {
    letter-spacing: 16px;
  }
}
.contact-form__checkbox-list {
  display: flex;
  flex-direction: column;
  gap: 9px;
}
@media screen and (max-width: 768px) {
  .contact-form__checkbox-list {
    gap: 10px;
  }
}
.contact-form__checkbox-list label {
  display: flex;
  gap: 20px;
  justify-content: start;
}
@media screen and (max-width: 768px) {
  .contact-form__checkbox-list label {
    gap: 10px;
  }
}
.contact-form__input {
  flex: 1;
  line-height: 33px;
  text-overflow: clip;
}
.contact-form input:not([type=submit]),
.contact-form textarea {
  display: block;
  border: 1px solid black;
  width: 100%;
}
.contact-form input:not([type=submit]) {
  height: 40px;
  line-height: 33px;
  padding-top: 6px;
  padding-left: 19px;
}
.contact-form input[type=checkbox] {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  width: 20px;
  height: 20px;
  border-radius: 0;
  position: relative;
  cursor: pointer;
}
.contact-form input[type=checkbox]:checked::after {
  content: "";
  position: absolute;
  left: 7px;
  top: 4px;
  width: 5px;
  height: 10px;
  border: solid #000;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}
.contact-form textarea {
  height: 300px;
  padding-top: 13px;
  padding-left: 20px;
}
@media screen and (max-width: 768px) {
  .contact-form textarea {
    height: 190px;
    line-height: 25px;
    padding-top: 12px;
  }
}
.contact-form input::-moz-placeholder, .contact-form textarea::-moz-placeholder {
  color: #B2B2B2;
  font-size: 15px;
}
.contact-form input::placeholder,
.contact-form textarea::placeholder {
  color: #B2B2B2;
  font-size: 15px;
}
.contact-form__submit {
  display: flex;
  justify-content: center;
  margin-top: 50px;
}
.contact-form__submit .wpcf7-spinner {
  position: absolute;
  margin: 0;
}

.fieldset-wrapper {
  display: flex;
  gap: 29px;
}
@media screen and (max-width: 768px) {
  .fieldset-wrapper {
    flex-direction: column;
    gap: 2px;
  }
}

fieldset .contact-form__label {
  line-height: 30px;
  padding-top: 0;
}
@media screen and (max-width: 768px) {
  fieldset .contact-form__label {
    line-height: 33px;
  }
}
fieldset .contact-form__label span {
  letter-spacing: 20px;
}
@media screen and (max-width: 768px) {
  fieldset .contact-form__label span {
    letter-spacing: 16px;
  }
}

.checkbox-text {
  font-size: 18px;
  line-height: 30px;
  transform: translateY(-5.5px);
}
@media screen and (max-width: 768px) {
  .checkbox-text {
    font-size: 16px;
    transform: translateY(-2px);
  }
}

.contact-send {
  text-align: center;
  padding-top: 67px;
  padding-bottom: 90px;
}
@media screen and (max-width: 768px) {
  .contact-send {
    text-align: start;
    padding-top: 47px;
    padding-bottom: 50px;
  }
}
.contact-send__text {
  margin-bottom: 40px;
}
@media screen and (max-width: 768px) {
  .contact-send__text {
    margin-bottom: 39px;
  }
}

.result-list {
  padding-top: 65px;
  padding-bottom: 71px;
}
.result-list__list {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  row-gap: 61px;
  -moz-column-gap: 106px;
       column-gap: 106px;
}
@media screen and (max-width: 768px) {
  .result-list__list {
    -moz-column-gap: 50px;
         column-gap: 50px;
  }
}
@media screen and (max-width: 576px) {
  .result-list__list {
    display: flex;
    flex-direction: column;
    gap: 50px;
  }
}
.result-list__item a {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.result-list__img {
  position: relative;
  width: 100%;
  aspect-ratio: 387/273;
}
.result-list__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.result-list__desc {
  font-size: 20px;
  line-height: 25px;
  font-weight: bold;
  margin-bottom: 10px;
}
.result-list__time {
  display: block;
  text-align: end;
  font-size: 18px;
  line-height: 32px;
}

.result-details {
  padding-top: 70px;
  padding-bottom: 60px;
}
@media screen and (max-width: 768px) {
  .result-details {
    padding-top: 50px;
    padding-bottom: 40px;
  }
}
.result-details__thumbnail {
  width: 100%;
  aspect-ratio: 11/5;
  position: relative;
}
@media screen and (max-width: 768px) {
  .result-details__thumbnail {
    aspect-ratio: 335/236;
  }
}
.result-details__thumbnail img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.result-details__thumbnail .img__heading {
  width: 100px;
}
.result-details__title {
  font-size: 25px;
  line-height: 40px;
  font-weight: bold;
  margin-top: 50px;
  margin-bottom: 15px;
}
@media screen and (max-width: 768px) {
  .result-details__title {
    font-size: 20px;
    line-height: 30px;
    margin-top: 30px;
    margin-bottom: 6px;
  }
}
.result-details__time {
  display: block;
  font-size: 17px;
  line-height: 30px;
  font-weight: normal;
}
.result-details__content {
  display: flex;
  gap: 40px;
  margin-top: 57px;
  margin-bottom: 60px;
}
@media screen and (max-width: 768px) {
  .result-details__content {
    flex-direction: column;
    gap: 28px;
    margin-top: 21px;
    margin-bottom: 40px;
  }
}
.result-details__table {
  border-collapse: collapse;
  box-sizing: border-box;
  width: 400px;
  flex-shrink: 0;
}
@media screen and (max-width: 768px) {
  .result-details__table {
    width: 100%;
  }
}
.result-details th,
.result-details td {
  box-sizing: border-box;
  border: 1px solid #707070;
  font-size: 18px;
  line-height: 30px;
  padding-left: 20px;
  padding-top: 7px;
}
@media screen and (max-width: 768px) {
  .result-details th,
  .result-details td {
    padding-left: 10px;
  }
}
.result-details th {
  background-color: #E5E5E5;
  width: 140px;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .result-details th {
    width: 120px;
  }
}
.result-details td {
  font-weight: normal;
}
@media screen and (max-width: 768px) {
  .result-details__desc {
    font-size: 18px;
  }
}
.result-details .post__nav {
  gap: 199px;
}
@media screen and (max-width: 768px) {
  .result-details .post__nav {
    gap: 22px;
  }
}
.result-details .post__nav-info {
  margin-bottom: 100px;
}
@media screen and (max-width: 768px) {
  .result-details .post__nav-info {
    margin-bottom: 63px;
  }
}
.result-details .post__nav span {
  display: block;
}
.result-details .post__nav a:nth-child(2) span {
  text-align: end;
}
.result-details__related {
  padding-bottom: 157px;
}
@media screen and (max-width: 768px) {
  .result-details__related {
    padding-bottom: 197px;
  }
}

.result-related__heading {
  background-color: black;
  color: white;
  font-size: 18px;
  line-height: 33px;
  padding-left: 30px;
  padding-top: 9px;
  padding-bottom: 8px;
  margin-bottom: 30px;
}
@media screen and (max-width: 768px) {
  .result-related__heading {
    text-align: center;
    padding-left: 0;
    margin-bottom: 20px;
  }
}
.result-related__list {
  display: flex;
  flex-direction: column;
  gap: 30px;
}
@media screen and (max-width: 768px) {
  .result-related__list {
    gap: 20px;
  }
}
.result-related__item a {
  display: flex;
  gap: 30px;
}
@media screen and (max-width: 768px) {
  .result-related__item a {
    gap: 20px;
  }
}
.result-related__img {
  width: 29.5454545455%;
  aspect-ratio: 260/183;
  flex-shrink: 0;
  position: relative;
}
@media screen and (max-width: 768px) {
  .result-related__img {
    width: 47.7611940299%;
    aspect-ratio: 160/113;
  }
}
.result-related__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.result-related__img .img__heading {
  width: 100px;
}
@media screen and (max-width: 768px) {
  .result-related__img .img__heading {
    width: 80px;
  }
}
.result-related__title {
  font-size: 20px;
  line-height: 25px;
  margin-bottom: 13px;
}
@media screen and (max-width: 768px) {
  .result-related__title {
    font-size: 17px;
    line-height: 28px;
    margin-bottom: 3.93px;
  }
}
.result-related__time {
  display: block;
  font-size: 17px;
  line-height: 30px;
  padding-left: 4px;
}
@media screen and (max-width: 768px) {
  .result-related__time {
    padding-left: 0;
  }
}

.p-search {
  padding-top: 66px;
  padding-bottom: 70px;
}
@media screen and (max-width: 768px) {
  .p-search {
    padding-top: 36px;
    padding-bottom: 59px;
  }
}
.p-search__header {
  display: flex;
  justify-content: space-between;
  margin-bottom: 42px;
}
.p-search__heading {
  font-size: 18px;
  line-height: 30px;
}
.p-search__heading span {
  font-weight: 500;
}
.p-search__list {
  display: flex;
  flex-direction: column;
  gap: 70px;
}
@media screen and (max-width: 576px) {
  .p-search__list {
    gap: 39px;
  }
}
.p-search__item a {
  display: flex;
  gap: 50px;
}
@media screen and (max-width: 576px) {
  .p-search__item a {
    flex-direction: column;
    gap: 30px;
  }
}
.p-search__img {
  width: 29.5454545455%;
  aspect-ratio: 260/184;
  position: relative;
  flex-shrink: 0;
}
@media screen and (max-width: 768px) {
  .p-search__img {
    aspect-ratio: 335/200;
  }
}
@media screen and (max-width: 576px) {
  .p-search__img {
    width: 100%;
  }
}
.p-search__img img {
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.p-search .img__heading {
  width: 80px;
}
@media screen and (max-width: 576px) {
  .p-search .img__heading {
    width: 90px;
  }
}
.p-search__title {
  font-size: 20px;
  line-height: 25px;
}
@media screen and (max-width: 576px) {
  .p-search__title {
    line-height: 30px;
  }
}
.p-search__time {
  display: block;
  font-size: 17px;
  line-height: 30px;
  margin-top: 3px;
  margin-bottom: 11px;
}
@media screen and (max-width: 576px) {
  .p-search__time {
    margin-top: 6px;
    margin-bottom: 8px;
    text-align: end;
  }
}
@media screen and (max-width: 576px) {
  .p-search__desc {
    overflow: hidden;
    max-height: 150px;
    -webkit-line-clamp: unset;
  }
}

footer {
  background-color: rgb(203, 0, 0);
  text-align: center;
}

.footer__wrapper {
  padding-top: 44px;
  padding-bottom: 48.58px;
}
@media screen and (max-width: 768px) {
  .footer__wrapper {
    padding-bottom: 50.67px;
  }
}

.footer__nav-list {
  display: flex;
  gap: 32.5px;
  justify-content: center;
  color: white;
  font-weight: 700;
  font-size: 17px;
  line-height: 33px;
}
@media screen and (max-width: 768px) {
  .footer__nav-list {
    gap: 29px;
  }
}

.footer__logo {
  margin-top: 21.74px;
  margin-bottom: 23px;
}
@media screen and (max-width: 768px) {
  .footer__logo {
    margin-top: 18.74px;
    margin-bottom: 28.91px;
  }
}

.copyright {
  color: white;
  font-weight: 500;
  font-size: 18px;
  line-height: 33px;
  letter-spacing: 0.25px;
}
@media screen and (max-width: 768px) {
  .copyright {
    line-height: 20px;
    margin-bottom: 16px;
  }
}

.footer__sns-list {
  display: flex;
  gap: 12.2px;
  justify-content: center;
  align-items: center;
}

.error {
  text-align: center;
  padding-top: 68px;
  padding-bottom: 90px;
}
@media screen and (max-width: 768px) {
  .error {
    text-align: start;
    padding-top: 47px;
    padding-bottom: 50px;
  }
}
.error__text {
  margin-bottom: 40px;
}
@media screen and (max-width: 768px) {
  .error__text {
    margin-bottom: 9px;
  }
}/*# sourceMappingURL=style.css.map */