@charset "utf-8";

:root {
  --font-family-gothic:
    "Noto Sans JP", 游ゴシック体, "Yu Gothic", YuGothic, sans-serif;
  --font-family-mplus: "M PLUS 1p", sans-serif;

  /* カラー変数 */
  /* 緑色系（メインカラー） */
  --color-primary: #04aa3a;
  --color-primary-light: #1cb71c;
  --color-primary-dark: #009331;
  --color-primary-review: #42a03d;
  --color-primary-review-dark: #156611;

  /* オレンジ色系 */
  --color-secondary: #ff8c2e;
  --color-secondary-dark: #ff8400;

  /* 黄色（ハイライト） */
  --color-highlight: #fcee22;

  /* 緑色系（背景） */
  --color-bg-green-light: #eeffef;
  --color-bg-green-medium: #dcffe3;
  --color-bg-green-very-light: #f7fef6;

  /* アクセントカラー */
  --color-pink-bg: #ffeaea;
  --color-red: #f01e28;
  --color-red-light: #ff4c5b;
  --color-blue-dark: #1e2d3c;
}

/* @font-face {
  font-family: 'SourceHanCodeJP-BoldIt';
  src: url('./fonts/SourceHanCodeJP-BoldIt.otf') format('opentype');
  font-weight: bold;
  font-style: italic;
} */

*,
*::after,
*::before {
  box-sizing: border-box;
}

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  padding: 0;
  margin: 0;
  outline: 0;
  border: 0;
}

body {
  font-family: var(--font-family-gothic);
  line-height: 1.5;
  color: #333;
  background-color: #fff;
}

a {
  color: #333;
  text-decoration: none;

  &:has(img) {
    transition: filter 0.3s ease;

    @media (any-hover: hover) {
      &:hover {
        filter: opacity(0.7);
      }
    }
  }
}

button,
input,
select,
textarea {
  font-size: 100%;
  outline: 0;
}

ol,
ul {
  list-style: none;
}

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

.spacer {
  display: none;
}

.body_wrap_container {
  background-color: #fff;
}

.pc--none {
  @media (width >=768px) {
    display: none;
  }
}

.sp--none {
  @media (width <=767px) {
    display: none;
  }
}

/*改行*/
.br-sp {
  display: none;
}

@media screen and (max-width: 767px) {
  .br-sp {
    display: inline;
  }

  .br-pc {
    display: none;
  }
}

/* スマホ非表示 */
@media screen and (max-width: 767px) {
  .sp-none {
    display: none;
  }
}

/*お問い合わせ*/
.grecaptcha-badge {
  visibility: hidden;
}

/* -----------------------------------------------------
	ヘッダー
----------------------------------------------------- */
.appear-container {
  position: relative;
}

body:has(.page_container.privacy),
body:has(.page_container.company) {
  .header {
    display: none;
  }
}

.header {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 10;

  @media (width <=767px) {
    display: none;
  }
}

.header-inner {
  display: flex;
  /* gap: 6.875svw; */
  justify-content: space-between;
  padding-inline-start: 12px;

  @media (width >=768px) {
    width: min(83.34svw, 1100px);
    align-items: center;
    padding: 5px 20px;
    margin-inline: auto;

    @media (width <=1000px) {
      padding: 0 10px;
    }
  }
}

.header-logo {
  line-height: 1;
  max-width: 48%;
  /*SPヘッダーロゴサイズ調整*/

  @media (width >=768px) {
    flex: 0 1 auto;
    max-width: clamp(120px, 16vw, 200px);
    /*PCヘッダーロゴサイズ調整*/
    min-width: 120px;
  }

  @media (width <=767px) {
    align-self: center;
  }

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

.header-top__info {
  display: flex;

  @media (width >=768px) {
    align-items: center;
    gap: 15px;
    border-radius: 8px;
    /* background: rgba(255, 255, 255, 0.65); */
    /* box-shadow: 0 0 13px 1px rgb(87 201 59 / 40%); */
    padding: 8px 12px 8px 12px;
  }

  @media (width <=1100px) {
    padding: 4px 12px 4px 12px;
  }
}

.header-form {
  flex: 0 1 clamp(140px, 18vw, 230px);
  min-width: 0;

  @media (width <=767px) {
    display: none;
  }

  img {
    @media (width >=768px) {
      width: 100%;
      height: auto;
      display: block;
    }
  }

  >a {
    display: block;
  }

}

.header-tel {
  display: flex;
  column-gap: 6px;
  white-space: nowrap;
  padding-top: 10px;
  flex: 0 1 auto;
  min-width: 0;

  @media (width <=767px) {
    display: none;
  }

  >a {
    display: flex;
    flex-direction: column;
    line-height: 1.2;
    font-weight: 700;
    color: #fff;
    text-shadow: 0 2px 6px rgb(0 0 0 / 30%);
  }
}

.header-tel__time {
  font-size: min(0.92svw, 12px);
  padding-left: 3px;
}

.header-tel__nember {
  font-size: min(3.2svw, 40px);

  &::before {
    content: "";
    background-size: contain;
    background-image: url(/image/content/icon-tel--white.svg);
    display: inline-block;
    width: min(2.3svw, 28px);
    aspect-ratio: 1;
    background-repeat: no-repeat;
    filter: drop-shadow(0 2px 6px rgba(0, 0, 0, 0.3));
    margin-right: 8px;
  }
}

.header-contacts__icons {
  display: flex;
  margin: 8px 10px 8px 0;
  gap: 8px;

  @media (width >=768px) {
    display: none;
  }

  li {
    flex: 1;

    img {
      width: 50px;
    }
  }
}

.exclude-header {
  @media (width >=768px) {
    grid-area: 1/1/3/-1;
  }
}

/* -----------------------------------------------------
	メインビジュアル
----------------------------------------------------- */
.hero_image {
  @media (width >=768px) {
    text-align: center;
    background-image: url(/image/content/fv-pc-1920.webp);
    background-repeat: no-repeat;
    background-position: center top;
    background-size: auto 100%;
  }

  img {
    width: 100%;
  }
}

.hero_image_inner {
  @media (width >=768px) {
    width: min(83.34svw, 1200px);
    margin-inline: auto;
  }
}

/* secondary */
/* .hero_secondary {
  display: none;

  @media (width >=768px) {
    display: block;
    text-align: center;
    background-image: url(/image/content/fv-secondary-1920.webp);
    background-repeat: no-repeat;
    background-position: center top;
    background-size: auto 100%;
  }

  img {
    width: 100%;
  }
} */

/* -----------------------------------------------------
	背景パターン共通スタイル（選ばれる理由・料金の目安）
----------------------------------------------------- */
:is(.reason, .price) {
  background-repeat: no-repeat;
  background-size: cover;
  padding: 72px 18px 100px;
}

/* -----------------------------------------------------
	CTA
----------------------------------------------------- */
.cta-copy {
  background-image: url(../image/conversion/bg-cta-catch.webp);
  background-size: cover;
  padding-block: 8px 12px;
  font-family: "Noto Sans JP", 游ゴシック体, "Yu Gothic", YuGothic, sans-serif;

  @media (width >=768px) {
    padding-block: 24px;
  }

  >p {
    font-size: clamp(1rem, 0.7573rem + 1.0356vw, 2rem);
    text-align: center;
    color: #fff;
    line-height: 1;
    font-weight: 700;

    >span {
      font-size: clamp(1.125rem, 0.8519rem + 1.165vw, 2.25rem);
      color: #f5c66e;

      >span {
        font-size: clamp(2rem, 1.5146rem + 2.0712vw, 4rem);
      }
    }
  }
}

.cta-contact {
  padding-block: 30px 40px;
  background-image: url(../image/conversion/bg-cta.webp);
  background-position: center top;
  background-size: 70% auto;
  background-repeat: repeat;

  @media (width >=768px) {
    padding-block: 80px 60px;
    background-size: 50% auto;
  }

}

.cta-contact__inner {
  margin-inline: auto;
  width: calc(100% - 32px);

  @media (width >=768px) {
    width: min(calc(1520/1920*100svw), 1520px);
  }
}

.cta-contact__body {
  background-color: #fff;
  border-radius: 16px;
  padding: 40px 16px;
  display: flex;
  align-items: center;

  @media (width <=1100px) {
    padding: 30px 16px;
  }

  @media (width <=767px) {
    flex-direction: column;
    row-gap: 12px;
    padding: 25px 15px 20px;
    border-radius: 8px;
  }

  @media (width >=768px) {
    justify-content: center;
    gap: min(1.5svw, 30px);
  }
}

.cta-contact__items {
  display: flex;

  @media (width <=767px) {
    flex-direction: column;
    gap: 3px;
  }
}

.cta-contact__item {
  @media (width >=768px) {
    flex: min(22.34svw, 429px) 0 1;
  }
}

.cta-contact__item img {
  @media (width <=767px) {
    margin-left: 2px;
  }
}

.cta-contact__tel {
  @media (width >=768px) {
    flex: 523px 0 1;
  }
}

.cta-address {
  background-color: #fff;
  display: flex;
  column-gap: 67px;
  font-style: normal;
  justify-content: center;
  white-space: nowrap;

  @media (width >=900px) {
    margin-top: -10px;
  }
}

@media (width <=900px) {
  .cta-address {
    flex-direction: column;
  }
}

@media (width <=767px) {
  .cta-address {
    padding-inline: 0;
  }
}

.cta-tel__number {
  --font-size: min(3.85svw, 74px);
  font-size: var(--font-size);
  display: block flex;
  align-items: center;
  line-height: 1.2;
  color: #333;
  font-weight: 700;

  @media (width <=900px) {
    line-height: 1;
  }

  @media (width <=767px) {
    line-height: 1.2;
    --font-size: min(10.8svw, 40px);
  }
}

.cta-tel__number.cta-tel__number::before {
  content: "";
  background-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNjYiIGhlaWdodD0iMzgiIHZpZXdCb3g9IjAgMCA2NiAzOCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTU2LjkxIDBIMFYzNy4xNEg1Ni45MVYwWiIgZmlsbD0iIzAwQTczQyIvPgo8cGF0aCBkPSJNNTguNjEwMSAzMy42MDk4QzU4LjYxMDEgMzUuNTY5OCA2MC4yMDAxIDM3LjE2OTggNjIuMTcwMSAzNy4xNjk4QzY0LjE0MDEgMzcuMTY5OCA2NS43MzAxIDM1LjU2OTggNjUuNzMwMSAzMy42MDk4QzY1LjczMDEgMzEuNjQ5OCA2NC4xMzAxIDMwLjA0OTggNjIuMTcwMSAzMC4wNDk4QzYwLjIxMDEgMzAuMDQ5OCA1OC42MTAxIDMxLjYzOTggNTguNjEwMSAzMy42MDk4Wk01OS4wMjAxIDMzLjYwOThDNTkuMDIwMSAzMS44Nzk4IDYwLjQzMDEgMzAuNDY5OCA2Mi4xNzAxIDMwLjQ2OThDNjMuOTEwMSAzMC40Njk4IDY1LjMxMDEgMzEuODc5OCA2NS4zMTAxIDMzLjYwOThDNjUuMzEwMSAzNS4zMzk4IDYzLjkwMDEgMzYuNzQ5OCA2Mi4xNzAxIDM2Ljc0OThDNjAuNDQwMSAzNi43NDk4IDU5LjAyMDEgMzUuMzM5OCA1OS4wMjAxIDMzLjYwOThaIiBmaWxsPSJibGFjayIvPgo8cGF0aCBkPSJNNjMuOSAzNS45MUg2My4yMkw2MS44NCAzMy43N0g2MS4yM1YzNS45MUg2MC42ODAxVjMxLjIxSDYyLjAxQzYyLjQ1IDMxLjIxIDYyLjgxMDEgMzEuMzIgNjMuMDcwMSAzMS41M0M2My4zMzAxIDMxLjc1IDYzLjQ2IDMyLjA1IDYzLjQ2IDMyLjQzQzYzLjQ2IDMyLjcyIDYzLjM3MDEgMzIuOTcgNjMuMTgwMSAzMy4xOUM2Mi45OTAxIDMzLjQxIDYyLjczIDMzLjU2IDYyLjQgMzMuNjVMNjMuOSAzNS45TTYxLjIzIDMzLjNINjEuOTJDNjIuMjEgMzMuMyA2Mi40NDAxIDMzLjIyIDYyLjYyMDEgMzMuMDdDNjIuODAwMSAzMi45MSA2Mi44OSAzMi43MiA2Mi44OSAzMi40OEM2Mi44OSAzMS45NSA2Mi41NzAxIDMxLjY5IDYxLjkzMDEgMzEuNjlINjEuMjNWMzMuM1oiIGZpbGw9ImJsYWNrIi8+CjxwYXRoIGQ9Ik0xNC4zIDI4LjgxMDNDMTEuMTggMjguODEwMyA3LjMwMDAyIDI2LjQyMDMgNy4zMDAwMiAyMS41MDAzQzcuMzAwMDIgMTcuNjgwMyAxMS4wOCAxNC42MzAzIDE0LjMgMTIuODAwM0MxNy41MSAxNC42MzAzIDIxLjMgMTcuNjgwMyAyMS4zIDIxLjUwMDNDMjEuMyAyNi40MjAzIDE3LjQzIDI4LjgxMDMgMTQuMyAyOC44MTAzWk0zNS43NCAyMS40MjAzQzM1Ljc0IDE3LjYwMDMgMzkuNTIgMTQuNTUwMyA0Mi43NCAxMi43MjAzQzQ1Ljk1IDE0LjU1MDMgNDkuNzMgMTcuNjAwMyA0OS43MyAyMS40MjAzQzQ5LjczIDI2LjM0MDMgNDUuODYgMjguNzMwMyA0Mi43NCAyOC43MzAzQzM5LjYyIDI4LjczMDMgMzUuNzQgMjYuMzUwMyAzNS43NCAyMS40MjAzWk01Ni45IDUuNzgwMjdDNTEuMTIgNS43ODAyNyA0NS45OSA3LjIyMDI3IDQyLjUxIDkuMDMwMjdDMzkuMDMgNy4yMjAyNyAzNC4yMiA1Ljc4MDI3IDI4LjQ0IDUuNzgwMjdDMjIuNjYgNS43ODAyNyAxNy44NSA3LjIyMDI3IDE0LjM3IDkuMDMwMjdDMTAuODkgNy4yMjAyNyA1Ljc3IDUuNzgwMjcgMCA1Ljc4MDI3VjkuMDMwMjdDMy40MiA5LjAzMDI3IDcuNTYwMDEgOS42NzAyOSAxMC44MiAxMS4wODAzQzcuMzEwMDEgMTMuNDMwMyAzLjgzMDAyIDE2Ljk5MDMgMy44MzAwMiAyMS40OTAzQzMuODMwMDIgMjcuNDMwMyA4Ljg5MDAxIDMxLjk3MDMgMTQuMzggMzEuOTcwM0MxOS44NyAzMS45NzAzIDI0LjY5IDI3LjQzMDMgMjQuNjkgMjEuNDkwM0MyNC42OSAxNi45OTAzIDIxLjQ2IDEzLjQzMDMgMTcuOTQgMTEuMDgwM0MyMS4yIDkuNjYwMjkgMjUuMDMgOS4wMzAyNyAyOC40NSA5LjAzMDI3QzMxLjg3IDkuMDMwMjcgMzUuNzEgOS42NzAyOSAzOC45NiAxMS4wODAzQzM1LjQ0IDEzLjQzMDMgMzIuMjEgMTYuOTkwMyAzMi4yMSAyMS40OTAzQzMyLjIxIDI3LjQzMDMgMzcuMDIgMzEuOTcwMyA0Mi41MSAzMS45NzAzQzQ4IDMxLjk3MDMgNTIuOTkgMjcuNDMwMyA1Mi45OSAyMS40OTAzQzUyLjk5IDE2Ljk5MDMgNDkuNTkgMTMuNDMwMyA0Ni4wNyAxMS4wODAzQzQ5LjMzIDkuNjYwMjkgNTMuNDggOS4wMzAyNyA1Ni45IDkuMDMwMjdWNS43ODAyN1oiIGZpbGw9IndoaXRlIi8+Cjwvc3ZnPgo=);
  background-repeat: no-repeat;
  width: min(4svw, 66px);
  aspect-ratio: 33/19;
  display: inline-block;
  translate: 0 4px;
  background-size: contain;

  @media (width <=900px) {
    translate: 0 0;
  }

  @media (width <=767px) {
    width: 36px;
    height: 21px;
    translate: 0 3px;
  }
}

.cta-address__topic {
  display: block;
  /* padding-block-start: 10px; */
  font-size: min(1.19svw, 23px);
  font-weight: 700;

  @media (width <=900px) {
    font-size: 10px;
  }

  @media (width <=800px) {
    font-size: 9px;
  }

  @media (width <=767px) {
    margin-left: 5px;
    font-size: 12px;
    padding-block-start: 2px;
  }
}

.cta-message__tel {
  font-size: 15px;
  font-weight: 700;
  display: flex;
  gap: 6px;
  align-items: center;
  margin-left: 5px;

  &::before {
    content: "";
    background-image: url('data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzEiIGhlaWdodD0iMzEiIHZpZXdCb3g9IjAgMCAzMSAzMSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTEzLjYzMzcgMjUuMTgwOEMxNi4wMzcyIDI2Ljg4OTMgMTguNjI5IDI4LjMyMjcgMjEuMzM2NyAyOS40NTIxQzIyLjY5MDUgMzAuMDE2OCAyMy42MDI3IDMwLjI5OTIgMjQuMTA5NCAzMC4zMjA5SDI0LjE4MThDMjYuMDg1OCAzMC4zMjA5IDI4LjU0MDEgMjYuODk2NSAyOC44Mjk3IDI1Ljc4ODlDMjkuMTc3MiAyNC40NjQgMjguNjc3NiAyMy4wNTk1IDI3LjU1NTUgMjIuMjEyNUwyNS4wMDcxIDIwLjI5NEMyNC4zNzAxIDE5LjgxNjIgMjMuNjA5OSAxOS41NjI4IDIyLjc5OTEgMTkuNTYyOEMyMS45MDEzIDE5LjU2MjggMjEuMDMyNiAxOS44ODEzIDIwLjM2NjUgMjAuNDY3N0MxOS45NzU2IDIwLjgxNTMgMTkuNDQ3MSAyMS4zMDAzIDE5LjE1MDMgMjEuNjY5NUMxOS4xMjg2IDIxLjY4NCAxOS4wOTI0IDIxLjY5MTIgMTkuMDQ4OSAyMS42OTEyQzE3Ljk3NzUgMjEuNjkxMiAxNC4yNDE4IDE4LjU2MzcgMTMuMjQyOCAxNy41NjQ3QzEyLjE4NTggMTYuNTg3MyA4LjkwNjIxIDEyLjk1MyA4Ljk2NDEzIDExLjk2MTJDOC45NjQxMyAxMS44ODg4IDguOTkzMDkgMTEuODc0MyA5LjAwMDMzIDExLjg2NzFDOS4zNjk1NSAxMS41OTkyIDkuODY5MDkgMTEuMDkyNCAxMC4yMzExIDEwLjcwODdDMTEuNDE4NCA5LjQ1NjI5IDExLjQ5OCA3LjU4MTIzIDEwLjQxOTMgNi4yNDkxM0w4LjQyODQgMy43OTQ4OUM4LjI3NjM3IDMuNjA2NjYgOC4wOTUzOCAzLjQzMjkxIDcuODM0NzUgMy4yMzAyQzcuNzMzMzkgMy4xNTc4IDcuNjM5MjggMy4wODU0MiA3LjQ5NDQ5IDIuOTk4NTVDNy4wNDU2MyAyLjczMDY4IDYuNTQ2MSAyLjU1NjkzIDYuMDAzMTIgMi40OTkwMUM1Ljg1ODMzIDIuNDg0NTMgNS43MTM1NCAyLjQ3NzI5IDUuNTYxNTEgMi40NzcyOUM1LjI3MTkyIDIuNDc3MjkgNC45ODIzNCAyLjUxMzQ4IDQuNzE0NDcgMi41Nzg2NEMzLjY5MzY4IDIuODI0NzkgLTAuMDg1NDAxOCA1LjE5MjE2IDAuMDAxNDczNzMgNy4xMTc5QzAuMDIzMTkyNiA3LjYxMDE5IDAuMzIwMDE3IDguNDg2MTcgMC45MDY0MjcgOS43ODkzQzIuMDc5MjUgMTIuMzk1NiAzLjU3MDYxIDE0Ljg5MzIgNS4zNTE1NiAxNy4yMTcyQzcuNjgyNzIgMjAuMjY1IDEwLjQ3IDIyLjk1MSAxMy42NDA5IDI1LjE5NTJMMTMuNjMzNyAyNS4xODA4WiIgZmlsbD0iIzA0QUEzQSIvPgo8cGF0aCBkPSJNMjYuMzk3MiAzLjc4NzY0QzI0LjI5NzcgMS43Njc3OSAyMS42NDA4IDAuNDY0NjM3IDE4Ljc1OTQgMC4wMTU3ODAyQzE4LjU3ODQgLTAuMDEzMTc4MyAxOC40MDQ3IDAuMDAxMzE1MTIgMTguMjM4MiAwLjAzMDI3MzZDMTguMTUxMyAwLjA1MTk5MjUgMTguMDY0NCAwLjA3MzcwMDggMTcuOTc3NSAwLjEwOTg5OUgxNy45NjMxQzE3Ljg4MzQgMC4xNDYwOTcgMTcuODAzOCAwLjE4MjMwNSAxNy43MzE0IDAuMjMyOTgyQzE3LjczMTQgMC4yMzI5ODIgMTcuNzI0MiAwLjIzMjk4OSAxNy43MTY5IDAuMjQwMjI5QzE3LjY0NDUgMC4yOTA5MDYgMTcuNTcyMSAwLjM0MTU3IDE3LjUxNDIgMC40MDY3MjZDMTcuMjUzNiAwLjY2MDExMyAxNy4wNzk4IDEuMDAwMzkgMTcuMDc5OCAxLjM5MTMzQzE3LjA3OTggMi4wNzE4NSAxNy41Nzk0IDIuNjY1NSAxOC4yNzQ0IDIuNzc0MUMyMC41NjkzIDMuMTI4ODQgMjIuNjc2MSA0LjE1Njg2IDI0LjM0MTIgNS43NTY4MkMyNi4wMDYzIDcuMzY0MDIgMjcuMDc3OCA5LjM5MTExIDI3LjQ0NyAxMS41OTJDMjcuNTU1NiAxMi4yNTggMjguMTc4MiAxMi43NDMxIDI4Ljg4MDQgMTIuNzQzMUMyOS43NzgxIDEyLjc0MzEgMzAuNDY1OSAxMS45Njg0IDMwLjMyMTEgMTEuMTIxNEMyOS44NTA1IDguMzQ4NjEgMjguNTA0IDUuODAwMjQgMjYuNDA0NSAzLjc3MzE1TDI2LjM5NzIgMy43ODc2NFoiIGZpbGw9IiMwNEFBM0EiLz4KPHBhdGggZD0iTTE4LjEwNzggOC41MDc2NkMxOC44OTY5IDguNzQ2NTYgMTkuNjEzNiA5LjE2NjQ3IDIwLjIwNzMgOS43Mzg0QzIwLjgwMDkgMTAuMzEwMyAyMS4yNDI1IDExLjAwNTMgMjEuNDk1OSAxMS43NTgyQzIxLjY5MTQgMTIuMzQ0NyAyMi4yNDg4IDEyLjc1MDEgMjIuODg1OSAxMi43NTAxQzIzLjg1NiAxMi43NTAxIDI0LjU4IDExLjg1MjQgMjQuMjkwNCAxMC45NjE5QzIzLjkwNjcgOS43NjAxMiAyMy4yMTkgOC42NjY5MiAyMi4yNzA2IDcuNzU0NzNDMjEuMzIyMiA2Ljg0MjU0IDIwLjE3ODMgNi4xODM3MyAxOC45MzMxIDUuODA3MjdDMTguMDA2NCA1LjUzMjE2IDE3LjA3MjUgNi4yMjcxOCAxNy4wNzI1IDcuMTUzODVDMTcuMDcyNSA3Ljc3NjQ2IDE3LjQ5MjQgOC4zMTIxOCAxOC4xMDc4IDguNTAwNDFWOC41MDc2NloiIGZpbGw9IiMwNEFBM0EiLz4KPC9zdmc+');
    background-size: contain;
    width: 15px;
    display: inline-block;
    aspect-ratio: 1;
    background-repeat: no-repeat;
    margin-top: 0;
  }

  @media (width >=768px) {
    display: none;
  }
}

/* -----------------------------------------------------
	選ばれる理由
----------------------------------------------------- */
.reason {
  padding: 50px 0 70px;

  @media (width >=768px) {
    padding: 100px 0 100px;
  }
}

.section-title {
  --section-title-padding-bottom: 100px;
  --section-title-span-padding: 24px 113px;

  text-align: center;
  padding-block-end: var(--section-title-padding-bottom);

  @media (width <=767px) {
    --section-title-padding-bottom: 50px;
    --section-title-span-padding: 24px;
  }

  >span {
    background-image: url(/image/content/bg-section-title.svg);
    background-repeat: no-repeat;
    background-size: contain;
    font-weight: 700;
    color: #fff;
    padding: var(--section-title-span-padding);
    background-position: center;
    font-size: clamp(1rem, calc(0.595rem + 2.589vw), 2.667rem);

    @media (width <=767px) {
      padding: 40px;
      font-size: 24px;
    }
  }
}

/* -----------------------------------------------------
	コンテナ共通スタイル（選ばれる理由・お客様の声・作業までの流れ・よくある質問）
----------------------------------------------------- */
:is(.reason-items, .reviews-items, .flow-items, .faq-items) {
  display: flex;
  flex-direction: column;
  margin-inline: auto;
}

.reason-items {
  --reason-items-gap: 64px;
  gap: var(--reason-items-gap);
  width: min(calc(100% - 30px), 900px);

  @media (width <=850px) {
    width: 550px;
  }

  @media (width <=767px) {
    --reason-items-gap: 32px;
    width: min(calc(100% - 30px), 900px);
  }
}

/* -----------------------------------------------------
	カードアイテム共通スタイル（選ばれる理由・作業までの流れ）
----------------------------------------------------- */
:is(.reason-item, .flow-item) {
  position: relative;
  display: flex;
  background-color: #fff;
  border-radius: 16px;
  align-items: center;
}

.reason-item {
  --reason-item-flex-direction: row;
  --reason-item-gap: 24px;
  flex-direction: var(--reason-item-flex-direction);
  gap: var(--reason-item-gap);
  padding: 48px 32px 32px;
  border: solid #ccc 1px;

  @media (width <=850px) {
    --reason-item-flex-direction: column;
    --reason-item-gap: 12px;
    align-items: center;
  }

  @media (width <=767px) {
    padding: 48px 20px 30px;
  }
}

@media (min-width: 851px) {
  .reason-item__text {
    width: calc(100% - 300px);
  }

  .reason-item__image {
    flex: 0 0 300px;
  }
}

.reason-item__image img {
  object-fit: cover;
  aspect-ratio: 16 / 9;
  border-radius: 8px;
}

/* -----------------------------------------------------
	ステップバッジ共通スタイル（選ばれる理由・作業の実績・作業までの流れ）
----------------------------------------------------- */
:is(.reason-item__step, .work-item__step, .flow-item__step) {
  --step-width: 116px;
  --step-transform: translate(-60%, -50%);
  --step-after-width: 23px;
  --step-after-height: 16px;
  --step-after-bottom: 10px;

  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: var(--step-width);
  aspect-ratio: 1;
  font-weight: 700;
  color: #fff;
  background-color: var(--color-primary-light);
  border-radius: 50%;
  transform: var(--step-transform);
  line-height: 1;

  @media (width <=1024px) {
    --step-transform: translate(-30%, -50%);
  }

  @media (width <=480px) {
    --step-width: 70px;
    --step-transform: translate(-8%, -25%);
    --step-after-width: 11px;
    --step-after-height: 12px;
    --step-after-bottom: 0px;
  }

  &::after {
    content: "";
    display: inline-block;
    background-image: url("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjMiIGhlaWdodD0iMTYiIHZpZXdCb3g9IjAgMCAyMyAxNiIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTIyLjYzMDYgMTUuNjA3M0wxNC44ODg1IDBMMCA4LjAwMzczTDIyLjYzMDYgMTUuNjA3M1oiIGZpbGw9IiMxQ0I3MUMiLz4KPC9zdmc+Cg==");
    background-size: contain;
    background-repeat: no-repeat;
    width: var(--step-after-width);
    height: var(--step-after-height);
    bottom: var(--step-after-bottom);
    right: 5px;
    position: absolute;
  }
}

:is(.reason-item__step-label, .work-item__step-label, .flow-item__step-label) {
  --step-label-font-size: 20px;
  font-size: var(--step-label-font-size);
  text-transform: uppercase;

  @media (width <=767px) {
    --step-label-font-size: 12px;
    letter-spacing: 0.5px;
  }
}

:is(.reason-item__step-number, .work-item__step-number, .flow-item__step-number) {
  --step-number-font-size: 60px;
  font-size: var(--step-number-font-size);

  @media (width <=767px) {
    --step-number-font-size: 36px;
  }
}

/* reason-item専用の上書き（480px以下のみ異なるため） */
.reason-item__step-number {
  @media (width <=480px) {
    --step-number-font-size: 36px;
  }
}

/* -----------------------------------------------------
	タイトル共通スタイル（選ばれる理由・作業までの流れ）
----------------------------------------------------- */
:is(.reason-item__title, .flow-item__title) {
  padding-block-end: 16px;
  color: var(--color-primary);

  @media (width <=850px) {
    text-align: center;
  }
}

.reason-item__title {
  --title-font-size: 28px;
  --title-span-font-size: 36px;
  font-size: var(--title-font-size);

  @media (width <=767px) {
    --title-font-size: 18px;
    --title-span-font-size: 22px;
  }

  >span {
    color: var(--color-secondary-dark);
    font-size: var(--title-span-font-size);
  }
}

/* -----------------------------------------------------
	説明文共通スタイル（選ばれる理由・作業までの流れ）
----------------------------------------------------- */
:is(.reason-item__desc, .flow-item__desc) {
  font-weight: 500;

  @media (width <=767px) {
    font-size: 14px;
  }
}

/* -----------------------------------------------------
	チェッカーボード背景共通スタイル（作業の実績・作業までの流れ）
----------------------------------------------------- */
/* :is(.works, .flow) {
  background-image: conic-gradient(var(--color-bg-green-light) 0deg 90deg, var(--color-bg-green-medium) 90deg 180deg, var(--color-bg-green-light) 180deg 270deg, var(--color-bg-green-medium) 270deg 360deg);
} */

/* -----------------------------------------------------
	作業の実績
----------------------------------------------------- */
.works {
  padding: 80px 18px 80px;
  background-image: url(/image/content/bg-pattern.webp);
  background-size: 150% auto;
  background-position: 20% -50px;
  background: #f4ebc9;

  @media (width <=767px) {
    padding: 50px 0 50px;
    /* background-size: 200% auto;
    background-position: 30% -100px; */
  }
}

.works .section-title--sm {
  color: #333;
}

.work-content {
  --content-padding-inline: 16px;

  display: flex;
  flex-direction: column;
  gap: 12px;
  /* padding-inline: var(--content-padding-inline); */
  padding: 0 10px 10px;

  @media (width >=768px) {
    --content-padding-inline: 0;
    width: min(100%, 750px);
    margin-inline: auto;
  }
}

@media (min-width: 768px) {
  .work-content.inner {
    width: min(100%, 1100px);
    padding: 0 2em;
  }
}

/* -----------------------------------------------------
	資料DL
----------------------------------------------------- */
.document-dl {
  --background-image: url(/image/document/bg-document-lg.webp);
  background-image: var(--background-image);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  padding: 80px 18px 80px;

  @media (width <=767px) {
    --background-image: url(/image/document/bg-document-sm.webp);
    padding: min(15svw, 60px) min(3.75svw, 30px);
  }
}

.document-dl__container {
  --padding: 70px min(2.5svw, 48px) 30px;
  background-color: #fff;
  border-radius: 24px;
  box-shadow: 0 0 16px 0 rgba(0, 0, 0, 0.10);
  padding: var(--padding);

  @media (width <=767px) {
    --padding: 35px min(5svw, 20px);
  }

  @media (width >=768px) {
    width: min(92svw, 1150px);
    margin-inline: auto;
    padding: 70px clamp(20px, 2.5vw, 40px) 30px;
    display: flex;
    margin-top: 30px;
    gap: clamp(20px, 3vw, 40px);
    background: #fff;
    border-radius: 24px;
    overflow: hidden;
  }
}

.document-dl__action {
  --margin-block: 20px 40px;
  margin-block: var(--margin-block);

  @media (width <=767px) {
    --margin-block: 20px;
  }

  @media (width >=768px) {
    margin-inline: auto;
    width: clamp(200px, 28svw, 380px);
  }
}

.document-dl__action-message {
  font-size: min(160%, 1.8svw);
  text-align: center;
  margin-bottom: 15px;

  @media (width <=767px) {
    font-size: 20px;
    margin-bottom: 12px;
  }


  &::after {
    content: "";
    display: block;
    background-image: url(/image/document/icon-triangle--dotted.svg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    width: 28px;
    margin: 6px auto;
    aspect-ratio: 47.64/26.03;
  }

  >span {
    color: #ff792e;
  }
}

.document-dl__body {
  @media (width >=768px) {
    flex: 0 1 45%;
    min-width: 0;
  }
}


.document-dl__image {
  margin-top: 30px;

  @media (width >=768px) {
    margin-top: 0;
    flex: 0 1 55%;
    min-width: 0;
  }

  >img {
    border-radius: 16px;
    box-shadow: 0 0 16px rgba(0, 0, 0, 0.15);
  }
}

/* -----------------------------------------------------
	成果コミットキャンペーン
----------------------------------------------------- */
@media (max-width: 767px) {
  .commit .section-title--no-line {
    display: none;
  }
}

.commit {
  --background-image: url(/image/commit/bg-pattern-commit-lg.webp);
  background-image: var(--background-image);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  padding-block: 120px 84px;

  @media (width <=767px) {
    --background-image: url(/image/commit/bg-pattern-commit-sm.webp);
    padding: 60px 16px 30px;
  }

  .section-title-en--italic {
    @media (width >=768px) {
      display: none;
    }
  }

  .document-dl__action {
    @media (width >=768px) {
      margin-block-end: 10px;
    }
  }
}

.commit-container {
  border-radius: 30px;
  background-color: #fff;
  padding-inline: 22px 60px;

  @media (width <=767px) {
    padding: 0 22px 22px;
  }

  @media (width >=768px) {
    width: min(92svw, 1000px);
    margin-inline: auto;
  }
}

.commit-head__title {
  --width-min: 80%;
  --translate-y: -50%;

  margin-inline: auto;
  width: var(--width-min);
  translate: 0 var(--translate-y);

  @media (width <=767px) {
    --width-min: min(67.5svw, 270px);
    --translate-y: -30%;
    margin-block-end: -15px;
  }
}

.commit-content {
  @media (width >=768px) {
    display: flex;
    justify-content: center;
    align-items: center;
    column-gap: min(2.34svw, 45px);
  }
}

.commit-promote {
  min-width: 0px;
  flex: 0 1 50%;
}

.commit-lg-group {
  min-width: 0px;
  flex: 0 1 50%;
}

.commit-promote {
  @media (width <=767px) {
    display: none;
  }
}

.commit-badge {
  margin-block-end: 28px;

  @media (width >=768px) {
    display: none;
  }
}

.commit-price {
  margin-block: 10px 20px;

  /* @media (width <=767px) {
    scale: 1.1;
  } */
}

@media (width >=768px) {
  .commit .section-title--no-line {
    display: none;
  }

  .commit-head__title img {
    margin-left: 30px;
  }

  .commit .document-dl__action {
    width: 90%;
  }
}

.commit .document-dl__action-message {
  font-size: clamp(16px, 180%, 36px);

  @media (width <=1100px) {
    font-size: clamp(16px, 2.5svw, 36px);
  }

  @media (width <=767px) {
    font-size: 22px;
  }
}

/* -----------------------------------------------------
  英語付き見出し（下線は日本語の100%幅）
----------------------------------------------------- */
.section-title--line-fit {
  --font-size: min(2.3svw, 40px);
  font-size: var(--font-size);
  color: var(--color-primary-light);
  text-align: center;
  letter-spacing: 0.08em;
  width: fit-content;
  margin-inline: auto;

  @media (width <=767px) {
    --font-size: min(6.25svw, 25px);
  }

  &::before {
    content: attr(data-title-en);
    display: block;
    margin-bottom: 0.35em;
    font-size: 0.55em;
    font-family: 'SourceHanCodeJP-BoldIt', sans-serif;
    font-style: italic;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-primary-light);
  }

  .title-ja {
    display: inline-block;
    position: relative;

    &::after {
      content: '';
      display: block;
      width: 100%;
      height: 2px;
      background: var(--color-primary-light);
      margin-top: 16px;

      @media (width <=767px) {
        margin-top: 10px;
      }
    }
  }
}

/* -----------------------------------------------------
  英語付き見出し（下線は日本語の90%幅）
----------------------------------------------------- */
.section-title--line-90 {
  --font-size: min(2.3svw, 40px);
  font-size: var(--font-size);
  color: var(--color-primary-light);
  text-align: center;
  letter-spacing: 0.08em;
  width: fit-content;
  margin-inline: auto;
  margin-bottom: 70px;

  @media (width <=767px) {
    --font-size: min(6.25svw, 25px);
    margin-bottom: 40px;
  }

  &::before {
    content: attr(data-title-en);
    display: block;
    margin-bottom: 0.35em;
    font-size: 0.55em;
    font-family: 'SourceHanCodeJP-BoldIt', sans-serif;
    font-style: italic;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-primary-light);
  }

  .title-ja {
    display: inline-block;
    position: relative;

    &::after {
      content: '';
      display: block;
      width: 90%;
      height: 2px;
      background: var(--color-primary-light);
      margin-top: 16px;
      margin-inline: auto;

      @media (width <=767px) {
        margin-top: 10px;
      }
    }
  }
}

/* -----------------------------------------------------
  英語付き見出し（下線なし）
----------------------------------------------------- */
.section-title--no-line {
  font-size: min(160%, 1.8svw);
  color: var(--color-primary-light);
  text-align: center;
  letter-spacing: 0.08em;
  width: fit-content;
  margin-inline: auto;
  margin-bottom: 30px;

  @media (width <=767px) {
    font-size: min(5.5svw, 25px);
    margin-bottom: 20px;
  }

  &::before {
    content: attr(data-title-en);
    display: block;
    margin-bottom: 0.35em;
    font-size: 0.55em;
    font-family: 'SourceHanCodeJP-BoldIt', sans-serif;
    font-style: italic;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-primary-light);

    @media (width <=767px) {
      font-size: 0.65em;
    }
  }
}

/* -----------------------------------------------------
	見出し
----------------------------------------------------- */
.section-title-en--italic {
  --font-size: min(2.3svw, 40px);
  font-size: var(--font-size);
  color: var(--color-primary-light);
  text-align: center;
  letter-spacing: 0.08em;

  @media (width <=767px) {
    --font-size: min(6.25svw, 25px);
  }

  &::before {
    content: attr(data-title--en);
    font-size: 0.55em;
    font-family: 'SourceHanCodeJP-BoldIt', sans-serif;
    color: var(--color-primary-light);
    text-transform: uppercase;
    display: block;
    letter-spacing: 0.05em;
    font-style: italic;
    margin-bottom: 0.65em;
  }

  &::after {
    content: '';
    display: block;
    width: min(220px, 30vw);
    height: 2px;
    background: var(--color-primary-light);
    margin: 16px auto 0;
  }
}

/* -----------------------------------------------------
	運用事例
----------------------------------------------------- */
.successful-case {
  --padding-block: 100px;
  padding-block: var(--padding-block);

  @media (width <=767px) {
    --padding-block: 44px;
  }

  .section-title-en--italic {
    --padding-block-end: 24px;
    --margin-block-end: 88px;
    width: fit-content;
    margin-inline: auto;
    padding-block-end: var(--padding-block-end);
    margin-block-end: var(--margin-block-end);

    @media (width <=767px) {
      --padding-block-end: 12px;
      --margin-block-end: 40px;
    }
  }
}

.successful-case__desc {
  --font-size: min(1.45svw, 32px);
  --margin-block-end: 70px;
  margin: 0 auto var(--margin-block-end);
  font-size: var(--font-size);
  color: var(--color-primary-light);
  font-weight: 700;

  @media (width <=767px) {
    --margin-block-end: 50px;
    --font-size: 16px;
    padding-inline: 30px;
  }

  @media (width >=768px) {
    width: min(30svw, 682px);
  }
}

.successful-case__desc.style-2 {
  --margin-block-end: 0px;

  @media (width >=768px) {
    width: min(50svw, 682px);
  }
}

.successful-case__items {
  margin-inline: auto;

  @media (width >=768px) {
    width: min(57.29svw, 1100px);
  }

  @media (width <=767px) {
    padding-inline: 15px;
  }

  .successful-case__item {
    --margin-block-end: 40px;

    &:not(:last-child) {
      margin-block-end: var(--margin-block-end);
    }

    @media (width >=768px) {
      &:last-child {
        width: 130%;
        position: relative;
        left: 50%;
        transform: translateX(-50%);
      }
    }
  }
}


.successful-case__item-title {
  --font-size: min(1.8svw, 40px);
  background-color: var(--color-primary-light);
  color: #fff;
  text-align: center;
  font-size: var(--font-size);
  border: solid 1px var(--color-primary-light);
  border-radius: 5px 5px 0 0;
  padding-block: 5px;

  @media (width <=767px) {
    --font-size: min(5.5svw, 27px);
  }
}

.successful-case__item-body {
  border: solid 3px var(--color-primary-light);
  border-top: 0;
  border-radius: 0 0 5px 5px;
  padding-block: 10px 0;

  @media (width <=767px) {
    padding: 15px 5px;
  }
}




/* -----------------------------------------------------
	作業の風景
----------------------------------------------------- */
.scenery {
  --scenery-gap-row: 24px;
  --scenery-item-flex-basis: 31.9%;

  background-image: url(/image/scenery/bg-scenery.svg);
  background-repeat: no-repeat;
  background-size: cover;
  padding-block: 80px 64px;

  @media (width <=767px) {
    --scenery-gap-row: 12px;
    --scenery-item-flex-basis: 48%;
    padding-block: 50px 70px;
  }
}

.scenery-items {
  display: flex;
  gap: 10px;
  width: min(calc(100% - 30px), 1000px);
  flex-wrap: wrap;
  margin-inline: auto;

  @media (width <=767px) {
    gap: 8px;
  }
}

.scenery-item {
  flex: var(--scenery-item-flex-basis);
  flex: 0 0 calc((100% - 20px) / 3);

  @media (width <=767px) {
    flex: 0 0 calc((100% - 8px) / 2);
  }
}


/* -----------------------------------------------------
	料金の目安
----------------------------------------------------- */
.price {
  background-image: url(/image/price/bg-pattern02.webp);

  img {
    width: min(1000px, 100%);
    margin-inline: auto;
    display: block;
  }

  @media (width <=767px) {
    padding: 50px 5px 50px;
  }
}

.price .section-title--sm {
  color: #333;
}

/* -----------------------------------------------------
	思い
----------------------------------------------------- */
.thought {
  background-image: url(/image/thought/bg-pattern.webp);
  padding: 80px 18px 80px;

  img {
    width: min(1000px, 100%);
    margin-inline: auto;
    display: block;
  }

  @media (width <=767px) {
    padding: 50px 5px 50px;
  }
}

/* -----------------------------------------------------
	背景画像共通スタイル（対応エリア・お客様の声）
----------------------------------------------------- */
:is(.area, .reviews) {
  padding-block: 64px;
  background-size: cover;
}

/* -----------------------------------------------------
対応可能エリア
----------------------------------------------------- */
.area {
  background-image: url(/image/area/bg-pattern.webp);

  @media (width <=767px) {
    padding-block: 50px 70px;
  }
}

.section-title--sm {
  --title-padding-bottom: 56px;
  --title-font-size: 48px;
  --title-before-font-size: 32px;

  display: flex;
  flex-direction: column;
  row-gap: 10px;
  line-height: 1;
  align-items: center;
  font-size: var(--title-font-size);
  font-weight: 700;
  color: #666;
  padding-block-end: var(--title-padding-bottom);

  @media (width <=767px) {
    --title-padding-bottom: 24px;
    --title-font-size: 20px;
    --title-before-font-size: 18px;
    row-gap: 5px;
  }

  &::before {
    content: attr(data-title--en);
    font-size: var(--title-before-font-size);
    color: var(--color-primary-light);
    text-transform: capitalize;
  }
}

.area-content {
  --content-padding-inline: 16px;

  display: flex;
  flex-direction: column;
  gap: 12px;
  padding-inline: var(--content-padding-inline);

  @media (width >=768px) {
    --content-padding-inline: 0;
    width: min(100%, 750px);
    margin-inline: auto;
  }
}

@media (min-width: 768px) {
  .area-content.inner {
    width: min(100%, 1000px);
    padding: 0 2em;
  }
}

.area-content__list {
  display: flex;
  flex-direction: column;
  border-radius: 6px;
  overflow: hidden;
}

.area-content__list dt {
  --list-dt-font-size: 24px;

  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px 16px;
  font-family: var(--font-family-gothic);
  font-size: var(--list-dt-font-size);
  font-weight: 700;
  line-height: 141.65%;
  color: var(--color-primary-dark);
  letter-spacing: 1.44px;
  white-space: nowrap;
  background-color: #fff;

  @media (width <=767px) {
    --list-dt-font-size: 14px;
  }
}

.area-content__list dd {
  --list-dd-font-size: 18px;

  padding: 8px 16px;
  margin-block-start: 0;
  margin-block-end: -12px;
  font-family: var(--font-family-gothic);
  font-size: var(--list-dd-font-size);
  font-weight: 700;
  line-height: 1.7;
  color: #333;
  letter-spacing: 1.08px;

  @media (width >=768px) {
    max-width: 750px;
    margin-inline: auto;
  }

  @media (width <=767px) {
    --list-dd-font-size: 12px;
  }

  &:last-child {
    margin-block-end: 0;
    padding-block-end: 12px;
  }
}

.area-content__note {
  --note-font-size: initial;

  padding-block-start: 40px;
  text-align: right;
  font-weight: 700;
  font-size: var(--note-font-size);

  @media (width <=767px) {
    --note-font-size: 10px;
  }
}


/* -----------------------------------------------------
	お客様の声
----------------------------------------------------- */
.reviews {
  background-image: url(/image/reviews/bg-pattern.webp);

  @media (width <=767px) {
    padding-block: 50px 70px;
  }
}

.reviews-items {
  --reviews-items-gap: 40px;
  gap: var(--reviews-items-gap);
  width: min(calc(100% - 30px), 700px);

  @media (width <=767px) {
    --reviews-items-gap: 20px;
  }
}

.reviews-item {
  border-radius: 16px;
  border: 5px solid var(--color-primary-review);
  background-color: var(--color-primary-review);

  &:nth-of-type(even) {
    border: 5px solid var(--color-primary-review-dark);
    background-color: var(--color-primary-review-dark);

    .reviews-item__body {
      background-color: var(--color-primary-review-dark);
    }
  }
}

.reviews-item__head {
  --head-gap: 40px;
  --head-padding: 8.5px 24px;

  display: flex;
  align-items: center;
  gap: var(--head-gap);
  background-color: #fff;
  padding: var(--head-padding);
  border-radius: 12px;

  @media (width <=767px) {
    --head-gap: 16px;
    --head-padding: 8px 16px;
  }
}

.reviews-item__avator {
  --avator-size: 120px;

  flex-shrink: 0;
  width: var(--avator-size);
  height: var(--avator-size);
  border-radius: 50%;
  overflow: hidden;

  @media (width <=767px) {
    --avator-size: 80px;
  }

  img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
  }
}

.reviews-item__meta {
  --meta-gap: 16px;

  display: flex;
  flex-direction: column;
  gap: var(--meta-gap);
  flex: 1;

  @media (width <=767px) {
    --meta-gap: 12px;
  }
}

.reviews-item__title {
  --title-font-size: 24px;
  --title-letter-spacing: 0.48px;

  font-family: var(--font-family-gothic);
  font-size: var(--title-font-size);
  font-weight: 700;
  line-height: 1.4;
  color: #333;
  letter-spacing: var(--title-letter-spacing);

  @media (width <=767px) {
    --title-font-size: 18px;
    --title-letter-spacing: 0.36px;
  }
}

.reviews-item__label {
  --label-gap: 16px;
  --label-span-font-size: 16px;
  --label-span-padding: 4px 8px;
  --label-span-letter-spacing: 0.32px;

  display: flex;
  gap: var(--label-gap);
  align-items: center;

  @media (width <=767px) {
    --label-gap: 8px;
    --label-span-font-size: 12px;
    --label-span-padding: 3px 6px;
    --label-span-letter-spacing: 0.24px;
  }

  span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--label-span-padding);
    border-radius: 8px;
    font-family: var(--font-family-gothic);
    font-size: var(--label-span-font-size);
    font-weight: 700;
    line-height: 1.4;
    color: #fff;
    letter-spacing: var(--label-span-letter-spacing);
    background-color: var(--color-primary-review);
  }
}

.reviews-item__body {
  --body-padding: 16px 32px;
  --body-p-font-size: 20px;
  --body-p-line-height: 1.76;
  --body-p-letter-spacing: 1px;

  background-color: var(--color-primary-review);
  padding: var(--body-padding);

  @media (width <=767px) {
    --body-padding: 12px;
    --body-p-font-size: 14px;
    --body-p-line-height: 1.7;
    --body-p-letter-spacing: 0.7px;
  }

  p {
    font-family: var(--font-family-gothic);
    font-size: var(--body-p-font-size);
    font-weight: 500;
    line-height: var(--body-p-line-height);
    color: #fff;
    letter-spacing: var(--body-p-letter-spacing);
    margin: 0;
  }
}

/* -----------------------------------------------------
  作業までの流れ
----------------------------------------------------- */
.flow {
  padding: 72px 18px 100px;
  background-image: url(/image/content/bg-pattern.webp);
  background-size: 150% auto;
  background-position: 20% -250px;

  @media (width <=767px) {
    padding: 50px 0 70px;
    background-size: 200% auto;
    background-position: 30% -70px;
  }
}

.flow-items {
  --flow-items-gap: 44px;
  gap: var(--flow-items-gap);
  width: min(calc(100% - 30px), 900px);

  @media (width <=767px) {
    --flow-items-gap: 16px;
  }
}

.flow-item {
  --flow-item-flex-direction: row;
  align-items: center;
  flex-direction: var(--flow-item-flex-direction);
  gap: 24px;
  padding: 48px 32px 32px;

  @media (width <=767px) {
    --flow-item-flex-direction: column;
    padding: 48px 20px 30px;
  }
}

.flow-item__arrow {
  --arrow-img-width: initial;

  text-align: center;

  img {
    width: var(--arrow-img-width);

    @media (width <=767px) {
      --arrow-img-width: 70px;
    }
  }
}

.flow-item__title {
  --title-font-size: 28px;
  font-size: var(--title-font-size);
  text-align: center;

  @media (width <=850px) {
    --title-font-size: 24px;
  }

  @media (width <=767px) {
    --title-font-size: 18px;
  }
}

@media (min-width: 768px) {
  .flow-item__text {
    width: calc(100% - 300px);
  }

  .flow-item__image {
    flex: 0 0 300px;
  }
}

.flow-item__image img {
  object-fit: cover;
  aspect-ratio: 16 / 9;
  border-radius: 16px;
}

/* -----------------------------------------------------
	よくある質問
----------------------------------------------------- */
.faq {
  --faq-padding-block: 32px;

  padding-block: var(--faq-padding-block);
  background: repeating-linear-gradient(-45deg,
      #fff,
      #fff 15px,
      var(--color-bg-green-very-light) 10px,
      var(--color-bg-green-very-light) 30px);

  @media (width <=767px) {
    padding-block: 50px 70px;
  }

  @media (width >=768px) {
    --faq-padding-block: 80px;
  }
}

.faq-items {
  --faq-items-gap: 24px;
  gap: var(--faq-items-gap);
  width: min(calc(100% - 30px), 900px);
  padding-bottom: var(--faq-items-padding-bottom);

  @media (width <=767px) {
    --faq-items-gap: 16px;
  }
}

.faq-item {
  border-radius: 7.5px;
  overflow: hidden;
  background-color: #fff;
}

.faq-item__title {
  --title-gap: 10px;
  --title-padding: 16px 32px;
  --title-font-size: 20px;
  --title-before-width: 45px;
  --title-before-height: 36px;

  display: flex;
  align-items: center;
  gap: var(--title-gap);
  padding: var(--title-padding);
  background-color: var(--color-primary);
  border-radius: 7.5px 7.5px 0 0;
  color: #fff;
  font-size: var(--title-font-size);
  font-weight: 700;

  @media (width <=767px) {
    --title-gap: 8px;
    --title-padding: 12px 16px;
    --title-font-size: 16px;
    --title-before-width: 19px;
    --title-before-height: 15px;
  }

  &::before {
    content: "";
    display: inline-block;
    background-image: url("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNDUiIGhlaWdodD0iMzYiIHZpZXdCb3g9IjAgMCA0NSAzNiIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTQxLjg3NSAzNS41QzQxLjA1OTIgMzUuNSA0MC4zNDg3IDM1LjIwODYgMzkuNzQzNCAzNC42MjU4QzM5LjE2NDUgMzQuMDQzIDM4Ljg3NSAzMy4zNDExIDM4Ljg3NSAzMi41MTk5QzM4Ljg3NSAzMS42NzIyIDM5LjE2NDUgMzAuOTU3IDM5Ljc0MzQgMzAuMzc0MkM0MC4zNDg3IDI5Ljc5MTQgNDEuMDU5MiAyOS41IDQxLjg3NSAyOS41QzQyLjY5MDggMjkuNSA0My4zODgyIDI5Ljc5MTQgNDMuOTY3MSAzMC4zNzQyQzQ0LjU3MjQgMzAuOTU3IDQ0Ljg3NSAzMS42NzIyIDQ0Ljg3NSAzMi41MTk5QzQ0Ljg3NSAzMy4zNDExIDQ0LjU3MjQgMzQuMDQzIDQzLjk2NzEgMzQuNjI1OEM0My4zODgyIDM1LjIwODYgNDIuNjkwOCAzNS41IDQxLjg3NSAzNS41WiIgZmlsbD0id2hpdGUiLz4KPHBhdGggZD0iTTE1LjkyMjMgMzVDMTIuODQ3OSAzNSAxMC4wOTcxIDM0LjI4NDcgNy42Njk5IDMyLjg1NDJDNS4yNzUwOCAzMS40MjM3IDMuMzk4MDYgMjkuNDA1MSAyLjAzODgzIDI2Ljc5ODRDMC42Nzk2MTEgMjQuMTU5OSAwIDIxLjA3NjMgMCAxNy41NDc3QzAgMTMuOTg3MyAwLjY3OTYxMSAxMC45MDM3IDIuMDM4ODMgOC4yOTdDMy4zOTgwNiA1LjY1ODQ5IDUuMjc1MDggMy42MjM5OCA3LjY2OTkgMi4xOTM0NkMxMC4wOTcxIDAuNzMxMTUzIDEyLjg0NzkgMCAxNS45MjIzIDBDMTguOTk2OCAwIDIxLjcxNTIgMC43MzExNTMgMjQuMDc3NyAyLjE5MzQ2QzI2LjQ3MjUgMy42MjM5OCAyOC4zNDk1IDUuNjU4NDkgMjkuNzA4NyA4LjI5N0MzMS4xMDAzIDEwLjkwMzcgMzEuNzk2MSAxMy45ODczIDMxLjc5NjEgMTcuNTQ3N0MzMS43OTYxIDE5LjI2NDMgMzEuNjE4MSAyMC44ODU2IDMxLjI2MjEgMjIuNDExNEMzMC45Mzg1IDIzLjkwNTUgMzAuNDUzMSAyNS4yODg0IDI5LjgwNTggMjYuNTU5OUwzNSAzMC40N0wzMS40MDc4IDM0Ljk1MjNMMjYuNDA3OCAzMS4xMzc2QzI1LjA0ODUgMzIuMzc3NCAyMy40NzkgMzMuMzMxMSAyMS42OTkgMzMuOTk4NkMxOS45NTE1IDM0LjY2NjIgMTguMDI1OSAzNSAxNS45MjIzIDM1Wk0xNS45MjIzIDI5LjY1OTRDMTcuMDU1IDI5LjY1OTQgMTguMTIzIDI5LjQ4NDYgMTkuMTI2MiAyOS4xMzQ5QzIwLjEyOTQgMjguNzUzNCAyMS4wMTk0IDI4LjI0NDggMjEuNzk2MSAyNy42MDlMMTcuMjMzIDI0LjA4MDRMMjAuNjc5NiAxOS43NDExTDI1IDIzLjAzMTNDMjUuMjkxMyAyMi4yMzY2IDI1LjUxNzggMjEuMzc4MyAyNS42Nzk2IDIwLjQ1NjRDMjUuODQxNCAxOS41MzQ1IDI1LjkyMjMgMTguNTY0OSAyNS45MjIzIDE3LjU0NzdDMjUuOTIyMyAxNS4wOTk5IDI1LjUwMTYgMTIuOTcgMjQuNjYwMiAxMS4xNThDMjMuODUxMSA5LjMxNDI2IDIyLjcwMjMgNy44OTk2NCAyMS4yMTM2IDYuOTE0MTdDMTkuNzI0OSA1Ljg5NjkxIDE3Ljk2MTIgNS4zODgyOCAxNS45MjIzIDUuMzg4MjhDMTMuOTE1OSA1LjM4ODI4IDEyLjE1MjEgNS44OTY5MSAxMC42MzExIDYuOTE0MTdDOS4xMTAwMyA3Ljg5OTY0IDcuOTI4OCA5LjMxNDI2IDcuMDg3MzggMTEuMTU4QzYuMjc4MzIgMTIuOTcgNS44NzM3OSAxNS4wOTk5IDUuODczNzkgMTcuNTQ3N0M1Ljg3Mzc5IDE5Ljk2MzcgNi4yNzgzMiAyMi4wOTM2IDcuMDg3MzggMjMuOTM3M0M3LjkyODggMjUuNzQ5MyA5LjExMDAzIDI3LjE2MzkgMTAuNjMxMSAyOC4xODEyQzEyLjE1MjEgMjkuMTY2NyAxMy45MTU5IDI5LjY1OTQgMTUuOTIyMyAyOS42NTk0WiIgZmlsbD0id2hpdGUiLz4KPC9zdmc+Cg==");
    background-size: contain;
    width: var(--title-before-width);
    height: var(--title-before-height);
    width: 35px;
    height: 28px;
    background-repeat: no-repeat;
    flex-shrink: 0;

    @media (width <=767px) {
      width: 30px;
      height: 24px;
    }
  }
}

.faq-item__desc {
  --desc-font-size: initial;
  --desc-padding: 24px 32px;

  margin: 0;
  padding: var(--desc-padding);
  border: 4px solid var(--color-primary);
  border-top: none;
  border-radius: 0 0 7.5px 7.5px;
  background-color: #fff;
  font-size: var(--desc-font-size);

  @media (width <=767px) {
    --desc-font-size: 14px;
    --desc-padding: 8px 16px;
  }
}

/* -----------------------------------------------------
	こんなお悩み、ございませんか？
----------------------------------------------------- */

.worries {
  background: #EEFFF0;
  padding-block: 50px 80px;

  @media (width <=850px) {
    padding-block: 10px;
  }
}

.trouble {
  width: min(calc(100% - 30px), 900px);
  margin-inline: auto;
  padding: 36px 24px;
  background-color: transparent;

  @media (width <=850px) {
    padding: 30px 10px 25px;
  }
}

.trouble-content__title {
  --title-padding-bottom: 48px;
  --title-display: block;

  font-size: min(4.7svw, 36px);
  font-weight: 700;
  padding-block-end: var(--title-padding-bottom);
  display: var(--title-display);

  @media (width >=851px) {
    text-align: center;
  }

  @media (width <=850px) {
    --title-padding-bottom: 16px;
    --title-display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
  }

  @media (width <=767px) {
    font-size: 24px;
  }

  span {
    font-size: min(6.3svw, 48px);
    color: var(--color-primary);

    @media (width <=767px) {
      font-size: 30px;
    }
  }
}

.trouble-customer__illust {
  flex: 202px 0 1;
  margin-inline-start: auto;

  @media (width <=850px) {
    display: none;
  }
}

.trouble-customer__illust--sp {
  flex: 70px 0 1;

  @media (width >=851px) {
    display: none;
  }
}

.trouble-checklist {
  >li {
    display: flex;
    column-gap: 16px;
    align-items: center;
    font-size: min(3.7svw, 28px);
    font-weight: 700;
    color: var(--color-primary);
    margin-block-end: 16px;
    padding-block-end: 16px;
    border-bottom: dashed 1px var(--color-primary);

    &:last-child {
      margin-block-end: 0;
    }

    &::before {
      content: "";
      background-image: url("/image/trouble/checkbox.svg");
      display: inline-block;
      width: min(6.4svw, 49px);
      aspect-ratio: 49 / 45;
      background-size: contain;
      background-repeat: no-repeat;
    }
  }
}

.trouble-check {
  --check-justify-content: initial;

  display: flex;
  align-items: flex-end;
  justify-content: var(--check-justify-content);

  @media (width <=850px) {
    --check-justify-content: center;
  }
}

.cta--bottom {
  background: #EEFFF0;

  @media (width >=768px) {
    text-align: center;
    background-image: url(/image/trouble/solution-pc-1920.webp);
    background-repeat: no-repeat;
    background-position: center top;
    background-size: auto 100%;
  }

  @media (width <=850px) {
    padding-inline: 10px;
  }

  @media (width <=767px) {
    padding-inline: 0;
  }

  img {
    width: 100%;
  }
}

.solution_image_inner {
  @media (width >=768px) {
    width: min(83.34svw, 1200px);
    margin-inline: auto;
  }
}

/* -----------------------------------------------------
	お問合せフォーム
----------------------------------------------------- */
.contact_form {
  padding-block-start: 44px;

  @media (width >=768px) {
    background-color: transparent;
    max-width: 1000px;
    margin-inline: auto;
    padding-block-start: 120px;
  }
}

#contact {
  --ads-faq-key: #23A83B;
  --ads-faq-max: 1100px;
  --color-primary: #23A83B;
}

#contact .contact__section-title {
  --ads-faq-title-en: 64px;
  display: flex;
  flex-direction: column;
  text-align: center;
  gap: 8px;
  font-weight: 700;
  margin-bottom: 0 !important;
  padding-bottom: 40px;
}

#contact .contact__section-title::before {
  display: block;
  font-size: 40px;
  text-transform: uppercase;
  letter-spacing: 0.28em;
  content: attr(data-title--en);
  color: #61ca3e;
  line-height: 1;
}

@media (width <=767px) {
  #contact .contact__section-title {
    padding-bottom: 10px;
  }

  #contact .contact__section-title::before {
    font-size: 36px;
    letter-spacing: 5px;
  }
}

#contact .contact__section-title span {
  color: #666;
}

@media (width <=767px) {
  #contact .contact__section-title span {
    font-size: 14px;
  }
}

.contact_form_title {
  padding-block-end: 30px;
  font-family: var(--font-family-mplus);
  font-size: 24px;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 10px;

  &::after {
    content: "";
    display: block;
    height: 6px;
    width: 96px;
    background-color: var(--color-red);
    border-radius: 6px;
    margin-inline: auto;
  }

  @media (width <=767px) {
    font-size: 18px;
  }
}

/* -----------------------------------------------------
	フッター
----------------------------------------------------- */
.footer {
  padding-block-start: 100px;

  @media (width <=767px) {
    padding-block-start: 50px;
  }
}

.footer_sitemap {
  padding-block: 20px;

  ul {
    list-style: none;
    display: flex;
    justify-content: center;

    li {
      &:nth-child(n + 2):before {
        content: "｜";
      }

      a {
        color: #333;
        margin: 0 1em;
        transition-property: color;
        transition-duration: 0.3s;
        transition-timing-function: ease;

        &:hover {
          @media (hover: hover) {
            text-decoration: underline;
          }
        }
      }
    }
  }
}

.footer_sitemap_list {
  display: flex;
  justify-content: center;
  list-style: none;

  li {
    a {
      margin: 0 1em;
      font-size: 14px;
      color: #333;
    }

    :last-child {
      ::before {
        content: "｜";
      }
    }
  }
}

.footer_copyright {
  padding-block: 20px;
  font-size: 12px;
  color: #222;
  text-align: center;
  background: #f0f0f0;
}

/* ----------------------------------------------------------------------
下層ページ共通
---------------------------------------------------------------------- */
.page_container {
  width: min(100%, 1000px);
  margin: 100px auto 0;

  @media (width <=1000px) {
    padding-inline: 20px;
  }

  @media (width <=767px) {
    margin: 40px auto 0;
  }
}

@media (width >=768px) {
  .page_container.company {
    margin: 80px auto 0;
  }
}

.comapny_info {
  width: inherit;
  line-height: 2.5;
  border-collapse: collapse;

  @media (width <=767px) {
    font-size: 14px;
    margin-top: -20px;
  }

  tbody {
    tr {
      border-bottom: 1px solid #ddd;

      &:last-of-type {
        border-bottom: none;
      }

      @media (width <=767px) {
        display: flex;
        flex-direction: column;
        padding: 1em 0;
      }
    }

    th,
    td {
      padding: 20px 5px 20px 50px;

      @media (width <=767px) {
        padding-inline-start: 20px;
      }
    }

    th {
      width: 25%;
      font-weight: bold;
      vertical-align: top;
      text-align: left;

      @media (width <=767px) {
        text-align: left;
        padding: 0;
      }
    }

    td {
      width: 75%;

      @media (width <=767px) {
        width: auto;
        padding: 0 0 0 1em;
        line-height: 1.8;
      }
    }
  }
}

.page-title {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-block: 32px 50px;
  font-size: 20px;
  font-weight: 700;
  color: var(--color-blue-dark);
  text-align: center;

  &::after {
    display: block;
    width: 96px;
    height: 6px;
    margin-inline: auto;
    content: "";
    background-color: var(--color-red-light);
    border-radius: 6px;
  }
}

/* パンくずリスト */
.breadcrumbs {
  width: min(100%, 1000px);
  margin: 0 auto;
  font-size: 14px;

  @media (width <=1000px) {
    padding-inline: 20px;
  }

  a {
    color: #333;
    transition:
      background-color 0.2s ease,
      color 0.2s ease;

    @media (any-hover: hover) {
      &:hover {
        color: #999;
      }
    }
  }
}

.pan1 {
  padding: 0 0.8em;
}

/* ----------------------------------------------------------------------
プライバシーポリシー
---------------------------------------------------------------------- */
@media (width >=768px) {
  .page_container.privacy {
    margin: 80px auto 0;
  }
}

.privacy_items {
  display: flex;
  flex-direction: column;
  gap: 30px;
  margin-block-start: 40px;
  font-size: 14px;

  >dl {

    >dt,
    >dd {
      font-size: 14px;

      @media (width >=768px) {
        font-size: 16px;
      }
    }

    >dt {
      margin-block-end: 5px;
      font-weight: 700;

      @media (width <=767px) {
        margin-block-end: 3px;
      }
    }
  }
}

.privacy_address {
  padding: 25px;
  margin-block-start: 50px;
  font-size: 14px;
  font-style: normal;
  border: solid 1px #ccc;

  @media (width >=768px) {
    font-size: 16px;
  }
}

/* ----------------------------------------------------------------------
フッターバー
---------------------------------------------------------------------- */
.acebar {
  position: fixed;
  right: 0px;
  bottom: -3px;
  z-index: 999;
  width: 100%;
  opacity: 0;
  pointer-events: none;
  transition: all;
  transition-duration: 1s;
  transform: translateY(20%) translateX(0%);

  @media (width >=768px) {
    display: none;
  }

  &.active {
    transform: translateY(0%) translateX(0);
    opacity: 1;
    pointer-events: auto;
    transition-duration: 1s;
    background: #fff;
  }
}

.acebar_list {
  margin: 0;
  list-style: none;
  background: transparent;
  display: flex;
  flex-wrap: wrap;
  font-size: 14px;
  width: 100%;
  z-index: 9998;
  line-height: 1.5;
  height: auto;

  li {
    flex: 1;
    display: flex;
    /* justify-content: center; */
    align-items: center;

    a {
      display: block;

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

.acebar-operator {
  background-image: url(./image/footerbar/bg-operator.webp);
  background-size: 30%;
  background-repeat: no-repeat;
  background-position: right -10px bottom;
}

.acebar-address {
  display: flex;
  flex-direction: column;
  column-gap: 67px;
  font-style: normal;
  justify-content: center;
}


.acebar-tel__number {
  align-items: center;
  line-height: 1.1;
  color: #333;
  font-weight: 700;
  /* font-size: min(5.86svw, 22px); */
  font-size: 6.1svw;
}

.acebar-tel__number.acebar-tel__number::before {
  /* content: ""; */
  background-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNjYiIGhlaWdodD0iMzgiIHZpZXdCb3g9IjAgMCA2NiAzOCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTU2LjkxIDBIMFYzNy4xNEg1Ni45MVYwWiIgZmlsbD0iIzAwQTczQyIvPgo8cGF0aCBkPSJNNTguNjEwMSAzMy42MDk4QzU4LjYxMDEgMzUuNTY5OCA2MC4yMDAxIDM3LjE2OTggNjIuMTcwMSAzNy4xNjk4QzY0LjE0MDEgMzcuMTY5OCA2NS43MzAxIDM1LjU2OTggNjUuNzMwMSAzMy42MDk4QzY1LjczMDEgMzEuNjQ5OCA2NC4xMzAxIDMwLjA0OTggNjIuMTcwMSAzMC4wNDk4QzYwLjIxMDEgMzAuMDQ5OCA1OC42MTAxIDMxLjYzOTggNTguNjEwMSAzMy42MDk4Wk01OS4wMjAxIDMzLjYwOThDNTkuMDIwMSAzMS44Nzk4IDYwLjQzMDEgMzAuNDY5OCA2Mi4xNzAxIDMwLjQ2OThDNjMuOTEwMSAzMC40Njk4IDY1LjMxMDEgMzEuODc5OCA2NS4zMTAxIDMzLjYwOThDNjUuMzEwMSAzNS4zMzk4IDYzLjkwMDEgMzYuNzQ5OCA2Mi4xNzAxIDM2Ljc0OThDNjAuNDQwMSAzNi43NDk4IDU5LjAyMDEgMzUuMzM5OCA1OS4wMjAxIDMzLjYwOThaIiBmaWxsPSJibGFjayIvPgo8cGF0aCBkPSJNNjMuOSAzNS45MUg2My4yMkw2MS44NCAzMy43N0g2MS4yM1YzNS45MUg2MC42ODAxVjMxLjIxSDYyLjAxQzYyLjQ1IDMxLjIxIDYyLjgxMDEgMzEuMzIgNjMuMDcwMSAzMS41M0M2My4zMzAxIDMxLjc1IDYzLjQ2IDMyLjA1IDYzLjQ2IDMyLjQzQzYzLjQ2IDMyLjcyIDYzLjM3MDEgMzIuOTcgNjMuMTgwMSAzMy4xOUM2Mi45OTAxIDMzLjQxIDYyLjczIDMzLjU2IDYyLjQgMzMuNjVMNjMuOSAzNS45TTYxLjIzIDMzLjNINjEuOTJDNjIuMjEgMzMuMyA2Mi40NDAxIDMzLjIyIDYyLjYyMDEgMzMuMDdDNjIuODAwMSAzMi45MSA2Mi44OSAzMi43MiA2Mi44OSAzMi40OEM2Mi44OSAzMS45NSA2Mi41NzAxIDMxLjY5IDYxLjkzMDEgMzEuNjlINjEuMjNWMzMuM1oiIGZpbGw9ImJsYWNrIi8+CjxwYXRoIGQ9Ik0xNC4zIDI4LjgxMDNDMTEuMTggMjguODEwMyA3LjMwMDAyIDI2LjQyMDMgNy4zMDAwMiAyMS41MDAzQzcuMzAwMDIgMTcuNjgwMyAxMS4wOCAxNC42MzAzIDE0LjMgMTIuODAwM0MxNy41MSAxNC42MzAzIDIxLjMgMTcuNjgwMyAyMS4zIDIxLjUwMDNDMjEuMyAyNi40MjAzIDE3LjQzIDI4LjgxMDMgMTQuMyAyOC44MTAzWk0zNS43NCAyMS40MjAzQzM1Ljc0IDE3LjYwMDMgMzkuNTIgMTQuNTUwMyA0Mi43NCAxMi43MjAzQzQ1Ljk1IDE0LjU1MDMgNDkuNzMgMTcuNjAwMyA0OS43MyAyMS40MjAzQzQ5LjczIDI2LjM0MDMgNDUuODYgMjguNzMwMyA0Mi43NCAyOC43MzAzQzM5LjYyIDI4LjczMDMgMzUuNzQgMjYuMzUwMyAzNS43NCAyMS40MjAzWk01Ni45IDUuNzgwMjdDNTEuMTIgNS43ODAyNyA0NS45OSA3LjIyMDI3IDQyLjUxIDkuMDMwMjdDMzkuMDMgNy4yMjAyNyAzNC4yMiA1Ljc4MDI3IDI4LjQ0IDUuNzgwMjdDMjIuNjYgNS43ODAyNyAxNy44NSA3LjIyMDI3IDE0LjM3IDkuMDMwMjdDMTAuODkgNy4yMjAyNyA1Ljc3IDUuNzgwMjcgMCA1Ljc4MDI3VjkuMDMwMjdDMy40MiA5LjAzMDI3IDcuNTYwMDEgOS42NzAyOSAxMC44MiAxMS4wODAzQzcuMzEwMDEgMTMuNDMwMyAzLjgzMDAyIDE2Ljk5MDMgMy44MzAwMiAyMS40OTAzQzMuODMwMDIgMjcuNDMwMyA4Ljg5MDAxIDMxLjk3MDMgMTQuMzggMzEuOTcwM0MxOS44NyAzMS45NzAzIDI0LjY5IDI3LjQzMDMgMjQuNjkgMjEuNDkwM0MyNC42OSAxNi45OTAzIDIxLjQ2IDEzLjQzMDMgMTcuOTQgMTEuMDgwM0MyMS4yIDkuNjYwMjkgMjUuMDMgOS4wMzAyNyAyOC40NSA5LjAzMDI3QzMxLjg3IDkuMDMwMjcgMzUuNzEgOS42NzAyOSAzOC45NiAxMS4wODAzQzM1LjQ0IDEzLjQzMDMgMzIuMjEgMTYuOTkwMyAzMi4yMSAyMS40OTAzQzMyLjIxIDI3LjQzMDMgMzcuMDIgMzEuOTcwMyA0Mi41MSAzMS45NzAzQzQ4IDMxLjk3MDMgNTIuOTkgMjcuNDMwMyA1Mi45OSAyMS40OTAzQzUyLjk5IDE2Ljk5MDMgNDkuNTkgMTMuNDMwMyA0Ni4wNyAxMS4wODAzQzQ5LjMzIDkuNjYwMjkgNTMuNDggOS4wMzAyNyA1Ni45IDkuMDMwMjdWNS43ODAyN1oiIGZpbGw9IndoaXRlIi8+Cjwvc3ZnPgo=);
  background-repeat: no-repeat;
  width: min(3.47svw, 66px);
  aspect-ratio: 33/19;
  display: inline-block;
  translate: 0 4px;
  background-size: contain;
}

.acebar-address__tel {
  display: flex;
  flex-direction: column;
  padding-inline-start: 6px;
}

.acebar-address__topic {
  font-size: 2.1svw;
  font-weight: 700;
  padding-inline-start: 8px;
}

.acebar-message__tel {
  font-size: 2.6svw;
  font-weight: 700;
  display: flex;
  gap: 3px;
  padding-inline-start: 4px;
  align-items: center;

  &::before {
    content: "";
    background-image: url('data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzEiIGhlaWdodD0iMzEiIHZpZXdCb3g9IjAgMCAzMSAzMSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTEzLjYzMzcgMjUuMTgwOEMxNi4wMzcyIDI2Ljg4OTMgMTguNjI5IDI4LjMyMjcgMjEuMzM2NyAyOS40NTIxQzIyLjY5MDUgMzAuMDE2OCAyMy42MDI3IDMwLjI5OTIgMjQuMTA5NCAzMC4zMjA5SDI0LjE4MThDMjYuMDg1OCAzMC4zMjA5IDI4LjU0MDEgMjYuODk2NSAyOC44Mjk3IDI1Ljc4ODlDMjkuMTc3MiAyNC40NjQgMjguNjc3NiAyMy4wNTk1IDI3LjU1NTUgMjIuMjEyNUwyNS4wMDcxIDIwLjI5NEMyNC4zNzAxIDE5LjgxNjIgMjMuNjA5OSAxOS41NjI4IDIyLjc5OTEgMTkuNTYyOEMyMS45MDEzIDE5LjU2MjggMjEuMDMyNiAxOS44ODEzIDIwLjM2NjUgMjAuNDY3N0MxOS45NzU2IDIwLjgxNTMgMTkuNDQ3MSAyMS4zMDAzIDE5LjE1MDMgMjEuNjY5NUMxOS4xMjg2IDIxLjY4NCAxOS4wOTI0IDIxLjY5MTIgMTkuMDQ4OSAyMS42OTEyQzE3Ljk3NzUgMjEuNjkxMiAxNC4yNDE4IDE4LjU2MzcgMTMuMjQyOCAxNy41NjQ3QzEyLjE4NTggMTYuNTg3MyA4LjkwNjIxIDEyLjk1MyA4Ljk2NDEzIDExLjk2MTJDOC45NjQxMyAxMS44ODg4IDguOTkzMDkgMTEuODc0MyA5LjAwMDMzIDExLjg2NzFDOS4zNjk1NSAxMS41OTkyIDkuODY5MDkgMTEuMDkyNCAxMC4yMzExIDEwLjcwODdDMTEuNDE4NCA5LjQ1NjI5IDExLjQ5OCA3LjU4MTIzIDEwLjQxOTMgNi4yNDkxM0w4LjQyODQgMy43OTQ4OUM4LjI3NjM3IDMuNjA2NjYgOC4wOTUzOCAzLjQzMjkxIDcuODM0NzUgMy4yMzAyQzcuNzMzMzkgMy4xNTc4IDcuNjM5MjggMy4wODU0MiA3LjQ5NDQ5IDIuOTk4NTVDNy4wNDU2MyAyLjczMDY4IDYuNTQ2MSAyLjU1NjkzIDYuMDAzMTIgMi40OTkwMUM1Ljg1ODMzIDIuNDg0NTMgNS43MTM1NCAyLjQ3NzI5IDUuNTYxNTEgMi40NzcyOUM1LjI3MTkyIDIuNDc3MjkgNC45ODIzNCAyLjUxMzQ4IDQuNzE0NDcgMi41Nzg2NEMzLjY5MzY4IDIuODI0NzkgLTAuMDg1NDAxOCA1LjE5MjE2IDAuMDAxNDczNzMgNy4xMTc5QzAuMDIzMTkyNiA3LjYxMDE5IDAuMzIwMDE3IDguNDg2MTcgMC45MDY0MjcgOS43ODkzQzIuMDc5MjUgMTIuMzk1NiAzLjU3MDYxIDE0Ljg5MzIgNS4zNTE1NiAxNy4yMTcyQzcuNjgyNzIgMjAuMjY1IDEwLjQ3IDIyLjk1MSAxMy42NDA5IDI1LjE5NTJMMTMuNjMzNyAyNS4xODA4WiIgZmlsbD0iIzA0QUEzQSIvPgo8cGF0aCBkPSJNMjYuMzk3MiAzLjc4NzY0QzI0LjI5NzcgMS43Njc3OSAyMS42NDA4IDAuNDY0NjM3IDE4Ljc1OTQgMC4wMTU3ODAyQzE4LjU3ODQgLTAuMDEzMTc4MyAxOC40MDQ3IDAuMDAxMzE1MTIgMTguMjM4MiAwLjAzMDI3MzZDMTguMTUxMyAwLjA1MTk5MjUgMTguMDY0NCAwLjA3MzcwMDggMTcuOTc3NSAwLjEwOTg5OUgxNy45NjMxQzE3Ljg4MzQgMC4xNDYwOTcgMTcuODAzOCAwLjE4MjMwNSAxNy43MzE0IDAuMjMyOTgyQzE3LjczMTQgMC4yMzI5ODIgMTcuNzI0MiAwLjIzMjk4OSAxNy43MTY5IDAuMjQwMjI5QzE3LjY0NDUgMC4yOTA5MDYgMTcuNTcyMSAwLjM0MTU3IDE3LjUxNDIgMC40MDY3MjZDMTcuMjUzNiAwLjY2MDExMyAxNy4wNzk4IDEuMDAwMzkgMTcuMDc5OCAxLjM5MTMzQzE3LjA3OTggMi4wNzE4NSAxNy41Nzk0IDIuNjY1NSAxOC4yNzQ0IDIuNzc0MUMyMC41NjkzIDMuMTI4ODQgMjIuNjc2MSA0LjE1Njg2IDI0LjM0MTIgNS43NTY4MkMyNi4wMDYzIDcuMzY0MDIgMjcuMDc3OCA5LjM5MTExIDI3LjQ0NyAxMS41OTJDMjcuNTU1NiAxMi4yNTggMjguMTc4MiAxMi43NDMxIDI4Ljg4MDQgMTIuNzQzMUMyOS43NzgxIDEyLjc0MzEgMzAuNDY1OSAxMS45Njg0IDMwLjMyMTEgMTEuMTIxNEMyOS44NTA1IDguMzQ4NjEgMjguNTA0IDUuODAwMjQgMjYuNDA0NSAzLjc3MzE1TDI2LjM5NzIgMy43ODc2NFoiIGZpbGw9IiMwNEFBM0EiLz4KPHBhdGggZD0iTTE4LjEwNzggOC41MDc2NkMxOC44OTY5IDguNzQ2NTYgMTkuNjEzNiA5LjE2NjQ3IDIwLjIwNzMgOS43Mzg0QzIwLjgwMDkgMTAuMzEwMyAyMS4yNDI1IDExLjAwNTMgMjEuNDk1OSAxMS43NTgyQzIxLjY5MTQgMTIuMzQ0NyAyMi4yNDg4IDEyLjc1MDEgMjIuODg1OSAxMi43NTAxQzIzLjg1NiAxMi43NTAxIDI0LjU4IDExLjg1MjQgMjQuMjkwNCAxMC45NjE5QzIzLjkwNjcgOS43NjAxMiAyMy4yMTkgOC42NjY5MiAyMi4yNzA2IDcuNzU0NzNDMjEuMzIyMiA2Ljg0MjU0IDIwLjE3ODMgNi4xODM3MyAxOC45MzMxIDUuODA3MjdDMTguMDA2NCA1LjUzMjE2IDE3LjA3MjUgNi4yMjcxOCAxNy4wNzI1IDcuMTUzODVDMTcuMDcyNSA3Ljc3NjQ2IDE3LjQ5MjQgOC4zMTIxOCAxOC4xMDc4IDguNTAwNDFWOC41MDc2NloiIGZpbGw9IiMwNEFBM0EiLz4KPC9zdmc+');
    background-size: contain;
    width: 12px;
    display: inline-block;
    aspect-ratio: 1;
    background-repeat: no-repeat;
  }
}

/* -----------------------------------------------------
	キャッシュレス決済にも対応
----------------------------------------------------- */
.payment_methods {
  padding: 30px 10px;
  background-color: #ACDF96;
  background-image: url(/image/content/payment_methods_bg.webp);
  background-repeat: no-repeat;
  background-position: center top;
  background-size: cover;

  @media (width >=768px) {
    padding-block: 74px;
  }
}

.payment_methods_title {
  margin-block-end: 15px;
  font-family: var(--font-family-mplus);
  font-size: 22px;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.05em;
  line-height: 1.2;

  @media (width >=768px) {
    margin-block-end: 40px;
    font-size: 40px;
    line-height: 1;
  }
}

.payment_methods_text {
  font-size: 14px;
  font-weight: normal;
  letter-spacing: initial;
  font-family: initial;

  @media (width >=768px) {
    font-size: 16px;
  }
}

.payment_method__bnrs {
  display: flex;
  gap: 15px 32px;
  margin-inline: auto;

  @media (width <=767px) {
    flex-direction: column;
  }

  @media (width >=768px) {
    justify-content: center;
    width: min(66.8svw, 1080px);
  }
}

.payment_method__bnr {
  @media (width >=768px) {
    width: min(48.52%, 524px);
  }
}

/* -----------------------------------------------------
	nowtime（現在時刻表示ボックス）
----------------------------------------------------- */
.nowtime {
  background-color: #194800;
  color: #fff;
  font-size: clamp(1.125rem, 1.034rem + 0.3883vw, 1.5rem);
  font-weight: 700;
  text-align: center;
  padding-block: 10px;

  .nt_dl {
    color: #fff646;
    letter-spacing: 0.05em;

    .nt_dt {
      font-size: clamp(1rem, 0.7573rem + 1.0356vw, 2rem);
    }

    .num {
      font-size: clamp(1.5rem, 1.1359rem + 1.5534vw, 3rem);
    }
  }

  .nowtime__catch {
    font-size: clamp(0.75rem, 0.568rem + 0.7767vw, 1.5rem);
  }
}

/* -----------------------------------------------------
	導入までの流れ・よくある質問（広告運用・ace引用）
	クラスは ads- プレフィックスで既存の .flow / .faq と衝突回避
----------------------------------------------------- */

/* ---------- 導入までの流れ（ads-flow） ---------- */
.ads-flow {
  padding: 80px 0;

  @media (width <=767px) {
    padding: 20px 0 40px;
  }
}

.ads-flow-inner {
  width: min(1100px, 92%);
  margin: 0 auto;
}

.ads-flow .ads-flow__section-title {
  --ads-flow-title-en: 64px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  font-weight: 700;
  text-align: left;
  margin-bottom: 0;
  padding-bottom: 76px;
}

.ads-flow .ads-flow__section-title::before {
  display: block;
  font-size: var(--ads-flow-title-en);
  text-transform: uppercase;
  letter-spacing: 0.28em;
  content: attr(data-title--en);
  color: #61ca3e;
  line-height: 1;
}

@media (width <=767px) {
  .ads-flow .ads-flow__section-title {
    text-align: center;
    padding-bottom: 30px;
  }

  .ads-flow .ads-flow__section-title::before {
    font-size: 36px;
    letter-spacing: 5px;
  }
}

.ads-flow .ads-flow__section-title span {
  color: #666;
}

@media (width <=767px) {
  .ads-flow .ads-flow__section-title span {
    font-size: 14px;
  }
}

.ads-flow-list {
  display: flex;
  flex-direction: column;
  gap: 24px;
  max-width: 950px;
  margin: auto;
}

@media (width <=480px) {
  .ads-flow-list {
    gap: 13px;
  }
}

.ads-flow-item {
  background: #fff;
  border-radius: 12px;
  padding: 24px 38px;
  border: solid #ccc 1px;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
}

.ads-flow-item__text {
  width: calc(100% - 330px);
  padding-right: 48px;
}

@media (width <=913px) {
  .ads-flow-item__text {
    width: 65%;
    padding-right: 20px;
  }
}

@media (width <=767px) {
  .ads-flow-item__text {
    width: 100%;
    padding-right: 0;
  }
}

.ads-flow-item__head {
  display: flex;
  align-items: center;
  margin-bottom: 14px;
}

.ads-flow-item__title {
  font-size: 20px;
  font-weight: 700;
  color: #4CAF50;
}

@media (width <=480px) {
  .ads-flow-item__title {
    font-size: 16px;
  }
}

.ads-flow-item__content {
  display: flex;
  align-items: center;
  gap: 18px;
}

.ads-flow-item__image {
  flex: 0 0 330px;
  border-radius: 8px;
  overflow: hidden;
  margin: 0;
}

.ads-flow-item__image img {
  width: 100%;
  height: auto;
}

@media (width <=913px) {
  .ads-flow-item__image {
    flex: 0 0 35%;
  }
}

@media (width <=767px) {
  .ads-flow-item__image {
    margin-top: 20px;
  }
}

.ads-flow-item__p {
  line-height: 1.9;
  font-size: 15px;
  color: #666;
}

@media (width <=480px) {
  .ads-flow-item__p {
    line-height: 1.6;
    font-size: 13px;
  }
}

.ads-flow-step {
  position: relative;
  display: inline-flex;
  align-items: center;
  padding: 5px 20px 5px 20px;
  font-size: 16px;
  font-weight: 700;
  color: #fff;
  background: #4caf50;
  border-radius: 0 3px 3px 0;
  margin-left: -50px;
  margin-right: 50px;
  white-space: nowrap;
}

.ads-flow-step::before {
  content: "";
  position: absolute;
  top: 100%;
  left: 0;
  border-top: 5px solid #568253;
  border-right: 0px solid transparent;
  border-left: 12px solid transparent;
}

@media (width <=767px) {
  .ads-flow-step {
    margin-right: 20px;
  }
}

@media (width <=480px) {
  .ads-flow-step {
    padding: 2px 10px 3px 9px;
    font-size: 14px;
  }
}

.ads-flow-triangle {
  display: flex;
  justify-content: center;
}

.ads-flow-triangle img {
  width: 48px;
  height: auto;
}

@media (max-width: 767px) {
  .ads-flow-item__content {
    flex-direction: column;
    align-items: flex-start;
  }

  .ads-flow-item__image {
    flex-basis: auto;
    width: 100%;
  }
}

/* ---------- よくある質問（ads-faq） ---------- */
#ads-page-faq {
  --ads-faq-key: #23A83B;
  --ads-faq-max: 1100px;
  --color-primary: #23A83B;
}

.ads-faq {
  padding: 48px 0 120px;

  @media (width <=767px) {
    padding: 48px 0 80px;
  }
}

.ads-faq-inner {
  width: min(1100px, 92%);
  margin: 0 auto;
}

#ads-page-faq .ads-faq__section-title {
  --ads-faq-title-en: 64px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  font-weight: 700;
  text-align: left;
  margin-bottom: 0 !important;
  padding-bottom: 71px;
}

#ads-page-faq .ads-faq__section-title::before {
  display: block;
  font-size: var(--ads-faq-title-en);
  text-transform: uppercase;
  letter-spacing: 0.28em;
  content: attr(data-title--en);
  color: #61ca3e;
  line-height: 1;
}

@media (width <=767px) {
  #ads-page-faq .ads-faq__section-title {
    text-align: center;
    padding-bottom: 30px;
  }

  #ads-page-faq .ads-faq__section-title::before {
    font-size: 36px;
    letter-spacing: 5px;
  }
}

#ads-page-faq .ads-faq__section-title span {
  color: #666;
}

@media (width <=767px) {
  #ads-page-faq .ads-faq__section-title span {
    font-size: 14px;
  }
}

#ads-page-faq .ads-faq__container {
  width: min(92vw, var(--ads-faq-max));
  margin-inline: auto;
}

#ads-page-faq .ads-faq-items {
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin: 0 auto;
  width: 100%;
  max-width: 1100px;
}

@media (width <=767px) {
  #ads-page-faq .ads-faq-items {
    gap: 12px;
  }
}

#ads-page-faq .ads-faq-item {
  background: #fff;
  overflow: hidden;
}

#ads-page-faq .ads-faq-question {
  display: flex;
  align-items: center;
  gap: 16px;
  position: relative;
  cursor: pointer;
  padding: 20px 48px 20px 27px;
  background: var(--ads-faq-key);
  border: solid 1px var(--ads-faq-key);
  border-radius: 12px;
  transition: all 0.2s;
}

@media (width <=767px) {
  #ads-page-faq .ads-faq-question {
    gap: 8px;
    padding: 17px 40px 17px 15px;
    border-radius: 16px;
    font-size: 16px;
  }
}

#ads-page-faq .ads-faq-item.is-active .ads-faq-question {
  border-radius: 12px 12px 0 0;
}

#ads-page-faq .ads-faq-question::after,
#ads-page-faq .ads-faq-question::before {
  content: "";
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  background-color: #fff;
  transition: opacity 0.2s, transform 0.25s;
}

@media (max-width: 767px) {

  #ads-page-faq .ads-faq-question::after,
  #ads-page-faq .ads-faq-question::before {
    right: 10px;
  }
}

#ads-page-faq .ads-faq-question::after {
  width: 24px;
  height: 3px;
}

@media (max-width: 767px) {
  #ads-page-faq .ads-faq-question::after {
    width: 20px;
  }
}

#ads-page-faq .ads-faq-question::before {
  width: 3px;
  height: 24px;
  right: 30px;
}

@media (max-width: 767px) {
  #ads-page-faq .ads-faq-question::before {
    height: 20px;
    right: 18px;
  }
}

#ads-page-faq .ads-faq-item.is-active .ads-faq-question::before {
  opacity: 0;
  transform: translateY(-50%) scaleY(0);
}

#ads-page-faq .ads-faq-item__q,
#ads-page-faq .ads-faq-item__a {
  font-weight: 700;
  color: #fff;
  font-size: 32px;
  line-height: 1;
}

@media (width <=767px) {

  #ads-page-faq .ads-faq-item__q,
  #ads-page-faq .ads-faq-item__a {
    font-size: 24px;
  }
}

:where(.ads-faq-item__q, .ads-faq-item__a) {
  color: var(--color-primary);
  font-size: clamp(1.9rem, -1.5067rem + 10.6952vw, 2.25rem);
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  flex-shrink: 0;
}

#ads-page-faq .ads-faq-item__a {
  color: #FF8834;
}

#ads-page-faq .ads-faq-item__question {
  font-size: 20px;
  font-weight: 700;
  color: #fff;
}

@media (width <=767px) {
  #ads-page-faq .ads-faq-item__question {
    font-size: 16px;
  }
}

@media (width <=480px) {
  #ads-page-faq .ads-faq-item__question {
    font-size: 12px;
  }
}

.ads-faq-answer {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 20px 27px;
  font-size: 16px;
  letter-spacing: 1px;
  color: #666;
  position: relative;
  border: solid 1px #ccc;
  border-top: none;
  border-radius: 0 0 12px 12px;
}

@media (width <=767px) {
  .ads-faq-answer {
    gap: 8px;
    padding: 17px 15px;
    border-radius: 0 0 16px 16px;
    font-size: 16px;
  }
}

@media (width <=480px) {
  .ads-faq-answer {
    font-size: 12px;
  }
}

/* アコーディオン: 回答は閉じた状態で開始し、.is-active で表示 */
#ads-page-faq .ads-faq-item .ads-faq-answer {
  display: none;
}

/* ========================================
   LP制作事例（.section-title--sm 参照・作業の実績と同構成）
   ======================================== */
.lp-works {
  padding-block: 90px;
}

@media (width <=767px) {
  .lp-works {
    padding-block: 60px;
  }
}

.lp-works .section-title--sm {
  width: fit-content;
  margin-inline: auto;
  padding-block-end: 30px;
  color: var(--color-primary);
  border-bottom: solid 1px;

  @media (width <=767px) {
    padding-block-end: 16px;
  }

  &::before {
    text-transform: uppercase;
  }
}

/* ========================================
   LP制作事例：無限スライダー（ace-web IndexSlider.js でアニメーション）
   ======================================== */
.index-slider.lp-works-slider {
  display: flex;
  overflow-x: hidden;
  padding-block-start: 50px;

  @media (width <=767px) {
    padding-block-start: 40px;
  }
}

.index-slider.lp-works-slider .index-slider__list {
  display: flex;
  backface-visibility: hidden;
  perspective: 1000px;
}

.index-slider.lp-works-slider .index-slider__item {
  flex: 265px 0 0;
  margin-inline: 8px;

  /* JS の幅計算用（合計 30px の間隔） */
  @media (width <=767px) {
    flex: 180px 0 0;
    margin-inline: 5px;
  }
}

.index-slider.lp-works-slider .index-slider__item img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

/* -----------------------------------------------------
	他社サービスとの比較
----------------------------------------------------- */
.compare {
  padding: 64px 16px;
  background: #fff;
  /* background-image: url(/image/compare/bg-radial.webp);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat; */

  .scroll-hint-shadow-wrap {

    &::before,
    &::after {
      background: none;
    }
  }

}

.compare-title,
.compare-satisfaction {
  margin-inline: auto;
  width: fit-content;
}

.compare-title {
  max-width: 680px;
}

.compare-satisfaction {
  margin-top: 16px;
  max-width: 420px;
}

.compare-title img,
.compare-satisfaction img {
  display: block;
  width: 100%;
  height: auto;
}

.compare-table {
  margin: 28px auto 0;
  width: min(100%, 1070px);
  overflow-x: auto;

}

.compare-table.js-compare-scroll {
  position: relative;
}

.compare-table__table {
  width: 100%;
  min-width: 680px;
  border-collapse: collapse;
  table-layout: fixed;
  border-collapse: separate;
  border-spacing: 0;

  .on {
    border: 2px solid var(--color-primary-light);
  }
}

.compare-table__table thead tr:first-child> :first-child {
  border-top-left-radius: 6px;

  @media (width <=767px) {
    border-top-left-radius: 3px;
  }
}

.compare-table__table thead tr:first-child> :last-child {
  >div {
    border-top-right-radius: 6px;

    @media (width <=767px) {
      border-top-right-radius: 3px;
    }
  }
}

.compare-table__table caption {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
}

.compare-table__head,
.compare-table__row-head,
.compare-table__cell {
  text-align: center;
  font-weight: 700;
}

.compare-table__head {
  font-size: 14px;
  color: #fff;
}

.compare-table__head--label {
  width: 19.6262%;
  background: transparent;
  border-top-color: #eef9f2;
  border-left-color: #eef9f2;
}

.compare-table__head--primary,
.compare-table__head--other {
  color: #fff;
}

.compare-table__head--primary {
  width: 38.785%;
  background: var(--color-primary-light);
  border-top-left-radius: 6px;
  border-top-right-radius: 6px;
  padding-block: 24px;
}

.compare-table__head--other {
  vertical-align: bottom;
  border-top: 0;

  &:not(:last-child) {
    >div {
      border-right: solid 1px #999;
    }
  }

  >div {
    padding-block: 17px;
    background: #898989;
  }
}

.compare-table__row-head {
  padding: 10px 6px;
  font-size: 12px;
  color: #444;
  background: #eaeaea;
  border-bottom-color: #e6fff3;
  line-height: 1.35;
}

.compare-table__cell {
  padding: 10px 4px;
  font-size: 12px;
  color: #333;
  background: #fff;
  line-height: 1.45;
}

.compare-table__cell--primary {
  color: var(--color-primary-light);
  font-size: 13px;
  background: #f5fff9;
  border-left: solid 1px currentColor;
  border-right: solid 1px currentColor;
}

.compare-table__table tbody .compare-table__row-head,
.compare-table__table tbody .compare-table__cell {
  border-bottom: 1px solid #c3c1c1;
}

.compare-table__table tbody tr:first-child th.compare-table__row-head {
  border-top-left-radius: 6px;
  border-top: 1px solid #c3c1c1;

  @media (width <=767px) {
    border-top-left-radius: 3px;
  }
}

.compare-table__table tbody tr:nth-child(n + 1):nth-last-child(n + 2) .compare-table__cell {
  border-bottom-style: dashed;
}

.compare-table__table tbody td:nth-child(2) {
  border-bottom-color: var(--color-primary-light);
}

.compare-table__table tbody tr:last-child> :first-child {
  border-bottom-left-radius: 6px;

  @media (width <=767px) {
    border-bottom-left-radius: 3px;
  }
}

.compare-table__table tbody tr:last-child> :last-child {
  border-bottom-right-radius: 6px;

  @media (width <=767px) {
    border-bottom-right-radius: 3px;
  }
}

.compare-table__table tbody td:nth-child(n + 3) {
  border-right: 1px solid #c3c1c1;
}

th.compare-table__row-head {
  border-left: 1px solid #c3c1c1;
}

@media (width >=768px) {
  .compare {
    padding: 90px 24px;
  }

  .compare-satisfaction {
    margin-top: 20px;
  }

  .compare-table {
    margin-top: 40px;
    overflow-x: visible;
  }

  .compare-table__table {
    min-width: 0;
  }

  .compare-table__head {
    font-size: 24px;
  }

  .compare-table__head.compare-table__head--other {
    font-size: 20px;
  }

  .compare-table__head--label {
    width: 19.6262%;
  }

  .compare-table__head--primary {
    width: 38.785%;
    padding-block: 22px;
  }

  .compare-table__row-head {
    padding: 18px 10px;
    font-size: 20px;
  }

  .compare-table__cell {
    padding: 18px 8px;
    font-size: 18px;
  }

  .compare-table__cell--primary {
    font-size: 20px;
  }
}

.price-free {
  color: var(--color-secondary-dark);
  font-size: 1.5em;
}

.free-period {
  color: var(--color-secondary-dark);
  font-size: 1.2em;
}

.rate-high {
  color: var(--color-secondary-dark);
  font-size: 1.1em;
}

/* ----------------------------------------------------------------------
 フローティングボタン（768px 未満は非表示、#acebar と二重にならない）
---------------------------------------------------------------------- */
.floating-buttons {
  display: none;

  @media (width >=768px) {
    display: flex;
    align-items: center;
    border-radius: 8px;
    gap: 10px;
    background-color: #fff;
    padding: 13px 10px 10px 16px;
    position: fixed;
    right: 1svw;
    bottom: 1svw;
    max-width: 600px;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease-in-out, visibility 0.3s ease-in-out;
  }
}

.floating-buttons--visible {
  @media (width >=768px) {
    box-shadow: 0 0 5px rgba(0, 0, 0, 0.3);
    z-index: 999;
    opacity: 1;
    visibility: visible;
  }
}

.floating-buttons__label {
  @media (width >=768px) {
    flex: 2;
    color: #333;
    font-size: 13px;
    margin-bottom: 0;
    line-height: 1.4;
    font-weight: bold;
    margin-left: 2px;
  }
}

.floating-buttons__button {
  @media (width >=768px) {
    flex: 1;
  }

  a {
    @media (width >=768px) {
      display: block;
      transition: filter 0.3s ease;
    }

    @media (width >=768px) and (hover: hover) {
      &:hover {
        filter: opacity(0.7);
      }
    }
  }

  img {
    @media (width >=768px) {
      display: block;
      vertical-align: bottom;
      width: 100%;
      max-width: 210px;
      height: auto;
    }
  }
}

.floating-buttons__tel {
  @media (width >=768px) {
    display: flex;
    gap: 2px;
    align-items: center;
    font-size: 38px;
    font-weight: 700;
    color: #333;
    white-space: nowrap;
    line-height: 1;
  }

  &::before {
    @media (width >=768px) {
      display: inline-block;
      flex-shrink: 0;
      width: min(2.5svw, 38px);
      aspect-ratio: 33/19;
      content: "";
      background-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNjYiIGhlaWdodD0iMzgiIHZpZXdCb3g9IjAgMCA2NiAzOCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTU2LjkxIDBIMFYzNy4xNEg1Ni45MVYwWiIgZmlsbD0iIzAwQTczQyIvPgo8cGF0aCBkPSJNNTguNjEwMSAzMy42MDk4QzU4LjYxMDEgMzUuNTY5OCA2MC4yMDAxIDM3LjE2OTggNjIuMTcwMSAzNy4xNjk4QzY0LjE0MDEgMzcuMTY5OCA2NS43MzAxIDM1LjU2OTggNjUuNzMwMSAzMy42MDk4QzY1LjczMDEgMzEuNjQ5OCA2NC4xMzAxIDMwLjA0OTggNjIuMTcwMSAzMC4wNDk4QzYwLjIxMDEgMzAuMDQ5OCA1OC42MTAxIDMxLjYzOTggNTguNjEwMSAzMy42MDk4Wk01OS4wMjAxIDMzLjYwOThDNTkuMDIwMSAzMS44Nzk4IDYwLjQzMDEgMzAuNDY5OCA2Mi4xNzAxIDMwLjQ2OThDNjMuOTEwMSAzMC40Njk4IDY1LjMxMDEgMzEuODc5OCA2NS4zMTAxIDMzLjYwOThDNjUuMzEwMSAzNS4zMzk4IDYzLjkwMDEgMzYuNzQ5OCA2Mi4xNzAxIDM2Ljc0OThDNjAuNDQwMSAzNi43NDk4IDU5LjAyMDEgMzUuMzM5OCA1OS4wMjAxIDMzLjYwOThaIiBmaWxsPSJibGFjayIvPgo8cGF0aCBkPSJNNjMuOSAzNS45MUg2My4yMkw2MS44NCAzMy43N0g2MS4yM1YzNS45MUg2MC42ODAxVjMxLjIxSDYyLjAxQzYyLjQ1IDMxLjIxIDYyLjgxMDEgMzEuMzIgNjMuMDcwMSAzMS41M0M2My4zMzAxIDMxLjc1IDYzLjQ2IDMyLjA1IDYzLjQ2IDMyLjQzQzYzLjQ2IDMyLjcyIDYzLjM3MDEgMzIuOTcgNjMuMTgwMSAzMy4xOUM2Mi45OTAxIDMzLjQxIDYyLjczIDMzLjU2IDYyLjQgMzMuNjVMNjMuOSAzNS45TTYxLjIzIDMzLjNINjEuOTJDNjIuMjEgMzMuMyA2Mi40NDAxIDMzLjIyIDYyLjYyMDEgMzMuMDdDNjIuODAwMSAzMi45MSA2Mi44OSAzMi43MiA2Mi44OSAzMi40OEM2Mi44OSAzMS45NSA2Mi41NzAxIDMxLjY5IDYxLjkzMDEgMzEuNjlINjEuMjNWMzMuM1oiIGZpbGw9ImJsYWNrIi8+CjxwYXRoIGQ9Ik0xNC4zIDI4LjgxMDNDMTEuMTggMjguODEwMyA3LjMwMDAyIDI2LjQyMDMgNy4zMDAwMiAyMS41MDAzQzcuMzAwMDIgMTcuNjgwMyAxMS4wOCAxNC42MzAzIDE0LjMgMTIuODAwM0MxNy41MSAxNC42MzAzIDIxLjMgMTcuNjgwMyAyMS4zIDIxLjUwMDNDMjEuMyAyNi40MjAzIDE3LjQzIDI4LjgxMDMgMTQuMyAyOC44MTAzWk0zNS43NCAyMS40MjAzQzM1Ljc0IDE3LjYwMDMgMzkuNTIgMTQuNTUwMyA0Mi43NCAxMi43MjAzQzQ1Ljk1IDE0LjU1MDMgNDkuNzMgMTcuNjAwMyA0OS43MyAyMS40MjAzQzQ5LjczIDI2LjM0MDMgNDUuODYgMjguNzMwMyA0Mi43NCAyOC43MzAzQzM5LjYyIDI4LjczMDMgMzUuNzQgMjYuMzUwMyAzNS43NCAyMS40MjAzWk01Ni45IDUuNzgwMjdDNTEuMTIgNS43ODAyNyA0NS45OSA3LjIyMDI3IDQyLjUxIDkuMDMwMjdDMzkuMDMgNy4yMjAyNyAzNC4yMiA1Ljc4MDI3IDI4LjQ0IDUuNzgwMjdDMjIuNjYgNS43ODAyNyAxNy44NSA3LjIyMDI3IDE0LjM3IDkuMDMwMjdDMTAuODkgNy4yMjAyNyA1Ljc3IDUuNzgwMjcgMCA1Ljc4MDI3VjkuMDMwMjdDMy40MiA5LjAzMDI3IDcuNTYwMDEgOS42NzAyOSAxMC44MiAxMS4wODAzQzcuMzEwMDEgMTMuNDMwMyAzLjgzMDAyIDE2Ljk5MDMgMy44MzAwMiAyMS40OTAzQzMuODMwMDIgMjcuNDMwMyA4Ljg5MDAxIDMxLjk3MDMgMTQuMzggMzEuOTcwM0MxOS44NyAzMS45NzAzIDI0LjY5IDI3LjQzMDMgMjQuNjkgMjEuNDkwM0MyNC42OSAxNi45OTAzIDIxLjQ2IDEzLjQzMDMgMTcuOTQgMTEuMDgwM0MyMS4yIDkuNjYwMjkgMjUuMDMgOS4wMzAyNyAyOC40NSA5LjAzMDI3QzMxLjg3IDkuMDMwMjcgMzUuNzEgOS42NzAyOSAzOC45NiAxMS4wODAzQzM1LjQ0IDEzLjQzMDMgMzIuMjEgMTYuOTkwMyAzMi4yMSAyMS40OTAzQzMyLjIxIDI3LjQzMDMgMzcuMDIgMzEuOTcwMyA0Mi41MSAzMS45NzAzQzQ4IDMxLjk3MDMgNTIuOTkgMjcuNDMwMyA1Mi45OSAyMS40OTAzQzUyLjk5IDE2Ljk5MDMgNDkuNTkgMTMuNDMwMyA0Ni4wNyAxMS4wODAzQzQ5LjMzIDkuNjYwMjkgNTMuNDggOS4wMzAyNyA1Ni45IDkuMDMwMjdWNS43ODAyN1oiIGZpbGw9IndoaXRlIi8+Cjwvc3ZnPgo=);
      background-repeat: no-repeat;
      background-size: contain;
      transform: translateY(1px);
    }
  }
}