:root {
  --viewport-width: 100vw;
  --b: calc(var(--viewport-width) / 160);
}

@media screen and (max-width: 550px) {
  :root {
    --viewport-width: max(100vw, 550px);
    --b: calc(var(--viewport-width) / 55);
  }
}
#diwks .intro {
  padding-top: 11.5rem;
  padding-bottom: 11rem;
}
@media screen and (max-width: 550px) {
  #diwks .intro {
    padding-top: 40px;
    padding-bottom: 50px;
  }
}
#diwks .intro__inner {
  gap: 6rem;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 768px) {
  #diwks .intro__inner {
    flex-direction: column;
  }
}
@media screen and (max-width: 550px) {
  #diwks .intro__inner {
    gap: 30px;
  }
}
#diwks .intro__inner .intro__inner--image {
  width: max(25.5rem, 250px);
}
@media screen and (max-width: 550px) {
  #diwks .intro__inner .intro__inner--image {
    width: 80%;
  }
}
#diwks .intro__inner .intro__inner--text {
  flex: 1;
}
@media screen and (max-width: 768px) {
  #diwks .intro__inner .intro__inner--text {
    text-align: center;
  }
}
#diwks .intro__inner .intro__inner--text b {
  display: block;
  color: #007440;
  font-size: max(2.9rem, 26px);
  font-weight: 600;
  line-height: 2;
  letter-spacing: 0.3em;
  margin-bottom: 1rem;
}
@media screen and (max-width: 550px) {
  #diwks .intro__inner .intro__inner--text b {
    font-size: 26px;
    letter-spacing: 0.2em;
    margin-bottom: 10px;
  }
}
#diwks .intro__inner .intro__inner--text b span {
  display: inline-block;
  color: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  letter-spacing: inherit;
}
#diwks .cta {
  background: linear-gradient(to bottom, transparent 20%, #007440 20%);
}
#diwks .cta__inner {
  display: flex;
  margin: 0 auto;
  margin-top: 15rem;
  border: 1px solid #007440;
  background: #fff;
  transform: translateY(-30%);
}
@media screen and (max-width: 1000px) {
  #diwks .cta__inner {
    margin-top: 40rem;
    flex-direction: column;
  }
}
@media screen and (max-width: 550px) {
  #diwks .cta__inner {
    margin-top: 100px;
    transform: translateY(-10%);
  }
}
#diwks .cta__inner--image {
  position: relative;
  width: 69rem;
}
@media screen and (max-width: 1000px) {
  #diwks .cta__inner--image {
    width: 100%;
  }
}
#diwks .cta__inner--image img {
  width: 100%;
  height: 100%;
  -o-object-position: right center;
     object-position: right center;
}
#diwks .cta__inner--image span {
  position: absolute;
  display: grid;
  place-items: center;
  text-align: center;
  top: 0;
  left: 0;
  padding: 4rem 4rem;
  color: #fff;
  font-size: max(1.9rem, 14px);
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0.1em;
  background: #007440;
}
@media screen and (max-width: 1000px) {
  #diwks .cta__inner--image span {
    padding: 6rem 6rem;
    font-size: max(4rem, 14px);
  }
}
@media screen and (max-width: 550px) {
  #diwks .cta__inner--image span {
    font-size: 14px;
    padding: 10px 20px;
  }
}
#diwks .cta__inner--text {
  flex: 1;
  padding: 4rem 5rem;
}
@media screen and (max-width: 550px) {
  #diwks .cta__inner--text {
    padding: 30px;
  }
}
#diwks .cta__inner--text p {
  color: #007440;
}
#diwks .cta__inner--text h3 {
  display: block;
  color: #007440;
  font-size: max(2.1rem, 20px);
  font-weight: 600;
  line-height: 2;
  letter-spacing: 0.3em;
  margin: 3rem 0 6rem;
}
@media screen and (max-width: 550px) {
  #diwks .cta__inner--text h3 {
    font-size: 20px;
    letter-spacing: 0.1em;
    margin: 10px 0 40px;
  }
}
#diwks .cta__inner--text h3 span {
  display: inline-block;
  color: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  letter-spacing: inherit;
}
#diwks .cta.cta2 {
  background: none;
}
#diwks .cta.cta2 .cta__inner {
  margin-top: 0;
  transform: translate(0);
}
@media screen and (max-width: 550px) {
  #diwks .cta.cta2 .cta__inner {
    margin-top: 0;
    transform: translate(0);
  }
}
#diwks .strong {
  position: relative;
  padding-top: 11rem;
  padding-bottom: 14rem;
  z-index: 0;
}
@media screen and (max-width: 550px) {
  #diwks .strong {
    padding-top: 80px;
    padding-bottom: 70px;
  }
}
#diwks .strong .deco {
  top: 40%;
  left: 0;
  width: 41rem;
  z-index: -1;
}
@media screen and (max-width: 550px) {
  #diwks .strong .deco {
    width: 200px;
    top: 55%;
  }
}
#diwks .strong__videos {
  padding-bottom: 12rem;
  text-align: center;
}
@media screen and (max-width: 550px) {
  #diwks .strong__videos {
    padding-bottom: 60px;
  }
}
#diwks .strong__videos h4 {
  color: #007440;
  font-size: max(2.6rem, 24px);
  font-weight: 600;
  line-height: 2;
  letter-spacing: 0.4em;
}
@media screen and (max-width: 550px) {
  #diwks .strong__videos h4 {
    font-size: 24px;
  }
}
#diwks .strong__videos--wrapper {
  gap: 4rem;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  justify-content: space-between;
  margin-top: max(5rem, 30px);
}
@media screen and (max-width: 1300px) {
  #diwks .strong__videos--wrapper {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 550px) {
  #diwks .strong__videos--wrapper {
    grid-template-columns: 1fr;
    margin-top: 30px;
  }
}
#diwks .strong__videos--wrapper .videoBox {
  flex: 1;
}
#diwks .strong__videos--wrapper .videoBox a {
  display: block;
  position: relative;
  width: 100%;
  overflow: hidden;
}
#diwks .strong__videos--wrapper .videoBox a img {
  width: 100%;
  aspect-ratio: 16/9;
  -o-object-fit: cover;
     object-fit: cover;
  transition: 0.5s cubic-bezier(0.03, 0.29, 0.24, 0.72);
}
#diwks .strong__videos--wrapper .videoBox a .playBtn {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: grid;
  place-items: center;
  width: 20%;
  aspect-ratio: 1/1;
  background: #fff;
  border-radius: 50%;
  border: 1px solid #007440;
  color: #007440;
  font-size: max(2rem, 20px);
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0;
  transition: 0.5s cubic-bezier(0.03, 0.29, 0.24, 0.72);
}
@media screen and (max-width: 1300px) {
  #diwks .strong__videos--wrapper .videoBox a .playBtn {
    font-size: 5rem;
  }
}
@media screen and (max-width: 550px) {
  #diwks .strong__videos--wrapper .videoBox a .playBtn {
    font-size: 28px;
  }
}
#diwks .strong__videos--wrapper .videoBox a:hover img {
  transform: scale(1.1);
}
#diwks .strong__videos--wrapper .videoBox a:hover .playBtn {
  transform: translate(-50%, -50%) scale(0.9);
}
#diwks .strong__videos--wrapper .videoBox span {
  display: block;
  color: #007440;
  font-size: max(1.7rem, 15px);
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: 0.15em;
  margin-top: 15px;
}
@media screen and (max-width: 550px) {
  #diwks .strong__videos--wrapper .videoBox span {
    font-size: 15px;
  }
}
#diwks .strong__detail {
  text-align: center;
}
#diwks .strong__detail > h3 {
  display: block;
  color: #007440;
  font-size: max(2.6rem, 17px);
  font-weight: 600;
  line-height: 2;
  letter-spacing: 0.4em;
  margin-bottom: max(10rem, 50px);
}
@media screen and (max-width: 550px) {
  #diwks .strong__detail > h3 {
    font-size: 17px;
    letter-spacing: 0.2em;
    margin-bottom: 50px;
  }
}
#diwks .strong__detail--wrapper {
  gap: 6rem;
  display: flex;
  align-items: start;
  justify-content: center;
}
@media screen and (max-width: 1000px) {
  #diwks .strong__detail--wrapper {
    padding: 0;
    align-items: center;
    flex-direction: column;
  }
}
@media screen and (max-width: 550px) {
  #diwks .strong__detail--wrapper {
    gap: 30px;
  }
}
#diwks .strong__detail--wrapper--image {
  width: 40rem;
}
@media screen and (max-width: 1000px) {
  #diwks .strong__detail--wrapper--image {
    width: 50%;
  }
}
@media screen and (max-width: 550px) {
  #diwks .strong__detail--wrapper--image {
    width: 80%;
  }
}
#diwks .strong__detail--wrapper--text {
  flex: 1;
}
#diwks .strong__detail--wrapper--text ul {
  gap: 3rem;
  display: flex;
  flex-direction: column;
}
@media screen and (max-width: 1000px) {
  #diwks .strong__detail--wrapper--text ul {
    gap: 0;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 768px) {
  #diwks .strong__detail--wrapper--text ul {
    grid-template-columns: repeat(1, 1fr);
  }
}
#diwks .strong__detail--wrapper--text ul li {
  text-align: left;
}
#diwks .strong__detail--wrapper--text ul li:not(:last-child) {
  border-bottom: 2px dotted #007440;
  padding-bottom: 3rem;
}
@media screen and (max-width: 1000px) {
  #diwks .strong__detail--wrapper--text ul li:nth-of-type(odd) {
    padding-right: 30px;
    padding-bottom: 15px;
    border-right: 2px dotted #007440;
  }
  #diwks .strong__detail--wrapper--text ul li:nth-of-type(even) {
    padding-left: 30px;
    padding-bottom: 15px;
  }
  #diwks .strong__detail--wrapper--text ul li:nth-of-type(3), #diwks .strong__detail--wrapper--text ul li:nth-of-type(4) {
    padding-top: 30px;
    border-bottom: none;
  }
}
@media screen and (max-width: 768px) {
  #diwks .strong__detail--wrapper--text ul li {
    padding: 30px 0 !important;
    border-right: none !important;
  }
  #diwks .strong__detail--wrapper--text ul li:nth-of-type(3), #diwks .strong__detail--wrapper--text ul li:nth-of-type(4) {
    border-bottom: 2px dotted #007440;
  }
}
#diwks .strong__detail--wrapper--text ul li dl {
  gap: 3.5rem;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 550px) {
  #diwks .strong__detail--wrapper--text ul li dl {
    gap: 15px;
  }
}
#diwks .strong__detail--wrapper--text ul li dl dt {
  min-width: -webkit-fit-content;
  min-width: -moz-fit-content;
  min-width: fit-content;
}
#diwks .strong__detail--wrapper--text ul li dl dt span {
  display: grid;
  place-items: center;
  width: max(4.5rem, 30px);
  aspect-ratio: 1/1;
  background: #007440;
  color: #fff;
  font-size: calc(max(4.5rem, 30px) * 0.6);
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0;
}
#diwks .strong__detail--wrapper--text ul li dl dd {
  flex: 1;
}
#diwks .strong__detail--wrapper--text ul li dl dd p {
  color: #007440;
  font-size: 1.7rem;
  line-height: 2;
}
@media screen and (max-width: 1000px) {
  #diwks .strong__detail--wrapper--text ul li dl dd p {
    font-size: 14px;
  }
}
#diwks .merit {
  position: relative;
  z-index: 0;
}
#diwks .merit .deco {
  top: 50%;
  right: 0;
  width: 40rem;
  z-index: -1;
}
@media screen and (max-width: 550px) {
  #diwks .merit .deco {
    display: none;
  }
}
#diwks .merit__wrapper:not(:first-of-type) {
  padding-top: max(6rem, 60px);
}
@media screen and (max-width: 550px) {
  #diwks .merit__wrapper:not(:first-of-type) {
    padding-top: 60px;
  }
}
#diwks .merit__wrapper--exp {
  gap: 6rem;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 1000px) {
  #diwks .merit__wrapper--exp {
    flex-direction: column;
  }
}
@media screen and (max-width: 550px) {
  #diwks .merit__wrapper--exp {
    gap: 30px;
  }
}
#diwks .merit__wrapper--exp .imageBox {
  width: 46rem;
}
@media screen and (max-width: 1000px) {
  #diwks .merit__wrapper--exp .imageBox {
    width: 80%;
  }
}
@media screen and (max-width: 550px) {
  #diwks .merit__wrapper--exp .imageBox {
    width: 100%;
  }
}
#diwks .merit__wrapper--exp .textBox {
  flex: 1;
}
#diwks .merit__wrapper--exp .textBox h3 {
  position: relative;
  color: #007440;
  font-size: max(1.8rem, 16px);
  font-weight: 600;
  line-height: 2;
  letter-spacing: 0.2em;
  padding-left: calc(max(1.8rem, 16px) * 1.5);
  margin-bottom: 3rem;
}
@media screen and (max-width: 550px) {
  #diwks .merit__wrapper--exp .textBox h3 {
    font-size: 16px;
    padding-left: 24px;
    margin-bottom: 15px;
  }
}
#diwks .merit__wrapper--exp .textBox h3::before {
  content: "";
  position: absolute;
  top: max(1.8rem, 16px);
  left: 0;
  width: auto;
  height: max(1.8rem, 16px);
  min-height: max(1.8rem, 16px);
  aspect-ratio: 1/1;
  background: #007440;
  transform: translateY(-50%);
}
@media screen and (max-width: 550px) {
  #diwks .merit__wrapper--exp .textBox h3::before {
    top: 16px;
    height: 16px;
    min-height: 16px;
  }
}
@media screen and (max-width: 550px) {
  #diwks .merit__wrapper--exp .textBox h3 span {
    display: block;
  }
  #diwks .merit__wrapper--exp .textBox h3 span.accent {
    display: inline;
  }
}
@media screen and (max-width: 1300px) {
  #diwks .merit__wrapper--exp .textBox p {
    line-height: 2;
  }
}
@media screen and (max-width: 1000px) {
  #diwks .merit__wrapper--exp .textBox p {
    line-height: 2.5;
  }
}
#diwks .merit__wrapper--detail {
  padding: max(10rem, 50px) 0;
}
@media screen and (max-width: 550px) {
  #diwks .merit__wrapper--detail {
    padding: 50px 0;
  }
}
#diwks .merit__wrapper--detail h4 {
  color: #007440;
  font-size: max(1.8rem, 16px);
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: 0.2em;
  margin-bottom: max(5rem, 30px);
}
@media screen and (max-width: 550px) {
  #diwks .merit__wrapper--detail h4 {
    font-size: 16px;
    margin-bottom: 30px;
  }
}
#diwks .merit__wrapper--detail ul {
  gap: 4rem 2.5rem;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: start;
}
@media screen and (max-width: 550px) {
  #diwks .merit__wrapper--detail ul {
    gap: 30px 0;
  }
}
#diwks .merit__wrapper--detail ul li {
  gap: 3rem;
  display: flex;
  flex-direction: column;
  width: calc((100% - 5rem) / 3);
}
@media screen and (max-width: 1000px) {
  #diwks .merit__wrapper--detail ul li {
    width: calc((100% - 2.5rem) / 2);
  }
}
@media screen and (max-width: 550px) {
  #diwks .merit__wrapper--detail ul li {
    width: 100%;
    gap: 15px;
  }
}
#diwks .merit__wrapper--detail ul li .imageBox {
  position: relative;
}
#diwks .merit__wrapper--detail ul li .imageBox .number {
  position: absolute;
  top: 0;
  left: 0;
  display: grid;
  place-items: center;
  width: 30px;
  aspect-ratio: 1/1;
  color: #fff;
  font-size: max(2rem, 14px);
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0;
  background: #007440;
}
#diwks .merit__wrapper--detail ul li p {
  font-size: max(1.4rem, 12px);
  line-height: 2;
}
#diwks .merit__wrapper--detail ul li p span {
  display: block;
  color: inherit;
  font-size: 12px;
  font-weight: inherit;
  line-height: 1;
  letter-spacing: 0.1em;
  margin-top: 2rem;
}
#diwks .merit .intro {
  padding-bottom: 16rem;
}
@media screen and (max-width: 550px) {
  #diwks .merit .intro {
    padding-bottom: 70px;
  }
}
#diwks .life {
  padding-top: 13rem;
  padding-bottom: 13rem;
  background: linear-gradient(to bottom, #def0ea, #fff 24rem);
  border-top: 4px solid #007440;
}
@media screen and (max-width: 550px) {
  #diwks .life {
    padding-top: 80px;
    padding-bottom: 80px;
  }
}
#diwks .life h3 {
  display: block;
  text-align: center;
  margin-bottom: max(11.5rem, 60px);
}
@media screen and (max-width: 550px) {
  #diwks .life h3 {
    margin-bottom: 60px;
  }
}
#diwks .life .attention {
  display: block;
  text-align: right;
  margin-top: 20px;
}
#diwks .life__wrapper {
  gap: 7rem;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 1000px) {
  #diwks .life__wrapper {
    flex-direction: column;
  }
  #diwks .life__wrapper.accent {
    flex-direction: column-reverse;
  }
}
@media screen and (max-width: 550px) {
  #diwks .life__wrapper {
    gap: 30px;
  }
}
#diwks .life__wrapper:not(:last-of-type) {
  margin-bottom: max(7rem, 50px);
}
@media screen and (max-width: 550px) {
  #diwks .life__wrapper:not(:last-of-type) {
    margin-bottom: 50px;
  }
}
#diwks .life__wrapper--image {
  width: 56rem;
  min-width: 56rem;
}
@media screen and (max-width: 1000px) {
  #diwks .life__wrapper--image {
    width: 80%;
  }
}
@media screen and (max-width: 768px) {
  #diwks .life__wrapper--image {
    width: 100%;
    min-width: 100%;
  }
}
#diwks .life__wrapper--text {
  flex: 1;
}
@media screen and (max-width: 1000px) {
  #diwks .life__wrapper--text {
    width: 80%;
  }
}
@media screen and (max-width: 768px) {
  #diwks .life__wrapper--text {
    width: 100%;
  }
}
#diwks .life__wrapper--text span {
  display: block;
  margin-bottom: 10px;
  font-size: max(1.4rem, 14px);
}
@media screen and (max-width: 550px) {
  #diwks .life__wrapper--text span {
    font-size: 14px;
  }
}
#diwks .life__wrapper--text img {
  width: 100%;
}
#diwks .ctaBox {
  margin-top: max(12.5rem, 80px);
  margin-bottom: max(15rem, 90px);
}
@media screen and (max-width: 550px) {
  #diwks .ctaBox {
    margin-top: 80px;
    margin-bottom: 90px;
  }
}
#diwks .ctaBox a {
  width: 80%;
  margin: auto;
  padding: max(2.5rem, 25px) 2rem max(2.5rem, 25px) 20px;
}
@media screen and (max-width: 1000px) {
  #diwks .ctaBox a {
    width: 100%;
  }
}
@media screen and (max-width: 550px) {
  #diwks .ctaBox a {
    padding: 30px;
  }
}
#diwks .ctaBox a dl {
  display: flex;
}
@media screen and (max-width: 550px) {
  #diwks .ctaBox a dl {
    flex-direction: column;
  }
}
#diwks .ctaBox a dl dt {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  min-width: 150px;
  padding-right: 2rem;
  font-size: max(1.8rem, 16px);
  cursor: pointer;
}
@media screen and (max-width: 550px) {
  #diwks .ctaBox a dl dt {
    font-size: 16px;
    padding-right: 0;
    padding-bottom: 20px;
  }
}
#diwks .ctaBox a dl dd {
  display: flex;
  align-items: center;
  padding-left: 2rem;
  padding-right: 10rem;
}
@media screen and (max-width: 550px) {
  #diwks .ctaBox a dl dd {
    padding-left: 0;
    padding-right: 0;
    padding-bottom: 5%;
    padding-top: 20px;
  }
}
#diwks .ctaBox a dl dd p {
  font-size: max(1.4rem, 12px);
  line-height: 2;
  cursor: pointer;
}
@media screen and (max-width: 550px) {
  #diwks .ctaBox a dl dd p {
    font-size: 14px;
  }
}
@media screen and (max-width: 550px) {
  #diwks .ctaBox a .line {
    top: 85%;
  }
}
#diwks .ctaBox a:nth-of-type(1) {
  background: #007440;
  margin-bottom: max(5rem, 30px);
}
#diwks .ctaBox a:nth-of-type(1) dl dt {
  color: #fff;
  border-right: 2px dotted #fff;
}
@media screen and (max-width: 550px) {
  #diwks .ctaBox a:nth-of-type(1) dl dt {
    border-right: none;
    border-bottom: 1px dotted #fff;
  }
}
#diwks .ctaBox a:nth-of-type(1) dl dd p {
  color: #fff;
}
#diwks .ctaBox a:nth-of-type(1) .line {
  background: rgba(255, 255, 255, 0.25);
}
#diwks .ctaBox a:nth-of-type(1) .line::before {
  background: #fff;
}
#diwks .ctaBox a:nth-of-type(1):hover {
  background: #def0ea;
}
#diwks .ctaBox a:nth-of-type(1):hover dt,
#diwks .ctaBox a:nth-of-type(1):hover dd p {
  color: #007440;
}
#diwks .ctaBox a:nth-of-type(1):hover dt {
  border-right: 2px dotted #007440;
}
@media screen and (max-width: 550px) {
  #diwks .ctaBox a:nth-of-type(1):hover dt {
    border-right: none;
    border-bottom: 1px dotted #007440;
  }
}
#diwks .ctaBox a:nth-of-type(1):hover .line {
  background: rgba(0, 116, 64, 0.25);
}
#diwks .ctaBox a:nth-of-type(1):hover .line::before {
  background: #007440;
}
#diwks .ctaBox a:nth-of-type(2) dl dt {
  color: #007440;
  border-right: 2px dotted #007440;
}
@media screen and (max-width: 550px) {
  #diwks .ctaBox a:nth-of-type(2) dl dt {
    border-right: none;
    border-bottom: 1px dotted #007440;
  }
}
#diwks .ctaBox a:nth-of-type(2) dl dd p {
  color: #007440;
}
#diwks .ctaBox a:nth-of-type(2):hover dt,
#diwks .ctaBox a:nth-of-type(2):hover dd p {
  color: #fff;
}
#diwks .ctaBox a:nth-of-type(2):hover dt {
  border-right: 2px dotted #fff;
}
@media screen and (max-width: 550px) {
  #diwks .ctaBox a:nth-of-type(2):hover dt {
    border-right: none;
    border-bottom: 1px dotted #fff;
  }
}/*# sourceMappingURL=diwks.css.map */