@charset "UTF-8";
.fontLato {
  font-family: "Lato", sans-serif;
}

/*---------------------------------------------
共通部分
---------------------------------------------*/
body {
  font-family: "Zen Kaku Gothic New", sans-serif;
  max-width: 100%;
  overflow-x: hidden;
  background-color: #f0ece7;
}

body * {
  letter-spacing: 0.1em;
  line-height: 120%;
  color: #333;
  font-weight: 500;
}

a {
  color: #209cc6;
  text-decoration: none;
}
a:hover {
  text-decoration: none;
}

.commonWidth {
  margin: 0 auto;
}

.footerWidth {
  margin: 0 auto;
}

.noLink {
  opacity: 0.5;
  pointer-events: none;
  cursor: inherit;
}

.icoCircle {
  background: linear-gradient(157deg, #209cc6 0%, #7dc3c8 49%, #f1d3d2 100%) 0% 0% no-repeat padding-box;
  border-radius: 50%;
  display: inline-block;
}

.topTitleArea .titleJp {
  border-bottom: solid 1.5px #000000;
}
.topTitleArea .titleJp .titleJpText {
  font-weight: 700;
}

.errorText {
  text-align: center;
}

@media only screen and (max-width: 767px) {
  .wrapWidth {
    width: 92.3vw;
    margin: 0 auto;
  }
  .commonWidth {
    width: 92.3vw;
  }
  .commonWidthSp {
    width: 92.3vw;
    margin: 0 auto;
  }
  .footerWidth {
    width: 92.3vw;
    margin: 0 auto;
  }
  .icoCircle {
    width: 12px;
    height: 12px;
  }
  .topTitleArea .titleEn {
    font-size: clamp(30px, 12.82vw, 50px);
  }
  .topTitleArea .titleJp {
    padding-top: 10px;
    padding-bottom: min(9.2vw, 36px);
    padding-left: min(7.7vw, 30px);
  }
  .topTitleArea .titleJp .titleJpText {
    padding: 0 0 0 8px;
    font-size: clamp(14px, 4.1vw, 16px);
  }
  .errorText {
    font-size: clamp(14px, 4.1vw, 16px);
  }
}
@media print, screen and (min-width: 768px) {
  .wrapWidth {
    width: clamp(712px, 92.7vw, 1780px);
    margin: 0 auto;
  }
  .wrapWidthPc {
    width: clamp(712px, 92.7vw, 1780px);
    margin: 0 auto;
  }
  .commonWidth {
    width: 90vw;
    max-width: 1200px;
  }
  .commonWidthPc {
    width: 90vw;
    max-width: 1200px;
    margin: 0 auto;
  }
  .footerWidth {
    width: 78vw;
    max-width: 1500px;
  }
  .icoCircle {
    width: 16px;
    height: 16px;
  }
  .topTitleArea .titleEn {
    font-size: min(7.8vw, 150px);
  }
  .topTitleArea .titleJp {
    padding-bottom: min(5.2vw, 100px);
  }
  .topTitleArea .titleJp .titleJpText {
    padding: 0 0 0 20px;
    font-size: clamp(15px, 1.67vw, 24px);
  }
  .errorText {
    font-size: clamp(14px, 1.39vw, 20px);
  }
}
/*---------------------------------------------
secHeader
---------------------------------------------*/
/*---------------------------------------------
secFooter
---------------------------------------------*/
.secFooter {
  background-color: #191919;
  color: #ffffff;
}

/*---------------------------------------------
テキスト分割アニメーション
---------------------------------------------*/
.txtSplitAnim {
  position: relative;
  opacity: 0;
  overflow: hidden;
}
.txtSplitAnim.spanComp {
  opacity: 1;
}
.txtSplitAnim span {
  position: relative;
  opacity: 0;
  top: 1.5em;
  transition: opacity 1s, top 0.8s;
  transition-timing-function: cubic-bezier(0, 1.21, 0.39, 1.07);
}
.txtSplitAnim.animated span {
  opacity: 1;
  top: 0em;
}

/*---------------------------------------------
エラー系テキスト
---------------------------------------------*/
.commonErrorText {
  line-height: 200%;
  text-align: justify;
}

@media only screen and (max-width: 767px) {
  .commonErrorText {
    font-size: clamp(14px, 4.61vw, 18px);
  }
}
@media only screen and (min-width: 768px) {
  .commonErrorText {
    font-size: clamp(14px, 1.53vw, 22px);
  }
}
/*---------------------------------------------
制作実績(一覧)
---------------------------------------------*/
#mainContent {
  width: 100%;
}

#pageContent {
  width: 430px;
  position: absolute;
  right: 0;
  left: 0;
  margin: 0 auto;
  background-color: #f0ece7;
}
#pageContent .secFooter {
  width: 100%;
}
#pageContent .secFooter .wrapWidth {
  width: 100%;
}

.sideform {
  position: fixed;
  right: 0;
  top: 0;
  background-color: #fff;
  min-height: 100lvh;
  height: 100%;
  overflow-y: scroll;
  width: calc(50% - 215px);
  padding: 40px 0;
}
.sideform .wrap {
  max-width: 344px;
  width: 90%;
  margin: auto;
  display: block;
}
.sideform .wrap h2 {
  font-size: 20px;
  letter-spacing: 0.05em;
  margin-bottom: 20px;
  text-align: center;
}
.sideform .wrap .flexBox {
  padding-bottom: 16px;
}
.sideform .wrap .flexBox .txtArea {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 9px;
}
.sideform .wrap .flexBox .txtArea .ttl {
  font-size: 15px;
}
.sideform .wrap .flexBox .txtArea .required {
  background-color: #333;
  font-size: 10px;
  border-radius: 9px;
  height: 18px;
  width: 38px;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
}
.sideform .wrap .flexBox .inputArea input[type=text],
.sideform .wrap .flexBox .inputArea input[type=date],
.sideform .wrap .flexBox .inputArea input[type=email],
.sideform .wrap .flexBox .inputArea input[type=tel] {
  width: 100%;
  display: block;
  min-height: 30px;
  font-size: 16px;
  padding: 4px;
  accent-color: #dcba62;
  box-shadow: 0px 0px 4px 0px rgba(0, 0, 0, 0.3);
}
.sideform .wrap .flexBox .inputArea input[type=text]:focus,
.sideform .wrap .flexBox .inputArea input[type=date]:focus,
.sideform .wrap .flexBox .inputArea input[type=email]:focus,
.sideform .wrap .flexBox .inputArea input[type=tel]:focus {
  outline: 2px solid #dcba62;
}
.sideform .wrap .flexBox .inputArea input[type=text]::-moz-selection, .sideform .wrap .flexBox .inputArea input[type=date]::-moz-selection, .sideform .wrap .flexBox .inputArea input[type=email]::-moz-selection, .sideform .wrap .flexBox .inputArea input[type=tel]::-moz-selection {
  color: #dcba62;
}
.sideform .wrap .flexBox .inputArea input[type=text]::selection,
.sideform .wrap .flexBox .inputArea input[type=date]::selection,
.sideform .wrap .flexBox .inputArea input[type=email]::selection,
.sideform .wrap .flexBox .inputArea input[type=tel]::selection {
  color: #dcba62;
}
.sideform .wrap .flexBox .inputArea .wpcf7-radio {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 12px;
  accent-color: #333;
}
.sideform .wrap .flexBox .inputArea .wpcf7-radio .wpcf7-list-item {
  margin: 0;
}
.sideform .wrap .flexBox .wpcf7-not-valid-tip {
  padding-top: 4px;
  font-size: 13px;
}
.sideform .wrap input[type=submit] {
  background-color: #3b3431;
  padding: 5px;
  height: 54px;
  max-width: 240px;
  width: 90%;
  align-items: center;
  display: block;
  justify-content: left;
  align-items: center;
  gap: 6px;
  margin: 20px auto 0;
  border-radius: 27px;
  font-weight: 700;
  font-size: 17px;
  letter-spacing: 0.05em;
  color: #fff;
  transition: 0.3s;
  justify-content: center;
}
.sideform .wrap input[type=submit]::before {
  display: none;
}
.sideform .wrap input[type=submit]:hover {
  transition: 0.3s;
  background-color: #dcba62;
  color: #fff;
}

.ttl {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
  margin-bottom: 16px;
}
.ttl h2 {
  font-size: 22px;
  letter-spacing: 0.05em;
  background-color: #f0ece7;
  display: block;
  z-index: 2;
  font-weight: 500;
}
.ttl span {
  display: flex;
  align-items: baseline;
  gap: 5px;
  background-color: #f0ece7;
  font-family: "Lato", sans-serif;
  font-size: 16px;
  letter-spacing: 0.2em;
  z-index: 2;
  margin-bottom: 2px;
  text-transform: uppercase;
}
.ttl span::before {
  content: "";
  display: block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background-color: #333;
}
.ttl::after {
  position: absolute;
  content: "";
  width: 80%;
  height: 1px;
  background-color: #333;
  z-index: 1;
}

.wrap {
  padding-left: 20px;
  padding-right: 20px;
  padding-top: 54px;
}

.baseBtn {
  background-color: #3b3431;
  padding: 5px;
  height: 54px;
  max-width: 250px;
  align-items: center;
  display: flex;
  justify-content: left;
  align-items: center;
  gap: 6px;
  margin: 20px 0 0;
  border-radius: 27px;
  font-weight: 700;
  font-size: 17px;
  letter-spacing: 0.05em;
  color: #fff;
  transition: 0.3s;
}
.baseBtn::before {
  content: "TAP";
  font-family: "Lato", sans-serif;
  font-weight: 700;
  font-size: 14px;
  color: #d4bc7c;
  letter-spacing: 0.2em;
  height: 44px;
  width: 62px;
  background-color: #fff;
  border-radius: 22px;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding-left: 4px;
}
.baseBtn.baseBtnY {
  background-color: #fff;
  color: #3b3431;
}
.baseBtn.baseBtnY::before {
  color: #fff;
  background-color: #d4bc7c;
}
.baseBtn:hover {
  transition: 0.3s;
  background-color: #d4bc7c;
  color: #fff;
}
.baseBtn:hover.baseBtnY {
  background-color: #d4bc7c;
  color: #fff;
}
.baseBtn:hover::before {
  color: #fff;
  background-color: #d4bc7c;
}
.baseBtn.baseBtnNone {
  justify-content: center;
}
.baseBtn.baseBtnNone::before {
  display: none;
}
.baseBtn.baseBtnNone:hover {
  transition: 0.3s;
  background-color: #3b3431;
  color: #fff;
}

.sp {
  display: none;
}

@media only screen and (max-width: 1000px) {
  #pageContent {
    left: 0;
    right: 0;
    margin: auto;
    max-width: initial;
  }
}
@media only screen and (max-width: 700px) {
  .sideform {
    display: none;
  }
  #pageContent {
    right: 0;
    width: 100%;
    max-width: 430px;
  }
  .sp {
    display: flex;
  }
  .pc {
    display: none;
  }
}
.bg {
  width: 100%;
  min-height: 100lvh;
  height: 100%;
  background-image: url(../images/bg-l.jpg);
  background-color: #f0ece7;
  background-size: cover;
  background-position: center;
  position: fixed;
  left: 0;
  top: 0;
  overflow-y: scroll;
  z-index: -1;
}/*# sourceMappingURL=common.css.map */