/*! destyle.css v2.0.2 | MIT License | https://github.com/nicolas-cusan/destyle.css */
*,
:after,
:before {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  border-style: solid;
  border-width: 0
}

html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0)
}

body {
  margin: 0
}

main {
  display: block
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  line-height: inherit;
  font-weight: inherit;
  margin: 0
}

address,
blockquote,
dl,
figure,
form,
iframe,
ol,
p,
pre,
table,
ul {
  margin: 0
}

ol,
ul {
  padding: 0;
  list-style: none
}

dt {
  font-weight: 700
}

dd {
  margin-left: 0
}

hr {
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  height: 0;
  overflow: visible;
  border-top-width: 1px;
  margin: 0;
  clear: both;
  color: inherit
}

pre {
  font-family: monospace;
  font-size: inherit
}

address {
  font-style: inherit
}

a {
  background-color: rgba(0, 0, 0, 0);
  text-decoration: none;
  color: inherit
}

abbr[title] {
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
  text-decoration: underline dotted
}

b,
strong {
  font-weight: bolder
}

code,
kbd,
samp {
  font-family: monospace;
  font-size: inherit
}

small {
  font-size: 80%
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline
}

sub {
  bottom: -0.25em
}

sup {
  top: -0.5em
}

embed,
iframe,
img,
object {
  vertical-align: bottom
}

button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  background: 0 0;
  padding: 0;
  margin: 0;
  outline: 0;
  border-radius: 0;
  text-align: inherit
}

[type=checkbox] {
  -webkit-appearance: checkbox;
  -moz-appearance: checkbox;
  appearance: checkbox
}

[type=radio] {
  -webkit-appearance: radio;
  -moz-appearance: radio;
  appearance: radio
}

button,
input {
  overflow: visible
}

button,
select {
  text-transform: none
}

[type=button],
[type=reset],
[type=submit],
button {
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none
}

[type=button][disabled],
[type=reset][disabled],
[type=submit][disabled],
button[disabled] {
  cursor: default
}

[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button::-moz-focus-inner {
  border-style: none;
  padding: 0
}

[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring,
button:-moz-focusring {
  outline: 1px dotted ButtonText
}

select::-ms-expand {
  display: none
}

fieldset,
option {
  padding: 0
}

fieldset {
  margin: 0;
  min-width: 0
}

legend {
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal
}

progress {
  vertical-align: baseline
}

textarea {
  overflow: auto
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto
}

[type=search] {
  outline-offset: -2px
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit
}

label[for] {
  cursor: pointer
}

details {
  display: block
}

summary {
  display: list-item
}

[contenteditable] {
  outline: 0
}

table {
  border-collapse: collapse;
  border-spacing: 0
}

caption {
  text-align: left
}

td,
th {
  vertical-align: top;
  padding: 0
}

th {
  text-align: left;
  font-weight: 700
}

[hidden],
template {
  display: none
}

html {
  font-size: .5208vw;
  scroll-behavior: smooth
}

@media screen and (max-width: 767px) {
  html {
    font-size: 2.6667vw
  }
}

body {
  min-width: 320px;
  margin: auto;
  color: #464646;
  font-family: "Shippori Mincho B1", serif;
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1.75;
  letter-spacing: .05em;
  overflow-x: hidden;
  position: relative
}

@media screen and (max-width: 767px) {
  body {
    font-size: 1.2rem;
    line-height: 1.8
  }
}

@media(min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none
  }
}

img {
  display: block;
  max-width: 100%;
  height: auto;
  image-rendering: -webkit-optimize-contrast
}

hr {
  color: #c4c4c4
}

@media screen and (max-width: 767px) {
  br.__pc {
    display: none
  }
}

br.__sp {
  display: none
}

@media screen and (max-width: 767px) {
  br.__sp {
    display: inherit
  }
}

br.__space {
  display: block;
  content: "";
  margin-bottom: .5em
}

@media screen and (max-width: 767px) {
  .__pc {
    display: none
  }
}

.__sp {
  display: none
}

@media screen and (max-width: 767px) {
  .__sp {
    display: inherit
  }
}

.header {
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  left: 0;
  background-color: #fff;
  z-index: 100
}

.header__inner {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  width: 186.2rem;
  margin-left: auto
}

@media screen and (max-width: 767px) {
  .header__inner {
    width: auto;
    -webkit-box-align: initial;
    -webkit-align-items: initial;
    -ms-flex-align: initial;
    align-items: initial
  }
}

@media screen and (max-width: 767px) {
  .header__logo {
    padding: 1.6rem 0 1.6rem 1rem;
    position: relative;
    z-index: 1
  }
}

.header__logo a {
  display: block
}

.header__logo a img {
  height: 4.8rem
}

@media screen and (max-width: 767px) {
  .header__logo a img {
    height: 2.4rem
  }
}

.header .hamburger {
  background: -webkit-gradient(linear, left top, right top, from(#09c), color-stop(2%, #058dc6), color-stop(10%, #166cb5), color-stop(18%, #2253a9), color-stop(26%, #2b41a0), color-stop(35%, #31369a), color-stop(44%, #339), color-stop(54%, #2d4099), color-stop(72%, #1d659a), color-stop(96%, #049f9c), to(#00a99d));
  background: -webkit-linear-gradient(left, #09c 0%, #058dc6 2%, #166cb5 10%, #2253a9 18%, #2b41a0 26%, #31369a 35%, #339 44%, #2d4099 54%, #1d659a 72%, #049f9c 96%, #00a99d 100%);
  background: linear-gradient(90deg, #09c 0%, #058dc6 2%, #166cb5 10%, #2253a9 18%, #2b41a0 26%, #31369a 35%, #339 44%, #2d4099 54%, #1d659a 72%, #049f9c 96%, #00a99d 100%);
  width: 6rem;
  height: 6rem
}

@media screen and (max-width: 767px) {
  .header .hamburger {
    display: block;
    position: relative;
    z-index: 1
  }
}

.header .hamburger__inner {
  height: 100%;
  padding: 1.6rem 1.5rem;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between
}

.header .hamburger.active {
  position: relative;
  -webkit-transition: all .3s;
  transition: all .3s;
  margin-left: auto
}

.header .hamburger.active span {
  position: absolute;
  -webkit-transition: all .3s;
  transition: all .3s
}

.header .hamburger.active span:first-of-type {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  top: 50%
}

.header .hamburger.active span:nth-of-type(2) {
  display: none
}

.header .hamburger.active span:last-of-type {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  top: 50%
}

.header .hamburger span {
  display: block;
  width: 3rem;
  height: .15rem;
  background-color: #fff;
  -webkit-transition: all .3s;
  transition: all .3s
}

.header__info {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -webkit-align-items: flex-end;
  -ms-flex-align: end;
  align-items: flex-end;
  -webkit-column-gap: 5.6rem;
  -moz-column-gap: 5.6rem;
  column-gap: 5.6rem
}

@media screen and (max-width: 767px) {
  .header__info {
    display: none;
    position: absolute;
    top: 0;
    left: 0;
    background-color: #ebebf5;
    width: 100%;
    height: 100vh
  }

  .header__info.is-show {
    display: block
  }
}

.header__nav.__text {
  padding-bottom: 1rem
}

@media screen and (max-width: 767px) {
  .header__nav.__text {
    max-width: 132rem;
    margin: auto;
    padding-top: 10rem
  }
}

@media screen and (max-width: 767px)and (max-width: 767px) {
  .header__nav.__text {
    max-width: calc(100% - 4rem)
  }
}

@media screen and (max-width: 767px) {
  .header__nav.__text .header__nav-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column
  }

  .header__nav.__text .header__nav-item {
    font-size: 1.8rem;
    position: relative
  }

  .header__nav.__text .header__nav-item a {
    display: block;
    padding: 1.5rem 1rem;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    width: 100%
  }

  .header__nav.__text .header__nav-item a:after {
    content: "";
    background: url("file:///外部SSD/■WEB制作ローカルフォルダ/img/header_link_arrow.svg") no-repeat;
    display: block;
    width: 3.5rem;
    height: .47rem
  }

  .header__nav.__text .header__nav-item:before {
    background: -webkit-gradient(linear, left top, right top, from(#09c), color-stop(2%, #058dc6), color-stop(10%, #166cb5), color-stop(18%, #2253a9), color-stop(26%, #2b41a0), color-stop(35%, #31369a), color-stop(44%, #339), color-stop(54%, #2d4099), color-stop(72%, #1d659a), color-stop(96%, #049f9c), to(#00a99d));
    background: -webkit-linear-gradient(left, #09c 0%, #058dc6 2%, #166cb5 10%, #2253a9 18%, #2b41a0 26%, #31369a 35%, #339 44%, #2d4099 54%, #1d659a 72%, #049f9c 96%, #00a99d 100%);
    background: linear-gradient(90deg, #09c 0%, #058dc6 2%, #166cb5 10%, #2253a9 18%, #2b41a0 26%, #31369a 35%, #339 44%, #2d4099 54%, #1d659a 72%, #049f9c 96%, #00a99d 100%);
    content: "";
    position: absolute;
    display: block;
    width: 100%;
    height: 2px;
    left: 0;
    bottom: 0
  }
}

.header__nav.__text .header__nav-list {
  -webkit-column-gap: 4rem;
  -moz-column-gap: 4rem;
  column-gap: 4rem
}

.header__nav.__hasIcon {
  background: -webkit-gradient(linear, left top, right top, from(#09c), color-stop(2%, #058dc6), color-stop(10%, #166cb5), color-stop(18%, #2253a9), color-stop(26%, #2b41a0), color-stop(35%, #31369a), color-stop(44%, #339), color-stop(54%, #2d4099), color-stop(72%, #1d659a), color-stop(96%, #049f9c), to(#00a99d));
  background: -webkit-linear-gradient(left, #09c 0%, #058dc6 2%, #166cb5 10%, #2253a9 18%, #2b41a0 26%, #31369a 35%, #339 44%, #2d4099 54%, #1d659a 72%, #049f9c 96%, #00a99d 100%);
  background: linear-gradient(90deg, #09c 0%, #058dc6 2%, #166cb5 10%, #2253a9 18%, #2b41a0 26%, #31369a 35%, #339 44%, #2d4099 54%, #1d659a 72%, #049f9c 96%, #00a99d 100%);
  padding: 1rem 3.2rem
}

@media screen and (max-width: 767px) {
  .header__nav.__hasIcon {
    position: absolute;
    left: 0;
    bottom: 0;
    padding: .5rem 1.5rem
  }
}

.header__nav.__hasIcon .header__nav-list {
  height: 7.6rem;
  -webkit-box-align: end;
  -webkit-align-items: flex-end;
  -ms-flex-align: end;
  align-items: flex-end
}

@media screen and (max-width: 767px) {
  .header__nav.__hasIcon .header__nav-list {
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    height: 100%
  }
}

.header__nav.__hasIcon .header__nav-item {
  text-align: center;
  color: #fff;
  border-right: 1px solid #fff;
  height: 100%
}

.header__nav.__hasIcon .header__nav-item a {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  height: 100%;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  line-height: 1
}

@media screen and (max-width: 767px) {
  .header__nav.__hasIcon .header__nav-item:first-of-type {
    padding: .5rem 0
  }
}

.header__nav.__hasIcon .header__nav-item:first-of-type img {
  margin: 0 auto .8rem;
  width: auto;
  height: 3.2rem
}

@media screen and (max-width: 767px) {
  .header__nav.__hasIcon .header__nav-item:first-of-type img {
    height: 1.8rem
  }
}

.header__nav.__hasIcon .header__nav-item:first-of-type a {
  padding-right: 3rem
}

@media screen and (max-width: 767px) {
  .header__nav.__hasIcon .header__nav-item:first-of-type a {
    padding-right: 1rem
  }
}

@media screen and (max-width: 767px) {
  .header__nav.__hasIcon .header__nav-item:nth-of-type(2) {
    padding: .5rem 0
  }
}

.header__nav.__hasIcon .header__nav-item:nth-of-type(2) img {
  margin: 0 auto .8rem;
  width: auto;
  height: 2.7rem
}

@media screen and (max-width: 767px) {
  .header__nav.__hasIcon .header__nav-item:nth-of-type(2) img {
    height: 1.65rem
  }
}

.header__nav.__hasIcon .header__nav-item:nth-of-type(2) a {
  padding: 0 3rem
}

@media screen and (max-width: 767px) {
  .header__nav.__hasIcon .header__nav-item:nth-of-type(2) a {
    padding: 0 1.2rem
  }
}

.header__nav.__hasIcon .header__nav-item:last-of-type {
  border-right: none;
  line-height: 1
}

.header__nav.__hasIcon .header__nav-item:last-of-type .tel {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-column-gap: .5rem;
  -moz-column-gap: .5rem;
  column-gap: .5rem;
  font-size: 3rem;
  line-height: 1;
  letter-spacing: .05em;
  margin-bottom: .4rem
}

@media screen and (max-width: 767px) {
  .header__nav.__hasIcon .header__nav-item:last-of-type .tel {
    font-size: 2.2rem;
    margin-bottom: .2rem
  }
}

.header__nav.__hasIcon .header__nav-item:last-of-type .tel img {
  width: auto;
  height: 2.5rem
}

@media screen and (max-width: 767px) {
  .header__nav.__hasIcon .header__nav-item:last-of-type .tel img {
    height: 1.7rem
  }
}

.header__nav.__hasIcon .header__nav-item:last-of-type hr {
  padding-bottom: 1rem;
  display: block;
  width: 100%
}

@media screen and (max-width: 767px) {
  .header__nav.__hasIcon .header__nav-item:last-of-type hr {
    padding-bottom: .2rem
  }
}

.header__nav.__hasIcon .header__nav-item:last-of-type a {
  padding-left: 3rem
}

@media screen and (max-width: 767px) {
  .header__nav.__hasIcon .header__nav-item:last-of-type a {
    padding-left: 1rem
  }
}

.header__nav-list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex
}

.header__nav-item {
  color: #339
}

.header__nav-item.__hasIcon {
  color: #fff
}

.footer {
  background: -webkit-gradient(linear, left top, right top, from(#09c), color-stop(2%, #058dc6), color-stop(10%, #166cb5), color-stop(18%, #2253a9), color-stop(26%, #2b41a0), color-stop(35%, #31369a), color-stop(44%, #339), color-stop(54%, #2d4099), color-stop(72%, #1d659a), color-stop(96%, #049f9c), to(#00a99d));
  background: -webkit-linear-gradient(left, #09c 0%, #058dc6 2%, #166cb5 10%, #2253a9 18%, #2b41a0 26%, #31369a 35%, #339 44%, #2d4099 54%, #1d659a 72%, #049f9c 96%, #00a99d 100%);
  background: linear-gradient(90deg, #09c 0%, #058dc6 2%, #166cb5 10%, #2253a9 18%, #2b41a0 26%, #31369a 35%, #339 44%, #2d4099 54%, #1d659a 72%, #049f9c 96%, #00a99d 100%);
  padding: 14rem 0 5rem;
  color: #fff
}

@media screen and (max-width: 767px) {
  .footer {
    padding: 6rem 0 3rem
  }
}

.footer__inner {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 8rem;
  -moz-column-gap: 8rem;
  column-gap: 8rem;
  max-width: 162.3rem;
  margin-left: auto
}

@media screen and (max-width: 767px) {
  .footer__inner {
    display: block;
    max-width: 132rem;
    margin: auto
  }
}

@media screen and (max-width: 767px)and (max-width: 767px) {
  .footer__inner {
    max-width: calc(100% - 4rem)
  }
}

.footer__company-info {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1
}

.footer__logo {
  margin-bottom: 4rem
}

.footer__logo img {
  max-height: 5.7rem
}

@media screen and (max-width: 767px) {
  .footer__logo img {
    height: 3.7rem
  }
}

.footer__address {
  margin-bottom: 1.5rem
}

.footer__tel,
.footer__mail {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex
}

.footer__tel span,
.footer__mail span {
  display: block;
  text-align: justify;
  width: 5.8rem
}

@media screen and (max-width: 767px) {

  .footer__tel span,
  .footer__mail span {
    width: 5rem
  }
}

.footer__mail {
  margin-bottom: 4.5rem
}

@media screen and (max-width: 767px) {
  .footer__mail {
    margin-bottom: 1.5rem
  }
}

.footer__nav {
  margin-bottom: 9rem
}

@media screen and (max-width: 767px) {
  .footer__nav {
    margin-bottom: 5rem
  }
}

.footer__nav-list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 2.5rem 3.5rem;
  max-width: 38rem
}

@media screen and (max-width: 767px) {
  .footer__nav-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 1rem 0
  }
}

.footer__bottom {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -webkit-align-items: flex-end;
  -ms-flex-align: end;
  align-items: flex-end;
  -webkit-column-gap: 8.5rem;
  -moz-column-gap: 8.5rem;
  column-gap: 8.5rem
}

@media screen and (max-width: 767px) {
  .footer__bottom {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: column-reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    row-gap: 3rem
  }
}

.footer__bottom p {
  font-size: 1.2rem;
  letter-spacing: .2em
}

.footer__bottom-links {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 3.5rem;
  -moz-column-gap: 3.5rem;
  column-gap: 3.5rem
}

.footer__bottom-links a:hover {
  opacity: .7;
  -webkit-transition: all .3s;
  transition: all .3s
}

.footer__map {
  width: 92rem;
  height: 46.4rem
}

@media screen and (max-width: 767px) {
  .footer__map {
    display: none
  }

  .footer__map.__sp {
    display: block !important;
    width: 100%;
    height: 14.4rem;
    margin-bottom: 3rem
  }
}

.footer__map iframe {
  width: 100%;
  height: 100%
}

.footer hr {
  margin-bottom: 3.5rem
}

@media screen and (max-width: 767px) {
  .footer hr {
    margin-bottom: 3rem
  }
}

.footer p {
  font-size: 1.6rem;
  line-height: 1.5625
}

@media screen and (max-width: 767px) {
  .footer p {
    font-size: 1.4rem
  }
}