@media (max-width: 767px) {
  .cw {
    padding-left: 15px;
    padding-right: 15px
  }
}

@media (min-width: 768px) {
  .cw {
    max-width: 1280px;
    width: calc( 100% - 60px);
    margin-left: auto;
    margin-right: auto
  }
}

.row:after {
  content: " ";
  display: block;
  clear: both
}

.row .left {
  float: left;
  width: 50%
}

.row .right {
  float: right;
  width: 50%
}

@media (min-width: 768px) {
  .row:after {
    content: " ";
    display: block;
    clear: both
  }
  .row .left {
    float: left;
    width: 50%
  }
  .row .right {
    float: right;
    width: 50%
  }
}

@media (max-width: 767px) {
  .row .left {
    float: none;
    width: 100%
  }
  .row .right {
    float: none;
    width: 100%
  }
}

@media (max-width: 767px) {
  .tabletOnly {
    display: none !important
  }
  .desktopOnly {
    display: none !important
  }
  .tabletUpOnly {
    display: none !important
  }
}

@media (min-width: 768px) and (max-width: 1023px) {
  .mobileOnly {
    display: none !important
  }
  .desktopOnly {
    display: none !important
  }
}

@media (min-width: 1024px) {
  .mobileOnly {
    display: none !important
  }
  .tabletOnly {
    display: none !important
  }
  .touchOnly {
    display: none !important
  }
}

.fl {
  float: left
}

.fr {
  float: right
}

@media (min-width: 768px) {
  .flDesktop {
    float: left
  }
  .frDesotop {
    float: right
  }
}

.ac {
  text-align: center
}

.al {
  text-align: left
}

.ar {
  text-align: right
}

@media (min-width: 768px) {
  .acDesktop {
    text-align: center
  }
  .alDesktop {
    text-align: left
  }
  .arDesktop {
    text-align: right
  }
}

@media (max-width: 767px) {
  .acMobile {
    text-align: center
  }
  .alMobile {
    text-align: left
  }
  .arMobile {
    text-align: right
  }
}

.relative {
  position: relative
}

.absolute {
  position: absolute
}

.fixed {
  position: fixed
}

.cf:after {
  content: " ";
  display: block;
  clear: both
}

@media (min-width: 768px) {
  .cfDesktop:after {
    content: " ";
    display: block;
    clear: both
  }
}

@media (max-width: 767px) {
  .cfMobile:after {
    content: " ";
    display: block;
    clear: both
  }
}

.objectFit {
  object-fit: cover;
  object-position: center center;
  font-family: 'object-fit: cover; object-position: center center;';
  width: 100%;
  height: 100%
}

.objectFitContain {
  object-fit: contain;
  object-position: center center;
  font-family: 'object-fit: contain; object-position: center center;';
  width: 100%;
  height: 100%
}

.objectFitTop {
  object-fit: cover;
  object-position: center top;
  font-family: 'object-fit: cover; object-position: center top;';
  width: 100%;
  height: 100%
}

.objectFitRight {
  object-fit: cover;
  object-position: 100% center;
  font-family: 'object-fit: cover; object-position: 100% center;';
  width: 100%;
  height: 100%
}

.objectFitLeft {
  object-fit: cover;
  object-position: 100% center;
  font-family: 'object-fit: cover; object-position: 0 center;';
  width: 100%;
  height: 100%
}

.sectionTitle {
font-family: 'Noto Serif JP', serif;
    font-size: 2.5rem;
    font-weight: 700;
    text-align: center;
    margin-bottom: 36px;
    height: 32px;
}

input[type="text"], input[type="tel"], input[type="email"], textarea {
  font-size: 1.6rem
}

input[type="text"]:placeholder-shown, input[type="tel"]:placeholder-shown, input[type="email"]:placeholder-shown, textarea:placeholder-shown {
  color: #c5c5c5
}

input[type="text"]::-webkit-input-placeholder, input[type="tel"]::-webkit-input-placeholder, input[type="email"]::-webkit-input-placeholder, textarea::-webkit-input-placeholder {
  color: #c5c5c5
}

input[type="text"]::-moz-placeholder, input[type="tel"]::-moz-placeholder, input[type="email"]::-moz-placeholder, textarea::-moz-placeholder {
  color: #c5c5c5;
  opacity: 1
}

input[type="text"]:-ms-input-placeholder, input[type="tel"]:-ms-input-placeholder, input[type="email"]:-ms-input-placeholder, textarea:-ms-input-placeholder {
  color: #c5c5c5
}

.completeMessege, .loader {
  text-align: center;
  font-size: 1.6rem;
  transition: opacity ease .3s;
  display: none;
  opacity: 0
}

.completeMessege.visible, .loader.visible {
  display: block;
  opacity: 1
}

.loader {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%
}

.loader .l_loading {
  display: block;
  height: 100%;
  position: fixed;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  z-index: 30;
  background: #ffffff;
  padding: 10px
}

.loader .p_loading__container {
  display: block;
  position: relative;
  top: 50%;
  left: 50%;
  -ms-transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  text-align: center;
  z-index: 25;
  width: 64px
}

.loader .icon_loading {
  animation: loading 1.5s linear infinite
}

.loader .icon_loading .c_loading-inner {
  stroke-dashoffset: 0;
  stroke-dasharray: 300;
  stroke-width: 5;
  stroke-miterlimit: 10;
  animation: loading-circle 1.5s linear infinite;
  stroke: #1B1B1B;
  fill: transparent
}

@keyframes loading {
  0% {
    transform: rotate(0)
  }
  100% {
    transform: rotate(360deg)
  }
}

@keyframes loading-circle {
  0% {
    stroke-dashoffset: 0
  }
  100% {
    stroke-dashoffset: -600
  }
}

form.complete {
  display: none
}

.submit.off {
  pointer-events: none;
  cursor: default;
  opacity: .5
}

#contact {
   margin-top: 110px;
  transition: all ease .3s
}

#contact .sectionTitle img {
  height: 24px
}

#contact .contactWrap {
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
  text-align: center
}

#contact .contactWrap .txt {
  margin-bottom: 60px;
  transition: all ease .3s;
  display: none
}

#contact .contactWrap .txt.visible {
  display: block;
  font-size: 14px;
}

#contact .contactWrap .txtS {
  font-size: 1.3rem;
  margin-top: 50px
}

#contact .contactWrap form .formWrap {
  margin-bottom: 40px;
  text-align: left;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  flex-wrap: wrap;
  position: relative
}

#contact .contactWrap form .formWrap .fmHeadline {
  width: calc(27% - 26px);
  display: block;
  margin-right: 24px;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  padding-top: 20px
}

#contact .contactWrap form .formWrap .fmHeadline .required {
  font-size: .9rem;
  background-color: #E64B38;
  color: #fff;
  width: 50px;
  height: 20px;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center
}
#contact span.wpcf7-form-control-wrap {
    width: 73%;
	position: relative;
}
#contact .contactWrap form .formWrap .inptField {
  display: block;
  background-color: #f4f4f4;
  padding: 20px;
  width: 100%
}

#contact span.wpcf7-form-control-wrap.yourname {
  width: 400px
}

#contact .contactWrap form .formWrap .inptField.txtField {
  height: 240px;
  resize: none
}

#contact .contactWrap form .formWrap .error {
  font-size: 1.2rem;
  color: #E64B38;
  position: absolute;
  left: 27%;
  bottom: -46%
}

#contact .contactWrap form .formWrap.textareaWp .error {
  bottom: 0;
  top: 247px
}

#contact .contactWrap form .btnWrap {
  margin-top: 50px
}

#contact .contactWrap form .btnWrap .btn {
  padding-top: 0;
  width: 290px;
  height: 72px;
  font-size: 1.6rem;
  cursor: pointer;
  /* margin-left: 20px; */
}

#contact .contactWrap .company {
  width: 460px;
  margin: 0 auto;
  text-align: center
}

#contact .contactWrap .company h2 {
  font-size: 24px;
  margin-top: 3em
}

#contact .contactWrap .company .info {
  margin-top: 2.5em;
  font-size: 16px;
  line-height: 2.2
}

#contact .contactWrap .completeMessege {
  max-width: 600px;
	margin: 0 auto;
}

#contact .contactWrap .completeMessege .txt {
  margin-bottom: 40px;
}

#contact .contactWrap .completeMessege .txtS {
  margin-top: 0;
  margin-bottom: 64px;
}


@media (max-width: 767px) {
  .completeMessege, .loader {
    margin-top: 100px
  }
  #contact {
    margin-top: 44px
  }
  #contact .sectionTitle {
    text-align: left;
    margin-bottom: 22px
  }
  #contact .sectionTitle img {
    height: 19px
  }
  #contact .contactWrap {
    text-align: left
  }
  #contact .contactWrap .txt {
    margin-bottom: 32px;
    text-align: left
  }
  #contact .contactWrap .txtS {
    margin-top: 0;
    text-align: left
  }
  #contact .contactWrap form .formWrap {
    margin-bottom: 15px
  }
  #contact .contactWrap form .formWrap .fmHeadline {
    width: 100%;
    padding-top: 0;
    margin-right: 0;
    margin-bottom: 10px;
    align-items: center;
	box-sizing: border-box;
  }
  #contact .contactWrap form .formWrap .inptField,
  #contact .contactWrap form .formWrap .inptField.nameField  {
    width: 100%;
    margin-bottom: 5px;
    font-size: 14px;
    padding: 14px 20px
  }
  #contact .contactWrap form .formWrap .inptField.txtField {
    height: 168px
  }
  #contact .contactWrap form .formWrap .error {
    position: static
  }
  #contact .contactWrap form .btnWrap {
    margin-top: 35px
  }
  #contact .contactWrap form .btnWrap .btn {
    width: 100%;
	/* margin-left: 0px; */
  }
  #contact .contactWrap .company {
    width: 100%;
    margin: 0 auto;
    text-align: left;
    padding-left: 0
  }
  #contact .contactWrap .company h2 {
    font-size: 20px
  }
  #contact .contactWrap .company .info {
    font-size: 14px
  }

  #contact .contactWrap .completeMessege {
    margin-top: 56px
  }
  #contact span.wpcf7-form-control-wrap {
    width: 100%;
}
}
/*========================
　コンタクトフォーム　カスタマイズ
========================*/
div.screen-reader-response{
  display: none;
}
div.wpcf7-mail-sent-ok {
  display: none!important;
}
div.wpcf7-validation-errors,
div.wpcf7-acceptance-missing {
  display: none !important;
}
div.wpcf7-response-output {
    display: none !important;
}
.wpcf7-not-valid-tip {
    font-size: 1.2rem !important;
    color: #E64B38 !important;
    position: absolute;
    left: 2px;
    /* top: 117%; */
    bottom: -30px;
}
div.wpcf7 .ajax-loader {
    display: none !important;
}

@media (max-width: 767px){
.wpcf7-not-valid-tip{
    position: static;
}
}