@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=BIZ+UDGothic:wght@400;700&family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&display?family=Open+Sans:ital,wght@0,300..800;1,300..800&display=swap");
* {
  color: #000;
  font-family: "Open Sans", "Noto Sans JP", sans-serif;
  font-weight: 400;
  margin: 0px;
  padding: 0px;
  line-height: 1em;
  font-size: 16px;
  font-feature-settings: "palt";
  letter-spacing: 0.05em;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

html {
  overflow: auto;
}

body {
  text-align: center;
  margin: 0px auto;
  min-width: 1080px;
  box-sizing: border-box;
  overflow: hidden;
}

img {
  height: auto;
}

input {
  -webkit-appearance: none;
}

a img {
  border: 0px;
}

a:hover {
  color: #01987a;
}

a[href^="tel:"] {
  pointer-events: none;
  text-decoration: none;
  cursor: default;
}

li {
  list-style-type: none;
}

.inner {
  position: relative;
  text-align: center;
  margin: 0px auto;
  width: 1080px;
}

/* ============================================================================== */
/* header */
/* ============================================================================== */
nav {
  position: absolute;
  top: 32px;
  left: 0px;
  z-index: 20;
  text-align: left;
  display: flex;
  flex-wrap: wrap;
}
nav img {
  width: 48px;
  height: 48px;
}
nav ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  width: 832px;
}
nav ul li {
  padding: 12px 0px 12px 24px;
}
nav ul li a {
  text-decoration: none;
  letter-spacing: 0em;
  display: block;
  font-family: "Open Sans", "Noto Serif JP", serif;
  font-weight: 600;
  color: #fff;
  text-shadow: 0 0 5px #000, 0 0 12px #000;
}
nav ul li a:hover {
  font-weight: 500;
  color: #02e4b7;
}
nav ul li a.insta {
  width: 24px;
  height: 24px;
  position: relative;
}
nav ul li a.insta:before {
  content: "";
  position: absolute;
  top: -4px;
  left: 0px;
  background: url("data:image/svg+xml;utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2088%2088%22%20xml%3Aspace%3D%22preserve%22%3E%3Cpath%20fill%3D%22%23fff%22%20d%3D%22M25.8%2C0.3c-4.7%2C0.2-7.9%2C1-10.7%2C2.1C12.2%2C3.5%2C9.8%2C5%2C7.3%2C7.5s-3.9%2C4.9-5.1%2C7.8c-1.1%2C2.8-1.8%2C6-2%2C10.7%20S0%2C32.1%2C0%2C44.1s0.1%2C13.4%2C0.3%2C18.1c0.2%2C4.7%2C1%2C7.9%2C2.1%2C10.7c1.1%2C2.9%2C2.6%2C5.3%2C5.1%2C7.8c2.4%2C2.4%2C4.9%2C3.9%2C7.8%2C5.1c2.8%2C1.1%2C6%2C1.8%2C10.7%2C2%20C30.6%2C88%2C32.1%2C88%2C44.1%2C88s13.4-0.1%2C18.1-0.3c4.7-0.2%2C7.9-1%2C10.7-2.1c2.9-1.1%2C5.3-2.6%2C7.8-5.1c2.4-2.4%2C3.9-4.9%2C5.1-7.8%20c1.1-2.8%2C1.8-6%2C2-10.7C88%2C57.4%2C88%2C55.9%2C88%2C43.9s-0.1-13.4-0.3-18.1c-0.2-4.7-1-7.9-2.1-10.7c-1.1-2.9-2.6-5.3-5.1-7.8%20c-2.4-2.4-4.9-3.9-7.8-5.1c-2.8-1.1-6-1.8-10.7-2S55.9%2C0%2C43.9%2C0S30.5%2C0.1%2C25.8%2C0.3%20M26.3%2C79.9c-4.3-0.2-6.6-0.9-8.2-1.5%20c-2.1-0.8-3.5-1.7-5.1-3.3c-1.5-1.5-2.5-3-3.3-5.1c-0.6-1.6-1.3-3.9-1.5-8.2C8%2C57.2%2C8%2C55.8%2C7.9%2C44.1s0-13.1%2C0.2-17.8%20c0.2-4.3%2C0.9-6.6%2C1.5-8.2c0.8-2.1%2C1.7-3.5%2C3.3-5.1s3-2.5%2C5.1-3.3c1.6-0.6%2C3.9-1.3%2C8.2-1.5c4.6-0.2%2C6-0.3%2C17.8-0.3s13.1%2C0%2C17.8%2C0.2%20c4.3%2C0.2%2C6.6%2C0.9%2C8.2%2C1.5c2.1%2C0.8%2C3.5%2C1.7%2C5.1%2C3.3s2.5%2C3%2C3.3%2C5.1c0.6%2C1.5%2C1.3%2C3.9%2C1.5%2C8.2c0.2%2C4.6%2C0.3%2C6%2C0.3%2C17.8s0%2C13.1-0.2%2C17.8%20c-0.2%2C4.3-0.9%2C6.6-1.5%2C8.2c-0.8%2C2.1-1.7%2C3.5-3.3%2C5.1c-1.5%2C1.5-3%2C2.5-5.1%2C3.3c-1.5%2C0.6-3.9%2C1.3-8.2%2C1.5c-4.6%2C0.2-6%2C0.3-17.8%2C0.3%20S30.9%2C80.1%2C26.3%2C79.9%20M62.2%2C20.5c0%2C2.9%2C2.4%2C5.3%2C5.3%2C5.3c2.9%2C0%2C5.3-2.4%2C5.3-5.3s-2.4-5.3-5.3-5.3c0%2C0%2C0%2C0%2C0%2C0%20C64.5%2C15.2%2C62.2%2C17.6%2C62.2%2C20.5%20M21.4%2C44c0%2C12.5%2C10.2%2C22.6%2C22.6%2C22.5c12.5%2C0%2C22.6-10.2%2C22.6-22.6c0-12.5-10.2-22.6-22.6-22.5%20C31.5%2C21.4%2C21.4%2C31.6%2C21.4%2C44%20M29.3%2C44c0-8.1%2C6.5-14.7%2C14.6-14.7c8.1%2C0%2C14.7%2C6.5%2C14.7%2C14.6c0%2C8.1-6.5%2C14.7-14.6%2C14.7%20C35.9%2C58.7%2C29.3%2C52.1%2C29.3%2C44C29.3%2C44%2C29.3%2C44%2C29.3%2C44%22%20%2F%3E%3C%2Fsvg%3E");
  display: block;
  width: 24px;
  height: 24px;
}
nav ul li a.insta:hover:before {
  background: url("data:image/svg+xml;utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2088%2088%22%20xml%3Aspace%3D%22preserve%22%3E%3Cpath%20fill%3D%22%2302e4b7%22%20d%3D%22M25.8%2C0.3c-4.7%2C0.2-7.9%2C1-10.7%2C2.1C12.2%2C3.5%2C9.8%2C5%2C7.3%2C7.5s-3.9%2C4.9-5.1%2C7.8c-1.1%2C2.8-1.8%2C6-2%2C10.7%20S0%2C32.1%2C0%2C44.1s0.1%2C13.4%2C0.3%2C18.1c0.2%2C4.7%2C1%2C7.9%2C2.1%2C10.7c1.1%2C2.9%2C2.6%2C5.3%2C5.1%2C7.8c2.4%2C2.4%2C4.9%2C3.9%2C7.8%2C5.1c2.8%2C1.1%2C6%2C1.8%2C10.7%2C2%20C30.6%2C88%2C32.1%2C88%2C44.1%2C88s13.4-0.1%2C18.1-0.3c4.7-0.2%2C7.9-1%2C10.7-2.1c2.9-1.1%2C5.3-2.6%2C7.8-5.1c2.4-2.4%2C3.9-4.9%2C5.1-7.8%20c1.1-2.8%2C1.8-6%2C2-10.7C88%2C57.4%2C88%2C55.9%2C88%2C43.9s-0.1-13.4-0.3-18.1c-0.2-4.7-1-7.9-2.1-10.7c-1.1-2.9-2.6-5.3-5.1-7.8%20c-2.4-2.4-4.9-3.9-7.8-5.1c-2.8-1.1-6-1.8-10.7-2S55.9%2C0%2C43.9%2C0S30.5%2C0.1%2C25.8%2C0.3%20M26.3%2C79.9c-4.3-0.2-6.6-0.9-8.2-1.5%20c-2.1-0.8-3.5-1.7-5.1-3.3c-1.5-1.5-2.5-3-3.3-5.1c-0.6-1.6-1.3-3.9-1.5-8.2C8%2C57.2%2C8%2C55.8%2C7.9%2C44.1s0-13.1%2C0.2-17.8%20c0.2-4.3%2C0.9-6.6%2C1.5-8.2c0.8-2.1%2C1.7-3.5%2C3.3-5.1s3-2.5%2C5.1-3.3c1.6-0.6%2C3.9-1.3%2C8.2-1.5c4.6-0.2%2C6-0.3%2C17.8-0.3s13.1%2C0%2C17.8%2C0.2%20c4.3%2C0.2%2C6.6%2C0.9%2C8.2%2C1.5c2.1%2C0.8%2C3.5%2C1.7%2C5.1%2C3.3s2.5%2C3%2C3.3%2C5.1c0.6%2C1.5%2C1.3%2C3.9%2C1.5%2C8.2c0.2%2C4.6%2C0.3%2C6%2C0.3%2C17.8s0%2C13.1-0.2%2C17.8%20c-0.2%2C4.3-0.9%2C6.6-1.5%2C8.2c-0.8%2C2.1-1.7%2C3.5-3.3%2C5.1c-1.5%2C1.5-3%2C2.5-5.1%2C3.3c-1.5%2C0.6-3.9%2C1.3-8.2%2C1.5c-4.6%2C0.2-6%2C0.3-17.8%2C0.3%20S30.9%2C80.1%2C26.3%2C79.9%20M62.2%2C20.5c0%2C2.9%2C2.4%2C5.3%2C5.3%2C5.3c2.9%2C0%2C5.3-2.4%2C5.3-5.3s-2.4-5.3-5.3-5.3c0%2C0%2C0%2C0%2C0%2C0%20C64.5%2C15.2%2C62.2%2C17.6%2C62.2%2C20.5%20M21.4%2C44c0%2C12.5%2C10.2%2C22.6%2C22.6%2C22.5c12.5%2C0%2C22.6-10.2%2C22.6-22.6c0-12.5-10.2-22.6-22.6-22.5%20C31.5%2C21.4%2C21.4%2C31.6%2C21.4%2C44%20M29.3%2C44c0-8.1%2C6.5-14.7%2C14.6-14.7c8.1%2C0%2C14.7%2C6.5%2C14.7%2C14.6c0%2C8.1-6.5%2C14.7-14.6%2C14.7%20C35.9%2C58.7%2C29.3%2C52.1%2C29.3%2C44C29.3%2C44%2C29.3%2C44%2C29.3%2C44%22%20%2F%3E%3C%2Fsvg%3E");
}

.white img {
  filter: invert(100%) sepia(0%) saturate(0%) hue-rotate(93deg) brightness(103%) contrast(103%);
}
.white a {
  color: #fff !important;
}

.slick {
  position: relative;
  top: 0px;
  left: 0px;
}
.slick li {
  height: 928px;
  overflow: hidden;
}
.slick li img {
  width: 100svw;
  min-width: 1016px;
}

h1 {
  font-size: 21px;
  font-family: "BIZ UDGothic", serif;
  font-weight: 700;
  padding: 10px 0px 0px 16px;
  display: inline-block;
}

header h2 {
  position: absolute;
  color: #fff;
  font-family: "Open Sans", "Noto Serif JP", serif;
  font-weight: 500;
  font-size: 64px;
  z-index: 10;
  text-align: left;
}

/* ============================================================================== */
/* INDEX */
/* ============================================================================== */
#home header h2 {
  top: 520px;
  margin-left: calc(50svw - 540px);
}
#home header h2 span {
  color: #016551;
  mix-blend-mode: multiply;
  display: block;
  font-weight: 900;
  font-size: 32px;
  margin-bottom: 16px;
  letter-spacing: 0;
}
#home header h1 {
  text-shadow: 0 0 10px #fff, 0 0 5px #fff;
}
#home header nav {
  background: linear-gradient(to bottom, #fff, transparent);
  top: 0px;
  padding: 32px 0px 120px calc((100svw - 1080px) / 2);
  width: 100svw;
  margin-left: calc((-100svw + 1080px) / 2);
}
#home header nav li a {
  color: #000;
  text-shadow: 0 0 10px #fff, 0 0 5px #fff;
}
#home header nav li a:hover {
  color: #01987a;
}
#home header nav li a.insta:before {
  background: url("data:image/svg+xml;utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2088%2088%22%20xml%3Aspace%3D%22preserve%22%3E%3Cpath%20fill%3D%22%23000%22%20d%3D%22M25.8%2C0.3c-4.7%2C0.2-7.9%2C1-10.7%2C2.1C12.2%2C3.5%2C9.8%2C5%2C7.3%2C7.5s-3.9%2C4.9-5.1%2C7.8c-1.1%2C2.8-1.8%2C6-2%2C10.7%20S0%2C32.1%2C0%2C44.1s0.1%2C13.4%2C0.3%2C18.1c0.2%2C4.7%2C1%2C7.9%2C2.1%2C10.7c1.1%2C2.9%2C2.6%2C5.3%2C5.1%2C7.8c2.4%2C2.4%2C4.9%2C3.9%2C7.8%2C5.1c2.8%2C1.1%2C6%2C1.8%2C10.7%2C2%20C30.6%2C88%2C32.1%2C88%2C44.1%2C88s13.4-0.1%2C18.1-0.3c4.7-0.2%2C7.9-1%2C10.7-2.1c2.9-1.1%2C5.3-2.6%2C7.8-5.1c2.4-2.4%2C3.9-4.9%2C5.1-7.8%20c1.1-2.8%2C1.8-6%2C2-10.7C88%2C57.4%2C88%2C55.9%2C88%2C43.9s-0.1-13.4-0.3-18.1c-0.2-4.7-1-7.9-2.1-10.7c-1.1-2.9-2.6-5.3-5.1-7.8%20c-2.4-2.4-4.9-3.9-7.8-5.1c-2.8-1.1-6-1.8-10.7-2S55.9%2C0%2C43.9%2C0S30.5%2C0.1%2C25.8%2C0.3%20M26.3%2C79.9c-4.3-0.2-6.6-0.9-8.2-1.5%20c-2.1-0.8-3.5-1.7-5.1-3.3c-1.5-1.5-2.5-3-3.3-5.1c-0.6-1.6-1.3-3.9-1.5-8.2C8%2C57.2%2C8%2C55.8%2C7.9%2C44.1s0-13.1%2C0.2-17.8%20c0.2-4.3%2C0.9-6.6%2C1.5-8.2c0.8-2.1%2C1.7-3.5%2C3.3-5.1s3-2.5%2C5.1-3.3c1.6-0.6%2C3.9-1.3%2C8.2-1.5c4.6-0.2%2C6-0.3%2C17.8-0.3s13.1%2C0%2C17.8%2C0.2%20c4.3%2C0.2%2C6.6%2C0.9%2C8.2%2C1.5c2.1%2C0.8%2C3.5%2C1.7%2C5.1%2C3.3s2.5%2C3%2C3.3%2C5.1c0.6%2C1.5%2C1.3%2C3.9%2C1.5%2C8.2c0.2%2C4.6%2C0.3%2C6%2C0.3%2C17.8s0%2C13.1-0.2%2C17.8%20c-0.2%2C4.3-0.9%2C6.6-1.5%2C8.2c-0.8%2C2.1-1.7%2C3.5-3.3%2C5.1c-1.5%2C1.5-3%2C2.5-5.1%2C3.3c-1.5%2C0.6-3.9%2C1.3-8.2%2C1.5c-4.6%2C0.2-6%2C0.3-17.8%2C0.3%20S30.9%2C80.1%2C26.3%2C79.9%20M62.2%2C20.5c0%2C2.9%2C2.4%2C5.3%2C5.3%2C5.3c2.9%2C0%2C5.3-2.4%2C5.3-5.3s-2.4-5.3-5.3-5.3c0%2C0%2C0%2C0%2C0%2C0%20C64.5%2C15.2%2C62.2%2C17.6%2C62.2%2C20.5%20M21.4%2C44c0%2C12.5%2C10.2%2C22.6%2C22.6%2C22.5c12.5%2C0%2C22.6-10.2%2C22.6-22.6c0-12.5-10.2-22.6-22.6-22.5%20C31.5%2C21.4%2C21.4%2C31.6%2C21.4%2C44%20M29.3%2C44c0-8.1%2C6.5-14.7%2C14.6-14.7c8.1%2C0%2C14.7%2C6.5%2C14.7%2C14.6c0%2C8.1-6.5%2C14.7-14.6%2C14.7%20C35.9%2C58.7%2C29.3%2C52.1%2C29.3%2C44C29.3%2C44%2C29.3%2C44%2C29.3%2C44%22%20%2F%3E%3C%2Fsvg%3E");
}
#home header nav li a.insta:hover:before {
  background: url("data:image/svg+xml;utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2088%2088%22%20xml%3Aspace%3D%22preserve%22%3E%3Cpath%20fill%3D%22%2301987a%22%20d%3D%22M25.8%2C0.3c-4.7%2C0.2-7.9%2C1-10.7%2C2.1C12.2%2C3.5%2C9.8%2C5%2C7.3%2C7.5s-3.9%2C4.9-5.1%2C7.8c-1.1%2C2.8-1.8%2C6-2%2C10.7%20S0%2C32.1%2C0%2C44.1s0.1%2C13.4%2C0.3%2C18.1c0.2%2C4.7%2C1%2C7.9%2C2.1%2C10.7c1.1%2C2.9%2C2.6%2C5.3%2C5.1%2C7.8c2.4%2C2.4%2C4.9%2C3.9%2C7.8%2C5.1c2.8%2C1.1%2C6%2C1.8%2C10.7%2C2%20C30.6%2C88%2C32.1%2C88%2C44.1%2C88s13.4-0.1%2C18.1-0.3c4.7-0.2%2C7.9-1%2C10.7-2.1c2.9-1.1%2C5.3-2.6%2C7.8-5.1c2.4-2.4%2C3.9-4.9%2C5.1-7.8%20c1.1-2.8%2C1.8-6%2C2-10.7C88%2C57.4%2C88%2C55.9%2C88%2C43.9s-0.1-13.4-0.3-18.1c-0.2-4.7-1-7.9-2.1-10.7c-1.1-2.9-2.6-5.3-5.1-7.8%20c-2.4-2.4-4.9-3.9-7.8-5.1c-2.8-1.1-6-1.8-10.7-2S55.9%2C0%2C43.9%2C0S30.5%2C0.1%2C25.8%2C0.3%20M26.3%2C79.9c-4.3-0.2-6.6-0.9-8.2-1.5%20c-2.1-0.8-3.5-1.7-5.1-3.3c-1.5-1.5-2.5-3-3.3-5.1c-0.6-1.6-1.3-3.9-1.5-8.2C8%2C57.2%2C8%2C55.8%2C7.9%2C44.1s0-13.1%2C0.2-17.8%20c0.2-4.3%2C0.9-6.6%2C1.5-8.2c0.8-2.1%2C1.7-3.5%2C3.3-5.1s3-2.5%2C5.1-3.3c1.6-0.6%2C3.9-1.3%2C8.2-1.5c4.6-0.2%2C6-0.3%2C17.8-0.3s13.1%2C0%2C17.8%2C0.2%20c4.3%2C0.2%2C6.6%2C0.9%2C8.2%2C1.5c2.1%2C0.8%2C3.5%2C1.7%2C5.1%2C3.3s2.5%2C3%2C3.3%2C5.1c0.6%2C1.5%2C1.3%2C3.9%2C1.5%2C8.2c0.2%2C4.6%2C0.3%2C6%2C0.3%2C17.8s0%2C13.1-0.2%2C17.8%20c-0.2%2C4.3-0.9%2C6.6-1.5%2C8.2c-0.8%2C2.1-1.7%2C3.5-3.3%2C5.1c-1.5%2C1.5-3%2C2.5-5.1%2C3.3c-1.5%2C0.6-3.9%2C1.3-8.2%2C1.5c-4.6%2C0.2-6%2C0.3-17.8%2C0.3%20S30.9%2C80.1%2C26.3%2C79.9%20M62.2%2C20.5c0%2C2.9%2C2.4%2C5.3%2C5.3%2C5.3c2.9%2C0%2C5.3-2.4%2C5.3-5.3s-2.4-5.3-5.3-5.3c0%2C0%2C0%2C0%2C0%2C0%20C64.5%2C15.2%2C62.2%2C17.6%2C62.2%2C20.5%20M21.4%2C44c0%2C12.5%2C10.2%2C22.6%2C22.6%2C22.5c12.5%2C0%2C22.6-10.2%2C22.6-22.6c0-12.5-10.2-22.6-22.6-22.5%20C31.5%2C21.4%2C21.4%2C31.6%2C21.4%2C44%20M29.3%2C44c0-8.1%2C6.5-14.7%2C14.6-14.7c8.1%2C0%2C14.7%2C6.5%2C14.7%2C14.6c0%2C8.1-6.5%2C14.7-14.6%2C14.7%20C35.9%2C58.7%2C29.3%2C52.1%2C29.3%2C44C29.3%2C44%2C29.3%2C44%2C29.3%2C44%22%20%2F%3E%3C%2Fsvg%3E");
}

.home_greeting {
  position: relative;
  top: -88px;
  right: 0;
  z-index: 5;
  width: 1016px;
}
.home_greeting:after {
  content: "";
  display: block;
  background: linear-gradient(to bottom, rgba(1, 152, 122, 0.2), transparent);
  top: 88px;
  left: calc((-100svw + 1080px) / 2);
  width: calc((100svw - 1080px) / 2 + 184px);
  height: 100%;
  position: absolute;
}
.home_greeting p {
  text-align: left;
  line-height: 2em;
  padding-left: 532px;
}
.home_greeting ul {
  display: flex;
  flex-wrap: wrap;
  width: 516px;
  justify-content: end;
  align-items: start;
  margin-left: 508px;
}
.home_greeting ul li {
  width: 240px;
  border-radius: 8px;
  padding: 32px 16px;
  background: #01987a;
}
.home_greeting ul li p {
  color: #fff;
  font-size: 17px;
  margin-bottom: 16px;
  line-height: 1.28em;
  padding-left: 0px;
  text-align: center;
}
.home_greeting ul li a {
  display: block;
  color: #fff;
  border: 1px solid #fff;
  border-radius: 32px;
  padding: 8px 16px;
  text-decoration: none;
  font-weight: 600;
  font-size: 13px;
  text-align: left;
  position: relative;
}
.home_greeting ul li a .arrow {
  line-height: 6;
  position: absolute;
  top: 50%;
  right: 16px;
  margin-top: -1px;
  background: #fff;
  display: block;
}
.home_greeting ul li a .arrow:before {
  content: "";
  width: 8px;
  height: 8px;
  border: 2px solid #fff;
  position: absolute;
  box-sizing: border-box;
}
.home_greeting ul li a .arrow.-right {
  width: 12px;
  height: 2px;
}
.home_greeting ul li a .arrow.-right:before {
  border-left: 0;
  border-bottom: 0;
  transform: rotate(45deg);
  transform-origin: top right;
  top: 50%;
  right: -1px;
}
.home_greeting ul li:last-of-type {
  background: #ec002c;
  margin-left: 16px;
}
.home_greeting ul li:last-of-type p {
  text-align: left;
  padding-left: 36px;
}
.home_greeting ul li:first-of-type {
  margin-top: 104px;
}
.home_greeting h2 {
  font-size: 48px;
  line-height: 1.44em;
  writing-mode: vertical-rl;
  text-align: left;
  position: absolute;
  top: 224px !important;
  left: 280px;
  height: 640px;
  letter-spacing: 0px;
  color: #000;
}
.home_greeting h3 {
  font-weight: 900;
  font-size: 18px;
  color: #01987a;
  padding: 64px 0px 48px 532px;
  text-align: left;
}

.circle_bg {
  background: url(images/circle_bg.svg) no-repeat;
  background-size: auto 100%;
  background-position: 50% 0;
}

.home_works h3 {
  color: #01987a;
  font-weight: 700;
  font-size: 21px;
  margin-bottom: 48px;
}
.home_works h3 strong {
  display: block;
  font-family: "Open Sans", "Noto Serif JP", serif;
  font-size: 40px;
  font-weight: 600;
  letter-spacing: 0;
  padding-top: 24px;
}

#home_map {
  width: 780px;
  margin: 64px auto 88px auto;
}

.home_works_li {
  display: flex;
  flex-wrap: wrap;
}
.home_works_li img {
  width: calc(50svw - 540px + 520px);
  margin-left: calc(-50svw + 540px);
  height: 520px;
  object-fit: cover;
  display: block;
}
.home_works_li p {
  width: 420px;
  padding-top: 48px;
  text-align: left;
  line-height: 1.68em;
}
.home_works_li ul {
  display: inline-flex;
  flex-wrap: wrap;
  counter-reset: num;
  width: 480px;
  padding-left: 32px;
}
.home_works_li ul li {
  width: calc(33.3333333333% - 24px);
  margin-left: 24px;
  background: #fff;
  padding: 88px 16px 16px 16px;
  position: relative;
  writing-mode: vertical-rl;
  text-align-last: left;
  height: 480px;
}
.home_works_li ul li h4 {
  font-size: 24px;
  font-weight: 600;
}
.home_works_li ul li h4 span {
  width: 24px;
  height: 18px;
  position: relative;
  display: inline-block;
}
.home_works_li ul li h4 span:after {
  content: "・";
  position: absolute;
  font-size: 24px;
  top: -3px;
  left: 10px;
}
.home_works_li ul li p {
  margin-right: 16px;
  width: auto;
  padding: 0px;
}
.home_works_li ul li:before {
  counter-increment: num;
  content: counter(num, decimal-leading-zero);
  position: absolute;
  top: 32px;
  left: auto;
  right: 16px;
  font-size: 56px;
  color: #ec002c;
  font-weight: 800;
  writing-mode: horizontal-tb;
}
.home_works_li ul li:nth-of-type(2) {
  margin-top: 64px;
}
.home_works_li ul li:last-of-type {
  margin-top: 128px;
}

.home_works_li_left {
  width: 520px;
  position: relative;
}
.home_works_li_left a {
  position: absolute;
  top: 504px;
  right: -96px;
  width: 160px;
  height: 160px;
  border: 1px solid #01987a;
  border-radius: 50%;
}
.home_works_li_left a .arrow {
  line-height: 6;
  position: absolute;
  top: 50%;
  left: 50%;
  margin-top: -4px;
  margin-left: -18px;
  background: #01987a;
  display: block;
}
.home_works_li_left a .arrow:before {
  content: "";
  width: 24px;
  height: 24px;
  border: 6px solid #01987a;
  position: absolute;
  box-sizing: border-box;
}
.home_works_li_left a .arrow.-right {
  width: 36px;
  height: 6px;
}
.home_works_li_left a .arrow.-right:before {
  border-left: 0;
  border-bottom: 0;
  transform: rotate(45deg);
  transform-origin: top right;
  top: 50%;
  right: -3px;
}
.home_works_li_left a:hover {
  border: 1px solid #ec002c;
}
.home_works_li_left a:hover .arrow {
  background: #ec002c;
}
.home_works_li_left a:hover .arrow:before {
  border: 6px solid #ec002c;
}
.home_works_li_left a:hover .arrow.-right:before {
  border-left: 0;
  border-bottom: 0;
}

.cases_btn {
  display: block;
  text-decoration: none;
  width: 360px;
  background: #01987a;
  color: #fff;
  font-weight: 600;
  padding: 16px 0px;
  margin: 88px auto 160px auto;
  position: relative;
  z-index: 5;
}
.cases_btn:hover {
  background: #ec002c;
  color: #fff;
}

.home_ticker {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 184px;
  display: flex;
  justify-content: flex-start;
}
.home_ticker p {
  display: flex;
}
.home_ticker p span {
  font-size: 160px !important;
  display: inline-block;
  white-space: nowrap;
  font-weight: 700;
  letter-spacing: 0;
}
.home_ticker.-upper {
  top: -240px;
  margin-bottom: -160px;
}
.home_ticker.-upper p {
  animation: animate-banner 35s linear infinite;
}
.home_ticker.-upper p span {
  color: #f2ced1;
}
.home_ticker.-lower {
  top: -184px;
  margin-bottom: -80px;
}
.home_ticker.-lower p {
  animation: animate-banner2 35s linear infinite;
}
.home_ticker.-lower p span {
  color: transparent;
  -webkit-text-stroke: 3px #f2ced1;
}

@keyframes animate-banner2 {
  0% {
    transform: translateX(-50%);
  }
  100% {
    transform: translateX(0);
  }
}
.home_initiatives {
  padding-bottom: 32px;
}
.home_initiatives h3 {
  writing-mode: vertical-rl;
  color: #01987a;
  font-size: 15px;
  font-weight: 600;
  position: absolute;
  left: 0px;
  top: 0px;
  text-align: left;
  letter-spacing: 0em;
  z-index: 5;
}
.home_initiatives h3 strong {
  font-family: "Open Sans", "Noto Serif JP", serif;
  font-size: 48px;
  font-weight: 700;
  color: #000;
  display: block;
  margin-right: 12px;
  letter-spacing: 0em;
}
.home_initiatives ul {
  width: 960px;
  margin-left: 152px;
  display: flex;
  flex-wrap: wrap;
  padding-bottom: 48px;
}
.home_initiatives ul li {
  width: 292px;
  padding-right: 32px;
  position: relative;
}
.home_initiatives ul li img {
  width: 100%;
}
.home_initiatives ul li p {
  font-size: 14px;
  color: #01987a;
  text-align: left;
  margin-top: 8px;
  font-weight: 600;
}
.home_initiatives ul li:nth-of-type(even) {
  padding-top: 72px;
}
.home_initiatives a {
  position: absolute;
  top: 420px;
  left: -32px;
  width: 160px;
  height: 160px;
  border: 1px solid #01987a;
  border-radius: 50%;
}
.home_initiatives a .arrow {
  line-height: 6;
  position: absolute;
  top: 50%;
  right: 32px;
  margin-top: -4px;
  margin-left: -18px;
  background: #01987a;
  display: block;
}
.home_initiatives a .arrow:before {
  content: "";
  width: 24px;
  height: 24px;
  border: 6px solid #01987a;
  position: absolute;
  box-sizing: border-box;
}
.home_initiatives a .arrow.-right {
  width: 36px;
  height: 6px;
}
.home_initiatives a .arrow.-right:before {
  border-left: 0;
  border-bottom: 0;
  transform: rotate(45deg);
  transform-origin: top right;
  top: 50%;
  right: -3px;
}
.home_initiatives a:hover {
  border: 1px solid #ec002c;
}
.home_initiatives a:hover .arrow {
  background: #ec002c;
}
.home_initiatives a:hover .arrow:before {
  border: 6px solid #ec002c;
}
.home_initiatives a:hover .arrow.-right:before {
  border-left: 0;
  border-bottom: 0;
}

#home_sdgs_mark {
  width: 70%;
}

.update .inner {
  padding: 64px 120px 120px 120px;
  display: flex;
  flex-wrap: wrap;
}
.update h4 {
  color: #ec002c;
  font-size: 40px;
  font-weight: 800;
  text-align: right;
  display: inline-block;
  letter-spacing: 0em;
}
.update h4 span {
  font-size: 13px;
  font-weight: 600;
  display: block;
  padding-top: 8px;
}
.update dl {
  width: 640px;
  display: flex;
  overflow-wrap: wrap;
  padding-left: 40px;
}
.update dl dt, .update dl dd {
  font-size: 14px;
  font-weight: 500;
  line-height: 1.44em;
  padding: 16px 0px;
  border-bottom: 1px solid rgba(1, 152, 122, 0.4);
  text-align: left;
  position: relative;
}
.update dl dt {
  width: 112px;
}
.update dl dd {
  width: calc(100% - 112px);
}
.update dl .arrow {
  line-height: 3;
  position: absolute;
  top: 24px;
  right: 8px;
  background: #01987a;
  display: block;
}
.update dl .arrow:before {
  content: "";
  width: 13px;
  height: 13px;
  border: 3px solid #01987a;
  position: absolute;
  box-sizing: border-box;
}
.update dl .arrow.-right {
  width: 16px;
  height: 3px;
}
.update dl .arrow.-right:before {
  border-left: 0;
  border-bottom: 0;
  transform: rotate(45deg);
  transform-origin: top right;
  top: calc(50% - 1px);
  right: -2px;
}

.home_insta {
  padding: 32px 160px;
  margin-bottom: 96px;
}
.home_insta img {
  width: 48px;
  height: 48px;
  margin-left: 16px;
}
.home_insta h3 {
  font-size: 18px;
  font-weight: 700;
}
.home_insta a {
  border: 6px solid #fff;
  display: block;
  box-shadow: 0 0 3px #999;
  border-radius: 8px;
  padding: 16px;
  text-decoration: none;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  background: linear-gradient(-15deg, rgba(84, 28, 245, 0.1), rgba(234, 63, 107, 0.1));
}
.home_insta a:hover {
  background: linear-gradient(-15deg, rgba(84, 28, 245, 0.7), rgba(234, 63, 107, 0.7));
}
.home_insta a:hover img {
  filter: invert(100%) sepia(0%) saturate(0%) hue-rotate(93deg) brightness(3000%) contrast(103%);
}
.home_insta a:hover h3 {
  color: #fff;
}

.home_about {
  background: url(images/home_about_bg.jpg) no-repeat;
  background-size: cover;
  padding-top: 184px;
  padding-bottom: 72px;
}
.home_about h3 {
  font-family: "Open Sans", "Noto Serif JP", serif;
  color: #fff;
  font-size: 64px;
  font-weight: 600;
  padding-bottom: 32px;
}
.home_about p {
  color: #fff;
}

.home_about_inner {
  display: flex;
  flex-wrap: wrap;
  text-align: left;
}
.home_about_inner div {
  width: 384px;
}
.home_about_inner div p {
  line-height: 1.68em;
}
.home_about_inner ul {
  width: 160px;
  margin-top: 8px;
}
.home_about_inner ul li a {
  display: block;
  text-decoration: none;
  color: #fff;
  font-size: 18px;
  font-weight: 500;
  margin-bottom: 24px;
  position: relative;
}
.home_about_inner ul li a .arrow {
  line-height: 1;
  position: relative;
  top: 11px;
  left: -26px;
  background: #fff;
  display: block;
}
.home_about_inner ul li a .arrow:before {
  content: "";
  width: 8px;
  height: 8px;
  border: 2px solid #fff;
  position: absolute;
  box-sizing: border-box;
}
.home_about_inner ul li a .arrow.-right {
  width: 14px;
  height: 2px;
}
.home_about_inner ul li a .arrow.-right:before {
  border-left: 0;
  border-bottom: 0;
  transform: rotate(45deg);
  transform-origin: top right;
  top: 50%;
  right: -1px;
}

.home_inq {
  background: linear-gradient(to right, #fff 0%, #fff 50%, transparent 50%, transparent 100%);
  margin-top: 360px;
}
.home_inq ul {
  background: #fff;
  display: flex;
  flex-wrap: wrap;
  padding: 32px 48px 24px 48px;
  margin-left: calc((100svw - 1080px) / 2);
  border-radius: 12px;
  width: 840px;
}
.home_inq ul li {
  width: 50%;
}
.home_inq ul li p {
  font-weight: 500;
  color: #000;
}
.home_inq ul li p.telNo {
  padding: 8px 0px 12px 0px;
  font-size: 48px;
  font-weight: 700;
  color: #01987a;
}
.home_inq ul li p.telNo + p {
  font-weight: 400;
  font-size: 14px;
}
.home_inq ul li a {
  width: 264px;
  background: #000;
  padding: 19px 32px 20px 32px;
  line-height: 1em;
  text-decoration: none;
  color: #fff;
  font-size: 18px;
  font-weight: 500;
  display: block;
  margin: 16px auto auto auto;
  border-radius: 32px;
}

/* ============================================================================== */
/* common */
/* ============================================================================== */
.common h1 {
  color: #fff !important;
}
.common header h2 {
  top: 192px;
  right: 0;
  z-index: 10;
  letter-spacing: 0;
  text-align: right;
}
.common nav img {
  filter: brightness(0) saturate(100%) invert(100%) sepia(100%) saturate(0%) hue-rotate(78deg) brightness(103%) contrast(103%);
}

.common_header {
  height: 280px;
  position: relative;
  overflow: hidden;
}
.common_header img {
  width: 100svw;
  height: 280px;
  object-fit: cover;
  display: block;
  position: relative;
}
.common_header div {
  position: absolute;
  top: 0;
  bottom: 2px;
  left: 0;
  right: 0;
  background: linear-gradient(40deg, rgba(1, 152, 122, 0.6), rgba(1, 152, 122, 0.1));
  mix-blend-mode: multiply;
  z-index: 1;
}

.block {
  display: flex;
  flex-wrap: wrap;
  text-align: left;
  margin: 96px 0px;
}

.block_left {
  width: 320px;
}

.block_right {
  width: calc(100% - 320px);
}
.block_right h5 {
  font-weight: 500;
  font-size: 32px;
  color: #01987a;
  margin-bottom: 40px;
  margin-top: 160px;
  line-height: 1.44em;
}
.block_right h5.space_n {
  margin-top: 0px;
}

/* ============================================================================== */
/* company */
/* ============================================================================== */
#company {
  text-align: left;
}
#company iframe {
  width: 1080px;
  height: 360px;
  border: none;
  margin: 88px 64px 32px 0px;
}
#company .block h3 {
  width: 320px;
  font-size: 28px;
  font-weight: 700;
  font-family: "BIZ UDGothic", serif;
}
#company .block h3 span {
  display: block;
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  color: #01987a;
  margin-bottom: 8px;
}
#company .block dl {
  display: flex;
  flex-wrap: wrap;
}
#company .block dl dt, #company .block dl dd {
  padding: 16px 0px;
  line-height: 1.44em;
  border-bottom: 1px solid rgba(1, 152, 122, 0.2);
}
#company .block dl dt {
  padding-right: 32px;
}

.greeting {
  margin-bottom: 120px;
}
.greeting p {
  line-height: 1.92em;
  padding-bottom: 48px;
}
.greeting img {
  width: 400px;
  margin-left: calc(100% - 400px);
  margin-bottom: 8px;
}

#company_i2 {
  width: 240px;
  margin-top: 32px;
}

#company_i7 {
  width: 100%;
  margin-bottom: 48px;
}

.history {
  margin-bottom: 120px;
}
.history dt {
  width: 136px;
  text-align: right;
}
.history dd {
  width: calc(100% - 136px);
}

.overview dt {
  width: 160px;
}
.overview dd {
  width: calc(100% - 160px);
}
.overview dd ul {
  margin-left: 19px;
}
.overview dd li {
  list-style-type: disc;
  line-height: 1.6em;
}

.jyuki {
  width: calc((100svw - 1080px) / 2 + 1080px);
  height: 18svw;
  overflow: hidden;
  margin-left: calc((-100svw + 1080px) / 2);
}
.jyuki div {
  display: flex;
  flex-wrap: wrap;
  justify-content: end;
  width: 100svw;
  margin-left: calc((-100svw + 1080px) / 2);
}
.jyuki img {
  height: 18svw;
  margin-right: 16px;
}
.jyuki img:last-of-type {
  margin-right: 0px;
}

.access_route {
  margin-top: -96px;
  margin-bottom: 160px;
}
.access_route p {
  line-height: 1.6em;
}

/* ============================================================================== */
/* works */
/* ============================================================================== */
#works .block_right p {
  line-height: 1.84em;
}
#works .block_right p.green_txt {
  font-size: 17px;
  margin-top: 24px;
  color: #01987a;
  font-weight: 600;
}

.works_li {
  background: #e5efeb;
  width: calc((100svw - 1080px) / 2 + 1080px);
  margin-left: calc((-100svw + 1080px) / 2);
  margin-bottom: 32px;
}
.works_li ul {
  width: 1080px;
  display: flex;
  flex-wrap: wrap;
  margin-left: calc((100svw - 1080px) / 2);
}
.works_li ul li {
  width: 33.3333333333%;
  padding: 64px 24px 48px 24px;
}
.works_li ul li img {
  width: 216px;
  margin: 0px auto;
  border-radius: 50%;
}
.works_li ul li h4 {
  font-size: 21px;
  font-weight: 700;
  color: #01987a;
  padding: 32px 0px 24px 0px;
}
.works_li ul li p {
  text-align: left;
  line-height: 1.6em;
  padding: 0px 8px;
}
.works_li ul li:last-of-type {
  background: #f8e0e0;
}
.works_li ul li:last-of-type h4 {
  color: #ec002c;
}

.smw_li {
  margin-bottom: 160px;
}
.smw_li h3 {
  font-size: 24px !important;
  margin-bottom: 32px;
}
.smw_li ul {
  margin-top: 64px;
  margin-left: -120px;
}
.smw_li li {
  display: table;
  margin-bottom: 24px;
  position: relative;
}
.smw_li li:after {
  content: "";
  display: block;
  position: absolute;
  width: 80px;
  height: 20px;
  background: radial-gradient(rgba(1, 152, 122, 0.5) 30%, transparent 30%) transparent;
  background-size: 20px 20px;
}
.smw_li li img {
  width: 224px;
  border-radius: 50%;
  border: 12px solid rgba(1, 152, 122, 0.5);
  margin-right: 32px;
}
.smw_li li div {
  display: table-cell;
  vertical-align: middle;
}
.smw_li li h4 {
  font-size: 18px;
  font-weight: 700;
  color: #01987a;
  padding-bottom: 8px;
}
.smw_li li p {
  width: 320px;
  line-height: 1.44em;
}
.smw_li li:first-of-type:after {
  transform: rotate(45deg);
  left: 144px;
  top: 232px;
}
.smw_li li:last-of-type:after {
  transform: rotate(-45deg);
  left: 144px;
  top: -29px;
}
.smw_li li:nth-of-type(even) {
  margin-left: 160px;
}
.smw_li li:nth-of-type(even):after {
  content: none;
}

.our_stg {
  width: 1080px;
  margin-bottom: 160px;
  margin-top: -96px;
}
.our_stg ul {
  display: flex;
  flex-wrap: wrap;
  align-items: start;
  justify-content: end;
}
.our_stg ul li {
  width: 344px;
  box-shadow: 0 0 3px #ccc;
  margin-left: 24px;
}
.our_stg ul li img {
  width: 100%;
}
.our_stg ul li h4 {
  font-size: 21px;
  font-weight: 700;
  color: #ec002c;
  padding: 24px 16px 16px 16px;
  line-height: 1.28em;
}
.our_stg ul li p {
  text-align: left;
  line-height: 1.68em;
  padding: 0px 24px 24px 24px;
}
.our_stg ul li:first-of-type {
  margin-top: 200px;
  margin-left: 0px;
}
.our_stg ul li:nth-of-type(2) {
  margin-top: 100px;
}

/* ============================================================================== */
/* cases */
/* ============================================================================== */
#cases .block h3, #initiatives .block h3, #works .block h3 {
  width: 320px;
  font-size: 28px;
  font-weight: 700;
  font-family: "BIZ UDGothic", serif;
}
#cases .block h3 span, #initiatives .block h3 span, #works .block h3 span {
  display: block;
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  color: #01987a;
  margin-bottom: 8px;
}

#cases .block h3 {
  width: 224px;
}
#cases .block caption {
  font-size: 32px;
  font-weight: 700;
  text-align: left;
  margin-bottom: 16px;
}
#cases .block table {
  width: 856px;
  margin-bottom: 88px;
  border-collapse: collapse;
  border-spacing: 0;
}
#cases .block table th {
  padding: 12px 8px;
  font-weight: 600;
  text-align: center;
  background: rgba(1, 152, 122, 0.15);
  border-right: 1px solid #fff;
}
#cases .block table th:last-of-type {
  border-right: noen;
}
#cases .block table td {
  padding: 18px 8px;
  border-bottom: 1px solid #ccc;
}

.year_btn {
  margin-bottom: 72px;
  display: flex;
  flex-wrap: wrap;
}
.year_btn li {
  width: 33.33%;
  padding: 8px;
}
.year_btn li a {
  display: block;
  text-decoration: none;
  padding: 16px;
  width: 100%;
  background: #ec002c;
  color: #fff;
  border-radius: 4px;
  text-align: center;
  font-size: 18px;
  font-weight: 700;
}
.year_btn li a:hover {
  background: #01987a;
}

/* ============================================================================== */
/* initiatives */
/* ============================================================================== */
#initiatives .block_right p {
  line-height: 1.84em;
}

#header_initiatives h2 {
  letter-spacing: -0.1em !important;
}

.for_ex {
  background: url(images/initi_i9.jpg) no-repeat;
  background-size: cover;
  padding: 144px 32px 96px 32px;
  margin-top: 104px;
  margin-bottom: -88px;
}
.for_ex h4 {
  font-size: 48px;
  color: #fff;
  font-weight: 600;
  margin-left: -96px;
  font-family: "Open Sans", "Noto Serif JP", serif;
  text-shadow: 0 0 15px #000, 0 0 15px #000, 0 0 3px #333;
}
.for_ex ul {
  display: flex;
  flex-wrap: wrap;
  padding-right: 64px;
  margin-top: 32px;
}
.for_ex ul li {
  box-shadow: 0 0 3px #999;
  padding: 32px;
  margin: 16px;
  width: calc(33.3333333333% - 32px);
  background: #fff;
  position: relative;
}
.for_ex ul li h5 {
  font-size: 18px !important;
  font-weight: 700 !important;
  margin-top: 0px !important;
  margin-bottom: 16px !important;
  color: #000 !important;
}
.for_ex ul li p {
  text-align: left;
  line-height: 1.6em;
  font-size: 15px;
}
.for_ex ul li:nth-of-type(even) {
  top: 64px;
}

.initi_li {
  width: calc((100svw - 1080px) / 2 + 1080px);
  margin-left: calc((-100svw + 1080px) / 2);
  background: rgba(236, 0, 44, 0.1);
  margin-bottom: 160px;
  position: relative;
  padding-top: 48px;
}
.initi_li ul {
  width: 1080px;
  margin-left: calc((100svw - 1080px) / 2);
  display: flex;
  flex-wrap: wrap;
  padding: 24px 24px 24px 0px;
}
.initi_li li {
  width: calc(33.3333333333% - 16px);
  margin: 8px;
  background: #fff;
  padding: 16px;
}
.initi_li li img {
  width: 100%;
}
.initi_li li h4 {
  font-size: 18px;
  font-weight: 600;
  color: #ec002c;
  margin: 16px auto;
}
.initi_li li p {
  text-align: left;
  line-height: 1.6em;
  margin: 8px 8px;
}
.initi_li li:nth-of-type() {
  margin-left: 0px;
}

.ticker {
  overflow: hidden;
  position: absolute;
  width: 100%;
  height: 208px;
  top: -44px;
  left: 0px;
  display: flex;
  justify-content: flex-start;
  overflow: hidden;
}
.ticker p {
  display: flex;
  animation: animate-banner 60s linear infinite;
}
.ticker p span {
  font-size: 88px !important;
  display: inline-block;
  color: rgba(236, 0, 44, 0.3) !important;
  white-space: nowrap;
  font-weight: 700;
}

@keyframes animate-banner {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}
.inti_doc {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
}
.inti_doc img {
  width: 240px;
  margin: 32px;
  border: 1px solid #ccc;
}

.comm_svs {
  margin-bottom: 160px;
}
.comm_svs img {
  width: 320px;
}

.sdgs {
  margin-top: 88px;
}

.sdgs_box {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 120px;
}

.sdgs_box_ico {
  border-right: 1px dotted rgba(1, 152, 122, 0.5);
  width: 96px;
  margin-right: 32px;
  padding-right: 32px;
}
.sdgs_box_ico img {
  width: 100%;
  display: block;
  margin-bottom: 16px;
}

.sdgs_box_txt {
  width: calc(100% - 128px);
}

.sdgs_wrap {
  clear: both;
}
.sdgs_wrap h6 {
  position: relative;
  padding: 8px 12px;
  width: fit-content;
  border-bottom: 2px solid #01987a;
  color: #01987a;
  font-weight: 700;
  margin-bottom: 16px;
}
.sdgs_wrap h6::before {
  content: "";
  position: absolute;
  bottom: -10px;
  left: 50%;
  width: 16px;
  height: 16px;
  box-sizing: border-box;
  background-color: #fff;
  translate: -50%;
}
.sdgs_wrap h6::after {
  content: "";
  position: absolute;
  bottom: -8px;
  left: 49%;
  width: 20px;
  height: 20px;
  box-sizing: border-box;
  border-top: 2px solid #01987a;
  rotate: -135deg;
}
.sdgs_wrap p {
  font-weight: 600;
  font-size: 17px;
  line-height: 1.68em !important;
}

#sdgs_link {
  display: block;
  width: 560px;
  margin-left: 160px;
  text-align: center;
  color: #fff;
  font-size: 18px;
  font-weight: 600;
  background: #01987a;
  padding: 16px;
  text-decoration: none;
  border-radius: 8px;
}
#sdgs_link:hover {
  background: #ec002c;
}

/* ============================================================================== */
/* inquiry */
/* ============================================================================== */
#inquiry {
  padding: 96px 0px 48px 0px;
}
#inquiry h3 {
  font-size: 24px;
  margin-bottom: 48px;
}
#inquiry form {
  width: 784px;
  margin-left: 144px;
  margin-bottom: 120px;
  text-align: left;
}
#inquiry form dl {
  margin-bottom: 32px;
  box-shadow: 0 0 3px #999;
  border-radius: 8px;
  padding: 48px;
}
#inquiry form dt {
  font-size: 14px;
  font-weight: 600;
  padding: 16px 24px 16px 0px;
  position: relative;
}
#inquiry form dt.required {
  padding: 16px 24px 16px 48px;
}
#inquiry form dt.required:before {
  position: absolute;
  top: 16px;
  left: 0px;
  content: "必須";
  display: inline-block;
  background: #ec002c;
  border-radius: 4px;
  padding: 2px 8px;
  color: #fff;
  font-size: 12px;
}
#inquiry form dd {
  font-size: 18px;
  padding-bottom: 24px;
}
#inquiry form dd input, #inquiry form dd textarea {
  width: 100%;
  background: rgba(1, 152, 122, 0.1);
  border: none;
  padding: 16px 24px;
  border-radius: 8px;
  margin-bottom: 12px;
}
#inquiry form dd input::placeholder, #inquiry form dd textarea::placeholder {
  line-height: 1.28em;
}
#inquiry form dd input.is-error, #inquiry form dd textarea.is-error {
  background: #f2dddd;
}
#inquiry form dd textarea {
  height: 160px;
}
#inquiry form dd p {
  line-height: 1.44em;
}
#inquiry form dd p.kome {
  margin-bottom: 16px;
}
#inquiry form dd p .is-error {
  color: #ff869d;
  display: block;
  padding-bottom: 16px;
  margin-top: -4px;
}
#inquiry form .btn {
  color: #fff;
  width: 200px;
  display: inline-block;
  padding: 16px;
  background: #000;
  border: 1px solid rgba(255, 255, 255, 0.7);
  border-radius: 8px;
  cursor: pointer;
}
#inquiry form #submit {
  background: #ec002c;
  border: 1px solid #ec002c;
  margin-left: 184px;
  margin-right: 16px;
}
#inquiry form #submit:disabled {
  background: #999;
  border: 1px solid #999;
  cursor: default;
  color: rgba(255, 255, 255, 0.7);
}

.form_comm {
  width: 480px;
  text-align: left;
  margin: 48px auto 120px auto;
  line-height: 1.68em;
}

/* ============================================================================== */
/* mail */
/* ============================================================================== */
#mail {
  background: #fff;
}
#mail .wrap h3 {
  font-size: 24px;
  margin-bottom: 64px;
}
#mail .confirm dl {
  margin: 48px auto 32px auto;
  padding: 32px;
  box-shadow: 0 0 3px #999;
  border-radius: 8px;
  width: 760px;
  display: flex;
  flex-wrap: wrap;
}
#mail .confirm dt, #mail .confirm dd {
  border-bottom: 1px solid #cdc;
  padding: 24px 16px;
  text-align: left;
}
#mail .confirm dt:last-of-type, #mail .confirm dd:last-of-type {
  border-bottom: none;
}
#mail .confirm dt {
  width: 168px;
}
#mail .confirm dd {
  width: calc(100% - 168px);
  border-left: 1px solid #cdc;
  padding-left: 24px;
}
#mail .btn {
  width: 200px;
  display: inline-block;
  margin: 24px 4px 32px 4px;
  padding: 16px;
  border: none;
  border-radius: 8px;
  background: #bbb;
  cursor: pointer;
}
#mail .btn[type=submit] {
  background: #ec002c;
  color: #fff;
}
#mail .btn:hover {
  background: #000;
  color: #fff;
}

.caution {
  margin-bottom: 120px;
}

/* ============================================================================== */
/* thanks */
/* ============================================================================== */
#thanks {
  margin-bottom: 160px;
}
#thanks h3 {
  font-size: 24px;
  margin-bottom: 48px;
}
#thanks p {
  padding: 0px 184px 64px 184px;
  text-align: left;
  line-height: 1.68em;
}

#thanks_logo {
  width: 240px;
  height: 178px;
  margin: 64px auto;
}

#go_home {
  display: block;
  width: 320px;
  box-shadow: 0 0 3px #999;
  border-radius: 4px;
  padding: 16px 24px;
  margin: 24px auto 88px auto;
  text-decoration: none;
}

#contact ul {
  display: flex;
  flex-wrap: wrap;
  padding: 0px 160px 120px 160px;
}
#contact ul li {
  width: 50%;
  background: #000;
}
#contact ul li h4 {
  color: #fff;
  font-size: 18px;
  padding: 48px 32px 16px 32px;
}
#contact ul li p {
  padding: 0px 0px 24px 0px !important;
  text-align: center !important;
  font-size: 32px;
  font-weight: 600;
  color: #fff;
}
#contact ul li:last-of-type {
  background: #01987a;
}

/* ============================================================================== */
/* footer */
/* ============================================================================== */
#pagetop {
  position: fixed;
  display: block;
  width: 36px;
  height: 36px;
  border-radius: 18px;
  bottom: 20px;
  right: 20px;
  z-index: 100000;
  background: #01987a;
  text-align: center;
  cursor: pointer;
}
#pagetop:before {
  content: "";
  width: 8px;
  height: 8px;
  border: 0px;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  -ms-transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  position: absolute;
  top: 50%;
  left: 50%;
  margin-left: -5px;
  margin-top: -3px;
}
#pagetop:hover {
  background: #000;
}

.recruit {
  background: #b90022;
  padding: 32px 56px 16px 0px;
}
.recruit .inner {
  display: flex;
  flex-wrap: wrap;
}
.recruit h6 {
  font-size: 56px;
  font-weight: 800;
  letter-spacing: 0em;
  width: 280px;
  margin-top: -6px;
  text-align: left;
}
.recruit p {
  width: calc(100% - 420px);
  color: #fff;
  text-align: left;
  line-height: 1.68em;
  font-size: 14px;
  font-weight: 400;
}
.recruit p strong {
  color: #fff;
  font-size: 30px;
  font-weight: 500;
  display: block;
  margin-bottom: 16px;
}
.recruit a {
  display: block;
  width: 120px;
  height: 120px;
  color: #fff;
  border: 1px solid #fff;
  border-radius: 50%;
  line-height: 96px;
  text-align: center;
  text-decoration: none;
  font-size: 14px;
  position: relative;
  margin-top: -8px;
}
.recruit a .arrow {
  line-height: 1;
  position: absolute;
  top: 80px;
  left: 50%;
  margin-left: -10px;
  background: #fff;
  display: block;
}
.recruit a .arrow:before {
  content: "";
  width: 8px;
  height: 8px;
  border: 2px solid #fff;
  position: absolute;
  box-sizing: border-box;
}
.recruit a .arrow.-right {
  width: 14px;
  height: 2px;
}
.recruit a .arrow.-right:before {
  border-left: 0;
  border-bottom: 0;
  transform: rotate(45deg);
  transform-origin: top right;
  top: 50%;
  right: -1px;
}
.recruit a:hover {
  background: #b90022;
}

#footer_rec_img {
  position: absolute;
  bottom: -16px;
  right: 96px;
  width: 264px;
}

footer {
  background: rgba(1, 152, 122, 0.2);
  padding: 32px 0px;
}

.footer_inner {
  display: flex;
  flex-wrap: wrap;
}

.footer_left {
  width: 320px;
  text-align: left;
}
.footer_left img {
  width: 248px;
}

.footer_right {
  width: calc(100% - 320px);
  position: relative;
}
.footer_right p {
  font-size: 14px;
  text-align: left;
  line-height: 1.68em;
}

.footer_nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: start;
  padding-top: 16px;
}
.footer_nav li {
  padding: 12px;
}
.footer_nav li a {
  text-decoration: none;
}
.footer_nav li a.insta {
  width: 24px;
  height: 24px;
  position: relative;
}
.footer_nav li a.insta:before {
  content: "";
  position: absolute;
  top: -4px;
  left: 0px;
  background: url("data:image/svg+xml;utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2088%2088%22%20xml%3Aspace%3D%22preserve%22%3E%3Cpath%20fill%3D%22%23000%22%20d%3D%22M25.8%2C0.3c-4.7%2C0.2-7.9%2C1-10.7%2C2.1C12.2%2C3.5%2C9.8%2C5%2C7.3%2C7.5s-3.9%2C4.9-5.1%2C7.8c-1.1%2C2.8-1.8%2C6-2%2C10.7%20S0%2C32.1%2C0%2C44.1s0.1%2C13.4%2C0.3%2C18.1c0.2%2C4.7%2C1%2C7.9%2C2.1%2C10.7c1.1%2C2.9%2C2.6%2C5.3%2C5.1%2C7.8c2.4%2C2.4%2C4.9%2C3.9%2C7.8%2C5.1c2.8%2C1.1%2C6%2C1.8%2C10.7%2C2%20C30.6%2C88%2C32.1%2C88%2C44.1%2C88s13.4-0.1%2C18.1-0.3c4.7-0.2%2C7.9-1%2C10.7-2.1c2.9-1.1%2C5.3-2.6%2C7.8-5.1c2.4-2.4%2C3.9-4.9%2C5.1-7.8%20c1.1-2.8%2C1.8-6%2C2-10.7C88%2C57.4%2C88%2C55.9%2C88%2C43.9s-0.1-13.4-0.3-18.1c-0.2-4.7-1-7.9-2.1-10.7c-1.1-2.9-2.6-5.3-5.1-7.8%20c-2.4-2.4-4.9-3.9-7.8-5.1c-2.8-1.1-6-1.8-10.7-2S55.9%2C0%2C43.9%2C0S30.5%2C0.1%2C25.8%2C0.3%20M26.3%2C79.9c-4.3-0.2-6.6-0.9-8.2-1.5%20c-2.1-0.8-3.5-1.7-5.1-3.3c-1.5-1.5-2.5-3-3.3-5.1c-0.6-1.6-1.3-3.9-1.5-8.2C8%2C57.2%2C8%2C55.8%2C7.9%2C44.1s0-13.1%2C0.2-17.8%20c0.2-4.3%2C0.9-6.6%2C1.5-8.2c0.8-2.1%2C1.7-3.5%2C3.3-5.1s3-2.5%2C5.1-3.3c1.6-0.6%2C3.9-1.3%2C8.2-1.5c4.6-0.2%2C6-0.3%2C17.8-0.3s13.1%2C0%2C17.8%2C0.2%20c4.3%2C0.2%2C6.6%2C0.9%2C8.2%2C1.5c2.1%2C0.8%2C3.5%2C1.7%2C5.1%2C3.3s2.5%2C3%2C3.3%2C5.1c0.6%2C1.5%2C1.3%2C3.9%2C1.5%2C8.2c0.2%2C4.6%2C0.3%2C6%2C0.3%2C17.8s0%2C13.1-0.2%2C17.8%20c-0.2%2C4.3-0.9%2C6.6-1.5%2C8.2c-0.8%2C2.1-1.7%2C3.5-3.3%2C5.1c-1.5%2C1.5-3%2C2.5-5.1%2C3.3c-1.5%2C0.6-3.9%2C1.3-8.2%2C1.5c-4.6%2C0.2-6%2C0.3-17.8%2C0.3%20S30.9%2C80.1%2C26.3%2C79.9%20M62.2%2C20.5c0%2C2.9%2C2.4%2C5.3%2C5.3%2C5.3c2.9%2C0%2C5.3-2.4%2C5.3-5.3s-2.4-5.3-5.3-5.3c0%2C0%2C0%2C0%2C0%2C0%20C64.5%2C15.2%2C62.2%2C17.6%2C62.2%2C20.5%20M21.4%2C44c0%2C12.5%2C10.2%2C22.6%2C22.6%2C22.5c12.5%2C0%2C22.6-10.2%2C22.6-22.6c0-12.5-10.2-22.6-22.6-22.5%20C31.5%2C21.4%2C21.4%2C31.6%2C21.4%2C44%20M29.3%2C44c0-8.1%2C6.5-14.7%2C14.6-14.7c8.1%2C0%2C14.7%2C6.5%2C14.7%2C14.6c0%2C8.1-6.5%2C14.7-14.6%2C14.7%20C35.9%2C58.7%2C29.3%2C52.1%2C29.3%2C44C29.3%2C44%2C29.3%2C44%2C29.3%2C44%22%20%2F%3E%3C%2Fsvg%3E");
  display: block;
  width: 24px;
  height: 24px;
}
.footer_nav li a.insta:hover:before {
  background: url("data:image/svg+xml;utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2088%2088%22%20xml%3Aspace%3D%22preserve%22%3E%3Cpath%20fill%3D%22%2301987a%22%20d%3D%22M25.8%2C0.3c-4.7%2C0.2-7.9%2C1-10.7%2C2.1C12.2%2C3.5%2C9.8%2C5%2C7.3%2C7.5s-3.9%2C4.9-5.1%2C7.8c-1.1%2C2.8-1.8%2C6-2%2C10.7%20S0%2C32.1%2C0%2C44.1s0.1%2C13.4%2C0.3%2C18.1c0.2%2C4.7%2C1%2C7.9%2C2.1%2C10.7c1.1%2C2.9%2C2.6%2C5.3%2C5.1%2C7.8c2.4%2C2.4%2C4.9%2C3.9%2C7.8%2C5.1c2.8%2C1.1%2C6%2C1.8%2C10.7%2C2%20C30.6%2C88%2C32.1%2C88%2C44.1%2C88s13.4-0.1%2C18.1-0.3c4.7-0.2%2C7.9-1%2C10.7-2.1c2.9-1.1%2C5.3-2.6%2C7.8-5.1c2.4-2.4%2C3.9-4.9%2C5.1-7.8%20c1.1-2.8%2C1.8-6%2C2-10.7C88%2C57.4%2C88%2C55.9%2C88%2C43.9s-0.1-13.4-0.3-18.1c-0.2-4.7-1-7.9-2.1-10.7c-1.1-2.9-2.6-5.3-5.1-7.8%20c-2.4-2.4-4.9-3.9-7.8-5.1c-2.8-1.1-6-1.8-10.7-2S55.9%2C0%2C43.9%2C0S30.5%2C0.1%2C25.8%2C0.3%20M26.3%2C79.9c-4.3-0.2-6.6-0.9-8.2-1.5%20c-2.1-0.8-3.5-1.7-5.1-3.3c-1.5-1.5-2.5-3-3.3-5.1c-0.6-1.6-1.3-3.9-1.5-8.2C8%2C57.2%2C8%2C55.8%2C7.9%2C44.1s0-13.1%2C0.2-17.8%20c0.2-4.3%2C0.9-6.6%2C1.5-8.2c0.8-2.1%2C1.7-3.5%2C3.3-5.1s3-2.5%2C5.1-3.3c1.6-0.6%2C3.9-1.3%2C8.2-1.5c4.6-0.2%2C6-0.3%2C17.8-0.3s13.1%2C0%2C17.8%2C0.2%20c4.3%2C0.2%2C6.6%2C0.9%2C8.2%2C1.5c2.1%2C0.8%2C3.5%2C1.7%2C5.1%2C3.3s2.5%2C3%2C3.3%2C5.1c0.6%2C1.5%2C1.3%2C3.9%2C1.5%2C8.2c0.2%2C4.6%2C0.3%2C6%2C0.3%2C17.8s0%2C13.1-0.2%2C17.8%20c-0.2%2C4.3-0.9%2C6.6-1.5%2C8.2c-0.8%2C2.1-1.7%2C3.5-3.3%2C5.1c-1.5%2C1.5-3%2C2.5-5.1%2C3.3c-1.5%2C0.6-3.9%2C1.3-8.2%2C1.5c-4.6%2C0.2-6%2C0.3-17.8%2C0.3%20S30.9%2C80.1%2C26.3%2C79.9%20M62.2%2C20.5c0%2C2.9%2C2.4%2C5.3%2C5.3%2C5.3c2.9%2C0%2C5.3-2.4%2C5.3-5.3s-2.4-5.3-5.3-5.3c0%2C0%2C0%2C0%2C0%2C0%20C64.5%2C15.2%2C62.2%2C17.6%2C62.2%2C20.5%20M21.4%2C44c0%2C12.5%2C10.2%2C22.6%2C22.6%2C22.5c12.5%2C0%2C22.6-10.2%2C22.6-22.6c0-12.5-10.2-22.6-22.6-22.5%20C31.5%2C21.4%2C21.4%2C31.6%2C21.4%2C44%20M29.3%2C44c0-8.1%2C6.5-14.7%2C14.6-14.7c8.1%2C0%2C14.7%2C6.5%2C14.7%2C14.6c0%2C8.1-6.5%2C14.7-14.6%2C14.7%20C35.9%2C58.7%2C29.3%2C52.1%2C29.3%2C44C29.3%2C44%2C29.3%2C44%2C29.3%2C44%22%20%2F%3E%3C%2Fsvg%3E");
}
.footer_nav li:first-of-type {
  padding-left: 0px;
}
.footer_nav li:last-of-type {
  padding-right: 0px;
}

.copyright {
  text-align: right;
  padding: 24px 0px 0px 0px;
  font-size: 14px;
}

/* ============================================================================== */
/* 個別設定 */
/* ============================================================================== */
.alignleft {
  float: left;
}

.alignright {
  float: right;
  margin-left: 32px;
  margin-bottom: 24px;
}

.aligncenter {
  text-align: center;
  margin: 0px auto;
}

.middle {
  width: 420px;
}

.f_center {
  text-align: center;
  margin: 0px auto;
}

.t_left {
  text-align: left !important;
}

.t_right {
  text-align: right !important;
}

.t_center {
  text-align: center;
  margin: 0px auto;
}

.d_none {
  display: none;
}

.clear {
  clear: both !important;
}

.red {
  color: #ec002c;
}

.kome {
  text-indent: -1.2em;
  margin-left: 1.2em;
}
