@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=BIZ+UDPGothic:wght@400;700&display=swap");
/* resset.dev • v5.0.2 */
/* # =================================================================
   # Global selectors
   # ================================================================= */
html {
  box-sizing: border-box;
  -webkit-text-size-adjust: 100%; /* Prevent adjustments of font size after orientation changes in iOS */
  word-break: normal;
  -moz-tab-size: 4;
  tab-size: 4;
}

*,
::before,
::after {
  background-repeat: no-repeat; /* Set `background-repeat: no-repeat` to all elements and pseudo elements */
  box-sizing: inherit;
}

::before,
::after {
  text-decoration: inherit; /* Inherit text-decoration and vertical align to ::before and ::after pseudo elements */
  vertical-align: inherit;
}

* {
  padding: 0; /* Reset `padding` and `margin` of all elements */
  margin: 0;
}

/* # =================================================================
   # General elements
   # ================================================================= */
hr {
  overflow: visible; /* Show the overflow in Edge and IE */
  height: 0; /* Add the correct box sizing in Firefox */
  color: inherit; /* Correct border color in Firefox. */
}

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

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

small {
  font-size: 80%; /* Set font-size to 80% in `small` elements */
}

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

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

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

a:active,
a:hover {
  outline-width: 0; /* Remove the outline when hovering in all browsers */
}

code,
kbd,
pre,
samp {
  font-family: monospace, monospace; /* Specify the font family of code elements */
}

pre {
  font-size: 1em; /* Correct the odd `em` font sizing in all browsers */
}

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

/* https://gist.github.com/unruthless/413930 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

table {
  border-color: inherit; /* Correct border color in all Chrome, Edge, and Safari. */
  text-indent: 0; /* Remove text indentation in Chrome, Edge, and Safari */
}

iframe {
  border-style: none;
}

/* # =================================================================
   # Forms
   # ================================================================= */
input {
  border-radius: 0;
}

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

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

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

textarea {
  overflow: auto; /* Internet Explorer 11+ */
  resize: vertical; /* Specify textarea resizability */
}

button,
input,
optgroup,
select,
textarea {
  font: inherit; /* Specify font inheritance of form elements */
}

optgroup {
  font-weight: bold; /* Restore the font weight unset by the previous rule */
}

button {
  overflow: visible; /* Address `overflow` set to `hidden` in IE 8/9/10/11 */
}

button,
select {
  text-transform: none; /* Firefox 40+, Internet Explorer 11- */
}

/* Apply cursor pointer to button elements */
button,
[type=button],
[type=reset],
[type=submit],
[role=button] {
  cursor: pointer;
}

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

/* Replace focus style removed in the border reset above */
button:-moz-focusring,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  outline: 1px dotted ButtonText;
}

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

/* Remove the default button styling in all browsers */
button,
input,
select,
textarea {
  background-color: transparent;
  border-style: none;
}

a:focus,
button:focus,
input:focus,
select:focus,
textarea:focus {
  outline-width: 0;
}

/* Style select like a standard input */
select {
  -moz-appearance: none; /* Firefox 36+ */
  -webkit-appearance: none; /* Chrome 41+ */
}

select::-ms-expand {
  display: none; /* Internet Explorer 11+ */
}

select::-ms-value {
  color: currentColor; /* Internet Explorer 11+ */
}

legend {
  border: 0; /* Correct `color` not being inherited in IE 8/9/10/11 */
  color: inherit; /* Correct the color inheritance from `fieldset` elements in IE */
  display: table; /* Correct the text wrapping in Edge and IE */
  max-width: 100%; /* Correct the text wrapping in Edge and IE */
  white-space: normal; /* Correct the text wrapping in Edge and IE */
  max-width: 100%; /* Correct the text wrapping in Edge 18- and IE */
}

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

/* Replace pointer cursor in disabled elements */
[disabled] {
  cursor: default;
}

/* # =================================================================
   # Specify media element style
   # ================================================================= */
img {
  border-style: none; /* Remove border when inside `a` element in IE 8/9/10 */
}

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

/* # =================================================================
   # Accessibility
   # ================================================================= */
/* Specify the progress cursor of updating elements */
[aria-busy=true] {
  cursor: progress;
}

/* Specify the pointer cursor of trigger elements */
[aria-controls] {
  cursor: pointer;
}

/* Specify the unstyled cursor of disabled, not-editable, or otherwise inoperable elements */
[aria-disabled=true] {
  cursor: default;
}

/**********************************************
** 関数
***********************************************/
/**********************************************
** クラス
***********************************************/
/* --------------------------------------- mixin --------------------------------------- */
h1,
h2,
h3,
h4,
h5,
h6 {
  line-height: normal;
  margin-block: 0;
}

p,
figure {
  margin-top: initial;
  margin-bottom: initial;
}

a {
  text-decoration: none;
  color: inherit;
  line-height: normal;
  transition: all 0.3s ease-out;
}
a:hover {
  text-decoration: none;
  color: inherit;
}

ul,
ol {
  color: #333333;
  margin-block: 0;
  list-style: none;
}

html {
  color: #333333;
  font-size: clamp(1px, 4.2666666667vw, 21.3333333333px);
  letter-spacing: 0;
  line-height: normal;
}
@media screen and (min-width: 768px) {
  html {
    line-height: normal;
  }
}

body {
  transition: opacity 300ms;
  overflow-x: hidden;
  font-family: "BIZ UDPGothic", YuGothic, "Lucida Grande", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", Meiryo, メイリオ, sans-serif;
  font-feature-settings: "palt" on;
  font-weight: 500;
  line-height: 160%;
}

:root {
  --default-font-family: "BIZ UDPGothic", YuGothic, "Lucida Grande", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", Meiryo, メイリオ, sans-serif;
}

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

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

/**********************************************
** カラー定義
***********************************************/
/**********************************************
** 共通スタイル
***********************************************/
.popupCta__btnTel.--shiny, .cta__btnTel.--shiny, .footerCta__tel.--shiny {
  position: relative;
  overflow: hidden;
}
.popupCta__btnTel.--shiny::after, .cta__btnTel.--shiny::after, .footerCta__tel.--shiny::after {
  content: "";
  position: absolute;
  top: -10%;
  left: -20%;
  width: 40px;
  height: 100%;
  transform: scale(2) rotate(20deg);
  background-image: linear-gradient(100deg, rgba(255, 255, 255, 0) 10%, rgba(255, 255, 255, 0.5) 100%, rgba(255, 255, 255, 0) 0%);
  animation-name: shiny;
  animation-duration: 3s;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite;
}
@keyframes shiny {
  0% {
    left: -20%;
  }
  10% {
    left: 120%;
  }
  100% {
    left: 120%;
  }
}

header {
  position: sticky;
  top: 0;
  z-index: 999;
  background-color: #fff;
}
header .header__inr {
  width: 92vw;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media screen and (min-width: 768px) {
  header .header__inr {
    padding: 0 clamp(1px, 9.0909090909vw, 100px);
    width: clamp(1px, 100vw, 1512px);
  }
}
header .header__logo {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2.4vw;
  margin: 2.4vw 0;
}
@media screen and (min-width: 768px) {
  header .header__logo {
    width: auto;
    flex-direction: column;
    gap: clamp(1px, 0.8181818182vw, 9px);
    margin: clamp(1px, 0.8181818182vw, 9px) 0;
  }
}
header .header__logoImg {
  order: 1;
  text-align: center;
}
@media screen and (min-width: 768px) {
  header .header__logoImg {
    order: 2;
  }
}
header .header__logoImg > img {
  width: 18.9333333333vw;
  height: 5.0666666667vw;
  margin-left: 1.3333333333vw;
}
@media screen and (min-width: 768px) {
  header .header__logoImg > img {
    width: clamp(1px, 14.5454545455vw, 160px);
    height: clamp(1px, 4.0909090909vw, 45px);
    margin-left: 0;
  }
}
header .header__logoCatchphrase {
  order: 2;
  color: #F08D18;
  font-size: 3.7333333333vw;
  font-weight: 700;
  line-height: 1.2;
}
@media screen and (min-width: 768px) {
  header .header__logoCatchphrase {
    order: 1;
    font-size: clamp(1px, 1.0909090909vw, 12px);
  }
}
header .header__cta > a {
  display: flex;
  align-items: center;
}
@media screen and (min-width: 768px) {
  header .header__cta > a {
    flex-direction: row;
    gap: clamp(1px, 0.9090909091vw, 10px);
    margin: 0;
  }
}
header .header__ctaBadge {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  background: #16A34A;
  color: #FFF;
  font-weight: 700;
  line-height: 1.2;
}
@media screen and (min-width: 768px) {
  header .header__ctaBadge {
    width: clamp(1px, 5.8181818182vw, 64px);
    height: clamp(1px, 5.8181818182vw, 64px);
    font-size: clamp(1px, 1.8181818182vw, 20px);
  }
}
header .header__ctaTel {
  color: #16A34A;
  text-align: center;
  font-family: Roboto;
  font-weight: 700;
  line-height: 1.2;
}
@media screen and (min-width: 768px) {
  header .header__ctaTel {
    font-size: clamp(1px, 3.6363636364vw, 40px);
  }
}
header .header__ctaTel small {
  display: block;
  color: #232B39;
  text-align: center;
  font-weight: 400;
}
@media screen and (min-width: 768px) {
  header .header__ctaTel small {
    font-size: clamp(1px, 1.4545454545vw, 16px);
  }
}

.footer__inr {
  width: 94.6666666667vw;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .footer__inr {
    width: clamp(1px, 90.9090909091vw, 1000px);
  }
}
.footer__banner {
  display: flex;
  width: 100%;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 8vw;
  margin: 10.6666666667vw auto;
}
@media screen and (min-width: 768px) {
  .footer__banner {
    gap: clamp(1px, 3.6363636364vw, 40px);
    margin: clamp(1px, 5.4545454545vw, 60px) auto;
  }
}
.footer__banner img {
  width: 100%;
}
.footer__note {
  background: #EEE;
  padding: 5.3333333333vw 0;
  margin: 0 auto;
  color: #666;
}
@media screen and (min-width: 768px) {
  .footer__note {
    padding: clamp(1px, 1.8181818182vw, 20px) 0;
  }
}
.footer__noteTitle {
  color: #666;
  font-size: 3.2vw;
  font-weight: 700;
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .footer__noteTitle {
    font-size: clamp(1px, 1.0909090909vw, 12px);
  }
}
.footer__noteText {
  margin-top: 2.4vw;
  font-size: 2.9333333333vw;
  font-weight: 400;
  line-height: 1.8;
}
@media screen and (min-width: 768px) {
  .footer__noteText {
    margin-top: clamp(1px, 0.8181818182vw, 9px);
    font-size: clamp(1px, 1vw, 11px);
  }
}
.footer__otherLinks {
  text-align: left;
  padding: 0;
  background: #fff;
}
@media screen and (min-width: 768px) {
  .footer__otherLinks {
    text-align: center;
    padding: clamp(1px, 1.8181818182vw, 20px) 0;
  }
}
.footer__otherLinks ul {
  text-align: left;
  border-top: 1px solid #CCB;
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .footer__otherLinks ul {
    text-align: center;
    border-top: none;
  }
}
.footer__otherLinks li {
  display: block;
  font-size: 3.2vw;
  font-weight: 400;
  line-height: 1;
  border-right: none;
  border-bottom: 1px solid #CCB;
  padding: 0;
  margin: 0;
  position: relative;
}
@media screen and (min-width: 768px) {
  .footer__otherLinks li {
    font-size: clamp(1px, 1.0909090909vw, 12px);
  }
}
.footer__otherLinks li::after {
  content: "chevron_right";
  color: #333;
  font-family: Material Icons;
  font-feature-settings: "liga";
  font-size: 4.2666666667vw;
  right: 2.6666666667vw;
  line-height: 1;
  margin: -2.1333333333vw 0 0;
  position: absolute;
  top: 50%;
  -webkit-font-feature-settings: "liga";
}
@media screen and (min-width: 768px) {
  .footer__otherLinks li::after {
    font-size: clamp(1px, 1.4545454545vw, 16px);
    right: clamp(1px, 0.9090909091vw, 10px);
    margin: clamp(-8px, -0.7272727273vw, -1px) 0 0;
  }
}
@media screen and (min-width: 768px) {
  .footer__otherLinks li {
    display: inline-block;
    border-right: 1px solid #CCB;
    border-bottom: none;
    margin: 0 4px 0 0;
  }
  .footer__otherLinks li::after {
    content: "";
  }
}
.footer__otherLinks li a {
  color: #333;
  display: block;
  padding: 2.6666666667vw;
  text-decoration: none;
}
.footer__otherLinks li a:visited {
  color: #333;
}
.footer__otherLinks li a:hover {
  color: #333;
  text-decoration: none;
}
@media screen and (min-width: 768px) {
  .footer__otherLinks li a {
    padding: clamp(1px, 0.4545454545vw, 5px) clamp(1px, 0.9090909091vw, 10px);
    text-decoration: underline;
  }
}
.footer__jpx, .footer__pmark {
  background: #EEE;
  text-align: left;
  font-weight: normal;
  font-size: 4vw;
  margin: 0 auto;
  padding: 6.4vw 2.6666666667vw;
}
@media screen and (min-width: 768px) {
  .footer__jpx, .footer__pmark {
    text-align: left;
    padding: clamp(1px, 0.9090909091vw, 10px) 0;
    font-size: clamp(1px, 1.0738181818vw, 11.812px);
    font-weight: 700;
    line-height: 1.6;
  }
}
.footer__jpx ul, .footer__pmark ul {
  display: flex;
  justify-content: left;
  align-items: flex-start;
}
@media screen and (min-width: 768px) {
  .footer__jpx ul, .footer__pmark ul {
    justify-content: center;
    align-items: center;
  }
}
.footer__jpx li:last-child, .footer__pmark li:last-child {
  padding: 0 2.6666666667vw;
  line-height: 1.6;
}
@media screen and (min-width: 768px) {
  .footer__jpx li:last-child, .footer__pmark li:last-child {
    padding: 0 clamp(1px, 0.9090909091vw, 10px);
  }
}
.footer__jpx img, .footer__pmark img {
  width: 40px;
  line-height: 0;
  vertical-align: middle;
}
.footer__jpx strong, .footer__pmark strong {
  color: #eb6877;
  font-size: 3.4666666667vw;
}
@media screen and (min-width: 768px) {
  .footer__jpx strong, .footer__pmark strong {
    font-size: clamp(1px, 1.1818181818vw, 13px);
  }
}
.footer__pmark {
  border-bottom: 1px solid #dedede;
}
.footer__copyright {
  padding: 4.5333333333vw;
  color: #fff;
  text-align: center;
  border-top: 1px solid #ccc;
  background: #333;
  font-size: 2.6666666667vw;
  font-weight: 400;
  line-height: 1.4;
}
@media screen and (min-width: 768px) {
  .footer__copyright {
    padding: clamp(1px, 1.5454545455vw, 17px);
    font-size: clamp(1px, 1.0909090909vw, 12px);
    line-height: clamp(1px, 1.1454545455vw, 12.6px);
  }
}
.footerCta {
  position: fixed;
  z-index: 999;
  bottom: 0;
  left: 0;
  width: 100%;
  background: #2E3858;
  color: #fff;
  white-space: nowrap;
}
.footerCta__inr {
  width: 94.6666666667vw;
  margin: 0 auto;
  padding: 3.2vw 30px 3.2vw 0;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2.1333333333vw;
}
@media screen and (min-width: 768px) {
  .footerCta__inr {
    width: clamp(1px, 90.9090909091vw, 1000px);
    height: clamp(1px, 7.2727272727vw, 80px);
    padding: 0 0 0 clamp(1px, 9.0909090909vw, 100px);
    gap: clamp(1px, 1.2727272727vw, 14px);
    flex-direction: row;
    align-items: center;
  }
}
@media screen and (min-width: 768px) {
  .footerCta__inr::before {
    content: "";
    background-image: url(../images/servicePromotion_person.png);
    background-size: contain;
    display: block;
    width: clamp(1px, 10.0909090909vw, 111px);
    height: clamp(1px, 9vw, 99px);
    position: absolute;
    bottom: 0;
    left: 0;
  }
}
.footerCta__head {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.0666666667vw;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .footerCta__head {
    align-items: flex-start;
    width: auto;
    gap: clamp(1px, 0.3636363636vw, 4px);
  }
}
.footerCta__ttl {
  font-size: 3.7333333333vw;
  font-weight: 700;
  line-height: 1.2;
  text-align: center;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .footerCta__ttl {
    font-size: clamp(1px, 1.8181818182vw, 20px);
    text-align: left;
    width: auto;
  }
}
.footerCta__desc {
  display: none;
}
@media screen and (min-width: 768px) {
  .footerCta__desc {
    display: flex;
    align-items: center;
    align-self: center;
    gap: clamp(1px, 0.9090909091vw, 10px);
    margin-top: clamp(1px, 0.5454545455vw, 6px);
  }
}
.footerCta__desc strong {
  display: flex;
  border-radius: 1.6vw;
  background: #16A34A;
  justify-content: center;
  align-items: center;
  width: 13.8666666667vw;
  height: 8.2666666667vw;
  font-size: 4.8vw;
  font-weight: 700;
  line-height: 1.3;
}
@media screen and (min-width: 768px) {
  .footerCta__desc strong {
    border-radius: clamp(1px, 0.5454545455vw, 6px);
    width: clamp(1px, 4.7272727273vw, 52px);
    height: clamp(1px, 2.8181818182vw, 31px);
    font-size: clamp(1px, 1.6363636364vw, 18px);
  }
}
.footerCta__desc {
  font-size: 4.2666666667vw;
  font-weight: 400;
  line-height: 6.4vw;
}
@media screen and (min-width: 768px) {
  .footerCta__desc {
    font-size: clamp(1px, 2.3636363636vw, 26px);
    line-height: clamp(1px, 2.1818181818vw, 24px);
  }
}
.footerCta__buttons {
  display: flex;
  gap: 2.1333333333vw;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .footerCta__buttons {
    width: auto;
    gap: clamp(1px, 1.2727272727vw, 14px);
  }
}
.footerCta__tel, .footerCta__web {
  display: flex;
  width: 45.3333333333vw;
  height: 11.2vw;
  justify-content: center;
  align-items: center;
  gap: 1.0666666667vw;
  border-radius: 5.3333333333vw;
  color: #fff;
  font-weight: 700;
  text-align: center;
  padding: 2.4vw 0;
  font-size: 4.2666666667vw;
  line-height: 1.5;
}
@media screen and (min-width: 768px) {
  .footerCta__tel, .footerCta__web {
    width: auto;
    height: clamp(1px, 5.6363636364vw, 62px);
    gap: clamp(1px, 0.7272727273vw, 8px);
    border-radius: clamp(1px, 0.9090909091vw, 10px);
    font-size: clamp(1px, 2vw, 22px);
    line-height: clamp(1px, 2.1818181818vw, 24px);
    padding: clamp(1px, 0.5454545455vw, 6px) clamp(1px, 1.4545454545vw, 16px);
  }
}
.footerCta__tel small, .footerCta__web small {
  font-size: 3.2vw;
  font-weight: 400;
}
@media screen and (min-width: 768px) {
  .footerCta__tel small, .footerCta__web small {
    font-size: clamp(1px, 1.4545454545vw, 16px);
  }
}
.footerCta__tel p, .footerCta__web p {
  font-size: 3.7333333333vw;
  font-weight: 400;
}
@media screen and (min-width: 768px) {
  .footerCta__tel p, .footerCta__web p {
    font-size: clamp(1px, 1.2727272727vw, 14px);
  }
}
.footerCta__tel:hover, .footerCta__web:hover {
  opacity: 1;
}
.footerCta__tel {
  background: #16A34A;
  box-shadow: 1px 4px 0 0 rgb(15.9351351351, 118.0648648649, 53.6);
}
.footerCta__tel::before {
  content: "";
  background-image: url(../images/animated_phone.apng);
  background-size: contain;
  background-repeat: no-repeat;
  display: block;
  width: 5.3333333333vw;
  height: 5.3333333333vw;
}
@media screen and (min-width: 768px) {
  .footerCta__tel::before {
    width: clamp(1px, 4.3636363636vw, 48px);
    height: clamp(1px, 4.3636363636vw, 48px);
  }
}
.footerCta__web {
  background: #F08D18;
  box-shadow: 1px 4px 0 0 rgb(200.012195122, 114.2926829268, 12.987804878);
}
.footerCta__web::before {
  content: "";
  background-image: url(../images/top/cta_ico_mail.png);
  background-size: contain;
  background-repeat: no-repeat;
  display: block;
  width: 6.9333333333vw;
  height: 5.3333333333vw;
}
@media screen and (min-width: 768px) {
  .footerCta__web::before {
    width: clamp(1px, 4.9090909091vw, 54px);
    height: clamp(1px, 3.5454545455vw, 39px);
  }
}
.footerCta + footer {
  margin-bottom: 19.2vw;
}
@media screen and (min-width: 768px) {
  .footerCta + footer {
    margin-bottom: clamp(1px, 7.2727272727vw, 80px);
  }
}
.footerCta__close {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 28px;
  height: 28px;
  background: rgba(0, 0, 0, 0.5);
  border: none;
  border-radius: 50%;
  cursor: pointer;
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.3s;
}
@media screen and (min-width: 768px) {
  .footerCta__close {
    top: 12px;
    right: 12px;
  }
}
.footerCta__close:hover {
  background: rgba(32, 16, 16, 0.7);
}

.group-site-link {
  background-color: #fff;
}
@media screen and (min-width: 768px) {
  .group-site-link {
    border-top: 1px solid #eee;
  }
}
.group-site-link__inner {
  margin-left: auto;
  margin-right: auto;
  padding: 9.3333333333vw 0 10.6666666667vw;
  width: 94.6666666667vw;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .group-site-link__inner {
    padding: clamp(1px, 3.6363636364vw, 40px) 0;
    width: clamp(1px, 90.9090909091vw, 1000px);
  }
}
.group-site-link__title {
  font-size: 5.8666666667vw;
  font-weight: 700;
  line-height: 1.25;
  text-align: center;
  color: #F08D18;
}
@media screen and (min-width: 768px) {
  .group-site-link__title {
    font-size: clamp(1px, 2.1818181818vw, 24px);
  }
}
.group-site-link__container {
  margin-top: 6.4vw;
}
@media screen and (min-width: 768px) {
  .group-site-link__container {
    margin-top: clamp(1px, 3.2727272727vw, 36px);
  }
}
.group-site-link__categories {
  display: grid;
  grid-template-columns: 1fr;
}
@media screen and (min-width: 768px) {
  .group-site-link__categories {
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(1px, 2.9090909091vw, 32px) clamp(1px, 2.1818181818vw, 24px);
  }
}
.group-site-link__category {
  position: relative;
  border-bottom: 1px solid #e5e5e5;
}
@media screen and (min-width: 768px) {
  .group-site-link__category {
    margin-bottom: 0;
    border-bottom: none;
  }
}
.group-site-link__heading {
  font-size: 4.2666666667vw;
  font-style: normal;
  font-weight: 700;
  line-height: 1.75;
  position: relative;
  cursor: pointer;
  padding: 2.6666666667vw 21.3333333333vw 2.6666666667vw 4.8vw;
}
@media screen and (min-width: 768px) {
  .group-site-link__heading {
    font-size: clamp(1px, 1.4545454545vw, 16px);
    line-height: clamp(1px, 1.7181818182vw, 18.9px);
    margin-bottom: clamp(1px, 1.3636363636vw, 15px);
    padding: 0;
  }
}
.group-site-link__heading::after {
  content: "";
  position: absolute;
  right: 10px;
  top: 24%;
  display: block;
  background-image: url(../images/footer/group_site_link_ico_arrow_down.svg);
  background-size: contain;
  width: 8.5333333333vw;
  height: 8.5333333333vw;
  transform: rotate(0deg);
  transition: transform 0.3s;
}
@media screen and (min-width: 768px) {
  .group-site-link__heading::after {
    display: none;
  }
}
.group-site-link__heading.is-open::after {
  transform: rotate(-180deg);
}
.group-site-link__list {
  display: none;
  padding: 0 0 4.2666666667vw;
  line-height: 2.9333333333vw;
}
.group-site-link__list.is-open {
  display: block;
}
@media screen and (min-width: 768px) {
  .group-site-link__list {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: clamp(1px, 0.5454545455vw, 6px);
    line-height: clamp(1px, 1vw, 11px);
    padding: 0;
  }
}
.group-site-link__item {
  padding: 2.1333333333vw 4.8vw;
}
@media screen and (min-width: 768px) {
  .group-site-link__item {
    padding: 0;
  }
}
.group-site-link__item:last-child {
  margin-bottom: 0;
}
.group-site-link__link {
  color: #06C;
  font-size: 3.7333333333vw;
  font-weight: 400;
  line-height: 1em;
}
@media screen and (min-width: 768px) {
  .group-site-link__link {
    font-size: clamp(1px, 1.2727272727vw, 14px);
  }
}

/**********************************************
CSS設計規則は、BEMとOOCSSを使ってClassを定義すること


BEMとは、Block　Element　Modifier　の略で、

Block -> 大きな括り
Element -> ブロックの中の要素
Modifier -> ブロックやエレメントの変化

block__element--modifier の形でクラス名を定義する

各単語は キャメルケース camelCase で
先頭以外の単語の最初を大文字にする


OOCSSとは、Object Oriented CSSの略で、
オブジェクト指向を意味し、使い回せるところは
なるべく使い回すようにする

独自で使い回せるクラスを定義する場合は、
ケバブケース kebab-case で
ハイフンで各単語の連結を行う


※ IDの定義は、上記と異なり、キャメルケース camelCase で
  必要に応じて定義すること
***********************************************/
/**********************************************
** ファーストビュー
***********************************************/
.fv {
  background-color: #F08D18;
  color: #fff;
  text-align: center;
  position: relative;
  height: 141.6vw;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .fv {
    height: clamp(1px, 50.0909090909vw, 551px);
  }
}
.fv__inr {
  width: 94.6666666667vw;
  height: 100%;
  display: flex;
  gap: 6.4vw;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  margin: 0 auto;
  padding: 8vw 0 0 0;
  position: relative;
}
@media screen and (min-width: 768px) {
  .fv__inr {
    flex-direction: row;
    align-items: start;
    width: clamp(1px, 79.5454545455vw, 875px);
    gap: clamp(1px, 1.8181818182vw, 20px);
    padding: clamp(1px, 5.4545454545vw, 60px) 0 0 0;
  }
}
.fv__inr::after {
  content: "";
  background-repeat: no-repeat;
  background-size: contain;
  display: block;
  position: absolute;
  background-image: url(../images/top/fv_result_bg_sp.png);
  width: 85.8666666667vw;
  height: 29.3333333333vw;
  bottom: -1.8666666667vw;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (min-width: 768px) {
  .fv__inr::after {
    background-image: url(../images/top/fv_title_bg.png);
    width: clamp(1px, 34.0909090909vw, 375px);
    height: clamp(1px, 18vw, 198px);
    left: clamp(1px, 0.9090909091vw, 10px);
    transform: translateX(0);
  }
}
.fv__title {
  font-style: normal;
  font-weight: 700;
  line-height: 1.3;
  font-size: 13.8666666667vw;
}
@media screen and (min-width: 768px) {
  .fv__title {
    width: clamp(1px, 38.6363636364vw, 425px);
    font-weight: 600;
    font-size: clamp(1px, 6.1818181818vw, 68px);
  }
}
.fv__title span {
  font-size: 9.0666666667vw;
}
@media screen and (min-width: 768px) {
  .fv__title span {
    font-size: clamp(1px, 4vw, 44px);
  }
}
.fv__title small {
  position: relative;
  display: flex;
  width: 52.5333333333vw;
  padding: 2.1333333333vw 0;
  justify-content: center;
  align-items: center;
  gap: 10px;
  border-radius: 8vw;
  background: #344B95;
  font-size: 4.8vw;
  font-weight: 400;
  line-height: 1.3;
  margin: 0 auto 32px auto;
}
@media screen and (min-width: 768px) {
  .fv__title small {
    width: clamp(1px, 29.2727272727vw, 322px);
    padding: clamp(1px, 0.7272727273vw, 8px) clamp(1px, 2.7272727273vw, 30px);
    border-radius: clamp(1px, 2.7272727273vw, 30px);
    font-size: clamp(1px, 2.7272727273vw, 30px);
    margin: 0 auto clamp(1px, 2.9090909091vw, 32px) auto;
  }
}
.fv__title small::before {
  content: "";
  background-image: url(../images/top/fv_title_ico_triangle.svg);
  background-size: contain;
  display: block;
  width: 3.7333333333vw;
  height: 2.6666666667vw;
  position: absolute;
  bottom: -2.4vw;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (min-width: 768px) {
  .fv__title small::before {
    width: clamp(1px, 2.1818181818vw, 24px);
    height: clamp(1px, 1.5454545455vw, 17px);
    bottom: clamp(-16px, -1.4545454545vw, -1px);
  }
}
.fv__result {
  display: block;
  height: 100%;
}
@media screen and (min-width: 768px) {
  .fv__result {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: clamp(1px, 1.8181818182vw, 20px);
    padding-bottom: clamp(1px, 1.8181818182vw, 20px);
  }
}
@media screen and (min-width: 768px) {
  .fv__result::before {
    content: "";
    background-image: url(../images/top/fv_result_bg.png);
    background-repeat: no-repeat;
    background-size: contain;
    display: block;
    width: clamp(1px, 30.3636363636vw, 334px);
    height: clamp(1px, 7.0909090909vw, 78px);
  }
}
.fv__result > ul {
  display: grid;
  align-items: center;
  justify-content: center;
  grid-template-columns: 1fr 1fr;
  gap: 2.6666666667vw;
}
@media screen and (min-width: 768px) {
  .fv__result > ul {
    width: clamp(1px, 39.0909090909vw, 430px);
    flex-flow: row;
    gap: clamp(1px, 0.9090909091vw, 10px);
  }
}
.fv__result > ul > li {
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 2.6666666667vw;
  font-style: normal;
  font-weight: 700;
  line-height: 1.2;
  white-space: nowrap;
}
@media screen and (min-width: 768px) {
  .fv__result > ul > li {
    max-width: clamp(1px, 19.0909090909vw, 210px);
    font-size: clamp(1px, 1.0909090909vw, 12px);
  }
}
.fv__result > ul > li::before, .fv__result > ul > li::after {
  content: "";
  background-repeat: no-repeat;
  background-size: contain;
  width: 6.4vw;
  height: 13.8666666667vw;
  aspect-ratio: 6/13;
}
@media screen and (min-width: 768px) {
  .fv__result > ul > li::before, .fv__result > ul > li::after {
    width: clamp(1px, 3.0909090909vw, 34px);
    height: clamp(1px, 6.7272727273vw, 74px);
    aspect-ratio: 17/37;
  }
}
.fv__result > ul > li::before {
  background-image: url(../images/top/result_deco_l.svg);
}
.fv__result > ul > li::after {
  background-image: url(../images/top/result_deco_r.svg);
}
.fv__result > ul > li strong {
  font-size: 4.2666666667vw;
}
@media screen and (min-width: 768px) {
  .fv__result > ul > li strong {
    font-size: clamp(1px, 1.8181818182vw, 20px);
  }
}
.fv__result > ul > li span {
  font-size: 6.4vw;
}
@media screen and (min-width: 768px) {
  .fv__result > ul > li span {
    font-size: clamp(1px, 3.0909090909vw, 34px);
  }
}
.fv__result > ul > li:first-of-type {
  grid-column: 1/3;
}
@media screen and (min-width: 768px) {
  .fv__result > ul > li:first-of-type {
    margin: 0 auto;
    max-width: clamp(1px, 19.0909090909vw, 210px);
  }
}
.fv__result > ul > li:first-of-type::before, .fv__result > ul > li:first-of-type::after {
  width: 10.1333333333vw;
  height: 22.1333333333vw;
  aspect-ratio: 38/83;
}
@media screen and (min-width: 768px) {
  .fv__result > ul > li:first-of-type::before, .fv__result > ul > li:first-of-type::after {
    width: clamp(1px, 5.2727272727vw, 58px);
    height: clamp(1px, 11.5454545455vw, 127px);
    aspect-ratio: 58/127;
  }
}
.fv__result > ul > li:first-of-type strong {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #fff;
  color: #344B95;
  font-size: 4.2666666667vw;
  font-weight: 600;
  line-height: 1.2;
  margin: 0 auto;
  width: 32vw;
  height: 6.1333333333vw;
}
@media screen and (min-width: 768px) {
  .fv__result > ul > li:first-of-type strong {
    width: clamp(1px, 14.7272727273vw, 162px);
    height: clamp(1px, 2.7272727273vw, 30px);
    font-size: clamp(1px, 2vw, 22px);
  }
}
.fv__result > ul > li:first-of-type span {
  display: block;
  font-size: 13.8666666667vw;
  font-style: normal;
  font-weight: 600;
  line-height: 1.2;
  margin-right: -2.1333333333vw;
  position: relative;
}
@media screen and (min-width: 768px) {
  .fv__result > ul > li:first-of-type span {
    font-size: clamp(1px, 6.5454545455vw, 72px);
    margin-right: clamp(-8px, -0.7272727273vw, -1px);
  }
}
.fv__result > ul > li:first-of-type span::after {
  content: "※";
  font-size: 2.6666666667vw;
  font-weight: 600;
  line-height: 1.2;
  position: absolute;
  top: 0.5333333333vw;
  right: -1.3333333333vw;
}
@media screen and (min-width: 768px) {
  .fv__result > ul > li:first-of-type span::after {
    top: clamp(1px, 0.4545454545vw, 5px);
    right: clamp(-15px, -1.3636363636vw, -1px);
    font-size: clamp(1px, 1.4545454545vw, 16px);
  }
}

/**********************************************
** 状況の確認
***********************************************/
.checkStatus {
  background: #F08D18;
  padding: 12vw 0;
}
@media screen and (min-width: 768px) {
  .checkStatus {
    padding: clamp(1px, 4.5454545455vw, 50px) 0;
  }
}
.checkStatus__inr {
  width: 94.6666666667vw;
  text-align: center;
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.6666666667vw;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .checkStatus__inr {
    width: clamp(1px, 80vw, 880px);
    grid-template-columns: 1fr 1fr;
    gap: clamp(1px, 3.6363636364vw, 40px) clamp(1px, 3.2727272727vw, 36px);
  }
}
.checkStatus__title {
  font-size: 5.8666666667vw;
  font-style: normal;
  font-weight: 700;
  line-height: 1.25;
  color: #fff;
}
@media screen and (min-width: 768px) {
  .checkStatus__title {
    font-size: clamp(1px, 2.1818181818vw, 24px);
    grid-column: 1/3;
  }
}
.checkStatus__contact {
  width: 100%;
  height: 28.5333333333vw;
  border-radius: 10px;
  background: #FFF;
  padding: 4.2666666667vw 0 4.2666666667vw 8vw;
  display: flex;
  flex-flow: column;
  align-items: start;
  justify-content: flex-start;
  gap: 2.6666666667vw;
  margin-top: 3.7333333333vw;
  cursor: pointer;
}
@media screen and (min-width: 768px) {
  .checkStatus__contact {
    width: clamp(1px, 35.2727272727vw, 388px);
    height: clamp(1px, 20.6363636364vw, 227px);
    border-radius: clamp(1px, 0.9090909091vw, 10px);
    padding: clamp(1px, 2.7272727273vw, 30px) 0 0;
    align-items: center;
    gap: clamp(1px, 2.7272727273vw, 30px);
    margin-top: 0;
  }
}
.checkStatus__contactTit {
  width: 81.3333333333vw;
  font-size: 4.8vw;
  font-style: normal;
  font-weight: 700;
  line-height: 1.25;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4.2666666667vw;
  padding: 0;
}
@media screen and (min-width: 768px) {
  .checkStatus__contactTit {
    width: auto;
    font-size: clamp(1px, 1.6363636364vw, 18px);
    line-height: clamp(1px, 2.0454545455vw, 22.5px);
    gap: clamp(1px, 0.9090909091vw, 10px);
    padding: clamp(1px, 0.4545454545vw, 5px) 0;
  }
}
.checkStatus__contactTit::before {
  content: "";
  background-image: url(../images/top/check_status_ico_contact.svg);
  background-size: contain;
  display: block;
  width: 8vw;
  height: 8.8vw;
}
@media screen and (min-width: 768px) {
  .checkStatus__contactTit::before {
    width: clamp(1px, 2.7272727273vw, 30px);
    height: clamp(1px, 3vw, 33px);
  }
}
.checkStatus__contactTit::after {
  content: "";
  background-image: url(../images/top/check_status_ico_arrow_green.svg);
  background-size: contain;
  display: block;
  width: 4.8vw;
  height: 4.8vw;
  margin-left: auto;
}
@media screen and (min-width: 768px) {
  .checkStatus__contactTit::after {
    width: clamp(1px, 1.6363636364vw, 18px);
    height: clamp(1px, 1.6363636364vw, 18px);
    margin-left: 0;
  }
}
.checkStatus__contactDesc {
  color: #888;
  font-size: 3.2vw;
  font-weight: 400;
  line-height: 1.33;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: left;
}
@media screen and (min-width: 768px) {
  .checkStatus__contactDesc {
    font-size: clamp(1px, 1.4545454545vw, 16px);
    line-height: 1.5;
  }
}
.checkStatus__list {
  display: grid;
  grid-template-columns: 1fr;
  justify-content: space-between;
  gap: 2.6666666667vw;
}
@media screen and (min-width: 768px) {
  .checkStatus__list {
    height: clamp(1px, 20.6363636364vw, 227px);
    gap: clamp(1px, 0.9090909091vw, 10px);
  }
}
.checkStatus__list li > a,
.checkStatus__list li > p {
  width: 100%;
  height: 100%;
  display: flex;
  padding: 4.2666666667vw 6.9333333333vw;
  align-items: center;
  justify-content: flex-start;
  gap: 2.6666666667vw;
  border-radius: 8vw;
  background: #FFF;
  font-size: 4.2666666667vw;
  font-weight: 700;
  line-height: 6vw;
  cursor: pointer;
}
@media screen and (min-width: 768px) {
  .checkStatus__list li > a,
  .checkStatus__list li > p {
    padding: clamp(1px, 1.8181818182vw, 20px) clamp(1px, 6.7272727273vw, 74px);
    gap: clamp(1px, 0.9090909091vw, 10px);
    border-radius: clamp(1px, 3.6363636364vw, 40px);
    font-size: clamp(1px, 1.4545454545vw, 16px);
    line-height: clamp(1px, 2.0454545455vw, 22.5px);
  }
}
.checkStatus__list li > a::before,
.checkStatus__list li > p::before {
  content: "";
  background-size: contain;
  display: block;
}
.checkStatus__list li > a:after,
.checkStatus__list li > p:after {
  content: "";
  background-image: url(../images/top/check_status_ico_arrow_orange.svg);
  background-size: contain;
  display: block;
  width: 4.8vw;
  height: 4.8vw;
  margin-left: auto;
}
@media screen and (min-width: 768px) {
  .checkStatus__list li > a:after,
  .checkStatus__list li > p:after {
    width: clamp(1px, 1.6363636364vw, 18px);
    height: clamp(1px, 1.6363636364vw, 18px);
  }
}
.checkStatus__list li > a.--cost::before,
.checkStatus__list li > p.--cost::before {
  background-image: url(../images/top/check_status_ico_cost.svg);
  width: 6.6666666667vw;
  height: 6.6666666667vw;
}
@media screen and (min-width: 768px) {
  .checkStatus__list li > a.--cost::before,
  .checkStatus__list li > p.--cost::before {
    width: clamp(1px, 2.2727272727vw, 25px);
    height: clamp(1px, 2.2727272727vw, 25px);
  }
}
.checkStatus__list li > a.--self::before,
.checkStatus__list li > p.--self::before {
  background-image: url(../images/top/check_status_ico_self.svg);
  width: 6.6666666667vw;
  height: 5.0666666667vw;
}
@media screen and (min-width: 768px) {
  .checkStatus__list li > a.--self::before,
  .checkStatus__list li > p.--self::before {
    width: clamp(1px, 2.2727272727vw, 25px);
    height: clamp(1px, 1.7272727273vw, 19px);
  }
}
.checkStatus__list li > a.--learn::before,
.checkStatus__list li > p.--learn::before {
  background-image: url(../images/top/check_status_ico_learn.svg);
  width: 7.2vw;
  height: 7.2vw;
}
@media screen and (min-width: 768px) {
  .checkStatus__list li > a.--learn::before,
  .checkStatus__list li > p.--learn::before {
    width: clamp(1px, 2.4545454545vw, 27px);
    height: clamp(1px, 2.4545454545vw, 27px);
  }
}
.checkStatusModal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.6);
  z-index: 1000;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
.checkStatusModal__inr {
  position: relative;
  width: 94.6666666667vw;
  text-align: center;
  margin: 0 auto;
  padding: 4vw 0 5.3333333333vw;
  border-radius: 2.6666666667vw;
  background: #FFF7EC;
}
@media screen and (min-width: 768px) {
  .checkStatusModal__inr {
    width: 400px;
    padding: 15px 0 20px;
    border-radius: 10px;
    background: #FFF7EC;
  }
}
.checkStatusModal__title {
  font-size: 5.3333333333vw;
  font-style: normal;
  font-weight: 700;
  line-height: 1.5;
  margin-top: 2.4vw;
  padding-bottom: 2.6666666667vw;
  border-bottom: 1px solid #F08D18;
}
@media screen and (min-width: 768px) {
  .checkStatusModal__title {
    font-size: 20px;
    margin-top: 9px;
    padding-bottom: 10px;
  }
}
.checkStatusModal__title strong {
  font-weight: 700;
  color: #F08D18;
}
.checkStatusModal__title span {
  position: relative;
}
.checkStatusModal__title span::before {
  content: "・";
  position: absolute;
  top: -1.15em;
  left: 50%;
  transform: translateX(-50%);
}
.checkStatusModal__check {
  position: relative;
  display: flex;
  width: 58.6666666667vw;
  height: 10.6666666667vw;
  padding-bottom: 1.6vw;
  align-items: center;
  justify-content: center;
  color: #232B39;
  background-image: url(../images/top/check_status_modal_ico_speech_bubble.svg);
  background-size: contain;
  background-repeat: no-repeat;
  font-size: 3.7333333333vw;
  font-style: normal;
  font-weight: 400;
  margin: 5.3333333333vw auto 2.1333333333vw;
}
@media screen and (min-width: 768px) {
  .checkStatusModal__check {
    width: 220px;
    height: 40px;
    padding-bottom: 6px;
    font-size: 14px;
    margin: 20px auto 8px;
  }
}
.checkStatusModal__txt {
  font-size: 4.8vw;
  font-weight: 400;
  line-height: 1.6;
  margin: 0 0 0.8vw 0;
}
@media screen and (min-width: 768px) {
  .checkStatusModal__txt {
    font-size: 18px;
    margin: 0 0 3px 0;
  }
}
.checkStatusModal__txt small {
  font-size: 3.7333333333vw;
  font-weight: 400;
}
@media screen and (min-width: 768px) {
  .checkStatusModal__txt small {
    font-size: 14px;
  }
}
.checkStatusModal__txt strong {
  font-size: 4.8vw;
  font-weight: 700;
  display: inline-block;
  margin-bottom: 4px;
}
@media screen and (min-width: 768px) {
  .checkStatusModal__txt strong {
    font-size: 18px;
  }
}
.checkStatusModal__btnLink {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 2.1333333333vw;
  border-radius: 5.3333333333vw;
  color: #fff;
  font-size: 5.8666666667vw;
  font-weight: 700;
  line-height: 6.4vw;
  margin: 2.6666666667vw 2.6666666667vw 4.2666666667vw 2.6666666667vw;
  height: 21.0666666667vw;
  padding: 0 1.6vw;
  background: #F08D18;
  box-shadow: 0 6px 0 0 rgb(200.012195122, 114.2926829268, 12.987804878);
}
@media screen and (min-width: 768px) {
  .checkStatusModal__btnLink {
    gap: 8px;
    border-radius: 20px;
    font-size: 22px;
    line-height: 24px;
    margin: 10px 32px 16px 32px;
    height: 79px;
    padding: 0 6px;
  }
}
.checkStatusModal__btnLink span {
  display: flex;
  padding: 2.1333333333vw 3.7333333333vw;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 2.6666666667vw;
  border-radius: 2.6666666667vw;
  border: 1px solid #FFF;
  font-size: 5.3333333333vw;
}
@media screen and (min-width: 768px) {
  .checkStatusModal__btnLink span {
    padding: 8px 14px;
    gap: 10px;
    border-radius: 10px;
    font-size: 20px;
  }
}
.checkStatusModal__btnLink::after {
  content: "";
  background-image: url(../images/top/check_status_modal_txt_bg1.png);
  background-size: contain;
  display: block;
  width: 16vw;
  height: 18.9333333333vw;
  position: absolute;
  top: -18.9333333333vw;
  left: 6vw;
}
@media screen and (min-width: 768px) {
  .checkStatusModal__btnLink::after {
    width: 60px;
    height: 71px;
    left: 22.5px;
    top: -71px;
  }
}
.checkStatusModal__btnLink::before {
  content: "";
  background-image: url(../images/top/check_status_modal_txt_bg2.png);
  background-size: contain;
  display: block;
  width: 16vw;
  height: 18.9333333333vw;
  position: absolute;
  top: -18.9333333333vw;
  right: 6vw;
}
@media screen and (min-width: 768px) {
  .checkStatusModal__btnLink::before {
    width: 60px;
    height: 71px;
    right: 22.5px;
    top: -71px;
  }
}
.checkStatusModal__btnLink:hover {
  opacity: 1;
  color: #fff;
}
.checkStatusModal__note {
  text-align: center;
  font-size: 2.6666666667vw;
  font-style: normal;
  font-weight: 400;
  line-height: 1.5;
}
.checkStatusModal__note > a {
  text-decoration: underline;
}
@media screen and (min-width: 768px) {
  .checkStatusModal__note {
    font-size: 10px;
  }
}
.checkStatusModal__close {
  position: absolute;
  top: 4vw;
  right: 6.6666666667vw;
  width: 5.6vw;
  height: 5.6vw;
  border-radius: 2px;
  border: 1px solid #B2B2B2;
  background: #FFF;
  cursor: pointer;
}
@media screen and (min-width: 768px) {
  .checkStatusModal__close {
    top: 15px;
    right: 25px;
    width: 21px;
    height: 21px;
  }
}
.checkStatusModal__closeLine {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 4.2666666667vw;
  height: 1px;
  background: #B2B2B2;
  transform: translate(-50%, -50%) rotate(45deg);
  border-radius: 1px;
}
@media screen and (min-width: 768px) {
  .checkStatusModal__closeLine {
    width: 16px;
    height: 1px;
  }
}
.checkStatusModal__closeLine:nth-of-type(2) {
  transform: translate(-50%, -50%) rotate(-45deg);
}
.checkStatusModal__closeOuter {
  position: absolute;
  top: -6.6666666667vw;
  right: 50%;
  transform: translateX(50%);
  display: flex;
  color: #fff;
  font-size: 3.7333333333vw;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (min-width: 768px) {
  .checkStatusModal__closeOuter {
    top: -25px;
    font-size: 14px;
  }
}
.checkStatusModal__closeOuter > div {
  position: relative;
  width: 5.3333333333vw;
}
@media screen and (min-width: 768px) {
  .checkStatusModal__closeOuter > div {
    width: 20px;
  }
}
.checkStatusModal__closeOuterLine {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 3.7333333333vw;
  height: 1px;
  background: #fff;
  transform: translate(-50%, -50%) rotate(45deg);
  border-radius: 1px;
}
@media screen and (min-width: 768px) {
  .checkStatusModal__closeOuterLine {
    width: 14px;
    height: 1px;
  }
}
.checkStatusModal__closeOuterLine:nth-of-type(2) {
  transform: translate(-50%, -50%) rotate(-45deg);
}

/**********************************************
** Top Diagnosis Banner
***********************************************/
.topDiagnosisBanner {
  padding: 1.6vw 0;
}
@media screen and (min-width: 768px) {
  .topDiagnosisBanner {
    padding: clamp(1px, 4.5454545455vw, 50px) 0;
  }
}
.topDiagnosisBanner__inr {
  width: 94.6666666667vw;
  margin: 0 auto;
  border: 1px solid #F08D18;
}
@media screen and (min-width: 768px) {
  .topDiagnosisBanner__inr {
    width: clamp(1px, 90.9090909091vw, 1000px);
  }
}
.topDiagnosisBanner a {
  display: block;
  width: 100%;
}
.topDiagnosisBanner img {
  width: 100%;
  height: auto;
  display: block;
}

/**********************************************
** 士業を探す
***********************************************/
.shigyoSearch {
  padding: 12.2666666667vw 0 9.6vw;
}
@media screen and (min-width: 768px) {
  .shigyoSearch {
    padding: clamp(1px, 4.5454545455vw, 50px) 0;
  }
}
.shigyoSearch__inr {
  width: 94.6666666667vw;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .shigyoSearch__inr {
    width: clamp(1px, 90.9090909091vw, 1000px);
  }
}
.shigyoSearch__title {
  font-size: 5.8666666667vw;
  font-weight: 700;
  line-height: 1.25;
  text-align: center;
  color: #F08D18;
}
@media screen and (min-width: 768px) {
  .shigyoSearch__title {
    font-size: clamp(1px, 2.1818181818vw, 24px);
  }
}
.shigyoSearch__listWrap {
  margin-top: 6.4vw;
  width: 100%;
  position: relative;
  background: #FFF;
  position: relative;
}
@media screen and (min-width: 768px) {
  .shigyoSearch__listWrap {
    margin-top: clamp(1px, 3.2727272727vw, 36px);
  }
}
.shigyoSearch__tabs {
  position: relative;
  width: 100%;
  height: 10.4vw;
}
@media screen and (min-width: 768px) {
  .shigyoSearch__tabs {
    height: clamp(1px, 4.0909090909vw, 45px);
  }
}
.shigyoSearch__tab {
  position: absolute;
  top: 0;
  left: 0;
  width: auto;
  height: 10.4vw;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: auto;
  border-radius: 2.6666666667vw 5.3333333333vw 0 0;
  border-top: 1px solid #FFF;
  border-right: 1px solid #FFF;
  border-left: 1px solid #FFF;
  background: #F08D18;
  color: #FFF;
  font-size: 4.5333333333vw;
  font-weight: 700;
  line-height: 5.6vw;
  padding: 0 5.3333333333vw 0 6.6666666667vw;
  cursor: pointer;
}
@media screen and (min-width: 768px) {
  .shigyoSearch__tab {
    width: clamp(1px, 32.7272727273vw, 360px);
    height: clamp(1px, 4.2727272727vw, 47px);
    font-size: clamp(1px, 1.8181818182vw, 20px);
    line-height: clamp(1px, 1.9090909091vw, 21px);
    border-radius: clamp(1px, 0.9090909091vw, 10px) clamp(1px, 1.8181818182vw, 20px) 0 0;
    font-size: clamp(1px, 1.8181818182vw, 20px);
    line-height: clamp(1px, 1.9090909091vw, 21px);
    padding: 0;
  }
}
.shigyoSearch__tab:nth-of-type(1) {
  left: -1px;
  z-index: 4;
  padding-left: 4vw;
}
@media screen and (min-width: 768px) {
  .shigyoSearch__tab:nth-of-type(1) {
    padding-left: 0;
  }
}
.shigyoSearch__tab:nth-of-type(2) {
  z-index: 3;
  left: 62%;
  transform: translateX(-50%);
}
@media screen and (min-width: 768px) {
  .shigyoSearch__tab:nth-of-type(2) {
    left: 50%;
  }
}
.shigyoSearch__tab:nth-of-type(3) {
  z-index: 2;
  left: auto;
  right: -1px;
}
.shigyoSearch__list {
  display: none;
  width: 100%;
  height: auto;
  padding-top: 0;
  position: relative;
  background-color: #fff;
  border-radius: 0 0 2.6666666667vw 2.6666666667vw;
  border-right: 2px solid #F08D18;
  border-bottom: 2px solid #F08D18;
  border-left: 2px solid #F08D18;
}
@media screen and (min-width: 768px) {
  .shigyoSearch__list {
    padding-top: clamp(1px, 0.9090909091vw, 10px);
    border-radius: 0 0 clamp(1px, 1.8181818182vw, 20px) clamp(1px, 1.8181818182vw, 20px);
  }
}
.shigyoSearch__listCont {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
}
@media screen and (min-width: 768px) {
  .shigyoSearch__listCont {
    gap: clamp(1px, 0.4545454545vw, 5px);
  }
}
.shigyoSearch__listCont:last-of-type > label {
  border-bottom: none;
}
.shigyoSearch__listCont:last-of-type .shigyoSearch__listLink {
  border-bottom: none;
}
@media screen and (min-width: 768px) {
  .shigyoSearch__listCont:last-of-type .shigyoSearch__listLink {
    display: inline-flex;
    flex-direction: row;
  }
}
.shigyoSearch__listTit {
  display: flex;
  width: 100%;
  height: 13.8666666667vw;
  padding: 0 4.8vw;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid #F08D18;
  cursor: pointer;
  font-size: 4.2666666667vw;
  line-height: 1.75;
  font-weight: 700;
}
.shigyoSearch__listTit::after {
  content: "";
  background-image: url(../images/top/shigyo_search_ico_arrow_up.svg);
  background-size: contain;
  display: block;
  width: 8.5333333333vw;
  height: 8.5333333333vw;
  transform: rotate(180deg);
  transition: transform 0.2s ease-in-out;
}
.shigyoSearch__listLink {
  width: 100%;
  display: none;
  align-items: center;
  flex-wrap: wrap;
  align-self: stretch;
  border-bottom: 1px solid #CCC;
}
@media screen and (min-width: 768px) {
  .shigyoSearch__listLink {
    display: flex;
    padding: clamp(1px, 1.3636363636vw, 15px) clamp(1px, 2.7272727273vw, 30px);
    gap: clamp(1px, 0.9090909091vw, 10px) clamp(1px, 2.7272727273vw, 30px);
  }
}
.shigyoSearch__listLink li {
  color: #1BA0E5;
  text-align: center;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
  width: 100%;
  height: 12.8vw;
}
@media screen and (min-width: 768px) {
  .shigyoSearch__listLink li {
    color: #0263B5;
    font-size: clamp(1px, 1.4545454545vw, 16px);
    width: auto;
    height: auto;
  }
}
.shigyoSearch__listLink li > a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 10.6666666667vw;
  width: 100%;
  height: 12.8vw;
  border-bottom: 1px solid #CCC;
}
@media screen and (min-width: 768px) {
  .shigyoSearch__listLink li > a {
    display: inline-block;
    width: auto;
    height: auto;
    padding: 0;
    border-bottom: none;
  }
}
.shigyoSearch__listLink li > a::after {
  content: "";
  background-image: url(../images/top/shigyo_search_ico_arrow_right.svg);
  background-size: contain;
  display: block;
  width: 8.5333333333vw;
  height: 8.5333333333vw;
}
@media screen and (min-width: 768px) {
  .shigyoSearch__listLink li > a::after {
    display: none;
  }
}
.shigyoSearch__listLink li:last-of-type > a {
  border-bottom: none;
}
.shigyoSearch__input {
  display: none;
}
.shigyoSearch__input:nth-of-type(1):checked ~ .shigyoSearch__tabs label:nth-of-type(1), .shigyoSearch__input:nth-of-type(2):checked ~ .shigyoSearch__tabs label:nth-of-type(2), .shigyoSearch__input:nth-of-type(3):checked ~ .shigyoSearch__tabs label:nth-of-type(3) {
  background: #FFF;
  color: #F08D18;
  border-top: 2px solid #F08D18;
  border-right: 2px solid #F08D18;
  border-left: 2px solid #F08D18;
}
.shigyoSearch__input:nth-of-type(1):checked ~ .shigyoSearch__tabs label:nth-of-type(1) {
  left: 0;
}
.shigyoSearch__input:nth-of-type(2):checked ~ .shigyoSearch__tabs label:nth-of-type(2) {
  z-index: 5;
}
.shigyoSearch__input:nth-of-type(3):checked ~ .shigyoSearch__tabs label:nth-of-type(3) {
  right: 0;
  z-index: 5;
}
.shigyoSearch__input:nth-of-type(1):checked ~ .shigyoSearch__lists .shigyoSearch__list:nth-of-type(1), .shigyoSearch__input:nth-of-type(2):checked ~ .shigyoSearch__lists .shigyoSearch__list:nth-of-type(2), .shigyoSearch__input:nth-of-type(3):checked ~ .shigyoSearch__lists .shigyoSearch__list:nth-of-type(3) {
  display: block;
}
.shigyoSearch__input:checked + label {
  border-bottom: 1px solid #F08D18;
}
.shigyoSearch__input:checked + label:after {
  transform: rotate(0deg);
}
.shigyoSearch__input:checked + label + .shigyoSearch__listLink {
  display: flex;
}

/**********************************************
** 注目の専門家をピックアップ[PR]
***********************************************/
.shigyoPickup {
  padding: 9.6vw 0;
}
@media screen and (min-width: 768px) {
  .shigyoPickup {
    padding: clamp(1px, 4.5454545455vw, 50px) 0;
  }
}
.shigyoPickup__inr {
  width: 97.3333333333vw;
  margin: 0 0 0 2.6666666667vw;
}
@media screen and (min-width: 768px) {
  .shigyoPickup__inr {
    width: clamp(1px, 90.9090909091vw, 1000px);
    margin: 0 auto;
  }
}
.shigyoPickup__title {
  font-size: 5.8666666667vw;
  font-weight: 700;
  line-height: 1.25;
  text-align: center;
  color: #F08D18;
  padding-right: 2.6666666667vw;
}
@media screen and (min-width: 768px) {
  .shigyoPickup__title {
    font-size: clamp(1px, 2.1818181818vw, 24px);
    padding-right: 0;
  }
}
.shigyoPickup__lists {
  padding: 6.4vw 2.6666666667vw 6.4vw 0;
  display: flex;
  gap: 6.4vw;
  overflow-x: scroll;
  overflow-y: hidden;
  scrollbar-color: #F08D18 #cccccc;
  scrollbar-width: thin;
}
@media screen and (min-width: 768px) {
  .shigyoPickup__lists {
    padding: clamp(1px, 3.2727272727vw, 36px) 0;
    gap: clamp(1px, 0.6363636364vw, 7px);
  }
}
.shigyoPickup__list {
  position: relative;
  background: #FFF;
  border-radius: 2.6666666667vw;
  border: 1px solid #CCC;
  display: flex;
  padding: 2.6666666667vw 3.7333333333vw;
  flex-direction: column;
  align-items: flex-start;
  gap: 2.6666666667vw;
  width: 83.4666666667vw;
  min-width: 83.4666666667vw;
  max-width: 83.4666666667vw;
}
@media screen and (min-width: 768px) {
  .shigyoPickup__list {
    border-radius: clamp(1px, 0.9090909091vw, 10px);
    padding: clamp(1px, 1.8181818182vw, 20px) clamp(1px, 1.2727272727vw, 14px) clamp(1px, 0.9090909091vw, 10px) clamp(1px, 1.2727272727vw, 14px);
    gap: clamp(1px, 0.9090909091vw, 10px);
    width: clamp(1px, 30.6363636364vw, 337px);
    min-width: clamp(1px, 30.6363636364vw, 337px);
    max-width: clamp(1px, 30.6363636364vw, 337px);
  }
}
.shigyoPickup__listLink {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}
.shigyoPickup__listHead {
  display: flex;
  align-items: center;
  gap: 2.6666666667vw;
  align-self: stretch;
}
@media screen and (min-width: 768px) {
  .shigyoPickup__listHead {
    gap: clamp(1px, 0.9090909091vw, 10px);
  }
}
.shigyoPickup__listHead img {
  width: 20.5333333333vw;
  height: 20.5333333333vw;
  border-radius: 2.1333333333vw;
  object-fit: cover;
}
@media screen and (min-width: 768px) {
  .shigyoPickup__listHead img {
    width: clamp(1px, 8.9090909091vw, 98px);
    height: clamp(1px, 8.9090909091vw, 98px);
    border-radius: clamp(1px, 0.7272727273vw, 8px);
  }
}
.shigyoPickup__listTit {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1.0666666667vw;
}
@media screen and (min-width: 768px) {
  .shigyoPickup__listTit {
    gap: clamp(1px, 0.9090909091vw, 10px);
  }
}
.shigyoPickup__listTit h3 {
  font-size: 4.2666666667vw;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (min-width: 768px) {
  .shigyoPickup__listTit h3 {
    font-size: clamp(1px, 1.4545454545vw, 16px);
    line-height: clamp(1px, 2.1818181818vw, 24px);
  }
}
.shigyoPickup__listReview {
  display: flex;
  align-items: center;
  gap: 2.4vw;
  font-size: 3.2vw;
  font-weight: 700;
  line-height: 4.2666666667vw;
}
@media screen and (min-width: 768px) {
  .shigyoPickup__listReview {
    gap: clamp(1px, 0.8181818182vw, 9px);
    font-size: clamp(1px, 1.2727272727vw, 14px);
    line-height: clamp(1px, 1.4545454545vw, 16px);
  }
}
.shigyoPickup__listReview .--score {
  display: flex;
}
.shigyoPickup__listReview .--count {
  font-weight: 400;
}
.shigyoPickup__listReview i {
  font-size: 3.7333333333vw;
  color: #F08D18;
}
@media screen and (min-width: 768px) {
  .shigyoPickup__listReview i {
    font-size: clamp(1px, 1.4545454545vw, 16px);
  }
}
.shigyoPickup__listReview a {
  position: relative;
  color: #1BA0E5;
  text-decoration: underline;
  z-index: 2;
}
.shigyoPickup__list p {
  font-size: 3.7333333333vw;
  font-weight: 400;
  line-height: 4.2666666667vw;
}
@media screen and (min-width: 768px) {
  .shigyoPickup__list p {
    font-size: clamp(1px, 1.2727272727vw, 14px);
    line-height: clamp(1px, 2.1818181818vw, 24px);
  }
}
.shigyoPickup__listArea {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  width: 100%;
  margin-bottom: -0.8vw;
}
@media screen and (min-width: 768px) {
  .shigyoPickup__listArea {
    margin-bottom: 0;
  }
}
.shigyoPickup__listArea > strong {
  color: #F08D18;
  font-weight: 700;
  margin-bottom: 0;
}

/**********************************************
** 相談内容から専門家を探す
***********************************************/
.tagSearch {
  padding: 9.6vw 0;
}
@media screen and (min-width: 768px) {
  .tagSearch {
    background-color: #F08D18;
    padding: clamp(1px, 5vw, 55px) 0;
  }
}
.tagSearch__inr {
  width: 94.6666666667vw;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .tagSearch__inr {
    width: clamp(1px, 90.9090909091vw, 1000px);
  }
}
.tagSearch__title {
  font-size: 5.8666666667vw;
  font-weight: 700;
  line-height: 1.25;
  text-align: center;
  color: #F08D18;
}
@media screen and (min-width: 768px) {
  .tagSearch__title {
    font-size: clamp(1px, 2.1818181818vw, 24px);
    color: #fff;
  }
}
.tagSearch__lists {
  display: flex;
  width: 94.6666666667vw;
  padding: 5.3333333333vw 6.9333333333vw;
  flex-wrap: wrap;
  align-items: flex-start;
  flex-direction: column;
  gap: 5.3333333333vw;
  background-color: #fff;
  border-radius: 2.6666666667vw;
  margin-top: 6.4vw;
  border: 1px solid #F08D18;
}
@media screen and (min-width: 768px) {
  .tagSearch__lists {
    flex-direction: row;
    width: clamp(1px, 90.9090909091vw, 1000px);
    padding: clamp(1px, 1.8181818182vw, 20px) clamp(1px, 3.6363636364vw, 40px);
    gap: clamp(1px, 1.8181818182vw, 20px);
    border-radius: clamp(1px, 0.9090909091vw, 10px);
    margin-top: clamp(1px, 3.0909090909vw, 34px);
    border: none;
  }
}
.tagSearch__lists li {
  width: 100%;
  height: 100%;
}
@media screen and (min-width: 768px) {
  .tagSearch__lists li {
    width: auto;
    height: auto;
  }
}
.tagSearch__lists li a {
  font-size: 4.2666666667vw;
  font-weight: 700;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 2.6666666667vw;
  width: 100%;
  height: 100%;
}
@media screen and (min-width: 768px) {
  .tagSearch__lists li a {
    font-size: clamp(1px, 1.4545454545vw, 16px);
    line-height: clamp(1px, 1.4545454545vw, 16px);
    gap: clamp(1px, 0.9090909091vw, 10px);
    width: auto;
    height: auto;
  }
}
.tagSearch__lists li a::before {
  content: "";
  background-image: url(../images/top/tag_search_ico_arrow.svg);
  background-size: contain;
  display: block;
  width: 5.8666666667vw;
  height: 5.8666666667vw;
}
@media screen and (min-width: 768px) {
  .tagSearch__lists li a::before {
    width: clamp(1px, 2vw, 22px);
    height: clamp(1px, 2vw, 22px);
  }
}

/**********************************************
** 最新の口コミ
***********************************************/
.newReview {
  padding: 9.6vw 0;
}
@media screen and (min-width: 768px) {
  .newReview {
    padding: clamp(1px, 4.5454545455vw, 50px) 0;
  }
}
.newReview__inr {
  width: 97.3333333333vw;
  margin: 0 0 0 2.6666666667vw;
}
@media screen and (min-width: 768px) {
  .newReview__inr {
    width: clamp(1px, 90.9090909091vw, 1000px);
    margin: 0 auto;
  }
}
.newReview__title {
  font-size: 5.8666666667vw;
  font-weight: 700;
  line-height: 1.25;
  text-align: center;
  color: #F08D18;
}
@media screen and (min-width: 768px) {
  .newReview__title {
    font-size: clamp(1px, 2.1818181818vw, 24px);
  }
}
.newReview__lists {
  padding: 6.4vw 2.6666666667vw 6.4vw 0;
  display: flex;
  gap: 6.4vw;
  overflow-x: scroll;
  overflow-y: hidden;
  scrollbar-color: #F08D18 #cccccc;
  scrollbar-width: thin;
}
@media screen and (min-width: 768px) {
  .newReview__lists {
    padding: clamp(1px, 3.2727272727vw, 36px) 0;
    gap: clamp(1px, 0.9090909091vw, 10px);
  }
}
.newReview__list {
  position: relative;
  background: #FFF;
  border-radius: 2.6666666667vw;
  border: 1px solid #CCC;
}
@media screen and (min-width: 768px) {
  .newReview__list {
    border-radius: clamp(1px, 0.9090909091vw, 10px);
  }
}
.newReview__list > a {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 3.2vw;
  padding: 3.7333333333vw 3.2vw;
  width: 81.3333333333vw;
  min-width: 81.3333333333vw;
  max-width: 81.3333333333vw;
}
@media screen and (min-width: 768px) {
  .newReview__list > a {
    gap: clamp(1px, 1.8181818182vw, 20px);
    padding: clamp(1px, 2.7272727273vw, 30px) clamp(1px, 2.1818181818vw, 24px);
    width: clamp(1px, 34.2727272727vw, 377px);
    min-width: clamp(1px, 34.2727272727vw, 377px);
    max-width: clamp(1px, 34.2727272727vw, 377px);
  }
}
.newReview__list h3 {
  color: #1BA0E5;
  font-size: 4.2666666667vw;
  font-weight: 700;
  line-height: 1.5;
  text-decoration: underline;
}
@media screen and (min-width: 768px) {
  .newReview__list h3 {
    font-size: clamp(1px, 1.6363636364vw, 18px);
  }
}
.newReview__listReview {
  display: flex;
  align-items: center;
  gap: 2.4vw;
}
@media screen and (min-width: 768px) {
  .newReview__listReview {
    gap: clamp(1px, 0.8181818182vw, 9px);
  }
}
.newReview__listReview .--score {
  display: flex;
  font-size: 5.8666666667vw;
  color: #F08D18;
}
@media screen and (min-width: 768px) {
  .newReview__listReview .--score {
    font-size: clamp(1px, 2vw, 22px);
  }
}
.newReview__listReview .--number {
  font-size: 4.2666666667vw;
  font-weight: 700;
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .newReview__listReview .--number {
    font-size: clamp(1px, 1.6363636364vw, 18px);
  }
}
.newReview__listDetail {
  color: #F08D18;
  font-size: 3.7333333333vw;
  font-weight: 700;
  line-height: 5.6vw;
  display: flex;
}
@media screen and (min-width: 768px) {
  .newReview__listDetail {
    font-size: clamp(1px, 1.4545454545vw, 16px);
    line-height: clamp(1px, 1.9090909091vw, 21px);
  }
}
.newReview__listDetail strong {
  color: initial;
  font-weight: 400;
}
.newReview__listDetail li:not(:first-of-type)::before {
  content: "/";
  color: initial;
  font-weight: 400;
}
.newReview__listPoints {
  background: #FFF7EC;
  display: flex;
  width: 100%;
  padding: 2.1333333333vw 5.6vw;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  margin-top: 3.2vw;
}
@media screen and (min-width: 768px) {
  .newReview__listPoints {
    width: clamp(1px, 29.7272727273vw, 327px);
    padding: clamp(1px, 0.7272727273vw, 8px) clamp(1px, 1.8181818182vw, 20px);
    margin-top: clamp(1px, 0.9090909091vw, 10px);
  }
}
.newReview__listPoints li {
  display: flex;
  align-items: center;
  font-size: 3.2vw;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  .newReview__listPoints li {
    font-size: clamp(1px, 1.2727272727vw, 14px);
  }
}
.newReview__listPoints li strong {
  margin-right: 1.0666666667vw;
  color: #888;
  font-weight: 400;
  line-height: 5.6vw;
}
@media screen and (min-width: 768px) {
  .newReview__listPoints li strong {
    margin-right: clamp(1px, 0.3636363636vw, 4px);
    line-height: clamp(1px, 1.9090909091vw, 21px);
  }
}
.newReview__listDesc {
  font-size: 3.7333333333vw;
  font-weight: 400;
  line-height: 1.5;
}
@media screen and (min-width: 768px) {
  .newReview__listDesc {
    font-size: clamp(1px, 1.4545454545vw, 16px);
  }
}
.newReview__listDesc strong {
  display: block;
  font-weight: 700;
}
.newReview__listDesc span {
  display: block;
  display: -webkit-box;
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}
.newReview__listInfo {
  color: #888;
  font-size: 3.7333333333vw;
  font-weight: 300;
  line-height: 1.5;
  display: flex;
}
@media screen and (min-width: 768px) {
  .newReview__listInfo {
    font-size: clamp(1px, 1.4545454545vw, 16px);
  }
}
.newReview__listInfo li:not(:first-of-type)::before {
  content: "/";
}
.newReview__btnMore {
  text-align: center;
}
.newReview__btnMore > a {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 2.6666666667vw;
  height: 11.2vw;
  margin: 6.4vw auto 0 auto;
  border-radius: 1.0666666667vw;
  border: 1px solid #F08D18;
  color: #F08D18;
  font-size: 3.7333333333vw;
  font-weight: 700;
  padding: 0 8vw;
}
@media screen and (min-width: 768px) {
  .newReview__btnMore > a {
    height: clamp(1px, 3.8181818182vw, 42px);
    margin: clamp(1px, 3.2727272727vw, 36px) auto 0 auto;
    font-size: clamp(1px, 1.2727272727vw, 14px);
    line-height: clamp(1px, 3.8181818182vw, 42px);
    padding: 0 clamp(1px, 2.7272727273vw, 30px);
  }
}
.newReview__btnMore > a:hover {
  color: #F08D18;
}
.newReview__btnMore > a::after {
  content: "";
  display: block;
  background-image: url(../images/top/new_review_ico_more.svg);
  background-size: contain;
  width: 3.7333333333vw;
  height: 3.7333333333vw;
}
@media screen and (min-width: 768px) {
  .newReview__btnMore > a::after {
    width: clamp(1px, 1.2727272727vw, 14px);
    height: clamp(1px, 1.2727272727vw, 14px);
  }
}

/**********************************************
** 選ばれる理由
***********************************************/
.reason {
  padding: 9.6vw 0;
  background-color: #F08D18;
}
@media screen and (min-width: 768px) {
  .reason {
    padding: clamp(1px, 4.5454545455vw, 50px) 0;
  }
}
.reason__inr {
  width: 94.6666666667vw;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .reason__inr {
    width: clamp(1px, 90.9090909091vw, 1000px);
  }
}
.reason__title {
  font-size: 5.8666666667vw;
  font-weight: 700;
  line-height: 1.25;
  text-align: center;
  color: #fff;
}
@media screen and (min-width: 768px) {
  .reason__title {
    font-size: clamp(1px, 2.1818181818vw, 24px);
  }
}
.reason p {
  font-size: 3.7333333333vw;
  line-height: 1.5;
}
@media screen and (min-width: 768px) {
  .reason p {
    font-size: clamp(1px, 1.2727272727vw, 14px);
  }
}
.reason__lists {
  list-style: none;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 14.9333333333vw;
  counter-reset: number 0;
  margin: 11.4666666667vw 0 0 0;
}
@media screen and (min-width: 768px) {
  .reason__lists {
    flex-direction: row;
    gap: clamp(1px, 1vw, 11px);
    margin: clamp(1px, 5.0909090909vw, 56px) 0 0 0;
  }
}
.reason__lists > li {
  width: 100%;
  display: flex;
  padding: 8.5333333333vw 4.2666666667vw;
  flex-direction: column;
  align-items: center;
  gap: 4.2666666667vw;
  align-self: stretch;
  border-radius: 2.1333333333vw;
  background-color: #fff;
  text-align: center;
  position: relative;
}
@media screen and (min-width: 768px) {
  .reason__lists > li {
    padding: clamp(1px, 2.9090909091vw, 32px) clamp(1px, 1.4545454545vw, 16px);
    gap: clamp(1px, 1.4545454545vw, 16px);
    border-radius: clamp(1px, 0.7272727273vw, 8px);
  }
}
.reason__lists > li::after {
  counter-increment: number 1;
  content: "0" counter(number) " ";
  display: flex;
  width: 21.3333333333vw;
  height: 21.3333333333vw;
  padding: 4.2666666667vw 2.1333333333vw;
  flex-direction: column;
  align-items: center;
  gap: 2.1333333333vw;
  border-radius: 50%;
  background: #fff;
  position: absolute;
  left: 50%;
  top: -6.9333333333vw;
  transform: translateX(-50%);
  font-size: 4.8vw;
  line-height: 1;
  font-weight: 700;
  color: #F08D18;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .reason__lists > li::after {
    width: clamp(1px, 7.2727272727vw, 80px);
    height: clamp(1px, 7.2727272727vw, 80px);
    top: clamp(-26px, -2.3636363636vw, -1px);
    padding: clamp(1px, 1.4545454545vw, 16px) clamp(1px, 0.7272727273vw, 8px);
    gap: clamp(1px, 0.7272727273vw, 8px);
    font-size: clamp(1px, 1.6363636364vw, 18px);
  }
}
.reason__lists > li > h3 {
  font-size: 4.8vw;
  font-weight: 700;
  line-height: 1.5;
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (min-width: 768px) {
  .reason__lists > li > h3 {
    height: 3em;
    font-size: clamp(1px, 1.6363636364vw, 18px);
  }
}
.reason__lists > li > h3 strong {
  color: #F08D18;
}
.reason__lists > li > div {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 4vw;
  text-align: left;
}
@media screen and (min-width: 768px) {
  .reason__lists > li > div {
    display: block;
    text-align: center;
  }
}
.reason__lists > li img {
  width: 24vw;
}
@media screen and (min-width: 768px) {
  .reason__lists > li img {
    width: clamp(1px, 13.0909090909vw, 144px);
  }
}
.reason__mtg h3 {
  font-size: 4.8vw;
  text-align: center;
  font-weight: 700;
  line-height: 1.5;
  margin-top: 8.5333333333vw;
  color: #fff;
}
@media screen and (min-width: 768px) {
  .reason__mtg h3 {
    font-size: clamp(1px, 1.8181818182vw, 20px);
    margin-top: clamp(1px, 2.9090909091vw, 32px);
  }
}
.reason__mtg ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6.4vw;
  margin: 4.2666666667vw 0 0 0;
}
@media screen and (min-width: 768px) {
  .reason__mtg ul {
    flex-direction: row;
    justify-content: center;
    gap: clamp(1px, 1vw, 11px);
    margin: clamp(1px, 1.4545454545vw, 16px) 0 0 0;
  }
}
.reason__mtg ul li {
  width: 100%;
  display: flex;
  padding: 6.4vw 4.2666666667vw;
  flex-direction: column;
  align-items: center;
  gap: 4.2666666667vw;
  align-self: stretch;
  border-radius: 2.1333333333vw;
  background-color: #fff;
  text-align: center;
  position: relative;
}
@media screen and (min-width: 768px) {
  .reason__mtg ul li {
    max-width: calc(33.3333333333% - clamp(1px, 1vw, 11px));
    padding: clamp(1px, 2.1818181818vw, 24px) clamp(1px, 1.4545454545vw, 16px);
    gap: clamp(1px, 1.4545454545vw, 16px);
    border-radius: clamp(1px, 0.7272727273vw, 8px);
  }
}
.reason__mtg ul li > h4 {
  font-size: 4.8vw;
  font-style: normal;
  font-weight: 700;
  line-height: 1.5;
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .reason__mtg ul li > h4 {
    font-size: clamp(1px, 1.6363636364vw, 18px);
  }
}
.reason__mtg ul li > h4 strong {
  color: #F08D18;
}
.reason__mtg ul li > h4 small {
  font-size: 2.6666666667vw;
  vertical-align: super;
}
@media screen and (min-width: 768px) {
  .reason__mtg ul li > h4 small {
    font-size: clamp(1px, 0.9090909091vw, 10px);
  }
}
.reason__mtg ul li > div {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 4vw;
  text-align: left;
}
@media screen and (min-width: 768px) {
  .reason__mtg ul li > div {
    display: block;
    text-align: center;
  }
}
.reason__mtg ul li p {
  order: 2;
}
@media screen and (min-width: 768px) {
  .reason__mtg ul li p {
    order: 1;
  }
}
.reason__mtg ul li p > small {
  margin-top: 0.4em;
  display: block;
  font-size: 3.7333333333vw;
}
@media screen and (min-width: 768px) {
  .reason__mtg ul li p > small {
    font-size: clamp(1px, 1.2727272727vw, 14px);
  }
}
.reason__mtg ul li img {
  order: 1;
}
@media screen and (min-width: 768px) {
  .reason__mtg ul li img {
    order: 2;
  }
}
.reason__mtg ul li img:first-of-type {
  width: 24vw;
}
@media screen and (min-width: 768px) {
  .reason__mtg ul li img:first-of-type {
    width: clamp(1px, 20vw, 220px);
  }
}
.reason__mtg ul li img:nth-of-type(2) {
  width: 24vw;
}
@media screen and (min-width: 768px) {
  .reason__mtg ul li img:nth-of-type(2) {
    width: clamp(1px, 17.8181818182vw, 196px);
  }
}

/**********************************************
** 人気記事ランキング
***********************************************/
.rankingArticles {
  padding: 9.6vw 0;
}
@media screen and (min-width: 768px) {
  .rankingArticles {
    padding: clamp(1px, 4.5454545455vw, 50px) 0;
  }
}
.rankingArticles__inr {
  width: 94.6666666667vw;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .rankingArticles__inr {
    width: clamp(1px, 90.9090909091vw, 1000px);
  }
}
.rankingArticles__title {
  font-size: 5.8666666667vw;
  font-weight: 700;
  line-height: 1.25;
  text-align: center;
  color: #F08D18;
}
@media screen and (min-width: 768px) {
  .rankingArticles__title {
    font-size: clamp(1px, 2.1818181818vw, 24px);
  }
}
.rankingArticles__lists {
  margin-top: 6.4vw;
  display: grid;
  grid-template-columns: 1fr;
  gap: 4.2666666667vw;
  counter-reset: number 0;
}
@media screen and (min-width: 768px) {
  .rankingArticles__lists {
    grid-template-columns: 1fr 1fr 1fr;
    margin-top: clamp(1px, 3.2727272727vw, 36px);
    gap: clamp(1px, 1.4545454545vw, 16px);
  }
}
.rankingArticles__list > a {
  display: flex;
  flex-wrap: nowrap;
  height: 21.3333333333vw;
  align-items: center;
  gap: 2.6666666667vw;
}
@media screen and (min-width: 768px) {
  .rankingArticles__list > a {
    height: clamp(1px, 7.2727272727vw, 80px);
    gap: clamp(1px, 1.0909090909vw, 12px);
  }
}
.rankingArticles__list > a::before {
  counter-increment: number 1;
  content: counter(number);
  font-size: 4.2666666667vw;
  font-weight: 700;
  color: #fff;
  border-radius: 50%;
  background: #F08D18;
  width: 8.5333333333vw;
  min-width: 8.5333333333vw;
  height: 8.5333333333vw;
  min-height: 8.5333333333vw;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (min-width: 768px) {
  .rankingArticles__list > a::before {
    font-size: clamp(1px, 1.2727272727vw, 14px);
    width: clamp(1px, 2.3636363636vw, 26px);
    min-width: clamp(1px, 2.3636363636vw, 26px);
    height: clamp(1px, 2.3636363636vw, 26px);
    min-height: clamp(1px, 2.3636363636vw, 26px);
  }
}
.rankingArticles__list > a img {
  width: 21.3333333333vw;
  height: 21.3333333333vw;
  border-radius: 2.1333333333vw;
  object-fit: cover;
}
@media screen and (min-width: 768px) {
  .rankingArticles__list > a img {
    width: clamp(1px, 5.6363636364vw, 62px);
    height: clamp(1px, 5.6363636364vw, 62px);
    border-radius: clamp(1px, 0.7272727273vw, 8px);
  }
}
.rankingArticles__list > a h3 {
  font-size: 3.7333333333vw;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (min-width: 768px) {
  .rankingArticles__list > a h3 {
    font-size: clamp(1px, 1.2727272727vw, 14px);
  }
}
.rankingArticles__list + .--more {
  display: none;
}
@media screen and (min-width: 768px) {
  .rankingArticles__list + .--more {
    display: flex;
  }
}
.rankingArticles__btnMore {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 2.1333333333vw;
  color: #F08D18;
  font-size: 3.7333333333vw;
  font-weight: 700;
  width: 58.6666666667vw;
  height: 10.1333333333vw;
  border-radius: 5.3333333333vw;
  border: 1px solid #F08D18;
  background: #fff;
  cursor: pointer;
  margin: 2.1333333333vw auto 0 auto;
}
@media screen and (min-width: 768px) {
  .rankingArticles__btnMore {
    display: none;
  }
}
.rankingArticles__btnMore::after {
  content: "";
  display: block;
  background-image: url(../images/top/new_review_ico_more.svg);
  background-size: contain;
  width: 3.7333333333vw;
  height: 3.7333333333vw;
  transform: rotate(90deg);
}
.rankingArticles__input {
  display: none;
}
.rankingArticles__input:checked ~ .rankingArticles__lists .rankingArticles__list + .--more {
  display: flex;
}
.rankingArticles__input:checked ~ .rankingArticles__lists .rankingArticles__btnMore {
  display: none;
}

/**********************************************
** 記事一覧
***********************************************/
.listArticles {
  padding: 9.6vw 0;
}
@media screen and (min-width: 768px) {
  .listArticles {
    padding: clamp(1px, 4.5454545455vw, 50px) 0;
  }
}
.listArticles__inr {
  width: 94.6666666667vw;
  margin: 0 0 0 2.6666666667vw;
}
@media screen and (min-width: 768px) {
  .listArticles__inr {
    width: clamp(1px, 90.9090909091vw, 1000px);
    margin: 0 auto;
  }
}
.listArticles__title {
  font-size: 5.8666666667vw;
  font-weight: 700;
  line-height: 1.25;
  text-align: center;
  color: #F08D18;
}
@media screen and (min-width: 768px) {
  .listArticles__title {
    font-size: clamp(1px, 2.1818181818vw, 24px);
  }
}
.listArticles__lists {
  padding: 6.4vw 0;
  display: flex;
  gap: 6.4vw;
  overflow-x: scroll;
  overflow-y: hidden;
  scrollbar-color: #F08D18 #cccccc;
  scrollbar-width: thin;
}
@media screen and (min-width: 768px) {
  .listArticles__lists {
    padding: clamp(1px, 3.2727272727vw, 36px) 0;
    gap: clamp(1px, 0.9090909091vw, 10px);
  }
}
.listArticles__list {
  background: #FFF;
  border-radius: 2.6666666667vw;
  border: 1px solid #CCC;
}
@media screen and (min-width: 768px) {
  .listArticles__list {
    border-radius: clamp(1px, 0.9090909091vw, 10px);
  }
}
.listArticles__list > a {
  display: block;
  padding: 2.6666666667vw;
}
@media screen and (min-width: 768px) {
  .listArticles__list > a {
    gap: clamp(1px, 1.8181818182vw, 20px);
    padding: clamp(1px, 1.8181818182vw, 20px) clamp(1px, 2.1818181818vw, 24px);
  }
}
.listArticles__list > a img {
  width: 76vw;
  height: 42.6666666667vw;
  aspect-ratio: 57/32;
  object-fit: cover;
  margin-bottom: 2.6666666667vw;
  border-radius: 2.1333333333vw;
}
@media screen and (min-width: 768px) {
  .listArticles__list > a img {
    width: clamp(1px, 25.9090909091vw, 285px);
    height: clamp(1px, 14.5454545455vw, 160px);
    margin-bottom: clamp(1px, 0.7272727273vw, 8px);
    border-radius: clamp(1px, 0.7272727273vw, 8px);
  }
}
.listArticles__list > a h3 {
  font-size: 4.2666666667vw;
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: 3.7333333333vw;
}
@media screen and (min-width: 768px) {
  .listArticles__list > a h3 {
    font-size: clamp(1px, 1.4545454545vw, 16px);
    line-height: clamp(1px, 2.1818181818vw, 24px);
    margin-bottom: clamp(1px, 2.1818181818vw, 24px);
  }
}
.listArticles__list > a span,
.listArticles__list > a time {
  display: block;
  color: #888;
  text-align: right;
  font-size: 3.2vw;
  font-weight: 400;
  line-height: 4.2666666667vw;
}
@media screen and (min-width: 768px) {
  .listArticles__list > a span,
  .listArticles__list > a time {
    font-size: clamp(1px, 1.4545454545vw, 16px);
    line-height: clamp(1px, 1.4545454545vw, 16px);
  }
}
.listArticles__btnMore {
  text-align: center;
}
.listArticles__btnMore > a {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 2.1333333333vw;
  height: 11.2vw;
  margin: 6.4vw auto 0 auto;
  border-radius: 1.0666666667vw;
  border: 1px solid #F08D18;
  color: #F08D18;
  font-size: 3.7333333333vw;
  font-weight: 700;
  padding: 0 8vw;
}
@media screen and (min-width: 768px) {
  .listArticles__btnMore > a {
    height: clamp(1px, 3.8181818182vw, 42px);
    margin: clamp(1px, 3.2727272727vw, 36px) auto 0 auto;
    font-size: clamp(1px, 1.2727272727vw, 14px);
    line-height: clamp(1px, 3.8181818182vw, 42px);
    padding: 0 clamp(1px, 2.7272727273vw, 30px);
  }
}
.listArticles__btnMore > a:hover {
  color: #F08D18;
}
.listArticles__btnMore > a::after {
  content: "";
  display: block;
  background-image: url(../images/top/new_review_ico_more.svg);
  background-size: contain;
  width: 3.7333333333vw;
  height: 3.7333333333vw;
}
@media screen and (min-width: 768px) {
  .listArticles__btnMore > a::after {
    width: clamp(1px, 1.2727272727vw, 14px);
    height: clamp(1px, 1.2727272727vw, 14px);
  }
}

/**********************************************
** 相続のおすすめ記事
***********************************************/
.recommendArticles {
  padding: 9.6vw 0 12.2666666667vw;
}
@media screen and (min-width: 768px) {
  .recommendArticles {
    padding: clamp(1px, 4.5454545455vw, 50px) 0;
  }
}
.recommendArticles__inr {
  width: 94.6666666667vw;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .recommendArticles__inr {
    width: clamp(1px, 90.9090909091vw, 1000px);
  }
}
.recommendArticles__title {
  font-size: 5.8666666667vw;
  font-weight: 700;
  line-height: 1.25;
  text-align: center;
  color: #F08D18;
}
@media screen and (min-width: 768px) {
  .recommendArticles__title {
    font-size: clamp(1px, 2.1818181818vw, 24px);
  }
}
.recommendArticles__lists {
  margin-top: 6.4vw;
  display: grid;
  grid-template-columns: 1fr;
  gap: 5.3333333333vw;
}
@media screen and (min-width: 768px) {
  .recommendArticles__lists {
    margin-top: clamp(1px, 3.2727272727vw, 36px);
    grid-template-columns: repeat(4, 1fr);
    gap: clamp(1px, 1vw, 11px);
  }
}
.recommendArticles__list {
  background: #FFF;
  border-radius: 10px;
  border: 2px solid #F08D18;
  display: block;
  width: 100%;
  overflow: hidden;
  padding-bottom: 5.3333333333vw;
}
@media screen and (min-width: 768px) {
  .recommendArticles__list {
    border-radius: clamp(1px, 0.9090909091vw, 10px);
    width: clamp(1px, 22vw, 242px);
    height: clamp(1px, 25.4545454545vw, 280px);
    padding-bottom: 0;
  }
}
.recommendArticles__list > figure {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.recommendArticles__list > figure img {
  width: 100%;
  height: 44.8vw;
  object-fit: cover;
}
@media screen and (min-width: 768px) {
  .recommendArticles__list > figure img {
    height: clamp(1px, 10.3636363636vw, 114px);
  }
}
.recommendArticles__list > figure h3 {
  color: #F08D18;
  font-size: 5.3333333333vw;
  font-weight: 600;
  line-height: 6vw;
  padding: 5.0666666667vw 5.3333333333vw 4vw;
}
@media screen and (min-width: 768px) {
  .recommendArticles__list > figure h3 {
    font-size: clamp(1px, 1.7272727273vw, 19px);
    line-height: clamp(1px, 2.0454545455vw, 22.5px);
    padding: clamp(1px, 1.3636363636vw, 15px) clamp(1px, 1vw, 11px) clamp(1px, 1.3636363636vw, 15px);
  }
}
.recommendArticles__list > figure a {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}
.recommendArticles__list ul {
  display: flex;
  padding: 0 5.3333333333vw;
  flex-direction: column;
  align-items: flex-start;
  gap: 4.2666666667vw;
}
@media screen and (min-width: 768px) {
  .recommendArticles__list ul {
    padding: 0 clamp(1px, 0.9090909091vw, 10px);
    gap: clamp(1px, 1.2727272727vw, 14px);
  }
}
.recommendArticles__list ul li a {
  display: flex;
  align-items: center;
  gap: 2.6666666667vw;
  font-size: 4.2666666667vw;
  font-weight: 700;
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .recommendArticles__list ul li a {
    gap: clamp(1px, 0.9090909091vw, 10px);
    font-size: clamp(1px, 1.4545454545vw, 16px);
    line-height: clamp(1px, 2.1818181818vw, 24px);
  }
}
.recommendArticles__list ul li a::before {
  content: "";
  background-image: url(../images/top/tag_search_ico_arrow.svg);
  background-size: contain;
  display: block;
  width: 5.8666666667vw;
  height: 5.8666666667vw;
}
@media screen and (min-width: 768px) {
  .recommendArticles__list ul li a::before {
    width: clamp(1px, 2vw, 22px);
    height: clamp(1px, 2vw, 22px);
  }
}

/**********************************************
** 相談の流れ
***********************************************/
.flow {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2.6666666667vw 0 10.6666666667vw 0;
  background: #FFF7EC;
}
@media screen and (min-width: 768px) {
  .flow {
    padding: clamp(1px, 0.9090909091vw, 10px) 0 clamp(1px, 3.6363636364vw, 40px) 0;
  }
}
.flow__inr {
  width: 94.6666666667vw;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .flow__inr {
    width: clamp(1px, 90.9090909091vw, 1000px);
  }
}
.flow__title {
  font-size: 5.8666666667vw;
  font-weight: 700;
  line-height: 1.25;
  text-align: center;
  color: #F08D18;
}
@media screen and (min-width: 768px) {
  .flow__title {
    font-size: clamp(1px, 2.1818181818vw, 24px);
  }
}
.flow__items {
  display: flex;
  margin-top: 3.7333333333vw;
  gap: 9.3333333333vw;
  flex-direction: column;
  align-items: flex-start;
}
@media screen and (min-width: 768px) {
  .flow__items {
    flex-direction: row;
    margin-top: clamp(1px, 2.3636363636vw, 26px);
    gap: clamp(1px, 3.1818181818vw, 35px);
  }
}
.flow__item {
  background-color: #FFFFFF;
  width: 100%;
  padding: 4.8vw 3.2vw;
  position: relative;
}
@media screen and (min-width: 768px) {
  .flow__item {
    padding: clamp(1px, 2.1818181818vw, 24px) clamp(1px, 1.0909090909vw, 12px);
  }
}
.flow__item > h3 {
  display: flex;
  align-items: center;
  justify-content: start;
  font-size: 4.8vw;
  font-weight: 700;
  margin-bottom: 2.6666666667vw;
  line-height: 1.2;
}
@media screen and (min-width: 768px) {
  .flow__item > h3 {
    font-size: clamp(1px, 1.4545454545vw, 16px);
    margin-bottom: clamp(1px, 1.0909090909vw, 12px);
    height: 2em;
  }
}
.flow__item > h3 > strong {
  font-size: 5.3333333333vw;
  color: #F08D18;
  margin-right: 2.6666666667vw;
}
@media screen and (min-width: 768px) {
  .flow__item > h3 > strong {
    font-size: clamp(1px, 1.8181818182vw, 20px);
    margin-right: clamp(1px, 0.9090909091vw, 10px);
  }
}
.flow__item > p {
  font-size: 3.7333333333vw;
  line-height: 1.5;
}
@media screen and (min-width: 768px) {
  .flow__item > p {
    font-size: clamp(1px, 1.2727272727vw, 14px);
  }
}
.flow__item::after {
  content: "";
  display: block;
  width: 7.2vw;
  height: 4vw;
  background-image: url(../images/top/ico_arrow_down2.svg);
  background-size: contain;
  position: absolute;
  top: -6.4vw;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (min-width: 768px) {
  .flow__item::after {
    width: clamp(1px, 2.4545454545vw, 27px);
    height: clamp(1px, 1.3636363636vw, 15px);
    top: 50%;
    left: clamp(-30px, -2.7272727273vw, -1px);
    transform: translateY(-50%) rotate(-90deg);
  }
}
.flow__item:first-of-type::after {
  display: none;
}

/**********************************************
** CTA
***********************************************/
.cta {
  background: #FFF7EC;
}
.cta__inr {
  width: 89.6vw;
  text-align: center;
  padding: 10.6666666667vw 0;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .cta__inr {
    width: clamp(1px, 80vw, 880px);
    padding: clamp(1px, 2.7272727273vw, 30px) 0 clamp(1px, 3.4545454545vw, 38px);
  }
}
.cta__title {
  display: inline-block;
  border: 1px solid #F08D18;
  padding: 2.6666666667vw;
  font-size: 4.8vw;
  font-weight: 700;
  line-height: 1;
  color: #F08D18;
}
@media screen and (min-width: 768px) {
  .cta__title {
    padding: clamp(1px, 1.3636363636vw, 15px);
    font-size: clamp(1px, 1.8181818182vw, 20px);
    margin-bottom: clamp(1px, 4.3636363636vw, 48px);
  }
}
.cta__middle {
  display: flex;
  align-items: start;
  justify-content: center;
  flex-flow: column;
  gap: 3.2vw;
  position: relative;
  margin: 4.2666666667vw auto 0;
  padding: 0 0 5.0666666667vw;
  width: 78.4vw;
}
@media screen and (min-width: 768px) {
  .cta__middle {
    align-items: center;
    flex-flow: row;
    gap: clamp(1px, 3.6363636364vw, 40px);
    margin: 0 0 clamp(1px, 3.8181818182vw, 42px);
    padding: 0;
    width: auto;
  }
}
.cta__middlePoints {
  display: grid;
  gap: 12px;
  grid-template-columns: 1fr;
}
@media screen and (min-width: 768px) {
  .cta__middlePoints {
    gap: clamp(1px, 1.0909090909vw, 12px);
  }
}
.cta__middlePoints li {
  position: relative;
  font-size: 4.8vw;
  font-weight: 700;
  line-height: 1;
  display: flex;
  align-items: center;
  gap: 1.6vw;
}
@media screen and (min-width: 768px) {
  .cta__middlePoints li {
    font-size: clamp(1px, 1.8181818182vw, 20px);
    gap: clamp(1px, 0.7272727273vw, 8px);
  }
}
.cta__middlePoints li strong {
  color: #F08D18;
}
.cta__middlePoints li::before {
  content: "";
  background-image: url(../images/top/cta_ico_check.svg);
  background-size: contain;
  display: block;
  width: 6.4vw;
  height: 6.4vw;
}
@media screen and (min-width: 768px) {
  .cta__middlePoints li::before {
    width: clamp(1px, 2.7272727273vw, 30px);
    height: clamp(1px, 2.7272727273vw, 30px);
  }
}
.cta__middlePresent {
  position: relative;
  margin-left: 2.6666666667vw;
}
@media screen and (min-width: 768px) {
  .cta__middlePresent {
    padding-right: clamp(1px, 19.9090909091vw, 219px);
    margin-left: 0;
  }
}
.cta__middlePresent > p {
  background-image: url(../images/top/cta_bg_present.svg);
  background-size: contain;
  background-repeat: no-repeat;
  width: 184px;
  height: 34px;
  padding: 5px 0 0 0;
  font-size: 16px;
  color: #fff;
  font-weight: 700;
  text-align: center;
  line-height: 1;
  margin-bottom: 10px;
}
@media screen and (min-width: 768px) {
  .cta__middlePresent > p {
    width: clamp(1px, 16.7272727273vw, 184px);
    height: clamp(1px, 3.0909090909vw, 34px);
    font-size: clamp(1px, 1.4545454545vw, 16px);
    margin-bottom: clamp(1px, 0.9090909091vw, 10px);
  }
}
.cta__middlePresent > div {
  display: flex;
  align-items: center;
  justify-self: center;
  gap: 10px;
}
.cta__middlePresent--checkList, .cta__middlePresent--guide {
  font-weight: 700;
  font-size: 2.6666666667vw;
  line-height: 5.3333333333vw;
}
@media screen and (min-width: 768px) {
  .cta__middlePresent--checkList, .cta__middlePresent--guide {
    font-size: clamp(1px, 1.2727272727vw, 14px);
    line-height: clamp(1px, 1.8181818182vw, 20px);
  }
}
.cta__middlePresent--checkList::before, .cta__middlePresent--guide::before {
  content: "";
  background-size: contain;
  background-repeat: no-repeat;
  display: block;
  margin: 0 auto;
}
.cta__middlePresent--checkList::before {
  background-image: url(../images/top/cta_ico_checklist.png);
  width: 7.2vw;
  height: 7.7333333333vw;
}
@media screen and (min-width: 768px) {
  .cta__middlePresent--checkList::before {
    width: clamp(1px, 3.7272727273vw, 41px);
    height: clamp(1px, 3.9090909091vw, 43px);
  }
}
.cta__middlePresent--guide::before {
  background-image: url(../images/top/cta_ico_guide.png);
  width: 5.8666666667vw;
  height: 7.7333333333vw;
}
@media screen and (min-width: 768px) {
  .cta__middlePresent--guide::before {
    width: clamp(1px, 3vw, 33px);
    height: clamp(1px, 3.9090909091vw, 43px);
  }
}
.cta__middlePresent--icoPlus {
  display: block;
  background-size: contain;
  background-repeat: no-repeat;
  background-image: url(../images/top/cta_ico_plus.svg);
  display: block;
  width: 2.6666666667vw;
  height: 2.6666666667vw;
  margin-bottom: 4vw;
}
@media screen and (min-width: 768px) {
  .cta__middlePresent--icoPlus {
    width: clamp(1px, 1.1818181818vw, 13px);
    height: clamp(1px, 1.1818181818vw, 13px);
    margin-bottom: clamp(1px, 1.3636363636vw, 15px);
  }
}
@media screen and (min-width: 768px) {
  .cta__middlePresent::after {
    content: "";
    background-image: url(../images/top/cta_bg.png);
    background-size: contain;
    background-repeat: no-repeat;
    display: block;
    width: clamp(1px, 19.9090909091vw, 219px);
    height: clamp(1px, 16.2727272727vw, 179px);
    position: absolute;
    right: 0;
    top: clamp(-15px, -1.3636363636vw, -1px);
  }
}
.cta__middle::after {
  content: "";
  background-image: url(../images/top/cta_bg.png);
  background-size: contain;
  background-repeat: no-repeat;
  display: block;
  width: 40vw;
  height: 36.8vw;
  position: absolute;
  right: 0;
  bottom: -4.2666666667vw;
}
@media screen and (min-width: 768px) {
  .cta__middle::after {
    display: none;
  }
}
.cta__bottom {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-flow: column;
  gap: 20px;
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .cta__bottom {
    flex-flow: row;
  }
}
.cta__bottom > a,
.cta__bottom > div {
  display: flex;
  width: 100%;
  height: 23.7333333333vw;
  justify-content: center;
  align-items: center;
  gap: 2.1333333333vw;
  border-radius: 5.3333333333vw;
  color: #fff;
  font-size: 5.8666666667vw;
  font-weight: 700;
  line-height: 6.4vw;
}
@media screen and (min-width: 768px) {
  .cta__bottom > a,
  .cta__bottom > div {
    width: clamp(1px, 39.0909090909vw, 430px);
    height: clamp(1px, 10.1818181818vw, 112px);
    min-width: clamp(1px, 7.6363636364vw, 84px);
    max-width: clamp(1px, 43.6363636364vw, 480px);
    gap: clamp(1px, 0.7272727273vw, 8px);
    border-radius: clamp(1px, 1.8181818182vw, 20px);
    font-size: clamp(1px, 2.5454545455vw, 28px);
    line-height: clamp(1px, 2.1818181818vw, 24px);
  }
}
.cta__bottom > a small,
.cta__bottom > div small {
  text-overflow: ellipsis;
  font-size: 3.2vw;
  font-weight: 400;
}
@media screen and (min-width: 768px) {
  .cta__bottom > a small,
  .cta__bottom > div small {
    font-size: clamp(1px, 1.4545454545vw, 16px);
  }
}
.cta__bottom > a:hover,
.cta__bottom > div:hover {
  opacity: 1;
}
.cta__btnTel {
  padding: 4.2666666667vw 1.6vw 3.2vw 1.6vw;
  background: #16A34A;
  box-shadow: 0 6px 0 0 rgb(15.9351351351, 118.0648648649, 53.6);
}
@media screen and (min-width: 768px) {
  .cta__btnTel {
    padding: clamp(1px, 1.4545454545vw, 16px) clamp(1px, 0.5454545455vw, 6px) clamp(1px, 1.0909090909vw, 12px) clamp(1px, 0.5454545455vw, 6px);
  }
}
.cta__btnTel::before {
  content: "";
  background-image: url(../images/animated_phone.apng);
  background-size: contain;
  background-repeat: no-repeat;
  display: block;
  width: 13.6vw;
  height: 13.6vw;
}
@media screen and (min-width: 768px) {
  .cta__btnTel::before {
    width: clamp(1px, 4.3636363636vw, 48px);
    height: clamp(1px, 4.3636363636vw, 48px);
  }
}
.cta__btnWeb {
  height: 21.0666666667vw;
  padding: 5.3333333333vw 1.6vw;
  background: #F08D18;
  box-shadow: 0 6px 0 0 rgb(200.012195122, 114.2926829268, 12.987804878);
}
@media screen and (min-width: 768px) {
  .cta__btnWeb {
    padding: clamp(1px, 1.8181818182vw, 20px) clamp(1px, 0.5454545455vw, 6px);
  }
}
.cta__btnWeb::before {
  content: "";
  background-image: url(../images/top/cta_ico_mail.png);
  background-size: contain;
  background-repeat: no-repeat;
  display: block;
  width: 14.4vw;
  height: 10.4vw;
}
@media screen and (min-width: 768px) {
  .cta__btnWeb::before {
    width: clamp(1px, 4.9090909091vw, 54px);
    height: clamp(1px, 3.5454545455vw, 39px);
  }
}

/**********************************************
** Popup CTA
***********************************************/
.popupCta {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.6);
  z-index: 1000;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
.popupCta__inr {
  position: relative;
  width: 94.6666666667vw;
  text-align: center;
  margin: 0 auto;
  padding: 4vw 0 5.3333333333vw;
  border-radius: 2.6666666667vw;
  background: #FFF7EC;
}
@media screen and (min-width: 768px) {
  .popupCta__inr {
    width: 400px;
    padding: 15px 0 20px;
    border-radius: 10px;
    background: #FFF7EC;
  }
}
.popupCta__title {
  font-size: 5.3333333333vw;
  font-style: normal;
  font-weight: 400;
  line-height: 1.5;
  padding-bottom: 2.6666666667vw;
  border-bottom: 1px solid #F08D18;
}
@media screen and (min-width: 768px) {
  .popupCta__title {
    font-size: 20px;
    padding-bottom: 10px;
  }
}
.popupCta__title strong {
  font-weight: 700;
  color: #F08D18;
}
.popupCta__check {
  background: #FFF;
  display: flex;
  padding: 2.6666666667vw 5.3333333333vw;
  margin: 5.3333333333vw 2.6666666667vw;
  flex-direction: column;
  align-items: flex-start;
  gap: 2.6666666667vw;
  align-self: stretch;
}
@media screen and (min-width: 768px) {
  .popupCta__check {
    padding: 10px 20px;
    margin: 20px 31px;
    gap: 10px;
  }
}
.popupCta__check li {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  font-size: 16px;
  font-weight: 400;
  line-height: 20px;
}
@media screen and (min-width: 768px) {
  .popupCta__check li {
    font-size: 16px;
    line-height: 20px;
  }
}
.popupCta__check li::before {
  content: "";
  background-image: url(../images/top/popup_cta_ico_check.svg);
  background-size: contain;
  display: block;
  width: 6.4vw;
  height: 6.4vw;
  margin-right: 0.8vw;
}
@media screen and (min-width: 768px) {
  .popupCta__check li::before {
    width: 24px;
    height: 24px;
    margin-right: 3px;
  }
}
.popupCta__txt {
  font-size: 3.7333333333vw;
  font-weight: 400;
  line-height: 1.5;
}
@media screen and (min-width: 768px) {
  .popupCta__txt {
    font-size: 14px;
  }
}
.popupCta__txt strong {
  font-weight: 700;
}
.popupCta__btnTel, .popupCta__btnWeb {
  display: flex;
  height: 23.7333333333vw;
  justify-content: center;
  align-items: center;
  gap: 2.1333333333vw;
  border-radius: 5.3333333333vw;
  color: #fff;
  font-size: 5.8666666667vw;
  font-weight: 700;
  line-height: 6.4vw;
  margin: 2.6666666667vw 2.6666666667vw 5.3333333333vw 2.6666666667vw;
}
@media screen and (min-width: 768px) {
  .popupCta__btnTel, .popupCta__btnWeb {
    height: 89px;
    gap: 8px;
    border-radius: 20px;
    font-size: 22px;
    line-height: 24px;
    margin: 10px 32px 20px 32px;
  }
}
.popupCta__btnTel small, .popupCta__btnWeb small {
  text-overflow: ellipsis;
  font-size: 3.2vw;
  font-weight: 400;
}
@media screen and (min-width: 768px) {
  .popupCta__btnTel small, .popupCta__btnWeb small {
    font-size: 12px;
  }
}
.popupCta__btnTel:hover, .popupCta__btnWeb:hover {
  opacity: 1;
  color: #fff;
}
.popupCta__btnTel {
  padding: 4.2666666667vw 1.6vw 3.2vw 1.6vw;
  background: #16A34A;
  box-shadow: 0 6px 0 0 rgb(15.9351351351, 118.0648648649, 53.6);
}
@media screen and (min-width: 768px) {
  .popupCta__btnTel {
    padding: 16px 6px 12px 6px;
  }
}
.popupCta__btnTel::before {
  content: "";
  background-image: url(../images/animated_phone.apng);
  background-size: contain;
  background-repeat: no-repeat;
  display: block;
  width: 13.6vw;
  height: 13.6vw;
}
@media screen and (min-width: 768px) {
  .popupCta__btnTel::before {
    width: clamp(1px, 4.3636363636vw, 48px);
    height: clamp(1px, 4.3636363636vw, 48px);
  }
}
.popupCta__btnWeb {
  height: 21.0666666667vw;
  padding: 5.3333333333vw 1.6vw;
  background: #F08D18;
  box-shadow: 0 6px 0 0 rgb(200.012195122, 114.2926829268, 12.987804878);
}
@media screen and (min-width: 768px) {
  .popupCta__btnWeb {
    height: 79px;
    padding: 20px 6px;
  }
}
.popupCta__btnWeb::before {
  content: "";
  background-image: url(../images/top/cta_ico_mail.png);
  background-size: contain;
  background-repeat: no-repeat;
  display: block;
  width: 14.4vw;
  height: 10.4vw;
}
@media screen and (min-width: 768px) {
  .popupCta__btnWeb::before {
    width: 54px;
    height: 39px;
  }
}
.popupCta__note {
  color: #1BA0E5;
  text-align: center;
  font-style: normal;
  font-weight: 400;
  line-height: 1.5;
  text-decoration: underline;
}
.popupCta__close {
  position: absolute;
  top: 4vw;
  right: 6.6666666667vw;
  width: 5.6vw;
  height: 5.6vw;
  border-radius: 2px;
  border: 1px solid #B2B2B2;
  background: #FFF;
  cursor: pointer;
}
@media screen and (min-width: 768px) {
  .popupCta__close {
    top: 15px;
    right: 25px;
    width: 21px;
    height: 21px;
  }
}
.popupCta__closeLine {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 4.2666666667vw;
  height: 1px;
  background: #B2B2B2;
  transform: translate(-50%, -50%) rotate(45deg);
  border-radius: 1px;
}
@media screen and (min-width: 768px) {
  .popupCta__closeLine {
    width: 16px;
    height: 1px;
  }
}
.popupCta__closeLine:nth-of-type(2) {
  transform: translate(-50%, -50%) rotate(-45deg);
}
.popupCta__closeOuter {
  position: absolute;
  top: -6.6666666667vw;
  right: 50%;
  transform: translateX(50%);
  display: flex;
  color: #fff;
  font-size: 3.7333333333vw;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (min-width: 768px) {
  .popupCta__closeOuter {
    top: -25px;
    font-size: 14px;
  }
}
.popupCta__closeOuter > div {
  position: relative;
  width: 5.3333333333vw;
}
@media screen and (min-width: 768px) {
  .popupCta__closeOuter > div {
    width: 20px;
  }
}
.popupCta__closeOuterLine {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 3.7333333333vw;
  height: 1px;
  background: #fff;
  transform: translate(-50%, -50%) rotate(45deg);
  border-radius: 1px;
}
@media screen and (min-width: 768px) {
  .popupCta__closeOuterLine {
    width: 14px;
    height: 1px;
  }
}
.popupCta__closeOuterLine:nth-of-type(2) {
  transform: translate(-50%, -50%) rotate(-45deg);
}

/**********************************************
** ページトップボタン
***********************************************/
#pagetop_link {
  cursor: pointer;
  position: fixed;
  right: 10px;
  bottom: 25%;
  width: 50px;
  height: 50px;
  display: flex;
  justify-content: center;
  align-items: center;
  background: rgba(0, 0, 0, 0.3);
  border-radius: 100%;
  z-index: 999;
}
#pagetop_link img {
  display: none;
}
@media screen and (min-width: 768px) {
  #pagetop_link img {
    display: none;
  }
}
#pagetop_link svg {
  width: 16px;
  height: 24px;
}

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