@charset "UTF-8";
/* 非表示 */
.is-hide {
  display: none;
}

/* ローディング画面をフェードアウト */
.fadeout-bg {
  -webkit-transition-property: opacity;
  transition-property: opacity;
  -webkit-transition-delay: .9s;
          transition-delay: .9s;
  -webkit-transition-duration: .8s;
          transition-duration: .8s;
  opacity: 0;
  pointer-events: none;
}

/* ローダーをフェードアウト */
.fadeout-loader {
  -webkit-transition-property: opacity;
  transition-property: opacity;
  -webkit-transition-delay: .9s;
          transition-delay: .9s;
  -webkit-transition-duration: .3s;
          transition-duration: .3s;
  opacity: 0;
  pointer-events: none;
}

/* ローディング画面 */
#loader-bg {
  background: #3e3a3a;
  height: 100%;
  left: 0;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 100;
  background-image: url("/wp-content/themes/laura/assets/img/feathers.svg");
  background-size: contain;
}

#loader {
  height: 120px;
  left: 50%;
  margin-left: -60px;
  margin-top: -60px;
  position: fixed;
  top: 50%;
  width: 120px;
}

#loader img {
  display: inline-block;
  width: 100%;
  margin: 0 auto;
  -webkit-animation: five 2.5s 1 cubic-bezier(0.64, -0.36, 0.1, 1);
          animation: five 2.5s 1 cubic-bezier(0.64, -0.36, 0.1, 1);
}

.shape-container {
  -webkit-animation: five-container 2.5s 1 cubic-bezier(0.64, -0.36, 0.1, 2);
          animation: five-container 2.5s 1 cubic-bezier(0.64, -0.36, 0.1, 2);
  position: absolute;
  left: calc(50% - 4em);
  top: calc(50% - 4em);
}

/* ローディングアニメーション */
@-webkit-keyframes sk-scaleout {
  0% {
    -webkit-transform: scale(0);
            transform: scale(0);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
@keyframes sk-scaleout {
  0% {
    -webkit-transform: scale(0);
            transform: scale(0);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}

@-webkit-keyframes five {
  0%, 15% {
    opacity: 0;
    -webkit-transform: translateX(-12em);
            transform: translateX(-12em);
  }
  15%, 25% {
    -webkit-transform: translateX(-12em);
            transform: translateX(-12em);
    opacity: 1;
  }
  85%, 90% {
    -webkit-transform: translateX(12em);
            transform: translateX(12em);
    opacity: 1;
  }
  100% {
    -webkit-transform: translateX(12em);
            transform: translateX(12em);
    opacity: 1;
  }
}

@keyframes five {
  0%, 15% {
    opacity: 0;
    -webkit-transform: translateX(-12em);
            transform: translateX(-12em);
  }
  15%, 25% {
    -webkit-transform: translateX(-12em);
            transform: translateX(-12em);
    opacity: 1;
  }
  85%, 90% {
    -webkit-transform: translateX(12em);
            transform: translateX(12em);
    opacity: 1;
  }
  100% {
    -webkit-transform: translateX(12em);
            transform: translateX(12em);
    opacity: 1;
  }
}

@-webkit-keyframes five-container {
  0%, 35% {
    -webkit-transform: none;
            transform: none;
  }
  50%, 60% {
    -webkit-transform: skewX(20deg);
            transform: skewX(20deg);
  }
  90%, 100% {
    -webkit-transform: none;
            transform: none;
  }
}

@keyframes five-container {
  0%, 35% {
    -webkit-transform: none;
            transform: none;
  }
  50%, 60% {
    -webkit-transform: skewX(20deg);
            transform: skewX(20deg);
  }
  90%, 100% {
    -webkit-transform: none;
            transform: none;
  }
}

html {
  line-height: 0;
  scrollbar-width: none;
}

body {
  color: #333333;
  background-color: #ffffff;
  margin: 0;
  padding: 0;
  font-family: lemonde-journal, a-otf-ud-reimin-pr6n, a-otf-futo-min-a101-pr6n,serif;
  width: 100vw;
}

ul, li {
  list-style: none;
  list-style: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 1% 2%;
}

body {
  font-size: 62.5%;
}

h1 {
  font-size: 5rem;
  line-height: 1;
  letter-spacing: 0.02em;
  font-family: lemonde-journal;
}

@media only screen and (max-width: 320px) {
  h1 {
    font-size: 2rem;
  }
}

@media only screen and (max-width: 767px) {
  h1 {
    font-size: 2rem;
    font-weight: bold;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  h1 {
    font-size: 2.9rem;
    font-weight: bold;
  }
}

@media (min-width: 1100px) and (max-width: 1600px) {
  h1 {
    font-size: 4rem;
  }
}

h2 {
  font-family: lemonde-journal;
  font-size: 2.5rem;
}

@media only screen and (max-width: 320px) {
  h2 {
    font-size: 1.6rem;
    font-weight: bold;
  }
}

@media only screen and (max-width: 767px) {
  h2 {
    font-size: 1.8rem;
    font-weight: bold;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  h2 {
    font-size: 2.1rem;
    font-weight: bold;
  }
}

h3 {
  font-family: a-otf-futo-min-a101-pr6n;
  font-size: 1.5rem;
  line-height: 1.7;
  font-weight: bold;
}

@media only screen and (max-width: 320px) {
  h3 {
    font-size: 0.8rem;
  }
}

@media only screen and (max-width: 767px) {
  h3 {
    font-size: 0.95rem;
    font-weight: bold;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  h3 {
    font-size: 1.3rem;
    font-weight: bold;
  }
}

p, a {
  font-size: 1.2rem;
  font-family: a-otf-ud-reimin-pr6n;
  line-height: 2.3;
  display: block;
  -webkit-margin-before: 0;
          margin-block-start: 0;
  -webkit-margin-after: 0;
          margin-block-end: 0;
  -webkit-margin-start: 0px;
          margin-inline-start: 0px;
  -webkit-margin-end: 0px;
          margin-inline-end: 0px;
}

@media only screen and (max-width: 320px) {
  p, a {
    font-size: 0.65rem;
  }
}

@media only screen and (max-width: 767px) {
  p, a {
    font-size: 0.8rem;
    line-height: 2.2;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  p, a {
    font-size: 1.2rem;
    line-height: 2.4;
  }
}

.copy {
  display: block;
  position: fixed;
  -webkit-writing-mode: vertical-lr;
      -ms-writing-mode: tb-lr;
          writing-mode: vertical-lr;
  white-space: nowrap;
  top: 50vh;
  left: 3%;
  font-size: 1rem;
  z-index: 1;
  color: #3e3a3a;
}

@media only screen and (max-width: 767px) {
  .copy {
    position: absolute;
    top: 65vh;
    font-size: 0.6rem;
    color: white;
    left: 5%;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  .copy {
    position: absolute;
    top: 30vh;
    font-size: 0.8rem;
    color: white;
    left: 5%;
  }
}

#gearbox {
  position: fixed;
  top: 2%;
  right: -5%;
  z-index: 10;
  -webkit-transition: -webkit-transform 0.3s ease-out;
  transition: -webkit-transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
  -webkit-filter: drop-shadow(1.5px 1.5px 1.5px rgba(0, 0, 0, 0.6));
          filter: drop-shadow(1.5px 1.5px 1.5px rgba(0, 0, 0, 0.6));
}

@media only screen and (max-width: 767px) {
  #gearbox {
    top: 0;
    right: -10%;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  #gearbox {
    right: -8%;
  }
}

#gearbox:hover {
  -webkit-transform: scale(1.1);
  transform: scale(1.1);
  cursor: pointer;
  -webkit-filter: drop-shadow(4px 4px 4px rgba(0, 0, 0, 0.4));
          filter: drop-shadow(4px 4px 4px rgba(0, 0, 0, 0.4));
}

.form__wrap {
  width: 100%;
  max-width: 900px;
  /*フォームの最大幅*/
  margin: 5% auto;
}

.wpcf7 .template03 {
  color: #333;
  font-size: 14px;
}

.wpcf7 .template03 a {
  margin: 0;
  padding: 0;
  text-decoration: underline;
  color: inherit;
  -webkit-transition: opacity .25s;
  transition: opacity .25s;
}

.wpcf7 .template03 a:hover {
  opacity: .5;
  -webkit-transition: opacity .25s;
  transition: opacity .25s;
}

.wpcf7 .template03 div.form__row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 0;
}

.wpcf7 .template03 div.form__row.row-privacy,
.wpcf7 .template03 div.form__row.row-submit {
  display: block;
  margin-top: 1em;
  text-align: center;
}

.wpcf7 .template03 div.form__row.row-privacy .form__body,
.wpcf7 .template03 div.form__row.row-submit .form__body {
  width: 100%;
}

.wpcf7 .template03 div.form__row.row-message {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}

.wpcf7 p.form__label,
.wpcf7 p.form__body {
  margin: 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.wpcf7 .template03 p.form__label {
  width: 36%;
  padding: 1em;
}

.wpcf7 .template03 p.form__body {
  width: 64%;
  padding: 1em;
}

.wpcf7 .template03 p.form__label label {
  position: relative;
  padding-left: 44px;
}

.wpcf7 .template03 p.form__label label::after {
  content: "任意";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 36px;
  margin: 0;
  padding: 0 5px;
  border-radius: 0;
  background-color: #f6f6f6;
  color: #999;
  font-size: 11px;
  text-align: center;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.wpcf7 .template03 p.form__label.is-required label {
  position: relative;
}

.wpcf7 .template03 p.form__label.is-required label::after {
  content: "必須";
  display: block;
  position: absolute;
  width: 36px;
  margin: 0;
  padding: 0 5px;
  border: 1px solid #e00022;
  background-color: #fff;
  color: #e00022;
  font-size: 11px;
  text-align: center;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

/* テキストフィールド */
.wpcf7 .template03 input[type=text],
.wpcf7 .template03 input[type=tel],
.wpcf7 .template03 input[type=email],
.wpcf7 .template03 textarea {
  width: 100%;
  margin: 0;
  padding: .5em 1em;
  border: 1px solid #3e3a3a;
  border-left: 4px solid #3e3a3a;
  border-radius: 0;
  -webkit-box-shadow: none;
          box-shadow: none;
  background-color: #fff;
  color: inherit;
  font-family: inherit;
  font-weight: inherit;
  font-size: inherit;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

/* テキストフィールド placeholder */
.wpcf7 .template03 input[type=text]::-webkit-input-placeholder,
.wpcf7 .template03 input[type=tel]::-webkit-input-placeholder,
.wpcf7 .template03 input[type=email]::-webkit-input-placeholder,
.wpcf7 .template03 input[type=url]::-webkit-input-placeholder,
.wpcf7 .template03 input[type=date]::-webkit-input-placeholder,
.wpcf7 .template03 input[type=number]::-webkit-input-placeholder,
.wpcf7 .template03 textarea::-webkit-input-placeholder {
  color: #ccc;
}
.wpcf7 .template03 input[type=text]:-ms-input-placeholder,
.wpcf7 .template03 input[type=tel]:-ms-input-placeholder,
.wpcf7 .template03 input[type=email]:-ms-input-placeholder,
.wpcf7 .template03 input[type=url]:-ms-input-placeholder,
.wpcf7 .template03 input[type=date]:-ms-input-placeholder,
.wpcf7 .template03 input[type=number]:-ms-input-placeholder,
.wpcf7 .template03 textarea:-ms-input-placeholder {
  color: #ccc;
}
.wpcf7 .template03 input[type=text]::-ms-input-placeholder,
.wpcf7 .template03 input[type=tel]::-ms-input-placeholder,
.wpcf7 .template03 input[type=email]::-ms-input-placeholder,
.wpcf7 .template03 input[type=url]::-ms-input-placeholder,
.wpcf7 .template03 input[type=date]::-ms-input-placeholder,
.wpcf7 .template03 input[type=number]::-ms-input-placeholder,
.wpcf7 .template03 textarea::-ms-input-placeholder {
  color: #ccc;
}
.wpcf7 .template03 input[type=text]::placeholder,
.wpcf7 .template03 input[type=tel]::placeholder,
.wpcf7 .template03 input[type=email]::placeholder,
.wpcf7 .template03 input[type=url]::placeholder,
.wpcf7 .template03 input[type=date]::placeholder,
.wpcf7 .template03 input[type=number]::placeholder,
.wpcf7 .template03 textarea::placeholder {
  color: #ccc;
}

.wpcf7 .template03 input[type=text]:-ms-input-placeholder,
.wpcf7 .template03 input[type=tel]:-ms-input-placeholder,
.wpcf7 .template03 input[type=email]:-ms-input-placeholder,
.wpcf7 .template03 input[type=url]:-ms-input-placeholder,
.wpcf7 .template03 input[type=date]:-ms-input-placeholder,
.wpcf7 .template03 input[type=number]:-ms-input-placeholder,
.wpcf7 .template03 textarea:-ms-input-placeholder {
  color: #ccc;
}

.wpcf7 .template03 input[type=text]::-ms-input-placeholder,
.wpcf7 .template03 input[type=tel]::-ms-input-placeholder,
.wpcf7 .template03 input[type=email]::-ms-input-placeholder,
.wpcf7 .template03 input[type=url]::-ms-input-placeholder,
.wpcf7 .template03 input[type=date]::-ms-input-placeholder,
.wpcf7 .template03 input[type=number]::-ms-input-placeholder,
.wpcf7 .template03 textarea::-ms-input-placeholder {
  color: #ccc;
}

/* テキストフィールド フォーカス時 */
.wpcf7 .template03 input[type=text]:focus,
.wpcf7 .template03 input[type=tel]:focus,
.wpcf7 .template03 input[type=email]:focus,
.wpcf7 .template03 input[type=url]:focus,
.wpcf7 .template03 input[type=date]:focus,
.wpcf7 .template03 input[type=number]:focus,
.wpcf7 .template03 textarea:focus {
  outline: 0;
  -webkit-box-shadow: 2px 3px 2px 1px rgba(205, 205, 205, 0.7);
          box-shadow: 2px 3px 2px 1px rgba(205, 205, 205, 0.7);
}

/* チェックボックス */
.wpcf7 .template03 input[type=checkbox] {
  display: none;
}

.wpcf7 .template03 input[type=checkbox] + span {
  cursor: pointer;
  position: relative;
  margin: 0;
  padding: 0 1em 0 1.8em;
  font-size: inherit;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-transition: opacity .25s ease;
  transition: opacity .25s ease;
}

.wpcf7 .template03 input[type=checkbox] + span::before {
  content: "";
  opacity: 1;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 1.24em;
  height: 1.24em;
  border: 1px solid #3e3a3a;
  border-radius: 0;
  background-color: #fff;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-transition: opacity .25s ease;
  transition: opacity .25s ease;
}

.wpcf7 .template03 input[type=checkbox] + span::after {
  content: "";
  opacity: 0;
  display: block;
  position: absolute;
  top: 0.15em;
  left: 0.44em;
  width: 0.4em;
  height: .8em;
  border-bottom: 3px solid #3e3a3a;
  border-right: 3px solid #3e3a3a;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-transform: rotate(40deg);
          transform: rotate(40deg);
  -webkit-transition: all .25s;
  transition: all .25s;
}

.wpcf7 .template03 input[type=checkbox]:checked + span {
  color: #3e3a3a;
  -webkit-transition: all .25s ease;
  transition: all .25s ease;
}

.wpcf7 .template03 input[type=checkbox]:checked + span::before {
  opacity: 0;
}

.wpcf7 .template03 input[type=checkbox]:checked + span::after {
  opacity: 1;
  border-bottom: 2px solid #3e3a3a;
  border-right: 2px solid #3e3a3a;
  -webkit-transform: rotate(400deg);
          transform: rotate(400deg);
  -webkit-transition: all .25s;
  transition: all .25s;
}

/* ラジオボタン */
.wpcf7 .template03 input[type=radio] {
  display: none;
}

.wpcf7 .template03 input[type=radio] + span {
  cursor: pointer;
  position: relative;
  padding: 0 1em 0 1.8em;
  font-size: inherit;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-transition: opacity .25s ease;
  transition: opacity .25s ease;
}

.wpcf7 .template03 input[type=radio] + span::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 1em;
  height: 1em;
  border: 1px solid #ccc;
  border-radius: 50%;
  background-color: #fff;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-transition: opacity .25s ease;
  transition: opacity .25s ease;
}

.wpcf7 .template03 input[type=radio] + span::after {
  content: "";
  display: block;
  opacity: 0;
  position: absolute;
  border: 1px solid #ccc;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-transition: opacity .25s ease;
  transition: opacity .25s ease;
}

.wpcf7 .template03 input[type=radio]:checked + span {
  color: #3e3a3a;
  -webkit-transition: all .25s ease;
  transition: all .25s ease;
}

.wpcf7 .template03 input[type=radio]:checked + span::before {
  background-color: transparent;
}

.wpcf7 .template03 input[type=radio]:checked + span::after {
  opacity: 1;
  top: 0;
  left: 0;
  width: 1em;
  height: 1em;
  border: 2px solid #3e3a3a;
  border-radius: 50%;
  background-color: transparent;
  -webkit-animation-name: border-circle;
          animation-name: border-circle;
  -webkit-animation-duration: .25s;
          animation-duration: .25s;
  -webkit-transition: opacity .25s ease;
  transition: opacity .25s ease;
}

/* セレクト */
.wpcf7 .template03 span.select-wrap {
  position: relative;
  width: 250px;
  margin: 0;
}

.wpcf7 .template03 select {
  cursor: pointer;
  width: 250px;
  max-width: 100%;
  margin: 0;
  padding: .5em 1.8em .5em 1em;
  border: 1px solid #3e3a3a;
  border-left: 4px solid #3e3a3a;
  border-radius: 0;
  -webkit-box-shadow: none;
          box-shadow: none;
  background-color: #fff;
  color: inherit;
  font-size: inherit;
  line-height: 1;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-transition: border-color 0.2s ease, outline 0.2s ease;
  transition: border-color 0.2s ease, outline 0.2s ease;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

.wpcf7 .template03 select::-ms-expand {
  display: none;
}

.wpcf7 .template03 span.select-wrap::after {
  content: "";
  pointer-events: none;
  position: absolute;
  display: block;
  width: .4em;
  height: .4em;
  top: calc(50% + .1em);
  right: .8em;
  margin-top: -3px;
  border-bottom: 1px solid #b3b3b3;
  border-right: 1px solid #b3b3b3;
  -webkit-transform: rotate(45deg) translateY(-50%);
          transform: rotate(45deg) translateY(-50%);
  -webkit-transform-origin: 50% 0;
          transform-origin: 50% 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.wpcf7 .template03 select:focus {
  outline: 0;
  -webkit-box-shadow: 2px 3px 2px 1px rgba(205, 205, 205, 0.7);
          box-shadow: 2px 3px 2px 1px rgba(205, 205, 205, 0.7);
}

.wpcf7 .template03 span.select-wrap:focus-within::after {
  border-bottom: 1px solid #3e3a3a;
  border-right: 1px solid #3e3a3a;
}

/* 送信ボタン */
.wpcf7 .template03 .submit-btn {
  overflow: hidden;
  position: relative;
  width: 320px;
  height: 65px;
  max-width: 100%;
  margin: 0;
  padding: 0;
  margin-left: auto;
  margin-right: auto;
}

.wpcf7 .template03 input[type="submit"] {
  cursor: pointer;
  position: relative;
  width: 320px;
  height: 65px;
  max-width: 100%;
  padding: 18px;
  border-radius: 0;
  -webkit-box-shadow: none;
          box-shadow: none;
  border: 1px solid #3e3a3a;
  background-color: transparent;
  color: #fff;
  font-size: 18px;
  text-align: center;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-transition: opacity .25s;
  transition: opacity .25s;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  z-index: 10;
}

.wpcf7 .template03 input[type="submit"] ~ div.submit-bg {
  position: absolute;
  top: 0;
  left: 0;
  margin: 0;
  padding: 0;
  width: 200%;
  height: 65px;
  background-color: #fff;
  background-image: -webkit-gradient(linear, left top, right top, from(#3e3a3a), to(#3e3a3a));
  background-image: linear-gradient(90deg, #3e3a3a, #3e3a3a);
  background-position: 100% 0;
  background-size: 50% 100%;
  background-repeat: no-repeat;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  -webkit-transition: -webkit-transform .25s;
  transition: -webkit-transform .25s;
  transition: transform .25s;
  transition: transform .25s, -webkit-transform .25s;
  z-index: 1;
}

.wpcf7 .template03 input[type="submit"]:hover {
  color: #3e3a3a;
}

.wpcf7 .template03 input[type="submit"]:hover ~ div.submit-bg {
  -webkit-transform: translateX(-4px);
          transform: translateX(-4px);
  -webkit-transition: -webkit-transform .25s;
  transition: -webkit-transform .25s;
  transition: transform .25s;
  transition: transform .25s, -webkit-transform .25s;
}

.wpcf7 .template03 input[type="submit"]:focus {
  outline: 0;
}

.wpcf7 .template03 input[type="submit"]:disabled {
  cursor: not-allowed;
  -webkit-box-shadow: none !important;
          box-shadow: none !important;
  border: 1px solid #f8f8f8 !important;
  background-color: #f8f8f8 !important;
  color: #999 !important;
}

.wpcf7 .template03 span.wpcf7-list-item {
  margin: 0 1em .2em 0;
}

.wpcf7 .template03 .ajax-loader {
  display: block;
}

@-webkit-keyframes border-circle {
  0% {
    width: 0;
    height: 0;
    -webkit-transform: translate(0.5em, 0.5em);
            transform: translate(0.5em, 0.5em);
  }
  100% {
    width: 1em;
    height: 1em;
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
}

@keyframes border-circle {
  0% {
    width: 0;
    height: 0;
    -webkit-transform: translate(0.5em, 0.5em);
            transform: translate(0.5em, 0.5em);
  }
  100% {
    width: 1em;
    height: 1em;
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
}

@media only screen and (max-width: 768px) {
  .wpcf7 .template03 span.wpcf7-list-item {
    display: block;
  }
  .wpcf7 .template03 div.form__row {
    display: block;
  }
  .wpcf7 .template03 p.form__label {
    width: 100%;
    padding: 1.5em 1em 0;
  }
  .wpcf7 .template03 p.form__body {
    width: 100%;
    padding: 1em 1em 1.5em;
  }
}

.wpcf7-response-output {
  display: -ms-grid;
  display: grid;
  place-content: center;
  width: 80%;
  margin: 10% auto;
  font-size: 1rem;
}

.screen-reader-response {
  display: none;
}

#rightgear {
  width: 12vw;
  height: auto;
}

@media only screen and (max-width: 767px) {
  #rightgear {
    width: 30vw;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  #rightgear {
    width: 20vw;
  }
}

/* The Overlay (background) */
.overlay {
  /* Height & width depends on how you want to reveal the overlay (see JS below) */
  height: 0;
  width: 100%;
  position: fixed;
  /* Stay in place */
  z-index: 100;
  /* Sit on top */
  left: 0;
  top: 0;
  background-color: black;
  /* Black fallback color */
  background-color: rgba(0, 0, 0, 0.9);
  /* Black w/opacity */
  overflow-x: hidden;
  /* Disable horizontal scroll */
  -webkit-transition: 0.5s;
  transition: 0.5s;
  /* 0.5 second transition effect to slide in or slide down the overlay (height or width, depending on reveal) */
}

/* Position the content inside the overlay */
.overlay-content {
  position: relative;
  top: 15%;
  /* 25% from the top */
  width: 100%;
  /* 100% width */
  text-align: center;
  /* Centered text/links */
  margin-top: 30px;
  /* 30px top margin to avoid conflict with the close button on smaller screens */
}

/* The navigation links inside the overlay */
.overlay a {
  padding: 8px;
  text-decoration: none;
  font-family: lemonde-journal;
  font-size: 36px;
  color: #d8d7cd;
  display: block;
  /* Display block instead of inline */
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

@media only screen and (max-width: 767px) {
  .overlay a {
    font-size: 24px;
  }
}

/* When you mouse over the navigation links, change their color */
.overlay a:hover, .overlay a:focus {
  color: white;
}

/* Position the close button (top right corner) */
.overlay .closebtn {
  position: absolute;
  top: 20px;
  right: 45px;
  font-size: 60px;
}

/* When the height of the screen is less than 450 pixels, change the font-size of the links and position the close button again, so they don't overlap */
@media screen and (max-height: 450px) {
  .overlay a {
    font-size: 20px;
  }
  .overlay .closebtn {
    font-size: 40px;
    top: 15px;
    right: 35px;
  }
}

.section_wrap {
  margin: 6% auto;
}

@media only screen and (max-width: 767px) {
  .section_wrap {
    margin: 20% auto 15% auto;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  .section_wrap {
    margin: 20% auto 10% auto;
  }
}

.section_wrap2 {
  width: 90%;
  margin: 10% 5% 0 5%;
}

@media only screen and (max-width: 767px) {
  .section_wrap2 {
    margin: 20% 4%;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  .section_wrap2 {
    margin: 30% auto 30% auto;
  }
}

.contents_wrap {
  margin: 2% auto;
}

@media only screen and (max-width: 767px) {
  .contents_wrap {
    margin: 2% auto;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  .contents_wrap {
    margin: 2% auto;
    width: 90%;
  }
}

.contents_title {
  text-align: center;
}

.contents_title .title_bar {
  width: 100%;
  display: block;
  margin: 3% auto;
}

@media only screen and (max-width: 767px) {
  .contents_title .title_bar {
    margin: 8% auto;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  .contents_title .title_bar {
    margin: 5% auto;
  }
}

.contents_title .title_bar .bar {
  display: inline-block;
  width: 1px;
  height: 20px;
  background-color: #3e3a3a;
}

.contents_module1 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  width: 100%;
  margin: 0 auto;
  padding: 5%;
  border: #3e3a3a solid 1px;
}

@media only screen and (max-width: 767px) {
  .contents_module1 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 2% 0;
    margin: 6% auto;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  .contents_module1 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 2% 0;
    margin: 10% auto 0 auto;
  }
}

.contents_module1 .contents_module1-img {
  width: 50%;
}

@media only screen and (max-width: 767px) {
  .contents_module1 .contents_module1-img {
    width: 100%;
    margin: 0 auto;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  .contents_module1 .contents_module1-img {
    width: 100%;
    margin: 0 auto;
  }
}

.contents_module1 .contents_module1-img img {
  width: 80%;
  height: auto;
  margin: 2% auto;
  position: relative;
  -webkit-filter: drop-shadow(1.5px 1.5px 1.5px rgba(0, 0, 0, 0.6));
          filter: drop-shadow(1.5px 1.5px 1.5px rgba(0, 0, 0, 0.6));
}

@media only screen and (max-width: 767px) {
  .contents_module1 .contents_module1-img img {
    width: 100%;
	  height: 250px;
    -o-object-fit: cover;
       object-fit: cover;
  }
}

.contents_module1 .contents_module1-para {
  width: 50%;
  margin: 0 auto;
  text-align: justify;
}

@media only screen and (max-width: 767px) {
  .contents_module1 .contents_module1-para {
    width: 90%;
    z-index: 10;
    margin-bottom: 5%;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  .contents_module1 .contents_module1-para {
    width: 75%;
    z-index: 10;
    margin-bottom: 5%;
  }
}

.contents_module1 .contents_module1-para h3 {
  font-weight: bold;
  font-size: 1.6rem;
  margin-bottom: 2%;
}

.btn {
  background: #000;
  color: #fff;
  cursor: pointer;
  font-size: 16px;
  font-weight: 400;
  line-height: 45px;
  margin: 5% auto;
  max-width: 250px;
  position: relative;
  text-decoration: none;
  text-transform: uppercase;
  width: 100%;
  text-align: center;
}

@media only screen and (max-width: 767px) {
  .btn {
    padding: 3%;
  }
}

.link-button {
  background: #464141;
  border: 1px solid #333030;
  -webkit-box-shadow: 0px 2px 0 #312e2e, 2px 4px 6px #393535;
          box-shadow: 0px 2px 0 #312e2e, 2px 4px 6px #393535;
  font-weight: 900;
  color: #ffffff;
  letter-spacing: 1px;
  -webkit-transition: all 150ms linear;
  transition: all 150ms linear;
}

.link-button:hover {
  background: #3a3636;
  border: 1px solid rgba(0, 0, 0, 0.05);
  -webkit-box-shadow: 1px 1px 2px rgba(255, 255, 255, 0.2);
          box-shadow: 1px 1px 2px rgba(255, 255, 255, 0.2);
  color: #6d6666;
  text-decoration: none;
  text-shadow: -1px -1px 0 #252323;
  -webkit-transition: all 250ms linear;
  transition: all 250ms linear;
}

.scroll-bar {
  position: absolute;
  top: 80vh;
  right: 5vw;
}

@media only screen and (max-width: 767px) {
  .scroll-bar {
    top: 75vh;
    right: 5vw;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  .scroll-bar {
    top: 50vh;
    right: 3vw;
  }
}

@media (min-width: 1100px) and (max-width: 1600px) {
  .scroll-bar {
    top: 65vh;
  }
}

.path-vert {
  stroke-dasharray: 700px;
  stroke-dasharray: 700px;
  /*   stroke-dashoffset: 800; */
  -webkit-animation: draw1 4s linear alternate;
          animation: draw1 4s linear alternate;
}

@-webkit-keyframes draw1 {
  from {
    stroke-dashoffset: 1200;
  }
  to {
    stroke-dashoffset: 400;
  }
}

@keyframes draw1 {
  from {
    stroke-dashoffset: 1200;
  }
  to {
    stroke-dashoffset: 400;
  }
}

.margin-top {
  margin-top: 5%;
}

@media only screen and (max-width: 767px) {
  .margin-top {
    margin-top: 40%;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  .margin-top {
    margin-top: 30%;
  }
}

.align-right {
  text-align: right;
}

@media only screen and (max-width: 767px) {
  .pc-only {
    display: none !important;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  .pc-only {
    display: block;
  }
}

@media only screen and (max-width: 1600px) {
  .pc-only {
    display: block;
  }
}

@media only screen and (max-width: 767px) {
  .sp-only {
    display: block !important;
  }
}

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

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

@media only screen and (max-width: 767px) {
  .sp-only_nega_margin-top {
    margin-top: -40% !important;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  .sp-only_nega_margin-top {
    margin-top: 10%;
  }
}

@media only screen and (max-width: 1600px) {
  .sp-only_nega_margin-top {
    margin-top: 0;
  }
}

@media only screen and (max-width: 767px) {
  .sp-only_posi_margin-top {
    margin-top: 30% !important;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  .sp-only_posi_margin-top {
    margin-top: 50% !important;
  }
}

@media only screen and (max-width: 1600px) {
  .sp-only_posi_margin-top {
    margin-top: 0;
  }
}

@media only screen and (max-width: 767px) {
  .sp-wrap {
    margin: 50% auto 0 auto;
  }
}

.element_start[data-emergence=hidden] {
  opacity: 0;
}

.element_start[data-emergence=visible] {
  -webkit-animation: draw1 0.8s ease-out  forwards;
          animation: draw1 0.8s ease-out  forwards;
}

.element_from_bottom[data-emergence=hidden] {
  opacity: 0;
}

.element_from_bottom[data-emergence=visible] {
  -webkit-animation: fadein_bottom 0.8s ease-out  forwards;
          animation: fadein_bottom 0.8s ease-out  forwards;
}

@-webkit-keyframes fadein_bottom {
  from {
    opacity: 0;
    -webkit-transform: translateY(150px);
            transform: translateY(150px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@keyframes fadein_bottom {
  from {
    opacity: 0;
    -webkit-transform: translateY(150px);
            transform: translateY(150px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

.element_from_right[data-emergence=hidden] {
  opacity: 0;
}

.element_from_right[data-emergence=visible] {
  -webkit-animation: fadein_right 0.8s ease-out  forwards;
          animation: fadein_right 0.8s ease-out  forwards;
}

@-webkit-keyframes fadein_right {
  from {
    opacity: 0;
    -webkit-transform: translateX(150px);
            transform: translateX(150px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}

@keyframes fadein_right {
  from {
    opacity: 0;
    -webkit-transform: translateX(150px);
            transform: translateX(150px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}

.element_from_left[data-emergence=hidden] {
  opacity: 0;
}

.element_from_left[data-emergence=visible] {
  -webkit-animation: fadein_left 0.8s ease-out  forwards;
          animation: fadein_left 0.8s ease-out  forwards;
}

@-webkit-keyframes fadein_left {
  from {
    opacity: 0;
    -webkit-transform: translate(-150px, 0);
            transform: translate(-150px, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translate(0);
            transform: translate(0);
  }
}

@keyframes fadein_left {
  from {
    opacity: 0;
    -webkit-transform: translate(-150px, 0);
            transform: translate(-150px, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translate(0);
            transform: translate(0);
  }
}

.element_from_bottom[data-emergence=hidden] {
  opacity: 0;
}

.element_from_bottom[data-emergence=visible] {
  -webkit-animation: fadein_bottom 0.8s ease-out forwards;
          animation: fadein_bottom 0.8s ease-out forwards;
}

@keyframes fadein_bottom {
  from {
    opacity: 0;
    -webkit-transform: translateY(60px);
            transform: translateY(60px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

header {
  width: 100vw;
  height: auto;
  overflow-x: hidden;
}

header video {
  width: 88vw;
  height: auto;
  position: relative;
  opacity: 100%;
  z-index: 0;
}

@media only screen and (max-width: 767px) {
  header video {
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: right;
       object-position: right;
    width: 100vw;
    height: 90vh;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  header video {
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: right;
       object-position: right;
    width: 100vw;
    height: 60vh;
  }
}

header .hero_video {
  display: block;
  position: relative;
  text-align: right;
  -webkit-filter: drop-shadow(3px 3px 3px rgba(0, 0, 0, 0.8));
          filter: drop-shadow(3px 3px 3px rgba(0, 0, 0, 0.8));
}

@media only screen and (max-width: 767px) {
  header .hero_video::after {
    display: block;
    width: 88vw;
    height: 100%;
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    background-color: rgba(0, 0, 0, 0.3);
    background-image: url("/wp-content/themes/laura/assets/img/download.png");
    background-blend-mode: lighten;
    background-repeat: repeat;
    background-position: 50%;
    width: 100vw;
    height: 90vh;
  }
}

@media only screen and (max-width: 320px) {
  header .hero_video {
    width: 100vw;
    height: 50vh;
  }
}

header .title-box {
  width: 28%;
  height: 18%;
  background-color: #3e3a3a;
  position: absolute;
  top: 6%;
  left: 0;
  z-index: 1;
  text-align: center;
  background: #464141;
  border: 1px solid #393535;
  -webkit-box-shadow: 0px 1px 0 #312e2e, 2px 5px 7px #333030;
          box-shadow: 0px 1px 0 #312e2e, 2px 5px 7px #333030;
}

@media only screen and (max-width: 767px) {
  header .title-box {
    height: 12%;
    width: 40%;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  header .title-box {
    height: 10%;
    width: 40%;
  }
}

header .title-box .main_logo {
  margin-left: 7%;
  -webkit-filter: drop-shadow(6px 6px 6px black);
          filter: drop-shadow(6px 6px 6px black);
}

header .title-box .main_logo img {
  width: 50%;
  height: auto;
  display: inline-block;
  margin: 2% 0 2% 16.5%;
  z-index: 2;
}

@media only screen and (max-width: 767px) {
  header .title-box .main_logo img {
    width: 70%;
    margin-top: 5%;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  header .title-box .main_logo img {
    width: 50%;
    margin-top: 0;
  }
}

header .sub-color {
  width: 5%;
  height: 18%;
  background-color: #e6e5ef;
  position: absolute;
  top: 6%;
  left: 0;
  z-index: 2;
}

@media only screen and (max-width: 767px) {
  header .sub-color {
    height: 12%;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  header .sub-color {
    height: 10%;
  }
}

header .accent-color {
  width: 2%;
  height: 18%;
  background-color: #ced7dc;
  position: absolute;
  top: 6%;
  left: 4%;
  z-index: 2;
}

@media only screen and (max-width: 767px) {
  header .accent-color {
    height: 12%;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  header .accent-color {
    height: 10%;
  }
}

header .hero_lead {
  color: #ffffff;
  position: absolute;
  top: 50vh;
  right: 7vw;
}

@media (min-width: 1100px) and (max-width: 1600px) {
  header .hero_lead {
    top: 45vh;
  }
}

header .hero_lead span {
  font-style: italic;
}

@media only screen and (max-width: 767px) {
  header .hero_lead h1 {
    font-size: 2.5rem;
    line-height: 3.3rem;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  header .hero_lead h1 {
    letter-spacing: 0.05em;
    line-height: 3rem;
  }
}

@media only screen and (max-width: 767px) {
  header .hero_lead {
    top: 32vh;
    left: 0;
    text-align: right;
    margin: 1% 0 05%;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  header .hero_lead {
    top: 35vh;
    text-align: right;
  }
}

header .hero_lead .hero_lead-para {
  margin-top: 3%;
  font-size: 1.7rem;
  line-height: 1.6;
  letter-spacing: 0.05em;
}

@media only screen and (max-width: 767px) {
  header .hero_lead .hero_lead-para {
    margin-top: 8%;
    margin-left: 15%;
    font-size: 0.8rem;
    line-height: 1.7;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  header .hero_lead .hero_lead-para {
    font-size: 1.2rem;
    font-weight: bold;
  }
}

#whoweare {
  text-align: center;
  margin-top: 10%;
}

#whoweare .video {
  display: -ms-grid;
  display: grid;
  place-content: center;
  width: 80%;
  height: auto;
  margin: 0 auto 10% auto;
}

@media only screen and (max-width: 767px) {
  #whoweare .video {
    width: 90vw;
    margin: 5% auto;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  #whoweare .video {
    width: 85vw;
    margin: 5% auto;
  }
}

#whoweare h3 {
  font-weight: bold;
}

#whoweare .whoweare_para {
  width: 65%;
  text-align: center;
  margin: 5% auto;
}

@media only screen and (max-width: 767px) {
  #whoweare .whoweare_para {
    width: 90%;
    text-align: justify;
  }
}

#whoweare .whoweare_movie {
  margin-top: 10%;
}

@media only screen and (max-width: 767px) {
  #whoweare .whoweare_movie {
    margin-top: 15%;
  }
}

#whoweare .whoweare_movie .fal {
  font-size: 2.5rem;
  margin-bottom: 2%;
}

@media only screen and (max-width: 767px) {
  #whoweare .whoweare_movie .fal {
    font-size: 1.6rem;
  }
}

#whoweare span {
  font-family: lemonde-journal;
  font-size: 1.6rem;
  letter-spacing: 0.05em;
}

@media only screen and (max-width: 767px) {
  #whoweare span {
    font-size: 0.9rem;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  #whoweare span {
    font-size: 1.4rem;
  }
}

#news {
  text-align: center;
  padding: 2% 0;
  background-color: #e6e5ef;
  background-blend-mode: lighten;
}

@media only screen and (max-width: 767px) {
  #news {
    margin-top: 15%;
  }
}

#news .contents_module1 {
  width: 70%;
  margin: 0 auto;
}

#news .news_wrap {
  margin: 2% auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -ms-flex-pack: distribute;
      justify-content: space-around;
  width: 80%;
}

@media only screen and (max-width: 767px) {
  #news .news_wrap {
    width: 95%;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  #news .news_wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

#news .news_wrap img {
  width: 300px;
  height: auto;
}

#news .news_wrap .contents_module_news {
  background-color: rgba(255, 255, 255, 0.3);
  background-blend-mode: lighten;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  width: 30%;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 2% auto;
}

#news .news_wrap .contents_module_news a:hover {
  color: grey;
}

@media only screen and (max-width: 767px) {
  #news .news_wrap .contents_module_news {
    width: 95%;
    margin: 5% auto;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  #news .news_wrap .contents_module_news {
    width: 80%;
    margin: 5% auto;
  }
}

#news .news_wrap .contents_module_news .contents_module_news-img {
  -ms-flex-item-align: baseline;
      align-self: baseline;
}

#news .news_wrap .contents_module_news .contents_module_news-img img {
  width: 90%;
  margin: 5% auto;
}

@media only screen and (max-width: 767px) {
  #news .news_wrap .contents_module_news .contents_module_news-img img {
    width: 90%;
  }
}

#news .news_wrap .contents_module_news .contents_module_news-para {
  width: 80%;
  text-align: justify;
  margin: 0% auto 10% auto;
}

#news .news_wrap .contents_module_news .contents_module_news-para a {
  line-height: 1.6;
}

@media only screen and (max-width: 767px) {
  #news .news_wrap .contents_module_news .contents_module_news-para {
    width: 90%;
  }
}

#news .news_wrap .contents_module_news .contents_module_news-para h3 {
  font-size: 1.2rem;
  line-height: 1.6;
  margin-bottom: 5%;
}

@media only screen and (max-width: 767px) {
  #news .news_wrap .contents_module_news .contents_module_news-para h3 {
    font-size: 0.8rem;
    font-weight: bold;
  }
}

#news .news_wrap .news_border {
  width: 90%;
  height: 1px;
  background-color: #3e3a3a;
  margin: 2% auto 5% auto;
}

#news .link-button {
  margin: 8% auto;
}

#mission {
  text-align: center;
  padding: 2% 0;
  background-color: #3e3a3a;
  background-image: url("/wp-content/themes/laura/assets/img/feathers.svg");
  background-blend-mode: soft-light;
  background-position-x: 40%;
  background-size: contain;
  background-repeat: no-repeat;
  color: #ffffff;
}

@media only screen and (max-width: 767px) {
  #mission {
    background-position: center;
    background-repeat: repeat;
    background-size: 240%;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  #mission {
    background-position: center;
    background-repeat: repeat;
  }
}

#mission .contents_module1-img {
  width: 50%;
  margin: 0 auto;
  padding: 0% 3%;
}

@media only screen and (max-width: 767px) {
  #mission .contents_module1-img {
    padding: 0;
    width: 95%;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  #mission .contents_module1-img {
    padding: 0;
    width: 80%;
  }
}

#mission .contents_module1-img .module_para {
  width: 80%;
  margin: 0 auto;
  padding: 2% 4%;
  text-align: center;
  display: block;
  border: #ffffff solid 1px;
}

@media only screen and (max-width: 767px) {
  #mission .contents_module1-img .module_para {
    width: 100%;
    margin: 15% auto;
    padding: 2%;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  #mission .contents_module1-img .module_para {
    padding: 2%;
    margin: 10% auto;
  }
}

#mission .contents_module1-img .module_para h3 {
  font-size: 2rem;
}

@media only screen and (max-width: 767px) {
  #mission .contents_module1-img .module_para h3 {
    font-size: 1.1rem;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  #mission .contents_module1-img .module_para h3 {
    font-size: 1.4rem;
  }
}

#mission .contents_module1-para {
  text-align: justify;
}

#mission .module_para {
  text-align: center;
}

#mission .contents_module1 {
  margin: 0 auto;
}

#mission .bar {
  background-color: #fff;
}

#service {
  text-align: center;
  padding: 2% 0;
}

@media only screen and (max-width: 767px) {
  #service h3 {
    font-size: 0.9rem;
    font-weight: bold;
  }
}

#service .movie-wrap {
  width: 50%;
  height: 0;
  position: relative;
}

@media only screen and (max-width: 767px) {
  #service .movie-wrap {
    width: 100%;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  #service .movie-wrap {
    width: 100%;
  }
	#service{
		margin-bottom: 30%;
	}
}

#service .movie-wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 85%;
  height: 40%;
  -webkit-filter: drop-shadow(1.5px 1.5px 1.5px rgba(0, 0, 0, 0.6));
          filter: drop-shadow(1.5px 1.5px 1.5px rgba(0, 0, 0, 0.6));
}

@media only screen and (max-width: 767px) {
  #service .movie-wrap iframe {
    width: 100%;
    height: 110%;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  #service .movie-wrap iframe {
    width: 70%;
    height: 70%;
    margin: 0 116px;
  }
}

@media only screen and (max-width: 767px) {
  #service .img-marketing {
    width: 100%;
	 position: relative;
    height: 80%;
  }
}

#service .img-marketing::before {
  content: "";
  background-color: #ced7dc;
  opacity: 60%;
  width: 40%;
  top: 60%;
  left: 0;
  height: 77%;
  display: block;
  position: absolute;
  z-index: 0;
}

@media only screen and (max-width: 767px) {
  #service .img-marketing::before {
    top: 12.1%;
	height:230%;
    width: 80%;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  #service .img-marketing::before {
    top: 54.5%;
    width: 70%;
  }
}

/* #service .img-bizdev:before {
  content: "";
  background-color: #e6e5ef;
  opacity: 60%;
  width: 40%;
  height: 30%;
  top: 68%;
  right: 0;
  display: block;
  position: absolute;
  z-index: 0;
}

@media only screen and (max-width: 767px) {
  #service .img-bizdev:before {
    top: 60.7%;
    width: 100%;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  #service .img-bizdev:before {
    top: 58%;
    width: 70%;
  }
} */

#service .service_video {
  width: 80%;
  height: auto;
  position: relative;
  -webkit-filter: drop-shadow(1.5px 1.5px 1.5px rgba(0, 0, 0, 0.6));
          filter: drop-shadow(1.5px 1.5px 1.5px rgba(0, 0, 0, 0.6));
}

@media only screen and (max-width: 767px) {
  #service .service_video {
    width: 95%;
  }
}

#service .contents_module1 {
  border: none;
  z-index: 1;
}

@media only screen and (max-width: 767px) {
  #service .contents_module1 {
    margin-top: 20%;
  }
}

#service .link-button {
  margin-top: 15%;
}

@media only screen and (max-width: 767px) {
  #service .link-button {
    -webkit-transform: translateY(100px);
            transform: translateY(100px);
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  #service .link-button {
    -webkit-transform: translateY(100px);
            transform: translateY(100px);
  }
}

@media only screen and (max-width: 767px) {
  #service #marketing {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
	  margin-bottom: 70%;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  #service #marketing {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
}

@media only screen and (max-width: 767px) {
  #service #bizdev {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

#service .bizdev {
  margin-top: -25%;
}

@media only screen and (max-width: 767px) {
  #service .bizdev {
    margin-top: 0;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  #service .bizdev {
    margin-top: -9%;
  }
}

footer {
  background-color: #3e3a3a;
  width: 100vw;
}

footer .footer_wrap {
  padding: 3% 8%;
  color: white;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -ms-flex-pack: distribute;
      justify-content: space-around;
  overflow: hidden;
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  footer .footer_wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

footer img {
  width: 20%;
}

@media only screen and (max-width: 767px) {
  footer .company_info {
    display: -ms-grid;
    display: grid;
    place-items: center;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  footer .company_info {
    text-align: center;
    width: 100%;
    margin: 5% auto;
  }
}

footer .footer_menu {
  margin-right: 10%;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  footer .footer_menu {
    display: none;
  }
}

@media only screen and (max-width: 1600px) {
  footer .footer_menu ul {
    display: block;
  }
}

footer .footer_menu li {
  padding: 1% 5%;
}

footer .footer_menu a {
  font-family: lemonde-journal;
}

footer .footer_menu a:hover {
  color: #818181;
}

footer .footer_span {
  font-size: 0.9rem;
}

.news-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
	position: relative;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  margin: 5% auto;
}

@media only screen and (max-width: 767px) {
  .news-wrap {
    width: 95%;
    display: block;
    margin: 10% auto 20% auto;
  }
}

.news-wrap p {
  font-size: 1.2rem;
}
.read-more{
	position: absolute;
	bottom: -6px;
	right:0px;
	padding: 8px;
	color: midnightblue;
	z-index:100;
	cursor:pointer;
}
.read-more:hover{
	opacity:.7;
}
@media only screen and (max-width: 767px) {
  .news-wrap p {
    font-size: 0.75rem;
  }
}

.news-wrap main {
  width: 80%;
  margin: 0 auto;
  padding: 0 5%;
}

@media only screen and (max-width: 767px) {
  .news-wrap main {
    width: 100%;
    margin: 0 auto;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  .news-wrap main {
    width: 100%;
    margin: 0 auto;
  }
}

.news-wrap main .entry-header {
  width: 70%;
}

.news-wrap main .entry-content {
  width: 80%;
}

.news-wrap main .entry-content p {
  font-size: 1.2rem;
}

.news-wrap aside {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  background-color: #ced7dc;
  padding: 2%;
  margin-top: 5%;
}

@media only screen and (max-width: 767px) {
  .news-wrap aside {
    display: none;
  }
}

.news-wrap aside .widget {
  margin: 25% auto;
}

.news-wrap aside .widget ul {
  margin-top: 5%;
  border-top: white dashed 1px;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.news-wrap aside .widget a:hover {
  color: white;
}

.news-wrap aside .widget_recent_entries {
  border-bottom: #3e3a3a solid 1px;
}

.news-wrap aside .widget_recent_entries li {
  display: block;
}

.news-wrap aside .widget_recent_comments {
  border-bottom: #3e3a3a solid 1px;
}

.news-wrap aside .widget_archive {
  border-bottom: #3e3a3a solid 1px;
}

.news-wrap h1 {
  font-size: 2rem;
}

.news-wrap h2 {
  font-size: 1.2rem;
  font-weight: bold;
}

.news-wrap a {
  font-size: 0.8rem;
}

.news-wrap .entry-title {
  font-family: a-otf-futo-min-a101-pr6n;
  margin-bottom: 1%;
  border-bottom: 2px solid #f0f0f0;
  line-height: 2;
}

.news-wrap .entry-title-bar {
  display: inline-block;
  vertical-align: top;
  position: relative;
  bottom: -2px;
  padding-bottom: 15px;
  margin-bottom: 0;
  border-bottom: 2px solid #505050;
}

.news-wrap .entry-content img {
	
  display: block;
  margin: 0 auto;
}

.news-wrap .news_content {
  margin: 5% auto;
}

@media only screen and (max-width: 767px) {
  .news-wrap .news_content {
    margin: 20% auto;
  }
	.single-wrap .entry-content img {
width: 100% !important;
  display: block;
  margin: 8px auto!important;
}
}

.news-wrap .news_content .news_title-border {
  border-bottom: #ced7dc 2px dotted;
  width: 100%;
  height: 5px;
  background-color: white;
}

.news-wrap .news_content .news_content-border {
  background-color: #4b4646;
  width: 100%;
  height: 1px;
  margin: 5% auto;
}

.search-form {
  margin: 10% auto;
}

.search-form span {
  font-size: 1.2rem;
}

.search-form .search-field {
  border: #3e3a3a 1px solid;
  border-radius: 4px;
  font-size: 1.2rem;
  padding: 2%;
  margin-left: 5%;
}

.search-submit {
  margin-left: 2%;
  display: inline-block;
  padding: 0.8em  1em;
  text-decoration: none;
  background: #818181;
  /*ボタン色*/
  color: #000000;
  /*ボタン色より暗く*/
  -webkit-box-shadow: 0px 2px 2px rgba(0, 0, 0, 0.29);
          box-shadow: 0px 2px 2px rgba(0, 0, 0, 0.29);
  border-bottom: solid 3px #000000;
  border-radius: 3px;
  font-weight: bold;
  font-size: 1.2rem;
  text-shadow: 1px 1px 1px rgba(255, 255, 255, 0.5);
}

.search-submit:hover {
  -webkit-transform: translateY(4px);
  transform: translateY(4px);
  -webkit-box-shadow: 0px 0px 1px rgba(0, 0, 0, 0.2);
          box-shadow: 0px 0px 1px rgba(0, 0, 0, 0.2);
  border-bottom: none;
}

.single-wrap {
  display: block;
  margin: 20% 5% 10% 5%;
}

@media only screen and (max-width: 767px) {
  .single-wrap {
    margin: 50% 5% 20% 5%;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  .single-wrap {
    margin: 30% 5% 10% 5%;
  }
}

.single-wrap .edit-link {
  display: none;
}

.single-wrap main {
  width: 100%;
}

@media only screen and (max-width: 767px) {
  .single-wrap main {
    width: 100%;
  }
}

.single-wrap main .entry-header {
  width: 80%;
  margin: 5% auto 0 auto;
  text-align: justify;
}

@media only screen and (max-width: 767px) {
  .single-wrap main .entry-header {
    width: 100%;
  }
}

.single-wrap main .entry-content {
  width: 80%;
  margin: 0 auto;
  text-align: justify;
	overflow-wrap: break-word;
}

@media only screen and (max-width: 767px) {
  .single-wrap main .entry-content {
    width: 100%;
    margin: 10% auto;
  }
}

.single-wrap main .entry-content p {
  font-size: 1.2rem;
}

@media only screen and (max-width: 767px) {
  .single-wrap main .entry-content p {
    font-size: 0.8rem;
  }
}

.single-wrap main .entry-content a {
  font-size: 1.2rem;
  color: grey;
}

.single-wrap main .entry-content a:hover {
  color: #3e3a3a;
}

@media only screen and (max-width: 767px) {
  .single-wrap main .entry-content a {
    font-size: 0.75rem;
  }
}

.single-wrap h1 {
  font-family: a-otf-futo-min-a101-pr6n;
  font-size: 1.5rem;
}

@media only screen and (max-width: 767px) {
  .single-wrap h1 {
    font-size: 1rem;
  }
}

.single-wrap h2 {
  font-size: 1.2rem;
  font-weight: bold;
}

.single-wrap a {
  font-size: 0.8rem;
}

.single-wrap .entry-title {
  font-family: a-otf-futo-min-a101-pr6n;
  margin: 5% auto 0 auto;
  border-bottom: 2px solid #f0f0f0;
  line-height: 1.6;
}

.single-wrap .entry-title-bar {
  display: inline-block;
  vertical-align: top;
  position: relative;
  bottom: -2px;
  padding-bottom: 15px;
  margin-bottom: 0;
  border-bottom: 2px solid #505050;
}

.single-wrap .entry-content img {
  display: block;
  margin: 0 auto;
}

.post-title a {
  font-size: 1.2rem;
}

.post-title a:hover {
  color: gray;
}

@media only screen and (max-width: 767px) {
  .post-title a {
    font-size: 0.75rem;
  }
}

.post-excerpt {
  display: block;
  position: relative;
  overflow: hidden;
  width: 100%;
}

.post-excerpt:before {
  content: "";
  position: absolute;
  border-style: none;
  left: 0;
  bottom: 0;
  z-index: 2;
  width: 100%;
  height: 5vw;
  background: linear-gradient(rgba(255, 255, 255, 0) 0, #fff 100px);
}

@media only screen and (max-width: 767px) {
  .post-excerpt:before {
    height: 31vw;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  .post-excerpt:before {
    height: 10vw;
  }
}

.post-excerpt a {
  display: inline-block;
}

.post-date {
  display: block;
  text-align: right;
  font-size: 1.22rem;
}

@media only screen and (max-width: 767px) {
  .post-date {
    font-size: 1rem;
  }
}

.wp-post-image {
  width: 300px;
  height: auto;
  margin: 5% auto;
}

.page-header {
  margin-bottom: 5%;
}

.entry-header a {
  font-size: 1.6rem;
}

.entry-header a:hover {
  color: grey;
}

.entry-summary {
  width: 80%;
  margin: 5% auto 5% 0;
}

article {
  margin: 5% auto;
}

@media only screen and (max-width: 767px) {
  aside #secondary {
    display: none;
  }
}

.posts-navigation {
  width: 80%;
  margin: 0 auto;
}

.posts-navigation .nav-next {
  display: none;
}

.posts-navigation .wp-pagenavi .pages {
  display: none;
}

.screen-reader-text {
  display: none;
}

.wp-pagenavi {
  display: inline-block;
}

.wp-pagenavi a {
  float: left;
  padding: 8px 16px;
  text-decoration: none;
}
/*# sourceMappingURL=main.css.map */