@charset "UTF-8";

/* Regular - 700 */
/*
    Template: swell
    Theme Name: SWELL CHILD
    Theme URI: https://swell-theme.com/
    Description: SWELLの子テーマ
    Version: 1.0.0
    Author: LOOS WEB STUDIO
    Author URI: https://loos-web-studio.com/

    License: GNU General Public License
    License URI: http://www.gnu.org/licenses/gpl.html
*/
:root {
  --main-color: #000;
  --sub-color: #fff;
}

html,
button,
input,
select,
textarea {
  /* 不要な指定は消す */
  font-family: "Noto Sans JP", sans-serif;
}

body {
  font-feature-settings: "halt" 0, "palt" 0;
  color: #333333;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  letter-spacing: 0.04em;
  line-height: 1.67;
  min-width: 1440px;
}

.wrap {
  margin: 0 auto;
  width: 1140px;
}

.wrap.mid {
  width: 1240px;
}

.wrap.lr {
  width: 1340px;
}

/* PC固定ページ 共通設定 */
.common_page_main {
  background: #F5F5F5;
  margin-block: 0 1em;
  padding-block: 140px;
}

.common_page_main .title_box {
  text-align: center;
}

.common_page_main .title_box .title {
  font-size: 40px;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1.5;
}

.common_page_wrap {
  background: #F7F6F4;
  padding: 80px 0 210px;
}

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

.reserve_text {
  font-size: 30px;
  text-align: center;
}

/* パンくず */
.breadcrumb {
  color: #3E3E3E;
  font-size: 12px;
  letter-spacing: 0.08em;
}

.breadcrumb a {
  color: #3E3E3E;
  text-decoration: none;
}

/* PC固定ページ お問い合わせ */
.contact_form_disc {
  color: #3E3E3E;
  font-weight: 400;
  letter-spacing: 0.08em;
  margin-block: 0 3.8em;
  text-align: center;
}

.contact_form_disc .text {
  font-size: 16px;
  margin-block: 0 1em;
}

.contact_form_disc .caution {
  font-size: 14px;
}

.common_contact_form .form_box {
  margin-block: 0 50px;
}

.common_contact_form .form_box dl {
  align-items: center;
  display: grid;
  gap: 80px;
  grid-template-columns: 26.5% 1fr;
}

.common_contact_form .form_box dl.start {
  align-items: flex-start;
}

.common_contact_form .form_box dl+dl {
  margin-block: 1.6em 0;
}

.common_contact_form .form_box dl dt {
  align-items: center;
  display: flex;
  font-size: 16px;
  font-weight: 700;
  gap: 1.3em;
  letter-spacing: 0.08em;
  padding-inline: 0 0.5em;
  position: relative;
}

.common_contact_form .form_box dl dt .label {
  border-radius: 100vmax;
  color: #3E3E3E;
  flex-shrink: 0;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.2em;
  padding: 0.2em 0.9em;
}

.common_contact_form .form_box dl dt .label.hissu {
  background: #C70000;
  color: #fff;
}

.common_contact_form .form_box dl dt .label.ninni {
  background: #E0E0E0;
}

.common_contact_form .form_box dl dt::after {
  background: #AAA;
  content: "";
  height: 30px;
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 1px;
}

.common_contact_form input[type=text],
.common_contact_form input[type=email],
.common_contact_form #zip,
.common_contact_form #zip2 {
  background: #FFFFFF;
  border: 1px solid #E6E6E6;
  border-radius: 4px;
  font-size: 14px;
  font-weight: 400;
  letter-spacing: 0.08em;
  padding: 0.8em 1em;
  width: 100%;
}

.common_contact_form textarea {
  background: #FFFFFF;
  border: 1px solid #E6E6E6;
  border-radius: 4px;
  font-size: 14px;
  font-weight: 400;
  height: 180px;
  letter-spacing: 0.08em;
  padding: 1em;
  width: 100%;
}

.common_contact_form input::-moz-placeholder,
.common_contact_form textarea::-moz-placeholder {
  color: #C7C4C4;
}

.common_contact_form input::placeholder,
.common_contact_form textarea::placeholder {
  color: #C7C4C4;
}

.common_contact_form select,
.common_contact_form .hasDatepicker[type=text] {
  background: #FFFFFF;
  border: 1px solid #E6E6E6;
  border-radius: 4px;
  font-size: 14px;
  letter-spacing: 0.08em;
  padding: 1em 1em;
  width: 47.5%;
}

.common_contact_form select.empty {
  color: #C7C4C4;
}

.page_contact #btn_wrap {
  justify-content: center;
  margin: auto;
  text-align: right;
  width: 74%;
}

.page_contact #btn_wrap button {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: #E6830A;
  border: none;
  color: #fff;
  cursor: pointer;
  display: block;
  font-size: 18px;
  font-weight: 900;
  letter-spacing: 0.08em;
  line-height: 60px;
  margin: auto;
  outline: none;
  padding: 0;
  text-align: center;
  transition: 0.3s;
  width: 310px;
}

.page_contact #btn_wrap button[name=submitBack] {
  background: #333;
  margin-top: 20px;
}

.page_contact #btn_wrap button:hover {
  opacity: 0.8;
}

.privacy_term_outer .privacy_term_inner {
  height: 138px;
  margin: auto;
  overflow: auto;
}

.privacy_term_outer .privacy_term_inner .privacy_index {
  font-size: 14px;
}

.privacy_term_outer .privacy_term_inner .main_text {
  font-size: 13px;
  margin-bottom: 25px;
}

.privacy_term_outer .privacy_term_inner dl dt {
  border-left: solid 3px #ccc;
  font-size: 13px;
  margin-bottom: 5px;
  padding-left: 1em;
}

.privacy_term_outer .privacy_term_inner dl dd {
  font-size: 13px;
}

.privacy_term_outer .privacy_term_inner dl+dl {
  margin-top: 30px;
}

.privacy_term_outer .privacy_term_inner::-webkit-scrollbar {
  width: 8px;
}

.privacy_term_outer .privacy_term_inner::-webkit-scrollbar-track {
  background: transparent;
}

.privacy_term_outer .privacy_term_inner::-webkit-scrollbar-thumb {
  background-color: #333;
  border-radius: 10px;
}

.privacy_term_outer {
  border-bottom: solid 1px #e3e3e3;
  border-top: solid 1px #e3e3e3;
  margin: 0 auto 50px;
  padding: 30px 0;
  width: 60%;
}

.privacy_check_list .mwform-checkbox-field-text {
  padding-right: 0;
}

.privacy_check_list .error {
  font-size: 12px;
}

.privacy_term_detail {
  font-size: 13px;
  font-weight: 600;
  margin: 20px 0;
  position: relative;
  text-align: center;
}

.privacy_term_detail::after {
  aspect-ratio: 1/1;
  border: solid #333;
  border-width: 2px 2px 0 0;
  content: "";
  display: block;
  margin: 5px auto 0;
  min-width: 0;
  rotate: 135deg;
  width: 10px;
}

.mw_wp_form_confirm .privacy_check_list,
.mw_wp_form_confirm .privacy_term_detail {
  display: none;
}

/* ラジオボタン デザイン */
.radio_btns,
.checkboxes {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5em 1.5em;
  padding: 0.5em 0;
}

/* ラジオボタンを隠す */
.radio_btns input[type=radio].radio_btns__item {
  display: none;
}

.radio_btns label {
  cursor: pointer;
  display: inline-block;
}

/* spanの左側にボタンを配置するスペースを作る */
.radio_btns .radio_btns__item+span {
  color: #3E3E3E;
  display: inline-block;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: 0.08em;
  padding-left: 2em;
  position: relative;
}

/* 各パーツを作成 */
.radio_btns .radio_btns__item+span::before,
.radio_btns .radio_btns__item+span::after {
  aspect-ratio: 1;
  background: #FFFFFF;
  border: 1px solid #E6E6E6;
  border-radius: 50%;
  bottom: 0;
  content: "";
  display: block;
  left: 0;
  margin: auto;
  min-width: 0;
  position: absolute;
  top: 0;
  width: 20px;
}

/* after上書き */
.radio_btns .radio_btns__item+span::after {
  aspect-ratio: 1;
  background: #5A5A5A;
  border: none;
  left: 5px;
  min-width: 0;
  top: 0px;
  transform: scale(0);
  transition: all 0.3s;
  width: 10px;
}

/*
  checked状態
  文字のcolorとボタンのopacityを変更
*/
.radio_btns .radio_btns__item:checked+span::after {
  transform: scale(1);
}

/* チェックボックス デザイン */
.page_contact input[type=checkbox] {
  /* デフォルトcheckボックス非表示*/
  display: none;
}

.mwform-checkbox-field label {
  cursor: pointer;
}

.mwform-checkbox-field-text {
  color: #3E3E3E;
  display: inline-block;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: 0.08em;
  padding: 0 0 0 30px;
  position: relative;
}

.mwform-checkbox-field-text::before,
.mwform-checkbox-field-text::after {
  content: "";
  display: block;
  position: absolute;
}

.mwform-checkbox-field-text::before {
  aspect-ratio: 1/1;
  background: #FFFFFF;
  border: 1px solid #E6E6E6;
  border-radius: 2px;
  left: 0;
  min-width: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
}

.mwform-checkbox-field-text::after {
  aspect-ratio: 2/1;
  border-color: transparent transparent #333 #333;
  border-style: solid;
  border-width: 3px;
  left: 0;
  margin-top: -0.2em;
  min-width: 0;
  opacity: 0;
  top: 50%;
  transform: translateY(-50%) rotate(-45deg);
  width: 20px;
}

input[type=checkbox]:checked+.mwform-checkbox-field-text::after {
  opacity: 1;
}

.mw_wp_form .horizontal-item {
  display: inline-block;
}

.mw_wp_form .horizontal-item+.horizontal-item {
  margin-left: 0 !important;
}

/* サンクスページ */
.page_contact .thanks_textArea .name {
  font-size: 16px;
  line-height: 2;
  margin-bottom: 20px;
  text-align: center;
}

.page_contact .thanks_textArea .contact_text {
  margin: 0 auto 50px;
  width: 62%;
}

.page_contact .thanks_textArea .ichiran_link {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: #E6830A;
  border: none;
  border-radius: 4px;
  color: #fff;
  cursor: pointer;
  display: block;
  font-size: 20px;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 0.08em;
  line-height: 50px;
  margin: 0 auto;
  outline: none;
  padding: 0;
  text-align: center;
  text-decoration: none;
  transition: 0.3s;
  width: 300px;
}

.page_contact .thanks_textArea .ichiran_link:hover {
  opacity: 0.8;
}

.page_contact .thanks_textArea .contact_text .space {
  display: block;
}

.page_contact .thanks_textArea .contact_text .space {
  display: block;
  margin-top: 10px;
}

/* ステップバー デザイン */
.page_contact .progressbar {
  align-items: center;
  display: flex;
  gap: 5.6em;
  justify-content: center;
  margin-block: 0 3em;
}

.page_contact .progressbar .item {
  color: #3E3E3E;
  font-size: 14px;
  font-weight: 400;
  letter-spacing: 0.08em;
  line-height: 1.5;
  position: relative;
  text-align: center;
}

.page_contact .progressbar .item+.item::before {
  background: #E6E6E6;
  content: "";
  height: 1px;
  left: -5em;
  position: absolute;
  top: 64%;
  width: 50px;
}

.page_contact .progressbar .item .mark {
  aspect-ratio: 1;
  background: #fff;
  border: 1px solid #AFAFAF;
  border-radius: 50%;
  display: block;
  margin: 0 auto 0.5em;
  position: relative;
  width: 36px;
}

.page_contact .progressbar .item .mark::before {
  aspect-ratio: 1;
  background: #5A5A5A;
  border-radius: 50%;
  content: "";
  left: 50%;
  opacity: 0;
  position: absolute;
  top: 50%;
  translate: -50% -50%;
  width: 41%;
}

.page_contact .progressbar .item.active .mark::before {
  opacity: 1;
}

.page_contact .progressbar .item .en {
  color: #A7A7A7;
  display: block;
  font-family: "Helvetica", "Arial", sans-serif;
  letter-spacing: 0;
}

.privacy_check_list {
  align-items: center;
  justify-content: center;
  margin-bottom: 25px;
}

.privacy_check_list .hissu {
  background: #c70200;
  border-radius: 30px;
  color: #fff;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.08em;
  padding: 2px 15px;
}

.mw_wp_form .privacy_check_list .horizontal-item {
  margin: 0;
}

/* PC固定ページ 404ページ */
#page_404 {
  text-align: center;
}

#page_404 .num {
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-family: "Montserrat", "Noto Sans JP", sans-serif;
  font-size: 100px;
}

#page_404 .text {
  font-size: 16px;
  margin-bottom: 1em;
}

.l-content {
  padding-top: 130px;
}

/* PC固定ページ アーカイブページ */
/* 投稿リスト表示 */
.archive_page_list>article {
  border-bottom: 1px dashed #eee;
  padding-bottom: 15px;
  padding-right: 30px;
  padding-top: 15px;
}

.archive_page_list>article:after {
  border: solid #ccc;
  border-width: 2px 2px 0 0;
  bottom: 0;
  content: "";
  height: 10px;
  margin: auto;
  position: absolute;
  right: 5px;
  top: 0;
  transform: rotate(45deg);
  width: 10px;
}

.archive_page_list>article .date {
  font-size: 80%;
  font-weight: bold;
  width: 100px;
}

.archive_page_list>article .content_area {
  width: calc(100% - 100px);
}

.archive_page_list>article .content_area .ttl {
  -webkit-box-orient: vertical;
  display: -webkit-box;
  font-weight: bold;
  overflow: hidden;
}

.archive_page_list>article .content_area .content {
  -webkit-box-orient: vertical;
  display: -webkit-box;
  font-size: 80%;
  overflow: hidden;
}

/* wp-pagenavi base */
.wp-pagenavi {
  margin-top: 50px;
  text-align: center;
}

.wp-pagenavi a,
.wp-pagenavi span {
  background-color: #C9A98F;
  border: solid 1px #C9A98F;
  border-radius: 3px;
  color: #999;
  display: inline-block;
  margin: 0 2px;
  padding: 8px 15px;
  text-align: center;
  text-decoration: none;
  transition: 0.2s ease-in-out;
}

.wp-pagenavi a:hover {
  background: #E6830A;
  border-color: #E6830A;
  color: #FFF;
}

.wp-pagenavi .current {
  background: #E6830A;
  border-color: #E6830A;
  color: #FFF;
  font-weight: bold;
}

a {
  color: inherit;
}

/* pcの電話番号発信対応 */
a[href^="tel:"] {
  pointer-events: none;
}

.sp {
  display: none;
}

.m_inline_pc {
  margin-inline: 0.48em 0.04em;
}

.m_inline {
  margin-inline: 0.48em 0.04em;
}

.m_inline_02 {
  margin-inline: 0.04em 0.48em;
}

.common_btn01 {
  background: #0B3D5C;
  border-radius: 30px;
  display: inline-block;
  padding: 22px 30px;
  position: relative;
  transition: 0.3s ease;
  width: min(100%, 220px);
}

.common_btn01_text {
  color: #FFFFFF;
  display: block;
  font-size: 16px;
  font-weight: 700;
  line-height: 1;
}

.common_btn01_icon {
  aspect-ratio: 1;
  background: #FFFFFF;
  border-radius: 100vh;
  display: grid;
  place-items: center;
  position: absolute;
  right: 30px;
  top: 50%;
  transform: translateY(-50%);
  transition: 0.3s ease;
  width: 24px;
}

.common_btn01_icon svg {
  aspect-ratio: 1/1;
  transform: translateX(-10%);
  transition: 0.3s ease;
  width: 10px;
}

.common_btn02 {
  display: block;
  width: min(100%, 360px);
}

.common_btn02__decotext {
  display: block;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.15em;
  line-height: 1.5;
  margin-inline: auto;
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
}

.common_btn02__decotext::before,
.common_btn02__decotext::after {
  aspect-ratio: 2/23;
  background: #333333;
  content: "";
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 2px;
}

.common_btn02__decotext::before {
  left: -13.5px;
  rotate: -27deg;
}

.common_btn02__decotext::after {
  right: -13.5px;
  rotate: 27deg;
}

.common_btn02__link {
  background: #0B3D5C;
  border-radius: 35px;
  display: block;
  margin-top: 10px;
  padding: 26px;
  position: relative;
  text-align: center;
  transition: 0.3s ease;
  width: min(100%, 360px);
}

.common_btn02__icon01 {
  aspect-ratio: 1/1;
  background: #FFFFFF;
  border: 3px solid #0B3D5C;
  border-radius: 100vh;
  display: grid;
  left: 0;
  place-items: center;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  transition: 0.3s ease;
  width: 80px;
}

.common_btn02__icon01_text01 {
  color: #151515;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.42;
}

.common_btn02__icon01__text_headlight {
  color: #EA8B18;
  display: inline-block;
  font-family: "Roboto", sans-serif;
  font-size: 32px;
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1;
  margin-top: -3px;
}

.common_btn02__icon01__text_headlight02 {
  font-size: 13px;
}

.common_btn02__text {
  color: #FFFFFF;
  display: block;
  font-size: 18px;
  font-weight: 700;
  line-height: 1;
  padding-left: 5px;
}

.common_btn02__icon02 {
  aspect-ratio: 1/1;
  background: #FFFFFF;
  border-radius: 100vh;
  display: inline-block;
  display: grid;
  place-items: center;
  position: absolute;
  right: 30px;
  top: 50%;
  transform: translateY(-50%);
  transition: 0.3s ease;
  width: 24px;
}

.common_btn02__icon02 svg {
  aspect-ratio: 1/1;
  height: auto;
  transform: translateX(-10%);
  width: 10px;
}

.common_btn02__icon02 svg path {
  transition: 0.3s ease;
}

.common_btn03 {
  background: #151515;
  border-radius: 35px;
  display: inline-block;
  padding: 27px 30px;
  position: relative;
  transition: 0.3s ease;
  width: min(100%, 420px);
}

.common_btn03_text {
  color: #FFFFFF;
  display: block;
  font-size: 16px;
  font-weight: 700;
  line-height: 1;
}

.common_btn03_icon {
  aspect-ratio: 1;
  background: #FFFFFF;
  border-radius: 100vh;
  display: grid;
  place-items: center;
  position: absolute;
  right: 30px;
  top: 50%;
  transform: translateY(-50%);
  transition: 0.3s ease;
  width: 24px;
}

.common_btn03_icon svg {
  aspect-ratio: 1/1;
  height: auto;
  transform: translateX(-10%);
  transition: 0.3s ease;
  width: 10px;
}

.common_btn04 {
  display: block;
  width: min(100%, 420px);
}

.common_btn04__decotext {
  color: #FFFFFF;
  display: block;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.4;
  margin-inline: auto;
  padding-bottom: 2px;
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
}

.common_btn04__decotext::before,
.common_btn04__decotext::after {
  aspect-ratio: 2/25;
  background: #FFFFFF;
  border-radius: 100vh;
  bottom: 0px;
  content: "";
  content: "";
  position: absolute;
  width: 2px;
}

.common_btn04__decotext::before {
  left: -14.5px;
  rotate: -27deg;
}

.common_btn04__decotext::after {
  right: -14.5px;
  rotate: 27deg;
}

.common_btn04__link {
  background: #EB8800;
  border: 2px solid #EB8800;
  border-radius: 35px;
  display: block;
  margin-top: 10px;
  padding: 24px;
  position: relative;
  text-align: center;
  transition: 0.3s ease;
  width: 100%;
}

.common_btn04__icon01 {
  aspect-ratio: 1/1;
  background: #FFFFFF;
  border: 3px solid #EB8800;
  border-radius: 100vh;
  display: grid;
  left: -2px;
  place-items: center;
  position: absolute;
  text-align: center;
  top: 50%;
  transform: translateY(-50%);
  transition: 0.3s ease;
  width: 80px;
}

.common_btn04__icon01_text01 {
  color: #151515;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.42;
}

.common_btn04__icon01__text_headlight {
  color: #FF7F00;
  display: inline-block;
  font-family: "Roboto", sans-serif;
  font-size: 32px;
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1;
}

.common_btn04__icon01__text_headlight02 {
  font-size: 13px;
}

.common_btn04__text {
  color: #FFFFFF;
  display: block;
  font-size: 18px;
  font-weight: 700;
  line-height: 1;
  transition: 0.3s ease;
}

.common_btn04__icon02 {
  aspect-ratio: 1/1;
  background: #FFFFFF;
  border-radius: 100vh;
  display: inline-block;
  display: grid;
  place-items: center;
  position: absolute;
  right: 30px;
  top: 50%;
  transform: translateY(-50%);
  transition: 0.3s ease;
  width: 24px;
}

.common_btn04__icon02 svg {
  aspect-ratio: 1/1;
  height: auto;
  transform: translateX(-10%);
  width: 10px;
}

.common_btn04__icon02 svg path {
  transition: 0.3s ease;
}

.common_btn05 {
  background: #151515;
  border-radius: 35px;
  display: inline-block;
  padding: 27px 30px;
  position: relative;
  transition: 0.3s ease;
  width: min(100%, 340px);
}

.common_btn05_text {
  color: #FFFFFF;
  display: block;
  font-size: 16px;
  font-weight: 700;
  line-height: 1;
}

.common_btn05_icon {
  aspect-ratio: 1;
  background: #FFFFFF;
  border-radius: 100vh;
  display: grid;
  place-items: center;
  position: absolute;
  right: 30px;
  top: 50%;
  transform: translateY(-50%);
  transition: 0.3s ease;
  width: 24px;
}

.common_btn05_icon svg {
  aspect-ratio: 1/1;
  height: auto;
  transform: translateX(-10%);
  transition: 0.3s ease;
  width: 10px;
}

.common_btn06 {
  align-items: center;
  background: #FFFFFF;
  border-radius: 5px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.16);
  display: inline-block;
  display: flex;
  gap: 20px;
  height: 80px;
  padding: 28px 10px;
  position: relative;
  transition: 0.3s ease;
}

.common_btn06_small {
  padding-block: 21px;
}

.common_btn06_num {
  color: #E6830A;
  font-family: "Roboto", sans-serif;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0em;
  line-height: 1.33;
}

.common_btn06_text {
  font-size: 15px;
  font-weight: 700;
  line-height: 1.07;
}

.common_btn06_text_small {
  font-size: 13px;
  line-height: 1.23;
}

.common_btn06_icon {
  aspect-ratio: 16/10;
  display: grid;
  height: auto;
  place-items: center;
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
}

.common_btn06_icon img {
  -o-object-fit: contain;
  aspect-ratio: 16/10;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.common_headline01 {
  text-align: center;
}

.common_headline01_sub {
  color: #F7A541;
  font-family: "Roboto", sans-serif;
  font-size: 18px;
  font-weight: 900;
  letter-spacing: 0em;
  line-height: 1.33;
}

.common_headline01_sub01 {
  padding-right: 15px;
}

.common_headline01_main {
  font-size: 40px;
  font-weight: 900;
  letter-spacing: 0.08em;
  line-height: 1.65;
  margin-top: 4px;
}

.common_headline01_main_en {
  font-family: "Roboto", sans-serif;
  font-size: 50px;
  font-weight: 900;
  letter-spacing: 0.04em;
  line-height: 1.18;
  margin-right: 5px;
}

.common_headline01_main_en01 {
  font-size: 56px;
  margin-right: 3px;
}

.common_headline02_sub {
  color: #F7A541;
  font-family: "Roboto", sans-serif;
  font-size: 30px;
  font-weight: 900;
  letter-spacing: 0em;
  line-height: 1.3;
}

.common_headline02_sub::first-letter {
  text-transform: uppercase;
}

.common_headline02_main {
  font-size: 45px;
  font-weight: 900;
  letter-spacing: 0.08em;
  line-height: 1.44;
  margin-top: 3px;
}

.common_card01 {
  background: #FFFFFF;
  border-radius: 20px;
  height: 100%;
  padding: 144px 30px 35px;
  position: relative;
}

.common_card01_img {
  display: block;
  left: 50%;
  margin-inline: auto;
  position: absolute;
  top: -37px;
  transform: translateX(-50%);
  width: min(100%, 192px);
}

.common_card01_img img {
  -o-object-fit: contain;
  aspect-ratio: 192/180;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.common_card01_titlewrap {
  display: grid;
  min-height: 58px;
  place-items: center;
}

.common_card01_title {
  font-size: 20px;
  font-weight: 900;
  letter-spacing: 0.1em;
  line-height: 1.45;
  text-align: center;
}

.common_card01_title_highlight {
  color: #E6830A;
}

.common_card01_txt {
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.09em;
  line-height: 1.71;
  margin-top: 10px;
}

.common_card02_link {
  display: block;
}

.common_card02_img {
  aspect-ratio: 360/210;
  background: #F7A541;
  border-radius: 20px;
  display: block;
  overflow: hidden;
  position: relative;
  transition: 0.3s ease;
}

.common_card02_img img {
  -o-object-fit: cover;
  aspect-ratio: 360/210;
  border-radius: 20px;
  height: auto;
  left: 50%;
  object-fit: cover;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  transition: 0.3s ease;
  width: 100%;
}

.common_card02_body {
  margin-top: 20px;
}

.common_card02_title {
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  display: -webkit-box;
  min-height: 54.45px;
  overflow: hidden;
}

.common_card02_title_text {
  background-image: linear-gradient(90deg, #333333, #333333);
  background-position: left bottom;
  background-repeat: no-repeat;
  background-size: 0 1px;
  display: inline;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.44;
  text-decoration: none;
  transition: background-size 0.5s;
}

.c-hoverRun:hover {
  background-size: 100% 1px;
}

.common_card02_txt {
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  color: #535353;
  display: -webkit-box;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 1.57;
  margin-top: 18px;
  min-height: 65.9px;
  overflow: hidden;
}

.common_card02_meta {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin-top: 17px;
  padding-top: 14px;
  position: relative;
}

.common_card02_meta::before {
  background-image: linear-gradient(90deg, #707070, #707070 6px, transparent 6px, transparent 8px);
  background-repeat: repeat-x;
  background-size: 8px 4px;
  content: "";
  height: 2px;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}

.common_card02_company {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.71;
}

.common_card02_icon {
  aspect-ratio: 1/1;
  background: #E29F14;
  border: 1px solid #E29F14;
  border-radius: 100vh;
  display: grid;
  place-items: center;
  transition: 0.3s ease;
  width: 40px;
}

.common_card02_icon svg {
  aspect-ratio: 12/11.31;
  height: auto;
  width: 14px;
}

.common_card02_icon svg line,
.common_card02_icon svg path {
  transition: 0.3s ease;
}

.common_cards01 {
  display: grid;
  gap: 20px;
  grid-template-columns: repeat(4, 1fr);
}

.common_cta01 {
  position: relative;
  z-index: 1;
}

.common_cta01::before {
  content: "";
  height: 100%;
  left: 0;
  mix-blend-mode: overlay;
  position: absolute;
  top: 0;
  width: 100%;
}

.common_cta01_deco01 {
  bottom: -79px;
  left: -79px;
  position: absolute;
  width: min(100%, 290px);
  z-index: -1;
}

.common_cta01_deco01 img {
  -o-object-fit: contain;
  aspect-ratio: 1/1;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.common_cta01_deco02 {
  bottom: -126px;
  left: 35px;
  position: absolute;
  width: min(100%, 211px);
  z-index: -1;
}

.common_cta01_deco02 img {
  -o-object-fit: contain;
  aspect-ratio: 1/1;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.common_cta01_deco03 {
  position: absolute;
  right: -15px;
  top: -78px;
  width: min(100%, 242px);
  z-index: -1;
}

.common_cta01_deco03 img {
  -o-object-fit: contain;
  aspect-ratio: 1/1;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.common_cta01_circle01 {
  aspect-ratio: 1/1;
  background: #144564;
  border-radius: 100vh;
  position: absolute;
  right: 26px;
  top: 122px;
  width: min(100%, 103px);
  z-index: -1;
}

.common_cta01_circle02 {
  aspect-ratio: 1/1;
  background: #144564;
  border-radius: 100vh;
  position: absolute;
  right: 249px;
  top: 33px;
  width: min(100%, 33px);
  z-index: -1;
}

.common_cta01_img {
  bottom: -8px;
  position: absolute;
  right: 25.5px;
  width: min(100%, 294.92px);
  z-index: 2;
}

.common_cta01_img img {
  -o-object-fit: contain;
  aspect-ratio: 294.92/205;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.common_cta01_container {
  background: #0B3D5C;
  border-radius: 20px;
  overflow: hidden;
  padding-block: 46px 47px;
  position: relative;
  z-index: 1;
}

.common_cta01_headline {
  text-align: center;
}

.common_cta01_headline_sub {
  color: #FFFFFF;
  font-size: 22px;
  font-weight: 700;
  line-height: 1.45;
}

.common_cta01_headline_main {
  color: #FFFFFF;
  font-size: 38px;
  font-weight: 900;
  letter-spacing: 0.1em;
  line-height: 1.45;
  margin-top: 6px;
}

.common_cta01_headline_main_highlight {
  color: #FFED17;
  margin-inline: -11px;
}

.common_cta01_text {
  color: #FFFFFF;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.67;
  margin-top: 24px;
  text-align: center;
}

.common_cta01_btn {
  display: flex;
  justify-content: center;
  margin-top: 38px;
}

.common_follow_sp {
  display: none;
}

.common_follow_sp.is_visible {
  opacity: 1;
  visibility: visible;
}

.common_item01 {
  border-radius: 20px;
  display: flex;
  overflow: hidden;
}

.common_item01_step {
  align-items: center;
  background: #517084;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 20px;
}

.common_item01_step_label {
  color: #FFFFFF;
  font-family: "Roboto", sans-serif;
  font-size: 14px;
  font-weight: 900;
  letter-spacing: 0em;
  line-height: 1;
}

.common_item01_step_num {
  color: #FFFFFF;
  font-family: "Roboto", sans-serif;
  font-size: 26px;
  font-weight: 900;
  letter-spacing: 0em;
  line-height: 1;
}

.common_item01_content {
  align-items: center;
  background: #FFFFFF;
  display: flex;
  flex: 1;
  gap: 43px;
  padding: 10px 50px 10px 47px;
}

.common_item01_content02 {
  padding-block: 19.5px 23.5px;
}

.common_item01_img {
  flex-shrink: 0;
  width: min(100%, 153.07px);
}

.common_item01_img img {
  -o-object-fit: contain;
  aspect-ratio: 153.07/139.8;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.common_item01_body {
  flex: 1;
  margin-bottom: 10px;
}

.common_item01_body01 {
  margin-bottom: 0;
  margin-top: 6px;
}

.common_item01_head {
  font-size: 24px;
  font-weight: 900;
  letter-spacing: 0.08em;
  line-height: 1.46;
}

.common_item01_dots {
  display: grid;
  margin-top: 8px;
  width: min(100%, 38px);
}

.common_item01_dots img {
  -o-object-fit: contain;
  aspect-ratio: 38/6;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.common_item01_txt {
  color: #535353;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1.5;
  margin-top: 20px;
}

.common_item02 {
  border-radius: 10px;
  padding: 20px 30px 30px 30px;
}

.common_item02.is_open .common_item02_answer {
  height: auto;
}

.common_item02_question {
  align-items: center;
  background: transparent;
  border: none;
  cursor: pointer;
  display: flex;
  gap: 30px;
  padding: 0;
  padding-right: 10px;
  width: 100%;
}

.common_item02_question_icon {
  aspect-ratio: 1/1;
  background: #E6830A;
  border-radius: 100vh;
  color: #FFFFFF;
  display: grid;
  flex-shrink: 0;
  font-family: "ヒラギノ角ゴ ProN", serif;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0em;
  line-height: 1;
  place-items: center;
  width: 40px;
}

.common_item02_question_text {
  flex: 1;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.44;
}

.common_item02_question_toggle {
  aspect-ratio: 1/1;
  background: #FFFFFF;
  border-radius: 50%;
  display: grid;
  flex-shrink: 0;
  place-items: center;
  position: relative;
  width: 36px;
}

.common_item02_question_toggle_plus {
  aspect-ratio: 1/1;
  height: auto;
  position: absolute;
  width: 14.76px;
}

.common_item02_question_toggle_plus::before,
.common_item02_question_toggle_plus::after {
  background: #3E3E3E;
  content: "";
  position: absolute;
  transition: transform 0.5s ease;
}

.common_item02_question_toggle_plus::before {
  height: 100%;
  left: 50%;
  top: 0;
  transform: translateX(-50%) rotate(0deg) scaleY(1);
  transform-origin: center;
  width: 2px;
}

.common_item02_question_toggle_plus::after {
  height: 2px;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 100%;
}

.common_item02.is_open .common_item02_question_toggle_plus::before {
  transform: translateX(-50%) rotate(90deg) scaleY(0);
}

.common_item02_answer {
  align-items: center;
  display: flex;
  gap: 30px;
  margin-top: 20px;
  padding-top: 20px;
  position: relative;
}

.common_item02_answer::before {
  background-image: radial-gradient(circle, #3E3E3E 0.5px, transparent 0.5px);
  background-repeat: repeat-x;
  background-size: 5px 1px;
  content: "";
  height: 1px;
  left: 0;
  position: absolute;
  top: 0;
  transition: 0.3s ease;
  width: 100%;
}

.common_item02_answer_icon {
  aspect-ratio: 1/1;
  background: #FFFFFF;
  border: 1px solid #E6830A;
  border-radius: 100vh;
  color: #E6830A;
  display: grid;
  flex-shrink: 0;
  font-family: "ヒラギノ角ゴ ProN", serif;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0em;
  line-height: 1;
  place-items: center;
  width: 40px;
}

.common_item02_answer_text {
  flex: 1;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 1.43;
}

.common_item03 {
  background: #FFFFFF;
  border-radius: 20px;
  padding: 33px 50px 53px;
  position: relative;
  z-index: 1;
}

.common_item03_title {
  font-size: 30px;
  font-weight: 900;
  left: 57px;
  letter-spacing: 0.08em;
  letter-spacing: 0.1em;
  line-height: 1.47;
  position: absolute;
  top: -23px;
  width: -moz-fit-content;
  width: fit-content;
  z-index: 1;
}

.common_item03_title::before,
.common_item03_title::after {
  aspect-ratio: 32/22.82;
  content: "";
  position: absolute;
  width: 32px;
  z-index: -1;
}

.common_item03_title::before {
  background: url(./image/icon_dot01.png) center center/contain no-repeat;
  left: -23px;
  top: -8px;
}

.common_item03_title::after {
  background: url(./image/icon_dot02.png) center center/contain no-repeat;
  bottom: -8px;
  right: -23px;
}

.common_item03_title_reverse {
  left: unset;
  right: 72px;
}

.common_item03_title_highlight {
  color: #E6830A;
}

.common_item03_title_small {
  color: #333333;
  font-size: 20px;
  font-weight: 900;
}

.common_item03_problem {
  align-items: center;
  display: flex;
  gap: 45.5px;
  margin-left: -17px;
}

.common_item03_problem_img {
  flex-shrink: 0;
  width: min(100%, 188px);
}

.common_item03_problem_img img {
  -o-object-fit: contain;
  aspect-ratio: 180/180;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.common_item03_problem_bubble {
  background: #F4F4F4;
  border-radius: 20px;
  flex: 1;
  padding: 27px 41px;
  position: relative;
}

.common_item03_problem_bubble::before {
  background: #F4F4F4;
  clip-path: polygon(100% 0, 0 50%, 100% 100%);
  content: "";
  display: inline-block;
  height: 30px;
  left: -20px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 30px;
}

.common_item03_problem_bubble_label {
  background: #F2F9FA;
  border: 2px solid #333333;
  border-radius: 17px;
  display: inline-block;
  font-size: 18px;
  font-weight: 900;
  left: 42px;
  letter-spacing: 0.1em;
  line-height: 1;
  padding: 4px 18px;
  position: relative;
  position: absolute;
  top: -16px;
}

.common_item03_problem_bubble_text {
  font-size: 18px;
  font-weight: 900;
  letter-spacing: 0.1em;
  line-height: 1.44;
}

.common_item03_arrow02 {
  display: none;
}

.common_item03_arrow02 img {
  -o-object-fit: contain;
  aspect-ratio: 110/32;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.common_item03_solution {
  align-items: flex-start;
  display: flex;
  justify-content: space-between;
  margin-right: -24.5px;
  margin-top: 29px;
}

.common_item03_solution_title {
  background: #FFED8E;
  border: 2px solid #333333;
  border-radius: 17px;
  display: inline-block;
  font-size: 18px;
  font-weight: 900;
  left: 30px;
  letter-spacing: 0.1em;
  line-height: 1;
  padding: 4px 18px;
  position: absolute;
  top: -15px;
}

.common_item03_solution_title::before {
  background: url(./image/feature01_sp01.png) center center/contain no-repeat;
  bottom: 0;
  content: "";
  display: none;
  height: 17.44vw;
  left: 2.05vw;
  position: absolute;
  width: 16.67vw;
}

.common_item03_solution_tags {
  align-items: center;
  display: flex;
  gap: 17px;
}

.common_item03_solution_tag_label {
  font-size: 18px;
  font-weight: 900;
  letter-spacing: 0.1em;
  line-height: 1.44;
  padding-right: 10.5px;
  position: relative;
}

.common_item03_solution_tag_label::after {
  background: #D0CBBE;
  content: "";
  height: 100%;
  position: absolute;
  right: 0;
  top: 0;
  width: 2px;
}

.common_item03_solution_tagwrap {
  align-items: center;
  display: flex;
  gap: 10px;
}

.common_item03_solution_tag {
  background: #333333;
  border-radius: 4px;
  color: #FFFFFF;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1;
  padding: 4.5px 10px;
}

.common_item03_solution_content {
  background: #FFF9EB;
  border-radius: 20px;
  padding: 37px 30px 28px;
  position: relative;
  width: min(100%, 820px);
}

.common_item03_solution_content::after {
  aspect-ratio: 32.18/30;
  background: #FFF9EB;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
  content: "";
  display: inline-block;
  position: absolute;
  right: -28px;
  top: 65.4px;
  width: 32.18px;
}

.common_item03_solution_text {
  font-size: 15px;
  font-weight: 600;
  letter-spacing: 0.1em;
  line-height: 1.6;
  margin-top: 19px;
}

.common_item03_solution_text+.common_item03_solution_text {
  margin-top: 20px;
}

.common_item03_solution_img {
  flex-shrink: 0;
  margin-top: -7px;
  width: min(100%, 188px);
}

.common_item03_solution_img img {
  -o-object-fit: contain;
  aspect-ratio: 180/180;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.common_item03_arrow {
  display: block;
  margin-inline: auto;
  margin-top: 17px;
  width: min(100%, 280px);
}

.common_item03_arrow img {
  -o-object-fit: contain;
  aspect-ratio: 280/50;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.common_item03_benefit {
  background: #FFFFFF;
  border: 2px solid #E6830A;
  border-radius: 20px;
  margin-top: 37px;
  padding: 26px 20px 22px;
  position: relative;
}

.common_item03_benefit_title {
  background: #E6830A;
  border-radius: 20px;
  color: #FFFFFF;
  font-size: 18px;
  font-weight: 900;
  left: 50%;
  letter-spacing: 0.1em;
  line-height: 1;
  padding: 11px 21.5px;
  position: absolute;
  top: -23px;
  transform: translateX(-50%);
  width: -moz-fit-content;
  width: fit-content;
}

.common_item03_benefit_text {
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-align: center;
}

.common_item03_benefit_text_highlight {
  background-image: radial-gradient(circle, #E6830A 2px, transparent 2px);
  background-position: left bottom;
  background-repeat: repeat-x;
  background-size: 8px 4px;
  color: #E6830A;
  display: inline;
  font-size: 22px;
  font-weight: 900;
  letter-spacing: 0.1em;
  line-height: 1.64;
  padding-bottom: 4px;
  position: relative;
}

.common_item03_benefit_img {
  bottom: -11px;
  display: block;
  position: absolute;
  right: -41px;
  width: min(100%, 147.68px);
}

.common_item03_benefit_img img {
  -o-object-fit: contain;
  aspect-ratio: 147.68/125.64;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.common_item04 {
  background: #EFF4F7;
  border-radius: 10px;
  padding: 24px 69px 20px 68px;
  position: relative;
}

.common_item04_pb {
  padding-bottom: 15px;
}

.common_item04_title {
  background: #22314B;
  border-radius: 20px;
  color: #FFFFFF;
  display: inline-block;
  font-size: 16px;
  font-weight: 900;
  left: 0;
  letter-spacing: 0.08em;
  line-height: 1;
  padding: 6px 20px 8px;
  position: absolute;
  top: -10px;
}

.common_item04_wrap {
  align-items: center;
  display: flex;
}

.common_item04_block {
  position: relative;
  text-align: center;
}

.common_item04_block01::after {
  background: url(./image/icon_mutiple.png) center center/contain no-repeat;
  bottom: 5px;
  content: "";
  display: inline-block;
  height: 32px;
  position: absolute;
  right: -30px;
  width: 33px;
}

.common_item04_tag {
  background: #0B3D5C;
  border-radius: 10px;
  color: #FFFFFF;
  display: inline-block;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1;
  padding: 2.5px 10px 3.5px;
  width: min(100%, 130px);
}

.common_item04_tag_light {
  background: #517084;
  border-radius: 10px;
  color: #FFFFFF;
  display: inline-block;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1;
  padding: 3px 10px 4px;
}

.common_item04_text {
  color: #0B3D5C;
  font-family: "Roboto", sans-serif;
  font-size: 35px;
  font-weight: 700;
  line-height: 1.31;
  margin-top: 4px;
  text-align: center;
}

.common_item04_text01 {
  position: relative;
}

.common_item04_text01::before,
.common_item04_text01::after {
  background: #B24141;
  content: "";
  height: 2px;
  left: 50%;
  position: absolute;
  position: absolute;
  top: 50%;
  transform-origin: center center;
  width: 142px;
}

.common_item04_text01::before {
  transform: translate(-50%, -50%) rotate(16deg);
}

.common_item04_text01::after {
  transform: translate(-50%, -50%) rotate(-16deg);
}

.common_item04_text_small {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 20px;
}

.common_item04_block02 {
  margin-left: 32px;
}

.common_item04_block02::after {
  background: url(./image/icon_icol.png) center center/contain no-repeat;
  bottom: 5px;
  content: "";
  display: inline-block;
  height: 29px;
  position: absolute;
  right: -36px;
  width: 29px;
}

.common_item04_block03 {
  margin-left: 46px;
}

.common_item04_content_sp {
  display: none;
}

.common_item04_arrow {
  margin-left: auto;
  margin-right: 25.5px;
  margin-top: -8px;
  width: min(100%, 79px);
}

.common_item04_arrow img {
  -o-object-fit: contain;
  aspect-ratio: 79/14.3;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.common_item04_caution {
  font-size: 15px;
  font-weight: 700;
  line-height: 1.4;
  position: relative;
  text-align: right;
  z-index: 1;
}

.common_item04_caution_line {
  position: relative;
}

.common_item04_caution_line::before {
  background: #FFED8E;
  bottom: -5px;
  content: "";
  height: 14px;
  position: absolute;
  right: 0;
  width: calc(100% + 10px);
  z-index: -1;
}

.common_item04_caution_highlight {
  color: #E6830A;
  font-family: "Roboto", sans-serif;
  font-size: 35px;
  font-weight: 700;
  letter-spacing: 0em;
  line-height: 1.31;
  margin-left: 4px;
}

.common_item04_caution_unit {
  color: #333333;
  font-size: 20px;
}

.common_items01 {
  display: grid;
  gap: 20px;
  grid-template-columns: repeat(1, 1fr);
}

.common_items01_item {
  position: relative;
}

.common_items01_item::before {
  background: #333333;
  content: "";
  height: 20px;
  left: 35px;
  position: absolute;
  top: 100%;
  width: 2px;
}

.common_items01_item:last-of-type::before {
  display: none;
}

.common_items02 {
  display: grid;
  gap: 20px;
  grid-template-columns: repeat(1, 1fr);
}

.common_items02_item:nth-of-type(odd) .common_item02 {
  background: #F0EFED;
}

.common_items02_item:nth-of-type(even) .common_item02 {
  background: #F5F2EA;
}

.common_items03 {
  display: grid;
  gap: 109px;
  grid-template-columns: repeat(1, 1fr);
}

.common_items03_item {
  position: relative;
  width: 100%;
}

.common_items03_item::after {
  background: #C7C3B6;
  bottom: -15.38vw;
  content: "";
  display: none;
  height: 2px;
  left: 0;
  position: absolute;
  width: 100%;
}

.common_lower_mv {
  background: #F7F6F4;
  padding-block: 199.3px 0;
  position: relative;
}

.common_lower_mv::before {
  background: url(./image/lower_mv_bg01.png) center center/100% 100% no-repeat;
  content: "";
  height: 302.3px;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 1;
}

.common_lower_mv_container {
  position: relative;
  z-index: 1;
}

.common_lower_mv_breadcrumb {
  margin-top: 45px;
  text-align: right;
}

.common_lower_mv_breadcrumb a {
  color: #777777;
  transition: 0.3s ease;
}

.common_lower_mv_breadcrumb span {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1.43;
}

.breadcrumb_separator {
  color: #777777;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1.43;
}

.common_media01 {
  align-items: center;
  background: #FFFFFF;
  border-radius: 10px;
  box-shadow: 0 0 4px rgba(0, 0, 0, 0.16);
  display: flex;
  gap: 12.5px;
  padding: 16px 20px 14px 10px;
}

.common_media01_img {
  width: min(100%, 97.5px);
}

.common_media01_img img {
  -o-object-fit: contain;
  aspect-ratio: 97.5/90;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.common_media01_body {
  flex: 1;
}

.common_media01_txt {
  font-size: 15px;
  font-weight: 700;
  line-height: 1.73;
}

.common_media02 {
  align-items: flex-start;
  display: flex;
  justify-content: space-between;
  position: relative;
  z-index: 1;
}

.common_media02_body01 {
  width: min(100%, 620px);
}

.common_media02_body02 {
  width: min(100%, 440px);
}

.common_media02_body03 {
  width: min(100%, 735px);
}

.common_media02_tag {
  align-items: flex-end;
  background: #E6830A;
  border-radius: 18px 18px 0 18px;
  display: flex;
  font-family: "Roboto", sans-serif;
  gap: 3px;
  padding: 7px 18px;
  width: -moz-fit-content;
  width: fit-content;
}

.common_media02_tag_small {
  color: #FFFFFF;
  font-family: "Roboto", sans-serif;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0em;
  line-height: 1.3;
}

.common_media02_tag_big {
  color: #FFFFFF;
  font-size: 26px;
  font-weight: 700;
  letter-spacing: 0em;
  line-height: 1;
}

.common_media02_head {
  font-size: 34px;
  font-weight: 900;
  letter-spacing: 0.08em;
  line-height: 1.41;
  margin-top: 14px;
}

.common_media02_head_highlight {
  color: #E6830A;
}

.common_media02_txtwrap01 {
  margin-top: 30px;
}

.common_media02_txtwrap02 {
  margin-right: 50px;
  width: min(100%, 600px);
}

.common_media02_txtwrap03 {
  margin-top: 30px;
}

.common_media02_txt {
  color: #555555;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1.73;
}

.common_media02_txt+.common_media02_txt {
  margin-top: 25px;
}

.common_media02_img01 {
  flex-shrink: 0;
  margin-right: 12.4px;
  margin-top: 169px;
  position: relative;
  width: min(100%, 414.56px);
}

.common_media02_img01::before {
  aspect-ratio: 1/1;
  background: #FFFFFF;
  border-radius: 100vh;
  bottom: -110px;
  content: "";
  display: inline-block;
  filter: blur(4px);
  left: -13px;
  position: absolute;
  position: absolute;
  width: 440px;
  z-index: -1;
}

.common_media02_img01 img {
  -o-object-fit: contain;
  aspect-ratio: 414.56/235.03;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.common_media02_img02 {
  margin-left: 37px;
  margin-top: 59px;
  position: relative;
  width: min(100%, 365px);
}

.common_media02_img02::before {
  aspect-ratio: 1/1;
  background: #FFFFFF;
  border-radius: 100vh;
  bottom: -73.8px;
  content: "";
  display: inline-block;
  filter: blur(4px);
  left: -40px;
  position: absolute;
  position: absolute;
  width: 440px;
  z-index: -1;
}

.common_media02_img02 img {
  -o-object-fit: contain;
  aspect-ratio: 365/287.29;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.common_media02_img03 {
  margin-top: 125px;
  position: relative;
  width: min(100%, 381.58px);
}

.common_media02_img03::before {
  aspect-ratio: 1/1;
  background: #FFFFFF;
  border-radius: 100vh;
  bottom: -30px;
  content: "";
  display: inline-block;
  filter: blur(4px);
  left: 51px;
  position: absolute;
  position: absolute;
  width: 460px;
  z-index: -1;
}

.common_media02_img03 img {
  -o-object-fit: contain;
  aspect-ratio: 381.58/492.47;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.cta01 {
  position: relative;
  z-index: 1500;
}

.cta01::before {
  background: url(./image/top_cta_bg01.png) center center/100% 100% no-repeat;
  content: "";
  height: 753.99px;
  left: 0;
  position: absolute;
  top: -80px;
  width: 100%;
}

.features01 {
  background: #F7F6F4;
  padding-block: 42px 200px;
}

.features01_container {
  position: relative;
}

.features01_btnwrap {
  display: grid;
  gap: 20px;
  grid-template-columns: repeat(4, 1fr);
}

.features01_item {
  margin-top: 110px;
}

/* footer */
.footer {
  padding-block: 43px 70px;
  position: relative;
  z-index: 1500;
}

.footer::after {
  display: none;
}

.footer_container {
  position: relative;
}

.footer_illustration {
  bottom: 39px;
  position: absolute;
  right: 0;
  width: min(100%, 126.26px);
  z-index: 1;
}

.footer_illustration img {
  -o-object-fit: contain;
  aspect-ratio: 126.26/114.68;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.footer_title {
  align-items: center;
  display: flex;
  font-family: "Roboto", sans-serif;
  font-size: 30px;
  font-weight: 900;
  gap: 42px;
  letter-spacing: 0.04em;
  line-height: 1.3;
}

.footer_title::before,
.footer_title::after {
  background-image: linear-gradient(to right, #333 70%, transparent 30%);
  background-repeat: repeat-x;
  background-size: 12px 6px;
  content: "";
  flex: 1;
  height: 2px;
}

.footer_title::before {
  display: none;
}

.footer_list {
  display: flex;
  gap: 27px;
  justify-content: space-between;
  margin-top: 16px;
}

.footer_item:first-of-type .footer_link {
  padding-left: 0;
}

.footer_item:last-of-type .footer_link {
  padding-right: 0;
}

.footer_link {
  align-items: center;
  display: flex;
  font-size: 15px;
  font-weight: 700;
  gap: 10.5px;
  letter-spacing: 0.04em;
  line-height: 1.4;
  padding: 10px 20px;
  transition: 0.3s ease;
  white-space: nowrap;
}

.footer_link::before {
  aspect-ratio: 6/14;
  background: url(./image/icon_arrow07.png) center center/contain no-repeat;
  content: "";
  height: auto;
  transition: 0.3s ease;
  width: 6px;
}

.footer_link::after {
  display: none;
}

.footer_link01 {
  padding-right: 42px;
  position: relative;
}

.footer_link01::after {
  aspect-ratio: 1/1;
  background: url(./image/icon_box01.png) center center/contain no-repeat;
  content: "";
  display: inline-block;
  position: absolute;
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  transition: 0.3s ease;
  width: 16px;
}

.footer_wrap01 {
  align-items: flex-end;
  display: flex;
  justify-content: space-between;
  margin-top: 174px;
  margin-right: 100px;
}

.footer_info {
  width: -moz-fit-content;
  width: fit-content;
}

.footer_logo {
  display: block;
  transition: 0.3s ease;
  width: min(100%, 249.92px);
}

.footer_logo img {
  -o-object-fit: contain;
  aspect-ratio: 249.92/63;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.footer_company {
  font-size: 15px;
  font-weight: 500;
  line-height: 1.4;
  margin-top: 12px;
}

.footer_info .flex_box {
  display: flex;
}

.footer_address {
  font-size: 14px;
  font-weight: 500;
  line-height: 1.47;
  margin-top: 11px;
}

.footer_info .flex_box .footer_address:last-child {
  margin-left: 14px;
  padding-left: 14px;
  border-left: 1px solid #D5D5D5;
}

.footer_tel {
  font-size: 15px;
  font-weight: 500;
  line-height: 1.4;
  margin-top: 8px;
}

.footer_wrap02 {
  width: min(100%, 413px);
}

.footer_meta {
  align-items: flex-end;
  display: flex;
  gap: 46px;
}

.footer_badge {
  display: inline-block;
  width: min(100%, 110px);
}

.footer_badge img {
  -o-object-fit: contain;
  aspect-ratio: 110/40;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.footer_links {
  align-items: center;
  display: flex;
}

.footer_links_item {
  font-size: 13px;
  font-weight: 500;
  line-height: 1.46;
  position: relative;
  transition: 0.3s ease;
  white-space: nowrap;
}

.footer_links_item:first-of-type {
  padding-right: 22px;
}

.footer_links_item:first-of-type::after {
  background: #333333;
  content: "";
  height: 13px;
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 1px;
}

.footer_links_item:last-of-type {
  padding-left: 17px;
}

.footer_copyright {
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 1.42;
  margin-top: 14px;
  white-space: nowrap;
}

.footer_totop {
  align-items: center;
  background: #FFFFFF;
  border-radius: 100vh;
  bottom: 91px;
  box-shadow: 0 0 4px rgba(0, 0, 0, 0.16);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  height: 100px;
  padding: 0;
  padding-top: 35.2px;
  position: absolute;
  right: 110px;
  transition: 0.3s ease;
  width: 100px;
}

.footer_totop_icon {
  width: min(100%, 28.25px);
}

.footer_totop_icon img {
  -o-object-fit: contain;
  aspect-ratio: 1/1;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.footer_totop_text {
  font-size: 13px;
  font-weight: 700;
  line-height: 1.46;
  margin-top: -3px;
}

/* drawer */
nav.globalMenuSp {
  display: none;
}

/* このクラスを、jQueryで付与・削除する */

/* ハンバーガーメニュー */
.hamburger {
  display: none;
}

.hamburger.is_open .hamburger_line:nth-of-type(1) {
  top: 6.26vw;
  transform: translateX(-50%) rotate(315deg);
}

.hamburger.is_open .hamburger_line:nth-of-type(2) {
  opacity: 0;
}

.hamburger.is_open .hamburger_line:nth-of-type(3) {
  top: 6.26vw;
  transform: translateX(-50%) rotate(-315deg);
}

/* header */
.header {
  background: #FFFFFF;
  display: flex;
  justify-content: center;
  left: 0;
  margin-inline: auto;
  position: absolute;
  right: 0;
  top: 0;
  transition: 0.3s ease;
  width: 100%;
  z-index: 3500;
}

.header_fixed {
  left: 0;
  min-width: 1440px;
  position: fixed;
  right: 0;
  top: 0;
  width: 100%;
}

.header_visible {
  background: #FFFFFF;
  border-color: #333333;
  opacity: 1;
  pointer-events: auto;
  visibility: visible;
}

.header_hidden {
  transition: 0.3s;
  z-index: 5;
}

.header.is_open {
  z-index: 3500;
}

.header_inner {
  align-items: center;
  display: flex;
  justify-content: space-between;
  width: min(100%, 1240px);
}

.header_logo {
  width: min(100%, 174.55px);
}

.header_logo_link {
  display: inline-block;
  padding-block: 23px;
  transition: 0.3s ease;
}

.header_logo_link img {
  -o-object-fit: contain;
  aspect-ratio: 174.55/44;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.header_list {
  align-items: center;
  display: flex;
}

.header_link {
  display: inline-block;
  padding: 33px 25px;
  position: relative;
}

.header_link_text {
  display: block;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.5;
  position: relative;
  transition: 0.3s ease;
  white-space: nowrap;
}

.header_link_text::before {
  background: #E6830A;
  bottom: -8px;
  content: "";
  display: inline-block;
  height: 2px;
  left: 0;
  position: absolute;
  transform: scaleX(0);
  transform-origin: center;
  transition: transform 0.3s ease;
  width: 100%;
}

.header_item_contact {
  margin-left: 25px;
  width: 220px;
}

.page_contact {
  background: #F7F6F4;
}

.reason01 {
  background: #F7F6F4;
  padding-block: 111px 217px;
  position: relative;
}

.reason01::before {
  background: url(./image/reason_bg02.png) center center/100% 100% no-repeat;
  content: "";
  height: 2195px;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 0;
}

.reason01::after {
  background: url(./image/reason_bg01.png) center center/contain no-repeat;
  content: "";
  height: 2352.28px;
  left: 50%;
  position: absolute;
  top: -161.4px;
  transform: translateX(-50%);
  width: 1842.34px;
  z-index: 0;
}

.reason01_container {
  position: relative;
  z-index: 1;
}

.reason01_item02 {
  margin-top: 118px;
}

.reason01_item03 {
  margin-top: 104px;
}

#page_sitemap {
  background: #F7F6F4;
  padding-block: 80px 120px;
}

#page_sitemap #sitemap_list {
  background: #F7F6F4;
}

#page_sitemap #sitemap_list .home-item a {
  background: #F7F6F4;
}

#page_sitemap #sitemap_list li a {
  background: #fff;
}

/* top_about */
.top_about {
  background: #F7F6F4;
  padding-top: 270px;
}

.top_about_container {
  position: relative;
  z-index: 1;
}

.top_about_headline {
  text-align: center;
}

.top_about_text {
  font-size: 16px;
  font-weight: 600;
  line-height: 2;
  margin-top: 37px;
  position: relative;
  text-align: center;
  z-index: 1;
}

.top_about_text_highlight {
  -webkit-box-decoration-break: clone;
  background-image: linear-gradient(to bottom, transparent 55%, #FFED8E 55%, #FFED8E 100%);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  box-decoration-break: clone;
  display: inline;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.6;
}

.top_about_recommend {
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 0.15em;
  margin-inline: auto;
  margin-top: 38px;
  width: -moz-fit-content;
  width: fit-content;
}

.top_about_recommend_line {
  display: inline-block;
  position: relative;
}

.top_about_recommend_line::after {
  background-image: repeating-linear-gradient(90deg, #333333, #333333 6px, transparent 6px, transparent 8px);
  background-position: left bottom;
  background-repeat: repeat-x;
  background-size: 100% 3px;
  bottom: -3px;
  content: "";
  height: 3px;
  left: 0;
  position: absolute;
  width: 100%;
}

.top_about_recommend_highlight {
  color: #E6830A;
  font-size: 34px;
  font-weight: 900;
  line-height: 1.44;
}

.top_about_cards {
  margin-top: 67px;
}

.top_about_btn {
  display: flex;
  justify-content: center;
  margin-top: 49px;
}

/* cta01 */
.top_cta01 {
  background: #F7F6F4;
}

/* cta02 */
.top_cta02 {
  background: #F7F6F4;
}

/* top_flow */
.top_flow {
  background: #F7F6F4;
  padding-bottom: 120px;
  position: relative;
}

.top_flow::before {
  background: url(./image/top_flow_bg01.png) center center/100% 100% no-repeat;
  content: "";
  height: 1965px;
  left: 50%;
  position: absolute;
  top: -262.5px;
  transform: translateX(-50%);
  width: 100%;
}

.top_flow_container {
  position: relative;
}

.top_flow_text {
  color: #535353;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 0.08em;
  line-height: 1.5;
  margin-top: 25px;
  text-align: center;
}

.top_flow_item {
  margin-top: 40px;
}

.top_introduction {
  padding-top: 134px;
  position: relative;
}

.top_introduction_container {
  position: relative;
  z-index: 1;
}

.top_introduction_headline {
  position: relative;
  text-align: center;
}

.top_introduction_text {
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 0.1em;
  line-height: 2.56;
  margin-top: 35px;
  position: relative;
  text-align: center;
}

.top_introduction_text_en {
  letter-spacing: 0em;
}

.top_introduction_highlight {
  background: #E6830A;
  color: #FFFFFF;
  display: inline-block;
  font-size: 22px;
  font-weight: 600;
  letter-spacing: 0.1em;
  line-height: 1.55;
}

.top_introduction_highlight01 {
  margin-left: -10px;
  padding-left: 10px;
}

.top_introduction_highlight02 {
  margin-right: 3px;
}

.top_introduction_image01 {
  left: -50px;
  position: absolute;
  top: -44px;
  width: min(100%, 244.07px);
  z-index: 1;
}

.top_introduction_image01 img {
  -o-object-fit: contain;
  aspect-ratio: 244.07/259.86;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.top_introduction_image01::before {
  background: #FFFFFF;
  border-radius: 100vh;
  content: "";
  display: inline-block;
  filter: blur(4px);
  height: 293.11px;
  left: 0;
  position: absolute;
  top: -18.2px;
  width: 293.11px;
  z-index: -1;
}

.top_introduction_image02 {
  bottom: -211px;
  position: absolute;
  right: -18.6px;
  width: min(100%, 270.32px);
  z-index: 1;
}

.top_introduction_image02 img {
  -o-object-fit: contain;
  aspect-ratio: 270.32/245.52;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.top_introduction_image02::before {
  background: #FFFFFF;
  border-radius: 100vh;
  content: "";
  display: inline-block;
  filter: blur(4px);
  height: 291.44px;
  left: 44.3px;
  position: absolute;
  top: -35.9px;
  width: 291.44px;
  z-index: -1;
}

/* top_mv */
.top_mv {
  background: #FFF9EB;
  padding-top: 130px;
  position: relative;
}

.top_mv::before {
  background: url(./image/top_mv_bg01.png) center center/100% 100% no-repeat;
  content: "";
  height: 1040px;
  left: 0;
  position: absolute;
  top: 356.9px;
  width: 100%;
  z-index: 0;
}

.top_mv_wrap {
  margin-inline: auto;
  padding-left: 50px;
  position: relative;
  width: min(100%, 1340px);
}

.top_mv_container {
  position: relative;
}

.top_mv_content {
  align-items: flex-start;
  display: flex;
  justify-content: space-between;
}

.top_mv_textwrap {
  width: min(100%, 545px);
}

.top_mv_header {
  align-items: center;
  display: flex;
  gap: 20px;
  width: -moz-fit-content;
  width: fit-content;
}

.top_mv_header_logo {
  flex-shrink: 0;
  width: min(100%, 137px);
}

.top_mv_header_logo img {
  -o-object-fit: contain;
  aspect-ratio: 137/50;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.top_mv_header_text {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  line-height: 1.46;
  width: min(100%, 323px);
}

.top_mv_main {
  margin-top: 44px;
}

.top_mv_main_content {
  margin-top: 0;
}

.top_mv_main_text01 {
  color: #454545;
  font-size: 24px;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.46;
}

.top_mv_main_text01_dot {
  display: inline-flex;
  position: relative;
}

.top_mv_main_text01_dot::after {
  background-image: radial-gradient(circle, #333333 2.5px, transparent 2.5px);
  background-position: left top;
  background-repeat: repeat-x;
  background-size: 25px 5px;
  content: "";
  height: 5px;
  left: 0;
  position: absolute;
  top: -3px;
  width: 100%;
}

.top_mv_main_text02 {
  font-size: 54px;
  font-weight: 900;
  letter-spacing: 0.16em;
  line-height: 1.24;
  margin-top: 3px;
}

.top_mv_main_text02_highlight {
  color: #F59C2F;
  font-family: "Roboto", sans-serif;
  font-size: 60px;
  letter-spacing: 0.04em;
  line-height: 1.12;
  margin-right: 6px;
}

.top_mv_main_kintone_support {
  color: #0B3D5C;
  font-size: 32px;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1.5;
}

.top_mv_main_text03 {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1.44;
  margin-top: 24px;
}

.top_mv_main_btn {
  margin-top: 34px;
}

.top_mv_main_image {
  display: block;
  margin-top: 4px;
  width: min(100%, 711.5px);
}

.top_mv_main_image img {
  -o-object-fit: contain;
  aspect-ratio: 711.5/519;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.top_mv_cards {
  background: #FFFFFF;
  padding: 5px 7px;
  position: relative;
}

.top_mv_cards_swiper {
  overflow: hidden;
}

.top_mv_cards_swiper .swiper-wrapper {
  align-items: stretch;
  animation: loop 80s linear infinite;
  display: flex;
  padding: 3px;
  width: -moz-fit-content;
  width: fit-content;
}

@keyframes loop {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(-50%);
  }
}

.top_mv_cards_swiper .swiper-slide {
  align-items: stretch;
  display: flex;
  flex-shrink: 0;
  height: auto;
  margin-left: 10px;
  width: 370px;
}

.top_mv_cards_swiper .swiper-slide:first-child {
  margin-left: 0;
}

.top_mv_card {
  background: #FFFFFF;
  border-radius: 20px;
  height: 100%;
  padding: 30px 20px 40px;
}

.top_mv_card_img {
  margin-inline: auto;
  margin-top: 0;
  max-width: 200px;
  width: 100%;
}

.top_mv_card_img img {
  height: auto;
  width: 100%;
}

.top_mv_card_text {
  color: #333333;
  font-size: 14px;
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1.71;
  margin-top: 20px;
  text-align: center;
}

/* top_price */
.top_price {
  background: #F7F6F4;
  padding-block: 272px 331px;
}

.top_price_container {
  position: relative;
}

.top_price_text {
  color: #535353;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 0.08em;
  line-height: 1.5;
  margin-top: 26px;
  text-align: center;
}

.top_price_main_title {
  font-size: 32px;
  font-weight: 900;
  letter-spacing: 0.08em;
  margin-inline: auto;
  margin-top: 12px;
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
}

.top_price_main_title::before,
.top_price_main_title::after {
  background: #333333;
  bottom: 14px;
  content: "";
  height: 44px;
  position: absolute;
  width: 2px;
}

.top_price_main_title::before {
  left: -25px;
  rotate: -23deg;
}

.top_price_main_title::after {
  right: -25px;
  rotate: 23deg;
}

.top_price_main_title_unit {
  display: inline-block;
  padding-inline: 18px;
  position: relative;
}

.top_price_main_title_unit::before,
.top_price_main_title_unit::after {
  font-size: 24px;
  font-weight: 900;
  position: absolute;
  top: 10px;
  transform: scale(1);
}

.top_price_main_title_unit::before {
  content: "“";
  left: -1px;
}

.top_price_main_title_unit::after {
  content: "”";
  right: 0px;
}

.top_price_main_title_highlight {
  color: #E6830A;
  display: inline-block;
  font-family: "Roboto", sans-serif;
  font-size: 66px;
  font-weight: 900;
  line-height: 1.45;
  margin-right: -5px;
}

.top_price_main_subtitle {
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1.19;
  margin-top: -4px;
  text-align: center;
}

.top_price_main_subtitle_small {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1.36;
}

.top_price_boxes {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin-top: 14px;
}

.top_price_box {
  background-color: #FFFFFF;
  border-radius: 20px;
  position: relative;
  width: min(100%, 320px);
}

.top_price_box::after {
  background: url(./image/icon_plus.png) center center/contain no-repeat;
  content: "";
  display: inline-block;
  height: 27.36px;
  position: absolute;
  right: -58.36px;
  top: 50%;
  transform: translateY(-50%);
  width: 27.36px;
}

.top_price_box:last-of-type::after {
  display: none;
}

.top_price_box_title {
  background: #517084;
  border-radius: 20px 20px 0 0;
  color: #FFFFFF;
  font-size: 22px;
  font-weight: 900;
  letter-spacing: 0.08em;
  line-height: 1.45;
  padding-block: 14px;
  text-align: center;
}

.top_price_box_price {
  padding: 7px 10px 13px;
  text-align: center;
}

.top_price_box_text {
  align-items: center;
  display: flex;
  margin-inline: auto;
  padding-inline: 5px;
  width: -moz-fit-content;
  width: fit-content;
}

.top_price_box_text_line {
  background-image: linear-gradient(to bottom, transparent 0%, transparent 65%, #FFED8E 65%, #FFED8E 85%, transparent 85%, transparent 100%);
}

.top_price_box_price_num {
  color: #E6830A;
  font-family: "Roboto", sans-serif;
  font-size: 92px;
  font-weight: 900;
  line-height: 1.32;
}

.top_price_box_price_num_blue {
  color: #314362;
}

.top_price_box_price_unit {
  color: #333333;
  font-size: 36px;
  font-weight: 900;
  letter-spacing: 0.08em;
  line-height: 1.44;
  margin-top: 25px;
}

.top_price_example {
  background: #FFFFFF;
  border-radius: 20px;
  margin-top: 40px;
  padding: 40px 50px 30px 80px;
  position: relative;
}

.top_price_example::before {
  background: #517084;
  border-radius: 0 20px 20px 0;
  content: "";
  height: 200px;
  left: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 10px;
}

.top_price_examplewrap {
  display: flex;
  justify-content: space-between;
}

.top_price_exampleblock01 {
  margin-top: 40px;
  width: -moz-fit-content;
  width: fit-content;
}

.top_price_example_title {
  font-size: 26px;
  font-weight: 900;
  letter-spacing: 0.08em;
  line-height: 1.42;
}

.top_price_example_dots {
  display: grid;
  height: 6px;
  margin-top: 20px;
  width: min(100%, 38px);
}

.top_price_example_dots img {
  -o-object-fit: contain;
  aspect-ratio: 38/6;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.top_price_example_list {
  margin-top: 50px;
}

.top_price_example_list_item {
  align-items: flex-start;
  display: flex;
  gap: 14px;
}

.top_price_example_list_item+.top_price_example_list_item {
  margin-top: 8px;
}

.top_price_example_list_item01 {
  align-items: center;
}

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

.top_price_example_icon {
  background: #EDEDED;
  border-radius: 100vh;
  display: grid;
  flex-shrink: 0;
  height: 30px;
  place-items: center;
  width: 30px;
}

.top_price_example_icon img {
  -o-object-fit: contain;
  aspect-ratio: 12.42/9.89;
  height: auto;
  object-fit: contain;
  width: 14px;
}

.top_price_example_text {
  font-size: 18px;
  font-weight: 900;
  line-height: 1.44;
}

.top_price_example_text_big {
  font-size: 30px;
  line-height: 1.47;
}

.top_price_example_text_highlight {
  color: #E6830A;
}

.top_price_example_caution {
  display: block;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.57;
  margin-top: 3px;
  padding-left: 44px;
}

.top_price_example_list_highlight {
  color: #EB8800;
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.8;
}

.top_price_example_list_small {
  color: #666;
  font-size: 12px;
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1.8;
}

.top_price_example_calc {
  background-color: #f9f9f9;
  border-left: 4px solid #456478;
  padding-block: 24px;
  padding-inline: 32px;
}

.top_price_example_calc+.top_price_example_calc {
  margin-top: 24px;
}

.top_price_example_calc_label {
  border-radius: 20px;
  color: #FFFFFF;
  display: inline-block;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.4;
  margin-bottom: 16px;
  padding-block: 8px;
  padding-inline: 16px;
}

.top_price_example_calc_label01 {
  background-color: #456478;
}

.top_price_example_calc_label02 {
  background-color: #456478;
}

.top_price_example_calc_tags {
  align-items: center;
  display: flex;
  gap: 16px;
  justify-content: space-between;
  margin-bottom: 12px;
}

.top_price_example_calc_tag {
  background-color: #456478;
  border-radius: 4px;
  color: #FFFFFF;
  flex: 1;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.4;
  padding-block: 8px;
  text-align: center;
}

.top_price_example_calc_formula {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  justify-content: center;
}

.top_price_example_calc_num {
  color: #456478;
  font-size: 32px;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.4;
}

.top_price_example_calc_num_line {
  color: #999;
  text-decoration: line-through;
}

.top_price_example_calc_unit {
  color: #333333;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.4;
}

.top_price_example_calc_symbol {
  color: #333333;
  font-size: 24px;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.4;
}

.top_price_example_calc_note {
  color: #333333;
  font-size: 14px;
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1.8;
  margin-top: 16px;
}

.top_price_example_calc_note_price {
  color: #EB8800;
  font-size: 24px;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.4;
}

.top_price_example_calc_note_unit {
  color: #333333;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.4;
}

.top_price_example_item+.top_price_example_item {
  margin-top: 29px;
}

/* top_qa */
.top_qa {
  background: #F7F6F4;
  padding-block: 98px 222px;
  position: relative;
}

.top_qa::before {
  background: url(./image/top_qa_bg01.png) center center/100% 100% no-repeat;
  content: "";
  height: 1809px;
  left: 50%;
  position: absolute;
  top: 0;
  transform: translateX(-50%);
  width: 100%;
}

.top_qa_container {
  position: relative;
}

.top_qa_item {
  margin-top: 45px;
}

.top_reason {
  background: #F7F6F4;
  padding-top: 154px;
  position: relative;
}

.top_reason::before {
  background: url(./image/top_reason_bg01.png) center center/100% 100% no-repeat;
  content: "";
  height: 1694.07px;
  left: 50%;
  position: absolute;
  top: 213.3px;
  transform: translateX(-50%);
  width: 100%;
}

.top_reason::after {
  background: url(./image/top_reason_bg02.png) center center/contain no-repeat;
  content: "";
  height: 1904.74px;
  left: calc(50% + 55px);
  position: absolute;
  top: 0;
  transform: translateX(-50%);
  width: 1456.8px;
}

.top_reason_container {
  position: relative;
  z-index: 1;
}

.top_reason_headline {
  position: relative;
  z-index: 2;
}

.top_reason_item {
  margin-top: 106px;
}

.top_reason_media {
  align-items: flex-start;
  display: flex;
  justify-content: flex-end;
  position: relative;
  z-index: 1;
}

.top_reason_media01 {
  gap: 119px;
  margin-right: -3px;
}

.top_reason_media02 {
  gap: 76px;
  margin-top: 111px;
}

.top_reason_media03 {
  gap: 68.8px;
  margin-right: -4px;
  margin-top: 79px;
}

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

.top_reason_media_body {
  width: min(100%, 588px);
}

.top_reason_media_body01 {
  margin-top: 75.2px;
}

.top_reason_media_tag {
  align-items: flex-end;
  background: #E6830A;
  border-radius: 18px 18px 0 18px;
  display: flex;
  font-family: "Roboto", sans-serif;
  gap: 3px;
  padding: 7px 18px 7px;
  width: -moz-fit-content;
  width: fit-content;
}

.top_reason_media_tag_small {
  color: #FFFFFF;
  font-family: "Roboto", sans-serif;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0em;
  line-height: 1.3;
}

.top_reason_media_tag_big {
  color: #FFFFFF;
  font-size: 26px;
  font-weight: 700;
  letter-spacing: 0em;
  line-height: 1;
}

.top_reason_media_head {
  font-size: 34px;
  font-weight: 900;
  letter-spacing: 0.08em;
  line-height: 1.41;
  margin-top: 14px;
}

.top_reason_media_head_highlight {
  color: #E6830A;
}

.top_reason_media_txt {
  color: #555555;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1.75;
  margin-top: 24px;
  width: min(100%, 580px);
}

.top_reason_media_img01 {
  flex-shrink: 0;
  margin-top: 73.4px;
  position: relative;
  width: min(100%, 357.6px);
}

.top_reason_media_img01::before {
  aspect-ratio: 1/1;
  background: #FFFFFF;
  border-radius: 100vh;
  content: "";
  display: inline-block;
  filter: blur(4px);
  left: 60.6px;
  position: absolute;
  position: absolute;
  top: -102.4px;
  width: 370px;
  z-index: -1;
}

.top_reason_media_img01 img {
  -o-object-fit: contain;
  aspect-ratio: 357.6/202.73;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.top_reason_media_img02 {
  margin-top: 40px;
  position: relative;
  width: min(100%, 340.49px);
}

.top_reason_media_img02::before {
  aspect-ratio: 1/1;
  background: #FFFFFF;
  border-radius: 100vh;
  content: "";
  display: inline-block;
  filter: blur(4px);
  left: 48px;
  position: absolute;
  position: absolute;
  top: -59px;
  width: 370px;
  z-index: -1;
}

.top_reason_media_img02 img {
  -o-object-fit: contain;
  aspect-ratio: 340.49/268;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.top_reason_media_img03 {
  position: relative;
  width: min(100%, 315.15px);
}

.top_reason_media_img03::before {
  aspect-ratio: 1/1;
  background: #FFFFFF;
  border-radius: 100vh;
  content: "";
  display: inline-block;
  filter: blur(4px);
  left: -72.1px;
  position: absolute;
  position: absolute;
  top: -3.8px;
  width: 370px;
  z-index: -1;
}

.top_reason_media_img03 img {
  -o-object-fit: contain;
  aspect-ratio: 315.15/406.73;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.top_reason_btn {
  display: flex;
  justify-content: center;
  margin-top: 59px;
}

.top_solution {
  background: #F7F6F4;
  padding-block: 45.4px 124px;
  position: relative;
}

.top_solution::before {
  background: url(./image/top_solution_bg01.png) center center/contain no-repeat;
  content: "";
  height: 1060px;
  left: 50%;
  position: absolute;
  top: -35px;
  transform: translateX(-50%);
  width: 1870px;
}

.top_solution_container {
  position: relative;
}

.top_solution_arrow {
  margin-inline: auto;
  width: min(100%, 85.46px);
}

.top_solution_arrow img {
  -o-object-fit: contain;
  aspect-ratio: 85.46/55.53;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.top_solution_headline {
  margin-top: 25.1px;
  text-align: center;
}

.top_solution_headline_sub {
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 0.15em;
  line-height: 1.43;
}

.top_solution_headline_main {
  font-size: 38px;
  font-weight: 900;
  letter-spacing: 0.15em;
  line-height: 1.45;
  margin-top: 4px;
}

.top_solution_headline_main_small {
  font-size: 24px;
}

.top_solution_headline_main_highlight {
  color: #F7A541;
}

.top_solution_media {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin-top: 45px;
  padding-left: 40px;
}

.top_solution_media_img {
  width: min(100%, 290px);
}

.top_solution_media_img img {
  -o-object-fit: contain;
  aspect-ratio: 290/274.43;
  height: auto;
  object-fit: contain;
  width: 100%;
}

.top_solution_media_body {
  width: min(100%, 729px);
}

.top_solution_text+.top_solution_text {
  margin-top: 32px;
}

.top_solution_text01 {
  font-size: 16px;
  font-weight: 500;
  line-height: 2;
}

.top_solution_text02 {
  color: #392A0A;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.78;
}

/* top_voice */
.top_voice {
  background: #F7F6F4;
  padding-block: 118px 138px;
}

.top_voice_wrap {
  width: min(100%, 1340px);
}

.top_voice_text {
  color: #535353;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 0.08em;
  line-height: 1.5;
  margin-top: 25px;
  text-align: center;
}

.top_voice_item {
  margin-top: 37px;
  padding-inline: 100px;
  position: relative;
}

.top_voice_swiperbtns {
  height: 100%;
  left: 0;
  pointer-events: none;
  position: absolute;
  top: 0;
  width: 100%;
}

.top_voice_swiperbtn {
  aspect-ratio: 1/1;
  background: #FFFFFF;
  border: 1px solid #22314B;
  border-radius: 100vh;
  cursor: pointer;
  display: grid;
  place-items: center;
  pointer-events: auto;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  transition: 0.3s ease;
  width: 50px;
}

.top_voice_swiperbtn svg {
  aspect-ratio: 1/1;
  width: 15px;
}

.top_voice_swiperbtn svg line,
.top_voice_swiperbtn svg path {
  transition: 0.3s ease;
}

.top_voice_swiperbtn_prev {
  left: 0;
}

.top_voice_swiperbtn_next {
  right: 0;
}

.swiper-button-disabled {
  opacity: 0.4;
}

.top_voice_scroll {
  display: none;
}

.top_voice_scroll_hint {
  display: none;
}

@keyframes scrollHintSwing {
  0% {
    transform: translate(-50%, -50%) translateX(-10px);
  }

  50% {
    transform: translate(-50%, -50%) translateX(10px);
  }

  100% {
    transform: translate(-50%, -50%) translateX(-10px);
  }
}

.top_voice_scroll.is_scrolled .top_voice_scroll_hint {
  opacity: 0;
}

@media screen and (max-width: 750px) {
  .radio_btns .radio_btns__item+span {
    font-size: 3.59vw;
  }

  .radio_btns .radio_btns__item+span::before,
  .radio_btns .radio_btns__item+span::after {
    width: 5.13vw;
  }

  .radio_btns .radio_btns__item+span::after {
    left: 1.28vw;
    width: 2.56vw;
  }

  .mwform-checkbox-field-text {
    font-size: 3.59vw;
    padding-left: 7.69vw;
  }

  .mwform-checkbox-field-text::before {
    width: 5.13vw;
  }

  .mwform-checkbox-field-text::after {
    width: 5.13vw;
  }

  .l-content {
    padding-top: 22.56vw;
  }

  a[href^="tel:"] {
    pointer-events: all;
  }

  .pc {
    display: none;
  }

  .sp {
    display: block;
  }

  .m_inline_pc {
    margin-inline: unset;
  }

  img {
    /* タッチイベント自体を無効化 */
    -webkit-touch-callout: none;
    /* 長押し時のメニューを無効化 (iOS Safari) */
    -webkit-user-select: none;
    /* テキスト選択を無効化 */
    -webkit-user-drag: none;
    /* ドラッグ動作を無効化 */
    -moz-user-select: none;
    pointer-events: none;
    /* 他のブラウザでの選択無効化 */
    touch-action: manipulation;
    user-select: none;
    /* ズームやスクロールジェスチャーを制限 */
  }

  .wrap {
    max-width: 89.74%;
  }

  .wrap.lr {
    max-width: 94.87%;
  }

  a[href$=".pdf"]::before {
    height: 8vw;
    margin-right: 2.5vw;
    width: 7vw;
  }

  a[href$=".pdf"]:hover {
    text-decoration: underline;
  }

  body {
    font-size: 13px;
    min-width: unset;
  }

  /* SPヘッダー */
  #sp_header {
    background: #fff;
    box-shadow: 1px 1px #ccc;
    height: 55px;
    left: 0;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 999;
  }

  #sp_header .logo {
    left: 10px;
    line-height: 0;
    position: absolute;
    top: 10px;
  }

  #sp_header .logo img {
    height: 40px;
  }

  #sp_header .icon {
    color: #000;
    position: absolute;
  }

  #sp_header .mail {
    font-size: 25px;
    right: 70px;
    top: 13px;
  }

  #sp_header .tel {
    font-size: 20px;
    right: 110px;
    top: 15px;
  }

  /* SP固定ページ 共通設定 */
  .common_page_main {
    padding-block: 20vw;
  }

  .common_page_main .title_box .title {
    font-size: 5.6vw;
  }

  .common_page_wrap {
    padding: 10.26vw 0 20.51vw;
  }

  .reserve_text {
    font-size: 6vw;
  }

  /* パンくず */
  .breadcrumb {
    font-size: 3vw;
  }

  /* SP固定ページ お問い合わせ */
  .contact_form_disc {
    margin-block: 0 2em;
  }

  .contact_form_disc .text {
    font-size: 3.6vw;
    margin-block: 0 0.8em;
  }

  .contact_form_disc .caution {
    font-size: 3.1vw;
    letter-spacing: 0.06em;
  }

  .common_contact_form .form_box {
    margin-block: 0 10vw;
  }

  .common_contact_form .form_box dl {
    gap: 0.6em;
    grid-template-columns: 1fr;
  }

  .common_contact_form .form_box dl+dl {
    margin-block: 1.3em 0;
  }

  .common_contact_form .form_box dl dt {
    flex-direction: row-reverse;
    font-size: 4.1vw;
    justify-content: space-between;
    padding-inline: 0;
  }

  .common_contact_form .form_box dl dt .label {
    font-size: 3.1vw;
  }

  .common_contact_form .form_box dl dt::after {
    content: none;
  }

  .common_contact_form input[type=text],
  .common_contact_form input[type=email],
  .common_contact_form #zip,
  .common_contact_form #zip2 {
    font-size: 3.6vw;
  }

  .common_contact_form select,
  .common_contact_form .hasDatepicker[type=text] {
    font-size: 3.6vw;
    width: 100%;
  }

  .common_contact_form textarea {
    font-size: 3.6vw;
    height: 33vw;
  }

  .radio_btns .radio_btns__item+span {
    font-size: 3.6vw;
  }

  .radio_btns .radio_btns__item+span::before,
  .radio_btns .radio_btns__item+span::after {
    width: 5vw;
  }

  /* after上書き */
  .radio_btns .radio_btns__item+span::after {
    left: 1.25vw;
    width: 2.5vw;
  }

  .radio_btns,
  .checkboxes {
    gap: 0.5em 2.5em;
  }

  .page_contact #btn_wrap button {
    font-size: 4.6vw;
    line-height: 15.5vw;
    width: 83%;
  }

  .page_contact #btn_wrap button[name=submitBack] {
    margin-top: 4vw;
  }

  .mwform-checkbox-field.horizontal-item {
    display: block;
  }

  .page_contact #btn_wrap {
    text-align: center;
    width: 100%;
  }

  .privacy_check_list .mwform-checkbox-field-text {
    font-size: 3.8vw;
    padding-left: 11vw;
  }

  .mwform-checkbox-field-text {
    font-size: 3.8vw;
    padding-left: 6.41vw;
  }

  .mwform-checkbox-field-text::before {
    border-radius: 0.51vw;
    width: 3.85vw;
  }

  .mwform-checkbox-field-text::after {
    width: 3.85vw;
  }

  .mw_wp_form .privacy_check_list .horizontal-item {
    margin-right: 4vw;
  }

  .privacy_check_list .hissu {
    padding: 0.3vw 4vw;
  }

  .privacy_check_list {
    margin-bottom: 6vw;
  }

  .privacy_term_detail {
    font-size: 3.4vw;
    margin: 5vw 0;
  }

  .privacy_term_outer {
    padding: 5vw 0;
    width: 96%;
  }

  .privacy_term_outer .privacy_term_inner .main_text {
    font-size: 3.4vw;
    line-height: 1.6;
    margin-bottom: 5vw;
  }

  .privacy_term_outer .privacy_term_inner dl dt {
    font-size: 3.5vw;
    margin-bottom: 1.5vw;
  }

  .privacy_term_outer .privacy_term_inner dl dd {
    font-size: 3.5vw;
    line-height: 1.6;
  }

  .privacy_term_outer .privacy_term_inner dl+dl {
    margin-top: 7vw;
  }

  .privacy_term_detail::after {
    margin: 1.5vw auto 0;
    width: 2.5vw;
  }

  /* サンクスページ */
  .page_contact .thanks_textArea .name {
    font-size: 4vw;
    margin-bottom: 3vw;
  }

  .page_contact .thanks_textArea .contact_text {
    font-size: 3.5vw;
    margin-bottom: 2em;
    width: 100%;
  }

  .page_contact .thanks_textArea .ichiran_link {
    font-size: 4vw;
    line-height: 12vw;
    width: 80%;
  }

  /* ステップバー デザイン */
  .page_contact .progressbar {
    gap: 4.5em;
    margin-block: 0 2.5em;
  }

  .page_contact .progressbar .item {
    font-size: 3.1vw;
  }

  .page_contact .progressbar .item+.item::before {
    left: -3.3em;
    top: 63%;
    width: 5.7vw;
  }

  .page_contact .progressbar .item .mark {
    margin: 0 auto 0.4em;
    width: 7.7vw;
  }

  /* SP固定ページ 404ページ */
  #page_404 .num {
    font-size: 20vw;
    line-height: 1.5;
  }

  #page_404 .text {
    font-size: 3.5vw;
  }

  /* SP投稿ページ アーカイブページ */
  .archive_page_list>article {
    padding-right: 20px;
  }

  .archive_page_list>article .date {
    width: 80px;
  }

  .archive_page_list>article .content_area {
    width: calc(100% - 80px);
  }

  .archive_page_list>article:after {
    height: 7px;
    width: 7px;
  }

  /* SP固定ページ サイトマップ */
  ul#sitemap_list li {
    margin: 0;
  }

  body #sitemap_list li a {
    font-size: 4vw;
    line-height: 9vw;
    margin-bottom: 1vw;
    padding: 1vw 2vw;
  }

  body #sitemap_list li.home-item {
    margin-bottom: 4vw;
  }

  body #sitemap_list {
    padding: 0;
  }

  .common_btn01 {
    padding-block: 4.1vw;
    padding-inline: 7.69vw;
  }

  .common_btn01_text {
    font-size: 4.1vw;
  }

  .common_btn01_icon {
    margin-left: 4.1vw;
    width: 11.28vw;
  }

  .common_btn02 {
    width: min(100%, 89.74vw);
  }

  .common_btn02__decotext {
    font-size: 3.59vw;
    line-height: 1.43;
  }

  .common_btn02__decotext::before,
  .common_btn02__decotext::after {
    width: 0.51vw;
  }

  .common_btn02__decotext::before {
    left: -4.62vw;
  }

  .common_btn02__decotext::after {
    right: -4.62vw;
  }

  .common_btn02__link {
    border-radius: 8.97vw;
    margin-top: 2.05vw;
    padding: 5.38vw;
    width: 100%;
  }

  .common_btn02__icon01 {
    border-width: 0.77vw;
    width: 17.95vw;
  }

  .common_btn02__icon01_text01 {
    font-size: 3.08vw;
  }

  .common_btn02__icon01__text_headlight {
    font-size: 7.69vw;
    margin-top: -0.51vw;
  }

  .common_btn02__icon01__text_headlight02 {
    font-size: 3.33vw;
  }

  .common_btn02__text {
    font-size: 4.62vw;
    padding-left: 0;
  }

  .common_btn02__icon02 {
    right: 7.69vw;
    width: 6.15vw;
  }

  .common_btn02__icon02 svg {
    width: 2.56vw;
  }

  .common_btn03 {
    border-radius: 8.97vw;
    padding: 5.9vw 5.13vw;
    width: min(100%, 89.74vw);
  }

  .common_btn03_text {
    font-size: 3.59vw;
    letter-spacing: 0.04em;
  }

  .common_btn03_icon {
    right: 5.13vw;
    width: 6.15vw;
  }

  .common_btn03_icon svg {
    width: 2.56vw;
  }

  .common_btn04 {
    width: min(100%, 89.74vw);
  }

  .common_btn04__decotext {
    font-size: 3.33vw;
    letter-spacing: 0.04em;
    line-height: 1.46;
  }

  .common_btn04__decotext::before,
  .common_btn04__decotext::after {
    aspect-ratio: 2/22;
    bottom: -0.77vw;
    width: 0.51vw;
  }

  .common_btn04__decotext::before {
    left: -3.59vw;
    rotate: -29deg;
  }

  .common_btn04__decotext::after {
    right: -3.59vw;
    rotate: 29deg;
  }

  .common_btn04__link {
    border-radius: 8.97vw;
    margin-top: 3.33vw;
    padding: 5.13vw;
    width: 100%;
  }

  .common_btn04__icon01 {
    border-width: 0.77vw;
    left: -0.51vw;
    width: 17.95vw;
  }

  .common_btn04__icon01_text01 {
    font-size: 3.08vw;
  }

  .common_btn04__icon01__text_headlight {
    font-size: 7.18vw;
  }

  .common_btn04__icon01__text_headlight02 {
    font-size: 3.33vw;
  }

  .common_btn04__text {
    font-size: 4.1vw;
  }

  .common_btn04__icon02 {
    right: 4.62vw;
    width: 6.15vw;
  }

  .common_btn04__icon02 svg {
    width: 2.56vw;
  }

  .common_btn05 {
    border-radius: 8.97vw;
    padding: 5.9vw 7.69vw;
    width: min(100%, 87.18vw);
  }

  .common_btn05_text {
    font-size: 4.1vw;
  }

  .common_btn05_icon {
    right: 7.69vw;
    width: 6.15vw;
  }

  .common_btn05_icon svg {
    width: 2.56vw;
  }

  .common_btn06 {
    border-radius: 1.28vw;
    gap: 2.56vw;
    height: unset;
    padding: 3.33vw 2.56vw;
  }

  .common_btn06_num {
    font-size: 4.62vw;
  }

  .common_btn06_text {
    font-size: 4.1vw;
    line-height: 1.5;
  }

  .common_btn06_text_small {
    font-size: 3.59vw;
    padding-left: 0.26vw;
  }

  .common_btn06_icon {
    right: 2.56vw;
    width: 3.33vw;
  }

  .common_headline01_sub {
    font-size: 4.1vw;
    line-height: 1.31;
  }

  .common_headline01_sub01 {
    padding-right: 0;
  }

  .common_headline01_sub02 {
    margin-right: 1.54vw;
  }

  .common_headline01_sub03 {
    padding-right: 1.28vw;
  }

  .common_headline01_sub04 {
    padding-left: 2.05vw;
  }

  .common_headline01_main {
    font-size: 6.15vw;
    line-height: 1.79;
    margin-top: 0.77vw;
    white-space: nowrap;
  }

  .common_headline01_main01 {
    margin-top: 0;
  }

  .common_headline01_main02 {
    font-size: 6.69vw;
    line-height: 1.47;
  }

  .common_headline01_main_en {
    font-size: 8.21vw;
    margin-right: 0;
  }

  .common_headline02_sub {
    font-size: 5.13vw;
    line-height: 1.3;
  }

  .common_headline02_main {
    font-size: 7.18vw;
    line-height: 1.21;
    margin-top: 0.26vw;
  }

  .common_card01 {
    align-items: center;
    border-radius: 5.13vw;
    display: flex;
    gap: 2.56vw;
    padding: 3.08vw 5.13vw 3.59vw 2.56vw;
  }

  .common_card01_img {
    flex-shrink: 0;
    left: unset;
    margin-inline: unset;
    position: static;
    position: static;
    transform: unset;
    width: min(100%, 28.21vw);
  }

  .common_card01_body {
    margin-top: 1.28vw;
  }

  .common_card01_titlewrap {
    min-height: unset;
    place-content: start;
  }

  .common_card01_title {
    font-size: 4.62vw;
    line-height: 1.44;
    text-align: left;
  }

  .common_card01_txt {
    font-size: 3.33vw;
    line-height: 1.54;
    margin-top: 2.56vw;
  }

  .common_card02_img {
    aspect-ratio: unset;
    border: none;
    border-radius: 5.13vw;
  }

  .common_card02_img img {
    aspect-ratio: 350/180;
    border-radius: 5.13vw;
    position: static;
    transform: none;
  }

  .common_card02_body {
    margin-top: 5.13vw;
  }

  .common_card02_title_text {
    font-size: 4.62vw;
    line-height: 1.44;
    min-height: 13.33vw;
  }

  .common_card02_txt {
    -webkit-line-clamp: 2;
    font-size: 3.33vw;
    line-height: 1.69;
    margin-top: 2.31vw;
    min-height: 10.51vw;
  }

  .common_card02_meta {
    margin-top: 4.62vw;
    padding-top: 3.59vw;
  }

  .common_card02_meta::before {
    background-image: linear-gradient(90deg, #707070, #707070 1.54vw, transparent 1.54vw, transparent 2.05vw);
    background-size: 2.05vw 1.03vw;
    height: 0.51vw;
  }

  .common_card02_company {
    font-size: 3.59vw;
    line-height: 1.43;
  }

  .common_card02_icon {
    width: 7.69vw;
  }

  .common_card02_icon svg {
    width: 3.33vw;
  }

  .common_cards01 {
    gap: 2.82vw;
    grid-template-columns: repeat(1, 1fr);
  }

  .common_cards02 {
    display: grid;
    gap: 2.56vw;
    grid-template-columns: repeat(3, 1fr);
    width: 274.36vw;
  }

  .common_cards02_item_pc {
    display: none;
  }

  .common_cta01_deco01 {
    bottom: -7.69vw;
    left: -37.18vw;
    width: min(100%, 62.82vw);
  }

  .common_cta01_deco02 {
    bottom: -18.21vw;
    left: -10vw;
    width: min(100%, 45.64vw);
  }

  .common_cta01_deco03 {
    right: -8.46vw;
    top: -24.36vw;
    width: min(100%, 62.05vw);
  }

  .common_cta01_circle01 {
    right: 2.56vw;
    top: 23.59vw;
    width: min(100%, 26.41vw);
  }

  .common_cta01_circle02 {
    right: 63.33vw;
    top: 4.87vw;
    width: min(100%, 8.46vw);
  }

  .common_cta01_img {
    bottom: -0.72vw;
    right: -4.85vw;
    width: min(100%, 37.66vw);
  }

  .common_cta01_container {
    border-radius: 5.13vw;
    padding-block: 10.26vw 21.03vw;
  }

  .common_cta01_headline_sub {
    font-size: 4.62vw;
    line-height: 1.44;
  }

  .common_cta01_headline_main {
    font-size: 6.15vw;
    line-height: 1.63;
    margin-top: 1.28vw;
    white-space: nowrap;
  }

  .common_cta01_headline_main_highlight {
    margin-left: 0;
  }

  .common_cta01_text {
    font-size: 3.85vw;
    line-height: 1.6;
    margin-top: 4.36vw;
  }

  .common_cta01_btn {
    margin-top: 6.15vw;
  }

  .common_follow_sp {
    background: #0B3D5C;
    bottom: 0;
    display: block;
    left: 0;
    opacity: 0;
    padding: 4.18vw 5.13vw 3.41vw;
    position: fixed;
    transition: 0.3s ease;
    visibility: hidden;
    width: 100%;
    z-index: 1000;
    z-index: 2000;
  }

  .common_follow_sp_deco {
    align-items: flex-end;
    background: #FFFFFF;
    border: 2px solid #0B3D5C;
    border-radius: 3.59vw;
    display: flex;
    font-size: 3.33vw;
    font-weight: 700;
    left: 50%;
    line-height: 1.3;
    padding: 0.64vw 3.33vw 0.64vw 3.85vw;
    position: absolute;
    top: -3.59vw;
    transform: translateX(-50%);
    width: -moz-fit-content;
    width: fit-content;
  }

  .common_follow_sp_deco_highlight {
    color: #E6830A;
    display: inline-block;
    font-family: "Roboto", sans-serif;
    font-size: 6.67vw;
    font-weight: 700;
    letter-spacing: -0.03em;
    line-height: 1;
    line-height: 0.73;
    margin-right: 0.26vw;
    width: -moz-fit-content;
    width: fit-content;
  }

  .common_follow_sp_img {
    bottom: 0;
    left: -4.85vw;
    position: absolute;
    width: min(100%, 27.34vw);
  }

  .common_follow_sp_img img {
    -o-object-fit: contain;
    aspect-ratio: 106.63/74.12;
    height: auto;
    object-fit: contain;
    width: 100%;
  }

  .common_follow_sp_text_small {
    color: #FFFFFF;
    display: block;
    font-size: 3.59vw;
    font-weight: 700;
    letter-spacing: 0.15em;
    line-height: 1.43;
    text-align: center;
  }

  .common_follow_sp_text_big {
    color: #FFFFFF;
    display: block;
    font-size: 5.64vw;
    font-weight: 700;
    letter-spacing: 0.02em;
    line-height: 1.45;
    margin-top: -0.38vw;
    text-align: center;
  }

  .common_follow_sp_icon {
    background: #FFFFFF;
    border-radius: 100vh;
    display: grid;
    display: grid;
    height: 6.15vw;
    place-items: center;
    position: absolute;
    right: 5.13vw;
    top: 50%;
    transform: translateY(-50%);
    width: 6.15vw;
  }

  .common_follow_sp_icon img {
    aspect-ratio: 1/1;
    height: auto;
    transform: translateX(-10%);
    width: 2.82vw;
  }

  .common_item01 {
    border-radius: 5.13vw;
    flex-direction: column;
    min-height: 64.1vw;
  }

  .common_item01_step {
    align-items: baseline;
    border-radius: 5.13vw 5.13vw 0 0;
    display: flex;
    flex-direction: row;
    gap: 0.51vw;
    height: 8.72vw;
    padding: 0.51vw;
  }

  .common_item01_step_label {
    font-size: 3.59vw;
  }

  .common_item01_step_num {
    font-size: 6.15vw;
    line-height: 1.33;
  }

  .common_item01_content {
    align-items: flex-start;
    flex-direction: column;
    gap: 0;
    padding: 3.85vw 5.13vw 4.92vw;
    position: relative;
  }

  .common_item01_img {
    position: absolute;
    right: 3.08vw;
    top: 0vw;
    width: min(100%, 26.92vw);
  }

  .common_item01_body {
    margin-bottom: 0;
  }

  .common_item01_head {
    align-items: flex-end;
    display: flex;
    font-size: 5.13vw;
    line-height: 1.45;
    min-height: 14.1vw;
  }

  .common_item01_dots {
    margin-top: 1.69vw;
    width: min(100%, 7.73vw);
  }

  .common_item01_txt {
    font-size: 3.33vw;
    line-height: 1.46;
    margin-top: 5.49vw;
  }

  .common_item02 {
    border-radius: 2.56vw;
    padding: 5.13vw 2.56vw 3.72vw;
  }

  .common_item02_question {
    gap: 2.56vw;
    padding-right: 1.03vw;
  }

  .common_item02_question_icon {
    font-size: 4.62vw;
    width: 10.26vw;
  }

  .common_item02_question_text {
    font-size: 3.85vw;
    min-height: 9.74vw;
  }

  .common_item02_question_toggle {
    width: 8.21vw;
  }

  .common_item02_question_toggle_plus {
    width: 3.08vw;
  }

  .common_item02_question_toggle_plus::before {
    width: 0.51vw;
  }

  .common_item02_question_toggle_plus::after {
    height: 0.51vw;
  }

  .common_item02_answer {
    align-items: flex-start;
    gap: 2.56vw;
    margin-top: 3.33vw;
    padding-top: 5.13vw;
  }

  .common_item02_answer::before {
    background-image: radial-gradient(circle, #3E3E3E 0.13vw, transparent 0.13vw);
    background-size: 1.28vw 0.26vw;
  }

  .common_item02_answer_icon {
    font-size: 4.62vw;
    width: 10.26vw;
  }

  .common_item02_answer_text {
    font-size: 3.33vw;
    line-height: 1.54;
  }

  .common_item03 {
    border-radius: 5.13vw;
    padding: 13.85vw 2.56vw 2.56vw;
  }

  .common_item03_ptbig {
    padding-top: 20.79vw;
  }

  .common_item03_title {
    font-size: 6.15vw;
    left: 50%;
    line-height: 1.25;
    text-align: center;
    top: -3.59vw;
    transform: translateX(-50%);
    white-space: nowrap;
  }

  .common_item03_title::before,
  .common_item03_title::after {
    width: 7.34vw;
  }

  .common_item03_title::before {
    left: -5.79vw;
    top: -2.56vw;
  }

  .common_item03_title::after {
    bottom: -3.08vw;
    right: -5.38vw;
  }

  .common_item03_title_reverse {
    right: unset;
  }

  .common_item03_title01 {
    top: -4.1vw;
  }

  .common_item03_title01::before {
    top: -1.79vw;
  }

  .common_item03_title01::after {
    right: 13vw;
  }

  .common_item03_title_small {
    font-size: 4.1vw;
  }

  .common_item03_problem {
    flex-direction: column;
    gap: 5.13vw;
    margin-left: 0;
  }

  .common_item03_problem_img {
    display: none;
  }

  .common_item03_problem_bubble {
    border-radius: 2.56vw;
    padding: 5.64vw 4.87vw 4.87vw 5.13vw;
  }

  .common_item03_problem_bubble::before {
    display: none;
  }

  .common_item03_problem_bubble_label {
    border-radius: 5.13vw;
    border-width: 1px;
    font-size: 4.62vw;
    left: 50%;
    padding: 1.79vw 4.87vw;
    top: -4.36vw;
    transform: translateX(-50%);
  }

  .common_item03_problem_bubble_text {
    font-size: 3.85vw;
    letter-spacing: 0.09em;
    line-height: 1.47;
  }

  .common_item03_arrow02 {
    display: block;
    margin-inline: auto;
    margin-top: 3.59vw;
    width: min(100%, 28.21vw);
  }

  .common_item03_solution {
    margin-right: 0;
    margin-top: 7.44vw;
  }

  .common_item03_solution_title {
    border-radius: 5.38vw;
    border-width: 1px;
    font-size: 4.62vw;
    left: 50%;
    padding: 1.79vw 4.87vw 1.79vw 17.95vw;
    top: -4.36vw;
    transform: translateX(-50%);
    white-space: nowrap;
  }

  .common_item03_solution_title::before {
    display: block;
  }

  .common_item03_solution_tags {
    align-items: center;
    flex-direction: column;
    gap: 3.08vw;
  }

  .common_item03_solution_tag_label {
    font-size: 4.62vw;
    padding-bottom: 0.77vw;
    padding-right: 0;
    width: -moz-fit-content;
    width: fit-content;
  }

  .common_item03_solution_tag_label::after {
    bottom: 0;
    height: 2px;
    top: unset;
    width: 100%;
  }

  .common_item03_solution_tagwrap {
    gap: 1.03vw;
    justify-content: center;
    width: 100%;
  }

  .common_item03_solution_tag {
    border-radius: 1.03vw;
    font-size: 3.85vw;
    padding: 1.15vw 2.31vw;
  }

  .common_item03_solution_tag_small {
    font-size: 3.08vw;
    padding: 1.54vw 2.56vw;
  }

  .common_item03_solution_content {
    border-radius: 2.56vw;
    padding: 9.74vw 5.13vw 5.13vw;
  }

  .common_item03_solution_content::after {
    display: none;
  }

  .common_item03_solution_text {
    font-size: 3.33vw;
    line-height: 1.69;
    margin-top: 4.87vw;
  }

  .common_item03_solution_text+.common_item03_solution_text {
    margin-top: 3.85vw;
  }

  .common_item03_solution_img {
    display: none;
  }

  .common_item03_arrow {
    margin-top: 3.08vw;
    width: min(100%, 41.03vw);
  }

  .common_item03_arrow img {
    aspect-ratio: 160/40;
  }

  .common_item03_benefit {
    border-radius: 2.56vw;
    margin-top: 8.21vw;
    padding: 9.23vw 4.62vw 5.38vw;
  }

  .common_item03_benefit_title {
    border-radius: 5.13vw;
    font-size: 4.62vw;
    padding: 2.82vw 5.51vw;
  }

  .common_item03_benefit_text {
    font-size: 3.85vw;
    letter-spacing: 0.04em;
    line-height: 1.73;
    text-align: left;
  }

  .common_item03_benefit_text01 {
    display: block;
    margin-top: -1.54vw;
  }

  .common_item03_benefit_text_highlight {
    font-size: 5.13vw;
    letter-spacing: 0.03em;
    line-height: 1.9;
  }

  .common_item03_benefit_img {
    bottom: -14.1vw;
    right: -3.33vw;
    width: min(100%, 20.64vw);
  }

  .common_item03_benefit_img img {
    aspect-ratio: 80.48/61.21;
  }

  .common_item04 {
    border-radius: 2.56vw;
    padding: 10.13vw 2.56vw 2.56vw;
  }

  .common_item04_title {
    font-size: 3.85vw;
    padding: 1.67vw 5.13vw;
    top: -3.59vw;
  }

  .common_item04_wrap {
    flex-direction: column;
  }

  .common_item04_block {
    background: #FFFFFF;
    border-radius: 1.54vw;
    padding: 2.82vw 2.56vw 1.03vw;
    width: 100%;
  }

  .common_item04_block01::after {
    bottom: -6.63vw;
    height: 4.93vw;
    left: 50%;
    transform: translateX(-50%);
    width: 5.09vw;
  }

  .common_item04_tag {
    border-radius: 2.56vw;
    font-size: 3.08vw;
    left: 50%;
    padding: 0.64vw 2.56vw 0.9vw;
    position: absolute;
    top: -2.31vw;
    transform: translateX(-50%);
    width: min(100%, 33.33vw);
  }

  .common_item04_tag_light {
    border-radius: 2.56vw;
    font-size: 3.33vw;
    left: 50%;
    padding: 0.77vw 2.56vw 1.03vw;
    position: absolute;
    top: -2.56vw;
    transform: translateX(-50%);
    white-space: nowrap;
  }

  .common_item04_text {
    font-size: 7.69vw;
    line-height: 1.3;
    margin-top: 0;
  }

  .common_item04_text01::before,
  .common_item04_text01::after {
    height: 0.51vw;
    width: 33.33vw;
  }

  .common_item04_text01::before {
    transform: translate(-50%, -50%) rotate(12deg);
  }

  .common_item04_text01::after {
    transform: translate(-50%, -50%) rotate(-12deg);
  }

  .common_item04_text_small {
    font-size: 4.62vw;
    padding-left: 0.26vw;
  }

  .common_item04_block02 {
    margin-left: 0;
    margin-top: 10.26vw;
  }

  .common_item04_block02::after {
    bottom: -6.28vw;
    height: 5vw;
    left: 50%;
    right: unset;
    transform: translateX(-50%) rotate(90deg);
    transform-origin: center center;
    width: 5vw;
  }

  .common_item04_block03 {
    margin-left: 0;
    margin-top: 9.87vw;
  }

  .common_item04_block03_02 {
    padding-bottom: 2.56vw;
    padding-top: 4.1vw;
  }

  .common_item04_content_pc {
    display: none;
  }

  .common_item04_content_sp {
    display: block;
  }

  .common_item04_arrow {
    margin-inline: auto;
    margin-top: 0vw;
    width: min(100%, 20.26vw);
  }

  .common_item04_caution {
    font-size: 3.59vw;
    line-height: 1.5;
    margin-top: 1.54vw;
    text-align: center;
  }

  .common_item04_caution_line::before {
    bottom: 0;
    height: 2.56vw;
    left: 50%;
    right: unset;
    transform: translateX(-50%);
    width: calc(100% + 0.51vw);
  }

  .common_item04_caution_highlight {
    font-size: 8.97vw;
    margin-left: 0;
  }

  .common_item04_caution_unit {
    font-size: 5.13vw;
  }

  .common_items01 {
    gap: 5.13vw;
  }

  .common_items01_item::before {
    height: 5.13vw;
    left: 50%;
    transform: translateX(-50%);
    width: 0.51vw;
  }

  .common_items02 {
    gap: 2.56vw;
  }

  .common_items03 {
    gap: 34.62vw;
  }

  .common_items03_item::after {
    display: block;
  }

  .common_items03_item:last-of-type::after {
    display: none;
  }

  .common_lower_mv {
    padding-block: 31.95vw 0;
  }

  .common_lower_mv::before {
    background-image: url(./image/lower_mv_bg_sp01.png);
    height: 39.69vw;
  }

  .common_lower_mv_breadcrumb {
    margin-top: 5.38vw;
  }

  .common_lower_mv_breadcrumb span {
    font-size: 3.08vw;
    line-height: 1.42;
  }

  .breadcrumb_separator {
    font-size: 3.08vw;
    line-height: 1.42;
  }

  .common_media01 {
    border-radius: 2.56vw;
    padding: 2.82vw 3.85vw 2.56vw;
  }

  .common_media01_img {
    display: none;
  }

  .common_media01_txt {
    font-size: 3.33vw;
    letter-spacing: 0.07em;
    line-height: 1.54;
  }

  .common_media02 {
    flex-direction: column-reverse;
    gap: 0;
  }

  .common_media02_body01 {
    margin-top: 2.05vw;
    width: 100%;
  }

  .common_media02_body02 {
    display: contents;
  }

  .common_media02_body03 {
    margin-top: -1.15vw;
    width: 100%;
  }

  .common_media02_tag {
    border-radius: 4.62vw 4.62vw 0vw 4.62vw;
    gap: 0.77vw;
    order: 3;
    padding: 1.54vw 3.59vw;
  }

  .common_media02_tag_small {
    font-size: 3.33vw;
  }

  .common_media02_tag_big {
    font-size: 5.64vw;
  }

  .common_media02_head {
    font-size: 6.15vw;
    line-height: 1.42;
    margin-top: 3.08vw;
    order: 2;
  }

  .common_media02_txtwrap01 {
    margin-top: 5.13vw;
  }

  .common_media02_txtwrap02 {
    margin-top: 5.13vw;
    order: 1;
    width: 100%;
  }

  .common_media02_txtwrap03 {
    margin-top: 5.08vw;
  }

  .common_media02_txt {
    font-size: 3.59vw;
    line-height: 1.57;
  }

  .common_media02_txt+.common_media02_txt {
    margin-top: 5.51vw;
  }

  .common_media02_img01 {
    margin-inline: auto;
    margin-top: 0;
    width: min(100%, 66.94vw);
  }

  .common_media02_img01::before {
    height: 61.54vw;
    left: 50%;
    position: absolute;
    top: 47%;
    transform: translate(-50%, -50%);
    width: 61.54vw;
  }

  .common_media02_img02 {
    margin-inline: auto;
    margin-left: 12.56vw;
    margin-top: 0;
    order: 4;
    width: min(100%, 58.96vw);
  }

  .common_media02_img02::before {
    height: 61.54vw;
    left: 54%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 61.54vw;
  }

  .common_media02_img02 img {
    transform: rotateY(180deg);
  }

  .common_media02_img03 {
    margin-left: 11.28vw;
    margin-top: 0;
    width: min(100%, 56.9vw);
  }

  .common_media02_img03::before {
    height: 61.54vw;
    left: 60%;
    top: 58%;
    transform: translate(-50%, -50%);
    width: 61.54vw;
  }

  .cta01::before {
    background-image: url(./image/top_cta_bg_sp01.png);
    height: 230.76vw;
    top: -12.87vw;
  }

  .features01 {
    padding-block: 9.74vw 39.26vw;
  }

  .features01_btnwrap {
    gap: 2.56vw;
    grid-template-columns: repeat(1, 1fr);
  }

  .features01_item {
    margin-top: 19.23vw;
  }

  .footer {
    padding-block: 10vw 28.21vw;
  }

  .footer::after {
    background: #F7F6F4;
    bottom: 0;
    content: "";
    display: block;
    height: 20.51vw;
    left: 0;
    position: absolute;
    width: 100%;
  }

  .footer_illustration {
    display: none;
  }

  .footer_title {
    font-size: 6.15vw;
    gap: 4.1vw;
    line-height: 1.33;
  }

  .footer_title::before,
  .footer_title::after {
    background-size: 3.08vw 1.54vw;
    height: 0.51vw;
  }

  .footer_title::before {
    display: block;
  }

  .footer_list {
    display: grid;
    gap: 0 7.44vw;
    grid-template-columns: repeat(2, 1fr);
    margin-top: 1.79vw;
  }

  .footer_list .footer_item:nth-child(1) {
    order: 1;
  }

  .footer_list .footer_item:nth-child(2) {
    order: 3;
  }

  .footer_list .footer_item:nth-child(3) {
    order: 5;
  }

  .footer_list .footer_item:nth-child(4) {
    order: 7;
  }

  .footer_list .footer_item:nth-child(5) {
    order: 2;
  }

  .footer_list .footer_item:nth-child(6) {
    order: 4;
  }

  .footer_list .footer_item:nth-child(7) {
    order: 6;
  }

  .footer_list .footer_item:nth-child(8) {
    order: 8;
  }

  .footer_item {
    border-bottom: 1px solid #D3CCBD;
  }

  .footer_link {
    font-size: 3.85vw;
    justify-content: space-between;
    letter-spacing: 0.04em;
    padding: 4.82vw 0;
  }

  .footer_link::before {
    display: none;
  }

  .footer_link::after {
    aspect-ratio: 6/14;
    background: url(./image/icon_arrow07.png) center center/contain no-repeat;
    content: "";
    display: block;
    height: auto;
    width: 1.54vw;
  }

  .footer_link01::after {
    background: url(./image/icon_box01.png) center center/contain no-repeat;
    right: 0;
    width: 4.1vw;
  }

  .footer_wrap01 {
    flex-direction: column;
    margin-top: 26.13vw;
    margin-right: 0;
  }

  .footer_logo {
    margin-inline: auto;
    width: min(100%, 48.21vw);
  }

  .footer_company {
    font-size: 3.59vw;
    line-height: 1.43;
    margin-top: 4.18vw;
    text-align: center;
  }

  .footer_address {
    font-size: 3.59vw;
    line-height: 1.57;
    margin-top: 1.54vw;
    text-align: center;
  }

  .footer_info .flex_box {
    display: block;
  }

  .footer_info .flex_box .footer_address:last-child {
    margin-left: 0;
    padding-left: 0;
    margin-top: 3vw;
    padding-top: 3vw;
    border-left: unset;
    border-top: 1px solid #D5D5D5;
  }

  .footer_tel {
    font-size: 3.59vw;
    line-height: 1.43;
    margin-top: 2.56vw;
    text-align: center;
  }

  .footer_wrap02 {
    margin-top: 5.64vw;
    width: 100%;
  }

  .footer_meta {
    align-items: center;
    flex-direction: column;
    gap: 5.9vw;
  }

  .footer_badge {
    width: min(100%, 41.28vw);
  }

  .footer_links_item {
    font-size: 3.33vw;
  }

  .footer_links_item:first-of-type {
    padding-right: 4.87vw;
  }

  .footer_links_item:first-of-type::after {
    height: 3.33vw;
  }

  .footer_links_item:last-of-type {
    padding-left: 4.87vw;
  }

  .footer_copyright {
    font-size: 3.08vw;
    margin-top: 5.13vw;
    text-align: center;
  }

  .footer_totop {
    display: none;
  }

  nav.globalMenuSp {
    background: #FAFAF9;
    display: block;
    height: 100vh;
    left: 0;
    overflow-y: scroll;
    padding: 27.44vw 5.13vw 7.69vw;
    position: fixed;
    top: 0;
    transform: translateX(100%);
    transition: all 0.6s;
    width: 100%;
    z-index: 3000;
  }

  .globalMenuSp_container {
    position: relative;
    z-index: 1;
  }

  nav.globalMenuSp.is_open {
    transform: translateX(0%);
  }

  .globalMenuSp_heading {
    align-items: center;
    display: flex;
    font-family: "Roboto", sans-serif;
    font-size: 6.15vw;
    font-weight: 900;
    justify-content: space-between;
    letter-spacing: 0.04em;
    line-height: 1.33;
  }

  .globalMenuSp_heading::before,
  .globalMenuSp_heading::after {
    background-image: linear-gradient(to right, #333333 50%, transparent 50%);
    background-repeat: repeat-x;
    background-size: 12px 6px;
    content: "";
    height: 0.51vw;
    margin-top: 0.77vw;
    width: 20.51vw;
  }

  .globalMenuSp_list {
    margin-top: 2.95vw;
  }

  .globalMenuSp_item {
    border-bottom: 1px solid #D3CCBD;
    display: block;
    position: relative;
  }

  .globalMenuSp_trigger {
    align-items: center;
    display: block;
    display: flex;
    font-size: 4.62vw;
    font-weight: 700;
    justify-content: space-between;
    line-height: 1.44;
    padding: 4.36vw 5.13vw 4.1vw;
  }

  .globalMenuSp_trigger::after {
    background: url(./image/icon_arrow07.png) center center/contain no-repeat;
    content: "";
    display: inline-block;
    flex-shrink: 0;
    height: 4.62vw;
    width: 1.79vw;
  }

  .globalMenuSp_trigger01::after {
    background-image: url(./image/icon_box01.png);
    height: 4.1vw;
    margin-right: -0.77vw;
    width: 4.1vw;
  }

  .globalMenuSp_infowrap {
    margin-top: 9.74vw;
  }

  .globalMenuSp_btnwrap {
    text-align: center;
  }

  .globalMenuSp_bottom_links {
    align-items: center;
    display: flex;
    justify-content: center;
    margin-top: 10vw;
  }

  .globalMenuSp_bottom_link {
    color: #333333;
    font-size: 3.33vw;
    font-weight: 500;
    line-height: 1.46;
    padding: 1.28vw 5.13vw;
    position: relative;
  }

  .globalMenuSp_bottom_link:first-of-type::after {
    background: #333333;
    content: "";
    height: 4.36vw;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 0.26vw;
  }

  .globalMenuSp_copyright {
    margin-top: 4.36vw;
    text-align: center;
  }

  .globalMenuSp_copyright small {
    display: block;
    font-size: 3.08vw;
    font-weight: 500;
    line-height: 1.33;
  }

  .hamburger {
    background: #0B3D5C;
    border: none;
    border-radius: 100vh;
    display: block;
    height: 12.82vw;
    padding: 0;
    pointer-events: auto;
    position: fixed;
    right: 2.56vw;
    top: 2.56vw;
    width: 12.82vw;
    z-index: 9999;
  }

  .hamburger_line {
    background: #FFFFFF;
    border-radius: 100vh;
    content: "";
    height: 2px;
    left: 50%;
    position: absolute;
    transform: translateX(-50%);
    transition: 0.5s;
    width: 4.48vw;
  }

  .hamburger_line:nth-of-type(1) {
    top: 4.77vw;
  }

  .hamburger_line:nth-of-type(2) {
    top: 6.26vw;
  }

  .hamburger_line:nth-of-type(3) {
    top: 7.74vw;
  }

  .header_inner {
    padding-inline: 2.56vw;
    width: 100%;
  }

  .header_logo {
    width: min(100%, 34.58vw);
  }

  .header_logo_link {
    padding-block: 4.62vw;
  }

  .header_nav {
    display: none;
  }

  .reason01 {
    padding-block: 25.64vw 33.38vw;
  }

  .reason01::before {
    background-image: url(./image/reason_bg_sp02.png);
    height: 782.17vw;
  }

  .reason01::after {
    background-image: url(./image/reason_bg_sp01.png);
    height: 782.17vw;
    left: 0;
    top: -32.49vw;
    transform: unset;
    width: 100%;
  }

  .reason01_item02 {
    margin-top: 17.95vw;
  }

  .reason01_item03 {
    margin-top: 2.82vw;
  }

  #page_sitemap {
    padding: 10.26vw 0 20.51vw;
  }

  .top_about {
    padding-top: 25.13vw;
  }

  .top_about_text {
    font-size: 3.85vw;
    line-height: 1.73;
    margin-top: 4.36vw;
  }

  .top_about_text01 {
    display: block;
    letter-spacing: 0.04em;
    margin-top: 0.77vw;
  }

  .top_about_text_highlight {
    font-size: 4.62vw;
    line-height: 1.67;
  }

  .top_about_recommend {
    font-size: 4.62vw;
    margin-top: 5.13vw;
    text-align: center;
  }

  .top_about_recommend_line::after {
    background-size: 2.56vw 1.28vw;
    height: 0.51vw;
  }

  .top_about_recommend_highlight {
    font-size: 8.21vw;
    letter-spacing: 0.15em;
    line-height: 1.47;
  }

  .top_about_cards {
    margin-top: 5.13vw;
  }

  .top_about_btn {
    margin-top: 11.03vw;
  }

  .top_flow {
    padding-bottom: 15.92vw;
    padding-top: 23.54vw;
  }

  .top_flow::before {
    background-image: url(./image/top_flow_bg_sp01.png);
    height: 551.07vw;
    top: 0vw;
    width: 100%;
  }

  .top_flow_text {
    font-size: 3.59vw;
    line-height: 1.71;
    margin-top: 5.13vw;
  }

  .top_flow_item {
    margin-top: 6.67vw;
  }

  .top_introduction {
    padding-bottom: 50.26vw;
    padding-top: 11.03vw;
  }

  .top_introduction_text {
    font-size: 3.85vw;
    line-height: 2.27;
    margin-top: 3.85vw;
  }

  .top_introduction_highlight {
    display: inline;
    font-size: 4.62vw;
    line-height: 1.56;
    margin-right: 0;
    padding-left: 2.56vw;
    padding-right: 0vw;
  }

  .top_introduction_highlight01 {
    margin-left: 0;
  }

  .top_introduction_highlight02 {
    margin-right: 0;
  }

  .top_introduction_text01 {
    display: block;
    line-height: 1.87;
    margin-top: 0.77vw;
  }

  .top_introduction_text02 {
    margin-left: 1.28vw;
  }

  .top_introduction_image01 {
    display: none;
  }

  .top_introduction_image02 {
    bottom: unset;
    left: 50%;
    top: 65.9vw;
    transform: translateX(-50%);
    width: min(100%, 56.87vw);
  }

  .top_introduction_image02::before {
    display: none;
  }

  .top_mv {
    padding-top: 22.56vw;
  }

  .top_mv::before {
    background-image: url(./image/top_mv_bg_sp01.png);
    height: 345.36vw;
    top: 37.95vw;
  }

  .top_mv_wrap {
    padding-left: 0;
    width: min(100%, 89.74vw);
  }

  .top_mv_content {
    flex-direction: column;
  }

  .top_mv_textwrap {
    display: contents;
  }

  .top_mv_header {
    flex-direction: column;
    gap: 1.79vw;
    order: 1;
    width: 100%;
  }

  .top_mv_header_logo {
    width: 27.44vw;
  }

  .top_mv_header_text {
    font-size: 3.4vw;
    line-height: 1.42;
    text-align: center;
	width: 100%;
  }

  .top_mv_main {
    margin-top: 5.18vw;
    order: 3;
  }

  .top_mv_main_text01 {
    font-size: 5.13vw;
    letter-spacing: 0em;
    line-height: 1.45;
    text-align: center;
  }

  .top_mv_main_text01_dot::after {
    background-image: radial-gradient(circle, #333333 0.38vw, transparent 0.38vw);
    background-size: 5.13vw 0.77vw;
    height: 0.77vw;
    top: -0.51vw;
  }

  .top_mv_main_text02 {
    font-size: 9.23vw;
    line-height: 1.33;
    margin-inline: -1.28vw -5.13vw;
    margin-top: 0vw;
    text-align: center;
    width: 96.92vw;
  }

  .top_mv_main_text02_highlight {
    display: inline-block;
    font-size: 11.79vw;
    letter-spacing: 0.04em;
    line-height: 1.04;
    margin-right: 0;
  }

  .top_mv_main_kintone_support {
    font-size: 6.15vw;
    line-height: 1.5;
  }

  .top_mv_main_text03 {
    font-size: 4.1vw;
    letter-spacing: 0.2em;
    line-height: 1.5;
    margin-top: 3.59vw;
    text-align: center;
  }

  .top_mv_main_btn {
    margin-top: 7.18vw;
  }

  .top_mv_main_image {
    margin-top: 3.08vw;
    order: 2;
    width: 100%;
  }

  .top_mv_main_image img {
    aspect-ratio: 350/260.84;
  }

  .top_mv_cards {
    margin-right: calc(50% - 50vw);
    margin-top: 7.95vw;
    padding: 2.95vw 0vw 2.95vw 3.85vw;
  }

  .top_mv_cards_swiper .swiper-wrapper {
    animation: loop 80s linear infinite;
    padding: 0.77vw;
  }

  .top_mv_cards_swiper .swiper-slide {
    margin-left: 2.56vw;
    width: 38.46vw;
  }

  .top_mv_cards_swiper .swiper-slide:first-child {
    margin-left: 0;
  }

  .top_mv_card {
    border-radius: 5.13vw;
    padding: 6.41vw 3.85vw 7.69vw;
  }

  .top_mv_card_img {
    max-width: 38.46vw;
  }

  .top_mv_card_text {
    font-size: 3.33vw;
    line-height: 1.69;
    margin-top: 3.85vw;
  }

  .top_price {
    padding-block: 35.9vw 10.26vw;
  }

  .top_price_text {
    font-size: 3.59vw;
    line-height: 1.71;
    margin-top: 4.62vw;
  }

  .top_price_main_title {
    font-size: 6.67vw;
    line-height: 1.42;
    margin-top: 7.69vw;
    text-align: center;
  }

  .top_price_main_title::before,
  .top_price_main_title::after {
    bottom: 4.1vw;
    height: 20.51vw;
    width: 0.51vw;
  }

  .top_price_main_title::before {
    left: -10vw;
    rotate: -19deg;
  }

  .top_price_main_title::after {
    right: -10vw;
    rotate: 19deg;
  }

  .top_price_main_title_unit {
    line-height: 1;
    padding-left: 4.62vw;
    padding-right: 0;
  }

  .top_price_main_title_unit::before,
  .top_price_main_title_unit::after {
    font-size: 6.15vw;
    top: 4.36vw;
  }

  .top_price_main_title_unit::before {
    left: 0vw;
  }

  .top_price_main_title_unit::after {
    right: -4.87vw;
  }

  .top_price_main_title_highlight {
    font-size: 15.38vw;
    line-height: 1.38;
    margin-right: -1.28vw;
    padding-right: 0;
    vertical-align: sub;
  }

  .top_price_main_title01 {
    display: inline-block;
    margin-right: 4.87vw;
    margin-top: -3.33vw;
  }

  .top_price_main_subtitle {
    font-size: 3.85vw;
    line-height: 1.47;
    margin-top: -2.31vw;
  }

  .top_price_main_subtitle_small {
    font-size: 3.33vw;
    line-height: 1.69;
  }

  .top_price_boxes {
    display: grid;
    gap: 11.74vw 5.13vw;
    grid-template-columns: repeat(2, 1fr);
    margin-top: 4.36vw;
  }

  .top_price_box {
    border-radius: 2.56vw;
    width: 100%;
  }

  .top_price_box::after {
    display: none;
  }

  .top_price_box:last-of-type::after {
    display: inline-block;
    height: 7.09vw;
    left: 50%;
    top: -9.14vw;
    transform: translateX(-50%);
    width: 7.09vw;
  }

  .top_price_box01 {
    grid-column: span 2;
  }

  .top_price_box_title {
    border-radius: 2.56vw 2.56vw 0 0;
    font-size: 4.62vw;
    line-height: 1.44;
    padding-block: 1.79vw;
  }

  .top_price_box_title_small {
    font-size: 3.33vw;
    line-height: 1.46;
    padding-block: 2.69vw;
  }

  .top_price_box_price {
    padding: 1.79vw 2.56vw 2.56vw;
  }

  .top_price_box_text {
    display: block;
  }

  .top_price_box_text_line {
    background-image: linear-gradient(to bottom, transparent 0%, transparent 70%, #FFED8E 70%, #FFED8E 95%, transparent 95%, transparent 100%);
  }

  .top_price_box_price_num {
    display: inline-block;
    font-size: 19.23vw;
    line-height: 1;
  }

  .top_price_box_price_unit {
    font-size: 7.18vw;
    line-height: 1;
    margin-top: 0;
    vertical-align: super;
  }

  .top_price_example {
    border-radius: 5.13vw;
    margin-top: 9.23vw;
    padding: 10.26vw 7.69vw 7.69vw;
  }

  .top_price_example::before {
    border-radius: 0 0 5.13vw 5.13vw;
    height: 2.56vw;
    left: 50%;
    top: 0;
    transform: translateX(-50%);
    width: 58.97vw;
  }

  .top_price_examplewrap {
    flex-direction: column;
    gap: 8.46vw;
  }

  .top_price_exampleblock01 {
    margin-top: 0vw;
  }

  .top_price_example_title {
    font-size: 5.64vw;
    line-height: 1.45;
    margin-left: 1.54vw;
    text-align: center;
  }

  .top_price_example_dots {
    height: 1.54vw;
    margin-inline: auto;
    margin-top: 2.31vw;
    width: min(100%, 9.74vw);
  }

  .top_price_example_list {
    margin-top: 4.1vw;
  }

  .top_price_example_list_item {
    gap: 3.59vw;
  }

  .top_price_example_list_item+.top_price_example_list_item {
    margin-top: 0.77vw;
  }

  .top_price_example_icon {
    height: 7.69vw;
    width: 7.69vw;
  }

  .top_price_example_icon img {
    width: 3.59vw;
  }

  .top_price_example_text {
    font-size: 4.1vw;
    line-height: 1.5;
  }

  .top_price_example_text_big {
    font-size: 6.67vw;
    line-height: 1.42;
  }

  .top_price_example_caution {
    font-size: 3.33vw;
    line-height: 1.54;
    margin-top: 0.51vw;
    padding-left: 11.28vw;
  }

  .top_price_example_list_highlight {
    font-size: 4.62vw;
    line-height: 1.8;
  }

  .top_price_example_list_small {
    font-size: 2.82vw;
    line-height: 1.8;
  }

  .top_price_example_calc {
    padding-block: 5.13vw;
    padding-inline: 4.1vw;
  }

  .top_price_example_calc+.top_price_example_calc {
    margin-top: 5.13vw;
  }

  .top_price_example_calc_label {
    font-size: 3.59vw;
    line-height: 1.4;
    margin-bottom: 3.08vw;
    padding-block: 1.54vw;
    padding-inline: 3.08vw;
  }

  .top_price_example_calc_tags {
    align-items: stretch;
    flex-direction: column;
    gap: 2.05vw;
    margin-bottom: 2.05vw;
  }

  .top_price_example_calc_tag {
    font-size: 2.82vw;
    line-height: 1.4;
    padding-block: 1.54vw;
  }

  .top_price_example_calc_formula {
    flex-direction: column;
    gap: 2.05vw;
  }

  .top_price_example_calc_num {
    font-size: 6.15vw;
    line-height: 1.4;
  }

  .top_price_example_calc_unit {
    font-size: 3.59vw;
    line-height: 1.4;
  }

  .top_price_example_calc_symbol {
    font-size: 5.13vw;
    line-height: 1.4;
  }

  .top_price_example_calc_note {
    font-size: 3.33vw;
    line-height: 1.8;
    margin-top: 3.08vw;
  }

  .top_price_example_calc_note_price {
    font-size: 5.13vw;
    line-height: 1.4;
  }

  .top_price_example_calc_note_unit {
    font-size: 3.59vw;
    line-height: 1.4;
  }

  .top_price_example_item+.top_price_example_item {
    margin-top: 8.72vw;
  }

  .top_qa {
    padding-block: 10.49vw 33.13vw;
  }

  .top_qa::before {
    background-image: url(./image/top_qa_sp01.png);
    height: 549.74vw;
  }

  .top_qa_wrap {
    max-width: 94.87%;
  }

  .top_qa_item {
    margin-top: 5.13vw;
  }

  .top_reason {
    padding-top: 18.97vw;
  }

  .top_reason::before {
    background: url(./image/top_reason_bg_sp01.png) center center/100% 100% no-repeat;
    height: 484.46vw;
    top: 0;
    width: 100%;
  }

  .top_reason::after {
    display: none;
  }

  .top_reason_headline {
    margin-inline: -1.54vw;
  }

  .top_reason_item {
    margin-top: 15.9vw;
  }

  .top_reason_media {
    flex-direction: column;
  }

  .top_reason_media01 {
    gap: 3.95vw;
    margin-right: 0;
  }

  .top_reason_media02 {
    gap: 0;
    margin-top: 14.62vw;
  }

  .top_reason_media03 {
    gap: 0;
    margin-right: 0;
    margin-top: 13.08vw;
  }

  .top_reason_media_body {
    width: 100%;
  }

  .top_reason_media_body01 {
    margin-top: 0vw;
  }

  .top_reason_media_tag {
    border-radius: 4.62vw 4.62vw 0vw 4.62vw;
    gap: 0.77vw;
    padding: 1.54vw 3.59vw;
  }

  .top_reason_media_tag_small {
    font-size: 3.33vw;
  }

  .top_reason_media_tag_big {
    font-size: 5.64vw;
  }

  .top_reason_media_head {
    font-size: 5.5vw;
    line-height: 1.42;
    margin-top: 3.08vw;
  }

  .top_reason_media_txt {
    font-size: 3.59vw;
    line-height: 1.71;
    margin-top: 4.87vw;
    width: 100%;
  }

  .top_reason_media_img01 {
    margin-inline: auto;
    margin-top: 0;
    width: min(100%, 57.72vw);
  }

  .top_reason_media_img01::before {
    height: 61.54vw;
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 61.54vw;
  }

  .top_reason_media_img02 {
    margin-inline: auto;
    margin-top: 0;
    width: min(100%, 58.96vw);
  }

  .top_reason_media_img02::before {
    height: 61.54vw;
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 61.54vw;
  }

  .top_reason_media_img03 {
    margin-left: 31.44vw;
    width: min(100%, 45.34vw);
  }

  .top_reason_media_img03::before {
    height: 61.54vw;
    left: -18.49vw;
    top: -0.97vw;
    width: 61.54vw;
  }

  .top_reason_btn {
    margin-top: 12.05vw;
  }

  .top_solution {
    padding-block: 5.23vw 0;
  }

  .top_solution::before {
    background-image: url(./image/top_solution_bg_sp01.png);
    height: 280.69vw;
    top: -12.05vw;
    width: 100%;
  }

  .top_solution_arrow {
    width: min(100%, 16.92vw);
  }

  .top_solution_headline {
    margin-inline: calc(50% - 50vw);
    margin-top: 4.36vw;
    padding-right: 1.79vw;
  }

  .top_solution_headline_sub {
    font-size: 4vw;
    line-height: 1.44;
  }

  .top_solution_headline_main {
    font-size: 6.67vw;
    line-height: 1.23;
    padding-left: 3.08vw;
  }

  .top_solution_headline_main_small {
    font-size: 4.62vw;
  }

  .top_solution_media {
    flex-direction: column-reverse;
    margin-top: 5.15vw;
    padding-left: 0;
  }

  .top_solution_media_img {
    margin-left: auto;
    margin-right: -2.56vw;
    margin-top: -3.08vw;
    width: min(100%, 40.5vw);
  }

  .top_solution_media_body {
    width: 100%;
  }

  .top_solution_text+.top_solution_text {
    margin-top: 6.41vw;
  }

  .top_solution_text01 {
    font-size: 3.59vw;
    line-height: 1.86;
  }

  .top_solution_text02 {
    font-size: 4.1vw;
    line-height: 1.63;
  }

  .top_voice {
    padding-block: 18.46vw 14.62vw;
  }

  .top_voice .swiper-wrapper {
    display: flex;
    gap: 2.56vw;
  }

  .top_voice_text {
    font-size: 3.59vw;
    line-height: 1.71;
    margin-top: 4.62vw;
  }

  .top_voice_item {
    -ms-overflow-style: none;
    margin-right: calc(50% - 50vw);
    margin-top: 6.67vw;
    overflow: scroll;
    padding-inline: 0;
    scrollbar-width: none;
  }

  .top_voice_item::-webkit-scrollbar {
    display: none;
  }

  .top_voice_swiperbtns {
    display: none;
  }

  .top_voice_scroll {
    display: block;
    height: 100%;
    left: 0;
    pointer-events: none;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 10;
  }

  .top_voice_scroll_hint {
    align-items: center;
    animation: scrollHintSwing 1.5s ease-in-out infinite;
    display: flex;
    justify-content: center;
    left: 50%;
    opacity: 1;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    transition: opacity 0.3s ease;
    width: min(100%, 35.9vw);
  }

  .top_voice_scroll_hint img {
    -o-object-fit: contain;
    aspect-ratio: 140/110;
    height: auto;
    object-fit: contain;
    width: 100%;
  }
}

@media (any-hover: hover) {
  .common_btn01:hover {
    background: #517084;
  }

  .common_btn01:hover .common_btn01_icon {
    right: 25px;
    width: 34px;
  }

  .common_btn01:hover svg {
    stroke: #517084;
  }

  .common_btn02__link:hover {
    background: #517084;
  }

  .common_btn02__link:hover .common_btn02__icon01 {
    border-color: #517084;
  }

  .common_btn02__link:hover .common_btn02__icon02 {
    right: 26px;
    width: 34px;
  }

  .common_btn02__link:hover .common_btn02__icon02 svg path {
    stroke: #517084;
  }

  .common_btn03:hover {
    background: #F7A541;
  }

  .common_btn03:hover .common_btn03_icon {
    right: 26px;
    width: 34px;
  }

  .common_btn03:hover svg path {
    stroke: #F7A541;
  }

  .common_btn04__link:hover {
    background: #FFFFFF;
  }

  .common_btn04__link:hover .common_btn04__text {
    color: #EB8800;
  }

  .common_btn04__link:hover .common_btn04__icon02 {
    background: #EB8800;
    right: 25px;
    width: 34px;
  }

  .common_btn04__link:hover .common_btn04__icon02 svg path {
    stroke: #FFFFFF;
  }

  .common_btn05:hover {
    background: #F7A541;
  }

  .common_btn05:hover .common_btn05_icon {
    right: 25px;
    width: 34px;
  }

  .common_btn05:hover svg path {
    stroke: #F7A541;
  }

  .common_btn06:hover {
    opacity: 0.7;
  }

  .common_card02_link:hover .common_card02_img img {
    aspect-ratio: 350/200;
    border-radius: 16px;
    width: 97.22%;
  }

  .common_card02_link:hover .common_card02_title_text {
    background-size: 100% 1px;
  }

  .common_card02_link:hover .common_card02_icon {
    background: #FFFFFF;
  }

  .common_card02_link:hover .common_card02_icon svg line,
  .common_card02_link:hover .common_card02_icon svg path {
    stroke: #E29F14;
  }

  .common_lower_mv_breadcrumb a:hover {
    opacity: 0.7;
  }

  .footer_link:hover {
    color: #E6830A;
  }

  .footer_link:hover::before {
    background-image: url(./image/icon_arrow10.png);
  }

  .footer_link01:hover::after {
    background-image: url(./image/icon_box02.png);
  }

  .footer_links_item:hover {
    opacity: 0.7;
  }

  .footer_totop:hover {
    opacity: 0.7;
  }

  .footer_logo:hover {
    opacity: 0.7;
  }

  .header_link:hover .header_link_text {
    color: #E6830A;
  }

  .header_link:hover .header_link_text::before {
    transform: scaleX(1);
  }

  .header_logo_link:hover {
    opacity: 0.7;
  }

  .top_voice_swiperbtn_prev:hover {
    left: -5px;
  }

  .top_voice_swiperbtn_prev:hover.swiper-button-disabled {
    left: 0;
  }

  .top_voice_swiperbtn_next:hover {
    right: -5px;
  }

  .top_voice_swiperbtn_next:hover.swiper-button-disabled {
    right: 0;
  }
}

/*# sourceMappingURL=sourcemaps/style.css.map */