/*light*/
/*Medium*/
/*Bold*/
/*Heavy*/
/*
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com
Twitter: @rich_clark
*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

nav ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: "";
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

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

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input, select {
  vertical-align: middle;
}

.l-footer {
  height: 100%;
  width: 100%;
  z-index: -1;
  grid-row: 3/4;
}
@media screen and (min-width: 1200px) {
  .l-footer {
    width: 100%;
    position: unset;
  }
}
.l-footer__inner {
  height: 100%;
}

.l-header {
  height: 13rem;
  display: flex;
  position: absolute;
  grid-row: 1/2;
}
@media screen and (min-width: 781px) {
  .l-header {
    height: 13rem;
  }
}
@media screen and (min-width: 1200px) {
  .l-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
  }
}

.l-main {
  grid-row: 2/3;
  min-height: 100%;
}
@media screen and (min-width: 1200px) {
  .l-main {
    width: 100%;
    grid-row: 2/3;
    grid-column: 1/2;
  }
}
.l-main__font {
  font-family: "M PLUS 1p", Noto Sans JP, MyYuGothicM, YuGothic, -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, Verdana, arial, helvetica, sans-serif;
  font-weight: 700;
}

.l-wrapper {
  display: grid;
  background-color: #efefef;
  z-index: 1;
  flex-direction: column;
  justify-content: center;
  width: 100%;
  box-sizing: border-box;
  position: fixed;
  overflow-x: hidden;
  min-height: 100vh;
  grid-template-rows: 5rem 1fr 1.5rem;
  grid-template-columns: 100%;
}
@media screen and (min-width: 1200px) {
  .l-wrapper {
    grid-template-rows: 13rem auto 1fr;
  }
}
.l-wrapper::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url("./background-CtVmAjYC.webp");
  background-size: contain;
  background-position: center;
  opacity: 0.55;
  z-index: -3;
}
.l-wrapper.fix {
  overflow: hidden;
  max-height: 100vh;
}

.c-title__hero {
  font-size: 4.32vw;
  color: #707070;
}
@media screen and (min-width: 781px) {
  .c-title__hero {
    font-size: 4.32vw;
  }
}
@media screen and (min-width: 1200px) {
  .c-title__hero {
    font-size: 2.08vw;
  }
}
.c-title__contents {
  font-size: clamp(3.75rem, 6vw, 6.2rem);
  font-family: "M PLUS 1p", Noto Sans JP, MyYuGothicM, YuGothic, -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, Verdana, arial, helvetica, sans-serif;
}
.c-title__contents--privacy {
  font-size: clamp(0.8rem, 4.5vw, 6.2rem);
  font-family: "M PLUS 1p", Noto Sans JP, MyYuGothicM, YuGothic, -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, Verdana, arial, helvetica, sans-serif;
}
@media screen and (min-width: 781px) {
  .c-title__contents--privacy {
    font-size: clamp(0.8rem, 3vw, 6.2rem);
  }
}
.c-title__card {
  font-size: clamp(3.125rem, 4vw, 6.2rem);
  color: #707070;
}
.c-title__grid {
  font-size: 1rem;
  color: #3E3E3E;
}
.c-title__grid--works {
  font-size: 1.5rem;
  color: #3E3E3E;
}

.c-button__contact--area {
  width: 5rem;
  height: 5rem;
  position: relative;
  display: flex;
  align-items: center;
  z-index: 10001;
}
@media screen and (min-width: 1200px) {
  .c-button__contact {
    cursor: pointer;
    border-radius: 50%;
    width: 5rem;
    height: 5rem;
    position: absolute;
    top: 0;
    left: -0.7rem;
    z-index: 9998;
    background-color: rgba(239, 239, 239, 0.2);
    box-shadow: -4px -4px 8px #fff, 4px 4px 8px rgba(0, 0, 0, 0.24);
    transition: all 0.3s ease-in-out;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .c-button__contact:hover {
    box-shadow: -2px -2px 4px #fff, 2px 2px 4px rgba(0, 0, 0, 0.24);
  }
}
@media screen and (min-width: 1200px) {
  .c-button__contact--text {
    position: static;
    z-index: 10002; /* リンクを前面に */
    cursor: pointer; /* 明示的に設定 */
  }
}

.c-text {
  color: #3E3E3E;
  font-size: 1rem;
  line-height: 2.5rem;
}
.c-text__center {
  text-align: center;
}
@media screen and (min-width: 781px) {
  .c-text__center--tab {
    text-align: center;
  }
}
.c-text__midium {
  font-size: 1.4rem;
}
.c-text__large {
  font-size: 1.2rem;
  color: #3E3E3E;
  line-height: 2.5rem;
}
@media screen and (min-width: 781px) {
  .c-text__large {
    font-size: 1.52rem;
  }
}
.c-text__grid--profile {
  font-size: 1.3rem;
}
@media screen and (min-width: 1200px) {
  .c-text__grid--profile {
    font-size: 1.55rem;
  }
}
.c-text__gray {
  color: #707070;
  font-size: 1rem;
  line-height: 2.5rem;
}
.c-text__required {
  color: #fc5050;
  font-size: 0.8rem;
  line-height: 2.5rem;
}

.c-link__list {
  cursor: pointer;
}
.c-link__list:link {
  color: #3E3E3E;
  text-decoration: none;
}
.c-link__list:visited {
  color: #3E3E3E;
  text-decoration: none;
}
.c-link__list:hover {
  color: #3E3E3E;
  text-decoration: underline;
  text-decoration-color: #3E3E3E;
}
.c-link__list:focus {
  color: #3E3E3E;
  text-decoration: none;
}
.c-link__list:active {
  color: #3E3E3E;
  text-decoration: none;
}
.c-link__icon {
  cursor: pointer;
  transition: opacity 0.3s ease;
}
.c-link__icon:link {
  color: #3E3E3E;
  text-decoration: none;
}
.c-link__icon:visited {
  color: #3E3E3E;
  text-decoration: none;
}
.c-link__icon:hover {
  color: #3E3E3E;
  transform: scale(1.1);
  text-decoration-color: #3E3E3E;
}
.c-link__icon:focus {
  color: #3E3E3E;
  text-decoration: none;
}
.c-link__icon:active {
  color: #3E3E3E;
  text-decoration: none;
}
.c-link__hamburger {
  cursor: pointer;
  transition: opacity 0.3s ease;
}
.c-link__hamburger:link {
  color: #3E3E3E;
  text-decoration: none;
}
.c-link__hamburger:visited {
  color: #3E3E3E;
  text-decoration: none;
}
.c-link__hamburger:hover {
  color: #3E3E3E;
  opacity: 0.6;
  text-decoration: underline;
  text-decoration-color: #3E3E3E;
}
.c-link__hamburger:focus {
  color: #3E3E3E;
  text-decoration: none;
}
.c-link__hamburger:active {
  color: #3E3E3E;
  text-decoration: none;
}

.c-hamburger__button--open {
  display: block;
  content: "";
  background-color: #3E3E3E;
  width: 1.35rem;
  height: 0.08rem;
  position: absolute;
  top: 50%;
  right: 22.5%;
  z-index: 1;
}
@media screen and (min-width: 781px) {
  .c-hamburger__button--open {
    width: 2rem;
  }
}
.c-hamburger__button--open:before {
  position: absolute;
  top: -7px;
  right: 0;
  content: "";
  background-color: #3E3E3E;
  width: 1.35rem;
  height: 0.08rem;
}
@media screen and (min-width: 781px) {
  .c-hamburger__button--open:before {
    width: 2rem;
    top: -0.7rem;
  }
}
.c-hamburger__button--open:after {
  position: absolute;
  top: 7px;
  right: 0;
  content: "";
  background-color: #3E3E3E;
  width: 1.35rem;
  height: 0.08rem;
}
@media screen and (min-width: 781px) {
  .c-hamburger__button--open:after {
    width: 2rem;
    top: 0.7rem;
  }
}
.c-hamburger__button--close {
  display: none;
  content: "";
  background-color: none;
  width: 1.6rem;
  height: 0.08rem;
  position: absolute;
  top: 50%;
  right: 19.4%;
  z-index: 2;
}
@media screen and (min-width: 781px) {
  .c-hamburger__button--close {
    width: 2.6rem;
    right: 11.4%;
  }
}
.c-hamburger__button--close:before {
  position: absolute;
  content: "";
  background-color: #3E3E3E;
  width: 1.6rem;
  height: 0.08rem;
  rotate: 45deg;
}
@media screen and (min-width: 781px) {
  .c-hamburger__button--close:before {
    width: 2.6rem;
  }
}
.c-hamburger__button--close:after {
  position: absolute;
  content: "";
  background-color: #3E3E3E;
  width: 1.6rem;
  height: 0.08rem;
  rotate: -45deg;
}
@media screen and (min-width: 781px) {
  .c-hamburger__button--close:after {
    width: 2.6rem;
  }
}
.c-hamburger__button--close.is-appear {
  display: block;
  visibility: visible;
}
.c-hamburger__button--area {
  cursor: pointer;
  position: fixed;
  top: 0.5rem;
  right: 3.3%;
  height: 2.5rem;
  width: 2.5rem;
  border-radius: 50%;
  background-color: rgba(239, 239, 239, 0.2);
  box-shadow: -4px -4px 8px #fff, 4px 4px 8px rgba(0, 0, 0, 0.24);
  transition: all 0.3s ease-in-out;
  z-index: 999;
}
.c-hamburger__button--area.is-square {
  border-radius: 0%;
}
@media screen and (min-width: 781px) {
  .c-hamburger__button--area {
    top: 1.5rem;
    right: 2.5%;
    height: 3.5rem;
    width: 3.5rem;
  }
}
@media screen and (min-width: 1200px) {
  .c-hamburger__button--area {
    display: none;
  }
}
.c-hamburger__button--area:hover {
  box-shadow: -2px -2px 4px #fff, 2px 2px 4px rgba(0, 0, 0, 0.24);
}

.c-solid__before {
  display: flex;
  width: 100%;
  margin: 0 auto;
  justify-content: center;
  align-items: center;
  color: rgba(188, 186, 186, 0.8);
}
@media screen and (min-width: 1200px) {
  .c-solid__before {
    margin: 0 5% 0 0;
  }
}
.c-solid__before::before {
  display: flex;
  content: "";
  width: 30%;
  height: 0.125rem;
  margin-right: 5%;
  margin-left: 5%;
  background-color: rgba(188, 186, 186, 0.8);
}
@media screen and (min-width: 1200px) {
  .c-solid__before::before {
    display: flex;
    content: "";
    height: 0.125rem;
    width: 60%;
    margin-right: 3rem;
    background-color: rgba(188, 186, 186, 0.8);
  }
}
.c-solid__before::after {
  display: flex;
  content: "";
  width: 30%;
  height: 0.125rem;
  margin-left: 5%;
  margin-right: 5%;
  background-color: rgba(188, 186, 186, 0.8);
}
@media screen and (min-width: 1200px) {
  .c-solid__before::after {
    display: none;
  }
}
.c-solid__before--privacy {
  display: flex;
  width: 100%;
  margin: 0 auto;
  justify-content: center;
  align-items: center;
  color: rgba(188, 186, 186, 0.8);
}
@media screen and (min-width: 1200px) {
  .c-solid__before--privacy {
    margin: 0 5% 0 0;
  }
}
.c-solid__before--privacy::before {
  display: flex;
  content: "";
  width: 7%;
  height: 0.125rem;
  margin-right: 2%;
  margin-left: 5%;
  background-color: rgba(188, 186, 186, 0.8);
}
@media screen and (min-width: 1200px) {
  .c-solid__before--privacy::before {
    display: flex;
    content: "";
    height: 0.125rem;
    width: 40%;
    margin-right: 3rem;
    background-color: rgba(188, 186, 186, 0.8);
  }
}
.c-solid__before--privacy::after {
  display: flex;
  content: "";
  width: 7%;
  height: 0.125rem;
  margin-left: 2%;
  margin-right: 5%;
  background-color: rgba(188, 186, 186, 0.8);
}
@media screen and (min-width: 1200px) {
  .c-solid__before--privacy::after {
    display: none;
  }
}
@media screen and (min-width: 375px) {
  .c-solid__after::before {
    display: none;
  }
}
@media screen and (min-width: 1200px) {
  .c-solid__after::before {
    display: flex;
    content: "";
    height: 0.125rem;
    width: 60%;
    margin-left: 3rem;
    background-color: rgba(188, 186, 186, 0.8);
  }
}
.c-solid__area {
  width: 89.3%;
  margin: 0 auto;
}
@media screen and (min-width: 781px) {
  .c-solid__area {
    width: 100%;
    margin: 0;
  }
}

.c-icon__mobile {
  font-size: 8rem;
  color: rgba(188, 186, 186, 0.8);
  margin: 4rem;
}
.c-icon__git {
  font-size: 1.5rem;
  margin-left: 10px;
}
.c-icon__link {
  font-size: 1.5rem;
  margin-right: 10px;
}

.c-image__square {
  display: block;
  aspect-ratio: 1/1;
  object-fit: cover;
  width: 13.5rem;
  height: 13.5rem;
  max-height: 25rem;
  max-width: 25rem;
}
@media screen and (min-width: 781px) {
  .c-image__square {
    width: 16.3rem;
    height: 16.3rem;
  }
}
@media screen and (min-width: 1200px) {
  .c-image__square {
    max-height: none;
    max-width: none;
  }
}

.c-label {
  height: 1.66rem;
  width: 100%;
}
.c-label__message {
  height: 26rem;
  width: 100%;
}
.c-label__send {
  display: flex;
  justify-content: center;
  margin: 0 auto;
  padding: 0.5rem;
  background-color: rgba(188, 186, 186, 0.55);
  color: #3E3E3E;
  font-size: 1rem;
  border: solid 0.15px #707070;
  border-radius: 4px;
  width: clamp(4rem, 28%, 6rem);
  cursor: pointer;
  transition: background-color 0.3s;
}
.c-label__send:hover {
  background-color: #707070;
  color: #efefef;
}
@media screen and (min-width: 781px) {
  .c-label__send {
    width: 18%;
  }
}

.is-style-service-text {
  width: 80.3%;
  margin: 5rem auto 1.5%;
  line-height: 2.5rem;
  font-family: "M PLUS 1p", Noto Sans JP, MyYuGothicM, YuGothic, -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, Verdana, arial, helvetica, sans-serif;
  text-align: left;
}
@media screen and (min-width: 781px) {
  .is-style-service-text {
    text-align: center;
    margin: 5rem auto 1%;
  }
}

.is-style-card-left {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  margin-top: 1rem;
  height: 100%;
  display: flex;
  align-items: center;
  flex-direction: column;
  padding: 8% 0;
  position: relative;
  z-index: -1;
}
@media screen and (min-width: 781px) {
  .is-style-card-left {
    margin-top: 2rem;
  }
}
@media screen and (min-width: 1200px) {
  .is-style-card-left {
    padding: 5% 0;
    margin-top: 3rem;
  }
}

.is-style-card-right {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  margin-top: 1rem;
  height: 100%;
  display: flex;
  align-items: center;
  flex-direction: column;
  padding: 8% 0;
  position: relative;
  z-index: -1;
  margin-bottom: 3.4375rem;
}
@media screen and (min-width: 781px) {
  .is-style-card-right {
    margin-top: 2rem;
  }
}
@media screen and (min-width: 1200px) {
  .is-style-card-right {
    padding: 5% 0;
    margin-top: 3rem;
  }
}

.is-style-card-center {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  margin-top: 1rem;
  height: 100%;
  display: flex;
  align-items: center;
  flex-direction: column;
  padding: 8% 0;
  position: relative;
  z-index: -1;
}
@media screen and (min-width: 781px) {
  .is-style-card-center {
    margin-top: 2rem;
  }
}
@media screen and (min-width: 1200px) {
  .is-style-card-center {
    padding: 5% 0 5% 1%;
    margin-top: 3rem;
  }
}

.is-style-card-price {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  margin-top: 1rem;
  height: 100%;
  display: flex;
  align-items: center;
  flex-direction: column;
  padding: 8% 0;
  position: relative;
  z-index: -1;
}
@media screen and (min-width: 781px) {
  .is-style-card-price {
    margin-top: 2rem;
  }
}
@media screen and (min-width: 1200px) {
  .is-style-card-price {
    padding: 5% 0 5% 1%;
    margin-top: 3rem;
  }
}
.is-style-card-price > .wp-block-font-awesome-icon {
  font-size: 8rem;
  color: rgba(188, 186, 186, 0.8);
  margin: 3.5rem !important;
}

.is-style-service-heading {
  font-size: clamp(2.8rem, 4vw, 6.2rem);
  color: #707070;
}

.is-style-card-wrap {
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 1200px) {
  .is-style-card-wrap {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    width: 85%;
    margin: 0 auto;
  }
}
.is-style-card-wrap > .wp-block-column > .wp-block-font-awesome-icon {
  font-size: 8rem;
  color: rgba(188, 186, 186, 0.8);
  margin: 4rem;
}

.is-style-service-sentence {
  margin: 0 5%;
  line-height: 2.5rem;
}

.is-style-contact-text {
  width: 80.3%;
  display: block;
  margin: 5rem auto;
  line-height: 2.5rem;
  font-family: "M PLUS 1p", Noto Sans JP, MyYuGothicM, YuGothic, -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, Verdana, arial, helvetica, sans-serif;
  text-align: left;
}
@media screen and (min-width: 781px) {
  .is-style-contact-text {
    text-align: center;
  }
}

.none {
  display: none !important;
}

.smf-progress-tracker {
  margin: 9rem auto 0 auto;
  width: 80vw;
}
@media screen and (min-width: 1200px) {
  .smf-progress-tracker {
    width: 44vw;
  }
}

.smf-form {
  display: flex;
  flex-direction: column;
  width: 80.3%;
  row-gap: 1rem;
  margin: 5rem auto;
  font-size: 1.2rem;
  color: #3E3E3E;
  line-height: 2.78rem;
  font-weight: 700;
  font-family: "M PLUS 1p", Noto Sans JP, MyYuGothicM, YuGothic, -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, Verdana, arial, helvetica, sans-serif;
}
@media screen and (min-width: 781px) {
  .smf-form {
    font-size: 1.52rem;
    width: 36.5rem;
    max-width: 89.3%;
  }
}

.smf-item__label {
  margin-bottom: 1rem;
  font: "M PLUS 1p", Noto Sans JP, MyYuGothicM, YuGothic, -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, Verdana, arial, helvetica, sans-serif;
}
.smf-item__label__text {
  position: relative;
}
.smf-item__label__text::after {
  content: "必須";
  color: #fc5050;
  position: absolute;
  top: 50%;
  right: -30%;
  transform: translateY(-50%);
  font-size: 0.8rem;
}

.wp-block-snow-monkey-forms-item:nth-child(3) .smf-item__label__text::after {
  display: none;
}

.wp-block-snow-monkey-forms-item:nth-child(5) .smf-item__label__text::after {
  top: 50%;
  right: -17%;
  transform: translateY(-50%);
  font: "M PLUS 1p", Noto Sans JP, MyYuGothicM, YuGothic, -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, Verdana, arial, helvetica, sans-serif;
}

[data-screen=confirm] .input_txt {
  display: none;
}

.smf-text-control__control {
  width: 100%;
  height: 2.03rem;
}

.smf-textarea-control__control {
  width: 100%;
  height: 26rem;
}

.smf-checkboxes-control__control {
  display: flex !important;
  justify-content: center !important;
}

.smf-checkbox-control {
  align-items: center !important;
}
.smf-checkbox-control__control {
  margin-top: 0 !important;
}

.smf-checkbox-control__label {
  font-size: 1rem !important;
}

.smf-action {
  display: flex;
  flex-direction: column-reverse;
  align-items: center;
}
@media screen and (min-width: 781px) {
  .smf-action {
    display: flex;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }
}

.smf-button-control {
  width: 100%;
  margin: 0 !important;
}

.smf-button-control__control[data-action=confirm] {
  display: flex !important;
  justify-content: center;
  margin: 2.5rem auto 15rem auto;
  padding: 0.5rem 0.85rem 0.5rem 1rem;
  background-color: rgba(188, 186, 186, 0.55);
  color: #3E3E3E;
  font-size: 1rem;
  border: solid 1px rgba(112, 112, 112, 0.78) 　 !important;
  border-radius: 4px !important;
  width: auto !important;
  cursor: pointer;
  transition: background-color 0.3s;
  font-family: "M PLUS 1p", Noto Sans JP, MyYuGothicM, YuGothic, -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, Verdana, arial, helvetica, sans-serif;
}
.smf-button-control__control[data-action=confirm]:hover {
  background-color: rgba(112, 112, 112, 0.231372549) !important;
  color: #1a1b1a !important;
  background-image: none;
}

.smf-button-control__control[data-action=complete] {
  display: flex !important;
  justify-content: center;
  width: auto !important;
  margin: 2.5rem auto 1rem auto;
  padding: 0.5rem 2rem;
  background-color: rgba(188, 186, 186, 0.55);
  color: #3E3E3E;
  font-size: 1rem;
  border: solid 1px rgba(112, 112, 112, 0.78) !important;
  border-radius: 4px !important;
  cursor: pointer;
  transition: background-color 0.3s;
  font-family: "M PLUS 1p", Noto Sans JP, MyYuGothicM, YuGothic, -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, Verdana, arial, helvetica, sans-serif;
}
.smf-button-control__control[data-action=complete]:hover {
  background-color: rgba(112, 112, 112, 0.231372549) !important;
  color: #1a1b1a !important;
  background-image: none;
}
@media screen and (min-width: 781px) {
  .smf-button-control__control[data-action=complete] {
    margin: 2.5rem auto 15rem 1rem;
  }
}

.smf-button-control__control[data-action=back] {
  display: flex !important;
  justify-content: center;
  width: auto !important;
  margin: 2.5rem auto 15rem auto;
  padding: 0.5rem 1.5rem;
  background-color: rgba(188, 186, 186, 0.55);
  color: #3E3E3E;
  font-size: 1rem;
  border: solid 1px rgba(112, 112, 112, 0.78) !important;
  border-radius: 4px !important;
  cursor: pointer;
  transition: background-color 0.3s;
  font-family: "M PLUS 1p", Noto Sans JP, MyYuGothicM, YuGothic, -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, Verdana, arial, helvetica, sans-serif;
}
.smf-button-control__control[data-action=back]:hover {
  background-color: rgba(112, 112, 112, 0.231372549) !important;
  color: #1a1b1a !important;
  background-image: none;
}
@media screen and (min-width: 781px) {
  .smf-button-control__control[data-action=back] {
    margin: 2.5rem 1rem 15rem auto;
  }
}

.smf-error-messages {
  font-family: "M PLUS 1p", Noto Sans JP, MyYuGothicM, YuGothic, -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, Verdana, arial, helvetica, sans-serif;
  font-size: 1rem;
}

.smf-placeholder {
  font-weight: 400;
}

.smf-complete-content {
  margin-bottom: 14rem;
}

.smf-system-error-content {
  margin: 0 auto 17rem;
}

.smf-item__description > a {
  cursor: pointer;
}
.smf-item__description > a:link {
  color: #2d5b8d;
  text-decoration: none;
  text-decoration: underline;
}
.smf-item__description > a:visited {
  color: #2d5b8d;
  text-decoration: none;
}
.smf-item__description > a:hover {
  color: #2d5b8d;
  text-decoration: underline;
  text-decoration-color: #3E3E3E;
}
.smf-item__description > a:focus {
  color: #2d5b8d;
  text-decoration: none;
}
.smf-item__description > a:active {
  color: #2d5b8d;
  text-decoration: none;
}

.is-style-grid-works {
  display: grid;
  grid-template-columns: 1fr !important;
  align-items: center;
  width: 89.3%;
  gap: 1.25rem;
  margin: 6rem auto 0 auto;
}
@media screen and (min-width: 781px) {
  .is-style-grid-works {
    display: grid;
    width: 86.32%;
    grid-template-columns: 1fr 1fr !important;
    row-gap: 3.25rem;
    column-gap: 1.25rem;
  }
}
@media screen and (min-width: 1200px) {
  .is-style-grid-works {
    width: 85%;
    grid-template-columns: 1fr 1fr 1fr !important;
  }
}

.is-style-grid-cell-works {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 1fr auto;
  place-items: center;
  align-items: center;
  width: 100%;
  height: 100%;
  padding: 0;
  position: relative;
  z-index: 1000;
}

.is-style-works-image > figure {
  display: flex !important;
  justify-content: center;
}
.is-style-works-image > figure > img {
  position: relative;
  z-index: 99999999999999;
  grid-row: 1/2;
  width: 80%;
  transition: 0.3s;
}
.is-style-works-image > figure > img:hover {
  transform: scale(1.08);
  cursor: pointer !important;
}

.is-style-works-textarea {
  grid-row: 2/3;
  display: flex;
  flex-direction: column;
  align-items: center;
  line-height: 1.7rem;
}

.is-style-work-heading {
  grid-row: 2/3;
  margin-top: 1rem;
}

.is-style-work-description {
  line-height: 2.5rem;
  margin: 0 5%;
  text-align: center;
}

.is-style-icon-left > div {
  cursor: pointer;
  transition: opacity 0.3s ease;
}
.is-style-icon-left > div:link {
  color: #3E3E3E;
  text-decoration: none;
}
.is-style-icon-left > div:visited {
  color: #3E3E3E;
  text-decoration: none;
}
.is-style-icon-left > div:hover {
  color: #3E3E3E;
  transform: scale(1.1);
  text-decoration-color: #3E3E3E;
}
.is-style-icon-left > div:focus {
  color: #3E3E3E;
  text-decoration: none;
}
.is-style-icon-left > div:active {
  color: #3E3E3E;
  text-decoration: none;
}
.is-style-icon-left > div > ul > li {
  margin-right: 10px !important;
}

.is-style-icon-right > div {
  cursor: pointer;
  transition: opacity 0.3s ease;
}
.is-style-icon-right > div:link {
  color: #3E3E3E;
  text-decoration: none;
}
.is-style-icon-right > div:visited {
  color: #3E3E3E;
  text-decoration: none;
}
.is-style-icon-right > div:hover {
  color: #3E3E3E;
  transform: scale(1.1);
  text-decoration-color: #3E3E3E;
}
.is-style-icon-right > div:focus {
  color: #3E3E3E;
  text-decoration: none;
}
.is-style-icon-right > div:active {
  color: #3E3E3E;
  text-decoration: none;
}
.is-style-icon-right > div > ul > li {
  margin-left: 10px !important;
}

#works .wp-block-spacer {
  display: none;
}
@media screen and (min-width: 1200px) {
  #works .wp-block-spacer {
    display: block;
  }
}

.is-style-grid-profile {
  display: grid;
  width: 85%;
  align-items: center;
  grid-template-columns: 1fr;
  grid-template-rows: 1fr 1fr;
  min-height: auto;
  font-weight: 400;
  margin: 5rem auto;
}
@media screen and (min-width: 1200px) {
  .is-style-grid-profile {
    width: 80%;
    grid-template-columns: 1fr 1fr !important;
    grid-template-rows: auto 1fr;
    row-gap: 5rem;
  }
}

.is-style-profile > img {
  display: block;
  aspect-ratio: 1/1;
  object-fit: cover;
  width: 13.5rem;
  height: 13.5rem;
  max-height: 25rem;
  max-width: 25rem;
  grid-row: 1/2;
  justify-self: center;
  margin: 0 auto 4.84rem;
  object-fit: cover;
  object-position: 50% 13%;
}
@media screen and (min-width: 781px) {
  .is-style-profile > img {
    width: 16.3rem;
    height: 16.3rem;
    margin-bottom: 2.23rem;
  }
}
@media screen and (min-width: 1200px) {
  .is-style-profile > img {
    max-height: none;
    max-width: none;
    justify-self: right;
    grid-row: 2/3;
    grid-column: 1/2;
    margin-top: 4rem;
    margin-right: 20%;
    margin-bottom: 4.84rem;
  }
}

.is-style-grid-profile-textarea-1 {
  grid-row: 2/3;
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: auto auto;
  text-align: left;
}
@media screen and (min-width: 1200px) {
  .is-style-grid-profile-textarea-1 {
    line-height: 2.68rem;
    justify-self: center;
    grid-column: 1/3;
    grid-row: 1/2;
  }
}

.is-style-profile-text-1 {
  font-size: 1.3rem;
  line-height: 2.5rem;
}
@media screen and (min-width: 1200px) {
  .is-style-profile-text-1 {
    font-size: 1.55rem;
    line-height: 3rem;
  }
}

.is-style-grid-profile-textarea-2 {
  line-height: 1.9rem;
}
@media screen and (min-width: 1200px) {
  .is-style-grid-profile-textarea-2 {
    grid-column: 2/3;
    grid-row: 2/3;
    line-height: 2.78rem;
  }
}

.is-style-profile-text-2 {
  font-size: 1.3rem;
  margin: 5rem auto;
}
@media screen and (min-width: 781px) {
  .is-style-profile-text-2 {
    margin: 0 auto;
  }
}
@media screen and (min-width: 1200px) {
  .is-style-profile-text-2 {
    margin: 2.44rem;
    font-size: 1.55rem;
  }
}
.is-style-profile-text-2 > a {
  cursor: pointer;
}
.is-style-profile-text-2 > a:link {
  color: #3E3E3E;
  text-decoration: none;
}
.is-style-profile-text-2 > a:visited {
  color: #3E3E3E;
  text-decoration: none;
}
.is-style-profile-text-2 > a:hover {
  color: #3E3E3E;
  text-decoration: underline;
  text-decoration-color: #3E3E3E;
}
.is-style-profile-text-2 > a:focus {
  color: #3E3E3E;
  text-decoration: none;
}
.is-style-profile-text-2 > a:active {
  color: #3E3E3E;
  text-decoration: none;
}

.is-style-line-height {
  line-height: 1.5rem;
}

.is-style-privacy {
  display: block;
  width: 85%;
  align-items: center;
  min-height: auto;
  font-weight: 400;
  margin: 5rem auto;
}
@media screen and (min-width: 1200px) {
  .is-style-privacy {
    width: 80%;
  }
}

.wp-caption {
  max-width: 100%;
  margin: 1em auto;
  text-align: center;
}

.wp-caption-text {
  font-size: 0.9rem;
  color: #707070;
  margin-top: 0.5em;
}

.sticky {
  border: 2px solid #707070;
  background-color: #707070;
  padding: 1em;
}

.gallery-caption {
  font-size: 0.85rem;
  color: #707070;
  text-align: center;
  margin-top: 0.3em;
}

.error404 .l-wrapper {
  font-family: "M PLUS 1p", Noto Sans JP, MyYuGothicM, YuGothic, -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, Verdana, arial, helvetica, sans-serif;
  display: grid;
  position: relative;
  overflow: hidden;
  min-height: 100dvh;
  grid-template-columns: 1fr;
  grid-template-rows: 13.4375rem 1fr 9.375rem;
}
@media screen and (min-width: 781px) {
  .error404 .l-wrapper {
    grid-template-rows: 13.5625rem 1fr 9.375rem;
  }
}
@media screen and (min-width: 1200px) {
  .error404 .l-wrapper {
    display: grid;
    min-height: 100dvh;
  }
}
.error404 .l-wrapper.fix {
  overflow: hidden;
}
.error404 .p-hero__title--menu {
  text-transform: uppercase;
}
.error404 .p-page404__main {
  margin: 5rem auto 10rem;
  width: 83%;
}
.error404 .p-page404__title--area {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.error404 .p-page404__text--area {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@media screen and (min-width: 781px) {
  .error404 .p-page404__text--area {
    align-items: center;
    text-align: center;
  }
}
.error404 .p-page404__text--sp {
  display: contents;
}
@media screen and (min-width: 781px) {
  .error404 .p-page404__text--sp {
    display: none;
  }
}
.error404 .p-page404__br--tb {
  display: none;
}
@media screen and (min-width: 781px) {
  .error404 .p-page404__br--tb {
    display: block;
  }
}
.error404 .p-page404__link {
  cursor: pointer;
}
.error404 .p-page404__link:link {
  color: #2d5b8d;
  text-decoration: none;
  text-decoration: underline;
}
.error404 .p-page404__link:visited {
  color: #2d5b8d;
  text-decoration: none;
}
.error404 .p-page404__link:hover {
  color: #2d5b8d;
  text-decoration: underline;
  text-decoration-color: #3E3E3E;
}
.error404 .p-page404__link:focus {
  color: #2d5b8d;
  text-decoration: none;
}
.error404 .p-page404__link:active {
  color: #2d5b8d;
  text-decoration: none;
}
.error404 .p-page404__link--bottom {
  display: contents;
}
@media screen and (min-width: 781px) {
  .error404 .p-page404__link--bottom {
    display: flex;
  }
}
.error404 .p-page404__margin--bottom {
  margin: 3rem auto 2.875rem;
}
@media screen and (min-width: 781px) {
  .error404 .p-page404__margin--bottom {
    margin-bottom: 6.875rem;
  }
}

.p-hero {
  display: flex;
  align-items: center;
  width: 100%;
  aspect-ratio: 375/285;
  /*&__menu{
      background-image: url(../../picture/three-burgers-zoom.jpg);
      background-repeat: no-repeat;
      background-size: 270%;
      background-position: 14.27% 46.8%;
      width: 100%;
      aspect-ratio: 375/285;
      position: relative;
      z-index: 10;
          @include g.tab{
          aspect-ratio: 834/285;
          background-size: 120%;
          background-position: calc(50% - 0%) calc(50% - 3.5%);
          width: 100%;
          }
          @include g.pc{
          background-image: url(../../picture/threeburgers.jpeg);
          aspect-ratio: 1553 /239;
          background-size: 105%;
          background-position: 10% 48%;
          }
  }*/
  /*&__single{
      aspect-ratio: 375/225;
  }*/
}
@media screen and (min-width: 1200px) {
  .p-hero {
    aspect-ratio: 1553/530;
  }
}
.p-hero__background {
  width: 100%;
  position: absolute;
  z-index: -2;
  height: auto;
  aspect-ratio: 700/480;
}
@media screen and (min-width: 1200px) {
  .p-hero__background {
    width: 70%;
    left: 14.7%;
    aspect-ratio: 1197/581;
  }
}
.p-hero__background--image {
  width: 100%;
  position: absolute;
  z-index: -2;
}
@media screen and (min-width: 1200px) {
  .p-hero__background--image {
    width: 59%;
    left: 20.3%;
  }
}
.p-hero__imageArea {
  position: relative;
  overflow: hidden;
  z-index: 10;
  width: 100%;
  height: auto;
  aspect-ratio: 375/285;
}
@media screen and (min-width: 781px) {
  .p-hero__imageArea {
    aspect-ratio: 834/285;
  }
}
@media screen and (min-width: 1200px) {
  .p-hero__imageArea {
    aspect-ratio: 1553/239;
  }
}
.p-hero__title--area {
  display: flex;
  flex-direction: column;
  padding-left: 6.7%;
  font-size: 9.6vw;
  color: #FFFFFF;
}
@media screen and (min-width: 781px) {
  .p-hero__title--area {
    font-size: 4.32vw;
    padding-left: 10.3%;
    width: 100%;
    flex-direction: row;
    align-items: center;
  }
}
@media screen and (min-width: 1200px) {
  .p-hero__title--area {
    font-size: 2.08vw;
    padding-left: 5.6%;
  }
}
.p-hero__title--menu {
  line-height: 2.637rem;
  font: 700 2.25rem "Roboto", Noto Sans JP, MyYuGothicM, YuGothic, -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, Verdana, arial, helvetica, sans-serif;
  margin-bottom: 12px;
}
@media screen and (min-width: 781px) {
  .p-hero__title--menu {
    font-size: 3.75rem;
    margin: 0%;
  }
}
.p-hero__title--menucontent {
  font-size: 1rem;
  line-height: 1.485rem;
}
@media screen and (min-width: 781px) {
  .p-hero__title--menucontent {
    padding-left: 2.2%;
  }
}
@media screen and (min-width: 1200px) {
  .p-hero__title--menucontent {
    font-size: 0.83vw;
    padding-top: 12px;
  }
}
.p-hero__singleArea {
  display: flex;
  align-items: center;
  position: relative;
}

.p-footer__text {
  display: block;
  color: #3E3E3E;
}
@media screen and (min-width: 375px) {
  .p-footer__text {
    font-size: 1.125rem;
  }
}
@media screen and (min-width: 781px) {
  .p-footer__text {
    font-size: 1.25rem;
  }
}
.p-footer__copyright {
  display: block;
  width: 30%;
  margin: 0 auto;
  text-align: center;
  font-size: 0.81rem;
  height: 100%;
  line-height: 1.5rem;
  color: #3E3E3E;
}
.p-footer__solid {
  display: block;
  border-top: solid 1px rgba(188, 186, 186, 0.8);
  height: 100%;
}

.p-menu {
  cursor: pointer;
  display: flex;
  position: fixed;
  flex-direction: column;
  top: 0;
  right: -100%;
  width: 100%;
  height: 100dvh;
  min-height: 100%;
  background-color: #efefef;
  z-index: 1000;
  visibility: inherit;
  overflow-y: auto;
}
.p-menu::before {
  content: "";
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100dvh;
  background-image: url("./background-CtVmAjYC.webp");
  background-size: contain;
  background-position: center;
  opacity: 0.55;
  z-index: -1;
}
.p-menu__menulist {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 10rem 0;
  font-size: 2rem;
  font-family: "M PLUS 1p", Noto Sans JP, MyYuGothicM, YuGothic, -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, Verdana, arial, helvetica, sans-serif;
}
.p-menu__list {
  color: #3E3E3E;
  padding: 5.18rem 0;
}
.p-menu__inner {
  position: relative;
  font-size: 1rem;
  z-index: 0;
}
@media screen and (min-width: 781px) {
  .p-menu__inner {
    font-size: 1.5rem;
  }
}
@media screen and (min-width: 1200px) {
  .p-menu {
    display: none;
  }
}
.p-menu.open {
  right: 0;
  position: fixed;
}

.p-grid {
  display: grid;
  grid-template-columns: 1fr !important;
  align-items: center;
  width: 89.3%;
  gap: 1.25rem;
  margin: 0 auto;
}
@media screen and (min-width: 781px) {
  .p-grid {
    display: grid;
    width: 86.32%;
    grid-template-columns: 1fr 1fr;
    row-gap: 3.25rem;
    column-gap: 1.25rem;
  }
}
@media screen and (min-width: 1200px) {
  .p-grid {
    width: 85%;
    grid-template-columns: 1fr 1fr 1fr;
  }
}
.p-grid__cell {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 1fr auto;
  place-items: center;
  align-items: center;
  width: 100%;
  height: 100%;
  padding: 0;
  position: relative;
  z-index: 1000;
}
.p-grid__image {
  grid-row: 1/2;
  width: 80%;
}
.p-grid__text {
  grid-row: 2/3;
  display: flex;
  flex-direction: column;
  align-items: center;
  line-height: 1.7rem;
}
.p-grid__icon {
  display: flex;
  justify-content: center;
}

@media screen and (min-width: 1200px) {
  .p-block__card {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    width: 85%;
    margin: 0 auto;
  }
}

.p-link__footer {
  cursor: pointer;
}
.p-link__footer:link {
  color: #FFFFFF;
  text-decoration: none;
}
.p-link__footer:visited {
  color: #FFFFFF;
  text-decoration: none;
}
.p-link__footer:hover {
  color: #FFFFFF;
  text-decoration: underline;
  text-decoration-color: #FFFFFF;
}
.p-link__footer:focus {
  color: #FFFFFF;
  text-decoration: none;
}
.p-link__footer:active {
  color: #FFFFFF;
  text-decoration: none;
}

.p-header__inner {
  position: relative;
  width: 100%;
}
.p-header__title {
  display: flex;
  font: 700 2.5rem "Roboto", Noto Sans JP, MyYuGothicM, YuGothic, -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, Verdana, arial, helvetica, sans-serif;
  color: #3E3E3E;
}
@media screen and (min-width: 1200px) {
  .p-header__title {
    margin: 0;
    padding: 0;
    font-size: 4rem;
    line-height: 4.6875rem;
  }
}
.p-header__title > a {
  cursor: pointer;
}
.p-header__title > a:link {
  color: #707070;
  text-decoration: none;
}
.p-header__title > a:visited {
  color: #707070;
  text-decoration: none;
}
.p-header__title > a:hover {
  color: #707070;
  text-decoration: none;
  text-decoration-color: #707070;
}
.p-header__title > a:focus {
  color: #707070;
  text-decoration: none;
}
.p-header__title > a:active {
  color: #707070;
  text-decoration: none;
}
.p-header__nav {
  display: none;
}
@media screen and (min-width: 1200px) {
  .p-header__nav {
    display: flex;
    align-items: center;
    margin-right: 1.875rem;
    width: 28rem;
    height: 5.8rem;
    right: 2.5rem;
    top: 4.4%;
    background-color: rgba(239, 239, 239, 0.8);
    position: fixed;
    z-index: 9999;
    border-radius: 10%/50%;
  }
}
.p-header__navarea {
  display: flex;
  align-items: center;
}
.p-header__menulist {
  display: flex;
  align-items: center;
  width: 27.44rem;
  gap: 8.71%;
  position: fixed;
  top: unset;
  right: 2.8rem;
  font-family: "M PLUS 1p", Noto Sans JP, MyYuGothicM, YuGothic, -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, Verdana, arial, helvetica, sans-serif;
}
.p-header__logo {
  position: absolute;
  left: 0.625rem;
  top: 1rem;
  height: auto;
  width: clamp(1rem, 66vw, 18rem);
}
@media screen and (min-width: 781px) {
  .p-header__logo {
    left: 2rem;
    top: 1.5rem;
  }
}
@media screen and (min-width: 1200px) {
  .p-header__logo {
    left: 4rem;
    top: -3.7rem;
    width: clamp(1rem, 66vw, 24rem);
  }
}
.p-header__logo--area {
  position: relative;
}

.p-card {
  width: 100%;
  margin: 0 auto;
  height: 100%;
  display: flex;
  align-items: center;
  flex-direction: column;
  padding: 8% 0;
  position: relative;
  z-index: -1;
}
@media screen and (min-width: 1200px) {
  .p-card {
    padding: 5% 0;
  }
}

.p-swiper {
  width: auto;
  height: auto;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
}
.p-swiper__wrapper {
  /* wrapperのサイズを調整 */
  width: 100%;
  height: 100%;
}
.p-swiper__slide {
  /* スライドのサイズを調整、中身のテキスト配置調整、背景色 */
  color: #ffffff;
  width: 100%;
  height: 100%;
  text-align: center;
  line-height: 300px;
}
.p-swiper__slide:nth-child(3n+1) {
  /*1、4、7、3n+1枚目の背景色 */
  background-color: #3E3E3E;
}
.p-swiper__slide:nth-child(3n+2) {
  /*2、5、8、3n+2枚目の背景色 */
  background-color: #707070;
}
.p-swiper__slide:nth-child(3n+3) {
  /*3、6、9、3n+3枚目の背景色 */
  background-color: rgba(188, 186, 186, 0.8);
}
.p-swiper__slide img {
  max-width: 90%;
  max-height: 80vh;
  object-fit: contain;
  display: block;
  margin: 0 auto;
}

.swiper-slide {
  display: flex !important;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  aspect-ratio: 1/1;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
.swiper-slide img {
  width: 80% !important;
  position: absolute;
  aspect-ratio: 1/1;
}
@media screen and (min-width: 1200px) {
  .swiper-slide img {
    width: 45.25% !important;
  }
}

.swiper-button-next {
  right: 0rem !important;
}
@media screen and (min-width: 1200px) {
  .swiper-button-next {
    right: 10px;
  }
}
.swiper-button-next::after {
  color: #FFFFFF !important;
  font-size: 1.875rem !important;
}
@media screen and (min-width: 1200px) {
  .swiper-button-next::after {
    font-size: 2.75rem !important;
  }
}

.swiper-button-prev {
  left: 0rem !important;
}
@media screen and (min-width: 1200px) {
  .swiper-button-prev {
    left: 10px;
  }
}
.swiper-button-prev::after {
  color: #FFFFFF !important;
  font-size: 1.875rem !important;
}
@media screen and (min-width: 1200px) {
  .swiper-button-prev::after {
    font-size: 2.75rem !important;
  }
}

.swiper-pagination-bullets {
  bottom: 1.7% !important;
  position: absolute;
}
@media screen and (min-width: 1200px) {
  .swiper-pagination-bullets {
    bottom: 22.7% !important;
  }
}
.swiper-pagination-bullet {
  --swiper-theme-color: white;
}

.swiper-scrollbar {
  display: none;
}

.p-slide__in {
  opacity: 0;
  transform: translateY(100px);
  visibility: hidden;
}

.p-modal__portfolio {
  position: fixed;
  width: 100%;
  height: auto;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  background: rgba(0, 0, 0, 0.7);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 9999;
  opacity: 0;
  transition: opacity 0.4s ease, transform 0.4s ease;
  visibility: hidden;
  pointer-events: none;
  overflow: hidden;
  touch-action: none;
}
@media screen and (min-width: 1200px) {
  .p-modal__portfolio {
    height: 100%;
    aspect-ratio: unset;
  }
}
.p-modal__portfolio.is-open {
  opacity: 1;
  pointer-events: auto;
  visibility: visible;
  overflow: hidden;
}
.p-modal__content {
  width: 100%;
  height: 100vh;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  transform: scale(0.8);
  transition: transform 0.4s ease;
  touch-action: pan-x pan-y;
}
.p-modal__portfolio.is-open .p-modal__content {
  transform: scale(1);
}
.p-modal__close {
  position: absolute;
  top: 0;
  right: 0;
  font-size: clamp(4rem, 4.7vw, 20rem);
  width: 6.5rem;
  height: 10.5rem;
  z-index: 100000000;
  background: transparent;
  border: none;
  color: white;
  cursor: pointer;
}
@media screen and (min-width: 1200px) {
  .p-modal__close {
    top: 0;
    right: 8.5rem;
  }
}

.js-open-modal {
  position: relative;
  z-index: 99999999999999;
  cursor: pointer;
  transition: 0.3s;
}
.js-open-modal:hover {
  transform: scale(1.08);
}

body.modal-open {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  overflow: hidden !important;
  touch-action: none;
}

.p-title__hero {
  display: flex;
  align-items: center;
  padding-left: 6.7%;
  position: relative;
  z-index: -1;
  opacity: 0;
  visibility: hidden;
}
@media screen and (min-width: 781px) {
  .p-title__hero {
    padding-left: 10.3%;
  }
}
@media screen and (min-width: 1200px) {
  .p-title__hero {
    padding-left: 5.5%;
  }
}
.p-title__grid--area {
  grid-row: 2/3;
}

.p-grid-profile {
  display: grid;
  width: 85%;
  align-items: center;
  grid-template-columns: 1fr;
  grid-template-rows: auto 1fr;
  min-height: auto;
  font-weight: 400;
}
@media screen and (min-width: 1200px) {
  .p-grid-profile {
    width: 80%;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto 1fr;
    row-gap: 5rem;
  }
}
.p-grid-profile__cell--image {
  grid-row: 1/2;
  justify-self: center;
  margin-bottom: 4.84rem;
  object-fit: cover;
  object-position: 50% 13%;
}
@media screen and (min-width: 1200px) {
  .p-grid-profile__cell--image {
    justify-self: right;
    grid-row: 2/3;
    grid-column: 1/2;
    margin-top: 4rem;
    margin-right: 20%;
  }
}
.p-grid-profile__cell--textarea {
  grid-row: 2/3;
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: auto auto;
}
@media screen and (min-width: 1200px) {
  .p-grid-profile__cell--textarea {
    line-height: 2.68rem;
    justify-self: center;
    grid-column: 1/3;
    grid-row: 1/2;
  }
}
.p-grid-profile__cell--textarea-text {
  grid-row: 1/2;
  height: auto;
}
@media screen and (min-width: 1200px) {
  .p-grid-profile__cell--textarea-text {
    grid-column: 1/3;
    padding: 0 0 0 35.2%;
    margin: 0;
  }
}
.p-grid-profile__cell--textarea-name {
  grid-row: 2/3;
}
.p-grid-profile__cell--textarea2 {
  line-height: 1.9rem;
}
@media screen and (min-width: 1200px) {
  .p-grid-profile__cell--textarea2 {
    grid-column: 2/3;
    grid-row: 2/3;
    line-height: 2.78rem;
  }
}

.p-contact {
  display: flex;
  flex-direction: column;
  width: 80.3%;
  row-gap: 1rem;
}
@media screen and (min-width: 781px) {
  .p-contact {
    width: 36.5rem;
    max-width: 89.3%;
  }
}
.p-contact__textarea {
  width: 80.3%;
}

#smooth-content {
  padding-top: 7rem;
  overscroll-behavior: contain;
  min-height: 100vh;
  height: auto;
  overflow-y: auto;
}
@media screen and (min-width: 1200px) {
  #smooth-content {
    padding-top: 13rem;
  }
}

.p-smooth__background {
  position: relative;
  background-color: #efefef;
  z-index: 1;
}
.p-smooth__background::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url("./background-CtVmAjYC.webp");
  background-size: contain;
  background-position: center;
  opacity: 0.55;
  z-index: -3;
}

.u-margin__center {
  margin: 0 auto;
}
.u-margin__center--large-pc {
  margin: 5rem auto;
}
@media screen and (min-width: 1200px) {
  .u-margin__center--large-pc {
    margin: 2.44rem;
  }
}
.u-margin__top {
  margin-top: 6rem;
}
.u-margin__top--small {
  margin-top: 3rem;
}
.u-margin__top--xsmall {
  margin-top: 1rem;
}
.u-margin__top--card {
  margin-top: 1rem;
}
@media screen and (min-width: 781px) {
  .u-margin__top--card {
    margin-top: 2rem;
  }
}
@media screen and (min-width: 1200px) {
  .u-margin__top--card {
    margin-top: 3rem;
  }
}
.u-margin__top--send {
  margin-top: 2.5rem;
}
.u-margin__midium--center {
  margin: 5rem auto;
}
.u-margin__bottom--card {
  margin-bottom: 3.4375rem;
}
.u-margin__bottom--contact {
  margin-bottom: 7rem;
}
.u-margin__text--card {
  margin: 0 5%;
}

.u-br__tb {
  display: inline-block;
}
@media screen and (min-width: 781px) {
  .u-br__tb {
    display: none;
  }
}

.u-width__text {
  width: 1.8rem;
}

.u-lineheight {
  line-height: 1.485rem;
}
.u-lineheight__large {
  line-height: 2.5rem;
}
@media screen and (min-width: 1200px) {
  .u-lineheight__large {
    line-height: 3rem;
  }
}

@media screen and (min-width: 1200px) {
  .u-padding__left {
    padding-left: 5.5%;
  }
}
.u-padding__left--xxsmall {
  padding-left: 0.375rem;
}

.u-weight__medium {
  font-weight: 400;
}
.u-weight__bold {
  font-weight: 700;
}

.u-text__small {
  font-size: 1.2rem;
}

.u-center__text {
  display: flex;
  justify-self: center;
}

.u-font {
  font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
}

.u-none {
  display: none;
}

.u-upper {
  text-transform: uppercase;
}