@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;
}

*,
*::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;
}

/* -----------------------------------------------------
	ヘッダー
----------------------------------------------------- */
.header {
  background-color: #fff;

  @media (width >=768px) {
    position: sticky;
    top: 0;
    z-index: 10;
  }
}

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

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

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

  @media (width >=768px) {
    flex: 0 1 auto;
    max-width: clamp(100px, 12vw, 170px);
    min-width: 100px;
  }

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

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

.header-top__info {
  display: flex;

  @media (width >=768px) {
    justify-content: flex-end;
    align-items: center;
    gap: 15px;
    width: auto;
    flex: 1 1 auto;
    min-width: 0;
  }
}

.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: #4b4b4b;
  }
}

.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('data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTUiIGhlaWdodD0iMzUiIHZpZXdCb3g9IjAgMCA1NSAzNSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTQ5LjM3MDggMy40NzgyMkgwLjkzNDkzN1YzMS4yODc2SDQ5LjM3MDhWMy40NzgyMloiIGZpbGw9IndoaXRlIiBzdHJva2U9IndoaXRlIiBzdHJva2UtbWl0ZXJsaW1pdD0iMTAiLz4KPHBhdGggZD0iTTIuNSAyLjVWNy4xMzI1N0M2LjA2MzUxIDcuMTMyNTcgOS4zNzU0OSA3LjgyNDMxIDEyLjI0MDMgOC45NDkyNkMxMi43NzgzIDkuMTU4ODggMTMuMjk1NCA5LjM4OTQ2IDEzLjc5ODQgOS42MjcwM0MxNC45NDQzIDkuMDc1MDMgMTYuMTc0MSA4LjU5OTkgMTcuNDgwNyA4LjIxNTZDMTkuODI4NSA3LjUyMzg2IDIyLjQwNjggNy4xMjU1OCAyNS4xMzE4IDcuMTI1NThDMjguNzA5MyA3LjEyNTU4IDMyLjA0MjIgNy44MTAzMyAzNC45MTQgOC45NDIyN0MzNS40NTIgOS4xNTE4OSAzNS45NjkxIDkuMzgyNDcgMzYuNDcyMiA5LjYyMDA0QzM3LjYxODEgOS4wNjgwNCAzOC44NDc4IDguNTkyOTEgNDAuMTYxNCA4LjIwODYxQzQyLjQ5NTIgNy41MjM4NiA0NS4wNTk1IDcuMTI1NTggNDcuNzcwNiA3LjExODU5VjIuNUgyLjVaIiBmaWxsPSIjMDRBQTNBIiBzdHJva2U9IndoaXRlIiBzdHJva2Utd2lkdGg9IjUiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCIvPgo8cGF0aCBkPSJNMzAuODQ3NCAyMC4wNjZDMzAuODQ3NCAyMS4yMzI5IDMxLjIwMzggMjIuMzA4OSAzMS44MDQ3IDIzLjIxMDNDMzIuNDEyNiAyNC4xMTE3IDMzLjI3MiAyNC44MjQ0IDM0LjI4NTIgMjUuMjUwNkMzNC45NTYgMjUuNTM3MSAzNS42OTY2IDI1LjY5MDggMzYuNDcyMiAyNS42OTA4QzM3LjY0NjEgMjUuNjkwOCAzOC43MTUxIDI1LjMzNDQgMzkuNjE2NSAyNC43MzM1QzQwLjUxNzggMjQuMTI1NiA0MS4yMzA1IDIzLjI2NjIgNDEuNjU2OCAyMi4yNTNDNDEuOTQzMiAyMS41ODIzIDQyLjA5NyAyMC44NDE2IDQyLjA5NyAyMC4wNjZDNDIuMDk3IDE5LjUwNyA0MS45NzgyIDE4LjkxMzEgNDEuNzMzNiAxOC4yOTgyQzQxLjQ4OTEgMTcuNjc2NCA0MS4xMTE4IDE3LjAzMzUgNDAuNjE1NyAxNi4zOTA3QzM5LjY1ODQgMTUuMTYxIDM4LjI0IDEzLjk1MjIgMzYuNDY1MiAxMi45MzJDMzUuMTAyNyAxMy43MTQ2IDMzLjk0OTggMTQuNjAyIDMzLjA2MjQgMTUuNTM4M0MzMi4xMTIxIDE2LjUyMzUgMzEuNDYyMyAxNy41NTA2IDMxLjEyNjkgMTguNTA3OUMzMC45MzEzIDE5LjA1MjkgMzAuODQwNSAxOS41NzY5IDMwLjg0MDUgMjAuMDczTDMwLjg0NzQgMjAuMDY2WiIgZmlsbD0iIzA0QUEzQSIgc3Ryb2tlPSJ3aGl0ZSIgc3Ryb2tlLXdpZHRoPSI1IiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiLz4KPHBhdGggZD0iTTQxLjk4NTIgMTMuNTA1QzQzLjE2NjEgMTQuNzM0NyA0NC4wNjA0IDE2LjA4MzMgNDQuNTcwNSAxNy41MjI3QzQ0Ljg1NyAxOC4zNDcyIDQ1LjAxNzcgMTkuMTk5NiA0NS4wMTc3IDIwLjA1OUM0NS4wMTc3IDIxLjgxOTggNDQuNDc5NyAyMy40NzU4IDQzLjU1NzQgMjQuODM4M0M0Mi42MzUgMjYuMjAwOSA0MS4zMzU0IDI3LjI4MzkgMzkuNzk4MiAyNy45MzM3QzM4Ljc3ODEgMjguMzY2OSAzNy42NDYxIDI4LjYwNDUgMzYuNDcyMyAyOC42MDQ1QzM0LjcwNDUgMjguNjA0NSAzMy4wNTU1IDI4LjA2NjUgMzEuNjkzIDI3LjE0NDFDMzAuMzMwNCAyNi4yMjE4IDI5LjI0NzQgMjQuOTIyMiAyOC41OTc2IDIzLjM4NUMyOC4xNjQ0IDIyLjM2NDggMjcuOTI2OCAyMS4yMzI5IDI3LjkyNjggMjAuMDU5QzI3LjkyNjggMTguNzY2NCAyOC4yOTAxIDE3LjUwMTcgMjguOTA1IDE2LjMxMzlDMjkuNTI2OSAxNS4xMjYgMzAuNDA3MyAxNC4wMDgxIDMxLjQ4MzMgMTIuOTg3OUMzMi4wNDkzIDEyLjQ1NjkgMzIuNjY0MiAxMS45NTM4IDMzLjMzNSAxMS40NzE3QzMyLjg4NzggMTEuMzExIDMyLjQyNjYgMTEuMTU3MiAzMS45NTg1IDExLjAxNzVDMjkuODc2MyAxMC40MDI2IDI3LjU3MDUgMTAuMDQ2MyAyNS4xMzE5IDEwLjA0NjNDMjIuMTM0NCAxMC4wNDYzIDE5LjM0NjQgMTAuNTg0MyAxNi45Mjg4IDExLjQ3MTdDMTcuODA5MiAxMi4xMDA1IDE4LjYwNTggMTIuNzg1MyAxOS4zMDQ1IDEzLjUwNUMyMC40ODU0IDE0LjczNDcgMjEuMzc5NyAxNi4wODMzIDIxLjg4OTggMTcuNTIyN0MyMi4xODMzIDE4LjM0NzIgMjIuMzQ0IDE5LjE5OTYgMjIuMzQ0IDIwLjA1OUMyMi4zNDQgMjEuODE5OCAyMS44MDYgMjMuNDc1OCAyMC44ODM2IDI0LjgzODNDMTkuOTYxMyAyNi4yMDA5IDE4LjY2MTcgMjcuMjgzOSAxNy4xMjQ1IDI3LjkzMzdDMTYuMTA0MyAyOC4zNjY5IDE0Ljk3MjQgMjguNjA0NSAxMy43OTg1IDI4LjYwNDVDMTIuMDMwNyAyOC42MDQ1IDEwLjM4MTcgMjguMDY2NSA5LjAxOTIzIDI3LjE0NDFDNy42NTY3MSAyNi4yMjE4IDYuNTczNjggMjQuOTIyMiA1LjkyMzg2IDIzLjM4NUM1LjQ5MDY1IDIyLjM2NDggNS4yNTMwOCAyMS4yMzI5IDUuMjUzMDggMjAuMDU5QzUuMjUzMDggMTguNzY2NCA1LjYxNjQyIDE3LjUwMTcgNi4yMzEzIDE2LjMxMzlDNi44NTMxNyAxNS4xMjYgNy43MzM1NyAxNC4wMDgxIDguODE2NiAxMi45ODc5QzkuMzc1NTggMTIuNDU2OSA5Ljk5NzQ1IDExLjk1MzggMTAuNjY4MiAxMS40NzE3QzEwLjIyMSAxMS4zMTEgOS43NTk4OCAxMS4xNTcyIDkuMjkxNzMgMTEuMDE3NUM3LjIyMzUgMTAuNDA5NiA0LjkzMTY3IDEwLjA1MzMgMi41MDcwOCAxMC4wNDYzVjMyLjIwMjlINDcuNzc3N1YxMC4wNDYzQzQ0LjgwMTEgMTAuMDQ2MyA0Mi4wMjAyIDEwLjU5MTMgMzkuNjE2NSAxMS40NzE3QzQwLjQ5NjkgMTIuMTAwNSA0MS4yOTM1IDEyLjc4NTMgNDEuOTkyMiAxMy41MDVINDEuOTg1MloiIGZpbGw9IiMwNEFBM0EiIHN0cm9rZT0id2hpdGUiIHN0cm9rZS13aWR0aD0iNSIgc3Ryb2tlLWxpbmVjYXA9InJvdW5kIiBzdHJva2UtbGluZWpvaW49InJvdW5kIi8+CjxwYXRoIGQ9Ik04LjE2Njc4IDIwLjA2NkM4LjE2Njc4IDIxLjIzMjkgOC41MjMxMyAyMi4zMDg5IDkuMTI0MDQgMjMuMjEwM0M5LjczMTkzIDI0LjExMTcgMTAuNTkxNCAyNC44MjQ0IDExLjYwNDUgMjUuMjUwNkMxMi4yNzUzIDI1LjUzNzEgMTMuMDE2IDI1LjY5MDggMTMuNzkxNSAyNS42OTA4QzE0Ljk1ODQgMjUuNjkwOCAxNi4wMzQ1IDI1LjMzNDQgMTYuOTM1OCAyNC43MzM1QzE3LjgzNzIgMjQuMTI1NiAxOC41NDk5IDIzLjI2NjIgMTguOTc2MSAyMi4yNTNDMTkuMjYyNiAyMS41ODIzIDE5LjQxNjMgMjAuODQxNiAxOS40MTYzIDIwLjA2NkMxOS40MTYzIDE5LjUwNyAxOS4yOTc1IDE4LjkxMzEgMTkuMDUzIDE4LjI5ODJDMTguODA4NCAxNy42NzY0IDE4LjQzMTEgMTcuMDMzNSAxNy45MzUgMTYuMzkwN0MxNi45Nzc3IDE1LjE2MSAxNS41NTkzIDEzLjk1MjIgMTMuNzg0NiAxMi45MzJDMTIuNDIyIDEzLjcxNDYgMTEuMjY5MSAxNC42MDIgMTAuMzgxNyAxNS41MzgzQzkuNDMxNDggMTYuNTIzNSA4Ljc4MTY2IDE3LjU1MDYgOC40NDYyNyAxOC41MDc5QzguMjUwNjIgMTkuMDUyOSA4LjE1OTc5IDE5LjU3NjkgOC4xNTk3OSAyMC4wNzNMOC4xNjY3OCAyMC4wNjZaIiBmaWxsPSIjMDRBQTNBIiBzdHJva2U9IndoaXRlIiBzdHJva2Utd2lkdGg9IjUiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCIvPgo8cGF0aCBkPSJNMi41IDIuNVY3LjEzMjU3QzYuMDYzNTEgNy4xMzI1NyA5LjM3NTQ5IDcuODI0MzEgMTIuMjQwMyA4Ljk0OTI2QzEyLjc3ODMgOS4xNTg4OCAxMy4yOTU0IDkuMzg5NDYgMTMuNzk4NCA5LjYyNzAzQzE0Ljk0NDMgOS4wNzUwMyAxNi4xNzQxIDguNTk5OSAxNy40ODA3IDguMjE1NkMxOS44Mjg1IDcuNTIzODYgMjIuNDA2OCA3LjEyNTU4IDI1LjEzMTggNy4xMjU1OEMyOC43MDkzIDcuMTI1NTggMzIuMDQyMiA3LjgxMDMzIDM0LjkxNCA4Ljk0MjI3QzM1LjQ1MiA5LjE1MTg5IDM1Ljk2OTEgOS4zODI0NyAzNi40NzIyIDkuNjIwMDRDMzcuNjE4MSA5LjA2ODA0IDM4Ljg0NzggOC41OTI5MSA0MC4xNjE0IDguMjA4NjFDNDIuNDk1MiA3LjUyMzg2IDQ1LjA1OTUgNy4xMjU1OCA0Ny43NzA2IDcuMTE4NTlWMi41SDIuNVoiIGZpbGw9IiMwNEFBM0EiLz4KPHBhdGggZD0iTTMwLjg0NzQgMjAuMDY2QzMwLjg0NzQgMjEuMjMyOSAzMS4yMDM4IDIyLjMwODkgMzEuODA0NyAyMy4yMTAzQzMyLjQxMjYgMjQuMTExNyAzMy4yNzIgMjQuODI0NCAzNC4yODUyIDI1LjI1MDZDMzQuOTU2IDI1LjUzNzEgMzUuNjk2NiAyNS42OTA4IDM2LjQ3MjIgMjUuNjkwOEMzNy42NDYxIDI1LjY5MDggMzguNzE1MSAyNS4zMzQ0IDM5LjYxNjUgMjQuNzMzNUM0MC41MTc4IDI0LjEyNTYgNDEuMjMwNSAyMy4yNjYyIDQxLjY1NjggMjIuMjUzQzQxLjk0MzIgMjEuNTgyMyA0Mi4wOTcgMjAuODQxNiA0Mi4wOTcgMjAuMDY2QzQyLjA5NyAxOS41MDcgNDEuOTc4MiAxOC45MTMxIDQxLjczMzYgMTguMjk4MkM0MS40ODkxIDE3LjY3NjQgNDEuMTExOCAxNy4wMzM1IDQwLjYxNTcgMTYuMzkwN0MzOS42NTg0IDE1LjE2MSAzOC4yNCAxMy45NTIyIDM2LjQ2NTIgMTIuOTMyQzM1LjEwMjcgMTMuNzE0NiAzMy45NDk4IDE0LjYwMiAzMy4wNjI0IDE1LjUzODNDMzIuMTEyMSAxNi41MjM1IDMxLjQ2MjMgMTcuNTUwNiAzMS4xMjY5IDE4LjUwNzlDMzAuOTMxMyAxOS4wNTI5IDMwLjg0MDUgMTkuNTc2OSAzMC44NDA1IDIwLjA3M0wzMC44NDc0IDIwLjA2NloiIGZpbGw9IiMwNEFBM0EiLz4KPHBhdGggZD0iTTQxLjk4NTIgMTMuNTA1QzQzLjE2NjEgMTQuNzM0NyA0NC4wNjA0IDE2LjA4MzMgNDQuNTcwNSAxNy41MjI3QzQ0Ljg1NyAxOC4zNDcyIDQ1LjAxNzcgMTkuMTk5NiA0NS4wMTc3IDIwLjA1OUM0NS4wMTc3IDIxLjgxOTggNDQuNDc5NyAyMy40NzU4IDQzLjU1NzQgMjQuODM4M0M0Mi42MzUgMjYuMjAwOSA0MS4zMzU0IDI3LjI4MzkgMzkuNzk4MiAyNy45MzM3QzM4Ljc3ODEgMjguMzY2OSAzNy42NDYxIDI4LjYwNDUgMzYuNDcyMyAyOC42MDQ1QzM0LjcwNDUgMjguNjA0NSAzMy4wNTU1IDI4LjA2NjUgMzEuNjkzIDI3LjE0NDFDMzAuMzMwNCAyNi4yMjE4IDI5LjI0NzQgMjQuOTIyMiAyOC41OTc2IDIzLjM4NUMyOC4xNjQ0IDIyLjM2NDggMjcuOTI2OCAyMS4yMzI5IDI3LjkyNjggMjAuMDU5QzI3LjkyNjggMTguNzY2NCAyOC4yOTAxIDE3LjUwMTcgMjguOTA1IDE2LjMxMzlDMjkuNTI2OSAxNS4xMjYgMzAuNDA3MyAxNC4wMDgxIDMxLjQ4MzMgMTIuOTg3OUMzMi4wNDkzIDEyLjQ1NjkgMzIuNjY0MiAxMS45NTM4IDMzLjMzNSAxMS40NzE3QzMyLjg4NzggMTEuMzExIDMyLjQyNjYgMTEuMTU3MiAzMS45NTg1IDExLjAxNzVDMjkuODc2MyAxMC40MDI2IDI3LjU3MDUgMTAuMDQ2MyAyNS4xMzE5IDEwLjA0NjNDMjIuMTM0NCAxMC4wNDYzIDE5LjM0NjQgMTAuNTg0MyAxNi45Mjg4IDExLjQ3MTdDMTcuODA5MiAxMi4xMDA1IDE4LjYwNTggMTIuNzg1MyAxOS4zMDQ1IDEzLjUwNUMyMC40ODU0IDE0LjczNDcgMjEuMzc5NyAxNi4wODMzIDIxLjg4OTggMTcuNTIyN0MyMi4xODMzIDE4LjM0NzIgMjIuMzQ0IDE5LjE5OTYgMjIuMzQ0IDIwLjA1OUMyMi4zNDQgMjEuODE5OCAyMS44MDYgMjMuNDc1OCAyMC44ODM2IDI0LjgzODNDMTkuOTYxMyAyNi4yMDA5IDE4LjY2MTcgMjcuMjgzOSAxNy4xMjQ1IDI3LjkzMzdDMTYuMTA0MyAyOC4zNjY5IDE0Ljk3MjQgMjguNjA0NSAxMy43OTg1IDI4LjYwNDVDMTIuMDMwNyAyOC42MDQ1IDEwLjM4MTcgMjguMDY2NSA5LjAxOTIzIDI3LjE0NDFDNy42NTY3MSAyNi4yMjE4IDYuNTczNjggMjQuOTIyMiA1LjkyMzg2IDIzLjM4NUM1LjQ5MDY1IDIyLjM2NDggNS4yNTMwOCAyMS4yMzI5IDUuMjUzMDggMjAuMDU5QzUuMjUzMDggMTguNzY2NCA1LjYxNjQyIDE3LjUwMTcgNi4yMzEzIDE2LjMxMzlDNi44NTMxNyAxNS4xMjYgNy43MzM1NyAxNC4wMDgxIDguODE2NiAxMi45ODc5QzkuMzc1NTggMTIuNDU2OSA5Ljk5NzQ1IDExLjk1MzggMTAuNjY4MiAxMS40NzE3QzEwLjIyMSAxMS4zMTEgOS43NTk4OCAxMS4xNTcyIDkuMjkxNzMgMTEuMDE3NUM3LjIyMzUgMTAuNDA5NiA0LjkzMTY3IDEwLjA1MzMgMi41MDcwOCAxMC4wNDYzVjMyLjIwMjlINDcuNzc3N1YxMC4wNDYzQzQ0LjgwMTEgMTAuMDQ2MyA0Mi4wMjAyIDEwLjU5MTMgMzkuNjE2NSAxMS40NzE3QzQwLjQ5NjkgMTIuMTAwNSA0MS4yOTM1IDEyLjc4NTMgNDEuOTkyMiAxMy41MDVINDEuOTg1MloiIGZpbGw9IiMwNEFBM0EiLz4KPHBhdGggZD0iTTguMTY2NjYgMjAuMDY2QzguMTY2NjYgMjEuMjMyOSA4LjUyMzAxIDIyLjMwODkgOS4xMjM5MSAyMy4yMTAzQzkuNzMxODEgMjQuMTExNyAxMC41OTEyIDI0LjgyNDQgMTEuNjA0NCAyNS4yNTA2QzEyLjI3NTIgMjUuNTM3MSAxMy4wMTU4IDI1LjY5MDggMTMuNzkxNCAyNS42OTA4QzE0Ljk1ODMgMjUuNjkwOCAxNi4wMzQzIDI1LjMzNDQgMTYuOTM1NyAyNC43MzM1QzE3LjgzNzEgMjQuMTI1NiAxOC41NDk4IDIzLjI2NjIgMTguOTc2IDIyLjI1M0MxOS4yNjI1IDIxLjU4MjMgMTkuNDE2MiAyMC44NDE2IDE5LjQxNjIgMjAuMDY2QzE5LjQxNjIgMTkuNTA3IDE5LjI5NzQgMTguOTEzMSAxOS4wNTI4IDE4LjI5ODJDMTguODA4MyAxNy42NzY0IDE4LjQzMSAxNy4wMzM1IDE3LjkzNDkgMTYuMzkwN0MxNi45Nzc2IDE1LjE2MSAxNS41NTkyIDEzLjk1MjIgMTMuNzg0NCAxMi45MzJDMTIuNDIxOSAxMy43MTQ2IDExLjI2OSAxNC42MDIgMTAuMzgxNiAxNS41MzgzQzkuNDMxMzUgMTYuNTIzNSA4Ljc4MTU0IDE3LjU1MDYgOC40NDYxNSAxOC41MDc5QzguMjUwNSAxOS4wNTI5IDguMTU5NjcgMTkuNTc2OSA4LjE1OTY3IDIwLjA3M0w4LjE2NjY2IDIwLjA2NloiIGZpbGw9IiMwNEFBM0EiLz4KPGcgY2xpcC1wYXRoPSJ1cmwoI2NsaXAwXzI5OF81NikiPgo8cGF0aCBkPSJNNTEuMDY3NCAyOC40ODcxSDUyLjE3MDhDNTIuMzcwNyAyOC40ODcxIDUyLjU0MTkgMjguNTIxMyA1Mi42ODQ1IDI4LjU4OThDNTIuODI3MSAyOC42NTgzIDUyLjkzNjIgMjguNzU2MSA1My4wMTIyIDI4Ljg4MzJDNTMuMDg4IDI5LjAxMDIgNTMuMTI2IDI5LjE2MzMgNTMuMTI2IDI5LjM0MjNWMjkuMzQ2QzUzLjEyNiAyOS41MjI1IDUzLjA4MjQgMjkuNjc4OSA1Mi45OTU1IDI5LjgxNTJDNTIuOTA4NSAyOS45NTE3IDUyLjc5MDggMzAuMDQ4OCA1Mi42NDI4IDMwLjEwNjhMNTMuMjA1NyAzMS4xNTg1SDUyLjU3MDdMNTIuMDc0NiAzMC4xOTIxSDUxLjYyNjZWMzEuMTU4NUg1MS4wNjc0VjI4LjQ4NzFaTTUyLjEwOTggMjkuNzY2NEM1Mi4yNDggMjkuNzY2NCA1Mi4zNTY2IDI5LjcyOTQgNTIuNDM1NiAyOS42NTU0QzUyLjUxNDUgMjkuNTgxMyA1Mi41NTQxIDI5LjQ3OSA1Mi41NTQxIDI5LjM0ODFWMjkuMzQ0NEM1Mi41NTQxIDI5LjIxNjEgNTIuNTEzMSAyOS4xMTQxIDUyLjQzMSAyOS4wMzlDNTIuMzQ4OSAyOC45NjM3IDUyLjIzOTUgMjguOTI2IDUyLjEwMjUgMjguOTI2SDUxLjYyNjhWMjkuNzY2Nkg1Mi4xMUw1Mi4xMDk4IDI5Ljc2NjRaIiBmaWxsPSJibGFjayIvPgo8cGF0aCBkPSJNNTIuMDA1IDMyLjM1MTVDNTAuNjI2NSAzMi4zNTE1IDQ5LjUwNSAzMS4yMjk5IDQ5LjUwNSAyOS44NTE1QzQ5LjUwNSAyOC40NzMgNTAuNjI2NSAyNy4zNTE1IDUyLjAwNSAyNy4zNTE1QzUzLjM4MzUgMjcuMzUxNSA1NC41MDUgMjguNDczIDU0LjUwNSAyOS44NTE1QzU0LjUwNSAzMS4yMjk5IDUzLjM4MzUgMzIuMzUxNSA1Mi4wMDUgMzIuMzUxNVpNNTIuMDA1IDI3LjY5MTlDNTAuODE0MyAyNy42OTE5IDQ5Ljg0NTQgMjguNjYwNyA0OS44NDU0IDI5Ljg1MTVDNDkuODQ1NCAzMS4wNDIyIDUwLjgxNDMgMzIuMDExIDUyLjAwNSAzMi4wMTFDNTMuMTk1NyAzMi4wMTEgNTQuMTY0NiAzMS4wNDIyIDU0LjE2NDYgMjkuODUxNUM1NC4xNjQ2IDI4LjY2MDcgNTMuMTk1NyAyNy42OTE5IDUyLjAwNSAyNy42OTE5WiIgZmlsbD0iYmxhY2siLz4KPC9nPgo8ZGVmcz4KPGNsaXBQYXRoIGlkPSJjbGlwMF8yOThfNTYiPgo8cmVjdCB3aWR0aD0iNSIgaGVpZ2h0PSI1IiBmaWxsPSJ3aGl0ZSIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoNDkuNTA1IDI3LjM1MTUpIi8+CjwvY2xpcFBhdGg+CjwvZGVmcz4KPC9zdmc+');
    display: inline-block;
    width: min(2.86svw, 55px);
    aspect-ratio: 33 / 19;
    background-repeat: no-repeat;
  }
}

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

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

  li {
    flex: 1;

    img {
      width: 50px;
    }
  }
}

@media (max-width: 767px) {
  #js-header {
    display: none;
  }
}

/* -----------------------------------------------------
	メインビジュアル
----------------------------------------------------- */
.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%;
  }
}

/* -----------------------------------------------------
	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;
  }
}

/* -----------------------------------------------------
	作業の風景
----------------------------------------------------- */
.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) {
    max-width: 1000px;
    margin-inline: auto;
    padding-block-start: 120px;
  }
}

.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;
  transition: all;
  transition-duration: 1s;
  transform: translateY(20%) translateX(0%);

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

  &.active {
    transform: translateY(0%) translateX(0);
    opacity: 1;
    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;
}

.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;
}

.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;
}

#ads-page-faq .ads-faq-item.is-active .ads-faq-answer {
  display: flex;
}

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

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

.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: 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;
}