@charset "UTF-8";
* {
  box-sizing: border-box;
}

*:last-child {
  margin-bottom: 0;
}

body {
  font-size: 16px;
  line-height: 1.75;
  margin: 0;
  color: #202020;
}

@media screen and (max-width: 768px) {
  body {
    font-size: 14px;
    line-height: 1.857;
  }
}
p {
  margin: 0 0 2rem;
}

ul {
  padding: 0;
  margin: 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin-top: 0;
}

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

a {
  transition: all 0.3s;
}

a:hover {
  opacity: 0.8;
}

body {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.625;
  letter-spacing: 0.08em;
  color: #333333;
}

@media screen and (max-width: 768px) {
  body {
    font-size: 14px;
    line-height: 1.857;
  }
}
html {
  scroll-behavior: smooth;
}

:root {
  --primary: #ee6600;
  --primary-2: #f27100;
  --secondary: #009de8;
  --green: #63b374;
  --gradation-primary: linear-gradient(90deg, #ff9800, #ee6600);
}

/* layout */
.header-container-in .header-in {
  width: 1280px;
  max-width: 100%;
  padding: 29px 30px;
  padding-right: 40px;
  margin: auto;
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  flex-direction: row;
  justify-content: space-between;
}

.header-container-in .header-logo {
  display: flex;
  margin-bottom: 0;
  padding-bottom: 10px;
}

.header-container-in .header-nav .nav-in {
  display: flex;
  align-items: center;
  flex-direction: row;
  gap: 36px;
}

.header-container-in .header-menu {
  justify-content: flex-end;
}
.header-container-in .header-menu.--menu1 {
  width: 385px;
  max-width: 100%;
}
.header-container-in .header-menu .menu-item.--tel .menu-item__tel {
  text-align: center;
}
.header-container-in .header-menu .menu-item.--tel .tel-number {
  font-size: 18px;
  font-weight: bold;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.header-container-in .header-menu .menu-item.--tel .tel-hours {
  font-size: 12px;
  margin-top: 2px;
}

.container {
  overflow-x: hidden;
}

.footer {
  padding: 59px 0 55px;
  text-align: center;
  background-color: white;
}

.footer-in {
  width: 1280px;
  max-width: 100%;
  margin: 0 auto;
  padding: 0 40px;
}

.footer-logo-out {
  margin-bottom: 30px;
}

.footer-nav .menu {
  display: flex;
  justify-content: center;
  gap: 75px;
}

.footer-nav .menu-item {
  position: relative;
  font-size: 16px;
  line-height: 1.1875;
  font-weight: 500;
}

.footer-nav .menu-item::before {
  content: "｜";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  left: unset;
  right: calc(-37.5px - 0.5em);
  font-weight: 500;
}

.footer-nav .menu-item:last-child::before {
  content: unset;
}

.footer-info {
  margin-bottom: 60px;
}

.footer-info__heading {
  margin-bottom: 10px;
  font-size: 30px;
  line-height: 1.2;
  font-weight: 700;
}

.footer-info__txt {
  font-size: 18px;
  line-height: 1.7222222222;
  font-weight: 600;
}

.footer-info__txt .small {
  font-size: 16px;
  line-height: 1.75;
  font-weight: 500;
}

@media screen and (max-width: 768px) {
  .header-container-in .header-in {
    min-height: 56px;
    padding: 14px 30px;
    padding-right: 22px;
  }
  .header-container-in .header-logo {
    padding: 0;
  }
  .header-container-in .header-logo img {
    width: 163px;
  }
  .header-container-in .header-nav {
    display: none;
  }
  .header-container-in .header-sp-menu {
    display: block;
  }
}
@media screen and (max-width: 768px) {
  .footer {
    padding: 40px 0 32px;
    background-color: #f4f2ee;
  }
  .footer-in {
    padding: 0 20px;
  }
  .footer-logo img {
    width: 320px;
  }
  .footer-info {
    margin-bottom: 0;
  }
  .footer-info__txt .small {
    display: inline-block;
    margin-top: 12px;
  }
  .footer-nav {
    display: none;
  }
}
/* layout */
/* component block */
.menu {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  flex-direction: row;
  gap: 13px;
  padding: 0;
  margin: 0;
  list-style: none;
}

.menu-item {
  font-size: 16px;
  line-height: 1.21875;
  letter-spacing: 0.14em;
  font-weight: 600;
}

.menu-item a {
  color: #231815;
  text-decoration: unset;
}

.secondary {
  color: var(--secondary);
}

.primary {
  color: var(--primary);
}
.primary-2 {
  color: var(--primary-2);
}

.dc-icon {
  display: block;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: top;
}

.dc-icon.--icon-circle {
  width: 19px;
  height: 23px;
  background-image: url("../img/icon_circle.svg");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}

.dc-icon.--icon-circle-double {
  width: 19px;
  height: 23px;
  background-image: url("../img/icon_circle_double.svg");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}

.dc-icon.--icon-x {
  width: 15px;
  height: 15px;
  background-image: url("../img/icon_x.svg");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}

.dc-icon.--icon-tri {
  width: 19px;
  height: 23px;
  background-image: url("../img/icon_tri.svg");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}

.dc-icon.--icon-dial {
  width: 35px;
  height: 23px;
  background-image: url("../img/icon_dial.svg");
}
.dc-icon.--icon-dial-orange {
  background-image: url("../img/icon_dial_orange.svg");
}
.dc-icon.--icon-dial-white {
  background-image: url("../img/icon_dial_white.svg");
}

.dc-btn.--btn-primary {
  display: flex;
  align-items: center;
  flex-direction: row;
  justify-content: center;
  gap: 14px;
  min-height: 62.5px;
  padding: 10px 23px;
  padding-left: 32px;
  font-size: 20px;
  line-height: 1.2;
  letter-spacing: 0.08em;
  font-weight: 600;
  color: white;
  border-radius: 2em;
  background: var(--gradation-primary);
  box-shadow: 0 0 6px 0 rgba(35, 24, 21, 0.35);
  text-decoration: unset;
}

.dc-btn.--btn-primary::after {
  content: "";
  width: 9px;
  height: 13px;
  background-image: url("../img/icon_arrow_1.svg");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}

.dc-btn.--btn-primary-white {
  color: var(--primary);
  background: white;
}

.dc-btn.--btn-primary-white::after {
  background-image: url("../img/icon_arrow_1_orange.svg");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}

.dc-btn.--btn-tag {
  width: fit-content;
  max-width: 100%;
  margin: 0 auto;
  padding: 23px 43px;
  padding-right: 63px;
}
.dc-btn.--btn-tag::after {
  display: none;
}
.dc-btn.--btn-tag .dc-btn__tag {
  display: inline-block;
  padding: 3px 11px;
  font-size: 20px;
  line-height: 1.2;
  letter-spacing: 0.08em;
  font-weight: 600;
  border-radius: 2em;
  color: var(--primary);
  background-color: white;
}
.dc-btn.--btn-tag-arrow {
  position: relative;
}
.dc-btn.--btn-tag-arrow::after {
  position: absolute;
  right: 30px;
  display: block;
  width: 10px;
  height: 16px;
}
.dc-btn.--btn-tag.--btn-primary-white .dc-btn__tag {
  color: white;
  background-color: var(--primary);
}

@media screen and (max-width: 768px) {
  .dc-btn.--btn-tag-arrow {
    padding: 23px 32px;
    padding-right: 52px;
  }
}
.dc-txt.--txt1 {
  font-size: 20px;
  line-height: 1.2;
  font-weight: 600;
  letter-spacing: 0.08em;
}

.dc-txt.--txt1 .dc-txt1-in {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
}

.dc-txt.--txt1 .dc-txt1-in::before,
.dc-txt.--txt1 .dc-txt1-in::after {
  content: "";
}

.dc-txt.--txt1 .dc-txt1-in::before {
  content: "\\";
  padding-right: 0.25em;
}

.dc-txt.--txt1 .dc-txt1-in::after {
  content: "/";
  padding-left: 0.25em;
}

.dc-txt.--txt1-large {
  font-size: 16px;
  line-height: 1.625;
  letter-spacing: 0.01em;
  font-weight: 500;
}
.dc-txt.--txt1-large .dc-txt1-in {
  align-items: unset;
  gap: 25px;
  margin-bottom: 10px;
}
.dc-txt.--txt1-large .dc-txt1-in::before,
.dc-txt.--txt1-large .dc-txt1-in::after {
  content: "";
  display: block;
  height: auto;
  padding: 0;
  border-left: 1px solid;
  transform: rotate(-25deg);
}
.dc-txt.--txt1-large .dc-txt1-in::after {
  transform: rotate(25deg);
}

@media screen and (max-width: 768px) {
  .dc-txt.--txt1 {
    font-size: 17.1px;
    line-height: 1.2222222222;
    text-align: center;
  }
}
.dc-txt.--txt1-2 .dc-txt1-in {
  position: relative;
  padding: 0 53px;
}
.dc-txt.--txt1-2 .dc-txt1-in::before,
.dc-txt.--txt1-2 .dc-txt1-in::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 5px;
  width: 2px;
  height: calc(100% - 15px);
  margin-top: auto;
  border-left: 4px solid;
  transform-origin: top;
}
.dc-txt.--txt1-2 .dc-txt1-in::before {
  left: 0;
  transform: rotate(-15deg);
}
.dc-txt.--txt1-2 .dc-txt1-in::after {
  right: 0;
  transform: rotate(15deg);
}
@media screen and (max-width: 768px) {
  .dc-txt.--txt1-2 .dc-txt1-in {
    padding: 0 29px;
  }
  .dc-txt.--txt1-2 .dc-txt1-in::before,
  .dc-txt.--txt1-2 .dc-txt1-in::after {
    bottom: -6px;
    width: 0px;
    height: calc(100% + 6px);
    border-width: 2px;
  }
}

.dc-txt.--txt-balloon {
  position: relative;
  z-index: 10;
  width: fit-content;
  max-width: 100%;
  font-size: 18px;
  line-height: 1.2222222222;
  font-weight: bold;
  text-align: center;
}

.dc-txt.--txt-balloon::before,
.dc-txt.--txt-balloon::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  top: unset;
  bottom: 0;
  clip-path: polygon(50% 100%, 0 0, 100% 0);
}

.dc-txt.--txt-balloon::before {
  z-index: 30;
  bottom: -6px;
  width: 20px;
  height: 10px;
  background-color: white;
}

.dc-txt.--txt-balloon::after {
  z-index: 20;
  width: 13px;
  height: 0;
  bottom: -10px;
  border: 13px solid;
  border-left: 0;
  border-top: 0;
}

.dc-txt.--txt-balloon .dc-txt-balloon-in {
  position: relative;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 264px;
  max-width: 100%;
  min-height: 50px;
  padding: 10px;
  border: 3px solid;
  border-radius: 2em;
  background-color: white;
}

.dc-txt.--txt-balloon-primary::before {
  background-color: var(--primary);
}
.dc-txt.--txt-balloon-primary::after {
  border-color: var(--primary);
}
.dc-txt.--txt-balloon-primary .dc-txt-balloon-in {
  border: 0;
  color: white;
  background-color: var(--primary);
}

.dc-txt.--txt-balloon-green::before {
  background-color: #63b374;
}
.dc-txt.--txt-balloon-green::after {
  border-color: #63b374;
}
.dc-txt.--txt-balloon-green .dc-txt-balloon-in {
  border: 0;
  color: white;
  background-color: #63b374;
}

.dc-txt.--txt-tel {
  display: flex;
  align-items: center;
  gap: 5px;
  text-decoration: unset;
}
.dc-txt.--txt-tel .dc-txt-tel__icon {
  margin-top: 4px;
}
.dc-txt.--txt-tel .dc-txt-tel__txt {
  font-size: 24px;
  line-height: 1.2083333333;
  letter-spacing: 0.3em;
}
.dc-txt.--txt-tel-secondary .dc-txt-tel__txt {
  color: var(--secondary);
}
.dc-txt.--txt-tel-large {
  margin-bottom: 10px;
}
.dc-txt.--txt-tel-large .dc-txt-tel__icon {
  margin-top: 4px;
  width: 43px;
  height: 28px;
}
.dc-txt.--txt-tel-large .dc-txt-tel__txt {
  font-size: 30px;
  line-height: 1.2;
  letter-spacing: 0.028em;
}
.dc-txt.--txt-tel-white {
  color: white;
}
@media screen and (max-width: 768px) {
  .dc-txt.--txt-tel {
    gap: 7px;
  }
  .dc-txt.--txt-tel .dc-txt-tel__icon {
    width: 45px;
    height: 29px;
    margin-top: 2px;
  }
  .dc-txt.--txt-tel .dc-txt-tel__txt {
    font-size: 31px;
    line-height: 1.2258064516;
    letter-spacing: 0.028em;
  }
}

.dc-tag.--tag1 {
  display: inline-block;
  padding: 6px 18px;
  font-size: 16px;
  line-height: 1.1875;
  letter-spacing: 0.01em;
  font-weight: 600;
  color: var(--primary);
  border: 2px solid;
  border-radius: 2em;
}
.dc-tag.--tag1-secondary {
  color: var(--secondary);
}

.dc-heading.--heading-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 13px;
  margin-bottom: 30px;
  font-size: 25px;
  line-height: 1.2;
  font-weight: 700;
}

@media screen and (max-width: 768px) {
  .dc-heading.--heading-icon {
    font-size: 22px;
    line-height: 1.2181818182;
  }
}
.dc-heading.--heading1 {
  margin-bottom: 35px;
  font-size: 30px;
  line-height: 1.75;
  letter-spacing: 0.08em;
  font-weight: 700;
  text-align: center;
}
.dc-heading.--heading2 {
  display: flex;
  align-items: center;
  gap: 15px;
  padding-left: 20px;
  margin-bottom: 45px;
  font-size: 20px;
  line-height: 1.2;
  letter-spacing: 0.08em;
  font-weight: 600;
}
.dc-heading.--heading2::before {
  content: "";
  width: 7px;
  height: 43px;
  border-radius: 2em;
  background-color: var(--primary);
}
@media screen and (max-width: 768px) {
  .dc-heading.--heading2 {
    gap: 10px;
    padding-left: 0;
    margin-bottom: 40px;
    font-size: 18px;
    line-height: 1.2222222222;
    letter-spacing: 0.08em;
  }
  .dc-heading.--heading2::before {
    width: 6px;
    height: 37px;
  }
}

.dc-columns {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
}

.dc-columns .dc-column {
  max-width: 100%;
}

.dc-card.--card1 {
  width: 323px;
  max-width: 100%;
  box-shadow: 0 0 20px 0 rgba(59, 49, 47, 0.3);
  border-radius: 25px;
  background-color: white;
  overflow: hidden;
}

.dc-card.--card1 .dc-card1-header {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 10px 20px 20px;
  min-height: 77px;
  font-size: 22px;
  line-height: 1.2272727273;
  font-weight: bold;
  color: white;
  text-align: center;
}

.dc-card.--card1 .dc-card1-body {
  padding: 22px 30px 20px;
}

.dc-card.--card1 .dc-card1__img {
  margin-bottom: 13px;
}

.dc-card.--card1 .dc-card1__img img {
  display: flex;
}

.dc-card.--card1 .dc-card1__txt {
  font-size: 16px;
  line-height: 1.625;
  font-weight: 600;
}

.dc-card.--card1-primary .dc-card1-header {
  background: linear-gradient(90deg, #ff9800, #ee6600);
}

.dc-card.--card1-secondary .dc-card1-header {
  background: linear-gradient(90deg, #009de8, #018dd0);
}

.dc-card.--card1-2 .dc-card1-header {
  min-height: 67px;
  padding: 15px 20px;
  align-items: center;
}
.dc-card.--card1-2 .dc-card1-body {
  padding: 22px 31px 33px;
}
.dc-card.--card1-2 .dc-card1__txt {
  font-size: 16px;
  line-height: 1.625;
  letter-spacing: 0.008em;
  font-weight: 500;
}

@media screen and (max-width: 768px) {
  .dc-card.--card1 .dc-card1-body {
    padding: 13px 30px 31px;
  }
  .dc-card.--card1-2 {
    width: 320px;
  }
  .dc-card.--card1-2 .dc-card1-header {
    min-height: 56px;
    padding: 10px 20px;
  }
  .dc-card.--card1-2 .dc-card1-body {
    padding: 14px 31px 22px;
  }
}
.dc-card.--card2 {
  position: relative;
  width: 468px;
  max-width: 100%;
  height: 100%;
  padding: 72px 35px 30px;
  border-radius: 30px;
  background-color: #f4f2ee;
  box-shadow: 0 0 20px 0 rgba(51, 51, 51, 0.3);
}
.dc-card.--card2 .dc-card2-item {
  position: relative;
  display: flex;
  flex-wrap: nowrap;
  gap: 15px;
  margin-bottom: 65px;
}
.dc-card.--card2 .dc-card2-item-column.--txt {
  flex: 1;
  font-size: 16px;
  line-height: 1.875;
  letter-spacing: 0.01em;
  font-weight: 600;
}
.dc-card.--card2 .dc-card2-item-column.--txt .small {
  font-size: 14px;
  line-height: 1.2142857143;
  letter-spacing: 0.008em;
}
.dc-card.--card2 .dc-card2-item::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -35px;
  width: 100%;
  height: 0;
  border-bottom: 2px solid #dcdddd;
}
.dc-card.--card2 .dc-card2-item:last-child {
  margin-bottom: 0;
}
.dc-card.--card2 .dc-card2-item:last-child::after {
  display: none;
}
.dc-card.--card2 .dc-card2__balloon {
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  top: -28px;
  bottom: unset;
  font-size: 22px;
  line-height: 1.1818181818;
  letter-spacing: 0.08em;
  font-weight: 800;
}
.dc-card.--card2 .dc-card2__no {
  font-weight: 500;
  font-family: "Roboto", sans-serif;
  font-size: 37px;
  line-height: 1.1351351351;
  letter-spacing: -0.016em;
  color: var(--primary);
}
.dc-card.--card2 .dc-card2__heading {
  margin-bottom: 5px;
  font-size: 20px;
  line-height: 1.5;
  letter-spacing: 0em;
  font-weight: 700;
}
.dc-card.--card2 .dc-card2__heading.--lhhigh {
  line-height: 38px;
}
.dc-card.--card2-secondary .dc-card2__no {
  color: var(--secondary);
}
.dc-card.--card2-green .dc-card2__no {
  color: var(--green);
}
@media screen and (max-width: 768px) {
  .dc-card.--card2 {
    padding: 56px 30px 25px;
  }
  .dc-card.--card2 .dc-card2-item {
    position: relative;
    gap: 10px;
    margin-bottom: 45px;
  }
  .dc-card.--card2 .dc-card2-item-column.--no {
    position: absolute;
    top: 0;
    left: 0;
  }
  .dc-card.--card2 .dc-card2-item::after {
    bottom: -22.5px;
  }
  .dc-card.--card2 .dc-card2__balloon {
    font-weight: 700;
  }
  .dc-card.--card2 .dc-card2__heading {
    padding-left: 35px;
    font-size: 20px;
    line-height: 1.5;
    letter-spacing: -0.028em;
    font-weight: 600;
  }
  .dc-card.--card2 .dc-card2__heading.--lhhigh {
    line-height: 30px;
  }
}
@media screen and (max-width: 389px) {
  .dc-card.--card2 {
    padding-left: 6.4102564103vw;
    padding-right: 6.4102564103vw;
  }
}
.dc-card.--card3 {
  display: flex;
  flex-direction: column;
  gap: 14px;
  width: 278px;
  max-width: 100%;
}
.dc-card.--card3 .dc-card3-tags {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  gap: 8px;
}
.dc-card.--card3 .dc-card3-meta {
  width: fit-content;
  max-width: 100%;
  margin: 10px 0 0;
}
.dc-card.--card3 .dc-card3-body {
  font-size: 16px;
  line-height: 1.875;
  letter-spacing: -0.032em;
  font-weight: 500;
}
.dc-card.--card3 .dc-card3__img img {
  display: flex;
}
.dc-card.--card3 .dc-card3__heading {
  display: flex;
  align-items: flex-end;
  gap: 5px;
  margin-bottom: 14px;
}
.dc-card.--card3 .dc-card3__heading__main {
  font-size: 22px;
  line-height: 1.2272727273;
  letter-spacing: 0.08em;
  font-weight: 700;
}
.dc-card.--card3 .dc-card3__heading__sub {
  font-size: 14px;
  line-height: 1.2142857143;
  letter-spacing: 0.028em;
  font-weight: 600;
  color: #dcdddd;
}
@media screen and (max-width: 768px) {
  .dc-card.--card3 .dc-card3-meta {
    margin: 10px 0 0;
  }
  .dc-card.--card3 .dc-card3-body {
    font-size: 16px;
    line-height: 1.875;
    letter-spacing: -0.032em;
  }
}
.dc-card.--card4 {
  display: flex;
  align-items: center;
  flex-direction: column;
  width: 488px;
  max-width: 100%;
}
.dc-card.--card4 .dc-txt.--txt-tel .dc-icon {
  width: 39px;
  height: 25px;
}
.dc-card.--card4 .dc-txt.--txt-tel .dc-txt-tel__txt {
  font-size: 29px;
  line-height: 1.2068965517;
  letter-spacing: 0.028em;
  font-weight: 600;
}
.dc-card.--card4 .dc-card4-content {
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: center;
  gap: 10px;
  width: 100%;
  height: 178px;
  padding: 40px 20px 20px;
  font-size: 20px;
  line-height: 1.5;
  letter-spacing: -0.032em;
  font-weight: 600;
  text-align: center;
  border-radius: 15px;
  background-color: white;
}
.dc-card.--card4 .dc-card4-content p {
  margin-bottom: 0;
}
.dc-card.--card4 .dc-card4-content .small {
  font-size: 14px;
  line-height: 2;
  letter-spacing: 0.008em;
  font-weight: 500;
  text-align: center;
}
.dc-card.--card4 .dc-card4-content .columns {
  display: flex;
  align-items: center;
  flex-direction: row;
  justify-content: center;
  gap: 17px;
}
.dc-card.--card4 .dc-card4__balloon {
  margin-bottom: -25px;
  font-size: 22px;
  line-height: 1.2181818182;
  letter-spacing: 0.08em;
  font-weight: 700;
}
.dc-card.--card5 {
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 159px;
  max-width: 100%;
  min-height: 86.5px;
  font-size: 18px;
  line-height: 1.2222222222;
  letter-spacing: 0.06em;
  font-weight: 600;
  color: white;
  background-color: var(--primary);
  text-decoration: unset;
  border-radius: 20px;
  box-shadow: 0 0 8px 0 rgba(51, 51, 51, 0.3);
}
.dc-card.--card5 p {
  margin-bottom: 0;
}
.dc-card.--card5 .dc-txt.--txt-tel {
  gap: 3px;
}
.dc-card.--card5 .dc-txt.--txt-tel .dc-txt-tel__icon {
  width: 21.7px;
  height: 14px;
}
.dc-card.--card5 .dc-txt.--txt-tel .dc-txt-tel__txt {
  font-size: 17.5px;
  line-height: 1.2;
  letter-spacing: -0.0012em;
}
.dc-card.--card5-green {
  background-color: var(--green);
}
.dc-card.--card5-group {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 24px;
}

.dc-box.--box-primary {
  width: 989px;
  max-width: 100%;
  margin: 0 auto;
  padding: 30px;
  border: 4px solid rgba(238, 103, 0, 0.5);
  border-radius: 15px;
}
.dc-box.--box-primary .dc-box-txt {
  font-size: 16px;
  line-height: 1.875;
  letter-spacing: 0.01em;
  font-weight: 500;
}
.dc-box.--box-primary .dc-box__heading {
  margin-bottom: 22px;
  font-size: 27px;
  line-height: 1.2185185185;
  letter-spacing: 0.08em;
  font-weight: 600;
  color: var(--primary);
}
@media screen and (max-width: 768px) {
  .dc-box.--box-primary .dc-box__heading {
    margin-bottom: 30px;
    font-size: 22px;
    line-height: 1.3181818182;
    letter-spacing: 0.08em;
    font-weight: 700;
    text-align: center;
  }
}

.dc-block.--block1 {
  display: flex;
  flex-direction: column;
}

.dc-block.--block1 .dc-txt.--txt-balloon {
  margin: 0 auto;
  margin-bottom: -13px;
}

.dc-block.--block1 .dc-card {
  flex: 1;
}

.dc-block.--block2 {
  display: flex;
  align-items: center;
  flex-direction: column;
  gap: 12px;
}

.dc-block.--block2 .dc-btn.--btn-primary {
  position: relative;
  width: 307px;
  max-width: 100%;
  min-height: 76px;
  padding: 10px 20px;
  font-size: 22px;
  line-height: 1.1818181818;
}

.dc-block.--block2 .dc-btn.--btn-primary::after {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  left: unset;
  right: 25px;
  width: 12px;
  height: 18px;
}

@media screen and (max-width: 768px) {
  .dc-block.--block2 .dc-btn.--btn-primary {
    width: 320px;
    min-height: 55px;
    font-size: 18px;
    line-height: 1.2222222222;
  }
}
.dc-block.--block-guide {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 40px;
  width: 896px;
  max-width: 100%;
  margin: 0 auto;
}

.dc-block.--block-guide .dc-block-guide-left {
  display: flex;
  align-items: center;
  gap: 8px;
}

.dc-block.--block-guide .dc-block-guide__txt {
  font-size: 20px;
  line-height: 1.8;
  letter-spacing: -0.036em;
}

.dc-block.--block-guide .dc-block-guide__txt .small {
  display: inline-block;
  margin-top: 5px;
  font-size: 16px;
  line-height: 1.5;
  letter-spacing: -0.032em;
}

.dc-block.--block-guide .dc-block-guide__no {
  font-family: "Roboto", sans-serif;
  font-style: normal;
  font-size: 97px;
  line-height: 1.1237113402;
  font-weight: 400;
}

.dc-block.--block-guide .dc-block-guide__img {
  width: 313px;
  max-width: 100%;
}

.dc-block.--block-guide .dc-block-guide__img img {
  box-shadow: 0 0 14px 0 rgba(35, 24, 21, 0.4);
}

.dc-block.--block-guide.--r {
  flex-direction: row-reverse;
}

.dc-block.--block-guide.--r .dc-block-guide-left {
  flex-direction: row-reverse;
  gap: 70px;
}

@media screen and (max-width: 768px) {
  .dc-block.--block-guide {
    align-items: flex-start;
    flex-direction: column;
    gap: 20px;
  }
  .dc-block.--block-guide .dc-block-guide-left {
    gap: 17px;
  }
  .dc-block.--block-guide .dc-block-guide__img {
    width: 320px;
  }
  .dc-block.--block-guide .dc-block-guide__img img {
    display: flex;
    width: 100%;
  }
  .dc-block.--block-guide .dc-block-guide__no {
    font-size: 61px;
    line-height: 1;
    letter-spacing: -0.32px;
  }
  .dc-block.--block-guide .dc-block-guide__txt {
    font-size: 15px;
    line-height: 1.8666666667;
  }
  .dc-block.--block-guide .dc-block-guide__txt .small {
    margin: 0;
    font-size: 14px;
    line-height: 1.7142857143;
  }
  .dc-block.--block-guide.--r {
    flex-direction: column;
  }
  .dc-block.--block-guide.--r .dc-block-guide-left {
    flex-direction: row;
    gap: 17px;
  }
}
.dc-block-1-group {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  justify-content: center;
  gap: 54px;
}

@media screen and (max-width: 768px) {
  .dc-block-1-group {
    gap: 30px;
  }
}
.dc-block-guide-group {
  display: flex;
  flex-direction: column;
  gap: 25px;
}

@media screen and (max-width: 768px) {
  .dc-block-guide-group {
    width: 320px;
    max-width: 100%;
    margin: 0 auto;
    gap: 48px;
  }
}
.dc-block.--block3 {
  display: flex;
  flex-wrap: nowrap;
  flex-direction: row;
  gap: 12px;
}
.dc-block.--block3 .dc-block3-column.--img img {
  display: flex;
}
@media screen and (max-width: 768px) {
  .dc-block.--block3 {
    flex-direction: column;
  }
}
.dc-block.--block4 {
  display: flex;
  flex-direction: column;
  gap: 58px;
  width: 989px;
  max-width: 100%;
  margin: 0 auto;
  padding: 40px;
  border-radius: 20px;
  box-shadow: 0 0 10px 0 rgba(51, 51, 51, 0.3);
  background-color: white;
}
.dc-block.--block4 .dc-block4-top {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  flex-direction: row;
  gap: 23px;
}
.dc-block.--block4 .dc-block4-top .dc-block4-columns {
  align-items: center;
}
.dc-block.--block4 .dc-block4-top .dc-block4-columns .column.--heading {
  width: 130px;
  height: 130px;
  font-size: 18px;
  line-height: 1.2222222222;
  letter-spacing: 0.08em;
  border-radius: 15px;
  background-color: #f4f2ee;
}
.dc-block.--block4 .dc-block4-top-column {
  max-width: 100%;
}
.dc-block.--block4 .dc-block4-top-column.--img {
  width: 301px;
}
.dc-block.--block4 .dc-block4-top-column.--txt {
  flex: 1;
}
.dc-block.--block4 .dc-block4-bottom {
  position: relative;
}
.dc-block.--block4 .dc-block4-bottom::before {
  content: "";
  position: absolute;
  top: -29px;
  left: 0;
  width: 100%;
  border-top: 2px solid #dcdddd;
}
.dc-block.--block4 .dc-block4-bottom .dc-block4-columns .column.--heading {
  width: 211px;
  height: auto;
  max-height: 110px;
  padding: 10px 0;
  padding-right: 20px;
  font-size: 17px;
  line-height: 1.7368421053;
  letter-spacing: 0.08em;
  font-weight: 600;
  text-align: center;
  background-image: url("../img/block4_deco.png");
  background-size: 100% 100%;
  background-repeat: no-repeat;
  color: white;
}
.dc-block.--block4 .dc-block4-columns {
  display: flex;
  flex-direction: row;
  gap: 15px;
}
.dc-block.--block4 .dc-block4-columns .column.--txt {
  flex: 1;
  font-size: 17px;
  line-height: 1.7647058824;
  letter-spacing: 0.01em;
  font-weight: 500;
}
.dc-block.--block4 .dc-block4-columns .column.--heading {
  display: flex;
  align-items: center;
  justify-content: center;
}
.dc-block.--block4 .dc-block4__heading {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 15px;
  font-size: 22px;
  line-height: 1.2181818182;
  letter-spacing: 0.006em;
  font-weight: 600;
}
.dc-block.--block4 .dc-block4__heading .no {
  font-family: "Roboto", sans-serif;
  font-size: 37px;
  line-height: 1.1351351351;
  letter-spacing: -0.032em;
  font-weight: 500;
}
.dc-block.--block4-group {
  display: flex;
  flex-direction: column;
  gap: 52px;
}
@media screen and (min-width: 769px) {
  .dc-block.--block4 .dc-block4-top-column.--txt {
    min-width: 300px;
  }
}
@media screen and (max-width: 768px) {
  .dc-block.--block4 {
    gap: 25px;
    width: 400px;
    padding: 0;
  }
  .dc-block.--block4 .dc-block4-top {
    align-items: center;
    flex-direction: column;
    gap: 16px;
  }
  .dc-block.--block4 .dc-block4-top-column {
    width: 100% !important;
    padding: 0 33px;
  }
  .dc-block.--block4 .dc-block4-top-column img {
    width: 100%;
    height: 157px;
    object-fit: cover;
  }
  .dc-block.--block4 .dc-block4-top .dc-block4-columns .column.--heading {
    width: 100%;
    height: auto;
    padding: 13px 20px;
    font-weight: 600;
    border-radius: 2em;
  }
  .dc-block.--block4 .dc-block4-bottom {
    padding: 0 33px 30px;
  }
  .dc-block.--block4 .dc-block4-bottom::before {
    display: none;
  }
  .dc-block.--block4 .dc-block4-bottom .dc-block4-columns .column.--heading {
    width: 100%;
    max-height: unset;
    padding: 10px 10px 25px;
    font-size: 18px;
    line-height: 1.7222222222;
    letter-spacing: 0.04em;
    background-image: url(../img/block4_deco_sp.png);
  }
  .dc-block.--block4 .dc-block4-columns {
    flex-direction: column;
    gap: 20px;
  }
  .dc-block.--block4 .dc-block4__heading {
    flex-direction: column;
    gap: 17px;
    width: 100%;
    margin: 0;
    font-size: 22px;
    line-height: 1.5454545455;
    letter-spacing: -0.008em;
    text-align: center;
  }
  .dc-block.--block4 .dc-block4__heading .no {
    width: 100%;
    padding: 9px 20px;
    font-size: 32px;
    line-height: 1.125;
    letter-spacing: -0.032em;
    text-align: center;
    border-radius: 20px 20px 0 0;
    color: white;
    background: var(--gradation-primary);
  }
}

.dc-faq {
  width: 900px;
  max-width: 100%;
}

.dc-faq p {
  margin-bottom: 13px;
}

.dc-faq p:last-child {
  margin-bottom: 0;
}

.dc-faq .dc-faq-q {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 25px;
  padding-left: 22px;
  cursor: pointer;
}

.dc-faq .dc-faq-q .dc-faq__icon {
  color: var(--primary);
}

.dc-faq .dc-faq-a {
  display: none;
}

.dc-faq .dc-faq-a .dc-faq__icon {
  position: absolute;
  left: 22px;
  top: 20px;
  color: var(--secondary);
}

.dc-faq .dc-faq-a-in {
  position: relative;
  padding: 21px 62px 28px;
  margin-top: 20px;
  border-radius: 20px;
  background: #f4f2ee;
}

.dc-faq .dc-faq__txt {
  font-size: 16px;
  line-height: 2.1875;
  letter-spacing: -0.016em;
  font-weight: 500;
}

.dc-faq .dc-faq__icon {
  font-size: 37px;
  line-height: 1;
  font-weight: 600;
}

.dc-faq .dc-faq__heading {
  margin: 0;
  font-size: 20px;
  line-height: 1.75;
  font-weight: 600;
  padding-right: 50px;
}

.dc-faq .dc-faq__toggle {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  left: unset;
  right: 25px;
  width: 24px;
  height: 24px;
}

.dc-faq .dc-faq__toggle::before,
.dc-faq .dc-faq__toggle::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  background-color: var(--primary);
  transition: all 0.2s;
}

.dc-faq .dc-faq__toggle::before {
  height: 3px;
}

.dc-faq .dc-faq__toggle::after {
  width: 3px;
}

.dc-faq.--show .dc-faq__toggle::after {
  opacity: 0;
}

.dc-faq-group {
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: center;
  gap: 45px;
  width: fit-content;
  max-width: 100%;
  margin: 0 auto;
}

@media screen and (max-width: 768px) {
  .dc-faq .dc-faq-q {
    align-items: flex-start;
    gap: 25px;
    min-height: 37px;
    padding: 0;
    padding-right: 30px;
  }
  .dc-faq .dc-faq-q .dc-faq__icon {
    margin-top: 0px;
  }
  .dc-faq .dc-faq-a .dc-faq__icon {
    position: static;
    float: left;
    padding-right: 15px;
    font-size: 18px;
    line-height: 1.5555555556;
  }
  .dc-faq .dc-faq-a-in {
    padding: 17px 20px 18px;
    padding-right: 15px;
    margin-top: 10px;
    background-color: white;
  }
  .dc-faq .dc-faq__heading {
    font-size: 18px;
    line-height: 1.6666666667;
    letter-spacing: 0;
    padding-right: 0;
  }
  .dc-faq .dc-faq__toggle {
    top: 5px;
    right: 0;
    bottom: unset;
  }
  .dc-faq .dc-faq__txt {
    font-size: 16px;
    line-height: 1.75;
    letter-spacing: -0.32px;
    font-size: 16px;
    line-height: 1.75;
    letter-spacing: -0.016em;
  }
  .dc-faq-group {
    gap: 20px;
  }
}
.dc-table.--table1 {
  margin-top: 54px;
}

.dc-table.--table1 ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.dc-table.--table1 ul li {
  position: relative;
  padding-left: 1em;
}

.dc-table.--table1 ul li::before {
  content: "・";
  position: absolute;
  left: 0;
}

.dc-table.--table1 .dc-table-in {
  display: flex;
  align-items: flex-end;
  flex-direction: row;
  justify-content: center;
  width: fit-content;
  margin: 0 auto;
  border-bottom: 2px solid #dcdddd;
  border-radius: 0 0 20px 20px;
}

.dc-table.--table1 .dc-table-col:nth-child(1) .dc-table-cell {
  width: 274px;
  padding: 20px 45px;
  font-size: 20px;
  line-height: 1.45;
  font-weight: 600;
  letter-spacing: -0.032em;
  text-align: left;
  background-color: #f4f2ee;
}

.dc-table.--table1 .dc-table-col:nth-child(1) .dc-table-cell:first-child {
  border-top: 2px solid #dcdddd;
  border-radius: 20px 0 0 0;
}

.dc-table.--table1 .dc-table-col:nth-child(1) .dc-table-cell:last-child {
  border-radius: 0 0 0 20px;
}

.dc-table.--table1 .dc-table-col:nth-child(1) .dc-table-cell:nth-child(2),
.dc-table.--table1 .dc-table-col:nth-child(1) .dc-table-cell:nth-child(3) {
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 210px;
}

.dc-table.--table1 .dc-table-col:not(:nth-child(1)) .dc-table-cell:nth-child(4),
.dc-table.--table1
  .dc-table-col:not(:nth-child(1))
  .dc-table-cell:nth-child(6) {
  display: flex;
  align-items: flex-start;
  flex-direction: column;
  justify-content: center;
  height: 145px;
}

.dc-table.--table1 .dc-table-col:nth-child(2) {
  position: relative;
  bottom: -2px;
  width: 272px;
  margin-top: -32px;
  box-shadow: 0 0 20px 0 rgba(59, 49, 47, 0.3);
  background-color: white;
  border-radius: 20px;
  overflow: hidden;
}

.dc-table.--table1 .dc-table-col:nth-child(2) .dc-table-cell {
  border-left: 0;
}

.dc-table.--table1 .dc-table-col:nth-child(2) .dc-table-cell:nth-child(1) {
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: center;
  padding: 20px 10px;
  min-height: 81px;
  font-size: 22px;
  line-height: 1.2272727273;
  letter-spacing: 0.008em;
  font-weight: 700;
  color: white;
  text-align: center;
  background: var(--gradation-primary);
  border-bottom: 1px solid white;
}

.dc-table.--table1 .dc-table-col:nth-child(2) .dc-table-cell:last-child {
  height: 147px;
}

.dc-table.--table1 .dc-table-col:nth-child(3) .dc-table-cell:nth-child(1),
.dc-table.--table1 .dc-table-col:nth-child(4) .dc-table-cell:nth-child(1) {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 51px;
  padding: 0;
  font-size: 20px;
  line-height: 1.2;
  font-weight: 700;
  color: white;
  text-align: center;
  border-radius: 20px 20px 0 0;
  background-color: #898989;
}

.dc-table.--table1 .dc-table-col:nth-child(3) .dc-table-cell:nth-child(4),
.dc-table.--table1 .dc-table-col:nth-child(4) .dc-table-cell:nth-child(4) {
  align-items: center;
  text-align: center;
}

.dc-table.--table1 .dc-table-col:nth-child(3) .dc-table-cell {
  border-left: 0;
}

.dc-table.--table1 .dc-table-col:nth-child(3) .dc-table-cell:first-child {
  border-left: 2px solid white;
  border-right: 1px solid white;
}

.dc-table.--table1 .dc-table-col:nth-child(3) .dc-table-cell:last-child {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  padding-top: 29px;
}

.dc-table.--table1 .dc-table-col:last-child .dc-table-cell {
  border-right: 2px solid #dcdddd;
}

.dc-table.--table1 .dc-table-col:last-child .dc-table-cell:first-child {
  border-left: 1px solid white;
}

.dc-table.--table1 .dc-table-col:last-child .dc-table-cell:last-child {
  border-radius: 0 0 20px 0;
}

.dc-table.--table1 .dc-table-cell {
  min-height: 65px;
  padding: 20px 30px;
  padding-right: 20px;
  font-size: 18px;
  line-height: 1.6111111111;
  letter-spacing: -0.032em;
  border-left: 2px solid #dcdddd;
  border-bottom: 2px solid #dcdddd;
}

.dc-table.--table1 .dc-table-cell .dc-icon {
  position: relative;
  right: 5px;
  margin: 0 auto;
}

.dc-table.--table1 .dc-table-cell:last-child {
  border-bottom: 0;
}

@media screen and (min-width: 769px) {
  .dc-table.--table1 {
    padding-top: 54px;
    padding-bottom: 30px;
    margin-top: 34px;
    overflow: auto;
  }
  .dc-table.--table1 .dc-table-col:nth-child(3),
  .dc-table.--table1 .dc-table-col:nth-child(4) {
    width: 269px;
  }
}
@media screen and (max-width: 768px) {
  .dc-table.--table1 {
    padding: 54px 0 40px;
    margin-top: 6px;
    overflow: auto;
  }
  .dc-table.--table1::-webkit-scrollbar {
    height: 16px;
    border-radius: 20px;
    background: #efefef;
  }
  .dc-table.--table1::-webkit-scrollbar-track {
    border-radius: 20px;
  }
  .dc-table.--table1::-webkit-scrollbar-thumb {
    border-radius: 2em;
    background: #c9caca;
  }
  .dc-table.--table1 .dc-table-col:nth-child(1) {
    width: 224px;
  }
  .dc-table.--table1 .dc-table-col:nth-child(1) .dc-table-cell {
    width: auto;
    padding: 20px 30px;
    padding-left: 35px;
  }
  .dc-table.--table1 .dc-table-col:nth-child(2) {
    width: 272px;
  }
  .dc-table.--table1 .dc-table-col:nth-child(3),
  .dc-table.--table1 .dc-table-col:nth-child(4) {
    width: 269px;
  }
}
.dc-section {
  position: relative;
}

.dc-section-back {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
}

.dc-section-back img {
  width: 100%;
  height: 100%;
  display: flex;
  object-fit: cover;
}

.dc-section-in {
  position: relative;
  z-index: 10;
  max-width: 100%;
  padding: 0 40px;
  margin: auto;
}

@media screen and (max-width: 768px) {
  .dc-section-in {
    padding: 0 20px;
  }
}
.dc-section.--fv
  .dc-block-1-group
  .dc-block.--block1:last-child
  .dc-card1__txt {
  letter-spacing: -0.01em;
}

.dc-section.--fv .dc-fv-top {
  position: relative;
  padding: 59px 0 30px;
}

.dc-section.--fv .dc-fv-top-abs {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
}

.dc-section.--fv .dc-fv-top-abs-wrap {
  position: relative;
  width: 1477px;
  margin: 0 calc(-738.5px + 50vw);
  transform: translateX(-40px);
}

.dc-section.--fv .dc-fv-top-abs.--abs1 {
  right: unset;
}

.dc-section.--fv .dc-fv-top-abs.--abs2 {
  left: unset;
}

.dc-section.--fv .dc-fv-bottom {
  padding-bottom: 80px;
}

@media screen and (min-width: 769px) {
  .dc-fv-bottom.--with-padding-top {
    padding-top: 30px;
  }
}

.dc-section.--fv .dc-fv-bottom__heading {
  margin-bottom: 35px;
  font-size: 30px;
  line-height: 1.8;
  text-align: center;
}

.dc-section.--fv .dc-fv-bottom__heading .big {
  margin-left: 0.1em;
  font-size: 46px;
  line-height: 1.1739130435;
}

.dc-section.--fv .dc-fv-tag {
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: center;
  gap: 3px;
  width: 170px;
  height: 170px;
  padding-top: 10px;
  background: linear-gradient(90deg, #ffff00, #eec701);
  border-radius: 100%;
  box-shadow: 0 0 14px 0 rgba(35, 24, 21, 0.2);
  text-align: center;
}

.dc-section.--fv .dc-fv-tag__sub {
  font-size: 17.7px;
  line-height: 1.186440678;
  font-weight: 600;
  letter-spacing: -0.04em;
}

.dc-section.--fv .dc-fv-tag__main {
  font-size: 22.2px;
  line-height: 1.3918918919;
  font-weight: 600;
  letter-spacing: -0.08em;
}

.dc-section.--fv .dc-fv-heading {
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: center;
  gap: 45.5px;
  text-align: center;
}

.dc-section.--fv .dc-fv-heading__sub .dc-txt.--txt1 {
  font-size: 26px;
  line-height: 1.75;
  letter-spacing: 0.14em;
  font-weight: 500;
}

.dc-section.--fv .dc-fv-heading__main {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 15px;
  font-size: 49.3px;
  line-height: 1.2170385396;
  letter-spacing: 0.08em;
  font-weight: 600;
}

.dc-section.--fv .dc-fv-btn {
  display: flex;
  align-items: center;
  flex-direction: column;
  gap: 10px;
  margin-top: 27px;
}

.dc-section.--fv .dc-fv-btn .dc-btn {
  position: relative;
  width: 367px;
  max-width: 100%;
  padding: 10px 30px;
}

.dc-section.--fv .dc-fv-btn .dc-btn::after {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  left: unset;
  right: 30px;
  width: 10px;
  height: 16px;
}

.dc-section.--fv .dc-fv-regist {
  display: flex;
  align-items: center;
  flex-direction: column;
  gap: 12px;
  font-size: 15.5px;
  line-height: 1.7096774194;
  letter-spacing: 0.04em;
  font-weight: 600;
  color: var(--primary);
}
.dc-section.--fv .dc-fv-regist p {
  margin-bottom: 0;
}
.dc-section.--fv .dc-fv-regist .attention {
  margin-top: 5px;
  font-size: 17px;
  line-height: 1.1764705882;
  letter-spacing: 0.01em;
  color: #333;
}
.dc-section.--fv .dc-fv-regist .attention span {
  text-decoration: underline;
}
.dc-section.--fv .dc-fv-regist .dc-btn.--btn-primary {
  background: var(--primary);
}
.dc-section.--fv .dc-fv-contact {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  justify-content: center;
  gap: 48px;
  margin-top: 26px;
}
.dc-section.--fv .dc-fv-contact > .dc-tb-hidden {
  width: 100%;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .dc-section.--fv {
    background-color: #f4f2ee;
  }
  .dc-section.--fv .dc-section-back {
    display: none;
  }
  .dc-section.--fv .dc-fv-top {
    position: relative;
    display: flex;
    flex-direction: column-reverse;
    gap: 26px;
    padding: 22px 0 0;
    margin-bottom: 34px;
  }
  .dc-section.--fv .dc-fv-top-abs {
    position: static;
    width: 161px;
    max-width: unset;
    height: 123px;
    margin: 0;
  }
  .dc-section.--fv .dc-fv-top-abs img {
    display: flex;
    width: 100%;
    height: 100%;
    border-radius: 10px;
    object-fit: cover;
    object-position: top;
  }
  .dc-section.--fv .dc-fv-top-abs-wrap {
    position: static;
    display: flex;
    flex-wrap: nowrap;
    flex-direction: row;
    justify-content: flex-start;
    gap: 12px;
    width: 100vw;
    min-width: 515px;
    margin: 0 calc(-257.5px + 50vw);
    transform: translateX(-20px);
  }
  .dc-section.--fv .dc-fv-top .dc-block.--block2 {
    margin-top: 10px;
  }
  .dc-section.--fv .dc-fv-tag {
    width: 94px;
    height: 94px;
    box-shadow: 0 0 14px 0 rgba(51, 51, 51, 0.2);
  }
  .dc-section.--fv .dc-fv-tag .dc-fv-tag__sub {
    font-size: 9.7px;
    line-height: 1.2268041237;
  }
  .dc-section.--fv .dc-fv-tag .dc-fv-tag__main {
    font-size: 12.2px;
    line-height: 1.4016393443;
  }
  .dc-section.--fv .dc-fv-heading {
    gap: 21px;
  }
  .dc-section.--fv .dc-fv-heading__sub {
    font-size: 16.9px;
    line-height: 1.2189349112;
    letter-spacing: 0.14em;
  }
  .dc-section.--fv .dc-fv-heading__sub .dc-txt.--txt1 {
    font-size: 14px;
    line-height: 1.75;
    letter-spacing: 0.14em;
    font-weight: 600;
  }
  .dc-section.--fv .dc-fv-heading__main {
    gap: 10px;
    font-size: 28px;
    line-height: 1.2176870748;
    letter-spacing: 0.08em;
    font-weight: 700;
  }
  .dc-section.--fv .dc-fv-heading__main__logo {
    width: 238px;
  }
  .dc-section.--fv .dc-fv-btn {
    gap: 6px;
    margin-top: 20px;
  }
  .dc-section.--fv .dc-fv-btn .dc-btn {
    width: 320px;
    min-height: 55px;
  }
  .dc-section.--fv .dc-fv-bottom {
    padding-bottom: 0;
    width: 100vw;
    margin: 0 calc(-50vw + 50%);
    background-color: white;
  }
  .dc-section.--fv .dc-fv-bottom__heading {
    margin-bottom: 25px;
    font-size: 24px;
    line-height: 1.5833333333;
  }
  .dc-section.--fv .dc-fv-bottom__heading .big {
    font-size: inherit;
    line-height: inherit;
  }
  .dc-section.--fv .dc-block.--block1 {
    max-width: 100%;
  }
  .dc-section.--fv .dc-fv-contact-sp {
    padding: 34px 0 32px;
    font-size: 14px;
    line-height: 2;
    letter-spacing: 0.008em;
    text-align: center;
  }
  .dc-section.--fv .dc-fv-contact-sp .link {
    margin-bottom: 17px;
  }
}
.dc-section.--cta {
  padding: 50px 40px;
  text-align: center;
}

.dc-section.--cta .dc-section-in {
  width: 810px;
  padding: 30px 40px 35px;
  border-radius: 20px;
}

.dc-section.--cta .dc-cta__heading {
  margin-bottom: 8px;
  font-size: 30px;
  line-height: 1.4833333333;
  letter-spacing: 0.08em;
  font-weight: 600;
  color: white;
}
.dc-section.--cta .dc-cta__heading.--small {
  margin-bottom: 25px;
  font-size: 27px;
  line-height: 1.5344827586;
  letter-spacing: 0.04em;
}

.dc-section.--cta .dc-cta__catch {
  margin-bottom: 23px;
  font-size: 16px;
  line-height: 1.9;
  letter-spacing: 0.01em;
  font-weight: 600;
}

.dc-section.--cta .dc-block.--block2 {
  gap: 18px;
}
.dc-section.--cta .dc-cta__detail {
  margin-top: 16px;
  font-size: 15px;
  line-height: 1.2;
  letter-spacing: 0.01em;
  font-weight: 500;
}
.dc-section.--cta .dc-cta__detail a {
  color: inherit;
}
.dc-section.--cta .dc-cta__detail .attention span {
  text-decoration: underline;
}
.dc-section.--cta-gray {
  background-color: #f4f2ee;
}
.dc-section.--cta-orange .dc-section-in {
  background: #f9a549;
}

@media screen and (max-width: 768px) {
  .dc-section.--cta {
    padding: 0;
  }
  .dc-section.--cta .dc-section-in {
    padding: 25px 10px 25px;
    border-radius: 0;
  }
  .dc-section.--cta .dc-cta__heading {
    margin-bottom: 20px;
    font-size: 26px;
    line-height: 1.4807692308;
    letter-spacing: 0.08em;
  }
  .dc-section.--cta .dc-cta__heading.--small {
    margin-bottom: 20px;
    font-size: 24px;
    line-height: 1.5208333333;
    letter-spacing: 0.08em;
  }
  .dc-section.--fv .dc-section.--cta .dc-cta__heading.--small {
    margin-bottom: 12px;
  }
  .dc-section.--cta .dc-cta__heading.--smaller {
    margin-bottom: 14px;
    font-size: 21px;
    line-height: 1.7380952381;
    letter-spacing: 0.08em;
  }
  .dc-section.--cta .dc-cta__catch {
    margin-bottom: 30px;
    font-size: 16px;
    line-height: 1.875;
    letter-spacing: 0.01em;
  }
  .dc-section.--cta .dc-block.--block2 {
    gap: 8px;
  }
  .dc-section.--cta .dc-cta__detail {
    margin-top: 21px;
  }
  .dc-section.--cta .dc-cta__detail .attention {
    font-size: 15px;
    line-height: 1.6;
    letter-spacing: 0.1em;
    font-weight: 400;
  }
  .dc-section.--cta .dc-txt.--txt1 {
    margin-bottom: 20px;
    font-size: 16px;
    line-height: 1.625;
    letter-spacing: 0.1em;
  }
}
.dc-section.--faq {
  padding: 55px 0;
}
.dc-section.--faq .dc-faq-group + .dc-heading {
  margin-top: 52px;
}

.dc-section.--faq .dc-section-in {
  width: 900px;
}

.dc-section.--faq h2 {
  margin-bottom: 20px;
  font-size: 30px;
  line-height: 1.2;
  font-weight: 600;
  text-align: center;
}

.dc-section.--faq .dc-block.--block2 {
  width: fit-content;
  max-width: 100%;
  margin-left: 0;
}

.dc-section.--faq .dc-block.--block2 .dc-txt.--txt1 {
  font-size: 17px;
  line-height: 1.2176470588;
}

@media screen and (max-width: 768px) {
  .dc-section.--faq {
    padding: 32px 0;
  }
  .dc-section.--faq h2 {
    margin-bottom: 25px;
    text-align: left;
  }
  .dc-section.--faq .dc-section-in {
    width: 500px;
    padding: 0 30px;
  }
  .dc-section.--faq .dc-faq-btn {
    display: flex;
    justify-content: center;
    margin-top: 15px;
  }
  .dc-section.--faq .dc-faq-group + .dc-heading {
    margin-top: 30px;
  }
}
@media screen and (max-width: 370px) {
  .dc-section.--faq .dc-section-in {
    padding: 0 20px;
  }
}
.dc-section.--worries {
  padding: 50px 0;
}
.dc-section.--worries .dc-worries-item {
  display: flex;
  align-items: center;
  flex-direction: column;
  gap: 15px;
}
.dc-section.--worries .dc-worries-itemGroup {
  flex-wrap: wrap;
  justify-content: center;
  gap: 30px 52px;
}
.dc-section.--worries .dc-worries-item__img {
  display: flex;
}
.dc-section.--worries .dc-worries-item__txt {
  font-size: 20px;
  line-height: 1.8;
  letter-spacing: -0.016em;
  font-weight: 700;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .dc-section.--worries {
    padding: 30px 0;
  }
  .dc-section.--worries .dc-heading.--heading1 {
    margin-bottom: 45px;
  }
  .dc-section.--worries .dc-worries-itemGroup {
    gap: 35px;
  }
}
.dc-section.--flow {
  padding: 45px 0;
}
.dc-section.--flow h2.dc-heading.--heading1 {
  margin-bottom: 30px;
}
.dc-section.--flow .dc-flow-columns {
  justify-content: center;
  gap: 50px;
}
.dc-section.--flow
  .dc-flow-columns
  .dc-column:first-child
  .dc-card.--card2
  .dc-card2-item-column.--txt {
  margin-bottom: 0.5px;
}
.dc-section.--flow
  .dc-flow-columns
  .dc-column:last-child
  .dc-card.--card2
  .dc-txt.--txt-tel {
  margin-top: -5px;
  margin-bottom: 9px;
}
.dc-section.--flow .dc-flow__intro {
  margin-bottom: 70px;
  font-size: 16px;
  line-height: 1.1875;
  letter-spacing: 0.01em;
  font-weight: 600;
  text-align: center;
}
.dc-section.--flow .dc-box {
  margin-top: 71px;
}
@media screen and (max-width: 768px) {
  .dc-section.--flow {
    padding: 30px 0 33px;
  }
  .dc-section.--flow h2.dc-heading.--heading1 {
    margin-bottom: 20px;
  }
  .dc-section.--flow .dc-section-in {
    padding: 0 35px;
  }
  .dc-section.--flow .dc-flow-columns {
    gap: 60px;
    width: 400px;
    max-width: 100%;
    margin: 0 auto;
  }
  .dc-section.--flow
    .dc-flow-columns
    .dc-column:first-child
    .dc-card.--card2
    .dc-card2-item:nth-child(2)
    .dc-card2__heading {
    font-size: 18px;
    line-height: 1.6666666667;
    letter-spacing: -0.08em;
  }
  .dc-section.--flow
    .dc-flow-columns
    .dc-column:first-child
    .dc-card.--card2
    .dc-card2-item:nth-child(2)
    .dc-card2-item-column.--txt
    .small {
    text-align: center;
    letter-spacing: 0.028em;
  }
  .dc-section.--flow
    .dc-flow-columns
    .dc-column:first-child
    .dc-card.--card2
    .dc-card2-item:nth-child(3)
    .dc-card2__heading {
    margin-bottom: 15px;
  }
  .dc-section.--flow
    .dc-flow-columns
    .dc-column:first-child
    .dc-card.--card2
    .dc-block.--block3 {
    gap: 16px;
  }
  .dc-section.--flow
    .dc-flow-columns
    .dc-column:first-child
    .dc-card.--card2
    .dc-block.--block3
    .dc-block3-column.--img
    img {
    width: 124px;
    margin: 0 auto;
  }
  .dc-section.--flow
    .dc-flow-columns
    .dc-column:last-child
    .dc-card.--card2
    .dc-txt.--txt-tel {
    margin-top: 0;
    margin-bottom: 5px;
  }
  .dc-section.--flow
    .dc-flow-columns
    .dc-column:last-child
    .dc-card.--card2
    .dc-card2-item:nth-child(3)
    .dc-card2__heading {
    margin-bottom: 15px;
  }
  .dc-section.--flow .dc-flow__intro {
    margin-bottom: 60px;
    font-size: 15px;
    line-height: 1.8666666667;
    letter-spacing: 0.01em;
  }
  .dc-section.--flow .center-sp {
    text-align: center;
  }
  .dc-section.--flow .letterSpacing-0 {
    letter-spacing: 0;
  }
  .dc-section.--flow
    .dc-flow-columns
    .dc-column:first-child
    .dc-card.--card2
    .dc-card2-item:nth-child(2)
    .dc-card2-item-column.--txt
    .small.center-sp {
    margin-bottom: 12px;
  }
  .dc-section.--flow
    .dc-flow-columns
    .dc-column:first-child
    .dc-card.--card2
    .dc-card2-item:nth-child(2)
    .dc-card2-item-column.--txt
    > div.dc-tb {
    margin-top: 0;
  }
  .dc-section.--flow .dc-box {
    margin-top: 35px;
  }
  .dc-section.--fv .dc-fv-regist {
    font-size: 12px;
    line-height: 1.6;
  }
  .dc-section.--fv .dc-section.--cta .dc-cta__heading + p {
    color: white;
    font-size: 14px;
    line-height: 1.6;
    margin-top: 12px;
  }
}
/* iPhone SE対応 */
@media screen and (max-width: 375px) {
  .dc-section.--cta .dc-cta__heading.--small {
    font-size: 22px;
  }
}
/* 下部CTAセクションのフォントサイズ調整 */
@media screen and (max-width: 768px) {
  .dc-section.--cta .dc-cta__heading.--small-adjust {
    font-size: 22px;
  }
}
.dc-section.--cta .dc-cta__contact {
  text-align: center;
}
.dc-cta__contact--grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin: 0 auto;
  max-width: 650px;
}
.dc-cta__btn {
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: center;
  padding: 20px 0;
  color: #fff;
  font-size: 18px;
  font-weight: 600;
  text-decoration: none;
  border-radius: 8px;
  box-shadow: 0 1px 5px rgba(0, 0, 0, 0.3);
}
@media screen and (max-width: 768px) {
  .dc-cta__contact--grid {
    max-width: 354px;
  }
  .dc-cta__btn {
    font-size: 16px;
  }
}
.dc-cta__btn--primary {
  background: linear-gradient(to right, var(--primary), #db4200);
}
.dc-cta__btn--primary:hover {
  opacity: 0.9;
}
.dc-cta__btn--line {
  background: linear-gradient(to right, #44cc6d, #33a657);
}
.dc-cta__btn--line:hover {
  opacity: 0.9;
}
.dc-cta__btn--full {
  grid-column: 1 / 3;
}
.dc-cta__tel {
  display: flex;
  gap: 6px;
  align-items: center;
  justify-content: center;
  margin-top: 2px;
}
.dc-section.--case {
  padding: 45px 0;
}
.dc-section.--case h2.dc-heading.--heading1 {
  margin-bottom: 30px;
}
.dc-section.--case .dc-case__intro {
  margin-bottom: 70px;
  font-size: 16px;
  line-height: 1.1875;
  letter-spacing: 0.01em;
  font-weight: 600;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .dc-section.--case {
    padding-bottom: 32px;
  }
  .dc-section.--case .dc-section-in {
    padding: 0 35px;
  }
}
.dc-section.--feature {
  padding: 50px 0;
}
@media screen and (max-width: 768px) {
  .dc-section.--feature {
    padding: 32px 0;
  }
}
.dc-section.--concierge {
  padding: 45px 0 40px;
}
.dc-section.--concierge .dc-concierge-cardGroup {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: center;
  gap: 70px;
}
.dc-section.--concierge .dc-concierge__intro {
  margin-bottom: 40px;
  font-size: 16px;
  line-height: 1.875;
  letter-spacing: 0.01em;
  font-weight: 600;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .dc-section.--concierge {
    padding: 28px 0 34px;
  }
  .dc-section.--concierge .dc-heading.--heading1 {
    margin-bottom: 14px;
  }
  .dc-section.--concierge .dc-section-in {
    padding: 0 10px;
  }
  .dc-section.--concierge .dc-concierge-cardGroup {
    gap: 45px;
  }
  .dc-section.--concierge .dc-concierge__intro {
    margin-bottom: 50px;
    font-size: 15px;
    line-height: 1.8933333333;
    letter-spacing: 0.01em;
  }
}

@media screen and (min-width: 769px) {
  .dc-tb {
    display: none !important;
  }
}
@media screen and (max-width: 768px) {
  .dc-tb-hidden {
    display: none !important;
  }
}
@media screen and (min-width: 426px) {
  .dc-sp {
    display: none !important;
  }
}
@media screen and (max-width: 425px) {
  .dc-sp-hidden {
    display: none !important;
  }
}
/* component block */
/* safari */
_::-webkit-full-page-media,
_:future,
:root .dc-table.--table1 .dc-table-cell .dc-icon.--icon-circle {
  width: 38px;
  left: 2.5px !important;
}
