@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;
  --secondary: #009de8;
  --gradation-primary: linear-gradient(90deg, #ff9800, #ee6600);
}

/* layout */
.header-container-in .header-in {
  width: 1280px;
  max-width: 100%;
  padding: 25px 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-logo img {
  width: 322px;
}
.header-container-in .header-nav .menu-item.--btn {
  margin-left: 10px;
}
.header-container-in .header-menu {
  justify-content: flex-end;
}
.header-container-in .header-sp-menu {
  display: none;
}
.header-container-in .header-sp-menu .sp-menu {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  align-items: flex-start;
  flex-direction: column;
  gap: 30px;
}
.header-container-in .header-sp-menu .sp-menu .menu-item {
  font-size: 15px;
  letter-spacing: 0.14px;
}
.header-container-in .header-sp-menu .sp-menu .menu-item a {
  color: white;
}
.header-container-in
  .header-sp-menu
  .sp-menu
  .menu-item
  .dc-btn.--btn-primary-white {
  position: relative;
  width: 278px;
  max-width: 100%;
  min-height: 55px;
  padding: 10px 35px;
  color: var(--primary);
}
.header-container-in
  .header-sp-menu
  .sp-menu
  .menu-item
  .dc-btn.--btn-primary-white::after {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  left: unset;
  right: 20px;
}
.header-container-in .header-sp-menu-container {
  position: fixed;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  z-index: 8500;
  transform: translateX(150%);
  transition: all 0.3s;
}
.header-container-in .header-sp-menu-content {
  width: 100%;
  height: 100%;
  padding: 140px 53px 42px;
  overflow: auto;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  background: linear-gradient(90deg, #ff9800, #ee6600);
}
.header-container-in .header-sp-menu-content .header-sp-nav {
  flex: 1;
  display: flex;
  align-items: center;
  align-items: flex-start;
}
@media screen and (max-width: 370px) {
  .header-container-in .header-sp-menu-content {
    padding-left: 20px;
    padding-right: 20px;
  }
}
.header-container-in .header-sp-menu__check {
  display: none;
}
.header-container-in .header-sp-menu__check:checked ~ .header-sp-menu__btn {
  position: fixed;
  top: 21px;
  right: 22px;
}
.header-container-in
  .header-sp-menu__check:checked
  ~ .header-sp-menu__btn
  span {
  background-color: white;
}
.header-container-in
  .header-sp-menu__check:checked
  ~ .header-sp-menu__btn
  span:nth-child(1) {
  transform: rotate(30deg);
}
.header-container-in
  .header-sp-menu__check:checked
  ~ .header-sp-menu__btn
  span:nth-child(3) {
  transform: rotate(-30deg);
}
.header-container-in
  .header-sp-menu__check:checked
  ~ .header-sp-menu__btn
  span:nth-child(2) {
  display: none;
}
.header-container-in
  .header-sp-menu__check:checked
  ~ .header-sp-menu-container {
  transform: translateX(0);
}
.header-container-in .header-sp-menu__btn {
  position: relative;
  z-index: 8600;
  display: block;
  width: 23px;
  height: 13.7px;
  cursor: pointer;
}
.header-container-in .header-sp-menu__btn span {
  position: absolute;
  width: 100%;
  height: 2px;
  background-color: #333333;
  transform-origin: left;
  transition: all 0.2s;
}
.header-container-in .header-sp-menu__btn span:nth-child(1) {
  top: 0;
}
.header-container-in .header-sp-menu__btn span:nth-child(2) {
  top: 0;
  bottom: 0;
  margin: auto;
}
.header-container-in .header-sp-menu__btn span:nth-child(3) {
  bottom: 0;
}

.container {
  overflow-x: hidden;
}

.footer {
  padding: 53px 0 43px;
  text-align: center;
  background-color: #f4f2ee;
}
.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;
  }
  .header-container-in
    .header-sp-menu
    .header-menu-btn-check:checked
    ~ .header-menu-btn {
    position: fixed;
    top: 0;
    right: 0;
  }
  .header-container-in
    .header-sp-menu
    .header-menu-btn-check:checked
    ~ .header-menu-btn
    .header-menu-btn__line {
    transform-origin: top;
  }
  .header-container-in
    .header-sp-menu
    .header-menu-btn-check:checked
    ~ .header-menu-btn
    .header-menu-btn__line:nth-child(1) {
    transform: rotate(25deg) translate(1.5px, 4.5px);
  }
  .header-container-in
    .header-sp-menu
    .header-menu-btn-check:checked
    ~ .header-menu-btn
    .header-menu-btn__line:nth-child(2) {
    transform: rotate(-25deg) translate(1.5px, -5.5px);
  }
  .header-container-in
    .header-sp-menu
    .header-menu-btn-check:checked
    ~ .header-sp-menu-container {
    transform: translateX(0);
  }
  .footer {
    padding: 50px 0 66px;
  }
  .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: 14px;
  line-height: 1.3571428571;
  letter-spacing: 0.14em;
}
.menu-item a {
  color: #231815;
  text-decoration: unset;
}

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

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

.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-btn.--btn-primary {
  display: flex;
  align-items: center;
  flex-direction: row;
  justify-content: center;
  gap: 14px;
  min-height: 65px;
  padding: 10px 23px;
  padding-left: 32px;
  font-size: 18px;
  line-height: 1.2222222222;
  font-weight: 600;
  letter-spacing: 0.08em;
  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-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;
}
@media screen and (max-width: 768px) {
  .dc-txt.--txt1 {
    font-size: 17.1px;
    line-height: 1.2222222222;
  }
}
.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-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-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:last-child .dc-card1-header {
  font-size: 18px;
}
.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);
}
@media screen and (max-width: 768px) {
  .dc-card.--card1 .dc-card1-body {
    padding: 13px 30px 31px;
  }
}
.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: 45px;
  }
}
.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-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: 12px;
  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: 26px;
  top: 20px;
  color: var(--secondary);
}
.dc-faq .dc-faq-a-in {
  position: relative;
  padding: 21px 62px 28px;
  margin-top: 23px;
  border-radius: 20px;
  background-color: white;
}
.dc-faq .dc-faq__txt {
  font-size: 16px;
  line-height: 2.1875;
  letter-spacing: -0.6px;
}
.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;
}
.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: 28px;
  width: fit-content;
  max-width: 100%;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .dc-faq .dc-faq-q {
    gap: 14px;
    padding: 0;
    padding-right: 55px;
  }
  .dc-faq .dc-faq-q .dc-faq__icon {
    margin-top: -10px;
  }
  .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: 20px 20px 15px;
    padding-right: 15px;
    margin-top: 10px;
  }
  .dc-faq .dc-faq__heading {
    font-size: 18px;
    line-height: 1.6666666667;
    letter-spacing: 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;
  }
  .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: 18px;
  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: 100px 0 110px;
}
.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;
  left: -40px;
  top: -100px;
  width: calc(100% + 80px);
  max-width: 1280px;
  margin: 0 auto;
}
@media screen and (min-width: 1281px) {
  .dc-section.--fv .dc-fv-top-abs-wrap {
    left: 0;
  }
}
.dc-section.--fv .dc-fv-top-abs.--abs1 {
  top: 23px;
  left: -135px;
  right: unset;
}
@media screen and (max-width: 1280px) and (min-width: 769px) {
  .dc-section.--fv .dc-fv-top-abs.--abs1 img {
    width: 38.828125vw;
  }
}
@media screen and (max-width: 1000px) and (min-width: 769px) {
  .dc-section.--fv .dc-fv-top-abs.--abs1 {
    left: -175px;
  }
}
.dc-section.--fv .dc-fv-top-abs.--abs2 {
  left: unset;
  top: 175px;
  right: -120px;
}
@media screen and (max-width: 1280px) and (min-width: 769px) {
  .dc-section.--fv .dc-fv-top-abs.--abs2 img {
    width: 38.828125vw;
  }
}
@media screen and (max-width: 1000px) and (min-width: 769px) {
  .dc-section.--fv .dc-fv-top-abs.--abs2 {
    right: -160px;
  }
}
.dc-section.--fv .dc-fv-top-abs.--abs3 {
  top: 25px;
  left: unset;
  right: 115px;
}
@media screen and (max-width: 1000px) and (min-width: 769px) {
  .dc-section.--fv .dc-fv-top-abs.--abs3 {
    right: 25px;
  }
}
.dc-section.--fv .dc-fv-bottom {
  padding-bottom: 45px;
}
.dc-section.--fv .dc-fv-bottom__heading {
  margin-bottom: 10px;
  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: 20px;
  text-align: center;
}
.dc-section.--fv .dc-fv-heading__sub {
  font-size: 27px;
  line-height: 1.2222222222;
  letter-spacing: 0.14em;
}
.dc-section.--fv .dc-fv-heading__main {
  font-size: 46px;
  line-height: 1.6086956522;
  font-weight: 600;
  letter-spacing: 0.08em;
}
.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;
}
@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;
    padding: 22px 0 0;
    margin-bottom: 36px;
  }
  .dc-section.--fv .dc-fv-top-abs {
    position: static;
    margin: 0;
  }
  .dc-section.--fv .dc-fv-top-abs img {
    display: flex;
  }
  .dc-section.--fv .dc-fv-top-abs-wrap {
    position: static;
    width: fit-content;
    max-width: unset;
    margin-left: -65px;
    margin-bottom: 20px;
    display: flex;
    flex-wrap: nowrap;
    flex-direction: row;
    gap: 12px;
  }
  .dc-section.--fv .dc-fv-top-abs.--abs1,
  .dc-section.--fv .dc-fv-top-abs.--abs2 {
    width: 143px;
  }
  .dc-section.--fv .dc-fv-top-abs.--abs3 {
    margin-left: 4px;
  }
  .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: 16px;
  }
  .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__main {
    font-size: 30.3px;
    line-height: 1.6204620462;
  }
  .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: 32px;
  }
  .dc-section.--fv .dc-fv-bottom__heading {
    margin-bottom: 23px;
    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%;
  }
}
@media screen and (max-width: 370px) {
  .dc-section.--fv .dc-fv-top-abs-wrap {
    margin-left: -140px;
  }
}
.dc-section.--cta {
  padding: 50px 40px;
  text-align: center;
}
.dc-section.--cta .dc-section-in {
  width: 810px;
  padding: 45px 40px 40px;
  background: radial-gradient(#fcc26b, #f9a549);
  border-radius: 20px;
}
.dc-section.--cta .dc-cta__heading {
  font-size: 40px;
  line-height: 1.2;
  font-weight: bold;
  margin-bottom: 12px;
  color: white;
}
.dc-section.--cta .dc-cta__catch {
  margin-bottom: 35px;
  font-size: 16px;
  line-height: 1.875;
  font-weight: 500;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 768px) {
  .dc-section.--cta {
    padding: 0;
  }
  .dc-section.--cta .dc-section-in {
    padding: 30px 20px;
    border-radius: 0;
  }
  .dc-section.--cta .dc-cta__heading {
    margin-bottom: 20px;
    font-size: 28px;
    line-height: 1.2142857143;
  }
  .dc-section.--cta .dc-cta__catch {
    margin-bottom: 27px;
    font-size: 16px;
    line-height: 1.65;
    letter-spacing: 1px;
  }
}
.dc-section.--guide-area .dc-block.--block-guide:nth-child(3) {
  justify-content: flex-end;
}
.dc-section.--guide-ai
  .dc-block.--block-guide:nth-child(2)
  .dc-block-guide-left {
  gap: 25px;
}
.dc-section.--guide-ai
  .dc-block.--block-guide:nth-child(2)
  .dc-block-guide__img {
  width: auto;
}
.dc-section.--guide-con .dc-block-guide__img img {
  box-shadow: unset;
}
.dc-section.--guide-con
  .dc-block.--block-guide:nth-child(2)
  .dc-block-guide-left {
  gap: 25px;
}
.dc-section.--guide-group {
  padding: 48px 0 8px;
}
.dc-section.--guide-group .dc-section {
  padding-bottom: 42px;
}
.dc-section.--guide-group .dc-guide-group__heading {
  margin-bottom: 20px;
  font-size: 30px;
  line-height: 1.2333333333;
  font-weight: 600;
  text-align: center;
}
.dc-section.--guide-group > .dc-section-in {
  padding: 0;
}
@media screen and (max-width: 768px) {
  .dc-section.--guide-area .dc-heading.--heading-icon img {
    width: 33px;
    height: 37px;
  }
  .dc-section.--guide-area .dc-block.--block-guide:nth-child(3) {
    align-items: flex-start;
  }
  .dc-section.--guide-area
    .dc-block.--block-guide:nth-child(4)
    .dc-block-guide-left {
    align-items: flex-start;
  }
  .dc-section.--guide-ai .dc-heading.--heading-icon img {
    width: 41.8px;
    height: 35.9px;
  }
  .dc-section.--guide-ai
    .dc-block.--block-guide:nth-child(2)
    .dc-block-guide-left {
    gap: 17px;
  }
  .dc-section.--guide-con .dc-heading.--heading-icon {
    font-size: 20px;
  }
  .dc-section.--guide-con .dc-heading.--heading-icon img {
    width: 39px;
    height: 39px;
  }
  .dc-section.--guide-con
    .dc-block.--block-guide:nth-child(1)
    .dc-block-guide-left {
    align-items: flex-start;
  }
  .dc-section.--guide-con
    .dc-block.--block-guide:nth-child(1)
    .dc-block-guide__txt {
    font-size: 14.5px;
  }
  .dc-section.--guide-con
    .dc-block.--block-guide:nth-child(1)
    .dc-block-guide__txt
    .small {
    font-size: 13px;
    line-height: 2;
  }
  .dc-section.--guide-con
    .dc-block.--block-guide:nth-child(2)
    .dc-block-guide-left {
    gap: 17px;
  }
  .dc-section.--guide-con
    .dc-block.--block-guide:nth-child(2)
    .dc-block-guide__txt {
    font-size: 14.5px;
  }
  .dc-section.--guide-con
    .dc-block.--block-guide:nth-child(3)
    .dc-block-guide-left {
    align-items: flex-start;
  }
  .dc-section.--guide-con
    .dc-block.--block-guide:nth-child(3)
    .dc-block-guide__txt {
    font-size: 14.5px;
  }
  .dc-section.--guide-group {
    padding: 34px 0 0;
    background-color: #f4f2ee;
  }
  .dc-section.--guide-group .dc-section {
    padding-bottom: 60px;
  }
  .dc-section.--guide-group .dc-section-back img {
    object-position: 50% 60px;
  }
  .dc-section.--guide-group .dc-heading.--heading-icon {
    justify-content: flex-start;
  }
  .dc-section.--guide-group .dc-guide-group__heading {
    padding-left: 20px;
    margin-bottom: 38px;
    font-size: 24px;
    line-height: 1.2083333333;
    text-align: left;
  }
  .dc-section.--guide-group > .dc-section-in {
    width: 360px;
  }
}
.dc-section.--service {
  padding: 48px 0 35px;
}
.dc-section.--service h2 {
  margin-bottom: 22px;
  font-size: 30px;
  line-height: 1.2;
  font-weight: 600;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .dc-section.--service {
    padding: 30px 0;
  }
  .dc-section.--service h2 {
    margin-bottom: 28px;
  }
  .dc-section.--service .dc-section-in {
    padding: 0;
  }
  .dc-section.--service .dc-table-in {
    margin-left: 30px;
    margin-right: 30px;
  }
}
.dc-section.--faq {
  padding: 65px 0;
  background-color: #f4f2ee;
}
.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: 30px 0;
  }
  .dc-section.--faq h2 {
    margin-bottom: 30px;
    text-align: left;
  }
  .dc-section.--faq .dc-section-in {
    padding: 0 35px;
  }
  .dc-section.--faq .dc-block.--block2 .dc-txt.--txt1 {
    font-size: 14px;
  }
}
@media screen and (max-width: 370px) {
  .dc-section.--faq .dc-section-in {
    padding: 0 20px;
  }
}

@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;
}
/* CONCIERGE-2110 */
p.dc-fv-heading__main{
  display:block!important;
  white-space:normal!important;
}
p.dc-fv-heading__main>.linebreak{
  display:block!important;
  width:100%!important;
  margin-top:.1em;
}