@charset "UTF-8";
/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/
@import url(base/normalize.css);
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");
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 {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

img {
  vertical-align: bottom;
}

button {
  border: none;
  background: none;
  outline: none;
  cursor: pointer;
}

/* ==========================================================================
	Base
============================================================================= */
html, body {
  position: relative;
  background: #fff;
  color: #222;
  font-family: "LINESeedJP", "Noto Sans JP", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  font-size: clamp(14px, 11.33333px + 0.34722vw, 18px);
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: var(--spacing);
  -webkit-font-feature-settings: "palt";
  font-feature-settings: "palt";
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

html {
  overflow: auto;
}

body {
  overflow: hidden;
}

:root {
  --spacing:0.1em;
}

* {
  -webkit-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

a {
  color: #222;
  -webkit-transition: .3s;
  transition: .3s;
  text-decoration: none;
}

@media (hover: hover) and (pointer: fine) {
  a:hover {
    opacity: 0.8;
  }
}

.is-pc a[href*="tel:"] {
  pointer-events: none;
  cursor: default;
  text-decoration: none;
}

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

.grecaptcha-badge {
  bottom: 300px !important;
  z-index: 100;
}

@media screen and (max-width: 767px) {
  .grecaptcha-badge {
    bottom: 90px !important;
  }
}

@font-face {
  font-family: "LINESeedJP";
  src: local("※"), url("../../assets/fonts/LINESeedJP_OTF_Bd.woff2") format("woff2"), url("../../assets/fonts/LINESeedJP_OTF_Bd.woff") format("woff");
  font-weight: 500;
  font-style: normal;
}

@font-face {
  font-family: "LINESeedJP";
  src: local("※"), url("../../assets/fonts/LINESeedJP_OTF_Rg.woff2") format("woff2"), url("../../assets/fonts/LINESeedJP_OTF_Rg.woff") format("woff");
  font-weight: 400;
  font-style: normal;
}

@font-face {
  font-family: "LINESeedJP";
  src: local("※"), url("../../assets/fonts/LINESeedJP_OTF_Th.woff2") format("woff2"), url("../../assets/fonts/LINESeedJP_OTF_Th.woff") format("woff");
  font-weight: 300;
  font-style: normal;
}

/* ==========================================================================
   共通レイアウト設定
============================================================================= */
/* ==============================
// container
// コンテンツ幅
================================= */
.l-container {
  width: 85%;
  max-width: 1440px;
  margin: 0 auto;
}

@media screen and (max-width: 767px) {
  .l-container {
    width: 88%;
  }
}

.l-container.w1224 {
  max-width: 1224px;
}

.l-container.w1100 {
  max-width: 1100px;
}

.l-container.w900 {
  max-width: 900px;
}

/* ==============================
// main
// ヘッダーナビより下の共通コンテンツラップ
// ヘッダーの高さ分コンテンツの位置を下げるためだけに使用
================================= */
.l-main {
  /* headerをfixedにするときは有効化
	padding-top:$header__heightPc; 
	@include mqMax(smallHeader){
		padding-top:$header__heightSp;
	} */
}

/* ==============================
// anchor
// アンカーリンクのジャンプ先をヘッダーの高さ分下げるために使用
// ページ内遷移であればJSの処理で自動で移動距離を制御するため不要だが､
// 違うページのアンカーを指定している場合､垂直位置指定がレンダリングのスピードでずれるため使用する
================================= */
.l-anchor {
  margin-top: -170px;
  padding-top: 170px;
}

@media screen and (max-width: 1099px) {
  .l-anchor {
    margin-top: -100px;
    padding-top: 100px;
  }
}

/* ==============================
// section
// 下層ページの章ごとのスペース
// section.l-section のほか　div.l-sectionなど､見出しのないブロックにも使う
================================= */
.l-section {
  position: relative;
  padding-top: clamp(100px, 66.66667px + 4.34028vw, 150px);
  padding-bottom: clamp(100px, 66.66667px + 4.34028vw, 150px);
}

@media screen and (max-width: 1099px) {
  .l-section {
    padding-top: clamp(64px, 40px + 3.125vw, 100px);
    padding-bottom: clamp(64px, 40px + 3.125vw, 100px);
  }
}

/* ==============================
// safeArea
// スマホでセーフエリアのある機種の場合の余白設定
================================= */
@media screen and (max-width: 767px) {
  .l-safeArea {
    padding-bottom: env(safe-area-inset-bottom);
  }
}

/* ==============================
// 追尾サイドナビ付き左右からむ
================================= */
.l-column {
  position: relative;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  z-index: 3;
}

@media screen and (max-width: 1099px) {
  .l-column {
    display: block;
  }
}

.pin-spacer {
  z-index: 1;
}

@media screen and (max-width: 1099px) {
  .pin-spacer {
    display: none !important;
  }
}

@media screen and (max-width: 1099px) {
  .l-column > .pin-spacer {
    width: 100% !important;
    margin: 0 auto !important;
    padding: 0 !important;
    height: auto !important;
  }
}

.l-column__side {
  -ms-flex-negative: 0;
  flex-shrink: 0;
  width: 280px;
  z-index: 2;
  padding-left: clamp(32px, 13.33333px + 2.43056vw, 60px);
}

@media screen and (max-width: 1099px) {
  .l-column__side {
    width: 88% !important;
    padding-left: 0 !important;
    position: relative !important;
    left: auto !important;
    top: auto !important;
    -webkit-transform: none !important;
    transform: none !important;
    margin: 0 auto !important;
  }
}

/* ===== sideNav（ドロップダウン） ===== */
@media screen and (max-width: 1099px) {
  .sideNav {
    position: relative;
  }
}

.sideNav__toggle {
  display: none;
}

@media screen and (max-width: 1099px) {
  .sideNav__toggle {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    width: 100%;
    height: clamp(44px, 36px + 1.04167vw, 56px);
    border-radius: 100vh;
    padding: 0 clamp(12px, 6.66667px + 0.69444vw, 20px);
    border: 1px solid #222;
    background: #fff;
    color: #222;
    letter-spacing: .03em;
    -webkit-transition: .3s;
    transition: .3s;
  }
}

@media screen and (max-width: 1099px) {
  .sideNav__toggle:hover {
    border-color: #F7930E;
  }
}

.sideNav__toggleText {
  font-weight: 700;
  font-size: clamp(14px, 12.66667px + 0.17361vw, 16px);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

@media screen and (max-width: 1099px) {
  .sideNav__toggleIcon {
    width: 10px;
    height: 10px;
    border-right: 2px solid #222;
    border-bottom: 2px solid #222;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    -webkit-transition: .3s;
    transition: .3s;
    -webkit-box-flex: 0;
    -ms-flex: 0 0 auto;
    flex: 0 0 auto;
    margin-left: 10px;
  }
}

@media screen and (max-width: 1099px) {
  .sideNav.is-open .sideNav__toggleIcon {
    -webkit-transform: rotate(-135deg);
    transform: rotate(-135deg);
  }
}

/* ===== list ===== */
.sideNav__list {
  padding-top: clamp(100px, 66.66667px + 4.34028vw, 150px);
}

@media screen and (max-width: 1099px) {
  .sideNav__list {
    padding-top: 10px;
    display: none;
    border: 1px solid #222;
    border-radius: clamp(16px, 13.33333px + 0.34722vw, 20px);
    padding: 10px;
    background: #fff;
  }
}

@media screen and (max-width: 1099px) {
  .sideNav.is-open .sideNav__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

@media screen and (max-width: 1099px) {
  .sideNav__list {
    -webkit-box-align: stretch;
    -ms-flex-align: stretch;
    align-items: stretch;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 10px;
  }
}

.sideNav__list li {
  margin-bottom: clamp(8px, 5.33333px + 0.34722vw, 12px);
}

@media screen and (max-width: 1099px) {
  .sideNav__list li {
    margin-bottom: 0;
    width: calc((100% - 10px) / 2);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

.sideNav__list a {
  text-decoration: none;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  color: #222;
  -webkit-transition: color .3s;
  transition: color .3s;
  white-space: nowrap;
}

@media screen and (max-width: 1099px) {
  .sideNav__list a {
    width: 100%;
    height: clamp(32px, 16px + 2.08333vw, 56px);
    border-radius: 100vh;
    padding: 0 clamp(10px, 6px + 0.52083vw, 16px);
    border: 1px solid #222;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}

.sideNav__list a:hover {
  color: #F7930E !important;
  opacity: 1;
}

@media screen and (max-width: 1099px) {
  .sideNav__list a:hover {
    border-color: #F7930E !important;
    background-color: #F7930E !important;
    color: #222 !important;
  }
}

.sideNav__list a:hover span::before {
  border: 1px solid #F7930E;
}

.sideNav__list a:hover span::after {
  background-color: #F7930E;
}

.sideNav__list a.is-active {
  color: #F7930E;
}

@media screen and (max-width: 1099px) {
  .sideNav__list a.is-active {
    border-color: #F7930E !important;
  }
}

.sideNav__list a.is-active span::before {
  border: 1px solid #F7930E;
}

.sideNav__list a.is-active span::after {
  background-color: #F7930E;
}

.sideNav__list a span {
  font-size: clamp(14px, 12.66667px + 0.17361vw, 16px);
  line-height: normal;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding-left: clamp(18px, 14px + 0.52083vw, 24px);
}

@media screen and (max-width: 1099px) {
  .sideNav__list a span {
    padding-left: 0;
    text-align: center;
  }
}

.sideNav__list a span::before, .sideNav__list a span::after {
  content: "";
  position: absolute;
  border-radius: 100vh;
  -webkit-transition: .3s;
  transition: .3s;
}

@media screen and (max-width: 1099px) {
  .sideNav__list a span::before, .sideNav__list a span::after {
    display: none;
  }
}

.sideNav__list a span::before {
  width: clamp(12px, 9.33333px + 0.34722vw, 16px);
  aspect-ratio: 1 / 1;
  border: 1px solid transparent;
  left: 0;
}

.sideNav__list a span::after {
  width: clamp(4px, 1.33333px + 0.34722vw, 8px);
  aspect-ratio: 1 / 1;
  background-color: #222;
  left: 5px;
}

.l-column__main {
  -webkit-box-flex: 1;
  -ms-flex-positive: 1;
  flex-grow: 1;
  width: calc(100% - 280px);
  z-index: 1;
  padding-top: clamp(100px, 66.66667px + 4.34028vw, 150px);
}

@media screen and (max-width: 1099px) {
  .l-column__main {
    padding-top: 40px;
    width: 100%;
  }
}

/* ==============================
// メッセージ
================================= */
.l-message {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  text-align: center;
  line-height: normal;
}

.l-message2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  text-align: center;
  line-height: normal;
  margin-top: clamp(56px, 45.33333px + 1.38889vw, 72px);
}

@media screen and (max-width: 767px) {
  .l-message2 {
    margin-top: 32px;
  }
}

.l-messageArea {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

@media screen and (max-width: 767px) {
  .l-messageArea span {
    line-height: normal;
  }
}

.l-messageText {
  font-size: clamp(14px, -3.33333px + 2.25694vw, 40px);
}

.l-messageMain {
  font-size: clamp(20px, 5.33333px + 1.90972vw, 42px);
}

.l-messageBig {
  font-size: clamp(22px, -3.33333px + 3.29861vw, 60px);
}

.l-messageLine {
  position: relative;
}

.l-messageLine::before {
  content: "";
  position: absolute;
  bottom: clamp(5px, 0.33333px + 0.60764vw, 12px);
  left: 0;
  width: 0%;
  height: clamp(5px, 1.66667px + 0.43403vw, 10px);
  background-color: #F7930E;
  -webkit-transition: 1s;
  transition: 1s;
}

.l-messageLine.is-active::before {
  width: 100%;
  -webkit-transition-delay: 0.2s;
  transition-delay: 0.2s;
}

.l-messageMain-span {
  position: relative;
  z-index: 1;
}

.l-messageIcon {
  height: clamp(22px, 4.66667px + 2.25694vw, 48px);
  width: auto;
  margin-left: clamp(2px, -2px + 0.52083vw, 8px);
}

/* ==============================
// CTA
================================= */
.l-ctaArea {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: clamp(8px, -2.66667px + 1.38889vw, 24px);
  margin-top: clamp(24px, 0px + 3.125vw, 60px);
}

@media screen and (max-width: 767px) {
  .l-ctaArea {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}

.l-ctaLink {
  min-height: clamp(56px, 26.66667px + 3.81944vw, 100px);
  min-width: clamp(190px, 116.66667px + 9.54861vw, 300px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: clamp(4px, 1.33333px + 0.34722vw, 8px);
  padding: 0 clamp(12px, -17.33333px + 3.81944vw, 56px);
  background-color: #0F2186;
  color: #fff;
  -webkit-box-shadow: 0px 8px 20px rgba(15, 33, 134, 0.5);
  box-shadow: 0px 8px 20px rgba(15, 33, 134, 0.5);
  border-radius: 100vh;
  white-space: nowrap;
}

.l-ctaLink:hover {
  -webkit-box-shadow: 0px 0px 0px rgba(15, 33, 134, 0.5);
  box-shadow: 0px 0px 0px rgba(15, 33, 134, 0.5);
  opacity: 1;
}

@media screen and (max-width: 767px) {
  .l-ctaLink {
    width: 100%;
  }
}

.l-ctaIcon {
  width: 100%;
  max-width: clamp(24px, 13.33333px + 1.38889vw, 40px);
}

.l-ctaText {
  font-size: clamp(16px, 6.66667px + 1.21528vw, 30px);
}

.l-ctaArea__center {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-top: clamp(32px, -6.66667px + 5.03472vw, 90px);
}

/* ==============================
// カラムテンプレート01
================================= */
.l-column01 {
  border-radius: clamp(10px, -3.33333px + 1.73611vw, 30px);
  overflow: hidden;
  padding: clamp(24px, -20px + 5.72917vw, 90px);
}

.l-column01__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  gap: clamp(24px, 0px + 3.125vw, 60px);
}

@media screen and (max-width: 767px) {
  .l-column01__list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}

.l-column01__item {
  width: calc((100% - (clamp(24px, 0px + 3.125vw, 60px)*2))/3);
  height: auto;
}

@media screen and (max-width: 767px) {
  .l-column01__item {
    width: 100%;
  }
}

.l-column01__line {
  border-right: 1px dashed #ccc;
  height: auto;
}

@media screen and (max-width: 767px) {
  .l-column01__line {
    border-right: 0px dashed #ccc;
    border-bottom: 1px dashed #ccc;
  }
}

.l-column01__fukidashi {
  background-color: #F7930E;
  padding: 16px clamp(6px, 2px + 0.52083vw, 12px) 12px;
  border-radius: 100vh;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  position: relative;
  margin-bottom: clamp(19px, 11.66667px + 0.95486vw, 30px);
}

.l-column01__fukidashi::before {
  content: "";
  position: absolute;
  width: clamp(20px, 13.33333px + 0.86806vw, 30px);
  aspect-ratio: 1/1;
  border-radius: 3px;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  background-color: #F7930E;
  bottom: calc(-1*clamp(8px, 5.33333px + 0.34722vw, 12px));
  z-index: 0;
}

.l-column01__fukidashi-span {
  color: #fff;
  line-height: 1.2;
  text-align: center;
  font-size: clamp(16px, 10.66667px + 0.69444vw, 24px);
  position: relative;
  z-index: 1;
}

.l-column01__photo {
  aspect-ratio: 3/2;
  border-radius: clamp(6px, 3.33333px + 0.34722vw, 10px);
  overflow: hidden;
  width: 100%;
  height: auto !important;
  font-size: clamp(19px, 11.66667px + 0.95486vw, 30px);
}

.l-column01__text01 {
  margin-top: clamp(16px, 10.66667px + 0.69444vw, 24px);
  font-size: clamp(12px, 6.66667px + 0.69444vw, 20px);
}

.l-column01__text02 {
  margin-top: clamp(8px, 2.66667px + 0.69444vw, 16px);
  font-size: clamp(9px, 5px + 0.52083vw, 15px);
  color: #707070;
}

.l-column01__textList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: clamp(4px, 1.33333px + 0.34722vw, 8px);
  margin-top: clamp(16px, 10.66667px + 0.69444vw, 24px);
}

.l-column01__textItem {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: clamp(4px, 1.33333px + 0.34722vw, 8px);
}

.l-column01__textIcon {
  width: clamp(14px, 7.33333px + 0.86806vw, 24px);
}

.l-column01__textP {
  width: calc(100% - clamp(14px, 7.33333px + 0.86806vw, 24px) - clamp(6px, 3.33333px + 0.34722vw, 10px));
}

/* ==============================
// カラムテンプレート02
================================= */
.l-column02 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: clamp(24px, 13.33333px + 1.38889vw, 40px);
}

@media screen and (max-width: 767px) {
  .l-column02 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}

.l-column02__left,
.l-column02__right {
  width: calc((100% - clamp(20px, 13.33333px + 0.86806vw, 30px))/2);
  height: auto;
}

@media screen and (max-width: 767px) {
  .l-column02__left,
  .l-column02__right {
    width: 100%;
  }
}

.l-column02__h3 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  line-height: normal;
  margin-bottom: clamp(16px, 0px + 2.08333vw, 40px);
}

.l-column02__h3En {
  line-height: 1;
  font-size: clamp(19px, 11.66667px + 0.95486vw, 30px);
  margin-bottom: clamp(8px, 2.66667px + 0.69444vw, 16px);
  letter-spacing: 0;
  font-weight: 900;
}

.l-column02__h3Jp {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

.l-column02__h3Jp-main {
  font-size: clamp(24px, 12px + 1.5625vw, 42px);
  line-height: 1.4;
}

.l-column02____h3Jp-small {
  font-size: clamp(16px, 6.66667px + 1.21528vw, 30px);
  line-height: 1.4;
  margin-top: clamp(6px, 2px + 0.52083vw, 12px);
}

.l-column02__h4 {
  font-size: clamp(15px, 5px + 1.30208vw, 30px);
  line-height: 1.4;
  margin-bottom: clamp(16px, 5.33333px + 1.38889vw, 32px);
  text-align: center;
}

.l-column02__p {
  font-size: clamp(14px, 10px + 0.52083vw, 20px);
  margin-bottom: clamp(16px, 0px + 2.08333vw, 40px);
}

.l-column02__p:last-child {
  margin-bottom: 0;
}

.l-column02__waku {
  padding: clamp(16px, 0px + 2.08333vw, 40px);
  border-radius: 10px;
  background-color: #fff;
  border: 2px solid #222;
}

.l-column02__right {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

.l-column02__photo {
  width: 100%;
  height: auto !important;
  overflow: hidden;
  border-radius: 10px;
  -webkit-box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.16);
  box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.16);
}

/* ==============================
// カラムテンプレート03
================================= */
.l-column03 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  gap: clamp(24px, 13.33333px + 1.38889vw, 40px);
}

@media screen and (max-width: 767px) {
  .l-column03 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}

.l-column03 > div {
  height: auto;
}

/* ==============================
// 追尾バナー
================================= */
.l-banner {
  position: fixed;
  margin: 15px 20px 0;
  z-index: 4;
  bottom: 0;
  right: clamp(10px, 3.33333px + 0.86806vw, 20px);
  /* 追加：初期は非表示 */
  opacity: 0;
  visibility: hidden;
  -webkit-transform: translateY(12px);
  transform: translateY(12px);
  pointer-events: none;
  -webkit-transition: opacity .35s ease, visibility .35s ease, -webkit-transform .35s ease;
  transition: opacity .35s ease, visibility .35s ease, -webkit-transform .35s ease;
  transition: opacity .35s ease, transform .35s ease, visibility .35s ease;
  transition: opacity .35s ease, transform .35s ease, visibility .35s ease, -webkit-transform .35s ease;
}

@media screen and (max-width: 1099px) {
  .l-banner {
    display: none;
  }
}

.l-banner.is-show {
  opacity: 1;
  visibility: visible;
  -webkit-transform: translateY(0);
  transform: translateY(0);
  pointer-events: auto;
}

.l-banner__link {
  text-decoration: none;
  display: block;
  position: relative;
}

.l-banner__link:hover {
  opacity: 1;
}

.l-banner__link:hover .l-banner__bnr-waku {
  -webkit-box-shadow: 0px 0px 0px rgba(15, 33, 134, 0.5);
  box-shadow: 0px 0px 0px rgba(15, 33, 134, 0.5);
}

.l-banner__bnr-waku {
  position: relative;
  overflow: hidden;
  border-radius: clamp(10px, -3.33333px + 1.73611vw, 30px) clamp(10px, -3.33333px + 1.73611vw, 30px) 0 0;
  -webkit-box-shadow: 0px 8px 20px rgba(15, 33, 134, 0.5);
  box-shadow: 0px 8px 20px rgba(15, 33, 134, 0.5);
  -webkit-transition: .3s;
  transition: .3s;
}

.l-banner__bnr-waku::before {
  position: absolute;
  content: '';
  display: inline-block;
  top: -180px;
  left: 0;
  width: 30px;
  height: 100%;
  background-color: #fff;
  -webkit-animation: kiran 3s ease-in-out infinite;
  animation: kiran 3s ease-in-out infinite;
}

@-webkit-keyframes kiran {
  0% {
    -webkit-transform: scale(0) rotate(45deg);
    transform: scale(0) rotate(45deg);
    opacity: 0;
  }
  80% {
    -webkit-transform: scale(0) rotate(45deg);
    transform: scale(0) rotate(45deg);
    opacity: 0.4;
  }
  81% {
    -webkit-transform: scale(4) rotate(45deg);
    transform: scale(4) rotate(45deg);
    opacity: 0.6;
  }
  100% {
    -webkit-transform: scale(50) rotate(45deg);
    transform: scale(50) rotate(45deg);
    opacity: 0;
  }
}

@keyframes kiran {
  0% {
    -webkit-transform: scale(0) rotate(45deg);
    transform: scale(0) rotate(45deg);
    opacity: 0;
  }
  80% {
    -webkit-transform: scale(0) rotate(45deg);
    transform: scale(0) rotate(45deg);
    opacity: 0.4;
  }
  81% {
    -webkit-transform: scale(4) rotate(45deg);
    transform: scale(4) rotate(45deg);
    opacity: 0.6;
  }
  100% {
    -webkit-transform: scale(50) rotate(45deg);
    transform: scale(50) rotate(45deg);
    opacity: 0;
  }
}

.l-banner__bnr {
  width: clamp(250px, 176.66667px + 9.54861vw, 360px);
  overflow: hidden;
}

.l-banner__bnr-book {
  position: absolute;
  z-index: 1;
  top: calc(-1*clamp(30px, 23.33333px + 0.86806vw, 40px));
  right: calc(-1*clamp(30px, 16.66667px + 1.73611vw, 50px));
  width: clamp(150px, 116.66667px + 4.34028vw, 200px);
}

.l-banner__close {
  font-weight: bold;
  position: absolute;
  top: -20px;
  right: -15px;
  z-index: 99999;
  width: clamp(30px, 23.33333px + 0.86806vw, 40px);
  font-size: clamp(16px, 10.66667px + 0.69444vw, 24px);
  padding-bottom: 4px;
  line-height: 0;
  height: auto;
  aspect-ratio: 1/1;
  border: none;
  background-color: #f8f8f8;
  border-radius: 100vh;
  cursor: pointer;
  -webkit-box-shadow: 0 0 7px rgba(0, 0, 0, 0.4);
  box-shadow: 0 0 7px rgba(0, 0, 0, 0.4);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.l-effect {
  position: relative;
  overflow: hidden;
}

.l-effect::before {
  position: absolute;
  content: '';
  display: inline-block;
  top: -180px;
  left: 0;
  width: 30px;
  height: 100%;
  background-color: #fff;
  -webkit-animation: kiran 3s ease-in-out infinite;
  animation: kiran 3s ease-in-out infinite;
}

/* ==============================
// テキストリスト
================================= */
.l-textList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: clamp(8px, 5.33333px + 0.34722vw, 12px);
}

.l-textItem {
  font-size: clamp(12px, 9.33333px + 0.34722vw, 16px);
  line-height: normal;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
  -ms-flex-align: baseline;
  align-items: baseline;
  padding-left: clamp(18px, 14px + 0.52083vw, 24px);
}

.l-textItem::after {
  content: "";
  position: absolute;
  border-radius: 100vh;
  width: clamp(4px, 1.33333px + 0.34722vw, 8px);
  height: auto;
  aspect-ratio: 1 / 1;
  background-color: #F7930E;
  left: 5px;
  top: .5em;
}

/* ==============================
// アコーディオン（機能一覧・よくある質問）
================================= */
.l-accordion {
  list-style: none;
  margin: 0;
  padding: 0;
  border-top: 1px solid #ccc;
}

.l-accordion > li {
  border-bottom: 1px solid #ccc;
}

.l-accordion__q button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
  width: 100%;
  font: inherit;
  text-align: left;
  cursor: pointer;
  -webkit-transition: opacity 400ms;
  transition: opacity 400ms;
  outline: none;
  padding: clamp(16px, 5.33333px + 1.38889vw, 32px) clamp(8px, -13.33333px + 2.77778vw, 40px);
}

.l-accordion__q button:hover .l-accordion__q-content {
  color: #F7930E;
}

.l-accordion__q-prefix {
  display: block;
  font-weight: 900;
  line-height: 1;
  font-size: clamp(16px, 0px + 2.08333vw, 40px);
  color: #F7930E;
  width: clamp(32px, 6.66667px + 3.29861vw, 70px);
}

.l-accordion__q-content {
  display: block;
  line-height: 1.6;
  font-size: clamp(16px, 0px + 2.08333vw, 40px);
  width: calc(100% - (clamp(32px, 6.66667px + 3.29861vw, 70px) + clamp(16px, 2px + 1.82292vw, 37px) + clamp(16px, 2px + 1.82292vw, 37px)));
  color: #222;
  -webkit-transition: .3s;
  transition: .3s;
}

.l-accordion__q-icon {
  position: absolute;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  right: clamp(16px, 0px + 2.08333vw, 40px);
  width: clamp(16px, 2px + 1.82292vw, 37px);
  height: clamp(16px, 2px + 1.82292vw, 37px);
}

.l-accordion__q-icon::before,
.l-accordion__q-icon::after {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  background: #222;
}

.l-accordion__q-icon::after {
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
  -webkit-transition: -webkit-transform 400ms;
  transition: -webkit-transform 400ms;
  transition: transform 400ms;
  transition: transform 400ms, -webkit-transform 400ms;
}

.l-accordion > li.is-open .l-accordion__q-icon::after {
  -webkit-transform: rotate(0deg);
  transform: rotate(0deg);
}

/* ===== A ===== */
.l-accordion__a {
  overflow: hidden;
  border-top: 1px solid #ccc;
}

.l-accordion__aArea {
  padding: clamp(16px, 5.33333px + 1.38889vw, 32px) clamp(8px, -13.33333px + 2.77778vw, 40px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

.l-accordion__a-inner {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
  -ms-flex-align: baseline;
  align-items: baseline;
}

.l-accordion__a-prefix {
  font-weight: 500;
  line-height: 1;
  font-size: clamp(16px, 0px + 2.08333vw, 40px);
  width: clamp(32px, 6.66667px + 3.29861vw, 70px);
  color: #FF7600;
}

.l-accordion__a-content {
  width: calc(100% - clamp(32px, 6.66667px + 3.29861vw, 70px));
}

.l-accordion__a-content-p {
  font-size: clamp(14px, 3.33333px + 1.38889vw, 30px);
  line-height: normal;
}

.l-accordion__title {
  font-size: clamp(14px, 3.33333px + 1.38889vw, 30px);
  margin-bottom: clamp(8px, 2.66667px + 0.69444vw, 16px);
  line-height: normal;
}

/* ==============================
// 途中CTA
================================= */
.l-ctaMain {
  position: relative;
}

.l-ctaMain::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 100vw;
  height: 100%;
  background-color: #F7930E;
  z-index: 0;
}

.l-ctaMain::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 100vw;
  height: 100%;
  background-image: url(../../assets/images/cmn/dot__bk.webp);
  z-index: 1;
}

.l-ctaMain .l-container {
  position: relative;
  z-index: 2;
  padding-top: clamp(64px, 40px + 3.125vw, 100px);
  padding-bottom: clamp(64px, 40px + 3.125vw, 100px);
}

.l-ctaMain .l-ctaArea {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .l-ctaMain .l-ctaArea {
    gap: 64px;
  }
}

.l-ctaMain .l-ctaArea__div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  position: relative;
  z-index: 1;
}

@media screen and (max-width: 767px) {
  .l-ctaMain .l-ctaArea__div {
    width: 100%;
  }
}

.l-ctaMain .l-ctaArea__infoSub {
  position: absolute;
  background-color: #fff;
  color: #222;
  line-height: 1;
  padding: 8px clamp(16px, 10.66667px + 0.69444vw, 24px) 7px;
  border-radius: 3px;
  top: calc(-1 * clamp(40px, 24px + 2.08333vw, 64px));
  white-space: nowrap;
}

.l-ctaMain .l-ctaArea__infoSubtext::before {
  bottom: -16px;
}

.l-ctaMain .l-ctaArea__infoSubtext {
  font-size: clamp(12px, 4px + 1.04167vw, 24px);
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.l-ctaMain .l-ctaArea__infoSubtext::before {
  content: "";
  position: absolute;
  width: 20px;
  aspect-ratio: 1 / 1;
  border-radius: 3px;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  background-color: #fff;
  bottom: -12px;
  z-index: -1;
}

.l-ctaMain .l-ctaLink {
  min-height: clamp(56px, 26.66667px + 3.81944vw, 100px);
  min-width: clamp(190px, 116.66667px + 9.54861vw, 300px);
  padding: 0 clamp(12px, -17.33333px + 3.81944vw, 56px);
}

@media screen and (max-width: 767px) {
  .l-ctaMain .l-ctaLink {
    width: 100%;
  }
}

.l-ctaMain .l-ctaText {
  font-size: clamp(16px, 0px + 2.08333vw, 40px);
}

/*
■　使い方

編集ツール：https://icomoon.io/app/#/select
１　icomoonにアクセスする
２　左上の「import icons」を押して assets>font>selection.json を選択
３　ここ（https://www.granfairs.com/blog/staff/howto-create-iconfont）の
　　STEP1. オリジナルアイコンを準備する　〜　STEP5. フォントファイルを生成　を参考に
　　アイコンフォントデータを編集・ダウンロード
４　ダウンロードしたファイルの「fonts」内のファイルと、selection.jsonを　assets>font　に全て入れる
５　<i class="icon-mail"></i>のような感じで使える

*/
@font-face {
  font-family: 'icomoon';
  src: url("./../../assets/fonts/icomoon.eot");
  src: url("./../../assets/fonts/icomoon.eot") format("embedded-opentype"), url("./../../assets/fonts/icomoon.ttf") format("truetype"), url("./../../assets/fonts/icomoon.woff") format("woff"), url("./../../assets/fonts/icomoon.svg") format("svg");
  font-weight: normal;
  font-style: normal;
  font-display: block;
}

[class^="icon-"], [class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: 'icomoon' !important;
  /* speak: none; */
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon-arr-thin-r:before {
  content: "\e900";
}

.icon-dl:before {
  content: "\e901";
}

.icon-arr-thin-t:before {
  content: "\e902";
}

.icon-popup:before {
  content: "\e903";
}

.icon-tel:before {
  content: "\e904";
}

.icon-arr-b:before {
  content: "\e905";
}

.icon-arr-l:before {
  content: "\e906";
}

.icon-arr-r:before {
  content: "\e907";
}

.icon-arr-t:before {
  content: "\e908";
}

.icon-arr-thin-b:before {
  content: "\e909";
}

.icon-arr-thin-l:before {
  content: "\e90a";
}

.icon-mail:before {
  content: "\e90b";
}

.icon-checked:before {
  content: "\e90c";
}

.icon-pamph:before {
  content: "\e90d";
}

.icon-freeDial:before {
  content: "\e90e";
}

.icon-mailThin:before {
  content: "\e90f";
}

.icon-line:before {
  content: "\e910";
}

.icon-facebook:before {
  content: "\ea90";
}

.icon-instagram:before {
  content: "\ea92";
}

.icon-twitter:before {
  content: "\ea96";
}

/* ==========================================================================
	ボタンのモジュール
============================================================================= */
.btn {
  min-height: clamp(56px, 26.66667px + 3.81944vw, 100px);
  min-width: clamp(190px, 116.66667px + 9.54861vw, 300px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: clamp(6px, 4.66667px + 0.17361vw, 8px);
  padding: 0 clamp(12px, -17.33333px + 3.81944vw, 56px);
  background-color: #0F2186;
  color: #fff;
  -webkit-box-shadow: 0px 8px 20px rgba(15, 33, 134, 0.5);
  box-shadow: 0px 8px 20px rgba(15, 33, 134, 0.5);
  border-radius: 100vh;
  white-space: nowrap;
  max-width: 900px;
  -webkit-transition: .3s;
  transition: .3s;
  font-size: clamp(16px, 6.66667px + 1.21528vw, 30px);
  color: #fff;
  font-weight: 900;
}

.btn:hover {
  -webkit-box-shadow: 0px 0px 0px rgba(15, 33, 134, 0.5);
  box-shadow: 0px 0px 0px rgba(15, 33, 134, 0.5);
  opacity: 1;
}

/* ==========================================================================
  メールフォームの共通モジュール
============================================================================= */
.form {
  /* エラー表示調整
	----------------------------------------------------------------- */
}

.form table {
  width: 100%;
}

.form .form__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: clamp(16px, 10.66667px + 0.69444vw, 24px);
  width: 100%;
  border-bottom: 1px solid #ccc;
  padding: clamp(24px, 20px + 0.52083vw, 30px) clamp(8px, -6.66667px + 1.90972vw, 30px);
}

@media screen and (max-width: 767px) {
  .form .form__item {
    display: block;
  }
}

.form dt, .form th {
  width: clamp(230px, 143.33333px + 11.28472vw, 360px);
  min-height: clamp(48px, 20px + 3.64583vw, 90px);
  line-height: 44px;
  font-weight: bold;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-size: clamp(16px, 10.66667px + 0.69444vw, 24px);
}

@media screen and (max-width: 767px) {
  .form dt, .form th {
    width: 100%;
    max-width: 100%;
    line-height: inherit;
    min-height: inherit;
    padding-bottom: 8px;
  }
}

.form dt span, .form th span {
  line-height: 1em;
  padding: 0.4em 0 0.4em;
  background: #ccc;
  color: #fff;
  font-size: clamp(12px, 6.66667px + 0.69444vw, 20px);
  text-align: center;
  display: inline-block;
  width: clamp(40px, 24px + 2.08333vw, 64px);
  margin: 7px 10px;
  float: right;
  border-radius: 6px;
}

@media screen and (max-width: 767px) {
  .form dt span, .form th span {
    float: none;
    line-height: 1.5em;
    margin: 0 0 0 5px;
    vertical-align: text-top;
  }
}

.form .required dt span,
.form .required th span {
  background: #F7930E;
}

.form dd, .form td {
  -webkit-box-flex: 1;
  -ms-flex-positive: 1;
  flex-grow: 1;
}

@media screen and (max-width: 767px) {
  .form dd, .form td {
    display: block;
    margin: 0;
  }
}

.form th, .form td {
  padding-bottom: 30px;
}

.form input, .form textarea, .form select {
  font-family: "LINESeedJP", "Noto Sans JP", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  outline: none;
}

.form input[type="text"],
.form input[type="tel"],
.form input[type="email"],
.form input[type="number"],
.form input[type="date"],
.form select,
.form textarea {
  width: 100%;
  background: #fff;
  border: 2px solid transparent;
  border-radius: 6px;
  min-height: clamp(56px, 33.33333px + 2.95139vw, 90px);
  line-height: 44px;
  padding: 0 1em;
  font-size: clamp(16px, 10.66667px + 0.69444vw, 24px);
  -webkit-appearance: none;
  cursor: pointer;
}

.form input[type="text"]::-webkit-input-placeholder, .form input[type="tel"]::-webkit-input-placeholder, .form input[type="email"]::-webkit-input-placeholder, .form input[type="number"]::-webkit-input-placeholder, .form input[type="date"]::-webkit-input-placeholder, .form select::-webkit-input-placeholder, .form textarea::-webkit-input-placeholder {
  color: #C1C1C1;
}

.form input[type="text"]::-moz-placeholder, .form input[type="tel"]::-moz-placeholder, .form input[type="email"]::-moz-placeholder, .form input[type="number"]::-moz-placeholder, .form input[type="date"]::-moz-placeholder, .form select::-moz-placeholder, .form textarea::-moz-placeholder {
  color: #C1C1C1;
}

.form input[type="text"]:-ms-input-placeholder, .form input[type="tel"]:-ms-input-placeholder, .form input[type="email"]:-ms-input-placeholder, .form input[type="number"]:-ms-input-placeholder, .form input[type="date"]:-ms-input-placeholder, .form select:-ms-input-placeholder, .form textarea:-ms-input-placeholder {
  color: #C1C1C1;
}

.form input[type="text"]::-ms-input-placeholder, .form input[type="tel"]::-ms-input-placeholder, .form input[type="email"]::-ms-input-placeholder, .form input[type="number"]::-ms-input-placeholder, .form input[type="date"]::-ms-input-placeholder, .form select::-ms-input-placeholder, .form textarea::-ms-input-placeholder {
  color: #C1C1C1;
}

.form input[type="text"]::placeholder,
.form input[type="tel"]::placeholder,
.form input[type="email"]::placeholder,
.form input[type="number"]::placeholder,
.form input[type="date"]::placeholder,
.form select::placeholder,
.form textarea::placeholder {
  color: #C1C1C1;
}

.form input[type="text"]:focus,
.form input[type="tel"]:focus,
.form input[type="email"]:focus,
.form input[type="number"]:focus,
.form input[type="date"]:focus,
.form select:focus,
.form textarea:focus {
  border-color: #F7930E;
  background: #f8f8f8;
}

.form select::-ms-expand {
  display: none;
}

.form .selectWrap {
  position: relative;
}

.form .selectWrap::after {
  content: "▼";
  position: absolute;
  right: 1em;
  top: 0.6em;
  pointer-events: none;
}

.form input[type="date"],
.form .selectWrap {
  max-width: 15em;
}

.form label {
  cursor: pointer;
}

.form textarea {
  display: block;
  padding: 17px 14px;
  height: 200px;
  line-height: 1.75;
  resize: vertical;
}

.form span.wpcf7-list-item {
  display: block;
  margin: 10px 0;
}

.form .form__zipCode {
  margin-bottom: 10px;
}

.form .form__zipCode input {
  display: inline-block;
  width: 10em;
  margin-left: 10px;
}

.form .form__submit {
  position: relative;
  margin: 0 auto;
  min-height: clamp(56px, 26.66667px + 3.81944vw, 100px);
  min-width: clamp(190px, 116.66667px + 9.54861vw, 300px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: clamp(6px, 4.66667px + 0.17361vw, 8px);
  padding: 0 clamp(12px, -17.33333px + 3.81944vw, 56px);
  background-color: #0F2186;
  color: #fff;
  -webkit-box-shadow: 0px 8px 20px rgba(15, 33, 134, 0.5);
  box-shadow: 0px 8px 20px rgba(15, 33, 134, 0.5);
  border-radius: 100vh;
  white-space: nowrap;
  max-width: 900px;
  -webkit-transition: .3s;
  transition: .3s;
}

.form .form__submit:hover {
  -webkit-box-shadow: 0px 0px 0px rgba(15, 33, 134, 0.5);
  box-shadow: 0px 0px 0px rgba(15, 33, 134, 0.5);
  opacity: 1;
}

.form .form__submit.js-disabled {
  border-color: #ccc;
  background: #ccc;
  -webkit-box-shadow: 0px 0px 0px rgba(15, 33, 134, 0.5);
  box-shadow: 0px 0px 0px rgba(15, 33, 134, 0.5);
}

@media (hover: hover) and (pointer: fine) {
  .form .form__submit.js-disabled:hover {
    color: #F7930E;
    border-color: #ccc;
    background: #ccc;
  }
  .form .form__submit.js-disabled:hover input {
    color: #222;
  }
}

.form .form__submit input {
  font-size: clamp(16px, 6.66667px + 1.21528vw, 30px);
  color: #fff;
  font-weight: 900;
  background: none;
  border: none;
  cursor: pointer;
  position: absolute;
  z-index: 1;
  width: 100%;
  height: 100%;
}

.form .wpcf7-spinner {
  display: none;
}

.form .form__submit + p {
  margin: 30px 0 0;
}

.form .form__acceptance {
  text-align: center;
  margin: clamp(36px, 33.33333px + 0.34722vw, 40px) 0 clamp(36px, 22.66667px + 1.73611vw, 56px);
}

.form .form__acceptance a {
  text-decoration: underline;
}

.form .form__acceptance a:hover {
  color: #F7930E;
}

.form .wpcf7-not-valid-tip {
  background: #FFF5E4;
  width: 100%;
  margin-top: 10px;
  color: #FF7600;
  font-weight: 600;
  border-radius: 6px;
  display: block;
  font-size: clamp(12px, 6.66667px + 0.69444vw, 20px);
  padding: 4px 10px 4px 10px;
}

.form div.wpcf7-mail-sent-ok {
  display: none !important;
}

.form .ui-datepicker {
  z-index: 10 !important;
}

/* ==========================================================================
  見出しのモジュール
============================================================================= */
.heading__Lv2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  margin-bottom: clamp(56px, 33.33333px + 2.95139vw, 90px);
}

@media screen and (max-width: 767px) {
  .heading__Lv2 {
    margin-bottom: 32px;
  }
}

.heading__Lv2-en {
  line-height: 1;
  font-size: clamp(14px, 3.33333px + 1.38889vw, 30px);
  margin-bottom: clamp(16px, 5.33333px + 1.38889vw, 32px);
  letter-spacing: 0;
  font-weight: 900;
}

.heading__Lv2-jp {
  line-height: 1;
  font-size: clamp(20px, 6.66667px + 1.73611vw, 40px);
  position: relative;
  margin-bottom: clamp(8px, 1.33333px + 0.86806vw, 18px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.heading__Lv2-jp::before, .heading__Lv2-jp::after {
  content: "";
  position: absolute;
  height: clamp(24px, 18.66667px + 0.69444vw, 32px);
  border-right: 2px dashed #F7930E;
}

.heading__Lv2-jp::before {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  left: -24px;
}

.heading__Lv2-jp::after {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  right: -24px;
}

.heading__white .heading__Lv2-jp {
  color: #fff;
}

.heading__white .heading__Lv2-jp::before, .heading__white .heading__Lv2-jp::after {
  border-color: #FFD800;
}

.heading__white .l-message span {
  color: #fff;
}

.heading__white .l-messageLine::before {
  background-color: #FFD800;
}

/* table
----------------------------------------------------------------- */
.table {
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
  display: table;
  table-layout: fixed;
  width: 100%;
  border-top: 1px dotted #e3e3e3;
}

.table .table-td, .table .table-th {
  display: table-cell;
  text-align: left;
  font-weight: 400;
  border-bottom: 1px dotted #e3e3e3;
}

.table .table-th {
  width: 210px;
  background-color: #f8f8f8;
  padding: 14px 20px 14px 22px;
}

.table .table-td {
  background-color: #fff;
  padding: 14px 24px;
  line-height: 2;
}

@media screen and (max-width: 767px) {
  .table {
    font-size: .9em;
    /*End @media */
  }
  .table .table-th {
    width: 8em;
    padding: 14px 0;
    text-align: center;
  }
}

.table-primary .table-th {
  width: 9em;
  background-color: #ffffff;
}

@media screen and (max-width: 767px) {
  .table-primary {
    /*End @media */
  }
  .table-primary .table-th {
    width: 7em;
  }
}

/* ==========================================================================
  ページ送りのモジュール
============================================================================= */
/* ==============================
// アーカイブページのページ送り
================================= */
.pagerArchive {
  text-align: center;
  margin: 60px 0 0;
}

.pagerArchive .wp-pagenavi span, .pagerArchive .wp-pagenavi a {
  display: inline-block;
  line-height: 40px;
  text-align: center;
  padding: 0 14px;
}

@media (hover: hover) and (pointer: fine) {
  .pagerArchive .wp-pagenavi span:hover, .pagerArchive .wp-pagenavi a:hover {
    border-color: #F7930E;
    color: #F7930E;
  }
}

.pagerArchive .wp-pagenavi span.current {
  background: #F7930E;
  color: #ffffff;
  border-color: #F7930E;
}

/* ==============================
// 記事詳細のページ送り
================================= */
.pagerSingle {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin: 0 -10px;
}

.pagerSingle__wrap {
  overflow: visible;
}

.pagerSingle__item {
  max-width: 10em;
  width: 100%;
  margin: 0 10px;
}

.pagerSingle__item a {
  text-decoration: none;
  display: inline-block;
  color: #F7930E;
}

.pagerSingle__item a::before,
.pagerSingle__item a::after {
  font-family: 'icomoon';
  position: static;
  display: inline-block;
  -webkit-transition: .2s;
  transition: .2s;
}

.pagerSingle__prev {
  text-align: right;
}

.pagerSingle__prev a::after {
  margin-left: 10px;
  content: "\e907";
}

@media (hover: hover) and (pointer: fine) {
  .pagerSingle__prev a:hover::after {
    -webkit-transform: translateX(0.5em);
    transform: translateX(0.5em);
  }
}

.pagerSingle__list {
  text-align: center;
}

.pagerSingle__next {
  text-align: left;
}

.pagerSingle__next a::before {
  margin-right: 10px;
  content: "\e906";
}

@media (hover: hover) and (pointer: fine) {
  .pagerSingle__next a:hover::before {
    -webkit-transform: translateX(-0.5em);
    transform: translateX(-0.5em);
  }
}

/* ==========================================================================
  汎用リスト用モジュール
============================================================================= */
.simpleList li::before {
  content: "・";
}

/* ==========================================================================
   シングルページなどに利用するシンプルなカテゴリリストのモジュール
============================================================================= */
.listSimpleCat__wrap {
  overflow: hidden;
}

.listSimpleCat__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin: -5px;
}

.listSimpleCat__item {
  margin: 5px;
}

@media screen and (max-width: 767px) {
  .listSimpleCat__item {
    font-size: 12px;
  }
}

.listSimpleCat__item > * {
  background: #ccc;
  color: #666;
  display: block;
  font-size: 14px;
  line-height: 1.5em;
  padding: 0 20px;
  text-decoration: none;
}

/* ==========================================================================
  大きなカテゴリ一覧のモジュール
　※アーカイブページなど、大きく使用する装飾されたカテゴリリスト
============================================================================= */
.listCategory__wrap {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  overflow: hidden;
}

.listCategory {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  position: relative;
  margin: 0 -25px;
}

.listCategory .cat-item {
  padding: 10px;
  margin-left: 15px;
  margin-right: 15px;
}

.listCategory a {
  font-weight: 700;
  color: #999999;
}

/* ==========================================================================
  ブログ記事一覧のサムネイル表示用モジュール
============================================================================= */
.listBlog__listWrap {
  overflow: hidden;
}

@media screen and (min-width: 768px) {
  .listBlog__listWrap {
    overflow: hidden;
  }
}

@media screen and (min-width: 768px) {
  .listBlog__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    position: relative;
    margin: -20px;
  }
}

@media screen and (min-width: 768px) {
  .listBlog__item {
    width: 33.33333333333%;
    padding: 20px;
  }
}

.listBlog__cat {
  position: absolute;
  top: 0;
  right: 0;
  background: #ffffff;
  font-size: 12px;
  padding: 0 15px;
  line-height: 28px;
  z-index: 1;
}

.listBlog__link {
  display: block;
  position: relative;
  text-decoration: none;
  font-weight: 500;
  letter-spacing: 0.1em;
  border: 1px solid #eeeeee;
}

@media (hover: hover) and (pointer: fine) {
  .listBlog__link:hover .listBlog__thumb {
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
  }
}

.listBlog__thumbWrap {
  position: relative;
  overflow: hidden;
  aspect-ratio: 331 / 227;
}

.listBlog__thumb {
  -webkit-transition: .4s;
  transition: .4s;
}

.listBlog__txtWrap {
  padding: 15px;
}

.listBlog__date {
  color: #666666;
  font-size: 12px;
}

.listBlog__ttl {
  line-height: 1.7em;
  margin: 1px 0 10px;
}

.listBlog__txt {
  font-weight: normal;
  font-size: 0.9em;
}

.listBlog__btn {
  text-align: center;
  line-height: 48px;
  border-top: 1px solid #eeeeee;
  color: #F7930E;
  font-size: 14px;
  font-family: "LINESeedJP", "Noto Sans JP", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  font-weight: 500;
  position: relative;
}

@media screen and (max-width: 767px) {
  .listBlog__item + .listBlog__item {
    margin-top: 25px;
  }
}

/* ==========================================================================
   ニュース一覧のモジュール
============================================================================= */
.listNews a {
  text-decoration: none;
}

.listNews .listSimpleCat__list {
  margin-bottom: 10px;
}

.listNews__inner {
  display: table;
  width: 100%;
  border-bottom: 1px solid #cccccc;
  padding: 20px 0;
}

.listNews__date {
  display: table-cell;
  vertical-align: top;
  width: 7em;
  font-size: 14px;
  color: #F7930E;
}

@media screen and (max-width: 767px) {
  .listNews__date {
    font-size: 10px;
    line-height: 26px;
  }
}

.listNews__info {
  display: table-cell;
  width: auto;
}

.listNews__title {
  line-height: 1.4em;
  display: block;
}

/* ==========================================================================
  ページ送りのモジュール
============================================================================= */
/* ==============================
// アーカイブページのページ送り
================================= */
.pagerArchive {
  text-align: center;
  margin: 60px 0 0;
}

.pagerArchive .wp-pagenavi span, .pagerArchive .wp-pagenavi a {
  display: inline-block;
  line-height: 40px;
  text-align: center;
  padding: 0 14px;
}

@media (hover: hover) and (pointer: fine) {
  .pagerArchive .wp-pagenavi span:hover, .pagerArchive .wp-pagenavi a:hover {
    border-color: #F7930E;
    color: #F7930E;
  }
}

.pagerArchive .wp-pagenavi span.current {
  background: #F7930E;
  color: #ffffff;
  border-color: #F7930E;
}

/* ==============================
// 記事詳細のページ送り
================================= */
.pagerSingle {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin: 0 -10px;
}

.pagerSingle__wrap {
  overflow: visible;
}

.pagerSingle__item {
  max-width: 10em;
  width: 100%;
  margin: 0 10px;
}

.pagerSingle__item a {
  text-decoration: none;
  display: inline-block;
  color: #F7930E;
}

.pagerSingle__item a::before,
.pagerSingle__item a::after {
  font-family: 'icomoon';
  position: static;
  display: inline-block;
  -webkit-transition: .2s;
  transition: .2s;
}

.pagerSingle__prev {
  text-align: right;
}

.pagerSingle__prev a::after {
  margin-left: 10px;
  content: "\e907";
}

@media (hover: hover) and (pointer: fine) {
  .pagerSingle__prev a:hover::after {
    -webkit-transform: translateX(0.5em);
    transform: translateX(0.5em);
  }
}

.pagerSingle__list {
  text-align: center;
}

.pagerSingle__next {
  text-align: left;
}

.pagerSingle__next a::before {
  margin-right: 10px;
  content: "\e906";
}

@media (hover: hover) and (pointer: fine) {
  .pagerSingle__next a:hover::before {
    -webkit-transform: translateX(-0.5em);
    transform: translateX(-0.5em);
  }
}

/* ==========================================================================
   サイト内の各所に使うちょっとした共通設定
============================================================================= */
.t-ofi {
  height: 100%;
}

.t-ofi img {
  max-width: 100%;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

.t-tCenter {
  text-align: center;
}

.t-tRight {
  text-align: right;
}

.t-tLeft {
  text-align: left;
}

.t-nowL, .t-nowC, .t-nowR {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.t-nowC {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.t-nowR {
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
}

.t-now {
  white-space: nowrap;
}

.t-wbr {
  word-break: keep-all;
  overflow-wrap: break-word;
}

.t-pb0 {
  padding-bottom: 0 !important;
}

.t-pt0 {
  padding-top: 0 !important;
}

@media screen and (min-width: 768px) {
  .t-hidePC {
    display: none;
  }
}

@media screen and (max-width: 767px) {
  .t-hideSP {
    display: none;
  }
}

.t-pc {
  display: block !important;
}

@media screen and (max-width: 767px) {
  .t-pc {
    display: none !important;
  }
}

.t-sp {
  display: none !important;
}

@media screen and (max-width: 767px) {
  .t-sp {
    display: block !important;
  }
}

.t-pcFlex {
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
}

@media screen and (max-width: 767px) {
  .t-pcFlex {
    display: none !important;
  }
}

.t-spFlex {
  display: none !important;
}

@media screen and (max-width: 767px) {
  .t-spFlex {
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
  }
}

.t-hidden {
  position: absolute;
  white-space: nowrap;
  width: 1px;
  height: 1px;
  overflow: hidden;
  border: 0;
  padding: 0;
  clip: rect(0, 0, 0, 0);
  clip-path: inset(50%);
}

.t-color__key01 {
  color: #F7930E;
}

.t-color__key04 {
  color: #FFD800;
}

.t-color__color-bg {
  color: #fff;
}

.t-bk__color-bg {
  background-color: #fff;
}

.t-bk__color-bg2 {
  background-color: #F1F1F1;
}

.t-link__black {
  background-color: #222 !important;
  -webkit-box-shadow: 0px 8px 20px rgba(0, 0, 0, 0.5) !important;
  box-shadow: 0px 8px 20px rgba(0, 0, 0, 0.5) !important;
  border: 1px solid #636363;
}

.l-ctaLink__black:hover {
  background-color: #222 !important;
  -webkit-box-shadow: 0px 8px 20px rgba(0, 0, 0, 0) !important;
  box-shadow: 0px 8px 20px rgba(0, 0, 0, 0) !important;
}

/* ==========================================================================
   headerのモジュール
============================================================================= */
.header {
  z-index: 1000;
  top: 0;
  left: 0;
  position: absolute;
  width: 100%;
  height: clamp(120px, 66.66667px + 6.94444vw, 200px);
}

@media screen and (max-width: 1299px) {
  .header {
    height: 100px;
  }
}

.header .l-container {
  height: 100%;
  width: 100%;
  max-width: calc(100% - (clamp(15px, 5px + 1.30208vw, 30px)*2));
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
  z-index: 1;
}

/* ==============================
// ロゴ
================================= */
.header__logo {
  display: block;
}

.header__logo:hover {
  opacity: 1;
}

.header__logo svg {
  display: block;
  width: clamp(200px, 120px + 10.41667vw, 320px);
  height: auto;
}

@media screen and (max-width: 1299px) {
  .header__logo svg {
    max-width: 240px;
  }
}

@media screen and (max-width: 767px) {
  .header__logo svg {
    width: 100%;
    max-width: 260px;
  }
}

.header__logo svg path {
  -webkit-transition: .3s;
  transition: .3s;
}

/* ==============================
// headerRight
================================= */
.headerRight {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: clamp(16px, 6.66667px + 1.21528vw, 30px);
}

/* ==============================
// nav
================================= */
.header__nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: clamp(16px, 0px + 2.08333vw, 40px);
}

@media screen and (max-width: 1299px) {
  .header__nav {
    display: none;
  }
}

.header__navList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: clamp(8px, -2.66667px + 1.38889vw, 24px);
}

.header__navLink {
  text-decoration: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: clamp(4px, 1.33333px + 0.34722vw, 8px);
  line-height: 1;
  position: relative;
  white-space: nowrap;
}

.header__navLink::before {
  content: "";
  position: absolute;
  bottom: -10px;
  left: 0;
  height: 2px;
  width: 0%;
  background-color: #F7930E;
  -webkit-transition: .3s;
  transition: .3s;
}

.header__navLink:hover {
  opacity: 1;
}

.header__navLink:hover .header__navText {
  color: #F7930E;
}

.header__navLink:hover::before {
  width: 100%;
}

.header__navIcon {
  width: 100%;
  max-width: clamp(19px, 11.66667px + 0.95486vw, 30px);
}

.header__navText {
  font-size: clamp(14px, 8.66667px + 0.69444vw, 22px);
  color: #fff;
  -webkit-transition: .3s;
  transition: .3s;
}

/* ==============================
// その他のボタン
================================= */
.header__infoWrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: clamp(12px, 4px + 1.04167vw, 24px);
}

.header__infoItem {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  position: relative;
}

.header__infoSub {
  position: absolute;
  background-color: #fff;
  color: #222;
  line-height: 1;
  padding: 8px clamp(6px, 2px + 0.52083vw, 12px) 7px;
  border-radius: 2px;
  top: calc(-1 * clamp(32px, 26.66667px + 0.69444vw, 40px));
  white-space: nowrap;
}

.header__infoSubtext {
  font-size: clamp(6px, 2px + 0.52083vw, 12px);
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.header__infoSubtext::before {
  content: "";
  position: absolute;
  width: 20px;
  aspect-ratio: 1/1;
  border-radius: 3px;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  background-color: #fff;
  bottom: -12px;
  z-index: -1;
}

.header__infoLink {
  line-height: 1;
}

.header__contact .header__infoLink {
  min-height: clamp(48px, 42.66667px + 0.69444vw, 56px);
  min-width: clamp(140px, 86.66667px + 6.94444vw, 220px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: clamp(4px, 1.33333px + 0.34722vw, 8px);
  padding: 0 clamp(12px, -6.66667px + 2.43056vw, 40px);
  background-color: #0F2186;
  color: #fff;
  -webkit-box-shadow: 0px 8px 20px rgba(15, 33, 134, 0.5);
  box-shadow: 0px 8px 20px rgba(15, 33, 134, 0.5);
  border-radius: 100vh;
  white-space: nowrap;
}

.header__contact .header__infoLink:hover {
  -webkit-box-shadow: 0px 0px 0px rgba(15, 33, 134, 0.5);
  box-shadow: 0px 0px 0px rgba(15, 33, 134, 0.5);
  opacity: 1;
}

.header__infoIcon {
  width: 100%;
  max-width: clamp(19px, 11.66667px + 0.95486vw, 30px);
}

.header__infoText {
  font-size: clamp(12px, 5.33333px + 0.86806vw, 22px);
}

/* ==============================
// 上部固定メニュー
================================= */
.is-headerOrg .header__navLink::before {
  background-color: #222;
}

.is-headerOrg .header__navLink:hover .header__navText {
  color: #222;
}

.is-headerClone {
  -webkit-transition: opacity .25s ease, visibility .25s ease, -webkit-transform .25s ease;
  transition: opacity .25s ease, visibility .25s ease, -webkit-transform .25s ease;
  transition: opacity .25s ease, transform .25s ease, visibility .25s ease;
  transition: opacity .25s ease, transform .25s ease, visibility .25s ease, -webkit-transform .25s ease;
  will-change: opacity, transform;
  position: fixed;
  backdrop-filter: blur(5px) brightness(1);
  -webkit-backdrop-filter: blur(5px) brightness(1);
}

.is-headerClone::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 0;
  background: -webkit-gradient(linear, left bottom, left top, from(rgba(0, 0, 0, 0)), to(rgba(0, 0, 0, 0.1)));
  background: linear-gradient(0deg, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.1));
}

.is-headerClone .header__logo .header__logo-mark path {
  fill: #F7930E;
}

.is-headerClone .header__navText {
  color: #222;
}

.is-footer-full .header__logo .header__logo-title path {
  fill: #fff;
}

.is-footer-full .header__navText {
  color: #fff;
}

.header {
  -webkit-transition: opacity .3s ease;
  transition: opacity .3s ease;
}

/* 表示 */
.header.is-show {
  opacity: 1;
  pointer-events: auto;
}

/* 非表示（透過） */
.header.is-hide {
  opacity: 0;
  pointer-events: none;
}

/* ==============================
// 管理バーの干渉を調整
================================= */
@media screen and (max-width: 600px) {
  #wpadminbar {
    position: fixed !important;
  }
}

/* ==========================================================================
  footerのモジュール
============================================================================= */
.l-safeArea {
  position: relative;
  z-index: 5;
}

.footer {
  background: #222;
}

.footer .l-container {
  padding-bottom: 120px;
  max-width: 100%;
  position: relative;
  z-index: 2;
}

@media screen and (max-width: 1099px) {
  .footer .l-container {
    display: block;
  }
}

/* ==============================
// 上側
================================= */
.footer__top {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  gap: 160px;
  border-bottom: 1px solid #636363;
  margin-bottom: clamp(44px, 26.66667px + 2.25694vw, 70px);
  padding-bottom: clamp(44px, 26.66667px + 2.25694vw, 70px);
}

@media screen and (max-width: 1099px) {
  .footer__top {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
    gap: 30px;
    margin-bottom: 30px;
    padding-bottom: 30px;
  }
}

.footer__top div {
  height: auto;
}

.footer__top .footer__top-left {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  width: clamp(120px, -13.33333px + 17.36111vw, 320px);
  gap: 16px;
}

@media screen and (max-width: 1099px) {
  .footer__top .footer__top-left {
    width: 100%;
  }
}

.footer__top .footer__logo {
  width: clamp(120px, -13.33333px + 17.36111vw, 320px);
}

@media screen and (max-width: 1099px) {
  .footer__top .footer__logo {
    width: 260px;
  }
}

.footer__top .footer__address {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: clamp(2px, -0.66667px + 0.34722vw, 6px);
}

@media screen and (max-width: 1099px) {
  .footer__top .footer__address br {
    display: none;
  }
}

.footer__top .footer__address p {
  line-height: normal;
}

.footer__top .footer__address-title {
  color: #fff;
  font-size: clamp(11px, 6.33333px + 0.60764vw, 18px);
}

@media screen and (max-width: 1099px) {
  .footer__top .footer__address-title {
    font-size: 16px;
    margin-bottom: 4px;
  }
}

.footer__top .footer__address-add {
  color: #ccc;
  font-size: clamp(9px, 5px + 0.52083vw, 15px);
}

@media screen and (max-width: 1099px) {
  .footer__top .footer__address-add {
    font-size: 10px;
  }
}

.footer__top .footer__map {
  color: #ccc;
  font-size: clamp(8px, 5.33333px + 0.34722vw, 12px);
}

@media screen and (max-width: 1099px) {
  .footer__top .footer__map {
    font-size: 10px;
  }
}

.footer__top .footer__map-link {
  color: #F7930E;
  text-decoration: underline;
  font-size: clamp(8px, 5.33333px + 0.34722vw, 12px);
}

.footer__top .footer__top-right {
  width: calc(100% - clamp(120px, -13.33333px + 17.36111vw, 320px) - clamp(32px, -26.66667px + 7.63889vw, 120px));
}

@media screen and (max-width: 1099px) {
  .footer__top .footer__top-right {
    width: 100%;
    border-bottom: 1px solid #636363;
  }
}

.footer__top .footer__nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: end;
  gap: clamp(38px, 23.33333px + 1.90972vw, 60px);
}

@media screen and (max-width: 1099px) {
  .footer__top .footer__nav {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 0;
  }
}

.footer__top .footer__navList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: clamp(32px, 20px + 1.5625vw, 50px);
}

@media screen and (max-width: 1099px) {
  .footer__top .footer__navList {
    gap: 0;
  }
}

.footer__top .footer__navItem {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: clamp(8px, 2.66667px + 0.69444vw, 16px);
}

@media screen and (max-width: 1099px) {
  .footer__top .footer__navItem {
    width: 100%;
    gap: 0;
  }
}

.footer__top .footer__navLink {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: clamp(4px, 1.33333px + 0.34722vw, 8px);
  line-height: 1;
  color: #fff;
  position: relative;
}

.footer__top .footer__navLink::before {
  content: "";
  position: absolute;
  bottom: -10px;
  left: 0;
  height: 2px;
  width: 0%;
  background-color: #F7930E;
  -webkit-transition: .3s;
  transition: .3s;
}

@media screen and (max-width: 1099px) {
  .footer__top .footer__navLink::before {
    display: none;
  }
}

.footer__top .footer__navLink:hover {
  opacity: 1;
}

.footer__top .footer__navLink:hover .spMenu__navText {
  color: #F7930E;
}

.footer__top .footer__navLink:hover::before {
  width: 100%;
}

@media screen and (max-width: 1099px) {
  .footer__top .footer__navLink {
    gap: 6px;
    width: 100%;
    padding: 16px 0 15px;
    border-top: 1px solid #636363;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }
}

.footer__top .footer__navIcon {
  width: clamp(19px, 11.66667px + 0.95486vw, 30px);
}

@media screen and (max-width: 767px) {
  .footer__top .footer__navIcon {
    width: 24px;
  }
}

.footer__top .footer__navText {
  font-size: clamp(14px, 7.33333px + 0.86806vw, 24px);
  -webkit-transition: .3s;
  transition: .3s;
}

@media screen and (max-width: 1099px) {
  .footer__top .footer__navText {
    font-size: 24px;
  }
}

.footer__top .footer__subNavList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: clamp(4px, 1.33333px + 0.34722vw, 8px);
}

@media screen and (max-width: 1099px) {
  .footer__top .footer__subNavList {
    gap: 0;
    width: 100%;
  }
}

@media screen and (max-width: 1099px) {
  .footer__top .footer__subNavItem {
    width: 100%;
  }
}

.footer__top .footer__subNavLink {
  color: #ccc;
  padding-left: calc(clamp(19px, 11.66667px + 0.95486vw, 30px) + clamp(4px, 1.33333px + 0.34722vw, 8px));
  position: relative;
}

.footer__top .footer__subNavLink::before {
  content: "";
  position: absolute;
  left: calc(clamp(19px, 11.66667px + 0.95486vw, 30px) + clamp(4px, 1.33333px + 0.34722vw, 8px));
  bottom: 0;
  height: 2px;
  width: calc(100% - clamp(19px, 11.66667px + 0.95486vw, 30px) - clamp(4px, 1.33333px + 0.34722vw, 8px));
  background-color: #ccc;
  z-index: 1;
}

@media screen and (max-width: 1099px) {
  .footer__top .footer__subNavLink::before {
    display: none;
  }
}

.footer__top .footer__subNavLink::after {
  content: "";
  position: absolute;
  left: calc(clamp(19px, 11.66667px + 0.95486vw, 30px) + clamp(4px, 1.33333px + 0.34722vw, 8px));
  bottom: 0;
  height: 2px;
  width: 0;
  background-color: #F7930E;
  z-index: 2;
  -webkit-transition: .3s;
  transition: .3s;
}

@media screen and (max-width: 1099px) {
  .footer__top .footer__subNavLink::after {
    display: none;
  }
}

.footer__top .footer__subNavLink:hover {
  color: #F7930E;
}

.footer__top .footer__subNavLink:hover::after {
  width: calc(100% - clamp(19px, 11.66667px + 0.95486vw, 30px) - clamp(4px, 1.33333px + 0.34722vw, 8px));
}

@media screen and (max-width: 1099px) {
  .footer__top .footer__subNavLink {
    width: 100%;
    display: block;
    padding-left: calc(24px + clamp(4px, 1.33333px + 0.34722vw, 8px));
    border-top: 1px solid #636363;
    padding-top: 8px;
    padding-bottom: 8px;
  }
}

/* ==============================
// 下側
================================= */
.footer__bottom {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.footer__subLink {
  color: #ccc;
  font-size: clamp(9px, 5px + 0.52083vw, 15px);
}

.footer__subText {
  color: #636363;
  font-size: clamp(9px, 5px + 0.52083vw, 15px);
}

.footer__subCopy {
  color: #ccc;
  font-size: clamp(9px, 5px + 0.52083vw, 15px);
}

.footer__copy {
  position: absolute;
  bottom: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100vw;
  z-index: 0;
}

@media screen and (max-width: 1099px) {
  .footer__copy {
    bottom: calc(80px + 8px);
  }
}

@media screen and (max-width: 767px) {
  .footer__copy {
    bottom: calc(80px + 8px);
  }
}

.footer__copy-img {
  min-width: 300vw;
  opacity: .2;
}

@media screen and (max-width: 1099px) {
  .footer__copy-img {
    min-width: 500vw;
  }
}

@media screen and (max-width: 767px) {
  .footer__copy-img {
    min-width: 700vw;
  }
}

.footer__copy-img:first-child {
  -webkit-animation: loop 100s -50s linear infinite;
  animation: loop 100s -50s linear infinite;
}

.footer__copy-img:last-child {
  -webkit-animation: loop2 100s linear infinite;
  animation: loop2 100s linear infinite;
}

@-webkit-keyframes loop {
  0% {
    -webkit-transform: translateX(100%);
    transform: translateX(100%);
  }
  to {
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%);
  }
}

@keyframes loop {
  0% {
    -webkit-transform: translateX(100%);
    transform: translateX(100%);
  }
  to {
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%);
  }
}

@-webkit-keyframes loop2 {
  0% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-200%);
    transform: translateX(-200%);
  }
}

@keyframes loop2 {
  0% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-200%);
    transform: translateX(-200%);
  }
}

/* ==========================================================================
	パン屑のモジュール
============================================================================= */
.breadcrumbs {
  font-size: 13px;
  padding-top: 5px;
  padding-bottom: 5px;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.breadcrumbs .l-container {
  overflow: hidden;
  text-overflow: ellipsis;
}

.breadcrumbs a {
  position: relative;
  margin-right: 30px;
  text-decoration: none;
}

@media (hover: hover) and (pointer: fine) {
  .breadcrumbs a:hover {
    text-decoration: underline;
  }
}

.breadcrumbs a::after {
  position: absolute;
  top: 50%;
  right: -16px;
  display: block;
  content: '';
  width: 8px;
  height: 8px;
  margin-top: -5px;
  border-top: 1px solid #999;
  border-right: 1px solid #999;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

@media screen and (max-width: 767px) {
  .breadcrumbs {
    padding: 5px 0;
    font-size: 10px;
  }
  .breadcrumbs span {
    line-height: 1.7em;
  }
}

@media screen and (min-width: 768px) and (max-width: 1099px) {
  .breadcrumbs {
    padding: 5px 0;
  }
}

/* ==========================================================================
   hamburgerのモジュール
============================================================================= */
.hamburger {
  position: relative;
  width: 100px;
  height: auto;
  aspect-ratio: 1/1;
  border-radius: 100vh;
  background-color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: clamp(6px, 3.33333px + 0.34722vw, 10px);
  -webkit-box-shadow: 0px 8px 20px rgba(0, 0, 0, 0.5);
  box-shadow: 0px 8px 20px rgba(0, 0, 0, 0.5);
  -webkit-transition: .3s;
  transition: .3s;
}

@media screen and (max-width: 1299px) {
  .hamburger {
    width: 64px;
  }
}

.hamburger:hover {
  -webkit-box-shadow: 0px 0px 0px rgba(0, 0, 0, 0.5);
  box-shadow: 0px 0px 0px rgba(0, 0, 0, 0.5);
}

.hamburger:hover .hamburgerArea span {
  background-color: #F7930E;
}

.hamburger:hover .hamburger__text span {
  color: #F7930E;
}

.hamburger .hamburgerArea {
  width: clamp(24px, 6.66667px + 2.25694vw, 50px);
  height: clamp(16px, 10px + 0.78125vw, 25px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  position: relative;
}

.hamburger .hamburger__text {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-bottom: -3px;
}

.hamburger .hamburger__text span {
  font-size: clamp(10px, 6px + 0.52083vw, 16px);
  font-weight: 600;
  line-height: 1;
  -webkit-transition: .3s;
  transition: .3s;
  color: #222;
}

.hamburger .hamburger__text-clouse {
  position: absolute;
  opacity: 0;
}

.hamburger .hamburgerArea span {
  position: absolute;
  -webkit-transition: .3s;
  transition: .3s;
  width: 100%;
  height: 2px;
  background-color: #222;
  border-radius: 4px;
}

.hamburger .hamburgerArea span:nth-of-type(1) {
  top: 0;
}

.hamburger .hamburgerArea span:nth-of-type(2) {
  top: 50%;
  margin-top: -1px;
}

.hamburger .hamburgerArea span:nth-of-type(3) {
  bottom: 0;
}

.is-spMenuActive .hamburger .hamburgerArea span:nth-of-type(1) {
  -webkit-transform: translateY(11.5px) rotate(-30deg);
  transform: translateY(11.5px) rotate(-30deg);
}

@media screen and (max-width: 1299px) {
  .is-spMenuActive .hamburger .hamburgerArea span:nth-of-type(1) {
    -webkit-transform: translateY(7px) rotate(-35deg);
    transform: translateY(7px) rotate(-35deg);
  }
}

.is-spMenuActive .hamburger .hamburgerArea span:nth-of-type(2) {
  opacity: 0;
}

.is-spMenuActive .hamburger .hamburgerArea span:nth-of-type(3) {
  -webkit-transform: translateY(-11.5px) rotate(30deg);
  transform: translateY(-11.5px) rotate(30deg);
}

@media screen and (max-width: 1299px) {
  .is-spMenuActive .hamburger .hamburgerArea span:nth-of-type(3) {
    -webkit-transform: translateY(-7px) rotate(35deg);
    transform: translateY(-7px) rotate(35deg);
  }
}

/* ==========================================================================
   gototopのモジュール
============================================================================= */
.gototop {
  position: fixed;
  z-index: 1000;
  right: 40px;
  bottom: 40px;
  background: #ccc;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  text-align: center;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  font-size: 0.8em;
  display: none;
}

/* ==========================================================================
   下層ページのHeroモジュール
============================================================================= */
.pageHero {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  background: #F7930E;
  position: relative;
  height: clamp(240px, 80px + 20.83333vw, 480px);
  width: 100%;
  overflow: hidden;
  padding-top: clamp(64px, 40px + 3.125vw, 100px);
}

.pageHero::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url(../../assets/images/cmn/dot__bk.webp);
  z-index: 1;
}

@media screen and (max-width: 767px) {
  .pageHero {
    max-height: none;
  }
}

.pageHero .l-container {
  position: relative;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
}

.pageHero .pageHero__ttl-en {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  gap: clamp(4px, 1.33333px + 0.34722vw, 8px);
  margin-bottom: clamp(8px, 2.66667px + 0.69444vw, 16px);
}

.pageHero .pageHero__icon {
  width: clamp(24px, 18.66667px + 0.69444vw, 32px);
}

.pageHero .pageHero__ttl-enText {
  font-size: clamp(16px, 10.66667px + 0.69444vw, 24px);
  color: #fff;
  line-height: normal;
}

.pageHero .pageHero__ttl-jp {
  font-size: clamp(32px, 16px + 2.08333vw, 56px);
  line-height: 1.2;
}

/* ==========================================================================
   CTAのモジュール
============================================================================= */
.cta {
  background: #e9e9e9;
  text-align: center;
  font-size: 30px;
  padding: 40px;
}

/* ==========================================================================
   スマホのフッタ固定メニューのモジュール
============================================================================= */
.spHomeBar {
  display: none;
  position: fixed;
  width: 100%;
  bottom: 0;
  left: 0;
  z-index: 1000;
}

@media screen and (min-width: 1100px) {
  .spHomeBar {
    display: none !important;
  }
}

.spHomeBar__navList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  padding: 3px;
  height: 80px;
}

.spHomeBar__navItem {
  width: 50%;
  text-align: center;
  margin: 3px;
}

.spHomeBar__navItem:last-child .spHomeBar__navLink {
  position: relative;
  overflow: hidden;
}

.spHomeBar__navItem:last-child .spHomeBar__navLink::before {
  position: absolute;
  content: '';
  display: inline-block;
  top: -180px;
  left: 0;
  width: 30px;
  height: 100%;
  background-color: #fff;
  -webkit-animation: kiran 3s ease-in-out infinite;
  animation: kiran 3s ease-in-out infinite;
}

@keyframes kiran {
  0% {
    -webkit-transform: scale(0) rotate(45deg);
    transform: scale(0) rotate(45deg);
    opacity: 0;
  }
  80% {
    -webkit-transform: scale(0) rotate(45deg);
    transform: scale(0) rotate(45deg);
    opacity: 0.4;
  }
  81% {
    -webkit-transform: scale(4) rotate(45deg);
    transform: scale(4) rotate(45deg);
    opacity: 0.6;
  }
  100% {
    -webkit-transform: scale(50) rotate(45deg);
    transform: scale(50) rotate(45deg);
    opacity: 0;
  }
}

.spHomeBar__navLink {
  text-decoration: none;
  background-color: #0F2186;
  -webkit-box-shadow: 0px 8px 20px rgba(15, 33, 134, 0.5);
  box-shadow: 0px 8px 20px rgba(15, 33, 134, 0.5);
  padding: 5px;
  height: 100%;
  border-radius: 100vh;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-transition: .3s;
  transition: .3s;
}

.spHomeBar__navLink p,
.spHomeBar__navLink img {
  position: relative;
  z-index: 1;
}

.spHomeBar__navLink p {
  color: #fff;
  font-size: clamp(16px, 6.66667px + 1.21528vw, 30px);
  line-height: 1em;
  -webkit-font-feature-settings: "palt";
  font-feature-settings: "palt";
}

.spHomeBar__navLink img {
  width: 100%;
  max-width: clamp(24px, 13.33333px + 1.38889vw, 40px);
  margin-right: clamp(2px, -2px + 0.52083vw, 8px);
}

@media (hover: hover) and (pointer: fine) {
  .spHomeBar__navLink:hover {
    text-decoration: none;
  }
}

.spHomeBar.is-active .spHomeBar__navLink {
  background-color: #F7930E;
}

/* ==========================================================================
   スマホのハンバーガーボタン押下メニューのモジュール
============================================================================= */
.spMenu {
  position: fixed;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  z-index: 10000;
  top: 0;
  left: 0;
  width: 100%;
  background-color: black;
  backdrop-filter: blur(8px) brightness(0.8);
  -webkit-backdrop-filter: blur(8px) brightness(0.8);
  display: none;
  height: 100vh;
  height: 100svh;
  height: 100dvh;
  overflow-x: hidden;
}

.spMenu .header__logo {
  display: block;
}

.spMenu .header__logo:hover {
  opacity: 1;
}

.spMenu .header__logo img {
  display: block;
  width: clamp(200px, 120px + 10.41667vw, 320px);
  height: auto;
}

@media screen and (max-width: 1299px) {
  .spMenu .header__logo img {
    max-width: 240px;
  }
}

@media screen and (max-width: 767px) {
  .spMenu .header__logo img {
    width: 100%;
    max-width: 260px;
  }
}

.spMenuArea {
  width: 100%;
  min-height: 100vh;
  min-height: 100svh;
  min-height: 100dvh;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.spMenuArea a {
  text-decoration: none;
}

.spMenuArea .l-container {
  padding-top: 8vh;
  padding-bottom: 40px;
  max-width: 100%;
  position: relative;
  z-index: 2;
}

@media screen and (max-width: 1299px) {
  .spMenuArea .l-container {
    padding-top: calc(100px + 8px);
  }
}

.spMenu__header {
  height: clamp(120px, 66.66667px + 6.94444vw, 200px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  position: absolute;
  width: 100%;
  z-index: 10;
}

@media screen and (max-width: 1299px) {
  .spMenu__header {
    height: 100px;
  }
}

.spMenu__header .l-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  width: 100%;
  max-width: calc(100% - (clamp(15px, 5px + 1.30208vw, 30px)*2));
  padding-top: 0;
  padding-bottom: 0;
}

.spMenu__header .header__logo svg {
  display: none;
}

@media screen and (max-width: 1099px) {
  .spMenu__header .header__logo svg {
    display: block;
  }
}

.is-spMenuActive {
  overflow: hidden;
  width: 100vw;
}

.is-spMenuActive .hamburger {
  border: 2px solid #fff;
  background-color: transparent;
}

.is-spMenuActive .hamburger:hover {
  border: 2px solid #F7930E;
}

.is-spMenuActive .hamburgerArea span {
  background-color: #fff;
}

.is-spMenuActive .hamburger__text span {
  color: #fff;
}

.is-spMenuActive .hamburger .hamburger__text-menu {
  opacity: 0;
}

.is-spMenuActive .hamburger .hamburger__text-clouse {
  opacity: 1;
}

/* ==============================
// 上側
================================= */
.spMenu__top {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  gap: 160px;
  border-bottom: 1px solid #636363;
  margin-bottom: clamp(44px, 26.66667px + 2.25694vw, 70px);
  padding-bottom: clamp(44px, 26.66667px + 2.25694vw, 70px);
}

@media screen and (max-width: 1099px) {
  .spMenu__top {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
    gap: 30px;
    margin-bottom: 30px;
    padding-bottom: 30px;
  }
}

.spMenu__top div {
  height: auto;
}

.spMenu__top .spMenu__top-left {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  width: clamp(120px, -66.66667px + 24.30556vw, 400px);
  gap: 16px;
}

@media screen and (max-width: 1099px) {
  .spMenu__top .spMenu__top-left {
    width: 100%;
  }
}

.spMenu__top .spMenu__logo {
  width: clamp(120px, -66.66667px + 24.30556vw, 400px);
}

@media screen and (max-width: 1099px) {
  .spMenu__top .spMenu__logo {
    width: 260px;
  }
}

.spMenu__top .spMenu__address {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: clamp(2px, -0.66667px + 0.34722vw, 6px);
}

@media screen and (max-width: 1099px) {
  .spMenu__top .spMenu__address br {
    display: none;
  }
}

.spMenu__top .spMenu__address p {
  line-height: normal;
}

.spMenu__top .spMenu__address-title {
  color: #fff;
  font-size: clamp(11px, 6.33333px + 0.60764vw, 18px);
}

@media screen and (max-width: 1099px) {
  .spMenu__top .spMenu__address-title {
    font-size: 16px;
    margin-bottom: 4px;
  }
}

.spMenu__top .spMenu__address-add {
  color: #ccc;
  font-size: clamp(9px, 5px + 0.52083vw, 15px);
}

@media screen and (max-width: 1099px) {
  .spMenu__top .spMenu__address-add {
    font-size: 10px;
  }
}

.spMenu__top .spMenu__map {
  color: #ccc;
  font-size: clamp(8px, 5.33333px + 0.34722vw, 12px);
}

@media screen and (max-width: 1099px) {
  .spMenu__top .spMenu__map {
    font-size: 10px;
  }
}

.spMenu__top .spMenu__map-link {
  color: #F7930E;
  text-decoration: underline;
  font-size: clamp(8px, 5.33333px + 0.34722vw, 12px);
}

.spMenu__top .spMenu__top-right {
  width: calc(100% - clamp(120px, -66.66667px + 24.30556vw, 400px) - clamp(32px, -26.66667px + 7.63889vw, 120px));
}

@media screen and (max-width: 1099px) {
  .spMenu__top .spMenu__top-right {
    width: 100%;
    border-bottom: 1px solid #636363;
  }
}

.spMenu__top .spMenu__nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: end;
  gap: clamp(38px, 23.33333px + 1.90972vw, 60px);
}

@media screen and (max-width: 1099px) {
  .spMenu__top .spMenu__nav {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 0;
  }
}

.spMenu__top .spMenu__navList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: clamp(32px, 20px + 1.5625vw, 50px);
}

@media screen and (max-width: 1099px) {
  .spMenu__top .spMenu__navList {
    gap: 0;
  }
}

.spMenu__top .spMenu__navItem {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: clamp(8px, 2.66667px + 0.69444vw, 16px);
}

@media screen and (max-width: 1099px) {
  .spMenu__top .spMenu__navItem {
    width: 100%;
    gap: 0;
  }
}

.spMenu__top .spMenu__navLink {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: clamp(4px, 1.33333px + 0.34722vw, 8px);
  line-height: 1;
  color: #fff;
  position: relative;
}

.spMenu__top .spMenu__navLink::before {
  content: "";
  position: absolute;
  bottom: -10px;
  left: 0;
  height: 2px;
  width: 0%;
  background-color: #F7930E;
  -webkit-transition: .3s;
  transition: .3s;
}

@media screen and (max-width: 1099px) {
  .spMenu__top .spMenu__navLink::before {
    display: none;
  }
}

.spMenu__top .spMenu__navLink:hover {
  opacity: 1;
}

.spMenu__top .spMenu__navLink:hover .spMenu__navText {
  color: #F7930E;
}

.spMenu__top .spMenu__navLink:hover::before {
  width: 100%;
}

@media screen and (max-width: 1099px) {
  .spMenu__top .spMenu__navLink {
    gap: 6px;
    width: 100%;
    padding: 16px 0 15px;
    border-top: 1px solid #636363;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }
}

.spMenu__top .spMenu__navIcon {
  width: clamp(19px, 11.66667px + 0.95486vw, 30px);
}

@media screen and (max-width: 1099px) {
  .spMenu__top .spMenu__navIcon {
    width: 24px;
  }
}

.spMenu__top .spMenu__navText {
  font-size: clamp(14px, 7.33333px + 0.86806vw, 24px);
  -webkit-transition: .3s;
  transition: .3s;
}

@media screen and (max-width: 1099px) {
  .spMenu__top .spMenu__navText {
    font-size: 24px;
  }
}

.spMenu__top .spMenu__subNavList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: clamp(4px, 1.33333px + 0.34722vw, 8px);
}

@media screen and (max-width: 1099px) {
  .spMenu__top .spMenu__subNavList {
    gap: 0;
    width: 100%;
  }
}

@media screen and (max-width: 1099px) {
  .spMenu__top .spMenu__subNavItem {
    width: 100%;
  }
}

.spMenu__top .spMenu__subNavLink {
  color: #ccc;
  padding-left: calc(clamp(19px, 11.66667px + 0.95486vw, 30px) + clamp(4px, 1.33333px + 0.34722vw, 8px));
  position: relative;
}

.spMenu__top .spMenu__subNavLink::before {
  content: "";
  position: absolute;
  left: calc(clamp(19px, 11.66667px + 0.95486vw, 30px) + clamp(4px, 1.33333px + 0.34722vw, 8px));
  bottom: 0;
  height: 2px;
  width: calc(100% - clamp(19px, 11.66667px + 0.95486vw, 30px) - clamp(4px, 1.33333px + 0.34722vw, 8px));
  background-color: #ccc;
  z-index: 1;
}

@media screen and (max-width: 1099px) {
  .spMenu__top .spMenu__subNavLink::before {
    display: none;
  }
}

.spMenu__top .spMenu__subNavLink::after {
  content: "";
  position: absolute;
  left: calc(clamp(19px, 11.66667px + 0.95486vw, 30px) + clamp(4px, 1.33333px + 0.34722vw, 8px));
  bottom: 0;
  height: 2px;
  width: 0;
  background-color: #F7930E;
  z-index: 2;
  -webkit-transition: .3s;
  transition: .3s;
}

@media screen and (max-width: 1099px) {
  .spMenu__top .spMenu__subNavLink::after {
    display: none;
  }
}

.spMenu__top .spMenu__subNavLink:hover {
  color: #F7930E;
}

.spMenu__top .spMenu__subNavLink:hover::after {
  width: calc(100% - clamp(19px, 11.66667px + 0.95486vw, 30px) - clamp(4px, 1.33333px + 0.34722vw, 8px));
}

@media screen and (max-width: 1099px) {
  .spMenu__top .spMenu__subNavLink {
    width: 100%;
    display: block;
    padding-left: calc(24px + clamp(4px, 1.33333px + 0.34722vw, 8px));
    border-top: 1px solid #636363;
    padding-top: 8px;
    padding-bottom: 8px;
  }
}

/* ==============================
// 下側
================================= */
.spMenu__bottom {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.spMenu__subLink {
  color: #ccc;
  font-size: clamp(9px, 5px + 0.52083vw, 15px);
}

.spMenu__subText {
  color: #636363;
  font-size: clamp(9px, 5px + 0.52083vw, 15px);
}

.spMenu__subCopy {
  color: #ccc;
  font-size: clamp(9px, 5px + 0.52083vw, 15px);
}

.spMenu__copy {
  position: absolute;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100vw;
  z-index: 0;
}

.spMenu__copy-img {
  min-width: 300vw;
  opacity: .2;
}

@media screen and (max-width: 1099px) {
  .spMenu__copy-img {
    min-width: 500vw;
  }
}

@media screen and (max-width: 767px) {
  .spMenu__copy-img {
    min-width: 700vw;
  }
}

.spMenu__copy-img:first-child {
  -webkit-animation: loop 100s -50s linear infinite;
  animation: loop 100s -50s linear infinite;
}

.spMenu__copy-img:last-child {
  -webkit-animation: loop2 100s linear infinite;
  animation: loop2 100s linear infinite;
}

@keyframes loop {
  0% {
    -webkit-transform: translateX(100%);
    transform: translateX(100%);
  }
  to {
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%);
  }
}

@keyframes loop2 {
  0% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-200%);
    transform: translateX(-200%);
  }
}

/* ==========================================================================
   editorのモジュール
   投稿表示系でthe_content()を.editorのクラスで囲っている箇所と
   投稿の編集画面で適用される
============================================================================= */
.editor * {
  color: #222;
}

.editor p {
  margin-bottom: 1.8em;
  line-height: 1.8em;
  word-break: break-all;
}

.editor img {
  max-width: 100%;
}

.editor a:not([class]) {
  color: #F7930E;
  text-decoration: underline;
}

@media (hover: hover) and (pointer: fine) {
  .editor a:hover {
    text-decoration: none;
  }
}

.editor strong {
  font-weight: bold;
}

.editor em {
  font-style: italic;
}

.editor h2, .editor h3, .editor h4, .editor h5 {
  /* 目次プラグインを使う際、アンカーリンク用のspanが挿入されてスタイルが消えてしまうときがある
		　　見出しに自動挿入されたspanで親のスタイルを全て引き継ぐよう修正 */
}

.editor h2 span, .editor h3 span, .editor h4 span, .editor h5 span {
  font-weight: inherit;
  color: inherit;
  line-height: inherit;
  margin-bottom: inherit;
}

.editor h2 {
  font-size: 1.3em;
  line-height: 1.6em;
  font-weight: normal;
  margin: 2em 0 14px;
  border-bottom: 1px dashed #000;
}

.editor h3 {
  font-size: 1.1em;
  line-height: 1.6em;
  margin: 2em 0 14px;
  border-bottom: 1px dashed #999;
}

.editor h4 {
  font-size: 1.1em;
  font-weight: bold;
}

.editor ul {
  margin: 20px;
}

.editor ul li {
  list-style: disc;
  margin-bottom: 5px;
  line-height: 1.5em;
}

.editor ol {
  margin: 20px;
}

.editor ol li {
  list-style-type: decimal;
  margin-bottom: 1em;
  line-height: 1.5em;
}

.editor blockquote {
  background: #f8f8f8;
  padding: 1em 1.5em;
  margin: 2em 0;
  font-size: .9em;
  color: #333333;
}

.editor blockquote p:last-child {
  margin-bottom: 0;
}

.editor iframe {
  max-width: 100%;
}

.editor .wp-caption {
  max-width: 100% !important;
  margin: 0 auto 20px;
}

.editor .wp-caption p {
  word-wrap: break-word;
}

.editor .aligncenter {
  display: block;
  margin: 0 auto;
}

.editor .alignright {
  float: right;
  margin: 20px;
}

.editor .alignright {
  float: right;
  margin: 20px;
}

.editor .alignleft {
  float: left;
  margin: 20px;
}

.editor :first-child {
  margin-top: 0;
}

.editor :last-child {
  margin-bottom: 0;
}

@media screen and (max-width: 767px) {
  .editor h2 {
    font-size: 120%;
  }
  .editor h3 {
    font-size: 110%;
  }
  .editor .alignright {
    float: none;
    margin: 0;
  }
  .editor .alignleft {
    float: none;
    margin: 0;
  }
}

.editor table {
  border: 1px solid #ccc;
  border-left: none;
  border-bottom: none;
}

.editor td, .editor th {
  border-bottom: 1px solid #ccc;
  border-left: 1px solid #ccc;
  padding: 0.2em 0.8em;
}

.editor th {
  background: #F7930E;
  text-align: left;
  border: none;
  color: #fff;
}

.editor th:nth-of-type(odd) {
  background: #FF7600;
}

.editor tr:nth-of-type(even) {
  background: #ccc;
}

.editor tr:nth-of-type(even) th {
  background: #F7930E;
}

.editor tr:nth-of-type(even) th:nth-of-type(even) {
  background: #FF7600;
}

.editor::after {
  content: "";
  display: block;
  clear: both;
}

/* ==========================================================================
   TOPページのレイアウト
============================================================================= */
body.home {
  /* ==============================
		// メインビジュアル
	================================= */
  /* 画像共通（初期は非表示） */
  /* 01は通常配置、02〜04は重ねる（現状維持） */
  /* =========================
		アニメーション付与
	========================= */
  /* 01：下からフェード */
  /* 02：あとからフェード */
  /* 03：ポップアップ（少し先に） */
  /* 04：ポップアップ（03の直後） */
  /* =========================
		keyframes
	========================= */
  /* ==============================
		// 導入実績
	================================= */
  /* ==============================
		// 店舗経営者の課題
	================================= */
  /* ==============================
		// AI検索×MEOの新常識
	================================= */
  /* ==============================
		// 口コミ365の導入メリット
	================================= */
  /* ==============================
		// 口コミ365の特徴
	================================= */
  /* ==============================
		// 機能一覧
	================================= */
  /* ==============================
		// 口コミ365の使い方
	================================= */
  /* ==============================
		// 口コミ365アンバサダー
	================================= */
  /* ==============================
		// 動画で詳しく見る
	================================= */
  /* ==============================
		// Googleマップ無料診断
	================================= */
  /* ==============================
		// 他社からの乗り換え
	================================= */
  /* ==============================
		// よくあるご質問
	================================= */
  /* ==============================
		// お問い合わせ
	================================= */
}

body.home .home__mv {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  background: #F7930E;
  position: relative;
  min-height: 400px;
  max-height: 100vh;
  max-height: 100svh;
  max-height: 100dvh;
  width: 100%;
  overflow: hidden;
}

body.home .home__mv::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url(../../assets/images/cmn/dot__bk.webp);
  z-index: 1;
}

@media screen and (max-width: 767px) {
  body.home .home__mv {
    max-height: none;
  }
}

body.home .home__mv .l-container {
  position: relative;
  z-index: 2;
  padding-top: clamp(80px, 0px + 10.41667vw, 200px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: end;
  height: 100%;
  width: calc(100% - (clamp(30px, 10px + 2.60417vw, 60px)*2));
  max-width: 1750px;
}

body.home .home__mvWrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  height: 100%;
  width: 100%;
  gap: clamp(32px, 16px + 2.08333vw, 56px);
}

@media screen and (max-width: 1099px) {
  body.home .home__mvWrap {
    gap: clamp(16px, 10.66667px + 0.69444vw, 24px);
  }
}

@media screen and (max-width: 767px) {
  body.home .home__mvWrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
    gap: 0;
  }
}

body.home .home__mvLeft {
  opacity: 0;
  position: relative;
  z-index: 2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 48%;
  -webkit-animation: mvFadeUp 0.9s cubic-bezier(0.215, 0.61, 0.355, 1) 0.5s forwards;
  animation: mvFadeUp 0.9s cubic-bezier(0.215, 0.61, 0.355, 1) 0.5s forwards;
  padding-bottom: 8vh;
}

@media screen and (max-width: 1099px) {
  body.home .home__mvLeft {
    width: 45%;
    padding-bottom: 40px;
  }
}

@media screen and (max-width: 767px) {
  body.home .home__mvLeft {
    width: 100%;
    padding-bottom: 40px;
  }
}

body.home .home__mv .l-ctaArea {
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

@media screen and (max-width: 767px) {
  body.home .home__mv .l-ctaArea {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
  }
}

body.home .home__mv .l-ctaLink {
  width: calc((100% - (clamp(8px, -2.66667px + 1.38889vw, 24px)))/2);
  min-width: 0;
}

body.home .home__mv .l-ctaLink:nth-child(3) {
  width: 100%;
}

@media screen and (max-width: 767px) {
  body.home .home__mv .l-ctaLink {
    width: 100%;
  }
}

body.home .home__mvRight {
  width: calc(52% - clamp(32px, 16px + 2.08333vw, 56px));
}

@media screen and (max-width: 1099px) {
  body.home .home__mvRight {
    width: calc(55% - clamp(16px, 10.66667px + 0.69444vw, 24px));
  }
}

@media screen and (max-width: 767px) {
  body.home .home__mvRight {
    width: 100%;
  }
}

body.home .home__mvH1 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: clamp(8px, -2.66667px + 1.38889vw, 24px);
}

body.home .home__mvH1-span {
  background-color: #fff;
  border-radius: 10px;
  -webkit-box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.16);
  box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.16);
  width: 100%;
}

body.home .home__mvH1-img {
  width: 100%;
}

body.home .home__mvP {
  -webkit-filter: drop-shadow(0px 3px 10px rgba(0, 0, 0, 0.16));
  filter: drop-shadow(0px 3px 10px rgba(0, 0, 0, 0.16));
  margin: clamp(16px, 5.33333px + 1.38889vw, 32px) 0;
}

body.home .home__mvList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: clamp(8px, 2.66667px + 0.69444vw, 16px);
}

body.home .home__mvItem {
  width: calc((100% - (clamp(8px, 2.66667px + 0.69444vw, 16px)*4))/5);
  background-color: #fff;
  border-radius: 10px;
  -webkit-box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.16);
  box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.16);
}

@media screen and (max-width: 767px) {
  body.home .home__mvItem {
    width: calc((100% - (clamp(8px, 2.66667px + 0.69444vw, 16px)*2))/3);
  }
}

body.home .home__mvPhoneArea {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  height: 100%;
}

body.home .home__mvPhone {
  width: auto;
  height: 100%;
  opacity: 0;
  will-change: opacity, transform;
}

body.home .home__mvPhone01 {
  position: relative;
  z-index: 0;
}

body.home .home__mvPhone02,
body.home .home__mvPhone03,
body.home .home__mvPhone04 {
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}

body.home .home__mvPhone02 {
  z-index: 1;
}

body.home .home__mvPhone03 {
  z-index: 2;
}

body.home .home__mvPhone04 {
  z-index: 3;
}

body.home .home__mvPhone01 {
  -webkit-animation: mvFadeUp 0.9s cubic-bezier(0.215, 0.61, 0.355, 1) 1.5s forwards;
  animation: mvFadeUp 0.9s cubic-bezier(0.215, 0.61, 0.355, 1) 1.5s forwards;
}

body.home .home__mvPhone02 {
  -webkit-animation: mvFade 0.8s cubic-bezier(0.215, 0.61, 0.355, 1) 2.5s forwards;
  animation: mvFade 0.8s cubic-bezier(0.215, 0.61, 0.355, 1) 2.5s forwards;
}

body.home .home__mvPhone03 {
  -webkit-animation: mvPop 0.8s cubic-bezier(0.215, 0.61, 0.355, 1) 3.5s forwards, mvNoticeJump 3.6s ease-in-out 4.6s infinite;
  animation: mvPop 0.8s cubic-bezier(0.215, 0.61, 0.355, 1) 3.5s forwards, mvNoticeJump 3.6s ease-in-out 4.6s infinite;
}

body.home .home__mvPhone04 {
  -webkit-animation: mvPop 0.8s cubic-bezier(0.215, 0.61, 0.355, 1) 2.5s forwards, mvNoticeZoom 4.2s ease-in-out 5.4s infinite;
  animation: mvPop 0.8s cubic-bezier(0.215, 0.61, 0.355, 1) 2.5s forwards, mvNoticeZoom 4.2s ease-in-out 5.4s infinite;
}

@-webkit-keyframes mvFadeUp {
  0% {
    opacity: 0;
    -webkit-transform: translateY(24px);
    transform: translateY(24px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}

@keyframes mvFadeUp {
  0% {
    opacity: 0;
    -webkit-transform: translateY(24px);
    transform: translateY(24px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}

@-webkit-keyframes mvFade {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes mvFade {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@-webkit-keyframes mvPop {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-50%) scale(0.96);
    transform: translateX(-50%) scale(0.96);
  }
  70% {
    opacity: 1;
    -webkit-transform: translateX(-50%) scale(1.02);
    transform: translateX(-50%) scale(1.02);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(-50%) scale(1);
    transform: translateX(-50%) scale(1);
  }
}

@keyframes mvPop {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-50%) scale(0.96);
    transform: translateX(-50%) scale(0.96);
  }
  70% {
    opacity: 1;
    -webkit-transform: translateX(-50%) scale(1.02);
    transform: translateX(-50%) scale(1.02);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(-50%) scale(1);
    transform: translateX(-50%) scale(1);
  }
}

@-webkit-keyframes mvNoticeJump {
  0% {
    -webkit-transform: translateX(-50%) translateY(0);
    transform: translateX(-50%) translateY(0);
  }
  8% {
    -webkit-transform: translateX(-50%) translateY(-10px);
    transform: translateX(-50%) translateY(-10px);
  }
  16% {
    -webkit-transform: translateX(-50%) translateY(0);
    transform: translateX(-50%) translateY(0);
  }
  24% {
    -webkit-transform: translateX(-50%) translateY(-6px);
    transform: translateX(-50%) translateY(-6px);
  }
  32% {
    -webkit-transform: translateX(-50%) translateY(0);
    transform: translateX(-50%) translateY(0);
  }
  100% {
    -webkit-transform: translateX(-50%) translateY(0);
    transform: translateX(-50%) translateY(0);
  }
}

@keyframes mvNoticeJump {
  0% {
    -webkit-transform: translateX(-50%) translateY(0);
    transform: translateX(-50%) translateY(0);
  }
  8% {
    -webkit-transform: translateX(-50%) translateY(-10px);
    transform: translateX(-50%) translateY(-10px);
  }
  16% {
    -webkit-transform: translateX(-50%) translateY(0);
    transform: translateX(-50%) translateY(0);
  }
  24% {
    -webkit-transform: translateX(-50%) translateY(-6px);
    transform: translateX(-50%) translateY(-6px);
  }
  32% {
    -webkit-transform: translateX(-50%) translateY(0);
    transform: translateX(-50%) translateY(0);
  }
  100% {
    -webkit-transform: translateX(-50%) translateY(0);
    transform: translateX(-50%) translateY(0);
  }
}

@-webkit-keyframes mvNoticeZoom {
  0% {
    -webkit-transform: translateX(-50%) translateY(0);
    transform: translateX(-50%) translateY(0);
  }
  8% {
    -webkit-transform: translateX(-50%) translateY(-10px);
    transform: translateX(-50%) translateY(-10px);
  }
  16% {
    -webkit-transform: translateX(-50%) translateY(0);
    transform: translateX(-50%) translateY(0);
  }
  24% {
    -webkit-transform: translateX(-50%) translateY(-6px);
    transform: translateX(-50%) translateY(-6px);
  }
  32% {
    -webkit-transform: translateX(-50%) translateY(0);
    transform: translateX(-50%) translateY(0);
  }
  100% {
    -webkit-transform: translateX(-50%) translateY(0);
    transform: translateX(-50%) translateY(0);
  }
}

@keyframes mvNoticeZoom {
  0% {
    -webkit-transform: translateX(-50%) translateY(0);
    transform: translateX(-50%) translateY(0);
  }
  8% {
    -webkit-transform: translateX(-50%) translateY(-10px);
    transform: translateX(-50%) translateY(-10px);
  }
  16% {
    -webkit-transform: translateX(-50%) translateY(0);
    transform: translateX(-50%) translateY(0);
  }
  24% {
    -webkit-transform: translateX(-50%) translateY(-6px);
    transform: translateX(-50%) translateY(-6px);
  }
  32% {
    -webkit-transform: translateX(-50%) translateY(0);
    transform: translateX(-50%) translateY(0);
  }
  100% {
    -webkit-transform: translateX(-50%) translateY(0);
    transform: translateX(-50%) translateY(0);
  }
}

body.home .sectionWorks {
  background-color: #F1F1F1;
  padding-top: clamp(40px, 13.33333px + 3.47222vw, 80px);
}

body.home .worksTop {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: clamp(8px, 2.66667px + 0.69444vw, 16px);
  position: relative;
}

@media screen and (max-width: 767px) {
  body.home .worksTop {
    gap: 0px;
  }
}

body.home .worksTop__title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: clamp(16px, 0px + 2.08333vw, 40px);
  padding-top: clamp(48px, 37.33333px + 1.38889vw, 64px);
}

@media screen and (max-width: 767px) {
  body.home .worksTop__title {
    margin-bottom: 16px;
  }
}

body.home .sectionWorks .l-message {
  margin-bottom: clamp(56px, 33.33333px + 2.95139vw, 90px);
}

@media screen and (max-width: 767px) {
  body.home .sectionWorks .l-message {
    margin-bottom: 32px;
  }
}

body.home .worksTop__titleSub-left,
body.home .worksTop__titleSub-right {
  width: clamp(40px, -3.33333px + 5.64236vw, 105px);
}

body.home .worksTop__h2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
  gap: clamp(4px, 1.33333px + 0.34722vw, 8px);
  margin: 0 calc(-1*clamp(16px, 10.66667px + 0.69444vw, 24px));
}

body.home .worksTop__h2Fukidashi {
  position: absolute;
  top: calc(-1*clamp(40px, 24px + 2.08333vw, 64px));
  left: calc(-1*clamp(20px, -9.33333px + 3.81944vw, 64px));
  width: clamp(96px, 60px + 4.6875vw, 150px);
}

@media screen and (max-width: 767px) {
  body.home .worksTop__h2Fukidashi {
    width: 80px;
    left: -45px;
  }
}

body.home .worksTop__h2Sub {
  font-size: clamp(25px, 9.66667px + 1.99653vw, 48px);
  line-height: 1;
}

@media screen and (max-width: 767px) {
  body.home .worksTop__h2Sub {
    font-size: 24px;
  }
}

body.home .worksTop__h2Main {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
  -ms-flex-align: baseline;
  align-items: baseline;
  gap: clamp(4px, 1.33333px + 0.34722vw, 8px);
}

body.home .worksTop__h2Main-number {
  font-size: clamp(64px, 40px + 3.125vw, 100px);
  line-height: 1;
  letter-spacing: -.05em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  position: relative;
}

@media screen and (max-width: 767px) {
  body.home .worksTop__h2Main-number {
    font-size: 48px;
  }
}

body.home .worksTop__h2Main-number span.on {
  position: absolute;
  opacity: 1;
  font-size: clamp(64px, 40px + 3.125vw, 100px);
  line-height: 1;
  letter-spacing: -.05em;
}

@media screen and (max-width: 767px) {
  body.home .worksTop__h2Main-number span.on {
    font-size: 48px;
  }
}

body.home .worksTop__h2Main-number span.off {
  opacity: 0;
}

body.home .sectionWorks .worksTop__h2Main-number.is-counting {
  -webkit-filter: drop-shadow(0 6px 14px rgba(0, 0, 0, 0.12));
  filter: drop-shadow(0 6px 14px rgba(0, 0, 0, 0.12));
}

body.home .worksTop__h2Main-text {
  font-size: clamp(24px, 12px + 1.5625vw, 42px);
  line-height: 1;
}

body.home .worksTop__president {
  width: clamp(240px, 186.66667px + 6.94444vw, 320px);
}

@media screen and (max-width: 767px) {
  body.home .worksTop__president {
    width: 130px;
  }
}

body.home .worksBottom {
  position: relative;
}

body.home .sectionWorks .arrows {
  position: absolute;
  z-index: 2;
  bottom: 50%;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  body.home .sectionWorks .arrows {
    width: 90%;
    margin: 0 5%;
  }
}

body.home .sectionWorks .arrows .slick-arrow {
  aspect-ratio: 1/1;
  width: clamp(40px, 10px + 3.90625vw, 85px);
  height: auto;
  border-radius: 100vh;
  background: #0F2186;
  -webkit-box-shadow: 0px 8px 20px rgba(15, 33, 134, 0.5);
  box-shadow: 0px 8px 20px rgba(15, 33, 134, 0.5);
  opacity: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-transition: .3s;
  transition: .3s;
}

body.home .sectionWorks .arrows .slick-arrow::before {
  content: "";
  position: absolute;
  width: clamp(8px, 2.66667px + 0.69444vw, 16px);
  height: auto;
  aspect-ratio: 1/1;
  border-left: 2px solid #fff;
  border-top: 2px solid #fff;
  opacity: 1;
  -webkit-transition: .3s;
  transition: .3s;
}

body.home .sectionWorks .arrows .slick-arrow:hover, body.home .sectionWorks .arrows .slick-arrow:focus {
  opacity: 1;
  background: #0F2186;
  -webkit-box-shadow: 0px 0px 0px rgba(15, 33, 134, 0.5);
  box-shadow: 0px 0px 0px rgba(15, 33, 134, 0.5);
}

body.home .sectionWorks .arrows .slick-prev::before {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  margin: 0 0 0 5px;
}

body.home .sectionWorks .arrows .slick-next::before {
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg);
  margin: 0 0 0 -5px;
}

body.home .worksSlider {
  margin: 0 calc(50% - 50vw);
  position: relative;
  z-index: 1;
}

body.home .worksSlider .slick-track {
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
}

body.home .worksSlider .slick-slide {
  height: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

body.home .worksSlider .slick-slide > div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
}

body.home .worksSlider__item {
  padding: 0 clamp(9px, 5px + 0.52083vw, 15px);
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: clamp(16px, 6.66667px + 1.21528vw, 30px);
  height: 100%;
}

@media screen and (max-width: 767px) {
  body.home .worksSlider__item {
    padding: 0 7.5px;
  }
}

body.home .worksSlider__img {
  border-radius: 10px;
  overflow: hidden;
  aspect-ratio: 3/2;
  height: auto;
}

body.home .worksSlider__text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

body.home .worksSlider__title {
  margin-bottom: clamp(12px, 6.66667px + 0.69444vw, 20px);
}

body.home .worksSlider__category {
  font-size: clamp(9px, 5px + 0.52083vw, 15px);
  color: #F7930E;
  border: 1px solid #F7930E;
  border-radius: 100vh;
  padding: 2px 12px 1px;
  margin-bottom: clamp(10px, 7.33333px + 0.34722vw, 14px);
  display: inline-block;
  line-height: normal;
}

body.home .worksSlider__maintitle {
  display: block;
  font-size: clamp(18px, 10px + 1.04167vw, 30px);
  line-height: 1.4;
}

body.home .worksSlider__maintitle-small {
  font-size: clamp(12px, 8px + 0.52083vw, 18px);
}

body.home .worksSlider__textList {
  margin-top: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: clamp(2px, 0.66667px + 0.17361vw, 4px);
}

body.home .worksSlider__textItem {
  font-size: clamp(11.2px, 7px + 0.54688vw, 17.5px);
  position: relative;
  padding-left: 1.5em;
}

body.home .worksSlider__textItem::before {
  content: "●";
  font-size: clamp(11.2px, 7px + 0.54688vw, 17.5px);
  color: #F7930E;
  position: absolute;
  left: 0;
}

body.home .sectionAio {
  position: relative;
}

body.home .sectionAio::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 100vw;
  height: 100%;
  background-color: #FFF5E4;
  z-index: 0;
}

body.home .sectionAio .l-container {
  position: relative;
  z-index: 1;
}

body.home .sectionAio__messageArea {
  padding: 0 clamp(24px, -20px + 5.72917vw, 90px) clamp(24px, -20px + 5.72917vw, 90px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: clamp(16px, 0px + 2.08333vw, 40px);
  position: relative;
}

body.home .sectionAio__messageArea::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 80%;
  left: 0;
  bottom: 0;
  border-radius: clamp(10px, -3.33333px + 1.73611vw, 30px);
  background-color: #fff;
  z-index: 0;
}

@media screen and (max-width: 767px) {
  body.home .sectionAio__messageArea::before {
    height: 95%;
  }
}

body.home .sectionAio__pc {
  width: 65%;
  margin: 0 auto;
  display: block;
  position: relative;
  z-index: 1;
}

@media screen and (max-width: 767px) {
  body.home .sectionAio__pc {
    width: 100%;
  }
}

body.home .sectionAio__message {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: clamp(0px, -10.66667px + 1.38889vw, 16px);
  position: relative;
  z-index: 1;
}

body.home .sectionAio__message-p {
  width: 100%;
  text-align: center;
  line-height: 2;
  font-size: clamp(14px, 7.33333px + 0.86806vw, 24px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: baseline;
  -ms-flex-align: baseline;
  align-items: baseline;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

body.home .sectionAio__message-pickup {
  color: #fff;
  position: relative;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  line-height: normal;
}

body.home .sectionAio__message-pickup::before {
  content: "";
  position: absolute;
  background-color: #F7930E;
  height: 100%;
  width: 0%;
  left: 0;
  -webkit-transition: 1s;
  transition: 1s;
}

body.home .sectionAio__message-pickup.is-active::before {
  width: 100%;
  -webkit-transition-delay: 0.2s;
  transition-delay: 0.2s;
}

body.home .sectionAio__message-pickup-span {
  position: relative;
  z-index: 1;
}

body.home .sectionAio__pointList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: clamp(6px, -0.66667px + 0.86806vw, 16px);
  position: relative;
  z-index: 1;
}

body.home .sectionAio__pointItem {
  width: 100%;
  background-color: #F7930E;
  border-radius: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  gap: clamp(8px, 2.66667px + 0.69444vw, 16px);
  min-height: clamp(56px, 34.66667px + 2.77778vw, 88px);
  padding: clamp(8px, 2.66667px + 0.69444vw, 16px) clamp(16px, 2.66667px + 1.73611vw, 36px);
}

@media screen and (max-width: 767px) {
  body.home .sectionAio__pointItem {
    padding: 16px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}

body.home .sectionAio__pointNumber {
  background-color: #fff;
  border-radius: 100vh;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  text-align: center;
  width: clamp(110px, 66.66667px + 5.64236vw, 175px);
  height: clamp(24px, 12px + 1.5625vw, 42px);
  line-height: 1;
  font-size: clamp(16px, 6.66667px + 1.21528vw, 30px);
  font-weight: 900;
  letter-spacing: 0;
}

@media screen and (max-width: 767px) {
  body.home .sectionAio__pointNumber {
    width: 100%;
  }
}

body.home .sectionAio__pointText {
  color: #fff;
  width: calc(100% - clamp(110px, 66.66667px + 5.64236vw, 175px) - clamp(8px, 2.66667px + 0.69444vw, 16px));
  font-size: clamp(15px, 5px + 1.30208vw, 30px);
  line-height: 1.4;
}

@media screen and (max-width: 767px) {
  body.home .sectionAio__pointText {
    width: 100%;
  }
}

body.home .sectionMerit__meritArea {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  gap: clamp(16px, 0px + 2.08333vw, 40px);
  padding: clamp(24px, -20px + 5.72917vw, 90px);
  border-radius: clamp(10px, -3.33333px + 1.73611vw, 30px);
  background-color: #FFF5E4;
}

@media screen and (max-width: 767px) {
  body.home .sectionMerit__meritArea {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
    gap: 40px;
  }
}

body.home .sectionMerit__meritLeft {
  width: calc((100% - clamp(16px, 0px + 2.08333vw, 40px))/2);
  height: auto;
}

@media screen and (max-width: 767px) {
  body.home .sectionMerit__meritLeft {
    width: 100%;
  }
}

body.home .sectionMerit__meritRight {
  width: calc((100% - clamp(16px, 0px + 2.08333vw, 40px))/2);
  height: auto;
}

@media screen and (max-width: 767px) {
  body.home .sectionMerit__meritRight {
    width: 100%;
  }
}

body.home .sectionMerit__meritLeft {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  gap: clamp(32px, 13.33333px + 2.43056vw, 60px);
}

body.home .sectionMerit__meritTop,
body.home .sectionMerit__meritBottom {
  background-color: #fff;
  border: 2px solid #222;
  border-radius: 10px;
  padding: clamp(16px, 0px + 2.08333vw, 40px);
}

body.home .sectionMerit__meritH3 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  background-color: #F7930E;
  border-radius: 100vh;
  min-height: clamp(38px, 23.33333px + 1.90972vw, 60px);
  width: 100%;
  max-width: 400px;
  margin: calc(-1*(clamp(16px, 0px + 2.08333vw, 40px) + (clamp(38px, 23.33333px + 1.90972vw, 60px)/2))) auto 0;
}

body.home .sectionMerit__meritH3-span {
  font-size: clamp(19px, 11.66667px + 0.95486vw, 30px);
  text-align: center;
  color: #fff;
}

body.home .sectionMerit__meritPhoto {
  border-radius: 10px;
  overflow: hidden;
  margin: clamp(16px, 2.66667px + 1.73611vw, 36px) 0;
}

body.home .sectionMerit__meritRight {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

body.home .sectionMerit__meritVideo {
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  border-radius: 10px;
  overflow: hidden;
  background-color: #222;
  -webkit-box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.16);
  box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.16);
}

@media screen and (max-width: 1099px) {
  body.home .sectionMerit__meritVideo {
    width: auto;
    height: clamp(640px, 533.33333px + 13.88889vw, 800px);
  }
}

@media screen and (max-width: 767px) {
  body.home .sectionMerit__meritVideo {
    width: 85%;
    height: auto;
  }
}

body.home .sectionMerit__meritVideo video {
  width: 100%;
}

body.home.is-flow .l-column__side a {
  color: #fff;
}

body.home.is-flow .l-column__side a span::after {
  background-color: #fff;
}

body.home.is-flow .l-column__side a.is-active {
  color: #FFD800;
}

body.home.is-flow .l-column__side a.is-active span::before {
  border: 1px solid #FFD800;
}

body.home.is-flow .l-column__side a.is-active span::after {
  background-color: #FFD800;
}

body.home.is-flow .l-column__side a:hover {
  color: #FFD800 !important;
}

body.home.is-flow .l-column__side a:hover span::before {
  border: 1px solid #FFD800;
}

body.home.is-flow .l-column__side a:hover span::after {
  background-color: #FFD800;
}

body.home.is-flow .header__logo .header__logo-mark path {
  fill: #fff;
}

body.home .sectionFeatures {
  position: relative;
}

body.home .sectionFeatures::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 100vw;
  height: 100%;
  background-color: #F7930E;
  z-index: 0;
  border-radius: clamp(40px, 13.33333px + 3.47222vw, 80px);
}

body.home .sectionFeatures::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 100vw;
  height: 100%;
  background-image: url(../../assets/images/cmn/dot__bk.webp);
  z-index: 1;
}

body.home .sectionFeatures .l-container {
  position: relative;
  z-index: 2;
}

body.home .sectionFeatures__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: clamp(24px, 12px + 1.5625vw, 42px);
}

body.home .sectionFeatures__item {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: clamp(24px, 13.33333px + 1.38889vw, 40px);
  padding: clamp(24px, -20px + 5.72917vw, 90px);
  border-radius: clamp(10px, -3.33333px + 1.73611vw, 30px);
  background-color: #F1F1F1;
}

body.home .sectionFeatures__item-bottom02 {
  border-top: 1px dashed #ccc;
  margin-top: clamp(16px, -6.66667px + 2.95139vw, 50px);
  padding-top: clamp(32px, 0px + 4.16667vw, 80px);
}

body.home .sectionFeatures__video video {
  width: 100%;
  height: auto;
  overflow: hidden;
  border-radius: 10px;
  -webkit-box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.16);
  box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.16);
}

body.home .sectionFeatures__video-tate {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

body.home .sectionFeatures__video-tate video {
  width: auto;
  height: clamp(400px, 240px + 20.83333vw, 640px);
}

@media screen and (max-width: 767px) {
  body.home .sectionFeatures__video-tate video {
    height: auto;
    width: 85%;
  }
}

body.home .sectionFeatures__item07 .l-column02__right,
body.home .sectionFeatures__item09 .l-column02__right {
  gap: clamp(24px, 13.33333px + 1.38889vw, 40px);
}

body.home .sectionFunctions__waku {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: clamp(16px, 0px + 2.08333vw, 40px);
  padding: clamp(24px, -20px + 5.72917vw, 90px);
  border-radius: clamp(10px, -3.33333px + 1.73611vw, 30px);
  background-color: #F1F1F1;
}

body.home .sectionHowtouse {
  position: relative;
}

body.home .sectionHowtouse::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 100vw;
  height: 100%;
  background-color: #F1F1F1;
  z-index: 0;
  border-radius: clamp(40px, 13.33333px + 3.47222vw, 80px) clamp(40px, 13.33333px + 3.47222vw, 80px) 0 0;
}

body.home .sectionHowtouse .l-container {
  position: relative;
  z-index: 2;
}

body.home .sectionAmbassador .l-container {
  position: relative;
}

body.home .sectionAmbassador .arrows2 {
  position: relative;
  z-index: 2;
  width: clamp(100px, 46.66667px + 6.94444vw, 180px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin: clamp(40px, 20px + 2.60417vw, 70px) auto 0;
}

@media screen and (max-width: 1099px) {
  body.home .sectionAmbassador .arrows2 {
    position: absolute;
    z-index: 2;
    bottom: 50%;
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
}

@media screen and (max-width: 767px) {
  body.home .sectionAmbassador .arrows2 {
    width: 90%;
    margin: 0 5%;
  }
}

body.home .sectionAmbassador .arrows2 .slick-arrow {
  aspect-ratio: 1/1;
  width: clamp(40px, 10px + 3.90625vw, 85px);
  height: auto;
  border-radius: 100vh;
  background: #0F2186;
  -webkit-box-shadow: 0px 8px 20px rgba(15, 33, 134, 0.5);
  box-shadow: 0px 8px 20px rgba(15, 33, 134, 0.5);
  opacity: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-transition: .3s;
  transition: .3s;
}

body.home .sectionAmbassador .arrows2 .slick-arrow::before {
  content: "";
  position: absolute;
  width: clamp(8px, 2.66667px + 0.69444vw, 16px);
  height: auto;
  aspect-ratio: 1/1;
  border-left: 2px solid #fff;
  border-top: 2px solid #fff;
  opacity: 1;
  -webkit-transition: .3s;
  transition: .3s;
}

body.home .sectionAmbassador .arrows2 .slick-arrow:hover, body.home .sectionAmbassador .arrows2 .slick-arrow:focus {
  opacity: 1;
  background: #0F2186;
  -webkit-box-shadow: 0px 0px 0px rgba(15, 33, 134, 0.5);
  box-shadow: 0px 0px 0px rgba(15, 33, 134, 0.5);
}

body.home .sectionAmbassador .arrows2 .slick-prev::before {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  margin: 0 0 0 5px;
}

body.home .sectionAmbassador .arrows2 .slick-next::before {
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg);
  margin: 0 0 0 -5px;
}

body.home .ambassadorSlider {
  margin-right: calc(50% - 50vw);
  position: relative;
  z-index: 1;
}

@media screen and (max-width: 1099px) {
  body.home .ambassadorSlider {
    margin: 0 calc(50% - 50vw);
  }
}

body.home .ambassadorSlider .slick-track {
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
}

body.home .ambassadorSlider .slick-slide {
  height: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

body.home .ambassadorSlider .slick-slide > div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
}

body.home .ambassadorSlider__item {
  padding: 0 clamp(9px, 5px + 0.52083vw, 15px);
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: clamp(16px, 6.66667px + 1.21528vw, 30px);
  height: 100%;
}

@media screen and (max-width: 767px) {
  body.home .ambassadorSlider__item {
    padding: 0 7.5px;
  }
}

body.home .ambassadorSlider__img {
  border-radius: 10px;
  overflow: hidden;
  aspect-ratio: 3/2;
  height: auto;
}

body.home .ambassadorSlider__text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

body.home .ambassadorSlider__title {
  margin-bottom: clamp(12px, 6.66667px + 0.69444vw, 20px);
}

body.home .ambassadorSlider__category {
  font-size: clamp(9px, 5px + 0.52083vw, 15px);
  color: #F7930E;
  margin-bottom: clamp(10px, 7.33333px + 0.34722vw, 14px);
  display: inline-block;
  line-height: normal;
}

body.home .ambassadorSlider__maintitle {
  display: block;
  font-size: clamp(18px, 10px + 1.04167vw, 30px);
  line-height: 1.4;
}

body.home .ambassadorSlider__maintitle-small {
  font-size: clamp(12px, 8px + 0.52083vw, 18px);
}

body.home .ambassadorSlider__textList {
  margin-top: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: clamp(2px, 0.66667px + 0.17361vw, 4px);
}

body.home .ambassadorSlider__textItem {
  font-size: clamp(11.2px, 7px + 0.54688vw, 17.5px);
  position: relative;
  padding-left: 1.5em;
}

body.home .ambassadorSlider__textItem::before {
  content: "●";
  font-size: clamp(11.2px, 7px + 0.54688vw, 17.5px);
  color: #F7930E;
  position: absolute;
  left: 0;
}

body.home .sectionYoutube {
  position: relative;
}

body.home .sectionYoutube::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 100vw;
  height: 100%;
  background-color: #FFF5E4;
  z-index: 0;
  border-radius: clamp(40px, 13.33333px + 3.47222vw, 80px) clamp(40px, 13.33333px + 3.47222vw, 80px) 0 0;
}

body.home .sectionYoutube .l-container {
  position: relative;
  z-index: 2;
}

body.home .sectionYoutube__waku {
  border-radius: clamp(10px, -3.33333px + 1.73611vw, 30px);
  overflow: hidden;
  padding: clamp(24px, -20px + 5.72917vw, 90px);
}

body.home .sectionYoutube__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: clamp(24px, 13.33333px + 1.38889vw, 40px);
}

body.home .sectionYoutube__item {
  width: calc((100% - clamp(16px, 0px + 2.08333vw, 40px))/2);
  position: relative;
}

body.home .sectionYoutube__item iframe {
  border-radius: 10px;
  overflow: hidden;
  -webkit-box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.16);
  box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.16);
  aspect-ratio: 16 / 9;
  width: 100%;
  height: auto;
}

@media screen and (max-width: 767px) {
  body.home .sectionYoutube__item {
    width: 100%;
  }
}

body.home .sectionFreecheck__waku {
  border-radius: clamp(10px, -3.33333px + 1.73611vw, 30px);
  overflow: hidden;
  padding: clamp(24px, -20px + 5.72917vw, 90px);
  position: relative;
}

body.home .sectionFreecheck__waku::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 100vw;
  height: 100%;
  background-color: #F7930E;
  z-index: 0;
}

body.home .sectionFreecheck__waku::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 100vw;
  height: 100%;
  background-image: url(../../assets/images/cmn/dot__bk.webp);
  z-index: 1;
}

body.home .sectionFreecheck__waku .sectionFreecheck__list {
  position: relative;
  z-index: 2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  gap: clamp(24px, 13.33333px + 1.38889vw, 40px);
}

@media screen and (max-width: 767px) {
  body.home .sectionFreecheck__waku .sectionFreecheck__list {
    ga: 8px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
  }
}

body.home .sectionFreecheck__waku .sectionFreecheck__item {
  width: calc((100% - clamp(20px, 6.66667px + 1.73611vw, 40px))/2);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: clamp(18px, 10px + 1.04167vw, 30px);
}

@media screen and (max-width: 767px) {
  body.home .sectionFreecheck__waku .sectionFreecheck__item {
    width: 100%;
  }
}

body.home .sectionFreecheck__waku .sectionFreecheck__text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: clamp(8px, 2.66667px + 0.69444vw, 16px);
}

body.home .sectionFreecheck__waku .sectionFreecheck__textP {
  font-size: clamp(12px, 6.66667px + 0.69444vw, 20px);
  color: #fff;
}

body.home .sectionMigrationsupport {
  position: relative;
}

body.home .sectionMigrationsupport::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 100vw;
  height: 100%;
  background-color: #FFF5E4;
  z-index: 0;
  border-radius: clamp(40px, 13.33333px + 3.47222vw, 80px) clamp(40px, 13.33333px + 3.47222vw, 80px) 0 0;
}

body.home .sectionMigrationsupport .l-container {
  position: relative;
  z-index: 2;
}

body.home .sectionMigrationsupport__textArea {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: clamp(4px, 1.33333px + 0.34722vw, 8px);
  margin-bottom: clamp(40px, 20px + 2.60417vw, 70px);
}

body.home .sectionMigrationsupport__textArea-p {
  font-size: clamp(14px, 7.33333px + 0.86806vw, 24px);
  text-align: center;
  line-height: normal;
}

body.home .sectionMigrationsupport__textArea-line {
  position: relative;
}

body.home .sectionMigrationsupport__textArea-line::before {
  content: "";
  position: absolute;
  bottom: 4px;
  left: 0;
  width: 100%;
  height: clamp(4px, 1.33333px + 0.34722vw, 8px);
  background-color: #F7930E;
}

body.home .sectionMigrationsupport__textArea-line span {
  position: relative;
  z-index: 1;
}

body.home .sectionMigrationsupport .l-column01__item {
  width: calc((100% - (clamp(30px, 10px + 2.60417vw, 60px) * 1)) / 2);
}

@media screen and (max-width: 767px) {
  body.home .sectionMigrationsupport .l-column01__item {
    width: 100%;
  }
}

body.home .sectionMigrationsupport .l-column01__item:first-child .l-column01__fukidashi-span {
  font-size: clamp(20px, 6.66667px + 1.73611vw, 40px);
}

body.home .sectionMigrationsupport .l-column01__item:last-child .l-column01__fukidashi {
  background-color: #0F2186;
}

body.home .sectionMigrationsupport .l-column01__item:last-child .l-column01__fukidashi::before {
  background-color: #0F2186;
}

body.home .sectionMigrationsupport .l-column01__fukidashi {
  height: clamp(64px, 40px + 3.125vw, 100px);
}

body.home .sectionMigrationsupport .l-column01__photo {
  aspect-ratio: 16 / 7;
  border: 1px solid #ccc;
}

body.home .sectionFaq {
  position: relative;
}

body.home .sectionFaq::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 100vw;
  height: 100%;
  background-color: #F1F1F1;
  z-index: 0;
  border-radius: 0 0 clamp(40px, 13.33333px + 3.47222vw, 80px) clamp(40px, 13.33333px + 3.47222vw, 80px);
}

body.home .sectionFaq .l-container {
  position: relative;
  z-index: 2;
}

body.home .sectionFaq__waku {
  border-radius: clamp(10px, -3.33333px + 1.73611vw, 30px);
  overflow: hidden;
  padding: clamp(24px, -20px + 5.72917vw, 90px);
}

body.home .sectionContact__waku {
  border-radius: clamp(10px, -3.33333px + 1.73611vw, 30px);
  overflow: hidden;
  padding: clamp(24px, -20px + 5.72917vw, 90px);
}

body.home .sectionContact .l-ctaArea {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-top: clamp(72px, 50px + 2.86458vw, 105px);
  margin-bottom: clamp(32px, -6.66667px + 5.03472vw, 90px);
}

body.home .sectionContact .l-ctaArea .l-ctaArea__div {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  position: relative;
  z-index: 1;
}

body.home .sectionContact .l-ctaArea .l-ctaArea__infoSub {
  position: absolute;
  background-color: #F7930E;
  color: #fff;
  line-height: 1;
  padding: 8px clamp(16px, 10.66667px + 0.69444vw, 24px) 7px;
  border-radius: 3px;
  top: calc(-1 * clamp(64px, 36.66667px + 3.55903vw, 105px));
  white-space: nowrap;
}

body.home .sectionContact .l-ctaArea .l-ctaArea__infoSubtext {
  font-size: clamp(12px, 4px + 1.04167vw, 24px);
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  line-height: 1.4;
  text-align: center;
}

body.home .sectionContact .l-ctaArea .l-ctaArea__infoSubtext::before {
  content: "";
  position: absolute;
  width: 20px;
  aspect-ratio: 1 / 1;
  border-radius: 3px;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  background-color: #F7930E;
  bottom: -12px;
  z-index: -1;
}

body.home .sectionContact .l-ctaArea .l-ctaArea__div:last-child .l-ctaLink {
  background-color: #222;
  -webkit-box-shadow: 0px 8px 20px rgba(0, 0, 0, 0.5);
  box-shadow: 0px 8px 20px rgba(0, 0, 0, 0.5);
}

body.home .sectionContact .l-ctaArea .l-ctaArea__div:last-child .l-ctaLink:hover {
  -webkit-box-shadow: 0px 0px 0px rgba(0, 0, 0, 0.5);
  box-shadow: 0px 0px 0px rgba(0, 0, 0, 0.5);
}

body.home .sectionContact .l-ctaArea .l-ctaLink {
  width: 100%;
  max-width: 900px;
}

body.home .sectionContact__formArea .heading__Lv2 {
  margin-bottom: clamp(56px, 45.33333px + 1.38889vw, 72px);
}

@media screen and (max-width: 767px) {
  body.home .sectionContact__formArea .heading__Lv2 {
    margin-bottom: 24px;
  }
}

body.home .sectionContact__formArea-form {
  border-top: 3px solid #F7930E;
}

/* ==========================================================================
   固定ページで共通のレイアウト
============================================================================= */
body.qr1 .is-headerOrg,
body.qr2 .is-headerOrg {
  display: none;
}

body.qr1 .pageHero,
body.qr2 .pageHero {
  display: none;
}

body.qr1 .se-pd,
body.qr2 .se-pd {
  margin-top: 170px;
  padding-top: clamp(64px, 40px + 3.125vw, 100px);
}

@media screen and (max-width: 1299px) {
  body.qr1 .se-pd,
  body.qr2 .se-pd {
    margin-top: 100px;
  }
}

body.qr1 .se-pd .l-container,
body.qr2 .se-pd .l-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

body.qr1 .se-pd .l-container .QR,
body.qr2 .se-pd .l-container .QR {
  max-width: 375px;
  width: 100%;
}

body.error404 .sectionThanks {
  text-align: center;
}

body.error404 .sectionThanks .l-container {
  max-width: 800px;
}

body.error404 .sectionThanks__h2 {
  font-size: clamp(32px, 21.33333px + 1.38889vw, 48px);
  line-height: 1.2;
  margin-bottom: clamp(16px, 5.33333px + 1.38889vw, 32px);
}

body.error404 .sectionThanks__h3 {
  font-size: clamp(24px, 18.66667px + 0.69444vw, 32px);
  line-height: normal;
  line-height: 1.2;
}

body.privacypolicy .sectionPrivacypolicy__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: clamp(32px, 16px + 2.08333vw, 56px);
}

body.privacypolicy .sectionPrivacypolicy__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: clamp(16px, 10.66667px + 0.69444vw, 24px);
}

body.privacypolicy .sectionPrivacypolicy__h2 {
  font-size: clamp(24px, 13.33333px + 1.38889vw, 40px);
  line-height: 1.4;
}

body.privacypolicy .sectionPrivacypolicy__text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: clamp(8px, 5.33333px + 0.34722vw, 12px);
  line-height: normal;
}

body.privacypolicy .sectionPrivacypolicy__subList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: clamp(4px, 1.33333px + 0.34722vw, 8px);
}

body.privacypolicy .sectionPrivacypolicy__subItem {
  position: relative;
  padding-left: clamp(14px, 10px + 0.52083vw, 20px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

body.privacypolicy .sectionPrivacypolicy__subItem::after {
  content: "";
  position: absolute;
  border-radius: 100vh;
  -webkit-transition: .3s;
  transition: .3s;
}

body.privacypolicy .sectionPrivacypolicy__subItem::after {
  width: clamp(4px, 1.33333px + 0.34722vw, 8px);
  aspect-ratio: 1 / 1;
  background-color: #F7930E;
  left: 0px;
  top: .6em;
}

body.privacypolicy .sectionPrivacypolicy-p2 {
  font-size: clamp(12px, 9.33333px + 0.34722vw, 16px);
}

body.company .sectionCompany .l-dl {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  line-height: normal;
}

@media screen and (max-width: 767px) {
  body.company .sectionCompany .l-dl {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
}

body.company .sectionCompany .l-dl:first-child .l-dt {
  border-top: 1px solid #F7930E;
}

@media screen and (max-width: 767px) {
  body.company .sectionCompany .l-dl:first-child .l-dt {
    border-top: 1px solid #ccc;
  }
}

body.company .sectionCompany .l-dl:first-child .l-dd {
  border-top: 1px solid #ccc;
}

@media screen and (max-width: 767px) {
  body.company .sectionCompany .l-dl:first-child .l-dd {
    border-top: 0px solid #ccc;
  }
}

body.company .sectionCompany .l-dt,
body.company .sectionCompany .l-dd {
  font-size: clamp(16px, 5.33333px + 1.38889vw, 32px);
}

body.company .sectionCompany .l-dt {
  width: clamp(100px, 6.66667px + 12.15278vw, 240px);
  border-bottom: 1px solid #F7930E;
  padding: clamp(16px, 10.66667px + 0.69444vw, 24px) clamp(8px, -2.66667px + 1.38889vw, 24px) clamp(16px, 10.66667px + 0.69444vw, 24px);
}

@media screen and (max-width: 767px) {
  body.company .sectionCompany .l-dt {
    color: #F7930E;
    width: 100%;
    border-bottom: 0px solid #F7930E;
    padding: clamp(16px, 10.66667px + 0.69444vw, 24px) clamp(8px, -2.66667px + 1.38889vw, 24px) clamp(0px, -16px + 2.08333vw, 24px);
  }
}

body.company .sectionCompany .l-dd {
  width: calc(100% - clamp(100px, 6.66667px + 12.15278vw, 240px));
  border-bottom: 1px solid #ccc;
  padding: clamp(16px, 10.66667px + 0.69444vw, 24px) clamp(8px, -2.66667px + 1.38889vw, 24px) clamp(6px, -6px + 1.5625vw, 24px);
}

@media screen and (max-width: 767px) {
  body.company .sectionCompany .l-dd {
    width: 100%;
    border-bottom: 1px solid #ccc;
    padding: clamp(8px, -2.66667px + 1.38889vw, 24px) clamp(8px, -2.66667px + 1.38889vw, 24px) clamp(16px, 10.66667px + 0.69444vw, 24px);
  }
}

body.company .sectionCompany .l-dd__link {
  color: #F7930E;
  text-decoration: underline;
}

body.company .sectionCompany .l-dd__link:hover {
  color: #FF7600;
}

/* ==========================================================================
	シングルページで共通のレイアウト
============================================================================= */
body.single .secPager {
  padding-top: 60px;
}

@media screen and (max-width: 767px) {
  body.single .secPager {
    padding-top: 40px;
  }
}

/* ==========================================================================
   アーカイブページ共通のレイアウト
============================================================================= */
/* ==========================================================================
   お知らせ一覧のレイアウト
============================================================================= */
/* ==========================================================================
   お知らせ詳細
============================================================================= */
/* ==========================================================================
   BLOG一覧のレイアウト
============================================================================= */
/* ==========================================================================
   blog 詳細
============================================================================= */
/* ==========================================================================
	サンクスページのレイアウト
============================================================================= */
body[class*="thanks"] main .sectionThanks {
  text-align: center;
}

body[class*="thanks"] main .sectionThanks .l-container {
  max-width: 800px;
}

body[class*="thanks"] main .sectionThanks__h2 {
  font-size: clamp(32px, 21.33333px + 1.38889vw, 48px);
  line-height: 1.3;
}

body[class*="thanks"] main .thanksMessage {
  text-align: center;
}

body[class*="thanks"] main .attention {
  margin-top: 40px;
  border-radius: clamp(10px, -3.33333px + 1.73611vw, 30px);
  overflow: hidden;
  padding: clamp(24px, 13.33333px + 1.38889vw, 40px);
  background-color: #ccc;
  color: #222;
  text-align: left;
}

@media screen and (max-width: 767px) {
  body[class*="thanks"] main .attention {
    font-size: .8rem;
  }
}
