@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Jost:ital,wght@0,100..900;1,100..900&family=Noto+Sans:ital,wght@0,100..900;1,100..900&display=swap");
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
/* Document
   ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
}

/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
  display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/* Grouping content
   ========================================================================== */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/* Text-level semantics
   ========================================================================== */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none; /* 1 */
  text-decoration: underline; /* 2 */
  text-decoration: underline dotted; /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content
   ========================================================================== */
/**
 * Remove the border on images inside links in IE 10.
 */
img {
  border-style: none;
}

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-size: 100%; /* 1 */
  line-height: 1.15; /* 1 */
  margin: 0; /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input { /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select { /* 1 */
  text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */
fieldset {
  padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  box-sizing: border-box; /* 1 */
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  padding: 0; /* 3 */
  white-space: normal; /* 1 */
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type=checkbox],
[type=radio] {
  box-sizing: border-box; /* 1 */
  padding: 0; /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type=search] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/* Misc
   ========================================================================== */
/**
 * Add the correct display in IE 10+.
 */
template {
  display: none;
}

/**
 * Add the correct display in IE 10.
 */
[hidden] {
  display: none;
}

/* ===============================
   基本リセット
   =============================== */
*,
*::before,
*::after {
  box-sizing: border-box;
  /* 幅計算をborder-boxに統一 */
}

html {
  line-height: 1.5;
  -webkit-text-size-adjust: 100%;
  /* iOSズーム防止 */
  -moz-tab-size: 4;
  tab-size: 4;
}

body {
  margin: 0;
  font-family: system-ui, sans-serif;
  background-color: #fff;
  color: #000;
}

/* 見出し・段落の余白調整 */
h1,
h2,
h3,
h4,
h5,
h6,
p {
  margin: 0;
  font-weight: inherit;
}

/* リストのリセット */
ul,
ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

/* 画像とメディア要素の基本 */
img,
svg,
video,
canvas {
  display: block;
  max-width: 100%;
  height: auto;
}

/* リンクの初期化 */
a {
  color: inherit;
  text-decoration: none;
}

/* ボタンのリセット */
button {
  font: inherit;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
}

/* フォーム系のリセット（必要に応じて） */
input,
textarea,
select {
  font: inherit;
}

/* テーブルのリセット */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

.l-footer__inner {
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--swl-pad_container, 0);
  padding-right: var(--swl-pad_container, 0);
  max-width: calc(var(--container_size, 0px) + var(--swl-pad_container, 0px) * 2);
}
.l-footer__inner .l-footer__top {
  display: flex;
  justify-content: space-between;
  padding-top: 2em;
  border-top: 1px solid #E4E4E4;
}
@media screen and (max-width: 960px) {
  .l-footer__inner .l-footer__top {
    flex-direction: column;
  }
}
@media screen and (max-width: 960px) {
  .l-footer__inner .l-footer__widgetArea {
    order: 1;
    padding-top: 3em;
  }
}
.l-footer__inner .w-footer {
  padding: 0;
}
.l-footer__inner .w-footer .w-footer__box {
  padding: 0;
}
.l-footer__inner .l-footer__navList {
  display: flex;
  flex-direction: column;
  justify-content: space-around;
}
@media screen and (max-width: 960px) {
  .l-footer__inner .l-footer__navList {
    order: 0;
    align-items: flex-start;
  }
}
.l-footer__inner .l-footer__navList .l-footer__nav {
  max-width: 464px;
  width: 100%;
  justify-content: flex-start;
  row-gap: 15px;
}
@media screen and (max-width: 960px) {
  .l-footer__inner .l-footer__navList .l-footer__nav {
    display: block;
    padding: 2em 0 2em;
  }
}
.l-footer__inner .l-footer__navList .l-footer__nav a {
  border-right: none;
  font-size: 0.875rem;
}
@media screen and (max-width: 960px) {
  .l-footer__inner .l-footer__navList .l-footer__nav a {
    padding: 0.5em;
  }
}
.l-footer__inner .l-footer__navList .l-footer__nav li:first-child a {
  border-left: none;
}

@media screen and (max-width: 960px) {
  .l-footer__nav-contact {
    width: 100%;
  }
}

.l-footer__snsList {
  display: flex;
  align-items: center;
  gap: 1.25em;
}
.l-footer__snsList .c-iconList {
  margin-bottom: 0;
}
.l-footer__snsList .c-iconList__link {
  width: auto;
  height: auto;
}
.l-footer__snsList .c-iconList__icon:before {
  font-size: 1.875rem;
}

.l-footer__foot .l-container {
  padding: 0;
  display: flex;
  justify-content: space-between;
  border-bottom: 1px solid #E4E4E4;
  border-top: 1px solid #E4E4E4;
  padding: 43px 0 63px;
}
.l-footer__foot .page-top-area {
  background-color: var(--color_text);
  width: 96px;
  height: 96px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0;
  border-radius: 50%;
}
.l-footer__foot .page-top-area .page-top {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0;
  flex-direction: column;
  color: #fff;
}
.l-footer__foot .page-top-area .u-screen-reader-text {
  font-size: 0.875rem;
}

.copyright-area {
  padding: 0.5em 0;
  background-color: var(--color_main);
}
.copyright-area .copyright {
  color: #fff;
}

@media screen and (min-width: 961px) {
  .c-headLogo {
    height: 3.38vw !important;
  }
}

.menu-item-gtranslate {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0;
}
@media screen and (max-width: 960px) {
  .menu-item-gtranslate {
    display: none;
  }
}

.gt_selector {
  background-color: transparent;
  color: #fff;
  border: 1px solid #fff;
  padding: 0.25em 1em;
  font-size: 14px !important;
  border-radius: 6px;
  text-align: center;
}
@media screen and (max-width: 960px) {
  .gt_selector {
    color: var(--color_text);
    border: 1px solid var(--color_text);
  }
}
.gt_selector:focus-visible {
  outline: none;
}
.gt_selector option {
  color: var(--color_text);
}

#body_wrap:not(.home) .gt_selector {
  color: var(--color_text);
  border: 1px solid var(--color_text);
}

.l-fixHeader .gt_selector {
  color: var(--color_text);
  border: 1px solid #959595;
}

.l-header__customBtn.sp_ {
  width: auto;
  display: flex;
  justify-content: center;
  align-items: baseline;
  height: 100%;
  margin-right: 15px;
}

.l-header__menuBtn {
  color: #fff;
  background-color: var(--color_main);
  border-radius: 6px;
  margin: 5px 16px 5px -5px;
  width: 45px;
  height: 45px;
}

@media screen and (min-width: 961px) {
  .pc-cut {
    display: none !important;
  }
}
@media screen and (max-width: 960px) {
  .pc-cut {
    display: block;
  }
}

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

.p-mainVisual .p-mainVisual__imgLayer {
  width: 60.05vw;
  left: auto;
  right: 0;
}
@media screen and (max-width: 960px) {
  .p-mainVisual .p-mainVisual__imgLayer {
    width: 100%;
  }
}
@media screen and (min-width: 600px) and (max-width: 960px) {
  .p-mainVisual .p-mainVisual__imgLayer {
    top: 20%;
  }
}
.p-mainVisual .p-mainVisual__imgLayer img {
  object-position: top;
}
@media screen and (max-width: 960px) {
  .p-mainVisual .p-mainVisual__imgLayer img {
    object-fit: contain;
    object-position: bottom;
  }
}
.p-mainVisual .p-mainVisual__icon {
  position: absolute;
}
.p-mainVisual .p-mainVisual__message {
  font-size: 0.8125rem;
  background-color: #fff;
  padding: 8px 1.875em;
  border-radius: 6px;
  display: block;
  font-weight: 600;
  box-shadow: 4px 4px 4px 0 rgba(20, 20, 20, 0.15);
  position: relative;
  bottom: -1vw;
  word-break: keep-all;
  overflow-wrap: anywhere;
}
@media screen and (max-width: 960px) {
  .p-mainVisual .p-mainVisual__message {
    opacity: 0;
    animation: fadeInOut 8s infinite;
    display: inline-block;
    padding: 1em;
  }
}
@media screen and (min-width: 600px) and (max-width: 960px) {
  .p-mainVisual .p-mainVisual__message {
    min-width: 196px;
  }
}
@media screen and (max-width: 599px) {
  .p-mainVisual .p-mainVisual__message {
    min-width: 170px;
  }
}
.p-mainVisual .p-mainVisual__message::after {
  content: "";
  background-image: url(../images/bubble-parts.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 1.25vw;
  height: 1.25vw;
  display: inline-block;
  position: absolute;
  bottom: -1vw;
}
@media screen and (max-width: 960px) {
  .p-mainVisual .p-mainVisual__message::after {
    width: 3.25vw;
    height: 3.25vw;
    bottom: -3vw;
  }
}
@media screen and (max-width: 960px) {
  .p-mainVisual .p-mainVisual__icon.--01 .p-mainVisual__message {
    animation-delay: 0s;
  }
  .p-mainVisual .p-mainVisual__icon.--02 .p-mainVisual__message {
    animation-delay: 2s;
  }
  .p-mainVisual .p-mainVisual__icon.--03 .p-mainVisual__message {
    animation-delay: 4s;
  }
  .p-mainVisual .p-mainVisual__icon.--04 .p-mainVisual__message {
    animation-delay: 6s;
  }
}
@keyframes fadeInOut {
  0%, 10% {
    opacity: 0;
  }
  15%, 35% {
    opacity: 1;
  }
  40%, 100% {
    opacity: 0;
  }
}
.p-mainVisual .p-mainVisual__icon.--01 {
  position: absolute;
  left: 2.5vw;
  top: 9.19vw;
}
@media screen and (max-width: 960px) {
  .p-mainVisual .p-mainVisual__icon.--01 {
    transform: translate(-50%, -50%);
  }
}
@media screen and (min-width: 600px) and (max-width: 960px) {
  .p-mainVisual .p-mainVisual__icon.--01 {
    top: 31%;
    left: 53%;
  }
}
@media screen and (max-width: 599px) {
  .p-mainVisual .p-mainVisual__icon.--01 {
    top: 51%;
    left: 60%;
  }
}
.p-mainVisual .p-mainVisual__icon.--01 .p-mainVisual__icon-figure img {
  width: 6.3vw;
  height: 6.3vw;
}
@media screen and (max-width: 960px) {
  .p-mainVisual .p-mainVisual__icon.--01 .p-mainVisual__icon-figure img {
    width: 14.13vw;
    height: 14.13vw;
  }
}
.p-mainVisual .p-mainVisual__icon.--01 .p-mainVisual__message {
  transform: translate(-86%, -24px);
}
@media screen and (max-width: 960px) {
  .p-mainVisual .p-mainVisual__icon.--01 .p-mainVisual__message {
    transform: translate(-86%, -15px);
  }
}
.p-mainVisual .p-mainVisual__icon.--01 .p-mainVisual__message::after {
  right: 2vw;
}
.p-mainVisual .p-mainVisual__icon.--02 {
  left: 62%;
  top: 11.72vw;
  transform: translateX(-50%);
}
@media screen and (max-width: 960px) {
  .p-mainVisual .p-mainVisual__icon.--02 {
    top: 51%;
    left: 88%;
    transform: translate(-50%, -50%);
  }
}
@media screen and (min-width: 600px) and (max-width: 960px) {
  .p-mainVisual .p-mainVisual__icon.--02 {
    top: 34%;
    left: 79%;
  }
}
@media screen and (max-width: 599px) {
  .p-mainVisual .p-mainVisual__icon.--02 {
    top: 51%;
    left: 88%;
  }
}
.p-mainVisual .p-mainVisual__icon.--02 .p-mainVisual__icon-figure img {
  width: 6.82vw;
  height: 6.82vw;
}
@media screen and (max-width: 960px) {
  .p-mainVisual .p-mainVisual__icon.--02 .p-mainVisual__icon-figure img {
    width: 15.46vw;
    height: 15.46vw;
  }
}
.p-mainVisual .p-mainVisual__icon.--02 .p-mainVisual__message {
  transform: translate(91px, -24px);
}
@media screen and (max-width: 960px) {
  .p-mainVisual .p-mainVisual__icon.--02 .p-mainVisual__message {
    transform: translate(-50px, -15px);
  }
}
.p-mainVisual .p-mainVisual__icon.--02 .p-mainVisual__message::after {
  left: 2vw;
  transform: scaleX(-1);
}
@media screen and (max-width: 960px) {
  .p-mainVisual .p-mainVisual__icon.--02 .p-mainVisual__message::after {
    left: 11vw;
    transform: unset;
  }
}
.p-mainVisual .p-mainVisual__icon.--03 {
  left: 7.86vw;
  bottom: 13.89vw;
}
@media screen and (max-width: 960px) {
  .p-mainVisual .p-mainVisual__icon.--03 {
    transform: translate(-50%, -50%);
  }
}
@media screen and (min-width: 600px) and (max-width: 960px) {
  .p-mainVisual .p-mainVisual__icon.--03 {
    bottom: 33%;
    left: 57%;
  }
}
@media screen and (max-width: 599px) {
  .p-mainVisual .p-mainVisual__icon.--03 {
    bottom: 19%;
    left: 65%;
  }
}
.p-mainVisual .p-mainVisual__icon.--03 .p-mainVisual__icon-figure img {
  width: 6.04vw;
  height: 6.04vw;
}
@media screen and (max-width: 960px) {
  .p-mainVisual .p-mainVisual__icon.--03 .p-mainVisual__icon-figure img {
    width: 15vw;
    height: 15vw;
  }
}
.p-mainVisual .p-mainVisual__icon.--03 .p-mainVisual__message {
  transform: translate(-86%, -24px);
}
@media screen and (max-width: 960px) {
  .p-mainVisual .p-mainVisual__icon.--03 .p-mainVisual__message {
    transform: translate(-86%, -15px);
  }
}
.p-mainVisual .p-mainVisual__icon.--03 .p-mainVisual__message::after {
  right: 2vw;
}
.p-mainVisual .p-mainVisual__icon.--04 {
  left: 70%;
  bottom: 15.72vw;
  transform: translateX(-50%);
}
@media screen and (max-width: 960px) {
  .p-mainVisual .p-mainVisual__icon.--04 {
    transform: translate(-50%, -50%);
  }
}
@media screen and (min-width: 600px) and (max-width: 960px) {
  .p-mainVisual .p-mainVisual__icon.--04 {
    left: 83%;
    bottom: 27%;
  }
}
@media screen and (max-width: 599px) {
  .p-mainVisual .p-mainVisual__icon.--04 {
    left: 90%;
    bottom: 22%;
  }
}
.p-mainVisual .p-mainVisual__icon.--04 .p-mainVisual__icon-figure img {
  width: 6.4vw;
  height: 6.4vw;
}
@media screen and (max-width: 960px) {
  .p-mainVisual .p-mainVisual__icon.--04 .p-mainVisual__icon-figure img {
    width: 16.86vw;
    height: 16.86vw;
  }
}
.p-mainVisual .p-mainVisual__icon.--04 .p-mainVisual__message {
  transform: translate(91px, -24px);
}
@media screen and (max-width: 960px) {
  .p-mainVisual .p-mainVisual__icon.--04 .p-mainVisual__message {
    transform: translate(-74px, -15px);
  }
}
.p-mainVisual .p-mainVisual__icon.--04 .p-mainVisual__message::after {
  left: 2vw;
  transform: scaleX(-1);
}
@media screen and (max-width: 960px) {
  .p-mainVisual .p-mainVisual__icon.--04 .p-mainVisual__message::after {
    left: 16vw;
    transform: unset;
  }
}
.p-mainVisual .p-mainVisual__textLayer {
  left: 0;
  transform: translateX(0);
  text-shadow: none !important;
}
@media screen and (max-width: 960px) {
  .p-mainVisual .p-mainVisual__textLayer {
    height: 53%;
  }
}
.p-mainVisual .mv_btn-wrap {
  display: flex;
}
@media screen and (max-width: 960px) {
  .p-mainVisual .mv_btn-wrap {
    position: absolute;
    bottom: 3em;
    right: 0;
  }
}
.p-mainVisual .mv_btn-wrap .wp-block-group__inner-container {
  display: flex;
  gap: 0.5em;
}
@media screen and (max-width: 960px) {
  .p-mainVisual .mv_btn-wrap .wp-block-group__inner-container {
    display: block;
  }
}
.p-mainVisual .mv_btn-wrap .is-style-btn_line a {
  background: #fff;
}
.p-mainVisual .mv_btn-wrap .is-style-btn_line a:hover {
  background-color: var(--the-btn-color, var(--color_main));
}
@media screen and (max-width: 960px) {
  .p-mainVisual .mv-btn {
    text-align: left;
    position: absolute;
    bottom: 5.25em;
    right: 1em;
  }
}

.ticker {
  padding: 2em 3.5em;
  box-shadow: 6px 4px 4px 0px rgba(51, 51, 51, 0.25);
  border-radius: 6px;
  transition: transform 0.5s ease;
  background-color: #fdfdfd;
  font-size: 0.875rem;
  max-width: 1000px;
  margin: 0 auto;
  font-weight: 600;
}
.ticker .ticker__link {
  color: inherit;
  text-decoration: none;
}
.ticker .ticker__link:hover {
  text-decoration: underline;
}
.ticker .ticker__meta {
  font-size: 0.75rem;
  display: flex;
  gap: 1em;
}
.ticker .ticker__cat {
  display: flex;
  gap: 0.25em;
  align-items: center;
}
.ticker .ticker__cat::before {
  content: "";
  width: 10px;
  height: 10px;
  display: inline-block;
  background-color: #FFCB2B;
  border-radius: 50%;
}
.ticker .ticker__text {
  margin-top: 1em;
}

.ly-sec__inner {
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--swl-pad_container, 0);
  padding-right: var(--swl-pad_container, 0);
  max-width: calc(var(--container_size, 0px) + var(--swl-pad_container, 0px) * 2);
}

.ly-sec__intro {
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  background-image: url(../images/hokkaido.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-size: 50.72vw 51.56vw;
  background-position: right 8vw top;
  padding: 11.98vw 0 22.72vw;
}
@media screen and (max-width: 1500px) {
  .ly-sec__intro {
    background-position: right center;
    padding-bottom: 26.72vw;
  }
}
@media screen and (max-width: 960px) {
  .ly-sec__intro {
    background-image: url(../images/hokkaido-sp.png);
    background-size: contain;
  }
}
@media screen and (min-width: 600px) and (max-width: 960px) {
  .ly-sec__intro {
    background-position: center bottom 55%;
    padding-bottom: 0;
  }
}
@media screen and (max-width: 599px) {
  .ly-sec__intro {
    background-position: center bottom 36%;
  }
}
.ly-sec__intro .intro__flex {
  display: flex;
  align-items: flex-end;
  position: relative;
}
@media screen and (max-width: 960px) {
  .ly-sec__intro .intro__flex {
    flex-direction: column;
    gap: 5em;
  }
}
.ly-sec__intro .intro__text:last-child {
  margin-top: 16px;
}
@media screen and (min-width: 961px) {
  .ly-sec__intro .intro__content {
    max-width: 657px;
    width: 100%;
  }
}
.ly-sec__intro .intro__images {
  flex: 1;
}
@media screen and (max-width: 960px) {
  .ly-sec__intro .intro__images {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
  }
}
.ly-sec__intro .intro__images-top {
  position: relative;
}
.ly-sec__intro .intro__images-top .intro__image {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0;
  padding-right: 6em;
}
@media screen and (max-width: 960px) {
  .ly-sec__intro .intro__images-top .intro__image {
    padding-right: 3em;
  }
}
.ly-sec__intro .intro__images-top .intro__image img {
  width: 30.41vw;
}
@media screen and (min-width: 600px) and (max-width: 960px) {
  .ly-sec__intro .intro__images-top .intro__image img {
    width: 100%;
  }
}
@media screen and (max-width: 599px) {
  .ly-sec__intro .intro__images-top .intro__image img {
    width: 80%;
  }
}
.ly-sec__intro .intro__images-top .intro__image__tourist-wrap {
  position: absolute;
  bottom: 0;
  right: 0.5em;
}
@media screen and (max-width: 960px) {
  .ly-sec__intro .intro__images-top .intro__image__tourist-wrap {
    bottom: 1em;
    right: -3em;
  }
}
.ly-sec__intro .intro__images-top .intro__image__tourist-wrap .intro__image__content {
  transform: translateX(23%);
}
@media screen and (max-width: 960px) {
  .ly-sec__intro .intro__images-top .intro__image__tourist-wrap .intro__image__content {
    transform: translate(34%, -22px);
  }
}
.ly-sec__intro .intro__images-top .intro__image__tourist-wrap .intro__image__message {
  transform: translate(-18%, -31px);
  font-size: 0.625rem;
  background-color: #fff;
  color: #758D9E;
  padding: 8px 1.875em;
  border-radius: 6px;
  display: block;
  font-weight: 600;
  box-shadow: 4px 4px 4px 0 rgba(20, 20, 20, 0.15);
  position: relative;
  bottom: -1vw;
  right: 0;
}
@media screen and (max-width: 960px) {
  .ly-sec__intro .intro__images-top .intro__image__tourist-wrap .intro__image__message {
    transform: translate(-92%, -12px);
    font-size: 0.375rem;
  }
}
.ly-sec__intro .intro__images-top .intro__image__tourist-wrap .intro__image__message::before {
  content: "";
  background-image: url(../images/idea_icon.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 1.25vw;
  height: 1.25vw;
  display: inline-block;
  position: absolute;
  top: -0.5vw;
  right: 0;
}
@media screen and (max-width: 960px) {
  .ly-sec__intro .intro__images-top .intro__image__tourist-wrap .intro__image__message::before {
    width: 3.66vw;
    height: 3.66vw;
    top: -2vw;
  }
}
.ly-sec__intro .intro__images-top .intro__image__tourist-wrap .intro__image__message::after {
  content: "";
  background-image: url(../images/bubble-parts.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 1.25vw;
  height: 1.25vw;
  display: inline-block;
  position: absolute;
  bottom: -1vw;
  left: 50%;
  transform: scaleX(-1);
}
@media screen and (max-width: 960px) {
  .ly-sec__intro .intro__images-top .intro__image__tourist-wrap .intro__image__message::after {
    transform: unset;
    width: 3.73vw;
    height: 3.73vw;
    bottom: -3vw;
    left: 70%;
  }
}
.ly-sec__intro .intro__images-top .intro__image__tourist-wrap .intro__image__icon-figure {
  width: 4.23vw;
}
@media screen and (max-width: 960px) {
  .ly-sec__intro .intro__images-top .intro__image__tourist-wrap .intro__image__icon-figure {
    width: 9.8vw;
  }
}
.ly-sec__intro .intro__images-top .intro__image__tourist-wrap .intro__image__tourist {
  width: 5.62vw;
}
@media screen and (max-width: 960px) {
  .ly-sec__intro .intro__images-top .intro__image__tourist-wrap .intro__image__tourist {
    width: 17.2vw;
  }
}
.ly-sec__intro .intro__images-bottom {
  display: flex;
  align-items: center;
  padding: 100px 160px 0;
  position: absolute;
  right: 0;
  bottom: -14vw;
}
@media screen and (max-width: 960px) {
  .ly-sec__intro .intro__images-bottom {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    grid-template-rows: repeat(2, 1fr);
    padding: 0;
    position: relative;
    align-items: flex-start;
    margin-top: 130px;
  }
}
.ly-sec__intro .intro__message {
  padding-right: 28px;
}
@media screen and (max-width: 960px) {
  .ly-sec__intro .intro__message {
    grid-row: span 2/span 2;
    max-width: fit-content;
    margin-left: auto;
    padding-right: 15px;
  }
}
.ly-sec__intro .intro__message::before {
  content: "";
  width: 265px;
  height: 1px;
  display: block;
  background-color: var(--color_text);
  transform: rotate(7deg);
  margin-left: auto;
}
@media screen and (max-width: 960px) {
  .ly-sec__intro .intro__message::before {
    width: 161px;
  }
}
.ly-sec__intro .intro__message::after {
  content: "";
  width: 265px;
  height: 1px;
  display: block;
  background-color: var(--color_text);
  transform: rotate(-7deg);
  margin-left: auto;
}
@media screen and (max-width: 960px) {
  .ly-sec__intro .intro__message::after {
    width: 161px;
  }
}
.ly-sec__intro .intro__image--character {
  max-width: 7.29vw;
  width: 100%;
}
@media screen and (max-width: 960px) {
  .ly-sec__intro .intro__image--character {
    max-width: 20vw;
    margin-left: 1em;
    margin-top: 2em;
  }
}
@media screen and (min-width: 600px) and (max-width: 960px) {
  .ly-sec__intro .intro__image--character {
    max-width: 16vw;
  }
}
@media screen and (max-width: 599px) {
  .ly-sec__intro .intro__image--character {
    max-width: 20vw;
  }
}
.ly-sec__intro .intro__character {
  align-self: flex-end;
  padding-left: 16px;
}
@media screen and (max-width: 960px) {
  .ly-sec__intro .intro__character {
    grid-column-start: 2;
    padding-top: 1em;
    align-self: flex-start;
  }
}

.ly-sec__trouble {
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}
.ly-sec__trouble .heading-line {
  text-align: center;
}
.ly-sec__trouble .trouble__contents {
  background-color: #FFEEB9;
  border: 10px solid #FFCB2B;
  border-radius: 80px;
  padding: 7.03vw 4.58vw;
  width: 79.4vw;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 960px) {
  .ly-sec__trouble .trouble__contents {
    width: calc(100% - 32px);
    margin: 0 16px;
    border: 5px solid #FFCB2B;
    padding: 19.7vw 16px;
    border-radius: 30px;
  }
}
@media screen and (min-width: 600px) and (max-width: 960px) {
  .ly-sec__trouble .trouble__contents {
    padding: 6.7vw 16px;
  }
}
@media screen and (max-width: 599px) {
  .ly-sec__trouble .trouble__contents {
    padding: 19.7vw 16px;
  }
}
.ly-sec__trouble .trouble__contents .ly-sec__inner {
  padding-left: 0;
  padding-right: 0;
}
.ly-sec__trouble .trouble__heading {
  position: relative;
  max-width: fit-content;
  margin: 0 auto;
}
.ly-sec__trouble .trouble__heading::after {
  content: "";
  background-image: url(../images/torakun_annai.png);
  background-size: contain;
  background-repeat: no-repeat;
  width: 7.08vw;
  height: 8.28vw;
  display: inline-block;
  position: absolute;
  right: -12vw;
  bottom: -3.28vw;
  transform: translateX(-50%);
}
@media screen and (max-width: 960px) {
  .ly-sec__trouble .trouble__heading::after {
    position: relative;
    width: 19.7vw;
    height: 23.7vw;
    transform: translateX(-50%);
  }
}
@media screen and (min-width: 600px) and (max-width: 960px) {
  .ly-sec__trouble .trouble__heading::after {
    width: 18vw;
    height: 20vw;
  }
}
@media screen and (max-width: 599px) {
  .ly-sec__trouble .trouble__heading::after {
    width: 19.7vw;
    height: 23.7vw;
  }
}
.ly-sec__trouble .trouble__content {
  margin-top: 5.5vw;
}
@media screen and (max-width: 960px) {
  .ly-sec__trouble .trouble__content {
    margin-top: 8.5vw;
  }
}
.ly-sec__trouble .trouble__list {
  display: flex;
  justify-content: space-between;
  row-gap: 84px;
  flex-wrap: wrap;
}
@media screen and (max-width: 960px) {
  .ly-sec__trouble .trouble__list {
    row-gap: 24px;
  }
}
.ly-sec__trouble .trouble__list .trouble__item {
  background-color: #fff;
  min-height: 207px;
  box-shadow: 4px 4px 4px 0 rgba(20, 20, 20, 0.15);
  border-radius: 15px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  padding: 15px 20px;
  width: calc(33.3333333333% - 1em);
}
@media screen and (max-width: 960px) {
  .ly-sec__trouble .trouble__list .trouble__item {
    border-bottom: 1px solid #fff;
    padding: 20px;
    min-height: auto;
  }
}
@media screen and (min-width: 600px) and (max-width: 960px) {
  .ly-sec__trouble .trouble__list .trouble__item {
    width: calc(50% - 1em);
  }
}
@media screen and (max-width: 599px) {
  .ly-sec__trouble .trouble__list .trouble__item {
    width: 100%;
  }
}
.ly-sec__trouble .trouble__list .trouble__item .trouble__text {
  margin-top: 15px;
}
.ly-sec__trouble .trouble__list .trouble__item:first-of-type .trouble__title::before {
  content: "";
  background-image: url(../images/trouble-icon.svg);
  background-size: contain;
  background-repeat: no-repeat;
  width: 2.5vw;
  height: 2.91vw;
  display: inline-block;
}
@media screen and (max-width: 960px) {
  .ly-sec__trouble .trouble__list .trouble__item:first-of-type .trouble__title::before {
    width: 8vw;
    height: 8.5vw;
  }
}
.ly-sec__trouble .trouble__list .trouble__item:nth-of-type(2) .trouble__title::before {
  content: "";
  background-image: url(../images/trouble-icon02.svg);
  background-size: contain;
  background-repeat: no-repeat;
  width: 2.65vw;
  height: 1.71vw;
  display: inline-block;
}
@media screen and (max-width: 960px) {
  .ly-sec__trouble .trouble__list .trouble__item:nth-of-type(2) .trouble__title::before {
    width: 9.3vw;
    height: 6.1vw;
  }
}
.ly-sec__trouble .trouble__list .trouble__item:nth-of-type(3) .trouble__title::before {
  content: "";
  background-image: url(../images/trouble-icon03.svg);
  background-size: contain;
  background-repeat: no-repeat;
  width: 3.69vw;
  height: 2.86vw;
  display: inline-block;
}
@media screen and (max-width: 960px) {
  .ly-sec__trouble .trouble__list .trouble__item:nth-of-type(3) .trouble__title::before {
    width: 14.6vw;
    height: 11.2vw;
  }
}
.ly-sec__trouble .trouble__list .trouble__item:nth-of-type(4) .trouble__title::before {
  content: "";
  background-image: url(../images/trouble-icon04.svg);
  background-size: contain;
  background-repeat: no-repeat;
  width: 3vw;
  height: 2.1vw;
  display: inline-block;
}
@media screen and (max-width: 960px) {
  .ly-sec__trouble .trouble__list .trouble__item:nth-of-type(4) .trouble__title::before {
    width: 10vw;
    height: 8vw;
  }
}
.ly-sec__trouble .trouble__list .trouble__item:nth-of-type(5) .trouble__title::before {
  content: "";
  background-image: url(../images/trouble-icon05.svg);
  background-size: contain;
  background-repeat: no-repeat;
  width: 3.75vw;
  height: 2.23vw;
  display: inline-block;
}
@media screen and (max-width: 960px) {
  .ly-sec__trouble .trouble__list .trouble__item:nth-of-type(5) .trouble__title::before {
    width: 11.7vw;
    height: 6.9vw;
  }
}
.ly-sec__trouble .trouble__list .trouble__item:nth-of-type(6) .trouble__title::before {
  content: "";
  background-image: url(../images/trouble-icon06.svg);
  background-size: contain;
  background-repeat: no-repeat;
  width: 2vw;
  height: 2.76vw;
  display: inline-block;
}
@media screen and (max-width: 960px) {
  .ly-sec__trouble .trouble__list .trouble__item:nth-of-type(6) .trouble__title::before {
    width: 12vw;
    height: 12.8vw;
  }
}

.ly-sec__service {
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  background-color: #1E51D7;
  color: #fff;
  padding-top: 24.56vw;
  margin-top: -19.58vw;
  margin-bottom: 7.43vw;
  position: relative;
}
.ly-sec__service .service__intro-message {
  position: absolute;
  top: 42.51vw;
  left: 7.1vw;
  display: flex;
}
@media screen and (max-width: 960px) {
  .ly-sec__service .service__intro-message {
    position: relative;
    top: unset;
    left: unset;
    padding: 4em 16px 1.5em;
  }
}
.ly-sec__service .service__intro-image {
  width: 8.28vw;
  height: 8.28vw;
  object-fit: contain;
}
@media screen and (min-width: 600px) and (max-width: 960px) {
  .ly-sec__service .service__intro-image {
    width: 21.3vw;
    height: 19.3vw;
  }
}
@media screen and (max-width: 599px) {
  .ly-sec__service .service__intro-image {
    width: 23.3vw;
    height: 27.3vw;
  }
}
.ly-sec__service .service__intro-text {
  transform: rotate(-9deg);
  padding-left: 100px;
}
@media screen and (max-width: 960px) {
  .ly-sec__service .service__intro-text {
    padding-left: 50px;
  }
}
.ly-sec__service .service__intro-text::before {
  content: "";
  width: 161px;
  height: 1px;
  display: block;
  background-color: #fff;
  transform: rotate(162deg);
  margin-left: -80px;
  margin-bottom: 15px;
}
@media screen and (max-width: 960px) {
  .ly-sec__service .service__intro-text::before {
    margin-left: -40px;
    margin-bottom: 20px;
    width: 146px;
  }
}
.ly-sec__service .service__intro-text::after {
  content: "";
  width: 161px;
  height: 1px;
  display: block;
  background-color: #fff;
  transform: rotate(186deg);
  margin-left: -80px;
  margin-top: 15px;
}
@media screen and (max-width: 960px) {
  .ly-sec__service .service__intro-text::after {
    margin-left: -40px;
  }
}
.ly-sec__service #service {
  padding-top: 7vw;
}
.ly-sec__service .service__content {
  padding: 13.22vw 0;
  display: flex;
  align-items: flex-start;
}
@media screen and (max-width: 960px) {
  .ly-sec__service .service__content {
    flex-direction: column;
    padding: 5.22vw 0 13.22vw;
  }
}
.ly-sec__service .service__chat-image {
  width: 40%;
  position: sticky;
  top: 8.55vw;
}
@media screen and (max-width: 960px) {
  .ly-sec__service .service__chat-image {
    top: unset;
    width: 100%;
  }
}
.ly-sec__service .service__chat-image img {
  max-width: 19.06vw;
  width: 100%;
  margin: 0 auto;
  display: block;
}
@media screen and (min-width: 600px) and (max-width: 960px) {
  .ly-sec__service .service__chat-image img {
    max-width: 45%;
  }
}
@media screen and (max-width: 599px) {
  .ly-sec__service .service__chat-image img {
    max-width: 80%;
  }
}
.ly-sec__service .service__points {
  width: 60%;
}
@media screen and (max-width: 960px) {
  .ly-sec__service .service__points {
    width: 100%;
  }
}
.ly-sec__service .service__point-item {
  display: flex;
  gap: 3.43em;
}
@media screen and (max-width: 960px) {
  .ly-sec__service .service__point-item {
    flex-direction: column;
    gap: 24px;
    padding: 70px 0;
  }
}
.ly-sec__service .service__point-item:not(:first-child) {
  margin-top: 118px;
}
@media screen and (max-width: 960px) {
  .ly-sec__service .service__point-item:not(:first-child) {
    margin-top: 0;
  }
}
@media screen and (max-width: 960px) {
  .ly-sec__service .service__point-item:not(:last-child) {
    border-bottom: 1px solid #fff;
  }
}
.ly-sec__service .service__point-text {
  margin-top: 52px;
}
@media screen and (max-width: 960px) {
  .ly-sec__service .service__point-text {
    margin-top: 24px;
  }
}

.ly-sec__price {
  padding: 9.43vw 0 5.2vw;
}
@media screen and (max-width: 960px) {
  .ly-sec__price {
    padding: 33.43vw 0 15.2vw;
  }
}
.ly-sec__price .price__cards {
  display: flex;
  justify-content: center;
  gap: 4.687em;
  padding: 100px 0;
  flex-wrap: wrap;
}
@media screen and (max-width: 960px) {
  .ly-sec__price .price__cards {
    flex-direction: column;
    padding: 20px 0;
  }
}
.ly-sec__price .price__cards .price__card {
  background-color: #CED9F6;
  border: 10px solid #1E51D7;
  padding: 35px 20px;
  display: flex;
  row-gap: 15px;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  border-radius: 35px;
  width: calc(50% - 4.687em);
  min-height: 640px;
}
@media screen and (max-width: 960px) {
  .ly-sec__price .price__cards .price__card {
    width: 100%;
    min-height: auto;
    border: 5px solid #1E51D7;
    max-width: 495px;
    margin: 0 auto;
  }
}
.ly-sec__price .price__cards .price__card-top {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3.187em;
}
@media screen and (max-width: 960px) {
  .ly-sec__price .price__cards .price__card-top {
    gap: 1.187em;
  }
}
.ly-sec__price .price__cards .price__card-title {
  font-size: 1.25rem;
  font-weight: bold;
  color: #fff;
  background-color: #1E51D7;
  padding: 15px 25px;
}
.ly-sec__price .price__cards .price__card-price {
  font-size: 3.125rem;
  font-weight: bold;
}
@media screen and (max-width: 960px) {
  .ly-sec__price .price__cards .price__card-price {
    font-size: 2.1875rem;
  }
}
.ly-sec__price .price__cards .price__card-bottom {
  text-align: center;
}
.ly-sec__price .price__cards .price__card-bottom .price__card-link {
  text-decoration: underline;
  font-weight: bold;
}
.ly-sec__price .price-payment {
  display: flex;
  align-items: center;
  gap: 15px;
  justify-content: center;
}
@media screen and (max-width: 960px) {
  .ly-sec__price .price-payment {
    flex-direction: column;
    text-align: center;
  }
}

.price__card--day {
  position: relative;
}
.price__card--day .price__card-lavel {
  position: absolute;
  top: -16px;
  right: -16px;
}
@media screen and (max-width: 960px) {
  .price__card--day .price__card-lavel {
    left: 2%;
    top: -7px;
    right: unset;
  }
}
.price__card--day .price__card-lavel__text {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0;
}
.price__card--day .price__card-lavel__text::before {
  content: "";
  background-image: url(../images/price_label.svg);
  background-size: contain;
  background-repeat: no-repeat;
  width: 150px;
  height: 150px;
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
}
@media screen and (max-width: 960px) {
  .price__card--day .price__card-lavel__text::before {
    width: 112px;
    height: 112px;
  }
}
.price__card--day .price__card-lavel__text::after {
  content: "";
  background-image: url(../images/price_label-2.svg);
  background-size: contain;
  background-repeat: no-repeat;
  width: 150px;
  height: 150px;
  display: inline-block;
  position: absolute;
  top: 87%;
  left: 58%;
  transform: translate(-50%, -50%);
  z-index: 1;
}
@media screen and (max-width: 960px) {
  .price__card--day .price__card-lavel__text::after {
    width: 112px;
    height: 112px;
    top: 67%;
  }
}
.price__card--day .price__card-lavel__text span {
  color: #fff;
  position: relative;
  z-index: 3;
  max-width: 95px;
  width: 100%;
}
@media screen and (max-width: 960px) {
  .price__card--day .price__card-lavel__text span {
    max-width: 65px;
  }
}

.ly-sec__flow {
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding: 5.2vw 0;
}
@media screen and (max-width: 960px) {
  .ly-sec__flow {
    padding: 266px 16px 25.2vw;
    position: relative;
  }
}
.ly-sec__flow .flow__visual {
  position: relative;
}
.ly-sec__flow .flow__visual .flow__image {
  position: relative;
}
.ly-sec__flow .flow__visual .flow__image::after {
  content: "";
  display: inline-block;
  width: 37.34vw;
  height: 37.34vw;
  background-color: var(--color_main);
  position: absolute;
  left: 50%;
  top: 100%;
  z-index: -1;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  clip-path: inset(0 0 50%);
}
@media screen and (min-width: 600px) and (max-width: 960px) {
  .ly-sec__flow .flow__visual .flow__image::after {
    width: 82vw;
    height: 77vw;
  }
}
@media screen and (max-width: 599px) {
  .ly-sec__flow .flow__visual .flow__image::after {
    width: 85vw;
    height: 80vw;
  }
}
.ly-sec__flow .flow__visual .flow__image img {
  margin: 0 auto;
  max-width: 37.34vw;
  width: 100%;
}
@media screen and (min-width: 600px) and (max-width: 960px) {
  .ly-sec__flow .flow__visual .flow__image img {
    max-width: 80%;
  }
}
@media screen and (max-width: 599px) {
  .ly-sec__flow .flow__visual .flow__image img {
    max-width: 100%;
  }
}
.ly-sec__flow .flow__visual-wrap {
  position: relative;
  padding-top: 60px;
}
@media screen and (max-width: 960px) {
  .ly-sec__flow .flow__visual-wrap {
    padding-top: 0;
  }
}
.ly-sec__flow .flow__icon {
  position: absolute;
  transform: translate(-50%, -50%);
}
.ly-sec__flow .flow__icon.--01 {
  top: 22%;
  left: 25%;
}
@media screen and (max-width: 960px) {
  .ly-sec__flow .flow__icon.--01 {
    top: 0;
    left: 21%;
    transform: unset;
  }
}
.ly-sec__flow .flow__icon.--01 .flow__icon-figure {
  width: 5.98vw;
  height: 5.98vw;
}
@media screen and (min-width: 600px) and (max-width: 960px) {
  .ly-sec__flow .flow__icon.--01 .flow__icon-figure {
    width: 13.06vw;
    height: 13.06vw;
  }
}
@media screen and (max-width: 599px) {
  .ly-sec__flow .flow__icon.--01 .flow__icon-figure {
    width: 17.06vw;
    height: 17.06vw;
  }
}
.ly-sec__flow .flow__icon.--02 {
  top: 22%;
  right: 24%;
}
@media screen and (max-width: 960px) {
  .ly-sec__flow .flow__icon.--02 {
    top: 2%;
    right: 12%;
    transform: unset;
  }
}
.ly-sec__flow .flow__icon.--02 .flow__icon-figure {
  width: 6.56vw;
  height: 6.56vw;
}
@media screen and (min-width: 600px) and (max-width: 960px) {
  .ly-sec__flow .flow__icon.--02 .flow__icon-figure {
    width: 14.33vw;
    height: 14.33vw;
  }
}
@media screen and (max-width: 599px) {
  .ly-sec__flow .flow__icon.--02 .flow__icon-figure {
    width: 17.33vw;
    height: 17.33vw;
  }
}
.ly-sec__flow .flow__icon.--03 {
  top: 76%;
  left: 20%;
}
@media screen and (max-width: 960px) {
  .ly-sec__flow .flow__icon.--03 {
    top: 10%;
    left: 23%;
    transform: unset;
  }
}
.ly-sec__flow .flow__icon.--03 .flow__icon-figure {
  width: 6.56vw;
  height: 6.56vw;
}
@media screen and (min-width: 600px) and (max-width: 960px) {
  .ly-sec__flow .flow__icon.--03 .flow__icon-figure {
    width: 13.8vw;
    height: 13.8vw;
  }
}
@media screen and (max-width: 599px) {
  .ly-sec__flow .flow__icon.--03 .flow__icon-figure {
    width: 16.8vw;
    height: 16.8vw;
  }
}
.ly-sec__flow .flow__icon.--04 {
  top: 73%;
  right: 13%;
}
@media screen and (max-width: 960px) {
  .ly-sec__flow .flow__icon.--04 {
    top: 10%;
    right: 24%;
    transform: unset;
  }
}
.ly-sec__flow .flow__icon.--04 .flow__icon-figure {
  width: 6.66vw;
  height: 6.66vw;
}
@media screen and (min-width: 600px) and (max-width: 960px) {
  .ly-sec__flow .flow__icon.--04 .flow__icon-figure {
    width: 15.46vw;
    height: 15.46vw;
  }
}
@media screen and (max-width: 599px) {
  .ly-sec__flow .flow__icon.--04 .flow__icon-figure {
    width: 18.46vw;
    height: 18.46vw;
  }
}
.ly-sec__flow .flow__swiperUnit {
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--swl-pad_container, 0);
  padding-right: var(--swl-pad_container, 0);
  max-width: calc(var(--container_size, 0px) + var(--swl-pad_container, 0px) * 2);
}
@media screen and (max-width: 960px) {
  .ly-sec__flow .flow__swiperUnit {
    width: 100%;
    max-width: 100%;
  }
}

.ly-sec__faq {
  padding: 5.2vw 0;
}

.ui-deco-ellipse__container {
  position: absolute;
  /* 背景として全体に敷く */
  inset: 0;
  pointer-events: none;
  /* クリック妨げない */
  opacity: 1;
  /* 0になっていたら1に */
  z-index: 2;
  /* アイコンの下/上は必要に応じて調整 */
}
@media screen and (max-width: 960px) {
  .ui-deco-ellipse__container {
    top: 0;
    left: 0;
  }
}

.ui-deco-ellipse__content {
  position: absolute;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  box-shadow: 0 0 12px 4px hsla(0, 0%, 89%, 0.24);
  animation: float 5s ease-in-out infinite;
}

.ui-deco-ellipse__content.red {
  background-color: #e53935;
}

.ui-deco-ellipse__content.blue {
  background-color: #1e51d7;
}

.ui-deco-ellipse__content.yellow {
  background-color: #ffcb2b;
}

@keyframes float {
  0%, 100% {
    transform: translateY(10px);
  }
  50% {
    transform: translateY(0);
  }
}
.ly-sec__app {
  color: #202936;
  background-color: #C9ECE9;
  border: 10px solid #00A596;
  border-radius: 50px;
  padding: 53px 16px;
}
@media screen and (max-width: 960px) {
  .ly-sec__app {
    border: 5px solid #00A596;
    margin-bottom: 50px;
  }
}
.ly-sec__app .app__wrap {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.ly-sec__app .app__heading img {
  padding: 8px 0;
}
@media screen and (max-width: 960px) {
  .ly-sec__app .app__heading img {
    width: 250px;
    margin: 0 auto;
  }
}
.ly-sec__app .app__content {
  padding: 24px 0 30px;
  word-break: keep-all;
  overflow-wrap: anywhere;
}
.ly-sec__app .app__content span {
  font-size: 0.75rem;
  font-weight: 600;
}
.ly-sec__app .app__btn-wrap {
  display: flex;
  gap: 4.18em;
}
@media screen and (max-width: 960px) {
  .ly-sec__app .app__btn-wrap {
    flex-direction: column;
    gap: 5px;
  }
}

.ly-sec__spots {
  padding-bottom: 7.39vw;
}
.ly-sec__spots .spots-wrapper {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 20px;
}
.ly-sec__spots .spots-wrapper .spots-item {
  position: relative;
  width: calc(50% - 20px);
  margin-bottom: 9.95vw;
}
@media screen and (max-width: 599px) {
  .ly-sec__spots .spots-wrapper .spots-item {
    width: 100%;
  }
}
.ly-sec__spots .spots-wrapper .spots-label {
  font-size: clamp(1.375rem, 1.136rem + 0.98vw, 2.313rem);
  padding: 0 25px;
  background: #fff;
  box-shadow: 4px 4px 4px 0 rgba(3, 3, 3, 0.25);
  display: inline-block;
  position: absolute;
  top: -0.5em;
  left: 0;
}
.ly-sec__spots .spots-wrapper .spots-image-box img {
  border-radius: 30px;
}
.ly-sec__spots .spots-wrapper .spots-content {
  display: flex;
  gap: 24px;
  align-items: center;
  position: absolute;
  bottom: -8.65vw;
  right: 0;
}
@media screen and (max-width: 599px) {
  .ly-sec__spots .spots-wrapper .spots-content {
    position: relative;
    bottom: unset;
    margin-top: 1em;
  }
}
.ly-sec__spots .spots-wrapper .spots-description {
  border: 1px solid #8C8C8C;
  border-radius: 15px;
  padding: 0.5em 1em;
}
.ly-sec__spots .spots-wrapper .p-mainVisual__icon-figure {
  width: 9.95vw;
  height: auto;
}
@media screen and (max-width: 599px) {
  .ly-sec__spots .spots-wrapper .p-mainVisual__icon-figure {
    width: 42.95vw;
  }
}

.page-id-99 .c-pageTitle,
.page-id-97 .c-pageTitle {
  opacity: 0;
}
.page-id-99 .post_content h2:where(:not([class^=swell-block-]):not(.faq_q):not(.p-postList__title)),
.page-id-97 .post_content h2:where(:not([class^=swell-block-]):not(.faq_q):not(.p-postList__title)) {
  border-left: unset;
  padding: 0;
}
.page-id-99 .ly-sec__app,
.page-id-97 .ly-sec__app {
  margin-top: 150px;
}
@media screen and (max-width: 960px) {
  .page-id-99 .ly-sec__app,
  .page-id-97 .ly-sec__app {
    margin-top: 50px;
  }
}

.settlement-intro {
  position: relative;
  max-width: fit-content;
  margin: 0 auto;
}
@media screen and (max-width: 960px) {
  .settlement-intro {
    gap: 1em;
    display: flex;
  }
}
.settlement-intro::before {
  content: "";
  background-image: url(../images/torakun_flag.png);
  background-repeat: no-repeat;
  background-size: contain;
  width: 139px;
  height: 139px;
  display: inline-block;
  position: absolute;
  top: 50%;
  left: -7.29vw;
  transform: translate(-50%, -50%);
}
@media screen and (max-width: 960px) {
  .settlement-intro::before {
    position: relative;
    width: 109px;
    height: 71px;
    transform: unset;
    left: 0;
  }
}

.settlement__cards {
  display: flex;
  justify-content: center;
  gap: 4.687em;
  padding: 3.81vw 0;
  flex-wrap: wrap;
}
@media screen and (max-width: 960px) {
  .settlement__cards {
    gap: 2.687em;
  }
}

.settlement__card {
  background-color: #CED9F6;
  border: 10px solid #1E51D7;
  padding: 35px 20px;
  display: flex;
  row-gap: 15px;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  border-radius: 35px;
  width: calc(50% - 4.687em);
  min-height: 550px;
}
@media screen and (max-width: 960px) {
  .settlement__card {
    width: 100%;
    border: 5px solid #1E51D7;
    min-height: auto;
  }
}

.settlement__card-top {
  margin-bottom: 30px;
}
@media screen and (max-width: 960px) {
  .settlement__card-top {
    margin-bottom: 10px;
  }
}

.settlement__card-title {
  font-size: 2rem;
  font-weight: bold;
}

.settlement__card-price {
  font-size: 2rem;
  font-weight: bold;
  text-align: center;
}

.settlement__card-price {
  font-size: 2rem;
  font-weight: bold;
}

.settlement__card-description {
  max-width: 300px;
}

.settlement__card-bottom {
  text-align: center;
}
.settlement__card-bottom p {
  font-weight: 600;
}
.settlement__card-bottom .settlement__card-lang {
  margin-bottom: 40px;
}
.settlement__card-bottom .coiney-lang-select {
  padding: 0.25em 1.5em;
  border-radius: 6px;
  border: 1px solid #eee;
  margin-top: 14px;
}
.settlement__card-bottom .coiney-lang-select::before {
  content: "";
  background-image: url(../images/contact_icon.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 34px;
  height: 24px;
  display: inline-block;
}
.settlement__card-bottom .coiney-pay-button {
  margin: 0 auto;
  margin-top: 14px;
}

.settlement__card-1day {
  margin: 5.81vw auto;
}

.settlement__btn-wrap {
  position: relative;
}
@media screen and (max-width: 960px) {
  .settlement__btn-wrap {
    margin-top: 117px;
  }
}
.settlement__btn-wrap .settlement__chara {
  z-index: 1;
  position: absolute;
  top: -2.5em;
  left: 13%;
  transform: translateX(-50%);
}
@media screen and (max-width: 960px) {
  .settlement__btn-wrap .settlement__chara {
    left: 28%;
  }
}
@media screen and (min-width: 600px) and (max-width: 960px) {
  .settlement__btn-wrap .settlement__chara {
    top: -2em;
  }
}
@media screen and (max-width: 599px) {
  .settlement__btn-wrap .settlement__chara {
    top: -5em;
  }
}
.settlement__btn-wrap .settlement__chara img {
  width: 105px;
  height: auto;
  position: absolute;
  top: 75%;
  left: 83%;
}
@media screen and (max-width: 960px) {
  .settlement__btn-wrap .settlement__chara img {
    width: 58px;
    top: 70%;
    left: -45px;
  }
}
.settlement__btn-wrap .settlement__bubble {
  background-color: #1E51D7;
  padding: 20px 40px;
  border-radius: 50px;
  color: #fff;
  display: inline-block;
  position: relative;
}
@media screen and (max-width: 960px) {
  .settlement__btn-wrap .settlement__bubble {
    padding: 10px;
    font-size: 0.75rem;
  }
}
.settlement__btn-wrap .settlement__bubble::after {
  content: "";
  background-image: url(../images/bubble-parts-blue.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 30px;
  height: 27px;
  display: inline-block;
  position: absolute;
  bottom: -18px;
  right: 25px;
}
@media screen and (max-width: 960px) {
  .settlement__btn-wrap .settlement__bubble::after {
    right: unset;
    transform: scaleX(-1);
    width: 14px;
    height: 20px;
    left: 26px;
  }
}

.smf-form--simple-table .smf-item {
  padding: 3rem 0;
}

@media screen and (min-width: 600px) {
  .smf-form--simple-table .smf-item__col--label {
    flex: 0 0 16em;
    max-width: 16em;
  }
}

.smf-item__label__text {
  display: flex;
  flex-wrap: wrap;
}

.smf-item:has([data-validations~=required]) .required-label {
  border-radius: 4px;
  font-size: 12px;
  color: #fff;
  background: rgba(255, 0, 0, 0.7960784314);
  padding: 0.25em 0.5em;
  margin-left: 0.5em;
}

.smf-form .smf-radio-button-control__control:checked {
  background-color: #125ac7;
  border-color: #125ac7;
}

.scroll-box {
  height: 500px;
  overflow: scroll !important;
  margin-bottom: 4em;
}

.smf-action .smf-button-control__control {
  background-color: var(--color_main);
  background-image: unset;
  color: #fff;
  border: unset;
  width: 50%;
  border-radius: 30px;
}

.smf-action .smf-button-control + .smf-button-control {
  margin-left: 0;
}

.smf-action .smf-button-control:first-of-type .smf-button-control__control {
  margin-bottom: 2em;
}

[data-screen=confirm] .scroll-box {
  display: none;
}

.chat-start-wrap {
  max-width: 450px;
  margin: 0 auto;
  padding: 1em;
  box-shadow: 0px 3px 5px 0px rgba(0, 0, 0, 0.1);
  border-radius: 16px;
}

.chat-start {
  max-width: 392px;
  margin: 0 auto;
}

.chat-start .wp-block-group__inner-container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1em;
}
.chat-start .wp-block-group__inner-container::after {
  content: "";
  background-image: url(../images/chevron-right.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 24px;
  height: 24px;
  display: inline-block;
}

.line-image .wp-block-group__inner-container::before {
  content: "";
  background-image: url(../images/line-icon.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 65px;
  height: 50px;
  display: inline-block;
}

.lineworks-image {
  position: relative;
}
.lineworks-image::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  display: inline-block;
  border: 3px solid #D42239;
}
.lineworks-image .wp-block-group__inner-container::before {
  content: "";
  background-image: url(../images/lineworks-icon.svg);
  width: 98px;
  height: 50px;
}
.lineworks-image .wp-block-group__inner-container::after {
  width: 67px;
  height: 37px;
}

.lineworks-name::before {
  content: "";
  background-image: url(../images/lineworks.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 13px;
  height: 13px;
  display: inline-block;
  margin-right: 0.25em;
}

.phone-image {
  display: flex;
  justify-content: center;
  align-items: center;
}
.phone-image::before {
  content: "";
  background-image: url(../images/SP.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 31px;
  height: 38px;
  display: inline-block;
  margin-right: 0.25em;
}

.pc-image {
  display: flex;
  justify-content: center;
  align-items: center;
}
.pc-image::before {
  content: "";
  background-image: url(../images/PC.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 31px;
  height: 38px;
  display: inline-block;
  margin-right: 0.25em;
}

.lineworks-border {
  max-width: 350px !important;
}

.lineworks-bottom {
  max-width: 470px;
  margin: 2em auto 0;
}
.lineworks-bottom .wp-block-column:first-of-type {
  position: relative;
}
.lineworks-bottom .wp-block-column:first-of-type::after {
  content: "";
  width: 1px;
  height: 10px;
  background-color: var(--color_text);
  position: absolute;
  bottom: 0;
  right: -1.5%;
  transform: translateY(-50%);
}

.qr-image {
  position: relative;
}
.qr-image::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 138px;
  height: 123px;
  display: inline-block;
  border: 3px solid #D42239;
}

.linewoeks-download {
  position: relative;
}
.linewoeks-download::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  display: inline-block;
  border: 3px solid #D42239;
}

.price__card-button {
  background-color: #1E51D7;
  padding: 20px 40px;
  display: block;
  margin-top: 23px;
  border-radius: 50px;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
}
@media screen and (max-width: 960px) {
  .price__card-button {
    padding: 10px 40px;
  }
}
.price__card-button::after {
  content: "";
  background-image: url(../images/chat_icon.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 41px;
  height: 31px;
  display: inline-block;
}

.contact-button {
  display: flex;
  justify-content: flex-end;
  margin-right: 2em;
}
.contact-button a {
  padding: 10px 40px;
  border: 1px solid var(--color_text);
  border-radius: 50px;
  font-weight: bold;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
@media screen and (max-width: 960px) {
  .contact-button a {
    justify-content: center;
    width: 100%;
  }
}
.contact-button a::after {
  content: "";
  background-image: url(../images/contact_icon.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 34px;
  height: 24px;
  display: inline-block;
}

.settlement__btn {
  background-color: #FFEEB9;
  height: 150px;
  font-size: 2rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #7A5400;
  position: relative;
}
@media screen and (max-width: 960px) {
  .settlement__btn {
    font-size: 1.25rem;
    padding: 20px 30px 20px 0;
    height: auto;
  }
}
.settlement__btn::after {
  content: "";
  background-image: url(../images/btn_arrow.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 57px;
  height: 57px;
  display: inline-block;
  position: absolute;
  top: 50%;
  right: calc(25% - 57px);
  transform: translate(-50%, -50%);
}
@media screen and (max-width: 960px) {
  .settlement__btn::after {
    width: 30px;
    height: 30px;
    right: 1em;
    transform: translateY(-50%);
  }
}

.app__button {
  background-color: #394FF6;
  padding: 20px 40px;
  border-radius: 50px;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
}
@media screen and (max-width: 960px) {
  .app__button {
    margin-top: 23px;
  }
}

.app__manual-button::after {
  content: "";
  background-image: url(../images/pdf-icon.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 42px;
  height: 30px;
  display: inline-block;
}

.app__download-button::after {
  content: "";
  background-image: url(../images/app-icon.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 42px;
  height: 30px;
  display: inline-block;
}

body {
  font-family: "YakuHanJP", "Jost", "Noto Sans", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-variation-settings: "wdth" 100;
  letter-spacing: 0.1em;
}

.chat-start-contents {
  font-family: "Noto Sans", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-variation-settings: "wdth" 100;
  letter-spacing: 0.1em;
}

h1 {
  font-weight: bold;
}

h3 {
  font-weight: bold;
}

.heading {
  margin-bottom: 70px;
  font-weight: bold;
}
@media screen and (max-width: 960px) {
  .heading {
    margin-bottom: 40px;
  }
}

.heading-line {
  display: block;
}

.heading-line:first-of-type {
  font-size: clamp(1.75rem, 1.495rem + 1.05vw, 2.75rem);
  letter-spacing: 0.01em;
}

.heading-line:last-of-type {
  font-size: clamp(1.375rem, 1.223rem + 0.65vw, 2rem);
  white-space: normal;
  word-break: keep-all;
  overflow-wrap: anywhere;
}

.heading--primary {
  color: #7A5400;
}

.center__heading {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0;
  flex-direction: column;
}

.mv-ttl {
  font-size: clamp(2.188rem, -0.714rem + 3.1vw, 3rem) !important;
}
@media screen and (max-width: 960px) {
  .mv-ttl {
    font-size: 1.825rem !important;
  }
}

.ly-sec__intro .highlight {
  display: inline-block;
  font-weight: bold;
  position: relative;
}
.ly-sec__intro .highlight::after {
  content: "";
  display: inline-block;
  width: 93%;
  height: 6px;
  background-color: var(--color_main);
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0;
}
.ly-sec__intro .intro__message-line {
  display: block;
  font-weight: bold;
  font-size: 1.25rem;
}
.ly-sec__intro .intro__message-line:first-of-type {
  padding-top: 2em;
}
.ly-sec__intro .intro__message-line:last-of-type {
  padding-bottom: 2em;
}
.ly-sec__intro .intro__character-label {
  display: block;
  font-weight: bold;
  font-size: 0.6875rem;
}
.ly-sec__intro .intro__character-name {
  display: block;
  font-weight: bold;
  font-size: 1.1875rem;
}
@media screen and (max-width: 960px) {
  .ly-sec__intro .intro__character-name {
    font-size: 0.75rem;
  }
}

@media screen and (max-width: 960px) {
  .ly-sec__service .service__heading .heading-line:last-of-type {
    font-size: 1.625rem;
  }
}
.ly-sec__service .service__point-lavel {
  font-size: clamp(2.563rem, 2.426rem + 0.58vw, 3.125rem);
  font-weight: bold;
  line-height: 1;
  display: flex;
}
.ly-sec__service .service__point-title {
  font-size: 1.5rem;
  font-weight: bold;
  display: flex;
  align-items: flex-end;
  height: 50px;
}
@media screen and (max-width: 960px) {
  .ly-sec__service .service__point-title {
    display: block;
    height: auto;
  }
}

.ly-sec__price .price__heading {
  background-color: #FFEEB9;
  padding: 40px 0 30px;
  position: relative;
}
@media screen and (max-width: 960px) {
  .ly-sec__price .price__heading {
    padding: 30px 0;
  }
}
.ly-sec__price .price__heading::before {
  content: "";
  width: 29.58vw;
  height: 9.27vw;
  background-image: url(../images/torakun_yukiasobi.png);
  background-repeat: no-repeat;
  background-size: contain;
  display: block;
  position: absolute;
  top: -9.27vw;
  right: 0;
}
@media screen and (min-width: 600px) and (max-width: 960px) {
  .ly-sec__price .price__heading::before {
    width: 67.26vw;
    height: 19.73vw;
    top: -19.27vw;
  }
}
@media screen and (max-width: 599px) {
  .ly-sec__price .price__heading::before {
    width: 72.26vw;
    height: 23.73vw;
    top: -22.27vw;
  }
}
.ly-sec__price .price__heading::after {
  content: "";
  width: 50px;
  height: 50px;
  background-image: url(../images/ttl_part.svg);
  background-repeat: no-repeat;
  background-size: contain;
  display: block;
  position: absolute;
  bottom: -46px;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (max-width: 960px) {
  .ly-sec__price .price__heading::after {
    bottom: -33px;
  }
}
.ly-sec__price .price__heading .heading-line:last-of-type {
  font-size: 1.6875rem;
}

.trouble__title {
  font-size: clamp(1.25rem, 0.938rem + 0.42vw, 1.438rem);
  color: #7A5400;
  display: flex;
  align-items: center;
  gap: 13px;
}

.faq__heading {
  font-size: 2rem;
}

.snsList__heading {
  font-size: 1.875rem;
  font-weight: bold;
}

.tax {
  font-size: 1.0625rem;
  margin-left: 0.25em;
}

.p-mainVisual__notice {
  position: absolute;
  bottom: 10vw;
  right: 2em;
  color: #fff;
  font-size: 0.875rem;
}
@media screen and (min-width: 600px) and (max-width: 960px) {
  .p-mainVisual__notice {
    bottom: 24em;
    right: unset;
    left: 1em;
  }
}
@media screen and (max-width: 599px) {
  .p-mainVisual__notice {
    bottom: 13em;
    right: 1em;
  }
}

.app__heading {
  font-weight: 600;
}
.app__heading span:first-of-type {
  font-size: clamp(1.375rem, 1.254rem + 0.52vw, 1.875rem);
}
.app__heading span:last-of-type {
  font-size: 1.25rem;
}

.p-fixBtnWrap {
  display: block;
  text-align: right;
}
@media screen and (max-width: 960px) {
  .p-fixBtnWrap {
    right: 2em;
    transition: bottom 0.3s ease;
  }
}

.p-fixBtnWrap.is-hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.float-wrap-line {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0;
  color: #fff;
  gap: 10px;
  background-color: #1E51D7;
  border-radius: 50px;
  position: relative;
  box-shadow: 4px 4px 4px 0 rgba(20, 20, 20, 0.15);
  display: inline-flex;
  gap: 0.5em;
  background-color: #06C755;
  margin-bottom: 1em;
  width: 70px;
  height: 70px;
  padding: 0;
  transition: padding 0.3s ease, box-shadow 0.3s ease;
}
@media screen and (max-width: 960px) {
  .float-wrap-line {
    width: 55px;
    height: 55px;
  }
}
.float-wrap-line::before {
  content: "";
  background-image: url(../images/float-lineIcon.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 40px;
  height: 40px;
  display: inline-block;
}
@media screen and (max-width: 960px) {
  .float-wrap-line::before {
    width: 30px;
    height: 30px;
  }
}
.float-wrap-line .float-text {
  display: none;
  white-space: nowrap;
}

.float-wrap-line:hover {
  padding: 0.62em 3.31em 0.62em 1.56em;
  width: auto;
  height: auto;
}
.float-wrap-line:hover .float-text {
  display: block;
}

.float-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0;
  color: #fff;
  gap: 10px;
  background-color: #1E51D7;
  padding: 0.62em 3.31em 0.62em 1.56em;
  border-radius: 50px;
  position: relative;
  box-shadow: 4px 4px 4px 0 rgba(20, 20, 20, 0.15);
}
.float-wrap .float-open {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.float-wrap .float-open span:first-of-type {
  font-size: 0.875rem;
  display: flex;
  align-items: center;
  gap: 5px;
}
.float-wrap .float-open span:first-of-type::before {
  content: "";
  background-image: url(../images/time-icon.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 22px;
  height: 22px;
  display: inline-block;
}
.float-wrap .float-open span:last-of-type {
  padding-left: 27px;
}
.float-wrap::after {
  content: "";
  background-image: url(../images/torakun-wink.png);
  background-repeat: no-repeat;
  background-size: contain;
  width: 79px;
  height: 79px;
  display: inline-block;
  position: absolute;
  top: 50%;
  right: -2.31em;
  transform: translateY(-50%);
  z-index: 1;
}
@media screen and (max-width: 960px) {
  .float-wrap::after {
    width: 65px;
    height: 65px;
  }
}

.flow__swiper {
  position: relative;
  margin-top: 55px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0;
}
@media screen and (max-width: 960px) {
  .flow__swiper {
    flex-direction: column;
    margin-top: 0;
  }
}
.flow__swiper .flow__swiperUnit {
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--swl-pad_container, 0);
  padding-right: var(--swl-pad_container, 0);
  max-width: calc(var(--container_size, 0px) + var(--swl-pad_container, 0px) * 2);
  padding: 0 !important;
  order: 1;
}
@media screen and (max-width: 960px) {
  .flow__swiper .flow__swiperUnit {
    order: 0;
  }
}
.flow__swiper .flow__swiperUnit .flow__wrap {
  align-items: stretch !important;
}
.flow__swiper .flow__swiperUnit .flow__step {
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin-right: 25px;
  padding: 20px;
  position: relative;
}
@media screen and (min-width: 961px) {
  .flow__swiper .flow__swiperUnit .flow__step:first-of-type::before {
    content: "";
    display: block;
    width: 1px;
    height: 100%;
    background-color: var(--color_text);
    position: absolute;
    left: 0;
    top: 0;
  }
}
@media screen and (min-width: 961px) {
  .flow__swiper .flow__swiperUnit .flow__step::after {
    content: "";
    display: block;
    width: 1px;
    height: 100%;
    background-color: var(--color_text);
    position: absolute;
    right: 0;
    top: 0;
  }
}
.flow__swiper .flow__swiperUnit .flow__step-badge {
  font-size: 2.25rem;
  font-weight: bold;
}
.flow__swiper .flow__nav {
  position: absolute;
  left: 4vw;
  top: 50%;
  transform: translateY(-50%);
  padding: 0 2em;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 18px;
  flex-direction: column;
  order: 0;
}
@media screen and (max-width: 1500px) {
  .flow__swiper .flow__nav {
    position: relative;
    top: unset;
    transform: unset;
    left: unset;
  }
}
@media screen and (max-width: 1500px) and (max-width: 960px) {
  .flow__swiper .flow__nav {
    order: 1;
    flex-direction: row;
    gap: 20px;
  }
}
.flow__swiper .flow__prev {
  position: relative;
  width: 70px;
  height: 70px;
  background-color: #C9ECE9;
  border: 3px solid var(--color_main);
  border-radius: 50%;
  top: unset;
  -webkit-transform: unset;
  transform: unset;
}
@media screen and (max-width: 960px) {
  .flow__swiper .flow__prev {
    width: 60px;
    height: 60px;
  }
}
.flow__swiper .flow__prev:after {
  content: "";
  background-image: url(../images/slider_prev.svg);
  background-size: contain;
  background-repeat: no-repeat;
  width: 50px;
  height: 53px;
  display: inline-block;
  width: 15px;
  height: 15px;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  border-bottom: unset;
  border-left: unset;
  left: 50%;
  top: 50%;
}
.flow__swiper .flow__next {
  width: 70px;
  height: 70px;
  background-color: #C9ECE9;
  border: 3px solid var(--color_main);
  border-radius: 50%;
  position: relative;
  top: unset;
  -webkit-transform: unset;
  transform: unset;
}
@media screen and (max-width: 960px) {
  .flow__swiper .flow__next {
    width: 60px;
    height: 60px;
  }
}
.flow__swiper .flow__next:after {
  content: "";
  background-image: url(../images/slider_next.svg);
  background-size: contain;
  background-repeat: no-repeat;
  width: 50px;
  height: 53px;
  display: inline-block;
  width: 15px;
  height: 15px;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  border-right: unset;
  border-top: unset;
  left: 50%;
  top: 50%;
}

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

.p-blogParts[data-partsid="19"] .swell-block-button__link {
  padding: 1.06em 2.81em;
}
.p-blogParts[data-partsid="19"] .swell-block-button__link span {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.25em;
}
@media screen and (max-width: 960px) {
  .p-blogParts[data-partsid="19"] .swell-block-button__link span {
    font-size: 1rem !important;
  }
}

.p-blogParts[data-partsid="36"] .faq_q {
  padding: 1em 1em 1em 4em;
  font-size: 1.125rem;
}
.p-blogParts[data-partsid="36"] .faq_q:before {
  font-weight: bold;
  font-size: 1.375rem;
  top: 50%;
  transform: translateY(-50%);
  border: 3px solid #164E9E;
  width: 50px;
  height: 50px;
  font-family: unset;
}
.p-blogParts[data-partsid="36"] .faq_a {
  padding: 1em 1em 1em 4em;
}
.p-blogParts[data-partsid="36"] .faq_a:before {
  font-weight: bold;
  font-size: 1.375rem;
  top: 50%;
  transform: translateY(-50%);
  border: 3px solid #EC2828;
  width: 50px;
  height: 50px;
  font-family: unset;
  padding-left: 0.05em;
}
@media screen and (max-width: 960px) {
  .p-blogParts[data-partsid="36"] .faq_a:before {
    top: 0.75em;
    transform: translateY(0);
  }
}

/*# sourceMappingURL=main.css.map */
