@charset "UTF-8";
/* import */
/* カラー */
/* レスポンシブ */
/*****STANDART CSS******/
:root {
  --view-size: 1000;
}

@media screen and (max-width: 767px) {
  :root {
    --view-size: 750;
  }
}
/* -----------------------------------
common：基本
----------------------------------- */
abbr, acronym, address, applet, article, aside, audio, b, big, blockquote, body, canvas, caption, center, cite, code, dd, del, details, dfn, div, dl, dt, em, embed, fieldset, figcaption, figure, footer, form, h1, h2, h3, h4, h5, h6, header, hgroup, html, i, iframe, img, ins, kbd, label, legend, li, mark, menu, nav, object, ol, output, p, pre, q, ruby, s, samp, section, small, span, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, time, tr, tt, u, ul, var,
video {
  margin: 0;
}

html {
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
  font-size: 16px;
  /******SMOOTH SCROLL ANCHOR******/
}

/*****STANDART CSS******/
/* ---------common--------- */
body {
  color: #222222;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  line-height: 1.4;
}

@media (max-width: 749px) {
  body.active {
    overflow: hidden;
  }
}

h1, h2, h3, h4, h5, h6 {
  font-weight: normal;
  line-height: 1;
}

b {
  font-weight: normal;
}

ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

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

a {
  transition: 0.3s;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}
a:hover {
  opacity: 0.7;
}

/* 768px以下では電話発信のリンクを無効化する */
@media (min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}
/* inner関係 */
.inner {
  max-width: 46.875rem;
  margin-inline: auto;
}
@media (max-width: 749px) {
  .inner {
    max-width: 100%;
  }
}

.p-in {
  padding-inline: 2.5rem;
}
@media (max-width: 749px) {
  .p-in {
    padding-inline: calc(40 / var(--view-size) * 100vw);
  }
}

/* -----------------------------------
common：フォント
----------------------------------- */
.serif {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

.inter {
  font-family: "Inter", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

.col-y {
  color: #FFFF97;
}

.col-main {
  color: #F2690C;
}

/* 縦書き */
.vertical {
  writing-mode: vertical-rl;
}

/* 大文字 */
.uppercase {
  text-transform: uppercase;
}

/* -----------------------------------
common：flex
----------------------------------- */
.row {
  display: flex;
  flex-wrap: wrap;
}

.between {
  justify-content: space-between;
}

.align_start {
  align-items: flex-start;
}

.align_center {
  align-items: center;
}

.align_end {
  align-items: flex-end;
}

.flex_center {
  justify-content: center;
}

.flex_start {
  justify-content: flex-start;
}

.flex_end {
  justify-content: flex-end;
}

.stretch {
  align-items: stretch;
}

.reverse {
  flex-direction: row-reverse;
}

/* -----------------------------------
common：display
----------------------------------- */
.all_dn {
  display: none;
}

@media (max-width: 749px) {
  .sp_dn {
    display: none;
  }
}

.sp_db {
  display: none;
}
@media (max-width: 749px) {
  .sp_db {
    display: block;
  }
}

/* -----------------------------------
common：position
----------------------------------- */
.fixed {
  position: fixed;
}

.relative {
  position: relative;
}

.absolute {
  position: absolute;
}

/* z-index */
.z_-10 {
  z-index: -10;
}

.z_10 {
  z-index: 10;
}

.z_20 {
  z-index: 20;
}

.z_30 {
  z-index: 30;
}

.z_40 {
  z-index: 40;
}

.z_50 {
  z-index: 50;
}

.z_8000 {
  z-index: 8000;
}

.z_9999 {
  z-index: 9999;
}

/* -----------------------------------
common：シャドウ
----------------------------------- */
.shadow01 {
  box-shadow: 0 0.25rem 0.25rem 0 rgba(0, 0, 0, 0.35);
}
@media (max-width: 749px) {
  .shadow01 {
    box-shadow: 0 calc(4 / var(--view-size) * 100vw) calc(4 / var(--view-size) * 100vw) 0 rgba(0, 0, 0, 0.35);
  }
}

.shadow02 {
  box-shadow: 0 0.25rem 0.25rem 0 rgba(0, 0, 0, 0.25);
}
@media (max-width: 749px) {
  .shadow02 {
    box-shadow: 0 calc(4 / var(--view-size) * 100vw) calc(4 / var(--view-size) * 100vw) 0 rgba(0, 0, 0, 0.25);
  }
}

.shadow03 {
  box-shadow: 0 0.125rem 0.125rem 0 rgba(0, 0, 0, 0.24);
}
@media (max-width: 749px) {
  .shadow03 {
    box-shadow: 0 calc(2 / var(--view-size) * 100vw) calc(2 / var(--view-size) * 100vw) 0 rgba(0, 0, 0, 0.24);
  }
}

/* -----------------------------------
common：共通タイトル
----------------------------------- */
/* -----------------------------------
common：共通ボタン
----------------------------------- */
.common_btn {
  display: block;
  align-items: center;
  justify-content: center;
  margin-top: 0;
}

.common_top_btn a {
  display: block;
  padding: 0 0;
  border-radius: 0;
  font-size: 0;
  line-height: 0;
  letter-spacing: 0;
  background-color: #000;
  transition: background-color 0.6s ease;
}

.common_btn a:hover {
  background-color: rgba(0, 0, 0, 0.6);
}

.pointer {
  cursor: pointer;
}

/* -----------------------------------
common：CF7 デフォルト無効
----------------------------------- */
input[type=submit] {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  font-size: inherit;
  background-color: inherit;
  border: none;
  font-weight: 500;
  color: inherit;
}

span.wpcf7-spinner {
  display: none;
}

/* label と input 間の余白を削除する */
label + input[type=text],
label + input[type=email],
label + textarea {
  margin-top: 0;
}

/* これらの一般的なタグの余白をリセットする */
form p, form br {
  margin: 0;
  padding: 0;
}

/* placeholderのフォントサイズ */
::-moz-placeholder {
  font-size: 1rem;
}
::placeholder {
  font-size: 1rem;
}
@media (max-width: 749px) {
  ::-moz-placeholder {
    font-size: calc(14 / var(--view-size) * 100vw);
  }
  ::placeholder {
    font-size: calc(14 / var(--view-size) * 100vw);
  }
}

/* 完了メッセージを消す */
.wpcf7 form.sent .wpcf7-response-output {
  display: none;
}

/* 
ヘッダー：ヘッダー
----------------------------------- */
.header {
  z-index: 99;
  opacity: 0;
  visibility: hidden;
  width: 100%;
  background-color: #FFFFFF;
  background-image: url("../image/header-bg.png");
  background-position: center bottom 1rem;
  background-size: 41.75rem;
  padding: 1.0625rem 2.5rem 5rem;
  transition: all 0.3s ease;
}
@media (max-width: 749px) {
  .header {
    max-width: calc(750 / var(--view-size) * 100vw);
    background-position: center bottom calc(16 / var(--view-size) * 100vw);
    background-size: calc(668 / var(--view-size) * 100vw);
    padding: calc(17 / var(--view-size) * 100vw) calc(40 / var(--view-size) * 100vw) calc(80 / var(--view-size) * 100vw);
  }
}

.header.active {
  opacity: 1;
  visibility: visible;
}

.header_logo {
  width: 17.5625rem;
  line-height: 0;
  padding-top: 2.25rem;
}
@media (max-width: 749px) {
  .header_logo {
    width: calc(281 / var(--view-size) * 100vw);
    padding-top: calc(36 / var(--view-size) * 100vw);
  }
}

.header_box_tel a {
  font-size: 2.5rem;
  font-weight: 700;
  letter-spacing: 0.048em;
  padding-left: 4.5625rem;
}
@media (max-width: 749px) {
  .header_box_tel a {
    font-size: calc(40 / var(--view-size) * 100vw);
    padding-left: calc(73 / var(--view-size) * 100vw);
  }
}

.header_box_tel a::before {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  display: inline-block;
  content: "";
  background-image: url("../image/icon-TEL.png");
  background-size: contain;
  background-position: left center;
  width: 4rem;
  height: 2.28875rem;
}
@media (max-width: 749px) {
  .header_box_tel a::before {
    width: calc(64 / var(--view-size) * 100vw);
    height: calc(36.62 / var(--view-size) * 100vw);
  }
}

.header_box_mail {
  width: 22.75rem;
  height: 4rem;
  background-color: #de2929;
  border-radius: 0.5rem;
  padding: 0 3.625rem;
  margin-top: 0.5rem;
}
@media (max-width: 749px) {
  .header_box_mail {
    width: calc(364 / var(--view-size) * 100vw);
    height: calc(64 / var(--view-size) * 100vw);
    border-radius: calc(8 / var(--view-size) * 100vw);
    padding: 0 calc(58 / var(--view-size) * 100vw);
    margin-top: calc(8 / var(--view-size) * 100vw);
  }
}

.header_box_mail a {
  display: inline-block;
  width: 100%;
  height: 100%;
  font-size: 2rem;
  font-weight: 700;
  color: #fff;
  padding: 0.59375rem 0;
  padding-left: 3.5rem;
}
@media (max-width: 749px) {
  .header_box_mail a {
    font-size: calc(32 / var(--view-size) * 100vw);
    padding: calc(9.5 / var(--view-size) * 100vw) 0;
    padding-left: calc(56 / var(--view-size) * 100vw);
  }
}

.header_box_mail a::before {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  display: inline-block;
  content: "";
  background-image: url("../image/icon-MAIL.png");
  background-size: contain;
  background-position: left center;
  width: 2.5rem;
  height: 1.828125rem;
  margin-right: 1rem;
}
@media (max-width: 749px) {
  .header_box_mail a::before {
    width: calc(40 / var(--view-size) * 100vw);
    height: calc(29.25 / var(--view-size) * 100vw);
    margin-right: calc(16 / var(--view-size) * 100vw);
  }
}

/* 
フッター
----------------------------------- */
.footer_bg {
  background-color: #0071CB;
  padding: 1.875rem 2.5rem 13.375rem;
}
@media (max-width: 749px) {
  .footer_bg {
    padding: calc(30 / var(--view-size) * 100vw) calc(40 / var(--view-size) * 100vw) calc(214 / var(--view-size) * 100vw);
  }
}

.footer .footer_ttl {
  width: 13rem;
  margin-inline: auto;
}
@media (max-width: 749px) {
  .footer .footer_ttl {
    width: calc(208 / var(--view-size) * 100vw);
  }
}

.footer .footer_box {
  margin-top: 1.4375rem;
}
@media (max-width: 749px) {
  .footer .footer_box {
    margin-top: calc(23 / var(--view-size) * 100vw);
  }
}

.footer .footer_box_blog {
  font-size: 2rem;
  font-weight: 500;
  color: #fff;
  text-align: center;
}
@media (max-width: 749px) {
  .footer .footer_box_blog {
    font-size: calc(32 / var(--view-size) * 100vw);
  }
}

.footer .footer_box_blog a {
  text-decoration: underline;
}

.footer .footer_box_list {
  margin-top: 1.4375rem;
}
@media (max-width: 749px) {
  .footer .footer_box_list {
    margin-top: calc(23 / var(--view-size) * 100vw);
  }
}

.footer .footer_box_list li {
  font-size: 1.5rem;
  font-weight: 400;
  color: #fff;
}
@media (max-width: 749px) {
  .footer .footer_box_list li {
    font-size: calc(24 / var(--view-size) * 100vw);
  }
}

.footer .footer_copy {
  font-size: 1.5rem;
  font-weight: 400;
  color: #fff;
  text-align: center;
  margin-top: 0.5rem;
}
@media (max-width: 749px) {
  .footer .footer_copy {
    font-size: calc(24 / var(--view-size) * 100vw);
    margin-top: calc(8 / var(--view-size) * 100vw);
  }
}

.pekopeko {
  position: relative;
  animation: pekopeko 2s infinite;
  box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
}

@keyframes pekopeko {
  0% {
    box-shadow: 0 0 0 rgba(0, 0, 0, 0.25);
    top: 3px;
  }
  10% {
    box-shadow: 0 0 0 rgba(0, 0, 0, 0.3);
    top: 3px;
  }
  20% {
    box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
    top: 0px;
  }
  30% {
    box-shadow: 0 0 0 rgba(0, 0, 0, 0.25);
    top: 3px;
  }
  40% {
    box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
    top: 0px;
  }
}
.efect {
  transition-duration: 1s;
  transition-timing-function: ease;
  transition-property: opacity, transform;
}

.fadeInRight {
  transform: translate3d(-50px, 0, 0);
  opacity: 0;
}

.fadeInRight.active {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

.fadeInUp {
  transform: translate3d(0, 50px, 0);
  opacity: 0;
}

.fadeInUp.active {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

.fadeIn {
  opacity: 0;
}

.fadeIn.active {
  opacity: 1;
}

.delay01 {
  transition-delay: 0.2s;
}

.delay02 {
  transition-delay: 0.4s;
}

.delay03 {
  transition-delay: 0.6s;
}

.delay04 {
  transition-delay: 0.8s;
}

.delay05 {
  transition-delay: 1s;
}

.delay06 {
  transition-delay: 0.6s;
}

.delay07 {
  transition-delay: 0.7s;
}

.delay08 {
  transition-delay: 0.8s;
}

.delay09 {
  transition-delay: 0.9s;
}

/* 
fv : ファーストビュー
----------------------------------- */
.fv_bg {
  background-image: url("../image/fv-bg.jpg");
  background-size: 100%;
  background-position: top center;
  height: 53.375rem;
  padding-top: 8rem;
}
@media (max-width: 749px) {
  .fv_bg {
    height: calc(854 / var(--view-size) * 100vw);
    padding-top: calc(128 / var(--view-size) * 100vw);
  }
}

.fv_ttl {
  width: 29.75rem;
  margin-left: 1.6875rem;
}
@media (max-width: 749px) {
  .fv_ttl {
    width: calc(476 / var(--view-size) * 100vw);
    margin-left: calc(27 / var(--view-size) * 100vw);
  }
}

.fv_badge {
  padding: 0 0.9375rem;
  margin-top: 3rem;
}
@media (max-width: 749px) {
  .fv_badge {
    padding: 0 calc(15 / var(--view-size) * 100vw);
    margin-top: calc(48 / var(--view-size) * 100vw);
  }
}

.fv_badge_item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-image: url("../image/fv-badge.png");
  background-size: contain;
  background-position: center center;
  width: 14.5625rem;
  aspect-ratio: 1/1;
  border-radius: 50%;
  box-shadow: 0 0.266875rem 0.266875rem 0 rgba(0, 0, 0, 0.25);
}
@media (max-width: 749px) {
  .fv_badge_item {
    width: calc(233 / var(--view-size) * 100vw);
    box-shadow: 0 calc(4.27 / var(--view-size) * 100vw) calc(4.27 / var(--view-size) * 100vw) 0 rgba(0, 0, 0, 0.25);
  }
}

.fv_badge_item p {
  font-size: 1.875rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  text-align: center;
}
@media (max-width: 749px) {
  .fv_badge_item p {
    font-size: calc(30 / var(--view-size) * 100vw);
  }
}

.fv_badge_item p b {
  font-size: 2.25rem;
  font-weight: 900;
}
@media (max-width: 749px) {
  .fv_badge_item p b {
    font-size: calc(36 / var(--view-size) * 100vw);
  }
}

.fv_cta {
  background-color: #F9EFDA;
  padding-top: 2.6875rem;
  padding-bottom: 2.5rem;
}
@media (max-width: 749px) {
  .fv_cta {
    padding-top: calc(43 / var(--view-size) * 100vw);
    padding-bottom: calc(40 / var(--view-size) * 100vw);
  }
}

.fv_cta_ttl {
  font-size: 2.5rem;
  font-weight: 600;
  line-height: 1.3;
  letter-spacing: 0.03em;
  text-align: center;
}
@media (max-width: 749px) {
  .fv_cta_ttl {
    font-size: calc(40 / var(--view-size) * 100vw);
  }
}

.fv_cta_ttl span {
  color: #DE2929;
}

.fv_cta_ttl b {
  font-size: 3.25rem;
  font-weight: 600;
}
@media (max-width: 749px) {
  .fv_cta_ttl b {
    font-size: calc(52 / var(--view-size) * 100vw);
  }
}

.fv_cta_ttl::before,
.fv_cta_ttl::after {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  width: 7.875rem;
  height: 0.1875rem;
  background-color: #222222;
}
@media (max-width: 749px) {
  .fv_cta_ttl::before,
  .fv_cta_ttl::after {
    width: calc(126 / var(--view-size) * 100vw);
    height: calc(3 / var(--view-size) * 100vw);
  }
}

.fv_cta_ttl::before {
  left: -2.3125rem;
  transform: translateY(-25%) rotate(70deg);
}
@media (max-width: 749px) {
  .fv_cta_ttl::before {
    left: calc(-37 / var(--view-size) * 100vw);
  }
}

.fv_cta_ttl::after {
  right: -2.3125rem;
  transform: translateY(-25%) rotate(-70deg);
}
@media (max-width: 749px) {
  .fv_cta_ttl::after {
    right: calc(-37 / var(--view-size) * 100vw);
  }
}

.fv_cta_cont {
  margin-top: 1.1875rem;
}
@media (max-width: 749px) {
  .fv_cta_cont {
    margin-top: calc(19 / var(--view-size) * 100vw);
  }
}

.cta_tel {
  width: 100%;
  border-radius: 0.5rem;
  overflow: hidden;
}
@media (max-width: 749px) {
  .cta_tel {
    border-radius: calc(8 / var(--view-size) * 100vw);
  }
}

.cta_cont_flex {
  margin-top: 1rem;
}
@media (max-width: 749px) {
  .cta_cont_flex {
    margin-top: calc(16 / var(--view-size) * 100vw);
  }
}

.cont_flex_line,
.cont_flex_mail {
  display: block;
  width: calc((100% - 1rem) / 2);
  border-radius: 0.5rem;
  overflow: hidden;
}
@media (max-width: 749px) {
  .cont_flex_line,
  .cont_flex_mail {
    width: calc((100% - 16 / var(--view-size) * 100vw) / 2);
    border-radius: calc(8 / var(--view-size) * 100vw);
  }
}

.cta_cont_card {
  width: 100%;
  margin-top: 0.8125rem;
}
@media (max-width: 749px) {
  .cta_cont_card {
    margin-top: calc(13 / var(--view-size) * 100vw);
  }
}

/* 
popup : ポップアップ
----------------------------------- */
.pop {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  top: 0;
  z-index: 100;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.4);
  transition: opacity 0.5s;
}

.pop.active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.pop_center {
  width: 100%;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  padding-top: 3.4375rem;
}
@media (max-width: 749px) {
  .pop_center {
    padding-top: calc(55 / var(--view-size) * 100vw);
  }
}

.pop_bg {
  background-color: #F9EFDA;
  padding-bottom: 5rem;
}
@media (max-width: 749px) {
  .pop_bg {
    padding-bottom: calc(80 / var(--view-size) * 100vw);
  }
}

.pop_ttl {
  background-color: #F2690C;
  font-size: 3rem;
  font-weight: 900;
  line-height: 1.4;
  color: #FFFFFF;
  text-align: center;
  padding: 0.125rem 0 0.875rem;
}
@media (max-width: 749px) {
  .pop_ttl {
    font-size: calc(48 / var(--view-size) * 100vw);
    padding: calc(2 / var(--view-size) * 100vw) 0 calc(14 / var(--view-size) * 100vw);
  }
}

.pop_ttl b {
  font-size: 4.5rem;
  font-weight: 700;
}
@media (max-width: 749px) {
  .pop_ttl b {
    font-size: calc(72 / var(--view-size) * 100vw);
  }
}

.pop_ttl span {
  font-size: 3.5rem;
}
@media (max-width: 749px) {
  .pop_ttl span {
    font-size: calc(56 / var(--view-size) * 100vw);
  }
}

.pop_sub {
  font-size: 2.5rem;
  font-weight: 600;
  line-height: 1.4;
  letter-spacing: 0.03em;
  text-align: center;
  margin-top: 4.75rem;
}
@media (max-width: 749px) {
  .pop_sub {
    font-size: calc(40 / var(--view-size) * 100vw);
    margin-top: calc(76 / var(--view-size) * 100vw);
  }
}

.pop_sub::before,
.pop_sub::after {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  width: 0.1875rem;
  height: 7.875rem;
  background-color: #222222;
}
@media (max-width: 749px) {
  .pop_sub::before,
  .pop_sub::after {
    width: calc(3 / var(--view-size) * 100vw);
    height: calc(126 / var(--view-size) * 100vw);
  }
}

.pop_sub::before {
  left: 8.9%;
  transform: translateY(-50%) rotate(-20deg);
}

.pop_sub::after {
  right: 8.9%;
  transform: translateY(-50%) rotate(20deg);
}

.pop_sub span {
  color: #DE2929;
}

.pop_sub b {
  font-size: 3.5rem;
  font-weight: 600;
}
@media (max-width: 749px) {
  .pop_sub b {
    font-size: calc(56 / var(--view-size) * 100vw);
  }
}

.pop-cont {
  margin-top: 0.75rem;
}
@media (max-width: 749px) {
  .pop-cont {
    margin-top: calc(12 / var(--view-size) * 100vw);
  }
}

.pop_box {
  margin-top: 1rem;
}
@media (max-width: 749px) {
  .pop_box {
    margin-top: calc(16 / var(--view-size) * 100vw);
  }
}

.pop_box_line,
.pop_box_mail {
  width: calc((100% - 1rem) / 2);
}
@media (max-width: 749px) {
  .pop_box_line,
  .pop_box_mail {
    width: calc((100% - 16 / var(--view-size) * 100vw) / 2);
  }
}

.pop_card {
  margin-top: 0.8125rem;
}
@media (max-width: 749px) {
  .pop_card {
    margin-top: calc(13 / var(--view-size) * 100vw);
  }
}

.pop_close {
  width: 2.25rem;
  aspect-ratio: 1/1;
  top: -6.7%;
  right: 3.1%;
}
@media (max-width: 749px) {
  .pop_close {
    width: calc(36 / var(--view-size) * 100vw);
  }
}

/* 
usp : 独自性
----------------------------------- */
.usp_bg {
  background-color: #FFFFFF;
  padding-top: 6rem;
  padding-bottom: 2.5rem;
}
@media (max-width: 749px) {
  .usp_bg {
    padding-top: calc(96 / var(--view-size) * 100vw);
    padding-bottom: calc(40 / var(--view-size) * 100vw);
  }
}

.usp_list {
  row-gap: 5rem;
}
@media (max-width: 749px) {
  .usp_list {
    row-gap: calc(80 / var(--view-size) * 100vw);
  }
}

.usp_list_item {
  width: calc((100% - 1.5rem) / 2);
  border: 0.375rem solid #F2690C;
  border-radius: 1.5625rem;
}
@media (max-width: 749px) {
  .usp_list_item {
    width: calc((100% - 24 / var(--view-size) * 100vw) / 2);
    border-width: calc(6 / var(--view-size) * 100vw);
    border-radius: calc(25 / var(--view-size) * 100vw);
  }
}

.usp_list_ttl {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 6.25rem;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background-color: #F2690C;
  top: 0;
  left: 50%;
  transform: translate(-50%, -62%);
}
@media (max-width: 749px) {
  .usp_list_ttl {
    width: calc(100 / var(--view-size) * 100vw);
  }
}

.usp_list_ttl figure {
  width: 4rem;
}
@media (max-width: 749px) {
  .usp_list_ttl figure {
    width: calc(64 / var(--view-size) * 100vw);
  }
}

.usp_list_ttl:nth-of-type(3) figure {
  width: 3.375rem;
}
@media (max-width: 749px) {
  .usp_list_ttl:nth-of-type(3) figure {
    width: calc(54 / var(--view-size) * 100vw);
  }
}

.usp_list_ttl:nth-of-type(4) figure {
  width: 4.125rem;
}
@media (max-width: 749px) {
  .usp_list_ttl:nth-of-type(4) figure {
    width: calc(66 / var(--view-size) * 100vw);
  }
}

.usp_list_txt {
  font-size: 3rem;
  font-weight: 900;
  text-align: center;
  padding: 2.6875rem 0;
}
@media (max-width: 749px) {
  .usp_list_txt {
    font-size: calc(48 / var(--view-size) * 100vw);
    padding: calc(43 / var(--view-size) * 100vw) 0;
  }
}

.usp_list_txt span {
  color: #F2690C;
}

/* 
works : ご安心の実績
----------------------------------- */
.works_bg {
  background-color: #F2690C;
  padding-top: 4.8125rem;
  padding-bottom: 5rem;
}
@media (max-width: 749px) {
  .works_bg {
    padding-top: calc(77 / var(--view-size) * 100vw);
    padding-bottom: calc(80 / var(--view-size) * 100vw);
  }
}

.works_ttl {
  font-size: 4.5rem;
  font-weight: 900;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: #FFFFFF;
  text-align: center;
}
@media (max-width: 749px) {
  .works_ttl {
    font-size: calc(72 / var(--view-size) * 100vw);
  }
}

.works_ttl span {
  font-size: 5rem;
}
@media (max-width: 749px) {
  .works_ttl span {
    font-size: calc(80 / var(--view-size) * 100vw);
  }
}

.works_ttl::before,
.works_ttl::after {
  display: block;
  content: "";
  position: absolute;
  width: 5.4375rem;
  aspect-ratio: 87/134;
  top: 62.7%;
  transform: translateY(-50%);
  background-size: contain;
}
@media (max-width: 749px) {
  .works_ttl::before,
  .works_ttl::after {
    width: calc(87 / var(--view-size) * 100vw);
  }
}

.works_ttl::before {
  background-image: url("../image/ttl-leaf-left.svg");
  background-position: left top;
  left: 0.4375rem;
}
@media (max-width: 749px) {
  .works_ttl::before {
    left: calc(7 / var(--view-size) * 100vw);
  }
}

.works_ttl::after {
  background-image: url("../image/ttl-leaf-right.svg");
  background-position: right top;
  right: 0.4375rem;
}
@media (max-width: 749px) {
  .works_ttl::after {
    right: calc(7 / var(--view-size) * 100vw);
  }
}

.works_list {
  margin-top: 6.375rem;
}
@media (max-width: 749px) {
  .works_list {
    margin-top: calc(102 / var(--view-size) * 100vw);
  }
}

.works_list ul {
  row-gap: 2rem;
}
@media (max-width: 749px) {
  .works_list ul {
    row-gap: calc(32 / var(--view-size) * 100vw);
  }
}

.works_list_cont {
  width: 100%;
  padding: 1.5rem 0 1.5rem;
  background-color: #FFFFFF;
  border-radius: 0.5rem;
  overflow: hidden;
}
@media (max-width: 749px) {
  .works_list_cont {
    padding: calc(24 / var(--view-size) * 100vw) 0 calc(24 / var(--view-size) * 100vw);
    border-radius: calc(8 / var(--view-size) * 100vw);
  }
}

.works_list_ttl {
  background-color: #F2690C;
  width: 26.5rem;
  border-radius: 6.25rem;
  padding: 0.25rem 0 0.3125rem;
  margin-inline: auto;
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.05em;
  text-align: center;
}
@media (max-width: 749px) {
  .works_list_ttl {
    width: calc(424 / var(--view-size) * 100vw);
    border-radius: calc(100 / var(--view-size) * 100vw);
    padding: calc(4 / var(--view-size) * 100vw) 0 calc(5 / var(--view-size) * 100vw);
    font-size: calc(40 / var(--view-size) * 100vw);
  }
}

.works_list_ttl span {
  display: inline-block;
  padding-left: 3.625rem;
}
@media (max-width: 749px) {
  .works_list_ttl span {
    padding-left: calc(58 / var(--view-size) * 100vw);
  }
}

.works_list_ttl span::before {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 2.5rem;
  aspect-ratio: 40/49;
  background-image: url("../image/ico-archive01.svg");
  background-size: contain;
}
@media (max-width: 749px) {
  .works_list_ttl span::before {
    width: calc(40 / var(--view-size) * 100vw);
  }
}

.works_list_cont:nth-of-type(2) .works_list_ttl span::before {
  width: 2.5rem;
  aspect-ratio: 40/45;
  background-image: url("../image/ico-archive02.svg");
}
@media (max-width: 749px) {
  .works_list_cont:nth-of-type(2) .works_list_ttl span::before {
    width: calc(40 / var(--view-size) * 100vw);
  }
}

.works_list_cont:nth-of-type(3) .works_list_ttl span::before {
  width: 3.125rem;
  aspect-ratio: 50/45;
  background-image: url("../image/ico-archive03.svg");
}
@media (max-width: 749px) {
  .works_list_cont:nth-of-type(3) .works_list_ttl span::before {
    width: calc(50 / var(--view-size) * 100vw);
  }
}

.works_list_cont:nth-of-type(4) .works_list_ttl span::before {
  width: 2rem;
  aspect-ratio: 32/42;
  background-image: url("../image/ico-archive04.svg");
}
@media (max-width: 749px) {
  .works_list_cont:nth-of-type(4) .works_list_ttl span::before {
    width: calc(32 / var(--view-size) * 100vw);
  }
}

.works_list_txt {
  font-size: 5rem;
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
}
@media (max-width: 749px) {
  .works_list_txt {
    font-size: calc(80 / var(--view-size) * 100vw);
  }
}

.works_list_01-sml {
  font-size: 4rem;
  font-weight: 400;
  letter-spacing: -0.02em;
}
@media (max-width: 749px) {
  .works_list_01-sml {
    font-size: calc(64 / var(--view-size) * 100vw);
  }
}

.works_list_02-sml {
  font-size: 3rem;
  font-weight: 700;
  letter-spacing: -0.01em;
}
@media (max-width: 749px) {
  .works_list_02-sml {
    font-size: calc(48 / var(--view-size) * 100vw);
  }
}

.works_list_cont:nth-of-type(3) .works_list_txt {
  font-size: 3rem;
  font-weight: 900;
  line-height: 1.3;
  margin-top: 1.375rem;
}
@media (max-width: 749px) {
  .works_list_cont:nth-of-type(3) .works_list_txt {
    font-size: calc(48 / var(--view-size) * 100vw);
    margin-top: calc(22 / var(--view-size) * 100vw);
  }
}

.works_list_cont:nth-of-type(4) .works_list_txt {
  font-size: 3rem;
  font-weight: 900;
  line-height: 1.4;
  margin-top: 1.3125rem;
}
@media (max-width: 749px) {
  .works_list_cont:nth-of-type(4) .works_list_txt {
    font-size: calc(48 / var(--view-size) * 100vw);
    margin-top: calc(21 / var(--view-size) * 100vw);
  }
}

.works_list_cont:nth-of-type(4) .works_list_txt b {
  font-size: 2.5rem;
  font-weight: 900;
}
@media (max-width: 749px) {
  .works_list_cont:nth-of-type(4) .works_list_txt b {
    font-size: calc(40 / var(--view-size) * 100vw);
  }
}

.works_list_txt span {
  font-size: 3rem;
  font-weight: 700;
}
@media (max-width: 749px) {
  .works_list_txt span {
    font-size: calc(48 / var(--view-size) * 100vw);
  }
}

.works_list_cont:nth-of-type(4) .works_list_txt span {
  display: block;
  margin-top: -0.1875rem;
  font-size: 2.5rem;
}
@media (max-width: 749px) {
  .works_list_cont:nth-of-type(4) .works_list_txt span {
    margin-top: calc(-3 / var(--view-size) * 100vw);
    font-size: calc(40 / var(--view-size) * 100vw);
  }
}

.works_list_info small {
  display: block;
  font-size: 1.5rem;
  line-height: 1.5;
  color: #000;
  text-align: center;
}
@media (max-width: 749px) {
  .works_list_info small {
    font-size: calc(24 / var(--view-size) * 100vw);
  }
}

/* 
service : まるごと、ご依頼パック
----------------------------------- */
.service_bg {
  background-color: #F9EFDA;
  padding-top: 5rem;
  padding-bottom: 4.9375rem;
}
@media (max-width: 749px) {
  .service_bg {
    padding-top: calc(80 / var(--view-size) * 100vw);
    padding-bottom: calc(79 / var(--view-size) * 100vw);
  }
}

.service_ttl_box {
  text-align: center;
}

.service_ttl_top {
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.05em;
}
@media (max-width: 749px) {
  .service_ttl_top {
    font-size: calc(40 / var(--view-size) * 100vw);
  }
}

.service_ttl_top::before,
.service_ttl_top::after {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  width: 3rem;
  aspect-ratio: 48/2;
  background-color: #000;
}
@media (max-width: 749px) {
  .service_ttl_top::before,
  .service_ttl_top::after {
    width: calc(48 / var(--view-size) * 100vw);
  }
}

.service_ttl_top::before {
  transform: translateY(-50%) rotate(72.6deg);
  left: 6.3125rem;
}
@media (max-width: 749px) {
  .service_ttl_top::before {
    left: calc(101 / var(--view-size) * 100vw);
  }
}

.service_ttl_top::after {
  transform: translateY(-50%) rotate(-72.6deg);
  right: 6.3125rem;
}
@media (max-width: 749px) {
  .service_ttl_top::after {
    right: calc(101 / var(--view-size) * 100vw);
  }
}

.service_ttl {
  font-size: 3.5rem;
  font-weight: 900;
  line-height: 1.5;
  margin-top: 1.5rem;
}
@media (max-width: 749px) {
  .service_ttl {
    font-size: calc(56 / var(--view-size) * 100vw);
    margin-top: calc(24 / var(--view-size) * 100vw);
  }
}

.service_ttl span {
  display: inline-block;
  background-color: #FFFFFF;
  padding: 0.5rem 0.625rem 0.75rem;
}
@media (max-width: 749px) {
  .service_ttl span {
    padding: calc(8 / var(--view-size) * 100vw) calc(10 / var(--view-size) * 100vw) calc(12 / var(--view-size) * 100vw);
  }
}

.service_ttl_bottom {
  font-size: 2.5rem;
  font-weight: 900;
  line-height: 1.5;
  letter-spacing: 0.05em;
  margin-top: 0.5rem;
}
@media (max-width: 749px) {
  .service_ttl_bottom {
    font-size: calc(40 / var(--view-size) * 100vw);
    margin-top: calc(8 / var(--view-size) * 100vw);
  }
}

.service_box {
  background-color: #F2690C;
  padding: 2.5rem 2.5rem 2.25rem;
  border-radius: 0.5rem;
  margin-top: 2.5rem;
}
@media (max-width: 749px) {
  .service_box {
    padding: calc(40 / var(--view-size) * 100vw) calc(40 / var(--view-size) * 100vw) calc(36 / var(--view-size) * 100vw);
    border-radius: calc(8 / var(--view-size) * 100vw);
    margin-top: calc(40 / var(--view-size) * 100vw);
  }
}

.service_box_ttl_outer::before,
.service_box_ttl_outer::after {
  display: block;
  content: "";
  position: absolute;
  top: 51%;
  transform: translateY(-50%);
  width: 2.4375rem;
  aspect-ratio: 39/57;
  background-image: url("../image/arrow-down01.svg");
  background-size: contain;
}
@media (max-width: 749px) {
  .service_box_ttl_outer::before,
  .service_box_ttl_outer::after {
    width: calc(39 / var(--view-size) * 100vw);
  }
}

.service_box_ttl_outer::before {
  left: -1.5625rem;
}
@media (max-width: 749px) {
  .service_box_ttl_outer::before {
    left: calc(-25 / var(--view-size) * 100vw);
  }
}

.service_box_ttl_outer::after {
  right: -1.5625rem;
}
@media (max-width: 749px) {
  .service_box_ttl_outer::after {
    right: calc(-25 / var(--view-size) * 100vw);
  }
}

.service_box_ttl {
  width: 32.0625rem;
  border: 0.125rem solid #FFFFFF;
  border-radius: 6.25rem;
  margin-inline: auto;
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.05em;
  color: #FFFFFF;
  text-align: center;
}
@media (max-width: 749px) {
  .service_box_ttl {
    width: calc(513 / var(--view-size) * 100vw);
    border-width: calc(2 / var(--view-size) * 100vw);
    border-radius: calc(100 / var(--view-size) * 100vw);
    font-size: calc(40 / var(--view-size) * 100vw);
  }
}

.service_box_ttl b {
  font-size: 3rem;
  font-weight: 900;
  letter-spacing: 0;
}
@media (max-width: 749px) {
  .service_box_ttl b {
    font-size: calc(48 / var(--view-size) * 100vw);
  }
}

.service_box_list {
  row-gap: 0.6875rem;
  margin-top: 1.5rem;
}
@media (max-width: 749px) {
  .service_box_list {
    row-gap: calc(11 / var(--view-size) * 100vw);
    margin-top: calc(24 / var(--view-size) * 100vw);
  }
}

.service_box_item {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: calc((100% - 1.375rem) / 3);
  border-radius: 0.25rem;
  overflow: hidden;
  background-color: #FFFFFF;
  padding-bottom: 3.125rem;
}
@media (max-width: 749px) {
  .service_box_item {
    border-radius: calc(4 / var(--view-size) * 100vw);
    padding-bottom: calc(50 / var(--view-size) * 100vw);
  }
}

.service_box_item::after {
  display: block;
  content: "";
  position: absolute;
  bottom: 1rem;
  left: 50%;
  transform: translateX(-50%);
  width: 1.5rem;
  aspect-ratio: 16/8;
  background-image: url("../image/arrow-down02.svg");
  background-size: 100% 100%;
}
@media (max-width: 749px) {
  .service_box_item::after {
    bottom: calc(16 / var(--view-size) * 100vw);
    width: calc(24 / var(--view-size) * 100vw);
  }
}

.service_box_item a {
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.service_box_item_txt {
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  font-size: 2.25rem;
  font-weight: 700;
  line-height: 1.2;
  text-align: center;
  margin-top: 1.0625rem;
}
@media (max-width: 749px) {
  .service_box_item_txt {
    font-size: calc(36 / var(--view-size) * 100vw);
    margin-top: calc(17 / var(--view-size) * 100vw);
  }
}

.service_txt {
  font-size: 2rem;
  line-height: 1.5;
  margin-top: 2.5rem;
}
@media (max-width: 749px) {
  .service_txt {
    font-size: calc(32 / var(--view-size) * 100vw);
    margin-top: calc(40 / var(--view-size) * 100vw);
  }
}

.service_txt b {
  font-weight: 700;
}

.service_cont {
  margin-top: 2.5rem;
}
@media (max-width: 749px) {
  .service_cont {
    margin-top: calc(40 / var(--view-size) * 100vw);
  }
}

.service_cont ul {
  row-gap: 2.5rem;
}
@media (max-width: 749px) {
  .service_cont ul {
    row-gap: calc(40 / var(--view-size) * 100vw);
  }
}

.service_cont_item {
  width: 100%;
  background-color: #FFFFFF;
  padding: 2.5rem 2.25rem;
}
@media (max-width: 749px) {
  .service_cont_item {
    padding: calc(40 / var(--view-size) * 100vw) calc(36 / var(--view-size) * 100vw);
  }
}

.service_cont_item_ttl {
  font-size: 3.5rem;
  font-weight: 900;
  line-height: 1.2;
  letter-spacing: 0.02em;
  text-align: center;
}
@media (max-width: 749px) {
  .service_cont_item_ttl {
    font-size: calc(56 / var(--view-size) * 100vw);
  }
}

.service_cont_item_img {
  display: block;
  width: 100%;
  margin-top: 2.5rem;
}
@media (max-width: 749px) {
  .service_cont_item_img {
    margin-top: calc(40 / var(--view-size) * 100vw);
  }
}

.service_cont_top {
  margin-top: 2rem;
}
@media (max-width: 749px) {
  .service_cont_top {
    margin-top: calc(32 / var(--view-size) * 100vw);
  }
}

.service_cont_top_ttl {
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 1.4;
  text-align: center;
}
@media (max-width: 749px) {
  .service_cont_top_ttl {
    font-size: calc(40 / var(--view-size) * 100vw);
    margin-top: calc(40 / var(--view-size) * 100vw);
  }
}

.service_cont_top_txt {
  font-size: 2rem;
  line-height: 1.5;
  text-align: justify;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
  transition: all 0.3s ease;
  margin-top: 2rem;
}
@media (max-width: 749px) {
  .service_cont_top_txt {
    font-size: calc(32 / var(--view-size) * 100vw);
  }
}

.service_cont_top_txt span {
  font-weight: 700;
}

.service_cont_top_txt.open {
  -webkit-line-clamp: unset;
  display: block;
}

.service_cont_btm {
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: all 0.3s ease;
}

.service_cont_btm.open {
  max-height: 100%;
  opacity: 1;
}

.service_cont_btm_head {
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 1.2;
  text-align: center;
  padding: 0.6875rem 0;
  margin-top: 5rem;
}
@media (max-width: 749px) {
  .service_cont_btm_head {
    font-size: calc(40 / var(--view-size) * 100vw);
    padding: calc(11 / var(--view-size) * 100vw) 0;
    margin-top: calc(80 / var(--view-size) * 100vw);
  }
}

.service_cont_btm_head span {
  font-size: 1.6875rem;
  letter-spacing: -0.04em;
  color: #FFFFFF;
  vertical-align: bottom;
  display: inline-block;
  width: 10.3125rem;
  background-color: #F2690C;
  border-radius: 6.25rem;
  padding: 0.5rem 0;
  margin-right: 1.5rem;
}
@media (max-width: 749px) {
  .service_cont_btm_head span {
    font-size: calc(27 / var(--view-size) * 100vw);
    width: calc(165 / var(--view-size) * 100vw);
    border-radius: calc(100 / var(--view-size) * 100vw);
    padding: calc(8 / var(--view-size) * 100vw) 0;
    margin-right: calc(24 / var(--view-size) * 100vw);
  }
}

.cont_btm_head-01 {
  margin-bottom: 1.25rem;
  padding: 0.75rem 0;
  border: 0.125rem solid #F2690C;
  border-radius: 0.0625rem;
}
@media (max-width: 749px) {
  .cont_btm_head-01 {
    margin-bottom: calc(20 / var(--view-size) * 100vw);
    padding: calc(12 / var(--view-size) * 100vw) 0;
    border-width: calc(2 / var(--view-size) * 100vw);
    border-radius: calc(1 / var(--view-size) * 100vw);
  }
}

.cont_btm_head-01::before,
.cont_btm_head-01::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  border-style: solid;
  translate: -50% 100%;
}

.cont_btm_head-01::before {
  border-width: 1.25rem 1.25rem 0 1.25rem;
  border-color: #F2690C transparent transparent;
}
@media (max-width: 749px) {
  .cont_btm_head-01::before {
    border-width: calc(20 / var(--view-size) * 100vw) calc(20 / var(--view-size) * 100vw) 0 calc(20 / var(--view-size) * 100vw);
  }
}

.cont_btm_head-01::after {
  border-width: 1.075rem 1.075rem 0 1.075rem;
  border-color: #FFFFFF transparent transparent;
}
@media (max-width: 749px) {
  .cont_btm_head-01::after {
    border-width: calc(17.2 / var(--view-size) * 100vw) calc(17.2 / var(--view-size) * 100vw) 0 calc(17.2 / var(--view-size) * 100vw);
  }
}

.cont_btm_head-02::before,
.cont_btm_head-02::after {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  width: 0.1875rem;
  height: 4rem;
  background-color: #F2690C;
}
@media (max-width: 749px) {
  .cont_btm_head-02::before,
  .cont_btm_head-02::after {
    width: calc(3 / var(--view-size) * 100vw);
    height: calc(64 / var(--view-size) * 100vw);
  }
}

.cont_btm_head-02::before {
  left: 6.875rem;
  transform: translateY(-50%) rotate(-25deg);
}
@media (max-width: 749px) {
  .cont_btm_head-02::before {
    left: calc(110 / var(--view-size) * 100vw);
  }
}

.cont_btm_head-02::after {
  right: 6.875rem;
  transform: translateY(-50%) rotate(25deg);
}
@media (max-width: 749px) {
  .cont_btm_head-02::after {
    right: calc(110 / var(--view-size) * 100vw);
  }
}

.service_cont_btm_ttl {
  font-size: 2rem;
  font-weight: 700;
  text-align: center;
  margin-top: 2.5rem;
}
@media (max-width: 749px) {
  .service_cont_btm_ttl {
    font-size: calc(32 / var(--view-size) * 100vw);
    margin-top: calc(40 / var(--view-size) * 100vw);
  }
}

.service_cont_btm_img {
  display: block;
  width: 100%;
  margin-top: 2rem;
}
@media (max-width: 749px) {
  .service_cont_btm_img {
    margin-top: calc(32 / var(--view-size) * 100vw);
  }
}

.service_cont_btm_txt {
  font-size: 2rem;
  line-height: 1.5;
  text-align: justify;
  margin-top: 2rem;
}
@media (max-width: 749px) {
  .service_cont_btm_txt {
    font-size: calc(32 / var(--view-size) * 100vw);
    margin-top: calc(32 / var(--view-size) * 100vw);
  }
}

.service_cont_btm_txt span {
  font-weight: 700;
}

.service_cont_btn {
  font-size: 1.75rem;
  font-weight: 700;
  text-align: center;
  margin-top: 2.5rem;
}
@media (max-width: 749px) {
  .service_cont_btn {
    font-size: calc(28 / var(--view-size) * 100vw);
    margin-top: calc(40 / var(--view-size) * 100vw);
  }
}

.service_cont_btn span {
  padding-right: 2.5rem;
}
@media (max-width: 749px) {
  .service_cont_btn span {
    padding-right: calc(40 / var(--view-size) * 100vw);
  }
}

.service_cont_btn span::before,
.service_cont_btn span::after {
  display: block;
  content: "";
  position: absolute;
  background-color: #222222;
}

.service_cont_btn span::before {
  width: 1.5rem;
  height: 0.3125rem;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
}
@media (max-width: 749px) {
  .service_cont_btn span::before {
    width: calc(24 / var(--view-size) * 100vw);
    height: calc(5 / var(--view-size) * 100vw);
  }
}

.service_cont_btn span::after {
  opacity: 1;
  width: 0.3125rem;
  height: 1.5rem;
  top: 50%;
  right: 0.5625rem;
  transform: translateY(-50%);
}
@media (max-width: 749px) {
  .service_cont_btn span::after {
    width: calc(5 / var(--view-size) * 100vw);
    height: calc(24 / var(--view-size) * 100vw);
    right: calc(9 / var(--view-size) * 100vw);
  }
}

.service_cont_btn.open span::after {
  opacity: 0;
}

/* 
price : サービス料金
----------------------------------- */
.price_bg {
  background-color: #F2690C;
  padding-top: 5rem;
  padding-bottom: 5.0625rem;
}
@media (max-width: 749px) {
  .price_bg {
    padding-top: calc(80 / var(--view-size) * 100vw);
    padding-bottom: calc(81 / var(--view-size) * 100vw);
  }
}

.price_ttl {
  font-size: 4.5rem;
  font-weight: 900;
  line-height: 1.5;
  letter-spacing: 0.05em;
  text-align: center;
  color: #FFFFFF;
}
@media (max-width: 749px) {
  .price_ttl {
    font-size: calc(72 / var(--view-size) * 100vw);
  }
}

.price_ttl span {
  display: inline-block;
  padding-bottom: 0.125rem;
  border-bottom: 0.375rem solid #FFFFFF;
}
@media (max-width: 749px) {
  .price_ttl span {
    padding-bottom: calc(8 / var(--view-size) * 100vw);
    border-width: calc(6 / var(--view-size) * 100vw);
  }
}

.price_box {
  margin-top: 5rem;
}
@media (max-width: 749px) {
  .price_box {
    margin-top: calc(80 / var(--view-size) * 100vw);
  }
}

.price_box ul {
  row-gap: 1.9375rem;
}
@media (max-width: 749px) {
  .price_box ul {
    row-gap: calc(31 / var(--view-size) * 100vw);
  }
}

.price_box_item {
  width: 100%;
  display: flex;
  align-items: center;
  border-radius: 0.5rem;
  overflow: hidden;
  background-color: #FFFFFF;
}
@media (max-width: 749px) {
  .price_box_item {
    border-radius: calc(8 / var(--view-size) * 100vw);
  }
}

.price_box_ttl {
  width: 27.5%;
  font-size: 2rem;
  font-weight: 700;
  line-height: 0.9;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 1.1875rem 0 1.8125rem;
  background-color: #F9EFDA;
}
@media (max-width: 749px) {
  .price_box_ttl {
    font-size: calc(32 / var(--view-size) * 100vw);
    padding: calc(19 / var(--view-size) * 100vw) 0 calc(29 / var(--view-size) * 100vw);
  }
}

.price_box_ttl b {
  display: block;
  font-size: 3.5rem;
  font-weight: 700;
  line-height: 1.5;
}
@media (max-width: 749px) {
  .price_box_ttl b {
    font-size: calc(56 / var(--view-size) * 100vw);
  }
}

.price_box_item:nth-of-type(2) .price_box_ttl {
  background-color: #FFF0D0;
}

.price_box_item:nth-of-type(3) .price_box_ttl {
  background-color: #FFE9BB;
}

.price_box_item:nth-of-type(4) .price_box_ttl {
  background-color: #FFE1A3;
}

.price_box_item:nth-of-type(5) .price_box_ttl {
  background-color: #FFD989;
}

.price_box_item:nth-of-type(6) .price_box_ttl {
  background-color: #FFD06E;
}

.price_box_item:nth-of-type(7) .price_box_ttl {
  background-color: #FFC64F;
}

.price_box_item:nth-of-type(8) .price_box_ttl {
  background-color: #FFBC30;
}

.price_box_item:nth-of-type(9) .price_box_ttl {
  background-color: #FFAD00;
}

.price_box_cont {
  width: 72.5%;
  align-items: center;
  justify-content: space-around;
}

.price_box_cont_left_top {
  width: 7.5rem;
  border-radius: 6.25rem;
  border: 0.0625rem solid #222222;
  padding: 0.125rem 0;
  font-size: 1.375rem;
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
}
@media (max-width: 749px) {
  .price_box_cont_left_top {
    width: calc(120 / var(--view-size) * 100vw);
    border-radius: calc(100 / var(--view-size) * 100vw);
    border-width: calc(1 / var(--view-size) * 100vw);
    padding: calc(2 / var(--view-size) * 100vw) 0;
    font-size: calc(22 / var(--view-size) * 100vw);
  }
}

.price_box_cont_left_btm {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
  margin-top: 0.3125rem;
}
@media (max-width: 749px) {
  .price_box_cont_left_btm {
    font-size: calc(32 / var(--view-size) * 100vw);
    margin-top: calc(5 / var(--view-size) * 100vw);
  }
}

.price_box_cont_left_btm small {
  font-size: 1.5rem;
}
@media (max-width: 749px) {
  .price_box_cont_left_btm small {
    font-size: calc(24 / var(--view-size) * 100vw);
  }
}

.price_box_cont_right {
  font-size: 3.5rem;
  font-weight: 900;
  line-height: 1.5;
  color: #EC2B00;
}
@media (max-width: 749px) {
  .price_box_cont_right {
    font-size: calc(56 / var(--view-size) * 100vw);
  }
}

.price_box_cont_right small {
  font-size: 2.5rem;
}
@media (max-width: 749px) {
  .price_box_cont_right small {
    font-size: calc(40 / var(--view-size) * 100vw);
  }
}

/* 
cta : 今すぐ無料見積もり
----------------------------------- */
.cta_bg {
  padding-top: 5rem;
  padding-bottom: 5rem;
}
@media (max-width: 749px) {
  .cta_bg {
    padding-top: calc(80 / var(--view-size) * 100vw);
    padding-bottom: calc(80 / var(--view-size) * 100vw);
  }
}

/* 
compare : 比較
----------------------------------- */
.compare_bg {
  padding-top: 3.9375rem;
  padding-bottom: 3.9375rem;
}
@media (max-width: 749px) {
  .compare_bg {
    padding-top: calc(63 / var(--view-size) * 100vw);
    padding-bottom: calc(63 / var(--view-size) * 100vw);
  }
}

.compare_ttl {
  line-height: 1.3;
  letter-spacing: 0.05em;
  text-align: center;
}

.compare_ttl_top {
  display: block;
  font-size: 2.5rem;
  font-weight: 700;
}
@media (max-width: 749px) {
  .compare_ttl_top {
    font-size: calc(40 / var(--view-size) * 100vw);
  }
}

.compare_ttl_btm {
  display: inline-block;
  font-size: 4.5rem;
  font-weight: 900;
  padding-bottom: 0.25rem;
  border-bottom: 0.375rem solid #F2690C;
  margin-top: 0.4375rem;
}
@media (max-width: 749px) {
  .compare_ttl_btm {
    font-size: calc(72 / var(--view-size) * 100vw);
    padding-bottom: calc(4 / var(--view-size) * 100vw);
    border-width: calc(6 / var(--view-size) * 100vw);
    margin-top: calc(7 / var(--view-size) * 100vw);
  }
}

.compare_box {
  display: flex;
  margin-top: 5.25rem;
}
@media (max-width: 749px) {
  .compare_box {
    margin-top: calc(84 / var(--view-size) * 100vw);
  }
}

.compare_box_list {
  flex-shrink: 0;
  width: 28.8%;
  display: flex;
  flex-direction: column;
}

.compare_box_list_head {
  font-size: 1.75rem;
  font-weight: 500;
  text-align: center;
  height: 6.5rem;
  background-color: #F9EFDA;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 0.0625rem solid #9D9D9D;
  margin-top: -0.0625rem;
}
@media (max-width: 749px) {
  .compare_box_list_head {
    font-size: calc(28 / var(--view-size) * 100vw);
    height: calc(104 / var(--view-size) * 100vw);
    border-width: calc(1 / var(--view-size) * 100vw);
    margin-top: calc(-1 / var(--view-size) * 100vw);
  }
}

.compare_box_list_head:last-of-type {
  height: 12.5rem;
}
@media (max-width: 749px) {
  .compare_box_list_head:last-of-type {
    height: calc(200 / var(--view-size) * 100vw);
  }
}

.compare_box_table {
  overflow-x: scroll;
  padding-bottom: 1.9375rem;
  margin-top: -0.9375rem;
}
@media (max-width: 749px) {
  .compare_box_table {
    padding-bottom: calc(31 / var(--view-size) * 100vw);
    margin-top: calc(-15 / var(--view-size) * 100vw);
  }
}

.compare_box_table figure {
  width: 85.75rem;
}
@media (max-width: 749px) {
  .compare_box_table figure {
    width: calc(1372 / var(--view-size) * 100vw);
  }
}

/* 
strong : 強み
----------------------------------- */
.strong_bg {
  background-color: #D9D9D9;
  padding-top: 5.0625rem;
}
@media (max-width: 749px) {
  .strong_bg {
    padding-top: calc(80 / var(--view-size) * 100vw);
  }
}

.strong_ttl {
  line-height: 1.3;
  letter-spacing: 0.05em;
  text-align: center;
}

.strong_ttl_top {
  display: block;
  font-size: 2.5rem;
  font-weight: 700;
}
@media (max-width: 749px) {
  .strong_ttl_top {
    font-size: calc(40 / var(--view-size) * 100vw);
  }
}

.strong_ttl_btm {
  display: inline-block;
  font-size: 4.5rem;
  font-weight: 900;
  padding-bottom: 0.1875rem;
  border-bottom: 0.375rem solid #F2690C;
  margin-top: 0.4375rem;
}
@media (max-width: 749px) {
  .strong_ttl_btm {
    font-size: calc(72 / var(--view-size) * 100vw);
    padding-bottom: calc(3 / var(--view-size) * 100vw);
    border-width: calc(6 / var(--view-size) * 100vw);
    margin-top: calc(7 / var(--view-size) * 100vw);
  }
}

.strong_box {
  margin-top: 5.5625rem;
}
@media (max-width: 749px) {
  .strong_box {
    margin-top: calc(89 / var(--view-size) * 100vw);
  }
}

.strong_box ul {
  flex-direction: column;
  row-gap: 2.375rem;
}
@media (max-width: 749px) {
  .strong_box ul {
    row-gap: calc(38 / var(--view-size) * 100vw);
  }
}

.strong_box_item {
  background-color: #FFFFFF;
  padding: 2.25rem 2.25rem;
  border-radius: 0.5rem;
  overflow: hidden;
}
@media (max-width: 749px) {
  .strong_box_item {
    padding: calc(36 / var(--view-size) * 100vw) calc(36 / var(--view-size) * 100vw);
    border-radius: calc(8 / var(--view-size) * 100vw);
  }
}

.strong_box_num {
  background-color: #F2690C;
  top: 0;
  left: 0;
  width: 6.25rem;
  aspect-ratio: 1/1;
  padding: 1.1875rem 0;
  border-radius: 0.5rem 0 0.5rem 0;
  font-size: 3rem;
  font-weight: 900;
  line-height: 1.3;
  color: #FFFFFF;
  text-align: center;
}
@media (max-width: 749px) {
  .strong_box_num {
    width: calc(100 / var(--view-size) * 100vw);
    padding: calc(19 / var(--view-size) * 100vw) 0;
    border-radius: calc(8 / var(--view-size) * 100vw) 0 calc(8 / var(--view-size) * 100vw) 0;
    font-size: calc(48 / var(--view-size) * 100vw);
  }
}

.strong_box_ttl {
  font-size: 3rem;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: 0.05em;
  text-align: center;
  margin-top: 2.375rem;
}
@media (max-width: 749px) {
  .strong_box_ttl {
    font-size: calc(48 / var(--view-size) * 100vw);
    margin-top: calc(38 / var(--view-size) * 100vw);
  }
}

.strong_box_ttl span {
  display: block;
  margin-bottom: 0.5625rem;
  font-size: 2rem;
  letter-spacing: 0;
  color: #222222;
}
@media (max-width: 749px) {
  .strong_box_ttl span {
    margin-bottom: calc(9 / var(--view-size) * 100vw);
    font-size: calc(32 / var(--view-size) * 100vw);
  }
}

.strong_box_ttl span::before,
.strong_box_ttl span::after {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  width: 0.125rem;
  height: 3.125rem;
  background-color: #222222;
}
@media (max-width: 749px) {
  .strong_box_ttl span::before,
  .strong_box_ttl span::after {
    width: calc(2 / var(--view-size) * 100vw);
    height: calc(50 / var(--view-size) * 100vw);
  }
}

.strong_box_ttl span::before {
  left: 6.375rem;
  transform: translateY(-50%) rotate(-28deg);
}
@media (max-width: 749px) {
  .strong_box_ttl span::before {
    left: calc(102 / var(--view-size) * 100vw);
  }
}

.strong_box_ttl span::after {
  right: 6.375rem;
  transform: translateY(-50%) rotate(28deg);
}
@media (max-width: 749px) {
  .strong_box_ttl span::after {
    right: calc(102 / var(--view-size) * 100vw);
  }
}

.strong_box_txt {
  font-size: 2rem;
  line-height: 1.5;
  text-align: justify;
  margin-top: 2.25rem;
}
@media (max-width: 749px) {
  .strong_box_txt {
    font-size: calc(32 / var(--view-size) * 100vw);
    margin-top: calc(36 / var(--view-size) * 100vw);
  }
}

.strong_box_txt b {
  font-weight: 700;
}

.strong .cta_bg {
  padding-top: 5.5625rem;
  padding-bottom: 4.8125rem;
}
@media (max-width: 749px) {
  .strong .cta_bg {
    padding-top: calc(89 / var(--view-size) * 100vw);
    padding-bottom: calc(77 / var(--view-size) * 100vw);
  }
}

/* 
archive : 実績多数
----------------------------------- */
.archive_bg {
  background-color: #F2690C;
  padding-top: 5rem;
  padding-bottom: 4.75rem;
}
@media (max-width: 749px) {
  .archive_bg {
    padding-top: calc(80 / var(--view-size) * 100vw);
    padding-bottom: calc(76 / var(--view-size) * 100vw);
  }
}

.archive_ttl {
  font-size: 4.5rem;
  font-weight: 900;
  line-height: 1.3;
  letter-spacing: 0.05em;
  color: #FFFFFF;
  text-align: center;
}
@media (max-width: 749px) {
  .archive_ttl {
    font-size: calc(72 / var(--view-size) * 100vw);
  }
}

.archive_ttl span {
  display: inline-block;
  padding-bottom: 0.25rem;
  border-bottom: 0.375rem solid #FFFFFF;
}
@media (max-width: 749px) {
  .archive_ttl span {
    padding-bottom: calc(4 / var(--view-size) * 100vw);
    border-width: calc(6 / var(--view-size) * 100vw);
  }
}

.archive_slide {
  margin-top: 5rem;
}
@media (max-width: 749px) {
  .archive_slide {
    margin-top: calc(80 / var(--view-size) * 100vw);
  }
}

.swiper {
  padding-bottom: 0.25rem;
}
@media (max-width: 749px) {
  .swiper {
    padding-bottom: calc(4 / var(--view-size) * 100vw);
  }
}

.swiper-slide {
  width: auto;
}

.archive_slide_item {
  box-sizing: border-box;
  background-color: #FFFFFF;
  width: 34rem;
  border-radius: 0.5rem;
  padding: 1.5rem 1.25rem;
  overflow: hidden;
}
@media (max-width: 749px) {
  .archive_slide_item {
    width: calc(544 / var(--view-size) * 100vw);
    border-radius: calc(8 / var(--view-size) * 100vw);
    padding: calc(24 / var(--view-size) * 100vw) calc(20 / var(--view-size) * 100vw);
  }
}

.archive_slide_img_left,
.archive_slide_img_right {
  width: calc((100% - 0.5rem) / 2);
  border-radius: 0.5rem;
  overflow: hidden;
}
@media (max-width: 749px) {
  .archive_slide_img_left,
  .archive_slide_img_right {
    width: calc((100% - 8 / var(--view-size) * 100vw) / 2);
    border-radius: calc(8 / var(--view-size) * 100vw);
  }
}

.archive_slide_img_left p,
.archive_slide_img_right p {
  width: 100%;
  top: 0;
  left: 0;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-align: center;
}
@media (max-width: 749px) {
  .archive_slide_img_left p,
  .archive_slide_img_right p {
    font-size: calc(32 / var(--view-size) * 100vw);
  }
}

.archive_slide_img_left p {
  background-color: #AAAAAA;
  color: #FFFFFF;
}

.archive_slide_img_right p {
  color: #FFFF97;
  background-color: #F2690C;
}

.archive_slide_box {
  margin-top: 1.5rem;
}
@media (max-width: 749px) {
  .archive_slide_box {
    margin-top: calc(24 / var(--view-size) * 100vw);
  }
}

.archive_slide_box_item {
  border: 0.125rem solid #F2690C;
  border-radius: 0.5rem;
  overflow: hidden;
}
@media (max-width: 749px) {
  .archive_slide_box_item {
    border-width: calc(2 / var(--view-size) * 100vw);
    border-radius: calc(8 / var(--view-size) * 100vw);
  }
}

.archive_slide_box_item_left {
  width: 17.875rem;
}
@media (max-width: 749px) {
  .archive_slide_box_item_left {
    width: calc(286 / var(--view-size) * 100vw);
  }
}

.archive_slide_box_item_right {
  width: 13.125rem;
}
@media (max-width: 749px) {
  .archive_slide_box_item_right {
    width: calc(210 / var(--view-size) * 100vw);
  }
}

.archive_slide_box_room01,
.archive_slide_box_price01 {
  background-color: #F2690C;
  font-size: 1.75rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  color: #FFFFFF;
  text-align: center;
  padding: 0.5rem 0;
}
@media (max-width: 749px) {
  .archive_slide_box_room01,
  .archive_slide_box_price01 {
    font-size: calc(28 / var(--view-size) * 100vw);
    padding: calc(8 / var(--view-size) * 100vw) 0;
  }
}

.archive_slide_box_room02,
.archive_slide_box_price02 {
  font-size: 1.75rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-align: center;
  padding: 0.5rem 0;
}
@media (max-width: 749px) {
  .archive_slide_box_room02,
  .archive_slide_box_price02 {
    font-size: calc(28 / var(--view-size) * 100vw);
    padding: calc(8 / var(--view-size) * 100vw) 0;
  }
}

.swiper-button-prev,
.swiper-button-next {
  width: 4rem;
  aspect-ratio: 1/1;
}
@media (max-width: 749px) {
  .swiper-button-prev,
  .swiper-button-next {
    width: calc(64 / var(--view-size) * 100vw);
  }
}

.swiper-button-prev {
  left: 2.0625rem;
}
@media (max-width: 749px) {
  .swiper-button-prev {
    left: calc(33 / var(--view-size) * 100vw);
  }
}

.swiper-button-next {
  right: 2.0625rem;
}
@media (max-width: 749px) {
  .swiper-button-next {
    right: calc(33 / var(--view-size) * 100vw);
  }
}

.swiper-button-prev::after,
.swiper-button-next::after {
  display: block;
  content: "";
  width: 100%;
  aspect-ratio: 1/1;
  background-size: 100% 100%;
}

.swiper-button-prev::after {
  background-image: url("../image/slide-prev.svg");
}

.swiper-button-next::after {
  background-image: url("../image/slide-next.svg");
}

/* 
voice : ご利用された方の声
----------------------------------- */
.voice_bg {
  background-color: #F9EFDA;
  padding-top: 12.8125rem;
}
@media (max-width: 749px) {
  .voice_bg {
    padding-top: calc(205 / var(--view-size) * 100vw);
  }
}

.voice_ttl {
  font-size: 4.5rem;
  font-weight: 900;
  line-height: 1.3;
  letter-spacing: 0.05em;
  text-align: center;
  margin: 0 calc(50% - 50vw);
  width: 100vw;
}
@media (max-width: 749px) {
  .voice_ttl {
    font-size: calc(72 / var(--view-size) * 100vw);
  }
}

.voice_ttl::before {
  display: block;
  content: "";
  position: absolute;
  top: -79%;
  left: 50%;
  transform: translateX(-50%);
  background-image: url("../image/icon-ttl-voice.svg");
  background-size: contain;
  width: 6.5rem;
  height: 5.25rem;
}
@media (max-width: 749px) {
  .voice_ttl::before {
    width: calc(104 / var(--view-size) * 100vw);
    height: calc(84 / var(--view-size) * 100vw);
  }
}

.voice_ttl_top {
  display: block;
  font-size: 2.5rem;
  font-weight: 700;
}
@media (max-width: 749px) {
  .voice_ttl_top {
    font-size: calc(40 / var(--view-size) * 100vw);
  }
}

.voice_ttl_btm {
  display: inline-block;
  padding-bottom: 0.25rem;
  border-bottom: 0.375rem solid #F2690C;
  margin-top: 0.125rem;
}
@media (max-width: 749px) {
  .voice_ttl_btm {
    padding-bottom: calc(4 / var(--view-size) * 100vw);
    border-width: calc(6 / var(--view-size) * 100vw);
    margin-top: calc(2 / var(--view-size) * 100vw);
  }
}

.voice_box {
  margin-top: 5rem;
}
@media (max-width: 749px) {
  .voice_box {
    margin-top: calc(80 / var(--view-size) * 100vw);
  }
}

.voice_box ul {
  row-gap: 2.5rem;
}
@media (max-width: 749px) {
  .voice_box ul {
    row-gap: calc(40 / var(--view-size) * 100vw);
  }
}

.voice_box_item {
  background-color: #FFFFFF;
  border-radius: 0.5rem;
  overflow: hidden;
  padding: 2.25rem 2.25rem;
}
@media (max-width: 749px) {
  .voice_box_item {
    border-radius: calc(8 / var(--view-size) * 100vw);
    padding: calc(36 / var(--view-size) * 100vw) calc(36 / var(--view-size) * 100vw);
  }
}

.voice_box_ttl {
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.05em;
  text-align: center;
}
@media (max-width: 749px) {
  .voice_box_ttl {
    font-size: calc(40 / var(--view-size) * 100vw);
  }
}

.voice_box_txt {
  font-size: 2rem;
  line-height: 1.5;
  margin-top: 1.5rem;
}
@media (max-width: 749px) {
  .voice_box_txt {
    font-size: calc(32 / var(--view-size) * 100vw);
    margin-top: calc(24 / var(--view-size) * 100vw);
  }
}

.voice_box_img {
  margin-top: 1.5rem;
}
@media (max-width: 749px) {
  .voice_box_img {
    margin-top: calc(24 / var(--view-size) * 100vw);
  }
}

.voice_box_foot {
  font-size: 2rem;
  line-height: 1.5;
  text-align: right;
  margin-top: 1.5rem;
}
@media (max-width: 749px) {
  .voice_box_foot {
    font-size: calc(32 / var(--view-size) * 100vw);
    margin-top: calc(24 / var(--view-size) * 100vw);
  }
}

/* 
foot_banner : 下部追随ボタン
----------------------------------- */
.banner {
  z-index: 99;
  width: 100%;
  bottom: 0;
  left: 0;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: all 0.3s ease;
}

.banner.active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.banner .inner {
  background-color: #FFFFFF;
  padding-block: 1rem;
}
@media (max-width: 749px) {
  .banner .inner {
    padding-block: calc(16 / var(--view-size) * 100vw);
  }
}

.banner_nav_tel,
.banner_nav_line,
.banner_nav_mail {
  border-radius: 0.625rem;
  overflow: hidden;
}
@media (max-width: 749px) {
  .banner_nav_tel,
  .banner_nav_line,
  .banner_nav_mail {
    border-radius: calc(10 / var(--view-size) * 100vw);
  }
}

.banner_nav_tel {
  width: 23.5rem;
}
@media (max-width: 749px) {
  .banner_nav_tel {
    width: calc(376 / var(--view-size) * 100vw);
  }
}

.banner_nav_line,
.banner_nav_mail {
  width: 8.5rem;
}
@media (max-width: 749px) {
  .banner_nav_line,
  .banner_nav_mail {
    width: calc(136 / var(--view-size) * 100vw);
  }
}

/* 
option : オプションサービス
----------------------------------- */
.option_bg {
  padding-top: 5rem;
  padding-bottom: 5rem;
}
@media (max-width: 749px) {
  .option_bg {
    padding-top: calc(80 / var(--view-size) * 100vw);
    adding-bottom: calc(80 / var(--view-size) * 100vw);
  }
}

.option_ttl {
  font-size: 4.5rem;
  font-weight: 900;
  line-height: 1.3;
  letter-spacing: 0.05em;
  text-align: center;
  margin: 0 calc(50% - 50vw);
  width: 100vw;
}
@media (max-width: 749px) {
  .option_ttl {
    font-size: calc(72 / var(--view-size) * 100vw);
  }
}

.option_ttl_top {
  display: block;
  font-size: 2.5rem;
  font-weight: 700;
}
@media (max-width: 749px) {
  .option_ttl_top {
    font-size: calc(40 / var(--view-size) * 100vw);
  }
}

.option_ttl_btm {
  display: inline-block;
  padding-bottom: 0.25rem;
  border-bottom: 0.375rem solid #F2690C;
  margin-top: 0.5625rem;
}
@media (max-width: 749px) {
  .option_ttl_btm {
    padding-bottom: calc(4 / var(--view-size) * 100vw);
    border-width: calc(6 / var(--view-size) * 100vw);
    margin-top: calc(9 / var(--view-size) * 100vw);
  }
}

.option_box {
  margin-top: 5rem;
}
@media (max-width: 749px) {
  .option_box {
    margin-top: calc(80 / var(--view-size) * 100vw);
  }
}

.option_box ul {
  -moz-column-gap: 2.375rem;
       column-gap: 2.375rem;
  row-gap: 5rem;
}
@media (max-width: 749px) {
  .option_box ul {
    -moz-column-gap: calc(38 / var(--view-size) * 100vw);
         column-gap: calc(38 / var(--view-size) * 100vw);
    row-gap: calc(80 / var(--view-size) * 100vw);
  }
}

.option_box_item {
  width: calc((100% - 2.375rem) / 2);
}
@media (max-width: 749px) {
  .option_box_item {
    width: calc((100% - 38 / var(--view-size) * 100vw) / 2);
  }
}

.option_box_img {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 19.75rem;
  aspect-ratio: 1/1;
  border-radius: 62.4375rem;
  background-color: #F9EFDA;
}
@media (max-width: 749px) {
  .option_box_img {
    width: calc(316 / var(--view-size) * 100vw);
    border-radius: calc(999 / var(--view-size) * 100vw);
  }
}

.option_box_img figure {
  width: 8.8125rem;
}
@media (max-width: 749px) {
  .option_box_img figure {
    width: calc(141 / var(--view-size) * 100vw);
  }
}

.option_box_item:nth-of-type(2) .option_box_img figure {
  width: 12.5rem;
}
@media (max-width: 749px) {
  .option_box_item:nth-of-type(2) .option_box_img figure {
    width: calc(200 / var(--view-size) * 100vw);
  }
}

.option_box_item:nth-of-type(3) .option_box_img figure {
  width: 12.5rem;
}
@media (max-width: 749px) {
  .option_box_item:nth-of-type(3) .option_box_img figure {
    width: calc(200 / var(--view-size) * 100vw);
  }
}

.option_box_item:nth-of-type(4) .option_box_img figure {
  width: 12.5rem;
}
@media (max-width: 749px) {
  .option_box_item:nth-of-type(4) .option_box_img figure {
    width: calc(200 / var(--view-size) * 100vw);
  }
}

.option_box_item:nth-of-type(5) .option_box_img figure {
  width: 12.5rem;
}
@media (max-width: 749px) {
  .option_box_item:nth-of-type(5) .option_box_img figure {
    width: calc(200 / var(--view-size) * 100vw);
  }
}

.option_box_item:nth-of-type(6) .option_box_img figure {
  width: 13.5625rem;
}
@media (max-width: 749px) {
  .option_box_item:nth-of-type(6) .option_box_img figure {
    width: calc(217 / var(--view-size) * 100vw);
  }
}

.option_box_item:nth-of-type(7) .option_box_img figure {
  width: 14.1875rem;
}
@media (max-width: 749px) {
  .option_box_item:nth-of-type(7) .option_box_img figure {
    width: calc(227 / var(--view-size) * 100vw);
  }
}

.option_box_ttl {
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: 0.05em;
  text-align: center;
  margin-top: 1rem;
}
@media (max-width: 749px) {
  .option_box_ttl {
    font-size: calc(40 / var(--view-size) * 100vw);
    margin-top: calc(16 / var(--view-size) * 100vw);
  }
}

.option_box_item:nth-of-type(3) .option_box_ttl {
  font-size: 1.875rem;
}
@media (max-width: 749px) {
  .option_box_item:nth-of-type(3) .option_box_ttl {
    font-size: calc(30 / var(--view-size) * 100vw);
  }
}

.option_box_txt {
  font-size: 2rem;
  line-height: 1.5;
  text-align: justify;
  margin-top: 1rem;
}
@media (max-width: 749px) {
  .option_box_txt {
    font-size: calc(32 / var(--view-size) * 100vw);
    margin-top: calc(16 / var(--view-size) * 100vw);
  }
}

/* 
thought : サービスの思い
----------------------------------- */
.thouget_bg {
  background-color: #F2690C;
  padding-top: 2.75rem;
}
@media (max-width: 749px) {
  .thouget_bg {
    padding-top: calc(44 / var(--view-size) * 100vw);
  }
}

.thouget_ttl {
  font-size: 4.5rem;
  font-weight: 900;
  line-height: 1.3;
  letter-spacing: 0.05em;
  color: #FFFFFF;
  text-align: center;
}
@media (max-width: 749px) {
  .thouget_ttl {
    font-size: calc(72 / var(--view-size) * 100vw);
  }
}

.thouget_ttl_top {
  font-size: 2.5rem;
  font-weight: 700;
}
@media (max-width: 749px) {
  .thouget_ttl_top {
    font-size: calc(40 / var(--view-size) * 100vw);
  }
}

.thouget_ttl_btm {
  display: inline-block;
  padding-bottom: 0.25rem;
  border-bottom: 0.375rem solid #FFFFFF;
  margin-top: 0.125rem;
}
@media (max-width: 749px) {
  .thouget_ttl_btm {
    padding-bottom: calc(4 / var(--view-size) * 100vw);
    border-width: calc(6 / var(--view-size) * 100vw);
    margin-top: calc(2 / var(--view-size) * 100vw);
  }
}

.thouget_box {
  margin-top: 8.3125rem;
}
@media (max-width: 749px) {
  .thouget_box {
    margin-top: calc(133 / var(--view-size) * 100vw);
  }
}

.thouget_box ul {
  row-gap: 5.75rem;
}
@media (max-width: 749px) {
  .thouget_box ul {
    row-gap: calc(92 / var(--view-size) * 100vw);
  }
}

.thouget_box_item {
  background-color: #FFFFFF;
  border-radius: 0.5rem;
}
@media (max-width: 749px) {
  .thouget_box_item {
    border-radius: calc(8 / var(--view-size) * 100vw);
  }
}

.thouget_box_ttl {
  top: -3.5rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 6.5rem;
  aspect-ratio: 1/1;
  border: 0.5rem solid #F2690C;
  border-radius: 6.25rem;
  background-color: #FFFFFF;
  font-size: 3.375rem;
  font-weight: 700;
  letter-spacing: 1.3;
}
@media (max-width: 749px) {
  .thouget_box_ttl {
    top: calc(-56 / var(--view-size) * 100vw);
    width: calc(104 / var(--view-size) * 100vw);
    border-width: calc(8 / var(--view-size) * 100vw);
    border-radius: calc(100 / var(--view-size) * 100vw);
    font-size: calc(54 / var(--view-size) * 100vw);
  }
}

.thouge_box_img {
  border-radius: 0.5rem 0.5rem 0 0;
  overflow: hidden;
}
@media (max-width: 749px) {
  .thouge_box_img {
    border-radius: calc(8 / var(--view-size) * 100vw) calc(8 / var(--view-size) * 100vw) 0 0;
  }
}

.thouget_box_sub {
  font-size: 3rem;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: 0.05em;
  text-align: center;
  margin-top: 2rem;
}
@media (max-width: 749px) {
  .thouget_box_sub {
    font-size: calc(48 / var(--view-size) * 100vw);
    margin-top: calc(32 / var(--view-size) * 100vw);
  }
}

.thouge_box_txt {
  font-size: 2rem;
  line-height: 1.5;
  text-align: justify;
  padding: 0 2rem 2rem;
  margin-top: 1.5rem;
}
@media (max-width: 749px) {
  .thouge_box_txt {
    font-size: calc(32 / var(--view-size) * 100vw);
    padding: 0 calc(32 / var(--view-size) * 100vw) calc(32 / var(--view-size) * 100vw);
    margin-top: calc(24 / var(--view-size) * 100vw);
  }
}

.thouge_box_txt b {
  font-weight: 700;
}

/* 
flow : ご依頼の流れ
----------------------------------- */
.flow_bg {
  padding-top: 5rem;
}
@media (max-width: 749px) {
  .flow_bg {
    padding-top: calc(80 / var(--view-size) * 100vw);
  }
}

.flow_ttl {
  font-size: 4.5rem;
  font-weight: 900;
  line-height: 1.3;
  letter-spacing: 0.05em;
  text-align: center;
}
@media (max-width: 749px) {
  .flow_ttl {
    font-size: calc(72 / var(--view-size) * 100vw);
  }
}

.flow_ttl span {
  display: inline-block;
}

.flow_dot {
  width: 0.375rem;
  height: 5rem;
  margin-top: 2.5rem;
  margin-inline: auto;
}
@media (max-width: 749px) {
  .flow_dot {
    width: calc(6 / var(--view-size) * 100vw);
    height: calc(80 / var(--view-size) * 100vw);
    margin-top: calc(40 / var(--view-size) * 100vw);
  }
}

.flow_box {
  margin-top: 2.5rem;
}
@media (max-width: 749px) {
  .flow_box {
    margin-top: calc(40 / var(--view-size) * 100vw);
  }
}

.flow_box ul {
  row-gap: 2.375rem;
}
@media (max-width: 749px) {
  .flow_box ul {
    row-gap: calc(38 / var(--view-size) * 100vw);
  }
}

.flow_box_item {
  border: 0.5rem solid #F2690C;
  border-radius: 0.5rem;
  overflow: hidden;
  padding: 1.75rem 1.75rem 1.625rem;
}
@media (max-width: 749px) {
  .flow_box_item {
    border-width: calc(8 / var(--view-size) * 100vw);
    border-radius: calc(8 / var(--view-size) * 100vw);
    padding: calc(28 / var(--view-size) * 100vw) calc(28 / var(--view-size) * 100vw) calc(26 / var(--view-size) * 100vw);
  }
}

.flow_box_ttl {
  width: 12.3125rem;
  margin-inline: auto;
  background-color: #F2690C;
  border-radius: 6.25rem;
  padding: 0.25rem 0;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.4;
  color: #FFFFFF;
  text-align: center;
}
@media (max-width: 749px) {
  .flow_box_ttl {
    width: calc(197 / var(--view-size) * 100vw);
    border-radius: calc(100 / var(--view-size) * 100vw);
    padding: calc(4 / var(--view-size) * 100vw) 0;
    font-size: calc(32 / var(--view-size) * 100vw);
  }
}

.flow_box_ttl b {
  font-size: 2.5rem;
  font-weight: 700;
}
@media (max-width: 749px) {
  .flow_box_ttl b {
    font-size: calc(40 / var(--view-size) * 100vw);
  }
}

.flow_box_ttl_sub {
  font-size: 3rem;
  font-weight: 900;
  line-height: 1.4;
  letter-spacing: 0.05em;
  text-align: center;
  margin-top: 1.5rem;
}
@media (max-width: 749px) {
  .flow_box_ttl_sub {
    font-size: calc(48 / var(--view-size) * 100vw);
    margin-top: calc(24 / var(--view-size) * 100vw);
  }
}

.flow_box_txt {
  font-size: 2rem;
  line-height: 1.5;
  text-align: justify;
  margin-top: 1.5rem;
}
@media (max-width: 749px) {
  .flow_box_txt {
    font-size: calc(32 / var(--view-size) * 100vw);
    margin-top: calc(24 / var(--view-size) * 100vw);
  }
}

.flow_box_txt small {
  font-size: 1.5rem;
}
@media (max-width: 749px) {
  .flow_box_txt small {
    font-size: calc(24 / var(--view-size) * 100vw);
  }
}

.flow_box_img {
  margin-top: 1.5rem;
}
@media (max-width: 749px) {
  .flow_box_img {
    margin-top: calc(24 / var(--view-size) * 100vw);
  }
}

/* 
law : 法令順守
----------------------------------- */
.law_bg {
  position: relative;
  background-image: url("../image/law-bg.jpg");
  background-repeat: repeat-y;
  padding-top: 5rem;
  padding-bottom: 4.25rem;
  z-index: -1;
}
@media (max-width: 749px) {
  .law_bg {
    padding-top: calc(80 / var(--view-size) * 100vw);
    padding-bottom: calc(68 / var(--view-size) * 100vw);
  }
}

.law_bg::before {
  display: block;
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(255, 255, 255, 0.4);
  z-index: -1;
}

.law_ttl {
  font-size: 4.5rem;
  font-weight: 900;
  line-height: 1.3;
  letter-spacing: 0.05em;
  text-align: center;
}
@media (max-width: 749px) {
  .law_ttl {
    font-size: calc(72 / var(--view-size) * 100vw);
  }
}

.law_ttl_top {
  display: block;
}

.law_ttl_btm {
  display: inline-block;
  padding-bottom: 0.25rem;
  border-bottom: 0.375rem solid #F2690C;
  margin-top: 0.125rem;
}
@media (max-width: 749px) {
  .law_ttl_btm {
    padding-bottom: calc(4 / var(--view-size) * 100vw);
    border-width: calc(6 / var(--view-size) * 100vw);
    margin-top: calc(2 / var(--view-size) * 100vw);
  }
}

.law_box {
  margin-top: 5rem;
}
@media (max-width: 749px) {
  .law_box {
    margin-top: calc(80 / var(--view-size) * 100vw);
  }
}

.law_box ul {
  row-gap: 2.875rem;
}
@media (max-width: 749px) {
  .law_box ul {
    row-gap: calc(46 / var(--view-size) * 100vw);
  }
}

.law_box_item {
  background-color: #FFFFFF;
  border-radius: 0.5rem;
  overflow: hidden;
  padding: 2.5rem 2.25rem 2.5rem;
}
@media (max-width: 749px) {
  .law_box_item {
    border-radius: calc(8 / var(--view-size) * 100vw);
    padding: calc(40 / var(--view-size) * 100vw) calc(36 / var(--view-size) * 100vw) calc(40 / var(--view-size) * 100vw);
  }
}

.law_box_ttl {
  font-size: 3.5rem;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.05em;
  text-align: center;
}
@media (max-width: 749px) {
  .law_box_ttl {
    font-size: calc(56 / var(--view-size) * 100vw);
  }
}

.law_box_img {
  margin-top: 2.5rem;
}
@media (max-width: 749px) {
  .law_box_img {
    margin-top: calc(40 / var(--view-size) * 100vw);
  }
}

.law_box_txt {
  font-size: 2rem;
  line-height: 1.5;
  text-align: justify;
  margin-top: 2rem;
}
@media (max-width: 749px) {
  .law_box_txt {
    font-size: calc(32 / var(--view-size) * 100vw);
    margin-top: calc(32 / var(--view-size) * 100vw);
  }
}

/* 
faq : よくある質問
----------------------------------- */
.faq_bg {
  background-color: #F2690C;
  padding-top: 11.3125rem;
  padding-bottom: 0rem;
}
@media (max-width: 749px) {
  .faq_bg {
    padding-top: calc(181 / var(--view-size) * 100vw);
    padding-bottom: calc(0 / var(--view-size) * 100vw);
  }
}

.faq_ttl {
  font-size: 4.5rem;
  font-weight: 900;
  line-height: 1.3;
  letter-spacing: 0.05em;
  color: #FFFFFF;
  text-align: center;
}
@media (max-width: 749px) {
  .faq_ttl {
    font-size: calc(72 / var(--view-size) * 100vw);
  }
}

.faq_ttl::before {
  display: block;
  content: "";
  position: absolute;
  top: -94%;
  left: 50%;
  transform: translateX(-50%);
  width: 6.5rem;
  height: 5.1875rem;
  background-image: url("../image/icon-qa-ttl.svg");
  background-size: 100%;
}
@media (max-width: 749px) {
  .faq_ttl::before {
    width: calc(104 / var(--view-size) * 100vw);
    height: calc(83 / var(--view-size) * 100vw);
  }
}

.faq_ttl span {
  display: inline-block;
  padding-bottom: 0.25rem;
  border-bottom: 0.375rem solid #FFFFFF;
}
@media (max-width: 749px) {
  .faq_ttl span {
    padding-bottom: calc(4 / var(--view-size) * 100vw);
    border-width: calc(6 / var(--view-size) * 100vw);
  }
}

.faq_box {
  padding-bottom: 5rem;
  margin-top: 5rem;
}
@media (max-width: 749px) {
  .faq_box {
    padding-bottom: calc(80 / var(--view-size) * 100vw);
    margin-top: calc(80 / var(--view-size) * 100vw);
  }
}

.faq_box ul {
  row-gap: 2.5rem;
}
@media (max-width: 749px) {
  .faq_box ul {
    row-gap: calc(80 / var(--view-size) * 100vw);
  }
}

.faq_box_acd {
  background-color: #F9EFDA;
  border-radius: 0.25rem;
  overflow: hidden;
}
@media (max-width: 749px) {
  .faq_box_acd {
    border-radius: calc(4 / var(--view-size) * 100vw);
  }
}

.faq_box_ttl {
  display: flex;
  align-items: center;
  list-style: none;
  padding: 2.5rem 0;
  padding-left: 6.8125rem;
  padding-right: 6.875rem;
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 1.4;
}
@media (max-width: 749px) {
  .faq_box_ttl {
    padding: calc(40 / var(--view-size) * 100vw) 0;
    padding-left: calc(109 / var(--view-size) * 100vw);
    padding-right: calc(110 / var(--view-size) * 100vw);
    font-size: calc(40 / var(--view-size) * 100vw);
  }
}

.faq_box_ttl::before,
.faq_box_ttl::after {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.faq_box_ttl::before {
  content: "Q";
  left: 2.5rem;
  font-size: 3rem;
}
@media (max-width: 749px) {
  .faq_box_ttl::before {
    left: calc(40 / var(--view-size) * 100vw);
    font-size: calc(40 / var(--view-size) * 100vw);
  }
}

.faq_box_ttl::after {
  content: "＋";
  right: 1.6875rem;
  font-size: 3.25rem;
}
@media (max-width: 749px) {
  .faq_box_ttl::after {
    right: calc(27 / var(--view-size) * 100vw);
    font-size: calc(52 / var(--view-size) * 100vw);
  }
}

.faq_box_acd details[open] .faq_box_ttl::after {
  content: "ー";
  font-weight: 500;
}

.faq_box_txt {
  font-size: 2rem;
  line-height: 1.5;
  background-color: #FFFFFF;
  padding: 2rem 2.3125rem;
}
@media (max-width: 749px) {
  .faq_box_txt {
    font-size: calc(32 / var(--view-size) * 100vw);
    padding: calc(32 / var(--view-size) * 100vw) calc(37 / var(--view-size) * 100vw);
  }
}

.faq_box_txt small {
  font-size: 1.5rem;
}
@media (max-width: 749px) {
  .faq_box_txt small {
    font-size: calc(24 / var(--view-size) * 100vw);
  }
}

.faq .cta_bg {
  background-color: #F9EFDA;
}/*# sourceMappingURL=style.css.map */