@charset "UTF-8";
.clearfix, #section01 .block_01 .block_top .feature, #section01 .block_01 .block_top .feature .holder, #section01 .block_01 .block_middle .service, #section01 .block_01 .block_middle .service .panel dl, #section01 .block_01 .block_bottom .feature, #section01 .document_block .documents {
  *zoom: 1; }
  .clearfix:after, #section01 .block_01 .block_top .feature:after, #section01 .block_01 .block_top .feature .holder:after, #section01 .block_01 .block_middle .service:after, #section01 .block_01 .block_middle .service .panel dl:after, #section01 .block_01 .block_bottom .feature:after, #section01 .document_block .documents:after {
    content: "";
    display: table;
    clear: both; }

/* ------------------------------
共通
------------------------------ */
.container {
  position: relative; }

.heading_sec {
  font-size: 32px;
  font-weight: bold;
  line-height: 1.3;
  text-align: center; }
  @media only screen and (max-width: 640px) {
    .heading_sec {
      font-size: 26px; } }
  .heading_sec::after {
    content: "";
    width: 90px;
    height: 5px;
    margin: 16px auto 0;
    display: block; }

/* ------------------------------
section01
------------------------------ */
@media only screen and (max-width: 640px) {
  #section01 {
    background: #b40400; } }
#section01 .block_01 {
  background: #ededed;
  padding-top: 140px;
  position: relative; }
  @media only screen and (max-width: 640px) {
    #section01 .block_01 {
      padding-top: 50px;
      background: url(/info/ad/image/reason/bg_sec01_01.png) center top no-repeat;
      background-size: contain; } }
  #section01 .block_01::after {
    z-index: 1; }
    @media only screen and (min-width: 641px) {
      #section01 .block_01::after {
        content: "";
        background: url(/info/ad/image/reason/bg_sec01_01.png) center top no-repeat;
        background-size: cover;
        width: 1410px;
        height: 1080px;
        display: block;
        position: absolute;
        top: -100px;
        right: -15px; } }
    @media only screen and (min-width: 1201px) {
      #section01 .block_01::after {
        right: calc((1170px - 100vw) / 2);
        width: 90vw;
        height: 1600px; } }
  #section01 .block_01 .container {
    padding: 0;
    z-index: 99; }
    @media only screen and (max-width: 640px) {
      #section01 .block_01 .container {
        padding: 0 15px; } }
    #section01 .block_01 .container::before {
      content: "";
      background: #b40400;
      width: 10000px;
      height: 2200px;
      display: block;
      position: absolute;
      top: 950px;
      left: -3300px;
      z-index: -2;
      transform: rotate(38deg); }
      @media only screen and (max-width: 640px) {
        #section01 .block_01 .container::before {
          top: 200px;
          left: -4800px; } }
  #section01 .block_01 .heading_sec {
    color: #fff;
    margin-bottom: 140px; }
    @media only screen and (max-width: 640px) {
      #section01 .block_01 .heading_sec {
        margin-bottom: 0; } }
    #section01 .block_01 .heading_sec::after {
      background: #fff; }
  #section01 .block_01 .block_top {
    color: #fff;
    padding: 60px 0 100px;
    position: relative;
    z-index: 10; }
    @media only screen and (max-width: 640px) {
      #section01 .block_01 .block_top {
        padding: 20px 0 40px; } }
    #section01 .block_01 .block_top h3 {
      height: 317px; }
      @media only screen and (max-width: 640px) {
        #section01 .block_01 .block_top h3 {
          height: auto;
          margin-bottom: 15px; } }
    #section01 .block_01 .block_top .pic {
      position: absolute;
      top: -150px;
      right: -160px;
      z-index: -1; }
      @media only screen and (max-width: 640px) {
        #section01 .block_01 .block_top .pic {
          position: static; } }
    #section01 .block_01 .block_top .feature {
      margin-top: 120px;
      display: inline-block;
      position: relative;
      left: 50%;
      transform: translateX(-50%); }
      @media only screen and (max-width: 640px) {
        #section01 .block_01 .block_top .feature {
          margin-top: 40px;
          display: block;
          position: static;
          transform: none; } }
      #section01 .block_01 .block_top .feature .holder {
        float: left; }
        @media only screen and (max-width: 640px) {
          #section01 .block_01 .block_top .feature .holder {
            text-align: center;
            float: none; } }
        #section01 .block_01 .block_top .feature .holder img {
          float: left; }
          @media only screen and (max-width: 640px) {
            #section01 .block_01 .block_top .feature .holder img {
              margin-bottom: 15px;
              float: none; } }
        #section01 .block_01 .block_top .feature .holder dl {
          padding: 30px 0 0 10px;
          float: left; }
          @media only screen and (max-width: 640px) {
            #section01 .block_01 .block_top .feature .holder dl {
              padding: 0;
              float: none; } }
          #section01 .block_01 .block_top .feature .holder dl dt {
            font-size: 20px;
            line-height: 1.3;
            margin-bottom: 12px; }
          #section01 .block_01 .block_top .feature .holder dl dd {
            font-size: 36px;
            font-weight: bold; }
            #section01 .block_01 .block_top .feature .holder dl dd.bigup.active {
              animation: bigup 3s ease-out infinite; }
            #section01 .block_01 .block_top .feature .holder dl dd span {
              font-size: 58px; }
        #section01 .block_01 .block_top .feature .holder:not(:last-child) {
          margin-right: 31px; }
          @media only screen and (max-width: 640px) {
            #section01 .block_01 .block_top .feature .holder:not(:last-child) {
              margin-right: 0;
              margin-bottom: 40px; } }
    #section01 .block_01 .block_top .note {
      font-size: 14px;
      text-align: right;
      margin-top: 5px; }
      @media only screen and (max-width: 640px) {
        #section01 .block_01 .block_top .note {
          margin-top: 15px; } }
  #section01 .block_01 .block_middle {
    padding-bottom: 160px;
    position: relative; }
    @media only screen and (max-width: 640px) {
      #section01 .block_01 .block_middle {
        padding-bottom: 30px; } }
    @media only screen and (min-width: 641px) {
      #section01 .block_01 .block_middle::before {
        content: "";
        background: url(/info/ad/image/reason/bg_sec01_02.png) center top no-repeat;
        background-size: cover;
        width: 1000px;
        height: 500px;
        display: block;
        position: absolute;
        bottom: -200px;
        left: -50px;
        z-index: -3; } }
    @media only screen and (min-width: 1201px) {
      #section01 .block_01 .block_middle::before {
        bottom: -500px;
        left: calc((1170px - 100vw) / 2);
        width: 90vw;
        height: 1000px; } }
    #section01 .block_01 .block_middle .service {
      margin-right: -2%; }
      @media only screen and (max-width: 640px) {
        #section01 .block_01 .block_middle .service {
          margin-right: 0; } }
      #section01 .block_01 .block_middle .service .panel {
        text-align: center;
        background: #fff;
        width: 48%;
        margin-right: 2%;
        margin-bottom: 30px;
        padding: 30px 30px 50px;
        float: left;
        position: relative; }
        @media only screen and (max-width: 640px) {
          #section01 .block_01 .block_middle .service .panel {
            width: 100%;
            padding: 30px 20px 40px;
            float: none; } }
        #section01 .block_01 .block_middle .service .panel:nth-child(3),
		#section01 .block_01 .block_middle .service .panel:nth-child(5){
          clear: both; }
        #section01 .block_01 .block_middle .service .panel h4 {
          font-size: 24px;
          font-weight: bold;
          text-align: left;
          line-height: 1.3;
          margin-bottom: 20px;
          padding-left: 130px; }
          @media only screen and (max-width: 640px) {
            #section01 .block_01 .block_middle .service .panel h4 {
              font-size: 20px;
              padding-left: 20px; } }
          @media only screen and (max-width: 640px) {
            #section01 .block_01 .block_middle .service .panel h4 br {
              display: none; } }
        @media only screen and (max-width: 640px) {
          #section01 .block_01 .block_middle .service .panel .pictogram {
            margin-bottom: 10px; } }
        #section01 .block_01 .block_middle .service .panel .pictogram .inner {
          text-align: center;
          width: 999px;
          display: table-cell;
          vertical-align: middle; }
          @media only screen and (max-width: 640px) {
            #section01 .block_01 .block_middle .service .panel .pictogram .inner {
              width: 100%;
              height: auto;
              display: block; } }
        #section01 .block_01 .block_middle .service .panel dl {
          display: inline-block;
          text-align: center; }
          @media only screen and (max-width: 640px) {
            #section01 .block_01 .block_middle .service .panel dl {
              margin-bottom: 20px; } }
          #section01 .block_01 .block_middle .service .panel dl dt {
            font-size: 24px;
            font-weight: bold;
            line-height: 1.4;
            padding: 10px 0 8px; }
            @media only screen and (max-width: 640px) {
              #section01 .block_01 .block_middle .service .panel dl dt {
                font-size: 20px; } }
          #section01 .block_01 .block_middle .service .panel dl dd {
            color: #e52c29;
            font-size: 40px;
            font-weight: bold; }
            @media only screen and (max-width: 640px) {
              #section01 .block_01 .block_middle .service .panel dl dd {
                font-size: 30px; } }
            #section01 .block_01 .block_middle .service .panel dl dd span.value {
              font-size: 85px; }
              @media only screen and (max-width: 640px) {
                #section01 .block_01 .block_middle .service .panel dl dd span.value {
                  font-size: 60px; } }
            #section01 .block_01 .block_middle .service .panel dl dd span.unit {
              font-size: 65px; }
              @media only screen and (max-width: 640px) {
                #section01 .block_01 .block_middle .service .panel dl dd span.unit {
                  font-size: 50px; } }
            #section01 .block_01 .block_middle .service .panel dl dd.firstview {
              font-size: 24px;
              font-weight: bold;
              line-height: 1.1;
              color: #181818; }
              #section01 .block_01 .block_middle .service .panel dl dd.firstview span.value {
                font-size: 62px;
                color: #e52c29; }
        #section01 .block_01 .block_middle .service .panel p {
          font-size: 18px;
          line-height: 1.6;
          text-align: left;
          margin: 10px 0  40px; }
          @media only screen and (max-width: 640px) {
            #section01 .block_01 .block_middle .service .panel p {
              font-size: 16px;
              margin-bottom: 20px;
              height: auto; } }
          #section01 .block_01 .block_middle .service .panel p.height_m {
            height: 84px; }
            @media only screen and (max-width: 640px) {
              #section01 .block_01 .block_middle .service .panel p.height_m {
                height: auto; } }
          #section01 .block_01 .block_middle .service .panel p.height_l {
            height: 120px; }
            @media only screen and (max-width: 640px) {
              #section01 .block_01 .block_middle .service .panel p.height_l {
                height: auto; } }
        #section01 .block_01 .block_middle .service .panel .btn {
          color: #fff;
          font-size: 24px;
          font-weight: bold;
          text-align: center;
          line-height: 1.4;
          background: #cd0400;
          padding: 16px 20px;
          border-radius: 999px;
          box-shadow: 0 5px 0 0 #980300;
          display: block;
          transition: all 0.5s ease; }
          @media only screen and (max-width: 640px) {
            #section01 .block_01 .block_middle .service .panel .btn {
              font-size: 18px;
              padding: 10px 20px;
              float: none; } }
          #section01 .block_01 .block_middle .service .panel .btn span {
            font-size: 18px;
            display: block; }
            @media only screen and (max-width: 640px) {
              #section01 .block_01 .block_middle .service .panel .btn span {
                font-size: 14px; } }
          #section01 .block_01 .block_middle .service .panel .btn:hover {
            background: #ff1f1b; }
        #section01 .block_01 .block_middle .service .panel:nth-child(1) .pictogram .inner, #section01 .block_01 .block_middle .service .panel:nth-child(2) .pictogram .inner {
          height: 270px; }
          @media only screen and (max-width: 640px) {
            #section01 .block_01 .block_middle .service .panel:nth-child(1) .pictogram .inner, #section01 .block_01 .block_middle .service .panel:nth-child(2) .pictogram .inner {
              height: auto; } }
        #section01 .block_01 .block_middle .service .panel:nth-child(3) .pictogram .inner, #section01 .block_01 .block_middle .service .panel:nth-child(4) .pictogram .inner {
          height: 235px; }
          @media only screen and (max-width: 640px) {
            #section01 .block_01 .block_middle .service .panel:nth-child(3) .pictogram .inner, #section01 .block_01 .block_middle .service .panel:nth-child(4) .pictogram .inner {
              height: auto; } }
        #section01 .block_01 .block_middle .service .panel::before {
          font-family: 'Roboto', Arial, sans-serif;
          font-weight: 700;
          color: #fff;
          font-size: 48px;
          position: absolute;
          top: 22px;
          left: 20px;
          z-index: 1; }
          @media only screen and (max-width: 640px) {
            #section01 .block_01 .block_middle .service .panel::before {
              font-size: 20px;
              top: 9px;
              left: 8px; } }
        #section01 .block_01 .block_middle .service .panel::after {
          width: 0;
          height: 0;
          border-style: solid;
          border-width: 170px 170px 0 0;
          border-color: #151861 transparent transparent transparent;
          content: "";
          position: absolute;
          top: 0;
          left: 0; }
          @media only screen and (max-width: 640px) {
            #section01 .block_01 .block_middle .service .panel::after {
              border-width: 60px 60px 0 0; } }
        #section01 .block_01 .block_middle .service .panel:nth-child(1)::before {
          content: "01"; }
        #section01 .block_01 .block_middle .service .panel:nth-child(2)::before {
          content: "02"; }
        #section01 .block_01 .block_middle .service .panel:nth-child(3)::before {
          content: "03"; }
        #section01 .block_01 .block_middle .service .panel:nth-child(4)::before {
          content: "04"; }
        #section01 .block_01 .block_middle .service .panel:nth-child(5)::before {
          content: "05"; }
  #section01 .block_01 .block_bottom {
    color: #fff;
    position: relative;
    z-index: 10;
    padding-top: 180px; }
    @media only screen and (max-width: 640px) {
      #section01 .block_01 .block_bottom {
        background: #800603;
        margin: 0 -15px;
        padding: 60px 15px; } }
    #section01 .block_01 .block_bottom::after {
      content: "";
      background: #800603;
      width: 10000px;
      height: 2500px;
      display: block;
      position: absolute;
      top: 700px;
      right: -3000px;
      z-index: -2;
      transform: rotate(-20deg); }
      @media only screen and (max-width: 640px) {
        #section01 .block_01 .block_bottom::after {
          display: none; } }
    #section01 .block_01 .block_bottom h3 {
      text-align: right; }
      @media only screen and (max-width: 640px) {
        #section01 .block_01 .block_bottom h3 {
          text-align: center;
          margin-bottom: 20px; } }
    #section01 .block_01 .block_bottom .pic {
      position: absolute;
      top: -120px;
      left: -130px;
      z-index: -1; }
      @media only screen and (max-width: 640px) {
        #section01 .block_01 .block_bottom .pic {
          position: static; } }
    #section01 .block_01 .block_bottom .feature {
      margin: 80px 0 90px; }
      @media only screen and (max-width: 640px) {
        #section01 .block_01 .block_bottom .feature {
          margin: 30px 0 40px; } }
      #section01 .block_01 .block_bottom .feature .holder {
        text-align: center;
        width: 20%;
        float: left; }
        @media only screen and (max-width: 640px) {
          #section01 .block_01 .block_bottom .feature .holder {
            width: 100%;
            float: none; } }
        #section01 .block_01 .block_bottom .feature .holder .pictogram {
          margin-bottom: 20px; }
          @media only screen and (max-width: 640px) {
            #section01 .block_01 .block_bottom .feature .holder .pictogram {
              margin-bottom: 10px; } }
          #section01 .block_01 .block_bottom .feature .holder .pictogram .inner {
            text-align: center;
            width: 999px;
            height: 181px;
            display: table-cell;
            vertical-align: middle; }
            @media only screen and (max-width: 640px) {
              #section01 .block_01 .block_bottom .feature .holder .pictogram .inner {
                width: 100%;
                height: auto;
                display: block; } }
        #section01 .block_01 .block_bottom .feature .holder p {
          font-size: 18px;
          line-height: 1.5;
          width: 999px;
          display: table-cell;
          vertical-align: middle; }
          @media only screen and (max-width: 640px) {
            #section01 .block_01 .block_bottom .feature .holder p {
              font-size: 16px;
              width: 100%;
              display: block; } }
        @media only screen and (max-width: 640px) {
          #section01 .block_01 .block_bottom .feature .holder:not(:last-child) {
            margin-bottom: 30px; } }
#section01 .document_block {
  background: url(/info/ad/image/common/bg_pattern_03.jpg);
  padding: 40px 0;
  position: relative;
  z-index: 100; }
  @media only screen and (max-width: 640px) {
    #section01 .document_block {
      padding: 20px 0; } }
  #section01 .document_block .documents {
    text-align: center;
    margin-top: 20px;
    display: inline-block;
    position: relative;
    left: 50%;
    transform: translateX(-50%); }
    @media only screen and (max-width: 640px) {
      #section01 .document_block .documents {
        display: block;
        position: static;
        transform: none; } }
    #section01 .document_block .documents .holder {
      margin: 20px 25px;
      float: left; }
      @media only screen and (max-width: 640px) {
        #section01 .document_block .documents .holder {
          margin: 0;
          float: none; } }
      #section01 .document_block .documents .holder p {
        margin-top: 20px; }
/*#section01 .document_block .documents .holder_lastchild {clear:both;}*/
      #section01 .document_block .documents .holder:nth-child(3),  #section01 .document_block .documents .holder:nth-child(5) {
        clear: both; }
      #section01 .document_block .documents .holder:not(:last-child) {
        margin-bottom: 20px; }
      #section01 .document_block .documents .holder .btn_document {
        color: #fff;
        font-size: 18px;
        font-weight: bold;
        line-height: 1.3;
        text-align: center;
        background: #0a0f93;
        min-width: 480px;
        padding: 16px 20px 16px 50px;
        border-radius: 999px;
        box-shadow: 0 5px 0 0 #151861;
        display: inline-block;
        position: relative;
        transition: all 0.5s ease; }
        @media only screen and (max-width: 640px) {
          #section01 .document_block .documents .holder .btn_document {
            font-size: 16px;
            width: 100%;
            min-width: inherit;
            padding-left: 45px; } }
        #section01 .document_block .documents .holder .btn_document::before {
          font-family: "fontello";
          font-style: normal;
          font-weight: normal;
          speak: none;
          display: inline-block;
          text-decoration: inherit;
          text-align: center;
          -webkit-font-smoothing: antialiased;
          -moz-osx-font-smoothing: grayscale;
          font-size: 22px;
          content: "\e807";
          position: absolute;
          top: 50%;
          left: 30px;
          transform: translateY(-50%); }
          @media only screen and (max-width: 640px) {
            #section01 .document_block .documents .holder .btn_document::before {
              left: 20px; } }
        #section01 .document_block .documents .holder .btn_document:hover {
          background: #0f16db; }

/*# sourceMappingURL=reason.css.map */
