@charset "UTF-8";
@-webkit-keyframes infinity-scroll {
  from {
    -webkit-transform: translateY(0);
            transform: translateY(0); }
  to {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%); } }
@keyframes infinity-scroll {
  from {
    -webkit-transform: translateY(0);
            transform: translateY(0); }
  to {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%); } }

@-webkit-keyframes purupuru_anim {
  0% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); }
  5% {
    -webkit-transform: translate(-5px, 0);
            transform: translate(-5px, 0); }
  10% {
    -webkit-transform: translate(5px, 0);
            transform: translate(5px, 0); }
  15% {
    -webkit-transform: translate(-5px, 0);
            transform: translate(-5px, 0); }
  20% {
    -webkit-transform: translate(5px, 0);
            transform: translate(5px, 0); }
  25% {
    -webkit-transform: translate(-5px, 0);
            transform: translate(-5px, 0); }
  30% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); }
  100% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); } }

@keyframes purupuru_anim {
  0% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); }
  5% {
    -webkit-transform: translate(-5px, 0);
            transform: translate(-5px, 0); }
  10% {
    -webkit-transform: translate(5px, 0);
            transform: translate(5px, 0); }
  15% {
    -webkit-transform: translate(-5px, 0);
            transform: translate(-5px, 0); }
  20% {
    -webkit-transform: translate(5px, 0);
            transform: translate(5px, 0); }
  25% {
    -webkit-transform: translate(-5px, 0);
            transform: translate(-5px, 0); }
  30% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); }
  100% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); } }

@-webkit-keyframes img-wrap {
  0% {
    clip-path: circle(0% 0%);
    -webkit-clip-path: circle(0 at 0% 0%); }
  100% {
    clip-path: circle(200% at 100% 100%);
    -webkit-clip-path: circle(200% at 100% 100%); } }

@keyframes img-wrap {
  0% {
    clip-path: circle(0% 0%);
    -webkit-clip-path: circle(0 at 0% 0%); }
  100% {
    clip-path: circle(200% at 100% 100%);
    -webkit-clip-path: circle(200% at 100% 100%); } }

@-webkit-keyframes hiraku_anim {
  0% {
    -webkit-transform: rotate(5deg);
            transform: rotate(5deg); }
  25% {
    -webkit-transform: rotate(-5deg);
            transform: rotate(-5deg); }
  50% {
    -webkit-transform: rotate(5deg);
            transform: rotate(5deg); }
  75% {
    -webkit-transform: rotate(-5deg);
            transform: rotate(-5deg); }
  100% {
    -webkit-transform: rotate(5deg);
            transform: rotate(5deg); } }

@keyframes hiraku_anim {
  0% {
    -webkit-transform: rotate(5deg);
            transform: rotate(5deg); }
  25% {
    -webkit-transform: rotate(-5deg);
            transform: rotate(-5deg); }
  50% {
    -webkit-transform: rotate(5deg);
            transform: rotate(5deg); }
  75% {
    -webkit-transform: rotate(-5deg);
            transform: rotate(-5deg); }
  100% {
    -webkit-transform: rotate(5deg);
            transform: rotate(5deg); } }

@-webkit-keyframes car_anim {
  0% {
    -webkit-transform: translate(50px, -50px);
            transform: translate(50px, -50px); }
  100% {
    -webkit-transform: translate(-50px, 50px);
            transform: translate(-50px, 50px); } }

@keyframes car_anim {
  0% {
    -webkit-transform: translate(50px, -50px);
            transform: translate(50px, -50px); }
  100% {
    -webkit-transform: translate(-50px, 50px);
            transform: translate(-50px, 50px); } }

@-webkit-keyframes car_anim_tab {
  0% {
    -webkit-transform: translate(4vw, -4vw);
            transform: translate(4vw, -4vw); }
  100% {
    -webkit-transform: translate(-4vw, 4vw);
            transform: translate(-4vw, 4vw); } }

@keyframes car_anim_tab {
  0% {
    -webkit-transform: translate(4vw, -4vw);
            transform: translate(4vw, -4vw); }
  100% {
    -webkit-transform: translate(-4vw, 4vw);
            transform: translate(-4vw, 4vw); } }

@-webkit-keyframes car_anim_sp {
  0% {
    -webkit-transform: translate(-10vw, -10vw);
            transform: translate(-10vw, -10vw); }
  100% {
    -webkit-transform: translate(10vw, 10vw);
            transform: translate(10vw, 10vw); } }

@keyframes car_anim_sp {
  0% {
    -webkit-transform: translate(-10vw, -10vw);
            transform: translate(-10vw, -10vw); }
  100% {
    -webkit-transform: translate(10vw, 10vw);
            transform: translate(10vw, 10vw); } }

@-webkit-keyframes omoi_anim {
  0% {
    -webkit-transform: scale(0.9, 0.9);
            transform: scale(0.9, 0.9); }
  50% {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1); }
  100% {
    -webkit-transform: scale(0.9, 0.9);
            transform: scale(0.9, 0.9); } }

@keyframes omoi_anim {
  0% {
    -webkit-transform: scale(0.9, 0.9);
            transform: scale(0.9, 0.9); }
  50% {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1); }
  100% {
    -webkit-transform: scale(0.9, 0.9);
            transform: scale(0.9, 0.9); } }

@-webkit-keyframes fukidashi_anim1 {
  0% {
    opacity: 0; }
  50% {
    opacity: 1; }
  100% {
    opacity: 1; } }

@keyframes fukidashi_anim1 {
  0% {
    opacity: 0; }
  50% {
    opacity: 1; }
  100% {
    opacity: 1; } }

@-webkit-keyframes fukidashi_anim2 {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }

@keyframes fukidashi_anim2 {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }

#content {
  color: #333333;
	font-size: calc((16 / 14) * 100%);
	margin: 0;
	width: auto;
	max-width: none; }
	@media screen and (max-width: 767px) {
		#content {
			font-size: 100%; } }
  #content p {
    font-weight: 500; }
  #content img {
    width: auto;
    height: auto;
    max-width: 100%;
    vertical-align: middle; }
    @media screen and (max-width: 767px) {
      #content img {
        width: 100%; } }
  #content a {
    color: #333;
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease; }
    #content a:hover {
      text-decoration: none; }
  #content article {
    padding: 120px 0; }
    @media screen and (max-width: 767px) {
      #content article {
        padding: 120px 20px; } }

.mv__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  max-width: 1440px !important;
  margin: 0 auto;
  padding-left: 20px; }
  @media screen and (max-width: 767px) {
    .mv__inner {
      display: block;
      padding: 0; } }
  @media screen and (min-width: 767px) and (max-width: 820px) {
    .mv__inner {
      padding-left: 20px; } }

.mv__btn {
  width: 300px;
  margin-top: 40px; }
  @media screen and (max-width: 767px) {
    .mv__btn {
      width: 240px;
      margin-top: 20px; } }
  .mv__btn a {
    display: block;
    background: #FD0102;
    border-radius: 20px;
    padding: 5px 0px;
    color: #fff !important;
    text-align: center;
    font-size: 20px; }
    @media screen and (max-width: 767px) {
      .mv__btn a {
        font-size: 16px;
        padding: 5px 10px; } }

.mv__left {
  max-width: 350px; }
  @media screen and (max-width: 767px) {
    .mv__left {
      width: 220px; } }

.mv__txt_img {
	box-sizing: border-box;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 45%;
          flex: 0 0 45%;
  text-align: center; }
  @media screen and (max-width: 767px) {
    .mv__txt_img {
      width: 260px;
      padding: 40px 20px; } }

.mv__illust {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 55%;
          flex: 0 0 55%; }
  .mv__illust_inner {
    overflow: hidden;
    height: 800px; }
    @media screen and (max-width: 767px) {
      .mv__illust_inner {
        height: 400px; } }
  .mv__illust_list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    list-style: none;
    -webkit-animation: infinity-scroll infinite linear 25s;
            animation: infinity-scroll infinite linear 25s;
    position: relative; }
    .mv__illust_list li img {
      display: block;
      -webkit-backface-visibility: hidden;
      image-rendering: -webkit-optimize-contrast; }
    .mv__illust_list li a {
      display: block; }
      .mv__illust_list li a:hover {
        cursor: url(../img/mouse-hover.svg) 60 60, auto; }
      .mv__illust_list li a img {
        width: 100% !important; }
    @media all and (-ms-high-contrast: none) {
      .mv__illust_list li.base {
        width: 780px; } }
    .mv__illust_list li.link {
      position: absolute; }
    .mv__illust_list li.energy {
      left: 6vw;
      bottom: 8vw;
      width: 15vw; }
      @media screen and (min-width: 1440px) {
        .mv__illust_list li.energy {
          left: 8vw;
          bottom: 115px;
          max-width: 160px; } }
      @media screen and (max-width: 767px) {
        .mv__illust_list li.energy {
          left: 17vw;
          width: 22vw;
          bottom: 14.5vw; } }
    .mv__illust_list li.car {
      right: 0;
      top: 42vw;
      width: 15vw; }
      @media screen and (min-width: 1440px) {
        .mv__illust_list li.car {
          top: 590px;
          max-width: 245px; } }
      @media screen and (max-width: 767px) {
        .mv__illust_list li.car {
          width: 28vw;
          top: 78vw; } }
    .mv__illust_list li.conditioning {
      right: 9vw;
      top: 9vw;
      width: 7.5vw; }
      @media screen and (min-width: 1440px) {
        .mv__illust_list li.conditioning {
          top: 125px;
          max-width: 112px;
          right: 130px; } }
      @media screen and (max-width: 767px) {
        .mv__illust_list li.conditioning {
          width: 13vw;
          top: 17vw;
          right: 15vw; } }
    .mv__illust_list li.electronic {
      left: 50%;
      -webkit-transform: translateX(-50%);
              transform: translateX(-50%);
      top: 15vw;
      width: 7vw; }
      @media screen and (min-width: 1440px) {
        .mv__illust_list li.electronic {
          top: 210px;
          max-width: 100px; } }
      @media screen and (max-width: 767px) {
        .mv__illust_list li.electronic {
          top: 32vw;
          width: 12vw; } }
    .mv__illust_list li.it {
      left: 50%;
      -webkit-transform: translateX(-50%);
              transform: translateX(-50%);
      top: 46vw;
      width: 14.5vw; }
      @media screen and (min-width: 1440px) {
        .mv__illust_list li.it {
          top: 660px;
          max-width: 222px; } }
      @media screen and (max-width: 767px) {
        .mv__illust_list li.it {
          top: 89vw;
          width: 30vw; } }
    .mv__illust_list li.public {
      left: 1vw;
      top: 50vw;
      width: 5vw; }
      @media screen and (min-width: 1440px) {
        .mv__illust_list li.public {
          top: 720px;
          max-width: 86px;
          left: 10px; } }
      @media screen and (max-width: 767px) {
        .mv__illust_list li.public {
          top: 97vw;
          width: 10vw;
          right: 13vw; } }
    .mv__illust_list li.transmission {
      right: 10vw;
      bottom: 8vw;
      width: 3.5vw; }
      @media screen and (min-width: 1440px) {
        .mv__illust_list li.transmission {
          right: 145px;
          bottom: 120px;
          max-width: 50px; } }
      @media screen and (max-width: 767px) {
        .mv__illust_list li.transmission {
          right: 17.5vw;
          bottom: 14vw;
          width: 6.5vw; } }
    .mv__illust_list li.home {
      left: 9vw;
      bottom: 19vw;
      width: 20vw; }
      @media screen and (min-width: 1440px) {
        .mv__illust_list li.home {
          bottom: 280px;
          max-width: 266px;
          left: 9vw; } }
      @media screen and (max-width: 767px) {
        .mv__illust_list li.home {
          left: 18vw;
          bottom: 35vw;
          width: 35vw; } }
    .mv__illust_list li.traffic {
      right: 2.0vw;
      bottom: 0vw;
      width: 10vw; }
      @media screen and (min-width: 1440px) {
        .mv__illust_list li.traffic {
          bottom: 0vw;
          max-width: 143px;
          right: 50px; } }
      @media screen and (max-width: 767px) {
        .mv__illust_list li.traffic {
          right: 5.5vw;
          bottom: 0vw;
          width: 16vw; } }
    .mv__illust_list li.building {
      right: 15px;
      top: 49vw;
      width: 3vw; }
      @media screen and (min-width: 1440px) {
        .mv__illust_list li.building {
          top: 710px;
          max-width: 45px;
          width: 3vw; } }
      @media screen and (max-width: 767px) {
        .mv__illust_list li.building {
          right: 15px;
          top: 93.5vw;
          width: 6vw; } }
    .mv__illust_list li.fa {
      left: 0;
      top: 33.5vw;
      width: 15vw; }
      @media screen and (min-width: 1440px) {
        .mv__illust_list li.fa {
          top: 490px;
          max-width: 190px; } }
      @media screen and (max-width: 767px) {
        .mv__illust_list li.fa {
          left: 10px;
          top: 65vw;
          width: 24vw; } }
    .mv__illust_list li.universe {
      left: 0;
      top: 9.5vw;
      width: 9vw; }
      @media screen and (min-width: 1440px) {
        .mv__illust_list li.universe {
          top: 120px;
          max-width: 130px; } }
      @media screen and (max-width: 767px) {
        .mv__illust_list li.universe {
          left: 0;
          top: 18vw;
          width: 16vw; } }

.lead__block {
  background: #EFEFEF;
  padding: 80px 0; }

.lead__inner {
  max-width: 1200px !important;
  margin: 0 auto;
  padding: 0 13px; }
  @media screen and (max-width: 767px) {
    .lead__inner {
      padding: 0 20px; } }

.lead__txt {
  text-align: center;
  font-weight: 500;
  line-height: 2.5; }
  @media screen and (max-width: 767px) {
    .lead__txt {
      text-align: left; } }

.content__ttl_img-1 {
  text-align: center;
  margin: 0 auto 60px; }
  .content__ttl_img-1.mb40 {
    margin-bottom: 40px; }
  .content__ttl_img-1.omoi {
    width: 80%; }
    @media screen and (max-width: 767px) {
      .content__ttl_img-1.omoi {
        width: 100%; } }
    .content__ttl_img-1.omoi img {
      width: 100% !important; }
    .content__ttl_img-1.omoi.omoi1 {
      max-width: 745px; }
    .content__ttl_img-1.omoi.omoi2 {
      max-width: 906px; }
    .content__ttl_img-1.omoi.omoi3 {
      max-width: 827px; }

.content-1 {
  max-width: 1200px !important;
  letter-spacing: 0.05em;
  margin: 0 auto; }
  .content-1:last-child::after {
    content: none; }
  .content-1::after {
    content: "";
    height: 100px;
    width: 2px;
    background: #000;
    display: block;
    margin: 100px auto; }
  .content-1__inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between; }
    @media screen and (max-width: 767px) {
      .content-1__inner {
        display: block; } }
    @media screen and (max-width: 767px) {
      .content-1__inner.flex-sp {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: reverse;
            -ms-flex-direction: column-reverse;
                flex-direction: column-reverse; } }
    @media screen and (min-width: 1074px) {
      .content-1__inner.omoi-2 {
        padding-bottom: 100px; } }
  .content-1__left {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex; }
    @media screen and (max-width: 767px) {
      .content-1__left {
        display: block;
        text-align: center; } }
  .content-1__label_img {
    width: 70px;
    margin-right: 30px; }
    @media screen and (max-width: 767px) {
      .content-1__label_img {
        margin: 0 auto 20px;
        width: 60px; } }
  @media screen and (max-width: 767px) {
    .content-1__illust {
      width: 100% !important;
      margin-top: 30px; } }
  .content-1__illust .illust-item {
    position: absolute; }
    .content-1__illust .illust-item img {
      width: 100% !important; }
  .content-1__illust.illust-1 {
    width: 451px;
    margin-left: 0px;
    position: relative; }
    @media screen and (max-width: 767px) {
      .content-1__illust.illust-1 {
        margin-left: 0;
        width: 100%;
        height: 300px; } }
    .content-1__illust.illust-1 .txt {
      right: 10px;
      max-width: 228px;
      width: 20vw;
      -webkit-animation: purupuru_anim 2s infinite alternate;
              animation: purupuru_anim 2s infinite alternate; }
      @media screen and (max-width: 767px) {
        .content-1__illust.illust-1 .txt {
          width: 163px;
          right: 10px; } }
    .content-1__illust.illust-1 .aircon {
      right: 32.3vw;
      width: 11vw;
      max-width: 120px; }
      @media screen and (min-width: 1200px) {
        .content-1__illust.illust-1 .aircon {
          right: 385px; } }
      @media screen and (max-width: 767px) {
        .content-1__illust.illust-1 .aircon {
          width: 120px;
          right: auto;
          left: 0; } }
    .content-1__illust.illust-1 .wind {
      right: 30.3vw;
      top: 6.8vw;
      width: 7vw;
      max-width: 82px;
      -webkit-animation: img-wrap 2s cubic-bezier(0.4, 0, 0.2, 1) infinite;
              animation: img-wrap 2s cubic-bezier(0.4, 0, 0.2, 1) infinite; }
      @media screen and (min-width: 1200px) {
        .content-1__illust.illust-1 .wind {
          right: 365px;
          top: 78px; } }
      @media screen and (max-width: 767px) {
        .content-1__illust.illust-1 .wind {
          width: 82px;
          right: auto;
          left: 55px;
          top: 80px; } }
    .content-1__illust.illust-1 .satellite {
      right: 0px;
      top: 160px;
      width: 37vw;
      max-width: 428px; }
      @media screen and (max-width: 767px) {
        .content-1__illust.illust-1 .satellite {
          width: 230px;
          right: 0px; } }
    .content-1__illust.illust-1 .biribiri {
      right: 30vw;
      top: 265px;
      width: 12vw;
      max-width: 132px;
      -webkit-animation: purupuru_anim 3s infinite alternate;
              animation: purupuru_anim 3s infinite alternate; }
      @media screen and (min-width: 1200px) {
        .content-1__illust.illust-1 .biribiri {
          right: 350px; } }
      @media screen and (max-width: 767px) {
        .content-1__illust.illust-1 .biribiri {
          width: 80px;
          right: 190px;
          top: 220px; } }
  .content-1__illust.illust-2 {
    width: 451px;
    margin-left: 0px;
    position: relative; }
    @media screen and (max-width: 767px) {
      .content-1__illust.illust-2 {
        margin-left: 0;
        width: 100%;
        height: 300px; } }
    .content-1__illust.illust-2 .txt {
      right: 2vw;
      top: 0;
      width: 14vw;
      max-width: 167px;
      -webkit-animation: hiraku_anim 3s infinite;
              animation: hiraku_anim 3s infinite; }
      @media screen and (min-width: 1200px) {
        .content-1__illust.illust-2 .txt {
          right: 0;
          top: 0; } }
      @media screen and (max-width: 767px) {
        .content-1__illust.illust-2 .txt {
          width: 145px;
          right: auto;
          left: 0;
          top: 50px; } }
    .content-1__illust.illust-2 .catapira {
      left: 100px;
      top: 60px;
      width: 21vw;
      max-width: 258px; }
      @media screen and (max-width: 767px) {
        .content-1__illust.illust-2 .catapira {
          width: 160px;
          top: 0px;
          left: auto;
          right: 0; } }
    .content-1__illust.illust-2 .car {
      width: 16vw;
      max-width: 166px;
      top: 35vw;
      right: -5vw;
      -webkit-animation: car_anim_tab 6s infinite;
              animation: car_anim_tab 6s infinite; }
      @media screen and (min-width: 1200px) {
        .content-1__illust.illust-2 .car {
          top: 450px;
          right: -70px;
          -webkit-animation: car_anim 6s infinite;
                  animation: car_anim 6s infinite; } }
      @media screen and (max-width: 767px) {
        .content-1__illust.illust-2 .car {
          width: 115px;
          right: 190px;
          top: 220px;
          -webkit-animation: car_anim_sp 6s infinite;
                  animation: car_anim_sp 6s infinite; } }
  .content-1__illust.illust-3 {
    width: 451px;
    margin-left: 0px;
    position: relative; }
    @media screen and (max-width: 767px) {
      .content-1__illust.illust-3 {
        margin-left: 0;
        width: 100%;
        height: 300px; } }
    .content-1__illust.illust-3 .txt {
      right: 0;
      top: 0;
      width: 20vw;
      max-width: 203px;
      -webkit-animation: omoi_anim 3s infinite;
              animation: omoi_anim 3s infinite; }
      @media screen and (min-width: 1200px) {
        .content-1__illust.illust-3 .txt {
          right: 0;
          top: 0px; } }
      @media screen and (max-width: 767px) {
        .content-1__illust.illust-3 .txt {
          width: 150px;
          right: auto;
          left: 0;
          top: 0; } }
    .content-1__illust.illust-3 .elevator {
      left: 0;
      top: 10vw;
      width: 30vw;
      max-width: 365px; }
      @media screen and (min-width: 1200px) {
        .content-1__illust.illust-3 .elevator {
          left: 0px;
          top: 80px; } }
      @media screen and (max-width: 767px) {
        .content-1__illust.illust-3 .elevator {
          top: 40px;
          width: 200px;
          left: auto;
          right: 0; } }
    .content-1__illust.illust-3 .chip {
      width: 17vw;
      max-width: 214px;
      top: 40vw;
      right: 20px;
      -webkit-animation: hiraku_anim 5s infinite;
              animation: hiraku_anim 5s infinite; }
      @media screen and (min-width: 1200px) {
        .content-1__illust.illust-3 .chip {
          top: 430px;
          right: 10px; } }
      @media screen and (max-width: 767px) {
        .content-1__illust.illust-3 .chip {
          width: 110px;
          right: 130px;
          top: 230px; } }
    .content-1__illust.illust-3 .fukidashi1 {
      width: 7vw;
      max-width: 80px;
      top: 5vw;
      right: 27vw;
      opacity: 0;
      -webkit-animation: fukidashi_anim1 5s infinite;
              animation: fukidashi_anim1 5s infinite; }
      @media screen and (min-width: 1200px) {
        .content-1__illust.illust-3 .fukidashi1 {
          top: 35px;
          right: 320px; } }
      @media screen and (max-width: 767px) {
        .content-1__illust.illust-3 .fukidashi1 {
          width: 50px;
          right: 130px;
          top: 5px; } }
    .content-1__illust.illust-3 .fukidashi2 {
      width: 5vw;
      max-width: 60px;
      top: 20.5vw;
      right: 11vw;
      opacity: 0;
      -webkit-animation: fukidashi_anim2 5s 1s infinite;
              animation: fukidashi_anim2 5s 1s infinite; }
      @media screen and (min-width: 1200px) {
        .content-1__illust.illust-3 .fukidashi2 {
          top: 220px;
          right: 120px; } }
      @media screen and (max-width: 767px) {
        .content-1__illust.illust-3 .fukidashi2 {
          width: 40px;
          right: 20px;
          top: 100px; } }
  .content-1__ttl {
    font-size: 46px;
    background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(60%, #FFFA74));
    background: linear-gradient(transparent 60%, #FFFA74 60%);
    display: inline;
    font-weight: 500; }
    @media screen and (max-width: 767px) {
      .content-1__ttl {
        font-size: 30px;
        margin-bottom: 20px; } }
  .content-1__txt {
    margin-top: 30px; }
    @media screen and (max-width: 767px) {
      .content-1__txt {
        line-height: 1.8; } }
  .content-1__btn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    font-weight: 500;
    margin-top: 30px; }
    .content-1__btn a[target='_blank']::after {
      content: '\f08e';
      font-family: 'FontAwesome';
      margin-left: 10px; }

.content-2 {
  background: #EFEFEF;
  padding: 100px 0; 
  letter-spacing: 0.05em;}
  .content-2__inner {
    max-width: 1200px !important;
    margin: 0 auto; }
    @media screen and (max-width: 767px) {
      .content-2__inner {
        padding: 0 20px; } }
  .content-2__lead {
    text-align: center;
    font-weight: 500; }
    @media screen and (max-width: 767px) {
      .content-2__lead {
        line-height: 1.8; } }
  .content-2__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin-top: 50px; }
    @media screen and (max-width: 767px) {
      .content-2__list {
        display: block;
        margin-top: 30px; } }
  .content-2__item {
    list-style: none;
    width: calc(100% / 3);
    border-right: 1px dashed #FD0102;
    padding: 0 30px; }
    @media screen and (max-width: 767px) {
      .content-2__item {
        width: 100%;
        border-right: 0;
        border-bottom: 1px dashed #FD0102;
        padding: 30px 0; } }
    .content-2__item img {
      height: 340px !important; }
    .content-2__item:last-child {
      border-right: 0; }
    .content-2__item_txt {
      font-weight: 500;
      text-align: center;
      line-height: 1.8;
      margin-top: 30px; }
      .content-2__item_txt span {
        color: #FD0102;
        font-size: 24px; }
        @media screen and (max-width: 767px) {
          .content-2__item_txt span {
            font-size: 22px; } }
  .content-2__btn {
    margin: 60px auto 0;
    width: 40%; }
    @media screen and (max-width: 767px) {
      .content-2__btn {
        width: 100% !important; } }
    .content-2__btn.career {
      width: 400px !important; }
      @media screen and (max-width: 767px) {
        .content-2__btn.career {
          width: 100% !important; } }

@media screen and (max-width: 767px) and (max-width: 767px) {
  .content-2__btn.career a::after {
    right: 20px !important; } }
    .content-2__btn.mirai {
      width: 230px; }
    .content-2__btn.hiraku {
      width: 253px; }
    .content-2__btn.omoi {
      margin: 20px 0 0; }
      @media screen and (max-width: 767px) {
        .content-2__btn.omoi {
          width: 100%;
          margin: 30px auto 0; } }
      .content-2__btn.omoi.with-icon {
        margin-left: 0; }
    .content-2__btn.message a {
      -webkit-box-pack: center !important;
          -ms-flex-pack: center !important;
              justify-content: center !important;
      padding: 8px 20px 12px 20px !important;
      display: -webkit-box !important;
      display: -ms-flexbox !important;
      display: flex !important; }
    .content-2__btn a {
      color: #333 !important;
      font-weight: 500;
      background: #fff;
      padding: 8px 10px 12px 10px;
      display: block;
      border-radius: 30px;
      border: 2px solid #FD0102;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-align: center;
      -ms-flex-align: center;
      align-items: center;
      -webkit-box-pack: center;
      -ms-flex-pack: center;
      justify-content: center; }
      @media screen and (max-width: 767px) {
        .content-2__btn a {
          padding: 10px 0 10px 0px;
          line-height: 1.7;
          border-radius: 40px;
          -webkit-box-pack: center;
              -ms-flex-pack: center;
                  justify-content: center;
          display: -webkit-box !important;
          display: -ms-flexbox !important;
          display: flex !important; }
        .content-2__btn.message a{
          padding: 10px!important;
        }
      }
      .content-2__btn a:hover {
        background: #fff;
        color: #333 !important;
        opacity: .8; }
        .content-2__btn a:hover::after {
          color: #FD0102 !important; }
      .content-2__btn a::after {
        font-family: fontawesome;
        content: "\f105";
        display: block;
        padding-left: 10px;
        color: #FD0102; }
        @media screen and (max-width: 767px) {
          .content-2__btn a::after {
            padding-right: 0px; } }

.content-3 {
  padding: 100px 0; }
  @media screen and (max-width: 767px) {
    .content-3 {
      padding: 120px 20px; } }
  .content-3__inner {
    max-width: 1200px !important;
    margin: 0 auto; }
    @media screen and (max-width: 767px) {
      .content-3__inner {
        padding: 0 20px; } }
  .content-3__lead {
    text-align: center;
    font-weight: 500; }
  .content-3__onomatope {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    width: 85vw !important;
    max-width: 1540px;
    margin-top: 60px; }
    @media screen and (max-width: 767px) {
      .content-3__onomatope {
        display: block;
        width: 100% !important; } }
    .content-3__onomatope ul {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
          -ms-flex-direction: column;
              flex-direction: column;
      -webkit-box-pack: justify;
          -ms-flex-pack: justify;
              justify-content: space-between;
      margin-left: 2px; }
    .content-3__onomatope .tab {
      cursor: pointer;
      -ms-writing-mode: tb-rl;
      -webkit-writing-mode: vertical-rl;
              writing-mode: vertical-rl;
      border: 2px solid #FD0102;
      border-radius: 0px 5px 5px 0;
      text-align: center;
      height: 120px;
      color: #FD0102;
      font-weight: 600;
      -webkit-transition: ease .5s;
      transition: ease .5s; }
      @media screen and (max-width: 767px) {
        .content-3__onomatope .tab {
          width: 100%;
          -ms-writing-mode: horizontal-tb;
          -webkit-writing-mode: horizontal-tb;
                  writing-mode: horizontal-tb;
          border-radius: 5px 5px 0px 0;
          height: auto;
          padding: 12px 0;
          margin-bottom: 5px; } }
      .content-3__onomatope .tab:hover {
        background: #FD0102;
        color: #fff; }
      .content-3__onomatope .tab.is-active {
        background: #FD0102;
        color: #fff; }
        .content-3__onomatope .tab.is-active-sp {
          background: #FD0102;
          color: #fff; }
    .content-3__onomatope.sp-only .tab {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      position: relative; }
      @media screen and (max-width: 767px) {
        .content-3__onomatope.sp-only .tab::after {
          position: absolute;
          right: 20px;
          content: "＋";
          font-size: 20px;
          margin-bottom: 0px;
          color: #FD0102; } }
      @media screen and (max-width: 767px) {
        .content-3__onomatope.sp-only .tab.is-active-sp::after {
          position: absolute;
          right: 20px;
          content: "＋";
          font-size: 20px;
          margin-bottom: 0px;
          color: #fff; } }
    .content-3__onomatope .panel {
      display: none; }
    .content-3__onomatope .panel.is-show {
      display: block; }
    .content-3__onomatope .panel {
      display: none; }
    .content-3__onomatope .panel.is-show-sp {
      display: block; }
  .content-3__accordion {
    overflow: hidden;
    width: 100%;
    border: 2px solid #FD0102;
    border-radius: 10px; }
    @media screen and (max-width: 767px) {
      .content-3__accordion {
        margin-bottom: 20px;
        border-radius: 0px;
        border: 2px solid #FD0102; } }
    .content-3__accordion dl {
      width: 100%;
      height: 605px;
      margin: 0;
      overflow-x: scroll;
      -ms-writing-mode: tb-rl;
      -webkit-writing-mode: vertical-rl;
              writing-mode: vertical-rl; }
      @media screen and (max-width: 767px) {
        .content-3__accordion dl {
          padding: 0;
          -ms-writing-mode: horizontal-tb;
          -webkit-writing-mode: horizontal-tb;
                  writing-mode: horizontal-tb;
          overflow-y: scroll; } }
    .content-3__accordion dt, .content-3__accordion dd {
      float: right; }
      @media screen and (max-width: 767px) {
        .content-3__accordion dt, .content-3__accordion dd {
          float: none; } }
    .content-3__accordion_ttl {
      cursor: pointer;
      background: #fff;
      color: #333;
      height: 605px;
      padding: 20px 0px;
      font-family: 'Noto Serif', serif;
      font-size: 32px;
      font-weight: 500;
      border-right: 1px solid #D3D3D3;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center; }
      @media screen and (max-width: 767px) {
        .content-3__accordion_ttl {
          border-right: 0;
          height: auto;
          font-size: 26px;
          display: -webkit-box;
          display: -ms-flexbox;
          display: flex;
          -webkit-box-align: center;
              -ms-flex-align: center;
                  align-items: center;
          position: relative;
          padding: 15px 0px;
          margin: 0 20px;
          border-bottom: 1px dashed #FD0102; } }
      .content-3__accordion_ttl:first-of-type {
        border-right: 0; }
        @media screen and (max-width: 767px) {
          .content-3__accordion_ttl:first-of-type {
            border-left: 0; } }
      .content-3__accordion_ttl:last-of-type {
        border-left: 1px solid #D3D3D3; }
        @media screen and (max-width: 767px) {
          .content-3__accordion_ttl:last-of-type {
            border-left: 0; } }
      .content-3__accordion_ttl span {
        font-size: 16px;
        font-weight: normal; }
      .content-3__accordion_ttl::before {
        content: "";
        margin: 10px 0;
        background: url(/saiyo/concept/img/onomatope-plus.svg);
        background-repeat: no-repeat;
        width: 24px;
        height: 24px;
        display: block; }
        @media screen and (max-width: 767px) {
          .content-3__accordion_ttl::before {
            margin-bottom: 0px;
            position: absolute;
            right: 20px; } }
      .content-3__accordion_ttl.active {
        color: #fff;
        background: #FD0102;
        padding-top: 65px;
        cursor: default; }
        @media screen and (max-width: 767px) {
          .content-3__accordion_ttl.active {
            margin: 0;
            padding: 20px; } }
        .content-3__accordion_ttl.active::before {
          display: none; }
          @media screen and (max-width: 767px) {
            .content-3__accordion_ttl.active::before {
              margin-bottom: 0px;
              position: absolute;
              right: 40px; } }
    .content-3__accordion_content {
      width: 100%;
      background: #FD0102;
      color: #fff;
      height: 605px;
      -ms-writing-mode: tb-rl;
      -webkit-writing-mode: vertical-rl;
              writing-mode: vertical-rl;
      padding: 70px 30px 10px;
      position: relative; }
      @media screen and (max-width: 767px) {
        .content-3__accordion_content {
          height: auto;
          -ms-writing-mode: horizontal-tb;
          -webkit-writing-mode: horizontal-tb;
                  writing-mode: horizontal-tb;
          padding: 30px 20px 30px; } }
      .content-3__accordion_content p {
        font-weight: normal !important; }
      .content-3__accordion_content .content__ttl {
        font-family: 'Noto Serif', serif;
        font-size: 32px;
        font-weight: 500; }
        @media screen and (max-width: 767px) {
          .content-3__accordion_content .content__ttl {
            font-size: 26px;
            margin-bottom: 30px;
            display: block; } }
        .content-3__accordion_content .content__ttl span {
          font-size: 16px;
          font-weight: normal; }
      .content-3__accordion_content .content__fukidashi {
        font-weight: bold !important;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        padding: 0 30px; }
        @media screen and (max-width: 767px) {
          .content-3__accordion_content .content__fukidashi {
            padding: 30px 0; } }
        .content-3__accordion_content .content__fukidashi::before {
          content: "";
          height: 18px;
          width: 20px;
          padding-bottom: 20px;
          background: url(/saiyo/concept/img/fukidashi.svg);
          display: block;
          background-repeat: no-repeat; }
          @media screen and (max-width: 767px) {
            .content-3__accordion_content .content__fukidashi::before {
              margin-right: 10px; } }
      .content-3__accordion_content .content__btn {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: end;
            -ms-flex-pack: end;
                justify-content: flex-end;
        margin-right: 30px; }
        @media screen and (max-width: 767px) {
          .content-3__accordion_content .content__btn {
            margin-right: 0px;
            margin-top: 30px; } }
        .content-3__accordion_content .content__btn a {
          border: 2px solid #fff;
          border-radius: 30px;
          color: #fff !important;
          padding: 30px 3px;
          font-weight: 500;
          display: block; }
          @media screen and (max-width: 767px) {
            .content-3__accordion_content .content__btn a {
              width: 100%;
              padding: 10px 5px;
              display: -webkit-box;
              display: -ms-flexbox;
              display: flex;
              -webkit-box-pack: center;
                  -ms-flex-pack: center;
                      justify-content: center; }
              .content-3__accordion_content .content__btn a::after {
                font-family: fontawesome;
                content: "\f105";
                display: block;
                padding-left: 10px;
                color: #fff; } }
      .content-3__accordion_content .content__close {
        cursor: pointer;
        position: absolute;
        top: 30px;
        left: 10px; }

@media not all and (max-width: 767px) {
  .sp-only {
    display: none; } }

@media screen and (max-width: 767px) {
  .pc-only {
    display: none; } }

.with-exterminal-icon {
  position: relative;
  padding: 9px 60px 11px 20px !important;
  position: relative; }
  .with-exterminal-icon::after {
    position: absolute;
    right: 20px;
    padding-right: 0px; }
  @media screen and (max-width: 767px) {
    .with-exterminal-icon {
      position: relative;
      padding: 10px 0 10px; }
      .with-exterminal-icon::after {
        position: absolute;
        right: 20px;
        padding-right: 0px; } }
  @media screen and (max-width: 767px) {
    .with-exterminal-icon {
      padding-right: 40px !important; } }
  .with-exterminal-icon:before {
    display: block;
    content: "";
    position: absolute;
    top: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    left: 74%;
    padding-left: 5px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 15px;
    height: 14px;
    background: url("../img/icon_blank.png");
    background-size: contain;
    background-repeat: no-repeat;
    image-rendering: -webkit-optimize-contrast;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden; }
    @media screen and (max-width: 767px) {
      .with-exterminal-icon:before {
        right: auto;
        -webkit-transform: translate(-50%, -50%);
                transform: translate(-50%, -50%);
        left: 47%;
        top: 50%;
        margin-left: 80px; } }

