@charset "UTF-8";

/* ==========================================================================
   ベースリセット & 共通設定
   ========================================================================== */
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
}

body {
  font-family: 'Zen Kaku Gothic New', sans-serif;
  color: #333;
  line-height: 1.6;
  background-color: #e0f2fe;
  /* 万が一画像が読み込めない時の背景色 */
}

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

.img-responsive {
  width: 100%;
  display: block;
}

/* ==========================================================================
   ホバーで浮き上がる共通アニメーションクラス（.upmotion）
   ========================================================================== */
.upmotion {
  transition: transform 0.2s ease, opacity 0.2s ease !important;
  cursor: pointer;
}

.upmotion:hover {
  opacity: 0.85;
  will-change: transform;
  transform: perspective(1px) translateZ(0) translateY(-4px) !important;
}

.upmotion:active {
  opacity: 0.85;
}

/* ==========================================================================
   背景画像
   ========================================================================== */
#global-bg {
  width: 100%;
  height: 100vh;
  background-image: url('../img/pc_bg_img.png');
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: cover;
  position: relative;
  overflow-x: hidden;
}

/* ==========================================================================
   コンテンツ全体のラッパー（最大幅1280px、中央寄せ）
   ========================================================================== */
#lp-wrapper {
  position: relative;
  max-width: 1280px;
  width: 100%;
  min-height: 100vh;
  margin: 0 auto;
}

/* ==========================================================================
   左サイドナビゲーション
   ========================================================================== */
.side-nav {
  position: fixed;
  top: 126px;
  left: 125px;
  width: 208px;
  z-index: 10;
  left: 50%;
  margin-left: -530px;

}

.side-nav ul {
  list-style: none;
}

.side-nav li {
  margin-bottom: 32px;
}

.side-nav a {
  text-decoration: none;
  color: #02074266;
  font-weight: bold;
  font-size: 1rem;
  transition: color 0.3s, opacity 0.3s;
  opacity: 1;
  display: inline-block;
}

.side-nav a:hover {
  color: #031948;
}

.side-nav a.is-active {
  color: #031948 !important;
}

/* ==========================================================================
   右サイドウィジェット（画像バナー）
   ========================================================================== */
.side-widgets {
  position: fixed;
  top: 160px;
  right: 40px;
  width: 352px;
  z-index: 10;
  right: auto;
  left: 50%;
  margin-left: 260px;
}

.side-widgets a {
  display: block;
  transition: transform 0.2s, opacity 0.2s;
}

.side-widgets a:hover {
  transform: translateY(-3px);
  opacity: 0.9;
}

.banner-set {
  margin-bottom: 40px;
}

.banner-set a {
  display: block;
  cursor: pointer;
  transition: opacity 0.2s ease;
}

.banner-set a:hover,
.banner-set a:active {
  opacity: 0.85;
}

.btn-line-fix {
  width: 100%;
}

/* ==========================================================================
   【PC・タブレット表示時】中央メインコンテンツ（393px固定）
   ========================================================================== */
#main-contents,
.company-footer_container {
  width: 393px;
  margin: 0 auto;
  background-color: #ffffff;
  box-shadow: 0 0 25px rgba(0, 0, 0, 0.15);
  position: relative;
  z-index: 2;
}

#main-contents {
  min-height: 100vh;
}

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

/* ==========================================================================
   追従ヘッダー
   ========================================================================== */
.site-header {
  position: fixed;
  width: 100%;
  max-width: 393px;
  background-color: rgba(255, 255, 255, 0.95);
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
  z-index: 100;
}

.header-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding: 6.5px 12px;
  box-sizing: border-box;
}

/* ==========================================================================
   ロゴ（logo）スタイルの最適化
   ========================================================================== */
.logo {
  width: 141.7px;
  height: auto;
}

.logo img {
  width: 100%;
  height: auto;
  display: block;
}

.header-cta {
  width: 193px;
  height: auto;
}

.header-cta a {
display:block;
}

/* ==========================================================================
   安心の明朗会計セクション
   ========================================================================== */
.accounting-box {
  background: linear-gradient(to right, #0463C8 0%, #023062 100%);
  padding-top: 8px;
  padding-bottom: 14px;
  padding-inline: 7.63%;
  text-align: center;
  position: relative;
}

.accounting-title-wrap {
  margin-bottom: 8px;
}

.accounting-title {
  font-family: 'Shippori Mincho', serif;
  font-size: 1rem;
  font-weight: 800;
  color: #ffffff;
  letter-spacing: 0.02em;
  line-height: 1.3;
}

.accounting-line {
  width: 100%;
  max-width: 224px;
  margin: 6px auto 0;
}

.accounting-line img {
  width: 100%;
  display: block;
}

.accounting-grid {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 14px;
}

.accounting-card {
  flex: 1;
}

.accounting-card img {
  width: 100%;
  display: block;
}

.accounting-footer {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  padding-left: 20px;
}

.deco-icon {
  position: absolute;
  left: 16px;
  top: -10px;
  width: 26px;
}

.deco-icon img {
  width: 100%;
  display: block;
}

.accounting-note {
  font-family: 'Shippori Mincho', serif;
  font-size: 1rem;
  font-weight: 800;
  color: #ffffff;
  letter-spacing: 0.02em;
  white-space: nowrap;
}

/* ==========================================================================
   【新設】バナーセクション（PC時：393pxのなかで352pxで配置）
   ========================================================================== */
.banner-section {
  background-color: #ffffff;
  padding: 24px 0;
}

.banner-inner {
  width: 352px;
  margin: 0 auto;
}

.banner-inner a {
  display: block;
  cursor: pointer;
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.banner-inner a:hover {
  opacity: 0.85;
  transform: translateY(-4px);
}

.banner-inner a:active {
  opacity: 0.85;
}

/* ==========================================================================
   スライダーセクション (Splide カスタマイズ完全版)
   ========================================================================== */
.slider-section {
  padding: 30px 0 110px;
  background-image: url('../img/cleaning-case_bg_img.png');
  background-repeat: no-repeat;
  background-size: cover;
  text-align: center;
}

.slider-section .slider-header {
  margin-bottom: 13px;
  font-family: 'Shippori Mincho', serif;
  font-weight: 800;
  color: #031948;
}

.slider-section .slider-sub {
  font-size: 1.1875rem;
  line-height: 1;
}

.slider-section .slider-main {
  font-size: 1.375rem;
  line-height: 1.5;
  margin-bottom: 27px;
}

.slider-section .slider-main span {
  font-size: 1.625rem;
}

.slider-section .slider-title {
  font-size: 1.5rem;
}

.slider-inner {
  width: 333px;
  margin: 0 auto 30px;
}

.splide {
  width: 100%;
}

.splide__slide img {
  width: 100%;
  height: auto;
  display: block;
}

/* --------------------------------------------------------------------------
   矢印とドットのカスタム配置
   -------------------------------------------------------------------------- */
.splide__arrows {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-top: 16px !important;
  gap: 40px !important;
}

.splide__arrow--prev {
  order: 1 !important;
}

.splide__pagination {
  position: static !important;
  transform: none !important;
  display: flex !important;
  gap: 24px !important;
  padding: 0 !important;
  margin: 0 !important;
  order: 2 !important;
  width: auto !important;
}

.splide__arrow--next {
  order: 3 !important;
}

.splide__arrow {
  position: static !important;
  transform: none !important;
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  cursor: pointer !important;
  line-height: 1 !important;
  border-radius: 0 !important;
  opacity: unset !important;
  width: 14px !important;
  height: auto !important;
}

.splide__arrow img {
  width: 100%;
  height: auto;
  display: block;
}

.splide__arrow:disabled {
  opacity: 0.2 !important;
  cursor: default !important;
}

.splide__arrow svg {
  display: none !important;
}

.splide__pagination__page {
  width: 8px !important;
  height: 8px !important;
  background: #d1d5db;
  opacity: 1 !important;
  margin: 0 !important;
  border: none !important;
  border-radius: 50% !important;
  cursor: pointer;
}

.splide__pagination__page.is-active {
  background: #0365bf !important;
  transform: scale(1) !important;
}

.slider-footer {
  font-family: 'Shippori Mincho', serif;
  font-weight: 800;
  color: #023062;
}

.catch-phrase-wrap {
  position: relative;
  display: inline-block;
}

.catch-phrase {
  font-size: 1.625rem;
  position: relative;
  z-index: 2;
}

.phrase-suffix {
  font-size: 1.1875rem;
}

.yellow-line {
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 85%;
  height: auto;
  z-index: 1;
}

.yellow-line img {
  width: 100%;
  display: block;
}

.footer-note {
  font-size: 1.1875rem;
}

.voice_popular-set_bg {
  background-image: url('../img/voice_bg2.png');
  background-repeat: no-repeat;
  background-position: center top;
  background-size: cover;
  padding-bottom: 120px;
}

/* --------------------------------------------------------------------------
  voiceセクション　（スライダーのスタイルは上記のsliderセクションと同様）
   -------------------------------------------------------------------------- */
.voice-section {
  padding: 0px 0 60px;
  position: relative;
  text-align: center;
}

.voice-line-btn {
  width: 307px;
  position: absolute;
  top: -74px;
  left: 50%;
  transform: translateX(-50%);
}

.voice-line-btn a {
  display: block;
}

.voice-line-btn img {
  width: 100%;
  display: block;
}

.voice-header {
  margin-bottom: 15px;
  font-family: 'Shippori Mincho', serif;
  font-weight: 800;
  color: #031948;
}

.voice-sub {
  font-size: 1.25rem;
  line-height: 1.4;
  margin-bottom: 5px;
}

.voice-title {
  font-size: 1.5rem;
  line-height: 1.3;
}

.voice-section .splide__pagination__page {
  background: #e5e7eb !important;
}

.voice-section .splide__pagination__page.is-active {
  background: #D97D00 !important;
  transform: scale(1) !important;
}

.voice-citation {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 0.75rem;
  font-weight: 400;
  width: 333px;
  text-align: left;
  line-height: 1.4;
  word-break: break-all;
  margin-top: 10px;
}

.voice-citation a {
  color: #333;
  text-decoration: none;
}

.voice-citation a:hover {
  text-decoration: underline;
}

.yellow-line-voice {
  width: 95%;
}

.voice-footer {
  color: #031948;
}

.catch-phrase {
  font-size: 1.625rem;
}

.footer-note {
  font-size: 1.1875rem;
}

/* --------------------------------------------------------------------------
 人気セットセクション　（スライダーのスタイルは上記のsliderセクションと同様）
   -------------------------------------------------------------------------- */
.popular-section {
  padding: 40px 0 50px;
  text-align: center;
  position: relative;
}

.popular-line-btn {
  width: 307px;
  position: absolute;
  top: -30px;
  left: 50%;
  transform: translateX(-50%);
}

.popular-line-btn-footer {
  width: 307px;
  position: absolute;
  bottom: -15px;
  left: 50%;
  transform: translateX(-50%);
}

.popular-line-btn a,
.popular-line-btn-footer a {
  display: block;
}

.popular-line-btn img,
.popular-line-btn-footer img {
  width: 100%;
  display: block;
}

.popular-header {
  margin-top: 8px;
  margin-bottom: 13px;
  font-family: 'Shippori Mincho', serif;
  font-weight: 800;
  color: #031948;
}

.popular-title {
  font-size: 1.5rem;
  line-height: 1.4;
}

.popular-main {
  font-size: 1.5rem;
  /* 24px */
  line-height: 1.3;
}

.popular-main .red-text {
  font-size: 2.125rem;
  color: #F43106;
  margin-left: 2px;
}

.popular-section .splide__pagination__page {
  background: #d1d5db !important;
}

.popular-section .splide__pagination__page.is-active {
  background: #0365bf !important;
  transform: scale(1) !important;
}

/* --------------------------------------------------------------------------
 選ばれる理由セクション　
   -------------------------------------------------------------------------- */
.reason-step {
  background-image: url('../img/reason_bg.png');
  background-repeat: no-repeat;
  background-position: center top;
  background-size: cover;
  margin-top: -85px;
}

.reason-section {
  padding: 50px 0 0px 0;
  text-align: center;
  position: relative;
  z-index: 1;
}

.reason-section .reason-header {
  margin-bottom: 15px;
  margin-right: 70px;
}

.reason-section .reason-main-title {
  font-family: 'Shippori Mincho', serif;
  font-size: 1.375rem;
  font-weight: 800;
  color: #031948;
  line-height: 1.4;
}

.reason-section .reason-list {
  width: 333px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.reason-section .reason-item {
  width: 100%;
}

.reason-section .reason-item img {
  width: 100%;
  height: auto;
  display: block;
}

/* ==========================================================================
   洗浄作業工程（flow）セクション
   ========================================================================== */
.flow-section {
  padding: 50px 0 70px 0;
  position: relative;
  text-align: center;
  overflow: clip;
  z-index: 2;
}

.flow-section .flow-splash-top {
  position: absolute;
  top: -14px;
  left: -9px;
  width: 140px;
  z-index: 10;
}

.flow-section .flow-splash-bottom {
  position: absolute;
  bottom: -35px;
  right: 0px;
  width: 230px;
  z-index: 30;
}

.flow-section .flow-splash-top img,
.flow-section .flow-splash-bottom img {
  width: 100%;
  height: auto;
  display: block;
}

.flow-section .flow-header {
  margin-bottom: 13px;
  position: relative;
  z-index: 2;
}

.flow-section .flow-title {
  font-family: 'Shippori Mincho', serif;
  font-size: 1.5rem;
  font-weight: 700;
  color: #031948;
  line-height: 1.3;
}

.flow-section .flow-container {
  width: 333px;
  margin: 0 auto;
  padding: 21px 13px;
  background-color: #B8DEFF;
  border-radius: 7px;
  box-sizing: border-box;
  position: relative;
  z-index: 20;
}

.flow-section .flow-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 7px;
}

.flow-section .flow-item {
  width: 275px;
  margin: 0 auto;
}

.flow-section .flow-item img {
  width: 100%;
  height: auto;
  display: block;
}

.flow-section .flow-footer-box {
  width: 100%;
  padding: 18px 10px;
  box-sizing: border-box;
  border-radius: 6px;
  background-color: #ffffff;
  box-shadow: inset 0px 0px 22px 0px #FFFBE0;
}

.flow-section .flow-footer-text {
  font-family: 'Shippori Mincho', serif;
  font-size: 1.125rem;
  font-weight: 800;
  color: #031948;
  line-height: 1.5;
  margin: 0;
}

/* ==========================================================================
   LINE相談（step / talk）セクション（フォントサイズ以外px指定）
   ========================================================================== */
.line-consultation-section {
  padding: 0px 0 80px 0;
  text-align: center;
}

.line-consultation-section .consultation-header {
  margin-bottom: 30px;
}

.line-consultation-section .consultation-sub {
  font-family: 'Shippori Mincho', serif;
  font-size: 1.1875rem;
  font-weight: 700;
  color: #031948;
  line-height: 1.4;
  margin-bottom: 5px;
}

.line-consultation-section .catch-phrase-wrap {
  position: relative;
  display: inline-block;
}

.line-consultation-section .catch-phrase {
  /* 【指定】Shippori Mincho 26px bold */
  font-family: 'Shippori Mincho', serif;
  font-size: 1.625rem;
  font-weight: 700;
  color: #031948;
  line-height: 1.3;
  position: relative;
  z-index: 2;
}

.line-consultation-section .yellow-line {
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 100%;
  height: auto;
  z-index: 1;
}

.line-consultation-section .yellow-line img {
  width: 100%;
  display: block;
}

.line-consultation-section .step-image-wrap {
  width: 333px;
  margin: 0 auto 35px;
}

.line-consultation-section .step-image-wrap img {
  width: 100%;
  height: auto;
  display: block;
}

.line-consultation-section .talk-image-title {
  font-family: 'Shippori Mincho', serif;
  font-size: 1.25rem;
  font-weight: 700;
  color: #031948;
  line-height: 1.4;
  margin-bottom: 20px;
}

.line-consultation-section .talk-image-wrap {
  width: 333px;
  margin: 0 auto 30px;
}

.line-consultation-section .talk-image-wrap img {
  width: 100%;
  height: auto;
  display: block;
}

.consultation-line-btn {
  width: 307px;
  margin: 0 auto;
}

.consultation-line-btn a {
  display: block;
}

.consultation-line-btn img {
  width: 100%;
  display: block;
}

.price {
  padding: 24px 0 24px;
  background-image: url('../img/price_bg_img.png');
  background-repeat: no-repeat;
  background-size: cover;
  text-align: center;
  position: relative;
  z-index: 100;
  margin-top: -48px;
}

.price .price-header {
  margin-bottom: 30px;
  display: flex;
  justify-content: center;
}

.price .price-title-wrap {
  position: relative;
}

.price .price-splash {
  position: absolute;
  top: -96px;
  left: 0px;
  width: 205px;
  height: auto;
  display: block;
}

.price .price-title {
  font-family: 'Shippori Mincho', serif;
  font-size: 1.625rem;
  font-weight: 800;
  color: #031948;
  line-height: 1.3;
  letter-spacing: 0.05em;
  position: relative;
  z-index: 2;
}

.price .price-list {
  width: 333px;
  margin: 15px auto 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: relative;
  z-index: 500;
}

.price .price-item {
  width: 100%;
}

.price .price-item img {
  width: 100%;
  height: auto;
  display: block;
}

/* ==========================================================================
   よくあるご質問（faq）セクション（フォントサイズ以外px指定）
   ========================================================================== */
.faq-section {
  padding: 24px 0 27px 0;
  background-color: #FFF9DA;
  text-align: center;
}

.faq-section .faq-header {
  margin-bottom: 13px;
}

.faq-section .faq-title {
  font-family: 'Shippori Mincho', serif;
  font-size: 1.625rem;
  font-weight: 700;
  color: #031948;
  line-height: 1.3;
  letter-spacing: 0.05em;
}

.faq-section .faq-container {
  width: 333px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.faq-section .faq-item {
  width: 100%;
  text-align: left;
  border-radius: 6px;
  overflow: hidden;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

.faq-section .faq-question {
  background-color: #FFA230;
  padding: 8px 40px 8px 8px;
  position: relative;
  display: flex;
  align-items: flex-start;
  cursor: pointer;
  user-select: none;
}

.faq-section .faq-q-icon {
  font-family: 'Zen Kaku Gothic New', sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: #ffffff;
  margin-right: 8px;
  line-height: 1.1;
}

.faq-section .faq-q-text {
  font-family: 'Zen Kaku Gothic New', sans-serif;
  font-size: 0.875rem;
  font-weight: 500;
  color: #031948;
  line-height: 1.4;
  margin: 0;
}

.faq-section .faq-toggle-icon {
  position: absolute;
  top: 50%;
  right: 16px;
  transform: translateY(-50%);
  width: 10px;
  height: 10px;
}

.faq-section .faq-toggle-icon::before {
  content: "";
  position: absolute;
  top: 4px;
  left: 1.5px;
  width: 10px;
  height: 1.5px;
  background-color: #ffffff;
  transition: transform 0.2s ease;
}

.faq-section .faq-toggle-icon::after {
  content: "";
  position: absolute;
  top: 0;
  left: 6px;
  width: 1.5px;
  height: 10px;
  background-color: #ffffff;
  transition: transform 0.2s ease;
}

.faq-section .faq-item.js-open .faq-toggle-icon::after {
  transform: scaleY(0);
}

.faq-section .faq-answer {
  background-color: #ffffff;
  height: 0;
  overflow: hidden;
  transition: height 0.3s ease;
}

.faq-section .faq-item.js-open .faq-answer {
  height: auto;
}

.faq-section .faq-answer-inner {
  padding: 8px 21.5px;
}

.faq-section .faq-a-text {
  font-family: 'Zen Kaku Gothic New', sans-serif;
  font-size: 0.875rem;
  font-weight: 500;
  color: #333333;
  line-height: 1.6;
  margin: 0;
}

/* ==========================================================================
   キャンペーンバナー2（banner2）セクション
   ========================================================================== */
.campaign-banner2-section {
  padding: 24px 0 20px 0;
  background-color: #ffffff;
  display: flex;
  justify-content: center;
}

.campaign-banner2-section .banner2-container {
  width: 355px;
  height: auto;
  position: relative;
  border-radius: 8px;
  overflow: hidden;
}

.campaign-banner2-section .banner2-bg-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.campaign-banner2-section .banner2-btn-wrap {
  position: absolute;
  bottom: 18px;
  left: 4px;
  width: 258px;
  z-index: 10;
}

.campaign-banner2-section .banner2-btn-wrap a {
  display: block;
}

.campaign-banner2-section .banner2-btn-wrap img {
  width: 100%;
  display: block;
}

/* ==========================================================================
   特定商取引法に基づく表記（company）セクション
   ========================================================================== */
.company-section {
  padding: 20px 0 32px 0;
  background-color: #ffffff;
  display: flex;
  justify-content: center;
}

.company-section .company-container {
  width: 332px;
  background-color: #E8E8E8;
  border-radius: 5px;
  padding: 24px 12px;
  box-sizing: border-box;
  text-align: center;
}

.company-section .company-title {
  display: inline-block;
  width: 100%;
  background-color: #ffffff;
  color: #231815;
  font-family: 'Zen Kaku Gothic New', sans-serif;
  font-size: 1rem;
  font-weight: 500;
  border-radius: 5px;
  padding: 8px 18px;
  margin: 0 0 16px 0;
  line-height: 1.2;
}

.company-section .company-list {
  margin: 0;
  padding: 0 13.5px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.company-section .company-row {
  display: flex;
  align-items: flex-start;
  text-align: left;
}

.company-section .company-list dt {
  width: 100px;
  flex-shrink: 0;
  font-family: 'Zen Kaku Gothic New', sans-serif;
  font-size: 0.9375rem;
  font-weight: 500;
  color: #000000;
  line-height: 1.4;
}

.company-section .company-list dd {
  margin: 0;
  flex-grow: 1;
  font-family: 'Zen Kaku Gothic New', sans-serif;
  font-size: 0.9375rem;
  font-weight: 400;
  color: #000000;
  line-height: 1.4;
}

/* ==========================================================================
   フッター（footer）セクション
   ========================================================================== */
.site-footer {
  padding: 16px 0;
  background-color: #031948;
  text-align: center;
  width: 100%;
}

.site-footer .copyright {
  font-family: 'Shippori Mincho', serif;
  font-size: 0.625rem;
  font-weight: 700;
  color: #ffffff;
  line-height: 1;
  letter-spacing: 0.02em;
  display: block;
}

/* ==========================================================================
   responsive（レスポンシブ）スタイル
   ========================================================================== */

@media (max-width: 1279px) {
  .side-widgets {
    width: calc((300 / 1280) * 100vw);
    right: calc((50 / 1280) * 100vw);
    left: unset;
    margin-left: unset;
  }

  .side-nav {
    left: calc((95 / 1280) * 100vw);
    margin-left: unset;
  }
}

@media (max-width: 1000px) {

  .side-nav,
  .side-widgets {
    display: none;
  }
}

/* ==========================================================================
   【最重要】画面幅が 393px 以下になったときの流体レスポンシブ処理
   ========================================================================== */
@media (max-width: 393px) {

  #main-contents,
  .company-footer_container {
    width: 100vw;
    box-shadow: none;
  }

  .logo {
    width: calc((141 / 393) * 100vw);
  }

  .header-cta {
    width: calc((193 / 393) * 100vw);
  }

  .accounting-box {
    padding-top: calc((8 / 393) * 100vw);
    padding-bottom: calc((14 / 393) * 100vw);
  }

  .accounting-title-wrap {
    margin-bottom: calc((8 / 393) * 100vw);
  }

  .accounting-title {
    font-size: calc((16 / 393) * 100vw);
  }

  .accounting-line {
    max-width: calc((224 / 393) * 100vw);
    margin-top: calc((6 / 393) * 100vw);
  }

  .accounting-grid {
    gap: calc((8 / 393) * 100vw);
    margin-bottom: calc((14 / 393) * 100vw);
  }

  .accounting-footer {
    padding-left: calc((20 / 393) * 100vw);
  }

  .deco-icon {
    left: calc((16 / 393) * 100vw);
    top: calc((-10 / 393) * 100vw);
    width: calc((26 / 393) * 100vw);
  }

  .accounting-note {
    font-size: calc((16 / 393) * 100vw);
  }

  .banner-section {
    padding: calc((24 / 393) * 100vw) 0;
  }

  .banner-inner {
    width: calc((352 / 393) * 100vw);
  }

  .slider-section {
    padding: calc((30 / 393) * 100vw) 0 calc((110 / 393) * 100vw);
  }

  .slider-inner {
    width: calc((333 / 393) * 100vw);
    margin-bottom: calc((30 / 393) * 100vw);
  }

  .slider-section .slider-header {
    margin-bottom: calc((13 / 393) * 100vw);
  }

  .slider-section .slider-sub {
    font-size: calc((19 / 393) * 100vw);
  }

  .slider-section .slider-main {
    font-size: calc((22 / 393) * 100vw);
    margin-bottom: calc((27 / 393) * 100vw);
  }

  .slider-section .slider-main span {
    font-size: calc((26 / 393) * 100vw);
  }

  .slider-section .slider-title {
    font-size: calc((24 / 393) * 100vw);
  }

  .splide__arrows {
    margin-top: calc((20 / 393) * 100vw) !important;
    gap: calc((40 / 393) * 100vw) !important;
  }

  .splide__arrow {
    width: calc((14 / 393) * 100vw) !important;
  }

  .splide__pagination {
    gap: calc((24 / 393) * 100vw) !important;
  }

  .splide__pagination__page {
    width: calc((8 / 393) * 100vw) !important;
    height: calc((8 / 393) * 100vw) !important;
  }


  .catch-phrase {
    font-size: calc((26 / 393) * 100vw);
  }

  .phrase-suffix {
    font-size: calc((19 / 393) * 100vw);
  }

  .yellow-line {
    bottom: calc((-1 / 393) * 100vw);
  }

  .footer-note {
    font-size: calc((19 / 393) * 100vw);
  }

  .voice_popular-set_bg {
    padding-bottom: calc((120 / 393) * 100vw);
  }

  .voice-section {
    padding: 0 0 calc((60 / 393) * 100vw);
  }

  .voice-line-btn {
    width: calc((307 / 393) * 100vw);
    top: calc((-74 / 393) * 100vw);
  }

  .voice-header {
    margin-bottom: calc((15 / 393) * 100vw);
  }

  .voice-sub {
    font-size: calc((20 / 393) * 100vw);
  }

  .voice-title {
    font-size: calc((24 / 393) * 100vw);
  }

  .voice-citation {
    width: calc((333 / 393) * 100vw);
    margin-top: calc((10 / 393) * 100vw);
    font-size: calc((12 / 393) * 100vw);
  }

  .voice-footer .catch-phrase {
    font-size: calc((26 / 393) * 100vw);
  }

  .voice-footer .footer-note {
    font-size: calc((19 / 393) * 100vw);
    margin-top: calc((8 / 393) * 100vw);
  }

  .popular-section {
    padding: calc((40 / 393) * 100vw) 0 calc((50 / 393) * 100vw);
  }

  .popular-line-btn {
    width: calc((307 / 393) * 100vw);
    top: calc((-30 / 393) * 100vw);
  }

  .popular-line-btn-footer {
    width: calc((307 / 393) * 100vw);
    bottom: calc((-15 / 393) * 100vw);
  }

  .popular-header {
    margin-bottom: calc((13 / 393) * 100vw);
    margin-top: calc((8 / 393) * 100vw);
  }

  .popular-title {
    font-size: calc((24 / 393) * 100vw);
  }

  .popular-main {
    font-size: calc((24 / 393) * 100vw);
  }

  .popular-main .red-text {
    font-size: calc((34 / 393) * 100vw);
  }

  .reason-step {
    margin-top: calc((-85 / 393) * 100vw);
  }

  .reason-section {
    padding: calc((50 / 393) * 100vw) 0 0 0;
  }

  .reason-section .reason-header {
    margin-bottom: calc((15 / 393) * 100vw);
    margin-right: calc((70 / 393) * 100vw);
  }

  .reason-section .reason-main-title {
    font-size: calc((22 / 393) * 100vw);
  }

  .reason-section .reason-list {
    width: calc((333 / 393) * 100vw);
    gap: calc((16 / 393) * 100vw);
  }

  .flow-section {
    padding: calc((50 / 393) * 100vw) 0 calc((70 / 393) * 100vw) 0;
  }

  .flow-section .flow-splash-top {
    top: calc((-14 / 393) * 100vw);
    left: calc((-9 / 393) * 100vw);
    width: calc((140 / 393) * 100vw);
  }

  .flow-section .flow-splash-bottom {
    bottom: calc((-35 / 393) * 100vw);
    width: calc((230 / 393) * 100vw);
  }

  .flow-section .flow-header {
    margin-bottom: calc((13 / 393) * 100vw);
  }

  .flow-section .flow-title {
    font-size: calc((24 / 393) * 100vw);
  }

  .flow-section .flow-container {
    width: calc((333 / 393) * 100vw);
    padding: calc((21 / 393) * 100vw) calc((13 / 393) * 100vw);
    border-radius: calc((7 / 393) * 100vw);
  }

  .flow-section .flow-item {
    width: calc((275 / 393) * 100vw);
  }

  .flow-section .flow-list {
    margin-bottom: calc((7 / 393) * 100vw);
  }

  .flow-section .flow-footer-box {
    padding: calc((18 / 393) * 100vw) calc((10 / 393) * 100vw);
    border-radius: calc((6 / 393) * 100vw);
    box-shadow: inset 0px 0px calc((22 / 393) * 100vw) 0px #FFFBE0;
  }

  .flow-section .flow-footer-text {
    font-size: calc((18 / 393) * 100vw);
  }

  .line-consultation-section {
    padding: 0 0 calc((80 / 393) * 100vw) 0;
  }

  .line-consultation-section .consultation-header {
    margin-bottom: calc((30 / 393) * 100vw);
  }

  .line-consultation-section .consultation-sub {
    font-size: calc((19 / 393) * 100vw);
  }

  .line-consultation-section .catch-phrase {
    font-size: calc((26 / 393) * 100vw);
  }

  .line-consultation-section .yellow-line {
    bottom: calc((-4 / 393) * 100vw);
  }

  .line-consultation-section .step-image-wrap {
    width: calc((333 / 393) * 100vw);
    margin-bottom: calc((35 / 393) * 100vw);
  }

  .line-consultation-section .talk-image-title {
    font-size: calc((20 / 393) * 100vw);
    margin-bottom: calc((20 / 393) * 100vw);
  }

  .line-consultation-section .talk-image-wrap {
    width: calc((333 / 393) * 100vw);
    margin-bottom: calc((30 / 393) * 100vw);
  }

  .line-consultation-section .consultation-line-btn {
    width: calc((307 / 393) * 100vw);
  }

  .price {
    padding: calc((24 / 393) * 100vw) 0 calc((24 / 393) * 100vw);
    margin-top: calc((-48 / 393) * 100vw);
  }

  .price .price-header {
    margin-bottom: calc((30 / 393) * 100vw);
  }

  .price .price-title-wrap {
    padding: 0 calc((40 / 393) * 100vw);
  }

  .price .price-splash {
    top: calc((-96 / 393) * 100vw);
    width: calc((205 / 393) * 100vw);
  }

  .price .price-title {
    font-size: calc((26 / 393) * 100vw);
  }

  .price .price-list {
    width: calc((333 / 393) * 100vw);
    gap: calc((16 / 393) * 100vw);
  }

  .faq-section {
    padding: calc((24 / 393) * 100vw) 0 calc((27 / 393) * 100vw) 0;
  }

  .faq-section .faq-header {
    margin-bottom: calc((13 / 393) * 100vw);
  }

  .faq-section .faq-title {
    font-size: calc((26 / 393) * 100vw);
  }

  .faq-section .faq-container {
    width: calc((333 / 393) * 100vw);
    gap: calc((16 / 393) * 100vw);
  }

  .faq-section .faq-item {
    border-radius: calc((6 / 393) * 100vw);
  }

  .faq-section .faq-question {
    padding: calc((8 / 393) * 100vw) calc((35 / 393) * 100vw) calc((8 / 393) * 100vw) calc((8 / 393) * 100vw);
  }

  .faq-section .faq-q-icon {
    font-size: calc((16 / 393) * 100vw);
    margin-right: calc((8 / 393) * 100vw);
  }

  .faq-section .faq-q-text {
    font-size: calc((14 / 393) * 100vw);
  }

  .faq-section .faq-toggle-icon {
    right: calc((16 / 393) * 100vw);
    width: calc((10 / 393) * 100vw);
    height: calc((10 / 393) * 100vw);
  }

  .faq-section .faq-toggle-icon::before {
    top: calc((4 / 393) * 100vw);
    width: calc((10 / 393) * 100vw);
    height: calc((1.5 / 393) * 100vw);
  }

  .faq-section .faq-toggle-icon::after {
    left: calc((6 / 393) * 100vw);
    width: calc((1.5 / 393) * 100vw);
    height: calc((10 / 393) * 100vw);
  }

  .faq-section .faq-answer-inner {
    padding: calc((8 / 393) * 100vw) calc((21.5 / 393) * 100vw);
  }

  .faq-section .faq-a-text {
    font-size: calc((14 / 393) * 100vw);
  }

  .campaign-banner2-section {
    padding: calc((24 / 393) * 100vw) 0 calc((20 / 393) * 100vw) 0;
  }

  .campaign-banner2-section .banner2-container {
    width: calc((355 / 393) * 100vw);
  }

  .campaign-banner2-section .banner2-btn-wrap {
    bottom: calc((18/ 393) * 100vw);
    left: calc((4 / 393) * 100vw);
    width: calc((258 / 393) * 100vw);
  }

  .company-section {
    padding: calc((20 / 393) * 100vw) 0 calc((32 / 393) * 100vw) 0;
  }

  .company-section .company-container {
    width: calc((332 / 393) * 100vw);
    border-radius: calc((5 / 393) * 100vw);
    padding: calc((24 / 393) * 100vw) calc((12 / 393) * 100vw);
  }

  .company-section .company-title {
    font-size: calc((16 / 393) * 100vw);
    border-radius: calc((5 / 393) * 100vw);
    padding: calc((8 / 393) * 100vw) calc((18 / 393) * 100vw);
    margin-bottom: calc((16 / 393) * 100vw);
  }

  .company-section .company-list {
    gap: calc((16 / 393) * 100vw);
    padding: 0 calc((13.5 / 393) * 100vw);
  }

  .company-section .company-list dt {
    width: calc((100 / 393) * 100vw);
    font-size: calc((15 / 393) * 100vw);
  }

  .company-section .company-list dd {
    font-size: calc((15 / 393) * 100vw);
  }

  .site-footer {
    padding: calc((16 / 393) * 100vw) 0;
  }

  .site-footer .copyright {
    font-size: calc((10 / 393) * 100vw);
  }
}