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

html {
  height: -webkit-fill-available;
  min-height: 100svh;
  font-size: 16px;
}

body {
  margin: 0;
  min-height: 100svh;
  min-height: -webkit-fill-available;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-size: 1rem;
  line-height: 1.5;
  color: #2A2A2A;
  background-color: #FFFEEA;
}

body.scroll-lock {
  overflow: hidden;
}

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

a {
  color: #2A2A2A;
  text-decoration: none;
  transition: .3s;
}

li {
  list-style: none;
  margin: 0;
  padding: 0;
}

@media screen and (min-width: 1023px) {
  .sp-only {
    display: none;
  }
}

@media screen and (min-width: 768px) {
  a[href*="tel:"] {
    pointer-events: none;
    cursor: default;
    text-decoration: none;
  }
}

@media screen and (max-width: 1024px) {
  body {
    font-size: 0.8125rem;
  }

  .pc-only {
    display: none;
  }
}

/* 共通要素 */
.content-title {
  font-family: sicuniversallinelge, sans-serif;
  font-style: normal;
  font-weight: normal;
  font-size: min(3.125vw, 3.75rem);
  text-align: center;
}

.action-btn {
  position: relative;
}

.action-btn::before {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  background-color: #FFCE47;
  border: solid 4px #2A2A2A;
  border-radius: 40px;
  position: absolute;
  top: 10px;
  left: 10px;
}

.action-btn .link {
  display: block;
  background-color: #fff;
  border: solid 4px #2A2A2A;
  border-radius: 32px;
  position: relative;
  transition: .3s;
}

.text-link {
  color: #EEB414;
  transition: .3s;
}

.text-link:hover {
  opacity: 0.7;
}

.hidden {
  display: none;
}

@media screen and (min-width: 1025px) {
  .action-btn .link:hover {
    transform: translate(10px, 10px);
  }
}

@media screen and (max-width: 1024px) {
  .action-btn .link:hover {
    transform: translate(6px, 6px);
  }
}

@media screen and (max-width: 768px) {
  .content-title {
    font-size: 1.75rem;
  }

  .action-btn::before {
    border-width: 2px;
    border-radius: 25px;
    top: 6px;
    left: 6px;
  }

  .action-btn .link {
    border-width: 2px;
    border-radius: 20px;
  }

  .action-btn .link:hover {
    transform: translate(6px, 6px);
  }
}

/* ヘッダー */
.header {
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  z-index: 100;
}

.header a {
  font-size: 1.125rem;
  font-weight: 600;
}

.header-wrapper {
  display: flex;
  justify-content: center;
  padding: 40px 40px 0 37px;
}

.header-wrapper .logo {
  margin-right: auto;
  position: relative;
}

.header-wrapper .logo::before,
.header-wrapper .logo::after {
  content: '';
  display: block;
  width: 12px;
  height: 66px;
  background: url("../img/kv-decoration.png") no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  top: -53px;
}

.header-wrapper .logo::before {
  left: 29px;
}

.header-wrapper .logo::after {
  right: 29px;
}

.header-wrapper .logo a {
  display: block;
  background-color: #fff;
  border: solid 4px #2A2A2A;
  border-radius: 16px;
  padding: 17px 33px 11px;
}

.center-menu {
  position: relative;
}

.center-menu::before,
.center-menu::after {
  content: '';
  display: block;
  width: 12px;
  height: 66px;
  background: url("../img/kv-decoration.png") no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  top: -53px;
}

.center-menu::before {
  left: 29px;
}

.center-menu::after {
  right: 29px;
}

.center-menu ul {
  display: flex;
}

.center-menu li {
  border: solid 4px #2A2A2A;
}

.center-menu li + li {
  border-left: none;
}

.center-menu li:first-child {
  border-top-left-radius: 16px;
  border-bottom-left-radius: 16px;
  overflow: hidden;
}

.center-menu li:last-child {
  border-top-right-radius: 16px;
  border-bottom-right-radius: 16px;
  overflow: hidden;
}

.center-menu li a {
  display: block;
  width: 168px;
  text-align: center;
  padding: 31px 10px;
  background-color: #fff;
  font-family: sicuniversallinelge, sans-serif;
  font-style: normal;
}

.center-menu li a:hover {
  background-color: #FCDA7C;
}

.side-menu {
  margin-left: auto;
  margin-top: -12px;
}

.side-menu.menu-toggle {
  display: none;
}

.ani-float {
  animation: float 2s linear infinite;
  scale: 1;
}

@keyframes float {
  0%{transform:translateY(0)}
  50%{transform:translateY(-10px)}
  100%{transform:translateY(0)}
}

.side-menu .btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 212px;
  height: 118px;
  padding-top: 16px;
  font-family: sicuniversallinelge, sans-serif;
  font-style: normal;
  position: relative;
  z-index: 1;
}

.side-menu::after {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  background: url("../img/menu-contact-background.svg") no-repeat;
  background-position: center;
  background-size: contain;
  position: relative;
  transition: .3s;
  position: absolute;
  top: 0;
  left: 0;
}

.side-menu::before {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  background: url("../img/menu-contact-background_hover.svg") no-repeat;
  background-position: center;
  background-size: contain;
  position: relative;
  position: absolute;
  top: 0;
  left: 0;
}

.sp-menu {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100dvh;
  z-index: 99;
  overflow: hidden;
  background-color: #5DC9FF;
}

.sp-nav {
  padding: min(26vw, 85px) 24px 0;
  height: 100%;
  position: relative;
}

.sp-nav li + li {
  margin-top: 2.7svh;
}

.sp-nav a {
  font-size: 2.2svh;
  font-weight: 600;
  text-align: center;
  padding: 2.71svh 0;
}

.sp-nav .action-btn .link {
  border-radius: 15px;
}

.sp-nav .action-btn::before {
  border-radius: 18px;
}

.sp-menu-img {
  width: 27.094svh;
  max-width: 260px;
  height: 27.094svh;
  max-height: 260px;
  position: absolute;
  bottom: -4.8vw;
  left: 50%;
  transform: translateX(-50%);
}

@media screen and (min-width: 1025px) {
  .side-menu:hover::after {
    opacity: 0;
  }
}

@media screen and (max-width: 1300px) {
  .header-wrapper {
    padding: 40px 15px 0 15px;
  }

  .header-wrapper .logo a {
    padding: 18px 28px 10px;
    width: 178px;
  }

  .center-menu li a {
    width: 148px;
    padding: 21px 5px;
  }

  .side-menu .btn {
    width: 188px;
    height: 107px;
  }
}

@media screen and (max-width: 1024px) {
  .center-menu {
    display: none;
  }

  .side-menu {
    display: none;
  }

  .side-menu.menu-toggle {
    display: block;
    margin-top: 0;
  }

  .side-menu .btn .hum {
    display: block;
    width: 37px;
    height: 3px;
    background-color: #2A2A2A;
    border-radius: 2px;
    position: absolute;
    left: 75px;
    transition: .3s;
  }

  .side-menu .btn .hum:nth-child(1) {
    top: 43px;
  }

  .side-menu .btn .hum:nth-child(2) {
    top: 54px;
  }

  .side-menu .btn .hum:nth-child(3) {
    top: 66px;
  }

  .side-menu.active .btn .hum:nth-child(1) {
    transform: rotate(45deg);
    top: 54px;
  }

  .side-menu.active .btn .hum:nth-child(2) {
    transform: rotate(45deg);
    top: 54px;
  }

  .side-menu.active .btn .hum:nth-child(3) {
    transform: rotate(-45deg);
    top: 54px;
  }

  .sp-menu .sp-nav li {
    max-width: 350px;
    margin-left: auto;
    margin-right: auto;
  }
}

@media screen and (max-width: 768px) {
  .header-wrapper {
    padding: 17px 20px 0 16px;
  }

  .header-wrapper .logo::before,
  .header-wrapper .logo::after {
    width: 7px;
    height: 43px;
    top: -33px;
  }

  .header-wrapper .logo::before {
    left: 8px;
  }

  .header-wrapper .logo::after {
    right: 8px;
  }

  .header-wrapper .logo a {
    border-radius: 8px;
    padding: 2.8vw 5.8vw;
    width: 36.267vw;
    height: 13.867vw;
  }

  .side-menu .btn {
    width: 24vw;
    height: 14.935vw;
    position: relative;
  }

  .side-menu .btn .hum {
    display: block;
    width: 5.334vw;
    height: 0.534vw;
    background-color: #2A2A2A;
    border-radius: 2px;
    position: absolute;
    left: 9vw;
    transition: .3s;
  }

  .side-menu .btn .hum:nth-child(1) {
    top: 9vw;
  }

  .side-menu .btn .hum:nth-child(2) {
    top: 7.2vw;
  }

  .side-menu .btn .hum:nth-child(3) {
    top: 5.4vw;
  }

  .side-menu.active .btn .hum:nth-child(1) {
    transform: rotate(45deg);
    top: 7.2vw;
  }

  .side-menu.active .btn .hum:nth-child(2) {
    transform: rotate(45deg);
    top: 7.2vw;
  }

  .side-menu.active .btn .hum:nth-child(3) {
    transform: rotate(-45deg);
    top: 7.2vw;
  }

  .sp-nav {
    padding: 26vw 24px 0;
  }
}

@media screen and (max-width: 600px) {
  .header-wrapper .logo a {
    border-width: 2px;
  }
}

/* キービジュアル */
.kv {
  padding-top: 45.833%;
  background: url("../img/kv-background.png") no-repeat #ffe769;
  background-position: center;
  background-size: cover;
  position: relative;
}

.kv-wrapper {
  width: 100%;
  display: flex;
  justify-content: center;
  gap: 4.5vw;
  position: absolute;
  top: 9vw;
  left: 50%;
  transform: translateX(-50%);
}

.kv-wrapper .img {
  width: 36.3636vw;
  min-width: 36.3636vw;
}

.kv-wrapper .text {
  padding-top: 7.448vw;
}

.kv-wrapper .text-top {
  font-family: sicuniversallinelge, sans-serif;
  font-style: normal;
  font-size: 2.084vw;
  color: #fff;
  margin-bottom: 1.2vw;
}

.kv-wrapper .text-top span {
  display: inline-block;
  background-color: #2A2A2A;
  padding: 0.42vw 1.66vw;
  margin-bottom: 0.73vw;
}

.kv-wrapper .text-bottom {
  font-size: 1.3125rem;
}

@media screen and (max-width: 1200px) {
  .kv-wrapper {
    padding: 0 20px;
  }
}

@media screen and (max-width: 768px) {
  .kv {
    padding-top: 169.894%;
    background: url("../img/kv-background_sp.png") no-repeat;
    background-position: center;
    background-size: cover;
  }

  .kv-wrapper {
    gap: 3.1vw;
    flex-flow: column-reverse;
    padding: 0 24px;
    top: 21.5vw;
  }

  .kv-wrapper .img {
    width: 100%;
    min-width: auto;
  }

  .kv-wrapper .text-top {
    font-size: 5.065vw;
    margin-bottom: 2vw;
  }

  .kv-wrapper .text-top span {
    padding: 1.136vw 4vw;
    margin-bottom: 1.5vw;
  }

  .kv-wrapper .text-bottom {
    font-size: max(3.735vw, 0.875rem);
  }
}

/* こんなお悩みありませんか？ */
.example {
  margin-top: 20px;
  padding: 0 60px;
}

.example-wrapper {
  max-width: 1200px;
  margin: 0 auto;
}

.example-wrapper h2.title {
  margin-bottom: 56px;
}

.example-block-top {
  margin-bottom: 40px;
}

.example-block-top ul {
  display: flex;
  gap: 32px;
  justify-content: center;
}

.example-block-bottom ul {
  display: flex;
  gap: 32px;
  justify-content: center;
}

.example-block-item .link {
  position: relative;
  transition-duration: .6s;
  transition-timing-function: ease-in-out;
  transform-style: preserve-3d;
}

.example-block-item::before {
  transition-duration: .6s;
  transition-timing-function: ease-in-out;
  transform-style: preserve-3d;
  transform: rotateX(0deg);
}

.example-block-item .link .card-front {
  z-index: 2;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  backface-visibility: hidden;
  transform: rotateX(0deg);
}

.example-block-item .link .card-back {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  backface-visibility: hidden;
  transform: rotateY(-180deg);
}

.example-block-top .example-block-item .link {
  width: 578px;
  height: 584px;
}

.example-block-top .example-block-item .link .card {
  padding: 36px 48px 23px;
}

.example-block-bottom .example-block-item .link {
  width: 374px;
  height: 448px;
}

.example-block-bottom .example-block-item .link .card {
  padding: 23px 32px;
}

.example-block-item .number {
  font-family: brandon-grotesque, sans-serif;
  font-style: normal;
  font-weight: 600;
}

.example-block-item .card-back .number {
  color: #929292;
}

.example-block-item .card-back .img {
  opacity: 0.1;
}

.example-block-item .card-back .text {
  font-weight: 600;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}

.example-block-top .example-block-item .number {
  font-size: 2.5rem;
  text-align: right;
}

.example-block-top .example-block-item .title {
  font-size: 2rem;
  font-weight: 600;
  text-align: center;
  margin: 2px 0 22px;
}

.example-block-top .example-block-item .card-back .text {
  font-size: 1.25rem;
  width: calc(100% - 96px);
  top: 208px;
}

.example-block-bottom .example-block-item .card-back .text {
  font-size: 1.125rem;
  width: calc(100% - 54px);
  top: 175px;
}

.example-block-top .example-block-item .card-back .text p + p {
  margin-top: 24px;
}

.example-block-bottom .example-block-item .card-back .text p + p {
  margin-top: 16px;
}

.example-block-top .example-block-item .img {
  width: 380px;
  margin: 0 auto;
}

.example-block-bottom .example-block-item .number {
  font-size: 2rem;
  font-weight: 600;
  text-align: right;
}

.example-block-bottom .example-block-item .title {
  font-size: 1.5rem;
  font-weight: 600;
  text-align: center;
  margin: 0 0 8px;
}

.example-block-bottom .example-block-item .img {
  width: 260px;
  margin: 0 auto;
}

@media screen and (min-width: 1025px) {
  .example-block-item:hover .link {
    transform: rotateY(-180deg) translate(-10px, 10px);
  }

  .example-block-item:hover::before {
    transform: rotateY(-180deg);
  }
}

@media screen and (max-width: 1300px) {
  .example {
    padding: 0 24px;
  }

  .example-block-item {
    width: 100%;
  }

  .example-block-top .example-block-item .link,
  .example-block-bottom .example-block-item .link {
    width: 100%;
  }

  .example-block-top .example-block-item .link {
    height: 50vw;
  }

  .example-block-bottom .example-block-item .link {
    height: 37vw;
  }

  .example-block-top .example-block-item .link .card {
    padding: 2.75vw 3.7vw 2.2vw;
  }

  .example-block-bottom .example-block-item .link .card {
    padding: 1.8vw 2.47vw;
  }

  .example-block-top .example-block-item .number {
    font-size: 3.1vw;
  }

  .example-block-bottom .example-block-item .number {
    font-size: 2.465vw;
  }

  .example-block-top .example-block-item .title {
    font-size: 2.465vw;
    margin: 2px 0 0;
  }

  .example-block-bottom .example-block-item .title {
    font-size: 1.84vw;
  }

  .example-block-top .example-block-item .img,
  .example-block-bottom .example-block-item .img {
    width: 90%;
  }
}

@media screen and (max-width: 1024px) {
  .example-block-item .link:hover {
    transform: translate(10px, 10px);
  }
}

@media screen and (max-width: 768px) {
  .example {
    margin-top: 8vw;
  }

  .example-wrapper h2.title {
    font-size: 1.5rem;
    margin-bottom: 24px;
  }

  .example-block-top {
    margin-bottom: 22px;
  }

  .example-block-top ul,
  .example-block-bottom ul {
    display: block;
  }

  .example-block-item + .example-block-item {
    margin-top: 22px;
  }

  .example-block-item .link:hover {
    transform: translate(6px, 6px);
  }

  .example-block-top .example-block-item .link,
  .example-block-bottom .example-block-item .link {
    padding: 0;
    height: auto;
  }

  .example-block-top .example-block-item .link .card,
  .example-block-bottom .example-block-item .link .card {
    padding: 24px;
  }

  .example-block-item .link .card-front {
    display: none;
  }

  .example-block-item .link .card-back {
    position: relative;
    transform: rotate(0deg);
  }

  .example-block-item .card-back .number {
    color: #2A2A2A;
  }

  .example-block-top .example-block-item .number,
  .example-block-bottom .example-block-item .number {
    font-size: 1.5rem;
  }

  .example-block-top .example-block-item .title,
  .example-block-bottom .example-block-item .title {
    font-size: 1.125rem;
    margin: 0 0 5px;
  }

  .example-block-item .card-back .img {
    opacity: 1;
  }

  .example-block-top .example-block-item .img,
  .example-block-bottom .example-block-item .img {
    width: 73%;
    max-width: 360px;
  }

  .example-block-item .card-back .text {
    position: relative;
    left: 0;
    transform: none;
  }

  .example-block-top .example-block-item .card-back .text,
  .example-block-bottom .example-block-item .card-back .text {
    font-size: 0.875rem;
  }

  .example-block-top .example-block-item .card-back .text,
  .example-block-bottom .example-block-item .card-back .text {
    width: 100%;
    top: auto;
    margin-top: 10px;
  }

  .example-block-top .example-block-item .card-back .text p + p,
  .example-block-bottom .example-block-item .card-back .text p + p {
    margin-top: 4px;
  }
}

/* サポート */
.solution {
  padding: 120px 60px 216px;
}

.solution-wrapper {
  background-color: #5DC9FF;
  border-radius: 40px;
  padding: 100px 40px;
}

.solution-wrapper h3.title {
  font-size: 2.5rem;
  font-weight: 600;
  text-align: center;
  margin-bottom: 44px;
}

.solution-wrapper h3.title .title-inner {
  width: fit-content;
  margin: 0 auto;
  position: relative;
}

.solution-wrapper h3.title .title-inner::before,
.solution-wrapper h3.title .title-inner::after {
  content: '';
  display: block;
  width: 220px;
  height: 170px;
  background: url("../img/solution-decoration.png") no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  bottom: -19px;
}

.solution-wrapper h3.title .title-inner::before {
  left: -188px;
  transform: scale(-1, 1);
}

.solution-wrapper h3.title .title-inner::after {
  right: -188px;
}

.solution-block {
  max-width: 1200px;
  margin: 0 auto;
}

.solution-block-item {
  background: #fff;
  border-right: solid 4px #2A2A2A;
  border-left: solid 4px #2A2A2A;
  padding: 0 107px;
  height: 322px;
  position: relative;
  z-index: 0;
}

.solution-block-item:nth-child(odd) {
  margin-top: 200px;
}

.solution-block-item:nth-child(even) {
  margin-top: 280px;
}

.solution-block-item:first-child {
  height: 450px;
  padding-top: 51px;
  border-top: solid 4px #2A2A2A;
  border-top-left-radius: 32px;
  border-top-right-radius: 32px;
  margin-top: 0;
}

.solution-block-item:last-child {
  height: 450px;
  padding-bottom: 51px;
  border-bottom: solid 4px #2A2A2A;
  border-bottom-left-radius: 32px;
  border-bottom-right-radius: 32px;
  margin-bottom: 0;
}

.solution-block-item-inner {
  display: flex;
  align-items: center;
  gap: 70px;
  margin-top: -30px;
  position: absolute;
  width: calc(100% - 228px);
}

.solution-block-item:nth-child(odd) .solution-block-item-inner {
  top: calc(50% + 30px);
  left: 50%;
  transform: translate(-50%, -50%);
}

.solution-block-item:nth-child(even) .solution-block-item-inner {
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.solution-block-item:first-child .solution-block-item-inner {
  top: calc(50% + 80px);
  align-items: flex-start;
}

.solution-block-item:last-child .solution-block-item-inner {
  top: calc(50% + 0px);
}

.solution-block-item::before,
.solution-block-item::after {
  content: '';
  display: block;
  width: calc(100% + 10px);
  background-position: center;
  background-size: contain;
  position: absolute;
  z-index: -2;
}

.solution-block-item:nth-child(odd)::before {
  height: 125px;
  background: url("../img/solution-background02.svg") no-repeat;
  transform: scale(-1, -1);
  top: -120px;
  left: -6px;
}

.solution-block-item:nth-child(odd)::after {
  height: 201px;
  background: url("../img/solution-background01.svg") no-repeat;
  transform: scale(-1, -1);
  bottom: -196px;
  left: -6px;
}

.solution-block-item:nth-child(even)::before {
  height: 201px;
  background: url("../img/solution-background01.svg") no-repeat;
  top: -196px;
  left: -4px;
}

.solution-block-item:nth-child(even)::after {
  height: 125px;
  background: url("../img/solution-background02.svg") no-repeat;
  bottom: -120px;
  left: -4px;
}

.solution-block-item:first-child::before {
  display: none;
}

.solution-block-item:last-child::after {
  display: none;
}

.solution-block-item .scroll-point {
  position: absolute;
  z-index: -1;
  opacity: 0;
}

.solution-block-item:nth-child(odd) .scroll-point {
  top: -180px;
}

.solution-block-item:nth-child(even) .scroll-point {
  top: -220px;
}

.solution-block-item .img {
  width: 440px;
  min-width: 440px;
}

.solution-block-item:first-child .text {
  margin-top: 27px;
}

.solution-block-item .text .number {
  font-family: brandon-grotesque, sans-serif;
  font-style: normal;
  font-weight: 600;
  font-size: 3rem;
  text-align: center;
  margin-bottom: 8px;
}

.solution-block-item .text .title {
  font-size: 1.5rem;
  font-weight: 600;
  margin-bottom: 32px;
}

.solution-block-item .text .inner-text p + p {
  margin-top: 16px;
}

@media screen and (max-width: 1400px) {
  .solution-wrapper h3.title {
    font-size: min(2.99vw, 2.6rem);
  }

  .solution-wrapper h3.title .title-inner::before,
  .solution-wrapper h3.title .title-inner::after {
    width: 15.805vw;
    height: 12.213vw;
    bottom: -2vw;
  }

  .solution-wrapper h3.title .title-inner::before {
    left: -13.5vw;
  }

  .solution-wrapper h3.title .title-inner::after {
    right: -13.5vw;
  }

  .solution-block-item {
    padding: 0 4vw;
  }

  .solution-block-item:nth-child(odd) {
    margin-top: 14vw;
  }

  .solution-block-item:nth-child(even) {
    margin-top: 19.6vw;
  }

  .solution-block-item:first-child {
    height: 38vw;
    padding-top: 4vw;
    margin-top: 40px;
  }

  .solution-block-item:last-child {
    height: 38vw;
    padding-bottom: 4vw;
  }

  .solution-block-item::before,
  .solution-block-item::after {
    width: calc(100% + 0.75vw);
  }

  .solution-block-item:nth-child(odd)::before {
    height: 10vw;
    background-position: center bottom;
    background-size: contain;
    bottom: -7.15vw;
    top: -8vw;
    left: -0.35vw;
  }

  .solution-block-item:nth-child(odd)::after {
    height: 16vw;
    background-position: center bottom;
    background-size: contain;
    bottom: -15.5vw;
    left: -0.35vw;
  }

  .solution-block-item:nth-child(even)::before {
    height: 16vw;
    background-position: center bottom;
    background-size: contain;
    bottom: -11.67vw;
    left: -0.35vw;
    top: -14.3vw;
  }

  .solution-block-item:nth-child(even)::after {
    height: 10vw;
    background-position: center bottom;
    background-size: contain;
    bottom: -7.8vw;
    left: -0.35vw;
  }

  .solution-block-item:first-child .solution-block-item-inner {
    top: calc(50% + 60px);
  }

  .solution-block-item-inner {
    gap: 5vw;
    width: calc(100% - 8vw);
  }

  .solution-block-item .img {
    width: 31vw;
    min-width: 31vw;
    height: 31vw;
  }
}

@media screen and (max-width: 1300px) {
  .solution {
    padding: 80px 24px 160px;
  }

  .solution-wrapper {
    padding: 60px 40px;
  }

  .solution-block-item .text .number {
    font-size: 1.715rem;
  }

  .solution-block-item .text .title {
    font-size: 1.24rem;
    margin-bottom: 20px;
  }
}

@media screen and (max-width: 1024px) {
  .solution-block-item:first-child .text {
    margin-top: 0;
  }
}

@media screen and (max-width: 900px) {
  .solution-block-item:first-child {
    height: 45vw;
  }

  .solution-block-item:last-child {
    height: 45vw;
  }
}

@media screen and (max-width: 768px) {
  .solution {
    padding: 56px 16px 110px;
  }

  .solution-wrapper {
    border-radius: 20px;
    padding: 32px 16px 40px;
  }

  .solution-wrapper h3.title {
    font-size: 1.125rem;
    margin-bottom: 24px;
  }

  .solution-wrapper h3.title .title-inner::before,
  .solution-wrapper h3.title .title-inner::after {
    width: 68px;
    height: 68px;
    bottom: -7px;
  }

  .solution-wrapper h3.title .title-inner::before {
    left: -61px;
  }

  .solution-wrapper h3.title .title-inner::after {
    right: -61px;
  }

  .solution-block-item {
    border-width: 2px;
    padding: 0 24px;
    height: auto;
  }

  .solution-block-item:nth-child(odd) .scroll-point {
    top: -90px;
  }

  .solution-block-item:nth-child(even) .scroll-point {
    top: -90px;
  }

  .solution-block-item:nth-child(odd) {
    margin-top: 24vw;
  }

  .solution-block-item:nth-child(even) {
    margin-top: 25vw;
  }

  .solution-block-item:first-child {
    height: auto;
    margin-top: 24px;
    padding-top: 24px;
    border-width: 2px;
    border-top-left-radius: 20px;
    border-top-right-radius: 20px;
  }

  .solution-block-item:last-child {
    height: auto;
    padding-bottom: 24px;
    border-width: 2px;
    border-bottom-left-radius: 20px;
    border-bottom-right-radius: 20px;
  }

  .solution-block-item::before,
  .solution-block-item::after {
    width: calc(100% + 4px);
  }

  .solution-block-item:nth-child(odd)::before,
  .solution-block-item:nth-child(odd)::after,
  .solution-block-item:nth-child(even)::before,
  .solution-block-item:nth-child(even)::after  {
    height: 20vw;
    background: url("../img/solution-background_pad.svg") no-repeat;
    background-position: center;
    background-size: contain;
  }

  .solution-block-item:nth-child(odd)::before {
    top: -16vw;
    left: -2px;
    transform: scale(-1, 1);
  }

  .solution-block-item:nth-child(odd)::after {
    bottom: -17vw;
    left: -2px;
  }

  .solution-block-item:nth-child(even)::before {
    top: -16vw;
    left: -2px;
  }

  .solution-block-item:nth-child(even)::after {
    bottom: -16vw;
    left: -2px;
    transform: scale(1, -1);
  }

  .solution-block-item-inner {
    gap: 16px;
    position: relative;
    width: 100%;
    margin-top: 0;
  }

  .solution-block-item:first-child .solution-block-item-inner {
    top: auto;
    left: auto;
    transform: none;
    align-items: center;
  }

  .solution-block-item:nth-child(odd) .solution-block-item-inner {
    flex-flow: column-reverse;
    top: auto;
    left: auto;
    transform: none;
  }

  .solution-block-item:nth-child(even) .solution-block-item-inner {
    flex-flow: column;
    top: auto;
    left: auto;
    transform: none;
  }

  .solution-block-item .img {
    width: 83%;
    max-width: 360px;
    min-width: auto;
    height: auto;
  }

  .solution-block-item .text .title {
    font-size: 0.9375rem;
    margin-bottom: 16px;
  }

  .solution-block-item .text .inner-text {
    font-size: 0.8125rem;
  }

  .solution-block-item .text .inner-text p + p {
    margin-top: 8px;
  }
}

@media screen and (max-width: 600px) {
  .solution-block-item:nth-child(odd)::before,
  .solution-block-item:nth-child(odd)::after,
  .solution-block-item:nth-child(even)::before,
  .solution-block-item:nth-child(even)::after  {
    background: url("../img/solution-background_sp.svg") no-repeat;
    background-position: center;
    background-size: contain;
  }
}

/* サービス内容 */
.service {
  padding: 80px 60px 0;
}

.service-wrapper {
  background-color: #4ED1C5;
  border-radius: 40px;
  padding: 80px 40px 137px;
  position: relative;
  overflow: hidden;
}

.service-wrapper .title-text {
  text-align: center;
  margin: 16px 0 115px;
}

.service-block {
  max-width: 1200px;
  margin: 0 auto;
  padding: 35px 0 10px;
  display: flex;
  background-color: #fff;
  border-left: solid 4px #2A2A2A;
  border-right: solid 4px #2A2A2A;
  position: relative;
}

.service-block::before,
.service-block::after {
  content: '';
  display: block;
  width: calc(100% + 10px);
  background-position: center;
  background-size: contain;
  position: absolute;
  left: -4.5px;
}

.service-block::before {
  height: 77px;
  background: url("../img/service-background-top.svg") no-repeat;
  top: -73px;
}

.service-block::after {
  height: 65px;
  background: url("../img/service-background-bottom.svg") no-repeat;
  bottom: -59px;
}

.service-block-item {
  display: flex;
  flex-flow: column;
  width: calc(100% / 3);
  padding: 0 46px;
  position: relative;
}

.service-block-item + .service-block-item {
  border-left: solid 4px #2A2A2A;
}

.service-block-item .title {
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.2;
  margin-bottom: 40px;
  border-radius: 16px;
  padding: 10px;
  height: 76px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.service-block-item.s-consulting .title {
  background-color: #5DC9FF;
}

.service-block-item.s-support .title {
  background-color: #FFCE47;
}

.service-block-item.s-development .title {
  background-color: #C3A9FF;
}

.service-block-item .list {
  flex-grow: 1;
}

.service-block-item .list p + p {
  margin-top: 16px;
}

.service-block-item .attention {
  font-size: 0.875rem;
}

.service-side-img {
  width: 297px;
  height: 327px;
  position: absolute;
  bottom: -140px;
  z-index: 1;
}

.service-side-img.left {
  left: -175px;
  transform: scale(-1, 1);
}

.service-side-img.right {
  right: -175px;
}

@media screen and (max-width: 1400px) {
  .service-block::before,
  .service-block::after {
    width: calc(100% + 9.5px);
  }

  .service-block::before {
    background-position: center bottom;
    background-size: contain;
  }

  .service-block::after {
    background-position: center top;
    background-size: contain;
  }

  .service-block-item .title {
    font-size: 1.7vw;
  }

  .service-side-img {
    width: 200px;
    height: 219px;
    bottom: -150px;
  }

  .service-side-img.left {
    left: -92px;
  }

  .service-side-img.right {
    right: -92px;
  }
}

@media screen and (max-width: 1300px) {
  .service {
    padding: 80px 24px 0;
  }

  .service-wrapper {
    padding: 60px 40px 100px;
  }

  .service-wrapper .title-text {
    margin: 16px 0 75px;
  }

  .service-block {
    padding: 25px 0 40px;
  }

  .service-block-item {
    padding: 0 30px;
  }

  .service-block-item .title {
    margin-bottom: 20px;
  }

  .service-block-item .list p + p {
    margin-top: 10px;
  }

  .service-block::before {
    left: -4px;
  }
}

@media screen and (max-width: 768px) {
  .service {
    padding: 56px 16px 0;
  }

  .service-wrapper {
    border-radius: 20px;
    padding: 32px 16px 17vw;
  }

  .service-wrapper .title-text {
    text-align: left;
    margin: 12px 0 20vw;
  }

  .service-block {
    display: block;
    border-bottom: solid #2A2A2A;
    border-width: 2px;
    border-bottom-left-radius: 20px;
    border-bottom-right-radius: 20px;
    padding: 18px 0 50px;
  }

  .service-block::before {
    width: calc(100% + 4px);
    height: 17vw;
    background: url("../img/service-background-top_pad.svg") no-repeat;
    background-position: center;
    background-size: contain;
    top: -15.5vw;
    left: -2px;
  }

  .service-block::after {
    display: none;
  }

  .service-block-item {
    width: 100%;
    padding: 0 23px;
  }

  .service-block-item + .service-block-item {
    margin-top: 32px;
    border-left: none;
  }

  .service-block-item .title {
    font-size: 1.125rem;
    margin-bottom: 24px;
    padding: 5px;
    height: 60px;
  }

  .service-block-item .list p + p {
    margin-top: 8px;
  }

  .service-side-img {
    width: min(40vw, 200px);
    height: auto;
    bottom: -168px;
  }

  .service-side-img.left {
    left: -36px;
  }

  .service-side-img.right {
    right: -36px;
  }
}

@media screen and (max-width: 600px) {
  .service-block::before {
    background: url("../img/service-background-top_sp.svg") no-repeat;
    background-position: center;
    background-size: contain;
    left: -2px;
  }
}

@media screen and (max-width: 500px) {
  .service-side-img {
    bottom: -152px;
  }
}

@media screen and (max-width: 400px) {
  .service-side-img {
    bottom: -106px;
  }
}

/* パッケージ */
.package {
  padding: 80px 24px;
  position: relative;
}

.scroll-point#package {
  position: absolute;
  top: -100px;
  z-index: -1;
  opacity: 0;
}

.package-wrapper {
  max-width: 1200px;
  margin: 0 auto;
}

.package-wrapper .title-text {
  font-size: 2.125rem;
  font-weight: 600;
  text-align: center;
  margin-bottom: 40px;
}

.package-wrapper h3.title {
  font-size: 2rem;
  font-weight: 600;
  text-align: center;
  background-color: #FFD35B;
  border: solid 4px #2A2A2A;
  border-radius: 42px;
  margin-bottom: 48px;
  padding: 16px;
}

.package-block {
  display: flex;
  gap: 40px;
  margin-bottom: 24px;
}

.package-block .package-block-item {
  width: calc(100% / 3);
  display: flex;
  flex-flow: column;
}

.package-block .package-block-item .title {
  font-size: 1.5rem;
  font-weight: 600;
  width: 277px;
  margin: 0 auto;
  padding: 12px 20px;
  text-align: center;
  border-top-left-radius: 32px;
  border-top-right-radius: 32px;
  border-top: solid 4px #2A2A2A;
  border-right: solid 4px #2A2A2A;
  border-left: solid 4px #2A2A2A;
}

.package-block .package-block-item.lite .title {
  background-color: #F68A71;
}

.package-block .package-block-item.mid .title {
  background-color: #4ED1C5;
}

.package-block .package-block-item.full .title {
  background-color: #4BC3FF;
}

.package-block .package-block-item .plan {
  padding: 60px 37px 40px;
  border-radius: 32px;
  border: solid 4px #2A2A2A;
  flex-grow: 1;
}

.package-block .package-block-item.lite .plan {
  background-color: #FEEEEB;
}

.package-block .package-block-item.mid .plan {
  background-color: #EBFAF9;
}

.package-block .package-block-item.full .plan {
  background-color: #EDF9FF;
}

.package-block .package-block-item .plan .price {
  font-family: "Noto Sans", sans-serif;
  font-size: 4rem;
  font-weight: 600;
  text-align: center;
  letter-spacing: -0.02em;
}

.package-block .package-block-item .plan .price .small {
  font-size: 1.5rem;
}

.package-block .package-block-item .plan .period {
  font-family: "Noto Sans", sans-serif;
  font-size: 1.25rem;
  font-weight: 600;
  margin: 24px 0;
  text-align: center;
  padding: 7px;
  border-radius: 23px;
}

.package-block .package-block-item.lite .plan .period {
  background-color: #F79B85;
}

.package-block .package-block-item.mid .plan .period {
  background-color: #4ED1C5;
}

.package-block .package-block-item.full .plan .period {
  background-color: #4BC3FF;
}

.package-wrapper .attention {
  font-size: 0.875rem;
}

@media screen and (max-width: 1300px) {
  .package-wrapper .title-text {
    font-size: 2.59vw;
  }

  .package-wrapper h3.title {
    font-size: min(3.125vw, 3.75rem);
  }

  .package-block {
    gap: 30px;
  }

  .package-block .package-block-item .title {
    font-size: 2vw;
    width: 21.308vw;
  }

  .package-block .package-block-item .plan .price {
    font-size: 3.7vw;
  }
}

@media screen and (max-width: 768px) {
  .package {
    padding: 56px 24px;
  }

  .scroll-point#package {
    top: -40px;
  }

  .package-wrapper .title-text {
    font-size: 1.125rem;
    margin-bottom: 24px;
    text-align: left;
  }

  .package-wrapper h3.title {
    font-size: 1rem;
    border-width: 2px;
    margin-bottom: 32px;
  }

  .package-block {
    display: block;
  }

  .package-block .package-block-item {
    width: 100%;
  }

  .package-block-item + .package-block-item {
    margin-top: 40px;
  }

  .package-block .package-block-item .title {
    font-size: 1.25rem;
    border-width: 2px;
    border-top-left-radius: 20px;
    border-top-right-radius: 20px;
    width: 242px;
  }

  .package-block .package-block-item .plan {
    border-radius: 20px;
    border-width: 2px;
    padding: 24px 32px 32px;
  }

  .package-block .package-block-item .plan .price {
    font-size: 3rem;
  }

  .package-block .package-block-item .plan .period {
    font-size: 1rem;
    margin: 16px 0;
    padding: 5px;
  }

  .package-wrapper .attention {
    font-size: 0.75rem;
  }
}

/* 導入の流れ */
.flow {
  padding: 0 60px 24px;
  position: relative;
}

.scroll-point#flow {
  position: absolute;
  top: -100px;
  z-index: -1;
  opacity: 0;
}

.flow-wrapper {
  background-color: #BC9FFF;
  border-radius: 40px;
  padding: 100px 40px 80px;
  position: relative;
}

.flow-wrapper h3.title {
  position: relative;
  width: fit-content;
  margin: 0 auto 40px;
}

.flow-decoration {
  position: absolute;
}

.flow-decoration.left {
  left: -449px;
  bottom: -213px;
  width: 431px;
}

.flow-decoration.right {
  right: -298px;
  bottom: -24px;
  width: 236px;
}

.flow-block {
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
}

.flow-block .flow-block-item {
  background-color: #fff;
  border: solid 4px #2A2A2A;
  border-radius: 32px;
  padding: 32px 20px 32px 60px;
  display: flex;
  align-items: center;
}

.flow-block .flow-block-item + .flow-block-item {
  margin-top: 16px;
}

.flow-block .flow-block-item .number {
  font-family: brandon-grotesque, sans-serif;
  font-style: normal;
  font-weight: 600;
  font-size: 2.5rem;
  text-align: center;
  height: 80px;
  margin-right: 40px;
  padding-right: 60px;
  border-right: solid 2px #2A2A2A;
}

.flow-block .flow-block-item .number .step {
  font-family: brandon-grotesque, sans-serif;
  font-style: normal;
  font-weight: 400;
  font-size: 1rem;
}

.flow-block .flow-block-item .icon {
  width: 80px;
  height: 80px;
  margin-right: 32px;
}

.flow-block .flow-block-item .text .title {
  font-size: 1.5rem;
  font-weight: 600;
  margin-bottom: 8px;
}

@media screen and (max-width: 1300px) {
  .flow {
    padding: 0 24px 24px;
  }

  .flow-wrapper {
    padding: 60px 40px 60px;
  }
}

@media screen and (max-width: 1024px) {
  .flow-decoration.left {
    left: 0;
    top: 12px;
    bottom: auto;
    width: 122px;
  }

  .flow-decoration.right {
    right: 0;
    top: 0;
    bottom: auto;
    width: 88px;
  }
}

@media screen and (max-width: 768px) {
  .flow {
    padding: 0 16px 8px;
  }

  .flow-wrapper {
    border-radius: 20px;
    padding: 32px 16px 40px;
  }

  .flow-wrapper h3.title {
    margin: 0 auto 16px;
  }

  .flow-block .flow-block-item {
    border-width: 2px;
    border-radius: 20px;
    padding: 24px 22px;
    display: block;
  }

  .flow-block .flow-block-item .number {
    height: auto;
    margin-right: 0;
    margin-bottom: 24px;
    padding-right: 0;
    padding-bottom: 5px;
    border-right: none;
    border-bottom: solid 2px #2A2A2A;
    display: flex;
    gap: 8px;
    align-items: center;
    justify-content: center;
  }

  .flow-block .flow-block-item .icon {
    width: 50px;
    height: 50px;
    margin: 0 auto 16px;
  }

  .flow-block .flow-block-item .text .title {
    font-size: 1.125rem;
    text-align: center;
  }
}

@media screen and (max-width: 450px) {
  .flow-decoration.left {
    top: -8px;
  }
}

/* よくあるご質問 */
.faq {
  padding: 80px 24px 221px;
  background: url("../img/faq-background.svg");
  background-repeat: repeat;
  background-position: center top;
  background-size: 65px;
  position: relative;
}

.scroll-point#faq {
  position: absolute;
  top: -100px;
  z-index: -1;
  opacity: 0;
}

.faq-wrapper {
  max-width: 1200px;
  margin: 0 auto;
}

.faq-wrapper .title {
  margin-bottom: 50px;
}

.faq-block .faq-block-item + .faq-block-item {
  margin-top: 34px;
}

.faq-block .faq-block-item .link {
  font-size: 1.25rem;
  font-weight: 600;
  position: relative;
}

.faq-block .faq-block-item .link.active {
  transform: translate(10px, 10px);
}

.faq-block .faq-block-item .link::before,
.faq-block .faq-block-item .link::after {
  content: '';
  display: block;
  width: 18px;
  height: 4px;
  background-color: #2A2A2A;
  border-radius: 8px;
  position: absolute;
  top: 53px;
  right: 50px;
  transition: .3s;
}

.faq-block .faq-block-item .link::after {
  transform: rotate(-90deg);
}

.faq-block .faq-block-item .link.active::after {
  transform: rotate(0deg);
}

.faq-block .faq-block-item .link .click-area {
  display: flex;
  align-items: center;
  cursor: pointer;
  padding: 36px 40px;
}

.faq-block .faq-block-item .link .icon {
  display: inline-block;
  width: 40px;
  min-width: 40px;
  height: 40px;
  margin-right: 16px;
}

.faq-block .faq-block-item .link .answer {
  transition: .3s;
  max-height: 0;
  opacity: 0;
  visibility: hidden;
  padding: 0 36px;
}

.faq-block .faq-block-item .link.active > .answer {
  max-height: 150px;
  opacity: 1;
  visibility: visible;
  padding: 0 40px 36px 40px;
}

.faq-block .faq-block-item .link .open-area {
  font-size: 1rem;
  font-weight: 400;
  display: flex;
  align-items: center;
}

@media screen and (max-width: 1300px) {
  .faq {
    padding: 40px 24px 166px;
  }
}

@media screen and (max-width: 768px) {
  .faq {
    padding: 48px 24px 140px;
    background: url("../img/faq-background_sp.svg");
    background-repeat: repeat;
    background-position: center top;
    background-size: 20px;
  }

  .scroll-point#faq {
    top: -40px;
  }

  .faq-wrapper .title {
    margin-bottom: 22px;
  }

  .faq-block .faq-block-item + .faq-block-item {
    margin-top: 22px;
  }

  .faq-block .faq-block-item .link {
    font-size: 1rem;
  }

  .faq-block .faq-block-item .link.active {
    transform: translate(6px, 6px);
  }

  .faq-block .faq-block-item .link::before,
  .faq-block .faq-block-item .link::after {
    width: 14px;
    height: 3px;
    top: 34px;
    right: 30px;
  }

  .faq-block .faq-block-item .link .click-area {
    align-items: flex-start;
    padding: 24px 60px 24px 24px;
  }

  .faq-block .faq-block-item .link .icon {
    width: 30px;
    min-width: 30px;
    height: 30px;
  }

  .faq-block .faq-block-item .link .answer {
    padding: 0 60px 0 24px;
  }

  .faq-block .faq-block-item .link.active > .answer {
    padding: 0 60px 24px 24px;
  }

  .faq-block .faq-block-item .link .open-area {
    font-size: 0.8125rem;
  }
}

/* バナー */
.banner-wrapper {
  background-color: #F25834;
  position: relative;
}

.banner-wrapper .title {
  width: 423px;
  height: 110px;
  background: url("../img/banner-title-background.svg") no-repeat;
  background-position: center;
  background-size: contain;
  padding-top: 27px;
  font-family: sicuniversallinelge, sans-serif;
  font-style: normal;
  font-size: 1.5rem;
  color: #fff;
  text-align: center;
  position: absolute;
  top: -98px;
  left: 50%;
  transform: translateX(-50%);
}

.banner-wrapper .info-block-area {
  overflow: hidden;
}

.banner-wrapper .info-block {
  width: fit-content;
  margin: 0 auto;
  padding: 70px 0;
  display: flex;
  gap: 64px;
  justify-content: center;
  align-items: center;
}

.banner-wrapper .info-block .tel-area {
  position: relative;
}

.banner-wrapper .info-block .tel {
  display: flex;
  gap: 16px;
}

.banner-wrapper .info-block .tel .icon {
  width: 72px;
  height: auto;
}

.banner-wrapper .info-block .tel .number {
  font-family: "brandon-grotesque", sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 2.5rem;
  color: #fff;
}

.banner-wrapper .info-block .tel .number .time {
  font-family: "Noto Sans", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 0.875rem;
}

.banner-wrapper .info-block .contact-area {
  position: relative;
}

.banner-wrapper .info-block .contact a {
  display: flex;
  gap: 16px;
  align-items: center;
  justify-content: center;
  width: 480px;
  padding: 39px 20px;
  font-size: 1.75rem;
  font-weight: 600;
  line-height: 1;
}

.banner-wrapper .info-block .contact .icon {
  width: 72px;
  height: auto;
}

.banner-side-img {
  position: absolute;
}

.banner-side-img.left {
  width: 280px;
  height: 280px;
  left: -290px;
  bottom: -110px;
}

.banner-side-img.right {
  width: 310px;
  height: 310px;
  right: -226px;
  bottom: -94px;
}

.time-text {
  font-family: brandon-grotesque, sans-serif;
  font-style: normal;
}

@media screen and (max-width: 1300px) {
  .banner-wrapper .info-block {
    gap: 30px;
  }

  .banner-wrapper .info-block .tel .icon {
    width: 50px;
  }

  .banner-wrapper .info-block .tel .number {
    font-size: 1.7rem;
  }

  .banner-side-img.left {
    width: 200px;
    height: 200px;
    left: -197px;
  }

  .banner-wrapper .info-block .contact a {
    width: 280px;
    padding: 15px;
    font-size: 1.3rem;
  }

  .banner-wrapper .info-block .contact .icon {
    width: 50px;
  }

  .banner-side-img.right {
    width: 210px;
    height: 210px;
    right: -170px;
  }
}

@media screen and (max-width: 768px) {
  .banner-wrapper .title {
    width: 300px;
    height: 117px;
    background: url("../img/banner-title-background_sp.svg") no-repeat;
    background-position: center;
    background-size: contain;
    font-size: 1rem;
    font-weight: 400;
    top: -73px;
  }

  .banner-wrapper .info-block {
    width: 100%;
    display: block;
    padding: 40px 24px 0;
  }

  .banner-wrapper .info-block .tel-area {
    margin-bottom: 34px;
    border-bottom: solid 2px #2A2A2A;
    overflow: hidden;
  }

  .banner-wrapper .info-block .tel {
    gap: 8px;
    justify-content: center;
  }

  .banner-wrapper .info-block .tel .icon {
    width: 40px;
  }

  .banner-wrapper .info-block .tel .number {
    font-size: 2rem;
    line-height: 1;
  }

  .banner-wrapper .info-block .tel .number .time {
    font-size: 0.75rem;
    margin-top: 10px;
  }

  .banner-wrapper .info-block .contact a {
    gap: 10px;
    width: 100%;
    padding: 23px 10px;
    font-size: 1.125rem;
  }

  .banner-wrapper .info-block .contact .icon {
    width: 40px;
    height: 40px;
  }

  .banner-side-img {
    position: relative;
    margin: 0 auto;
  }

  .banner-side-img.left {
    width: 170px;
    height: 170px;
    left: auto;
    bottom: -23px;
    margin-top: -33px;
  }

  .banner-side-img.right {
    width: 190px;
    height: 190px;
    right: auto;
    bottom: -34px;
    margin-top: -38px;
  }

  .banner-wrapper .info-block .contact-area .contact {
    max-width: 350px;
    margin: 0 auto;
  }
}

/* フッター */
.footer {
  border-top: solid 4px #2A2A2A;
  background-color: #fff;
  padding: 40px;
}

.footer-wrapper {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
}

.footer-wrapper .logo-area .footer-logo {
  width: 213px;
  height: auto;
  margin-bottom: 20px;
}

.footer-wrapper .logo-area .address {
  font-size: 0.75rem;
}

.footer-wrapper .text-area {
  display: flex;
  flex-flow: column;
  justify-content: flex-end;
}

.footer-wrapper .text-area .link {
  margin-bottom: 44px;
}

.footer-wrapper .text-area .link ul {
  display: flex;
  justify-content: space-between;
}

.footer-wrapper .text-area .link a {
  font-size: 0.875rem;
  display: inline-block;
  padding-right: 20px;
  background: url("../img/window-icon.svg") no-repeat;
  background-position: center right;
  background-size: 12px;
  transition: .3s;
}

.footer-wrapper .text-area .link a:hover {
  opacity: 0.7;
}

.footer-wrapper .text-area .copy {
  font-size: 0.75rem;
  color: #A5A5A5;
}

@media screen and (max-width: 768px) {
  .footer {
    border-width: 2px;
    padding: 40px 24px 30px;
  }

  .footer-wrapper {
    display: block;
  }

  .logo-area {
    margin-bottom: 40px;
  }

  .footer-wrapper .logo-area .footer-logo {
    width: 150px;
    margin-bottom: 16px;
    margin-left: auto;
    margin-right: auto;
  }

  .footer-wrapper .logo-area .address {
    text-align: center;
  }

  .footer-wrapper .text-area .link ul {
    gap: 14px;
    flex-flow: column;
    align-items: center;
  }

  .footer-wrapper .text-area .copy {
    text-align: center;
  }
}

/* お問い合わせ */
.contact-form {
  padding: 0 24px;
}

.contact-wrapper {
  margin: 0 auto;
  padding: 248px 0 120px;
  max-width: 1200px;
}

.contact-form.check .content-title {
  margin-bottom: 40px;
}

.contact-read {
  text-align: center;
  margin: 16px 0 40px;
}

.form-inputs {
  background-color: #fff;
  border: solid 4px #2A2A2A;
  border-radius: 40px;
  padding: 80px 84px;
}

.contact-form.thanks .form-inputs {
  padding: 156px 16px;
}

.contact-form.thanks .form-inputs .title {
  font-family: sicuniversallinelge, sans-serif;
  font-size: 3.75rem;
  font-style: normal;
  text-align: center;
  margin-bottom: 16px;
}

.contact-form.thanks .form-inputs .text {
  font-size: 1.125rem;
  text-align: center;
}

.form-group {
  padding: 24px 0;
  display: flex;
  border-bottom: solid 1px #C1C1C1;
}

.form-group.align-center {
  align-items: center;
}

.form-title {
  padding: 12px 0;
  font-weight: 600;
  min-width: 200px;
}

.form-title span {
  display: inline-block;
  color: #fff;
  font-size: 0.875rem;
  border-radius: 4px;
  margin-right: 8px;
  padding: 2px 8px;
  font-weight: 400;
}

.form-title span.require {
  background-color: #F25834;
}

.form-title span.any {
  background-color: #5DC9FF;
}

.input-area {
  width: 100%;
}

.contact-form.check .input-area {
  display: flex;
  align-items: center;
}

input,
textarea {
  width: 100%;
  padding: 12px 16px;
  border: solid 1px #C1C1C1;
  border-radius: 12px;
}

textarea {
  resize: none;
}

::placeholder {
  color: #C1C1C1;
}

.checkbox-label {
  font-weight: 600;
}

.checkbox {
  padding: 8px 0;
  position: relative;
}

.checkbox input,
.radiobox input {
  opacity: 0;
  appearance: none;
  display: block;
  padding: 0;
  margin: 0;
  border: none;
  position: absolute;
  top: 20px;
}

.checkbox .checkbox-label {
  position: relative;
  padding-left: 32px;
  cursor: pointer;
}

.checkbox .checkbox-label::before {
  content: '';
  display: inline-block;
  width: 18px;
  height: 18px;
  border: solid 2px #2A2A2A;
  background-color: #fff;
  border-radius: 3px;
  cursor: pointer;
  position: absolute;
  top: 2px;
  left: 0;
}

.checkbox input:checked + .checkbox-label::before {
  background-color: #FFCE47;
}

.checkbox input:checked + .checkbox-label::after {
  content: '';
  display: block;
  width: 10px;
  height: 7px;
  border-bottom: solid 2px #2A2A2A;
  border-left: solid 2px #2A2A2A;
  transform: rotate(-45deg);
  position: absolute;
  top: 6px;
  left: 4px;
}

.input-textarea {
  position: relative;
}

.input-textarea textarea {
  position: relative;
  z-index: 1;
}

.calendar {
  display: flex;
  border: solid 1px #C1C1C1;
  border-radius: 12px;
  overflow: hidden;
  width: 100%;
}

.calendar-area {
  overflow: hidden;
  display: flex;
  flex-grow: 1;
}

.loading {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-grow: 1;
  width: 100%;
  height: 100%;
  border-left: solid 1px #C1C1C1;;
}

.slot {
  width: 92px;
  font-weight: 600;
  text-align: center;
  border-left: solid 1px #C1C1C1;
  position: relative;
}

.date.slot {
  padding: 19px;
}

.slot + .slot {
  border-left: solid 1px #C1C1C1;
  border-top: solid 1px #C1C1C1;
}

.time.slot {
  border-left: none;
}

.calendar-btns {
  display: flex;
  justify-content: space-between;
  margin-bottom: 16px;
}

.calendar-btns button {
  display: block;
  width: 177px;
  height: 56px;
  background-color: #fff;
  border: solid 1px #2A2A2A;
  border-radius: 16px;
  position: relative;
  transition: .3s;
}

.calendar-btns button::before,
.calendar-btns button::after {
  content: '';
  display: block;
  width: 9px;
  height: 2px;
  border-radius: 2px;
  background-color: #2A2A2A;
  position: absolute;
  top: 10px;
}

.calendar-btns button::before {
  transform: rotate(45deg);
}

.calendar-btns button::after {
  transform: rotate(-45deg);
}

.calendar-btns button.prev::before,
.calendar-btns button.prev::after {
  left: 40px;
}

.calendar-btns button.next::before,
.calendar-btns button.next::after {
  right: 40px;
}

.calendar-btns button.prev::after,
.calendar-btns button.next::before {
  top: 23px;
}

.calendar-btns button.prev::before,
.calendar-btns button.next::after {
  top: 28px;
}

.calendar-btns button.prev {
  padding: 15px 32px 15px 68px;
}

.calendar-btns button.next {
  padding: 15px 68px 15px 32px;
}

.calendar-btns button:disabled {
  border-color: #D4D4D4;
  color: #D4D4D4;
  pointer-events: none;
  cursor: default;
}

.calendar-btns button:disabled::before,
.calendar-btns button:disabled::after {
  background-color: #D4D4D4;
}

.calendar .time {
  width: 177px;
  padding: 19px 0;
  line-height: 32px;
}

.calendar .time.none {
  height: 86px;
}

.calendar .mark img {
  width: 32px;
  height: 32px;
}

.tel-block .tel-area .icon {
  width: 72px;
  height: 72px;
}

.saturday {
  background-color: #E7F7FF;
}

.sunday {
  background-color: #FFEEE7;
}

.no {
  background-color: #F5F5F5;
}

.selected {
  background-color: #FFF4D6;
}

.date-entry input {
  padding: 0;
  border: none;
  width: 0;
  height: 0;
  top: 40px;
  left: 40px;
}

.reserve {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 19px;
}

.slot.ok .reserve {
  cursor: pointer;
}

.form-btns {
  margin-top: 40px;
}

.form-btns .form-group {
  justify-content: center;
  border-bottom: none;
  padding: 0 0 35px;
}

.form-btns .form-title {
  min-width: 70px;
}

.form-btns .input-area {
  width: auto;
  padding: 4px 0;
  position: relative;
}

.form-btns .form-link {
  display: flex;
  justify-content: center;
}

.form-btns .action-btn.back {
  margin-right: 40px;
}

.form-btns .action-btn::before {
  border-radius: 22px;
  top: 8px;
  left: 8px;
}

.form-btns .action-btn .link {
  width: 320px;
  padding: 28px;
  border-radius: 16px;
  font-size: 1.125rem;
  font-weight: 600;
  text-align: center;
}

.form-btns .action-btn.back .link {
  background-color: #E7E7E7;
  width: 200px;
}

.tel-block {
  margin-top: 112px;
  border: solid 1px #2A2A2A;
  padding: 23px;
}

.tel-block .title {
  font-size: 1.5rem;
  font-weight: 600;
  text-align: center;
  margin-bottom: 16px;
}

.tel-block .tel-area {
  display: flex;
  justify-content: center;
}

.tel-block .tel {
  display: flex;
  gap: 16px;
}

.tel-block .tel .number {
  font-family: "brandon-grotesque", sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 2.5rem;
  color: #F25834;
}

.tel-block .tel .number .time {
  font-family: "Noto Sans", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 0.875rem;
}

.date-entry input:checked + .reserve {
  background-color: #FFF4D6;
}

.invalid-feedback {
  display: inline-block;
  color: #F25834;
  font-size: 0.9rem;
  margin-top: 7px;
}

.form-btns .form-group .invalid-feedback {
  position: absolute;
  bottom: -15px;
  left: calc(-50% + 24px);
  white-space: nowrap;
}

.error {
  color: #F25834;
  font-size: 1.3rem;
  text-align: center;
}

.error-text + .error-text {
  margin-top: 7px;
}

@media screen and (min-width: 1025px) {
  .form-btns .action-btn .link:hover {
    transform: translate(8px, 8px);
  }

  .calendar-btns button:hover {
    background-color: #FCDA7C;
  }
}

@media screen and (max-width: 1400px) {
  .calendar-area {
    width: 100%;
  }

  .date-entry {
    width: calc(100% / 7);
  }

  .slot {
    width: 100%;
  }
}

@media screen and (max-width: 1300px) {
  .contact-wrapper {
    padding: 180px 0 60px;
  }

  .tel-block {
    margin-top: 70px;
  }
}

@media screen and (max-width: 1200px) {
  .reserve,
  .date.slot {
    padding: 19px 10px;
  }
}

@media screen and (max-width: 1024px) {
  .contact-wrapper {
    padding: 100px 0 40px;
  }

  .contact-form.thanks .contact-wrapper {
    padding: 190px 0 80px;
  }

  .form-inputs {
    padding: 20px 40px 40px;
  }

  .calendar .sign {
    display: inline-block;
    transform: rotate(90deg) translate(7px, 0px);
  }

  @-moz-document url-prefix() {
    .calendar .sign {
      transform: rotate(90deg) translate(0px, 0px);
    }
  }

  .contact-form.thanks .form-inputs {
    padding: 90px 16px;
  }

  .form-title {
    min-width: 163px;
  }

  .form-btns .input-area {
    padding: 2px 0 0;
  }

  .form-title span {
    font-size: 0.7rem;
  }

  .contact-form.thanks .form-inputs .title {
    font-size: 2.5rem;
  }

  .form-btns .form-group .invalid-feedback {
    left: calc(-50% - 17px);
  }

  .calendar .time.none {
    height: 77px;
  }

  .calendar .time {
    width: 85px;
    padding: 15px 0 16px;
    line-height: 1;
  }

  .reserve,
  .date.slot {
    padding: 19px 5px;
  }
}

@media screen and (max-width: 768px) {
  .contact-form.thanks .contact-wrapper {
    padding: 160px 0 60px;
  }

  .contact-form {
    padding: 0 16px;
  }

  .contact-read {
    margin: 10px 0 25px;
  }

  .form-inputs {
    border-radius: 20px;
    padding: 8px 16px 20px;
    border-width: 2px;
  }

  .contact-form.thanks .form-inputs {
    padding: 70px 16px;
  }

  .form-group {
    display: block;
    padding: 16px 0;
  }

  .form-btns .form-group {
    display: flex;
    justify-content: center;
    align-items: center;
  }

  .form-btns .input-area {
    padding: 0;
  }

  .form-title {
    font-size: 0.9rem;
    display: block;
    padding: 0;
    margin-bottom: 10px;
  }

  .form-btns .checkbox {
    padding: 0;
  }

  input,
  textarea {
    font-size: 1rem;
  }

  .checkbox .checkbox-label {
    padding-left: 27px;
  }

  .checkbox .checkbox-label::before {
    top: 1px;
  }

  .checkbox input:checked + .checkbox-label::after {
    top: 5px;
  }

  .calendar-btns {
    margin-bottom: 12px;
  }

  .calendar-btns button {
    width: 120px;
    height: 50px;
    border-radius: 12px;
  }

  .calendar-btns button.prev {
    padding: 5px 5px 5px 25px;
  }

  .calendar-btns button.next {
    padding: 5px 25px 5px 5px;
  }

  .calendar-btns button.prev::before,
  .calendar-btns button.prev::after {
    left: 10px;
  }

  .calendar-btns button.next::before,
  .calendar-btns button.next::after {
    right: 10px;
  }

  .calendar-btns button.prev::after,
  .calendar-btns button.next::before {
    top: 20px;
  }

  .calendar-btns button.prev::before,
  .calendar-btns button.next::after {
    top: 25px;
  }

  .slot {
    font-size: 0.5rem;
  }

  .reserve, .date.slot {
    padding: 5px;
  }

  .calendar .time.none {
    height: 34px;
  }

  .reserve {
    padding: 5px;
    height: 40px;
  }

  .calendar .time {
    width: 35px;
    padding: 8px 0;
  }

  .calendar .sign {
    transform: rotate(90deg) translate(4px, 0px);
  }

  @-moz-document url-prefix() {
    .calendar .sign {
      transform: rotate(90deg) translate(0px, 0px);
    }
  }

  .calendar .mark img {
    width: 20px;
    height: 20px;
  }

  .form-btns .form-title {
    margin-bottom: 0;
    min-width: auto;
  }

  .form-btns .action-btn {
    width: 100%;
    max-width: 328px;
  }

  .form-btns .action-btn.back {
    margin-right: 25px;
    width: fit-content;
  }

  .form-btns .action-btn .link {
    border-radius: 20px;
    width: 100%;
    padding: 18px 10px;
    font-size: 0.9rem;
  }

  .form-btns .action-btn.back .link {
    width: 125px;
  }

  .form-btns .action-btn .link:hover {
    transform: translate(6px, 6px);
  }

  .form-btns .action-btn::before {
    border-radius: 24px;
    top: 6px;
    left: 6px;
  }

  .tel-block {
    margin-top: 60px;
  }

  .tel-block {
    padding: 16px 10px;
  }

  .tel-block .title {
    font-size: 1rem;
  }

  .tel-block .tel {
    gap: 8px;
    justify-content: center;
  }

  .tel-block .tel-area .icon {
    width: 40px;
    height: 40px;
  }

  .tel-block .tel .number {
    font-size: 2rem;
    line-height: 1;
  }

  .tel-block .tel .number .time {
    font-size: 0.75rem;
    margin-top: 10px;
  }

  .invalid-feedback {
    font-size: 0.75rem;
  }

  .form-btns .form-group .invalid-feedback {
    bottom: -23px;
    left: calc(-50% + 23px);
  }
}

@media screen and (max-width: 500px) {
  .contact-form.thanks .contact-wrapper {
    padding: 130px 0 60px;
  }

  .contact-form.thanks .form-inputs .title {
    font-size: 2rem;
  }
}