@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Lato:ital,wght@0,100;0,300;0,400;0,700;0,900;1,100;1,300;1,400;1,700;1,900&family=Roboto+Condensed:ital,wght@0,100..900;1,100..900&family=Roboto:ital,wght@0,100;0,300;0,400;0,500;0,700;0,900;1,100;1,300;1,400;1,500;1,700;1,900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Roboto+Condensed:ital,wght@0,100..900;1,100..900&family=Roboto:ital,wght@0,100;0,300;0,400;0,500;0,700;0,900;1,100;1,300;1,400;1,500;1,700;1,900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&display=swap");
main {
  overflow: hidden; }
  main .en {
    font-family: "Roboto", sans-serif;
    line-height: 1;
    letter-spacing: -.04em; }
  main .header {
    width: 100vw;
    position: relative;
    top: 0;
    left: 0;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    background: url("../images/common/header_bg.jpg") no-repeat center center/cover;
    z-index: 99;
    /*&.has-bg{
    	background-color: #fff;
    	.header--inner{
    		&--right{
    		}
    	}
    }
    &.scrolled{
    	background-color: #fff;
    	.header--inner{
    		&--right{
    		}
    	}
    }*/ }
    main .header .inner {
      width: 100%;
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 1.2em 2.5em;
      position: relative;
      transition: all .3s ease; }
      main .header .inner--logo {
        width: auto;
        display: flex;
        align-items: center;
        position: relative;
        z-index: 999; }
        main .header .inner--logo h1 {
          width: 18.125vw;
          max-width: 232px; }
        main .header .inner--logo p {
          font-size: clamp(11px, 1.09375vw, 14px);
          color: #fff; }
      main .header .inner .nav-list .hamburger {
        display: none; }
      main .header .inner .nav-list .nav-area {
        /*position: fixed;
        width: 100vw;
        height: 100vh;
        background-image: linear-gradient(180deg, #00845C, #00422E 100%);
        padding: 2.5em 0;
        top: 0;
        right: -100%;
        //left: 50%;
        //transform: translateX(-50%);
        z-index: 9;
        transition: 0.4s;
        opacity: 0;
        visibility: hidden;
        &.-active{
            right: 0;
            opacity: 1;
            visibility: visible;
        }*/ }
        main .header .inner .nav-list .nav-area .global-navigation {
          /*width: 100%;
          height: 100%;
          overflow-y: auto;
          -webkit-overflow-scrolling: touch;
          padding-bottom: 5em;
          margin-top: 2em;
          line-height: 1;
          letter-spacing: .1em;*/
          /*a{
              text-transform: uppercase;
              line-height: 1.4;
              color: $maincolor;
          }*/ }
          main .header .inner .nav-list .nav-area .global-navigation--list {
            display: flex;
            align-items: flex-end; }
            main .header .inner .nav-list .nav-area .global-navigation--list li {
              font-weight: 500;
              line-height: 1;
              padding: 0 1em; }
              main .header .inner .nav-list .nav-area .global-navigation--list li a {
                color: #fff;
                position: relative; }
                main .header .inner .nav-list .nav-area .global-navigation--list li a:after {
                  content: '';
                  display: block;
                  position: absolute;
                  width: 0%;
                  height: 2px;
                  background-image: linear-gradient(90deg, #C5DFFC 0%, #468FD5 100%);
                  bottom: -.5em;
                  left: 0;
                  transition: all .3s ease;
                  z-index: 1; }
                main .header .inner .nav-list .nav-area .global-navigation--list li a:hover:after {
                  width: 100%; }
  main article {
    position: relative; }
    main article .contact-btn {
      position: fixed;
      bottom: 1.5em;
      right: 0;
      z-index: 999;
      background-color: #fff;
      border-radius: .5rem;
      padding: .5em;
      transition: all .3s ease; }
      main article .contact-btn--category {
        width: 6.5em;
        height: 6.5em;
        border-radius: .5rem;
        font-size: clamp(10px, 0.78125vw, 12px);
        letter-spacing: 0;
        text-align: center; }
        main article .contact-btn--category a {
          display: flex;
          justify-content: center;
          align-items: center;
          align-content: center;
          flex-direction: column;
          color: #fff; }
          main article .contact-btn--category a .icon {
            width: 30%;
            margin: 0 auto; }
        main article .contact-btn--category.stock {
          background-color: #07BBE4; }
        main article .contact-btn--category.inquiry {
          background-color: #F69B11; }
        main article .contact-btn--category:nth-of-type(n+2) {
          margin-top: .5em; }
      main article .contact-btn.bottom {
        opacity: 0; }
  main .footer {
    border-top: 2px solid #F2F2F2; }
    main .footer--over {
      width: 100%;
      position: relative;
      z-index: 1;
      isolation: isolate;
      mix-blend-mode: normal;
      /* もしくは mix-blend-mode を指定しない */
      padding: 2px 0 5em;
      clip-path: inset(0 0 0 0); }
      main .footer--over:before {
        content: "";
        display: block;
        position: absolute;
        width: 100%;
        height: 50%;
        background-color: #F9F9F9;
        top: -2px;
        left: 50%;
        transform: translateX(-50%);
        z-index: 1; }
      main .footer--over .parallax-bg {
        position: fixed;
        top: 0;
        left: 0;
        z-index: -1;
        width: 100%;
        height: 100%;
        background: url("../images/top/lead_bg.jpg") no-repeat center center/cover; }
        main .footer--over .parallax-bg img {
          display: none; }
      main .footer--over .inner {
        width: 85%;
        max-width: 1088px;
        margin: 0 auto; }
        main .footer--over .inner--main h2 {
          font-size: clamp(19px, 1.875vw, 24px);
          font-weight: bold;
          text-align: center;
          color: #196BB4;
          padding: 1em 0;
          margin-top: 3.5em;
          position: relative;
          z-index: 1; }
          main .footer--over .inner--main h2 span {
            display: inline-block;
            width: 100%;
            font-size: clamp(64px, 8.59375vw, 110px);
            font-style: italic;
            text-transform: uppercase;
            background: linear-gradient(90deg, #196BB4 0%, #8CB5D9 25%, #D3E7F8 50%, #8CB5D9 75%, #196BB4 100%);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            opacity: .2;
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
            z-index: -1; }
        main .footer--over .inner--main h3 {
          width: 80%;
          margin: 1em auto 0;
          font-size: clamp(24px, 2.34375vw, 30px);
          font-weight: bold;
          font-style: italic;
          line-height: 1.5;
          text-align: center;
          position: relative; }
          main .footer--over .inner--main h3:before, main .footer--over .inner--main h3:after {
            display: block;
            position: absolute;
            font-weight: 400;
            color: #ccc; }
          main .footer--over .inner--main h3:before {
            content: '「';
            top: 0;
            left: 0; }
          main .footer--over .inner--main h3:after {
            content: '」';
            bottom: 0;
            right: 0; }
          main .footer--over .inner--main h3 span {
            display: inline-block;
            background: linear-gradient(180deg, #196BB4 0%, #003366 100%);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            padding: 0 0.22em; }
        main .footer--over .inner--wrap {
          display: flex;
          justify-content: space-between;
          flex-wrap: wrap;
          position: relative;
          z-index: 2; }
          main .footer--over .inner--wrap--category {
            overflow: hidden;
            width: 32%;
            background-color: #fff;
            box-shadow: 0px 4px 8px 2px rgba(154, 154, 154, 0.05);
            padding-bottom: 2em; }
            main .footer--over .inner--wrap--category h4 {
              font-size: clamp(14px, 1.40625vw, 18px);
              font-weight: bold;
              text-align: center;
              color: #196BB4;
              background-color: #DFEBF8;
              padding: .5em; }
            main .footer--over .inner--wrap--category--texts {
              height: 13.5em;
              position: relative;
              display: flex;
              justify-content: center;
              align-items: center;
              align-content: space-between;
              flex-wrap: wrap; }
              main .footer--over .inner--wrap--category--texts p {
                text-align: center;
                margin-top: 2em; }
              main .footer--over .inner--wrap--category--texts .btn {
                width: 90%;
                margin: 0 auto;
                /*position: absolute;
                bottom: 0;
                left: 50%;
                transform: translateX(-50%);*/ }
            main .footer--over .inner--wrap--category.tel-contact .inner--wrap--category--texts {
              display: flex;
              justify-content: center;
              align-items: center;
              align-content: center;
              flex-wrap: wrap; }
              main .footer--over .inner--wrap--category.tel-contact .inner--wrap--category--texts .tel {
                width: 100%;
                font-size: clamp(26px, 2.5vw, 32px);
                font-weight: bold;
                margin-top: 1em; }
                main .footer--over .inner--wrap--category.tel-contact .inner--wrap--category--texts .tel span {
                  color: #196BB4;
                  display: inline-block;
                  padding-left: 1.5em;
                  position: relative; }
                  main .footer--over .inner--wrap--category.tel-contact .inner--wrap--category--texts .tel span:before {
                    content: '';
                    display: block;
                    position: absolute;
                    width: 1em;
                    height: 1em;
                    background: url("../images/common/icon_phone-call.png") no-repeat center center/cover;
                    top: 50%;
                    left: 0;
                    transform: translateY(-50%); }
              main .footer--over .inner--wrap--category.tel-contact .inner--wrap--category--texts p {
                margin-top: 0; }
                main .footer--over .inner--wrap--category.tel-contact .inner--wrap--category--texts p .border {
                  border: 1px solid #ddd;
                  padding: .2em .7em;
                  margin-right: 1em; }
    main .footer--under {
      background: url("../images/common/footer_bg.jpg") no-repeat center center/cover; }
      main .footer--under .inner {
        width: 100%;
        padding: 1.5em 2.5em;
        display: flex;
        align-items: center; }
        main .footer--under .inner--links {
          display: flex;
          align-items: center; }
          main .footer--under .inner--links .logo {
            width: 17.8125vw;
            max-width: 228px; }
          main .footer--under .inner--links ul {
            display: flex;
            align-items: flex-end; }
            main .footer--under .inner--links ul li {
              font-weight: 500;
              line-height: 1;
              padding: 0 1em; }
        main .footer--under .inner .copyright {
          display: inline;
          font-size: clamp(11px, 1.09375vw, 14px);
          letter-spacing: .05em;
          text-align: right;
          color: #949494;
          margin: 0 0 0 auto; }

#pagetop {
  width: 4.6875vw;
  height: 4.6875vw;
  max-width: 60px;
  max-height: 60px;
  position: fixed;
  left: 2em;
  bottom: 2em;
  z-index: 200;
  transition: all .1s ease; }
  #pagetop a {
    display: block;
    width: 100%;
    height: 100%;
    transition: all .3s ease;
    background: url("../images/common/btn_page-top.png") no-repeat center center/cover;
    /*&:before,
    &:after{
    	content: '';
    	display: block;
    	position: absolute;
    	top: 50%;
    	left: 50%;
    	transform: translate(-50%,-50%);
    }
    &:before{
    	box-sizing: border-box;
    	width: 100%;
    	height: 100%;
    	background-color: $maincolor;
    	border: 1px solid #fff;
    	border-radius: 50%;
    }
    &:after{
    	width: 25%;
    	height: 25%;
    	border-top: 2px solid #fff;
    	border-right: 2px solid #fff;
    	transform: rotate(-45deg) translate(-20%,-50%);
    }*/ }
    #pagetop a:hover {
      opacity: 1;
      transform: scale(1.04); }
  #pagetop.bottom {
    bottom: 7.5em !important; }

@media screen and (max-width: 767px) {
  main .header .inner {
    padding: .5em 0 .5em 1.2em; }
    main .header .inner--logo h1 {
      width: 57.6vw; }
    main .header .inner--logo p {
      font-size: clamp(11px, 3.7333333333vw, 14px); }
    main .header .inner .nav-list .hamburger {
      display: flex;
      border: none;
      background-color: transparent;
      margin-left: auto;
      position: relative;
      z-index: 10;
      padding-block: 0;
      padding-inline: 0; }
      main .header .inner .nav-list .hamburger--line {
        display: block;
        width: 4.5em;
        height: 4.5em;
        border-radius: 50%;
        position: relative;
        transition: all .4s; }
        main .header .inner .nav-list .hamburger--line span {
          position: absolute;
          width: 50%;
          height: 2px;
          left: 50%;
          z-index: 1001;
          transform: translateX(-50%);
          background-color: #fff;
          transition: all .4s;
          box-sizing: border-box;
          cursor: pointer;
          isolation: isolate;
          mix-blend-mode: normal;
          /* もしくは mix-blend-mode を指定しない */ }
          main .header .inner .nav-list .hamburger--line span:nth-of-type(1) {
            top: 35%; }
          main .header .inner .nav-list .hamburger--line span:nth-of-type(2) {
            top: 50%;
            transform: translate(-50%, -50%); }
          main .header .inner .nav-list .hamburger--line span:nth-of-type(3) {
            bottom: 35%; }
      main .header .inner .nav-list .hamburger.-active .hamburger--line span:nth-of-type(1) {
        top: 50%;
        -webkit-transform: translate(-50%, -50%) rotate(-45deg);
        transform: translateY(-50%, -50%) rotate(-45deg); }
      main .header .inner .nav-list .hamburger.-active .hamburger--line span:nth-of-type(2) {
        display: none; }
      main .header .inner .nav-list .hamburger.-active .hamburger--line span:nth-of-type(3) {
        top: 50%;
        -webkit-transform: translate(-50%, -50%) rotate(45deg);
        transform: translate(-50%, -50%) rotate(45deg); }
    main .header .inner .nav-list .nav-area {
      position: fixed;
      width: 60vw;
      height: 100vh;
      background-color: #fff;
      padding: 0 2em;
      top: 4.8em;
      right: -100%;
      z-index: 9;
      transition: 0.4s;
      opacity: 0;
      visibility: hidden; }
      main .header .inner .nav-list .nav-area.-active {
        right: 0;
        opacity: 1;
        visibility: visible; }
      main .header .inner .nav-list .nav-area .global-navigation {
        width: 100%;
        height: 100%;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        line-height: 1;
        letter-spacing: .1em;
        /*a{
            text-transform: uppercase;
            line-height: 1.4;
            color: $maincolor;
        }*/ }
        main .header .inner .nav-list .nav-area .global-navigation--list {
          align-items: stretch;
          flex-direction: column; }
          main .header .inner .nav-list .nav-area .global-navigation--list li {
            border-bottom: 2px solid #eee;
            padding: 2em 0; }
            main .header .inner .nav-list .nav-area .global-navigation--list li a {
              color: #333; }
              main .header .inner .nav-list .nav-area .global-navigation--list li a:after {
                display: none; }
            main .header .inner .nav-list .nav-area .global-navigation--list li:last-of-type {
              border-bottom: none; }
  main article .contact-btn {
    width: 100%;
    bottom: 0 !important;
    border-radius: 0;
    padding: .5em 5%;
    display: flex;
    justify-content: space-between; }
    main article .contact-btn--category {
      width: 49%;
      height: auto;
      border-radius: .5rem;
      font-size: clamp(10px, 2.6666666667vw, 12px); }
      main article .contact-btn--category a {
        display: flex;
        justify-content: center;
        align-items: center;
        align-content: center;
        flex-direction: row;
        padding: 1em; }
        main article .contact-btn--category a .icon {
          width: 1.2em;
          margin: 0 .5em 0 0; }
      main article .contact-btn--category:nth-of-type(n+2) {
        margin-top: 0; }
    main article .contact-btn.bottom {
      opacity: 0; }
  main .footer--over {
    padding: 2px 0 2.5em; }
    main .footer--over:before {
      height: 20em; }
    main .footer--over .inner {
      width: 88%; }
      main .footer--over .inner--main h2 {
        font-size: clamp(24px, 6.4vw, 24px);
        margin-top: 1em; }
        main .footer--over .inner--main h2 span {
          font-size: clamp(64px, 17.0666666667vw, 110px);
          opacity: .1; }
      main .footer--over .inner--main h3 {
        font-size: clamp(28px, 7.4666666667vw, 30px); }
      main .footer--over .inner--wrap--category {
        width: 100%;
        margin: 1em auto 0; }
        main .footer--over .inner--wrap--category h4 {
          font-size: clamp(18px, 4.8vw, 18px);
          font-weight: bold;
          text-align: center;
          color: #196BB4;
          background-color: #DFEBF8;
          padding: .5em; }
        main .footer--over .inner--wrap--category--texts {
          height: auto; }
          main .footer--over .inner--wrap--category--texts .btn {
            width: 90%;
            margin: 1.2em auto 0;
            position: relative;
            bottom: inherit;
            left: inherit;
            transform: none; }
        main .footer--over .inner--wrap--category.tel-contact .inner--wrap--category--texts {
          padding: 2.5em .5em; }
          main .footer--over .inner--wrap--category.tel-contact .inner--wrap--category--texts .tel {
            font-size: clamp(32px, 8.5333333333vw, 32px);
            margin-top: 0; }
  main .footer--under .inner {
    flex-direction: column;
    padding: 2.5em 1em 1em; }
    main .footer--under .inner--links {
      flex-direction: column; }
      main .footer--under .inner--links .logo {
        width: 55.2vw; }
      main .footer--under .inner--links ul {
        justify-content: center;
        align-items: center; }
        main .footer--under .inner--links ul li {
          margin-top: 1.5em; }
    main .footer--under .inner .copyright {
      font-size: clamp(11px, 3.7333333333vw, 14px);
      text-align: center;
      margin: 3em auto 0; }

  #pagetop {
    width: 13.3333333333vw;
    height: 13.3333333333vw;
    left: 0;
    bottom: 14.6666666667vw !important; }
    #pagetop.bottom {
      bottom: 10.5em !important; } }
@media (min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none; } }
/* =========================================================
 * reset　　　    /*リセット
========================================================= */
blockquote, body, div, dl, dt, dd, fieldset, form, h1, h2, h3, h4, h5, h6, input, li, ol, p, pre, select, span, textarea, td, th, ul, figure, figcaption {
  margin: 0px;
  padding: 0px; }

fieldset, img {
  border: 0; }

h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
  font-weight: normal; }

ol {
  list-style-type: none; }

ul {
  list-style-type: none; }
  ul li {
    list-style-type: none; }
    ul li img {
      line-height: 0;
      font-size: 0;
      vertical-align: top; }

img {
  border: none;
  vertical-align: bottom; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

caption, th {
  text-align: left; }

iframe {
  border: none; }

a:focus {
  outline: none; }

address, caption, cite, code, dfn, em, strong, th, var {
  font-style: normal;
  font-weight: normal; }

/* IE */
* html ul li dl, * html ol li dl {
  display: inline; }
*:first-child + html ul li dl, *:first-child + html ol li dl {
  display: inline; }

/* =========================================================
 * default settings      　   /*デフォルトセッティング 全体の設定
========================================================= */
* {
  box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box; }

html, body {
  font-size: 62.5%;
  overflow: auto; }

body {
  overflow: hidden;
  -webkit-text-size-adjust: 100%;
  font: inherit;
  font-size: clamp(13px, 1.25vw, 16px);
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  letter-spacing: .05em;
  line-height: 1.8;
  font-feature-settings: "palt";
  /*日本語フォントの文字間隔（カーニング）全角スペースを詰める調整、句読点や括弧などの約物を含めた文字間をしっかり詰めてくれます。*/
  color: #333;
  background: #fff; }

main {
  display: block; }

/*リンクテキスト全般の設定*/
a {
  width: 100%;
  height: 100%;
  display: block;
  text-decoration: none;
  color: #000;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -ms-transition: all 0.3s ease;
  transition: all 0.3s ease; }
  a:hover {
    transform: scale(1.04);
    opacity: 0.7;
    -webkit-opacity: .7;
    -moz-opacity: .7;
    filter: alpha(opacity=70);
    -ms-filter: "alpha(opacity=70)"; }

.disabled {
  pointer-events: none; }

.soon {
  pointer-events: none;
  opacity: .5; }

.hide,
.hidden {
  visibility: hidden; }

/*テキスト周りのタグ*/
p {
  line-break: strict; }

/*画像全般の設定*/
img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
  border: none; }

/*videoタグ*/
video {
  max-width: 100%; }

/*iframeタグ*/
iframe {
  width: 100%; }

/*レスポンシブ切り替え表示の設定*/
.pc {
  display: block; }

.sp {
  display: none; }

/* =========================================================
 * modal
========================================================= */
.mfp-bg {
  background-color: rgba(0, 0, 0, 0.8);
  -webkit-transition: all 0.15s ease-out;
  -moz-transition: all 0.15s ease-out;
  transition: all 0.15s ease-out; }

.mfp-close {
  text-indent: -9999px;
  font-family: serif;
  font-size: 64px;
  right: -10px !important;
  padding-right: 0 !important;
  top: -50px !important; }

/* overlay animate in */
.mfp-bg.mfp-ready {
  opacity: 0.8; }

/* overlay animate out */
.mfp-bg.mfp-removing {
  opacity: 0; }

/* content at start */
.mfp-wrap .modal-content {
  transform: translateY(-30px);
  opacity: 0;
  -webkit-transition: all 0.3s ease-out;
  -moz-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out; }

/* content animate it */
.mfp-wrap.mfp-ready .modal-content {
  transform: translateY(0);
  opacity: 1; }

/* content animate out */
.mfp-wrap.mfp-removing .modal-content {
  transform: translateY(30px);
  opacity: 0; }

.mfp-iframe-holder .mfp-content {
  width: 125vmin !important;
  max-width: 90% !important; }

@media screen and (max-width: 767px) {
  /*.mfp-container{
  	padding: 0;
  }
  .modal-content{
  	max-width: 94%;
  	margin: 15vw auto;
  	.popup-modal-close{
  		cursor: pointer;
  		position: absolute;
  		right: 0;
  		top: -41px;
  		span{
  			img{
  				max-width: 31px;
  			}
  		}
  	}
  	&--inner{
  		background-color: #fff;
  		padding: 15px 5% 30px 5%;
  		.team{
  			p{
  				@include fz_vw(11);
  			}
  		}
  		.content{
  			margin-top: 20px;
  			h2{
  				letter-spacing: .04em;
  				@include fz_vw(16);
  			}
  			p{
  				margin-top: 20px;
  				@include fz_vw(12);
  			}
  		}
  		.contact{
  			margin-top: 30px;
  			p{
  				@include fz_vw(12);
  				a{
  					&.tel{
  						pointer-events: visible;
  						text-decoration: underline;
  					}
  				}
  			}
  		}
  	}
  }*/ }
@media screen and (max-width: 767px) {
  body {
    -webkit-text-size-adjust: 100%;
    background: #fff;
    min-width: 100%;
    font-size: clamp(13px, 4.2666666667vw, 16px); }

  /*リンクテキスト全般の設定*/
  a {
    -webkit-transition: none;
    -moz-transition: none;
    -ms-transition: none;
    transition: none; }
    a:hover {
      opacity: 1;
      -webkit-opacity: 1;
      -moz-opacity: 1;
      filter: alpha(opacity=100);
      /* IE lt 8 */
      -ms-filter: "alpha(opacity=100)";
      /* IE 8 */ }

  /*画像全般の設定*/
  img {
    width: 100%; }

  /*テキスト周りのタグ*/
  .att {
    font-size: 3vw !important;
    font-weight: 400;
    line-height: 1 !important;
    margin-bottom: 1em; }

  /*レスポンシブ切り替え表示の設定*/
  .pc {
    display: none; }

  .sp {
    display: block; } }
@media all and (-ms-high-contrast: none) {
  .noise {
    display: none; } }
/* =========================================================
 * font
========================================================= */
/*Lato*/
/*Roboto Condensed & Roboto*/
/*Noto Sans Japanese*/
.lato {
  font-family: "Lato", sans-serif;
  font-optical-sizing: auto; }

.roboto-condensed {
  font-family: "Roboto Condensed", sans-serif;
  font-optical-sizing: auto;
  font-style: normal; }

.roboto {
  font-family: "Roboto", sans-serif;
  font-optical-sizing: auto; }

.noto-sans-jp {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal; }

.noto-serif-jp {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-style: normal; }

/* =========================================================
 * clearfix　　   /*クリアフィックス
========================================================= */
.clearfix {
  zoom: 1; }
  .clearfix:before {
    content: "";
    display: table; }
  .clearfix:after {
    content: "";
    display: table;
    clear: both; }

/* =========================================================
 * fade Animation　　   /*フェード アニメーション
========================================================= */
.fade,
.fadein,
.fadein-top,
.fadein-left,
.fadein-right,
.opening,
.fadein-popup {
  position: relative;
  opacity: 0;
  transition: opacity 0.875s ease-in-out , transform 0.875s ease-in-out; }

.fade {
  transform: translate(0, 0); }

.fadein {
  transform: translate(0, 50px); }

.fadein-top {
  transform: translate(0, -50px); }

.fadein-left {
  transform: translate(-50px, 0); }

.fadein-right {
  transform: translate(50px, 0); }

.fadein-popup {
  translate: none;
  rotate: none;
  scale: none;
  transform: translateY(20px) scale(0.8) !important;
  transition: opacity 0.5s ease-in-out , transform 0.5s ease-in-out; }

.fade.scrollin,
.fadein.scrollin,
.fadein-top.scrollin,
.fadein-left.scrollin,
.fadein-right.scrollin,
.opening.active {
  opacity: 1;
  transform: translate(0, 0); }

.fadein-popup.scrollin {
  transform: translate(0, 0) scale(1) !important;
  animation: popup 0.55s cubic-bezier(0.22, 1, 0.36, 1) forwards; }

/* =========================================================
 * fade Animation　　   /*フェード アニメーション
========================================================= */
@keyframes topleft {
  0% {
    transform: translate(-50%, -50%); }
  100% {
    transform: translate(250%, 250%); } }
@keyframes topright {
  0% {
    transform: translate(50%, 50%); }
  100% {
    transform: translate(-100%, 200%); } }
@keyframes bottomleft {
  0% {
    transform: translate(-50%, -50%); }
  100% {
    transform: translate(150%, -250%); } }
@keyframes bottomright {
  0% {
    transform: translate(50%, 50%); }
  100% {
    transform: translate(-150%, 250%); } }
@keyframes popup {
  0% {
    opacity: 0; }
  80%, 100% {
    opacity: 1; } }
.fadein-topleft {
  animation: topleft 10s infinite linear 1s both; }

.fadein-topright {
  animation: topright 6.3s infinite linear 1s both; }

.fadein-topright02 {
  animation: topright 9.5s infinite linear 1s both; }

.fadein-bottomleft {
  animation: bottomleft 5.5s infinite linear 1s both; }

.fadein-bottomright {
  animation: bottomright 5.5s infinite linear 1s both; }

/* =========================================================
 * scrollbar　　   /*フスクロールバー
========================================================= */
::-webkit-scrollbar {
  /* Chrome, Safari 対応 */
  display: none;
  -webkit-appearance: none;
  -ms-overflow-style: none;
  /* IE, Edge 対応 */
  scrollbar-width: none;
  /* Firefox 対応 */ }

/*垂直方向のスクロールバーに適用*/
/*::-webkit-scrollbar:horizontal {
    display: none;
    -webkit-appearance: none;
}*/
/*水平方向のスクロールバーに適用*/
/*::-webkit-scrollbar:vertical {
    display: none;
    -webkit-appearance: none;
}*/
/* =========================================================
 * CSS Animation　　   /*CSS アニメション
========================================================= */
/*メインビジュのSCROLL*/
@keyframes arrow-move {
  0% {
    top: -100%; }
  50% {
    top: 0; }
  100% {
    top: 100%; } }
@-webkit-keyframes arrow-move {
  0% {
    top: -100%; }
  50% {
    top: 0; }
  100% {
    top: 100%; } }
@keyframes animationZoom {
  100% {
    transform: scale(1.1); } }
@keyframes slideshow {
  0% {
    opacity: 0;
    transform: scale(1.2, 1.2); }
  10% {
    opacity: 1;
    transform: scale(1, 1); }
  28% {
    opacity: 1;
    transform: scale(1, 1); }
  38% {
    opacity: 0;
    transform: scale(1, 1); }
  100% {
    opacity: 0;
    transform: scale(1, 1); } }
/* =========================================================
 * cursor event　　   /*cursorイベント
========================================================= */
/*<!--mouse-->
<div id="cursor" class="cursor"></div>*/
/*#cursor{
    pointer-events: none;
    position: fixed;
    top: -8px;     //座標調節（カーソル位置と円の中心を合わせる）
    left: -8px;    //座標調節（カーソル位置と円の中心を合わせる）
    width: 16px;   //マウスストーカーの直径
    height: 16px;  //マウスストーカーの直径
    background: rgba(0,115,255,0.2);
	//border: 1px solid rgba(255,0,4,0.5);
    border-radius: 50%;
    transition: transform 0.2s, top, 0.5s, left 0.5s, width .5s, height .5s, background-color .5s;
    transition-timing-function: ease-out;
    z-index: 10005;
    &.hov_{
      top: -32px;     //大きさに合わせて座標調節
      left: -32px;    //大きさに合わせて座標調節
      width: 28px;
      height: 28px;
      transition: .5s;
      background: rgba(0,115,255,0.5);
      //border: none;
    }
}*/
/*@include max-screen($breakpoint-mobile){
	#cursor{
		display: none;
	}
}*/
/* =========================================================
 * js Animation　　   /*jS アニメーション
========================================================= */
/*1文字ずつ出現させるためのCSS*/
.eachTextAnime span {
  opacity: 0; }

.eachTextAnime.appeartext span {
  animation: text_anime_on .1s ease-out forwards; }

@keyframes text_anime_on {
  0% {
    opacity: 0; }
  50% {
    opacity: 1; }
  100% {
    opacity: 1; } }
.top article {
  background-color: #F9F9F9; }
  .top article .main {
    height: 47.96875vw;
    max-height: 614px;
    background: url("../images/top/main_bg_pc.jpg") no-repeat center center/cover;
    position: relative; }
    .top article .main .symbol {
      width: 25.3125vw;
      max-width: 324px;
      position: absolute;
      top: 7.9em;
      left: -3.6em; }
    .top article .main .inner {
      width: 88%;
      position: absolute;
      bottom: 4em;
      left: 50%;
      transform: translateX(-50%); }
      .top article .main .inner h2 {
        width: 25.46875vw;
        max-width: 326px; }
      .top article .main .inner p {
        width: 40.859375vw;
        max-width: 523px;
        margin-top: 4em; }
  .top article .lead {
    width: 100%;
    position: relative;
    z-index: 1;
    isolation: isolate;
    mix-blend-mode: normal;
    /* もしくは mix-blend-mode を指定しない */
    padding: 5em 0;
    clip-path: inset(0 0 0 0); }
    .top article .lead .parallax-bg {
      position: fixed;
      top: 0;
      left: 0;
      z-index: -1;
      width: 100%;
      height: 100%;
      background: url("../images/top/lead_bg.jpg") no-repeat center center/cover; }
      .top article .lead .parallax-bg img {
        display: none; }
    .top article .lead .inner {
      width: 82.5%;
      max-width: 1056px;
      margin: 0 auto; }
      .top article .lead .inner--wrap {
        background-color: #fff;
        display: flex;
        justify-content: space-between;
        align-items: center;
        flex-wrap: wrap;
        padding: 2.5em 0; }
        .top article .lead .inner--wrap--ttl {
          width: 39.5%;
          font-size: clamp(22px, 2.1875vw, 28px);
          font-style: italic;
          background: url("../images/common/img_symbolmark.png") no-repeat center center/auto 100%;
          padding: 1.5em;
          border-right: 1px solid #DFEBF8; }
          .top article .lead .inner--wrap--ttl h3 {
            font-weight: bold;
            line-height: 1;
            letter-spacing: 0; }
            .top article .lead .inner--wrap--ttl h3 span {
              position: relative;
              display: inline-block; }
              .top article .lead .inner--wrap--ttl h3 span:after {
                content: '';
                display: block;
                position: absolute;
                width: 100%;
                height: 1px;
                bottom: 0;
                left: 50%;
                transform: translateX(-50%); }
            .top article .lead .inner--wrap--ttl h3:nth-of-type(1) {
              color: #F69B11; }
              .top article .lead .inner--wrap--ttl h3:nth-of-type(1) span:after {
                background-color: #F69B11; }
            .top article .lead .inner--wrap--ttl h3:nth-of-type(2) {
              color: #08A03A; }
              .top article .lead .inner--wrap--ttl h3:nth-of-type(2) span:after {
                background-color: #08A03A; }
            .top article .lead .inner--wrap--ttl h3:nth-of-type(3) {
              color: #00AACC; }
              .top article .lead .inner--wrap--ttl h3:nth-of-type(3) span:after {
                background-color: #00AACC; }
            .top article .lead .inner--wrap--ttl h3:nth-of-type(n+2) {
              margin-top: .7em; }
        .top article .lead .inner--wrap--txt {
          width: 60.5%;
          padding: 2em;
          position: relative; }
          .top article .lead .inner--wrap--txt .icon {
            width: 9.140625vw;
            max-width: 117px;
            position: absolute;
            bottom: -1em;
            right: 5em; }
          .top article .lead .inner--wrap--txt p span {
            font-size: clamp(16px, 1.5625vw, 20px);
            font-weight: bold;
            color: #196BB4; }
  .top article .container--block:nth-of-type(n+2) {
    border-top: 2px solid #F2F2F2;
    padding-top: 0;
    margin-top: 4em; }
  .top article .container--block .inner {
    width: 77.5%;
    max-width: 992px;
    margin: 0 auto;
    position: relative; }
    .top article .container--block .inner--main h2 {
      font-size: clamp(19px, 1.875vw, 24px);
      font-weight: bold;
      text-align: center;
      color: #196BB4;
      padding: 1em 0;
      margin-top: 3.5em;
      position: relative;
      z-index: 1; }
      .top article .container--block .inner--main h2 span {
        display: inline-block;
        width: 100%;
        font-size: clamp(64px, 8.59375vw, 110px);
        font-style: italic;
        text-transform: uppercase;
        background: linear-gradient(90deg, #196BB4 0%, #8CB5D9 25%, #D3E7F8 50%, #8CB5D9 75%, #196BB4 100%);
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        opacity: .2;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: -1; }
    .top article .container--block .inner--main h3 {
      width: 80%;
      margin: 1em auto 0;
      font-size: clamp(24px, 2.34375vw, 30px);
      font-weight: bold;
      font-style: italic;
      line-height: 1.5;
      text-align: center;
      position: relative; }
      .top article .container--block .inner--main h3:before, .top article .container--block .inner--main h3:after {
        display: block;
        position: absolute;
        font-weight: 400;
        color: #ccc; }
      .top article .container--block .inner--main h3:before {
        content: '「';
        top: 0;
        left: 0; }
      .top article .container--block .inner--main h3:after {
        content: '」';
        bottom: 0;
        right: 0; }
      .top article .container--block .inner--main h3 span {
        display: inline-block;
        background: linear-gradient(180deg, #196BB4 0%, #003366 100%);
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        padding: 0 0.22em; }
    .top article .container--block .inner--main p {
      font-size: clamp(14px, 1.40625vw, 18px);
      text-align: center;
      margin-top: 2.5em; }
    .top article .container--block .inner--wrap {
      margin-top: 2em; }
      .top article .container--block .inner--wrap--category {
        box-shadow: 0px 4px 8px 2px rgba(154, 154, 154, 0.05); }
  .top article .container--block.block01 .inner--wrap {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap; }
    .top article .container--block.block01 .inner--wrap .figure {
      width: 100%;
      background-color: #fff;
      padding: 0 20%; }
    .top article .container--block.block01 .inner--wrap--category {
      width: 49.2%;
      background-color: #fff;
      display: flex;
      justify-content: space-between;
      flex-wrap: wrap;
      margin-top: 1em; }
      .top article .container--block.block01 .inner--wrap--category dt,
      .top article .container--block.block01 .inner--wrap--category dd {
        display: flex;
        justify-content: space-between;
        align-content: center; }
      .top article .container--block.block01 .inner--wrap--category dt {
        width: 35%;
        align-items: center;
        font-size: clamp(16px, 1.5625vw, 20px);
        line-height: 1;
        color: #196BB4;
        background-color: #DFEBF8;
        padding: 1em; }
        .top article .container--block.block01 .inner--wrap--category dt h4 {
          font-weight: bold;
          padding-left: 1.2em;
          position: relative; }
          .top article .container--block.block01 .inner--wrap--category dt h4:before {
            content: '';
            display: block;
            position: absolute;
            width: 1em;
            height: 1em;
            background: url("../images/common/icon_check.png") no-repeat center center/cover;
            top: 50%;
            left: 0;
            transform: translateY(-50%); }
      .top article .container--block.block01 .inner--wrap--category dd {
        width: 65%;
        flex-direction: column;
        padding: 1.5em; }
        .top article .container--block.block01 .inner--wrap--category dd .comment {
          font-size: clamp(11px, 1.09375vw, 14px);
          color: #949494; }
  .top article .container--block.block01 .inner .btn {
    width: 40%;
    margin: 5em auto 0; }
  .top article .container--block.block02 .inner--wrap--category {
    width: 100%;
    background-color: #fff;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin-top: 1em; }
    .top article .container--block.block02 .inner--wrap--category dt,
    .top article .container--block.block02 .inner--wrap--category dd {
      display: flex;
      justify-content: space-between;
      align-content: center; }
      .top article .container--block.block02 .inner--wrap--category dt span,
      .top article .container--block.block02 .inner--wrap--category dd span {
        font-weight: bold;
        color: #196BB4; }
    .top article .container--block.block02 .inner--wrap--category dt {
      width: 44.5%;
      align-items: center;
      font-size: clamp(19px, 1.875vw, 24px);
      background-color: #DFEBF8;
      border-left: 2px solid #196BB4;
      padding: 1em; }
      .top article .container--block.block02 .inner--wrap--category dt h4 {
        font-weight: bold; }
    .top article .container--block.block02 .inner--wrap--category dd {
      width: 55.5%;
      flex-direction: column;
      padding: 1.5em; }
      .top article .container--block.block02 .inner--wrap--category dd .comment {
        display: block;
        font-size: clamp(11px, 1.09375vw, 14px);
        color: #949494; }
  .top article .container--block.block03 .inner .decoration {
    width: 47.5vw;
    max-width: 608px;
    position: absolute;
    top: 1em;
    left: -26em; }
  .top article .container--block.block03 .inner--wrap {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap; }
    .top article .container--block.block03 .inner--wrap--category {
      width: 49.2%;
      background-color: #fff;
      padding: 1.5em;
      margin-top: 1em;
      position: relative; }
      .top article .container--block.block03 .inner--wrap--category .label {
        font-size: clamp(16px, 1.5625vw, 20px);
        line-height: 1;
        color: #196BB4;
        background-color: #DFEBF8;
        padding: .5em .7em;
        margin-top: 0;
        position: absolute;
        top: 0;
        left: 0; }
      .top article .container--block.block03 .inner--wrap--category .icon {
        width: 20%;
        margin: 1.5em auto 0; }
      .top article .container--block.block03 .inner--wrap--category h4 {
        font-size: clamp(19px, 1.875vw, 24px);
        font-weight: bold;
        text-align: center;
        color: #196BB4;
        margin-top: .7em; }
        .top article .container--block.block03 .inner--wrap--category h4 em {
          font-size: clamp(16px, 1.5625vw, 20px);
          font-weight: bold; }
      .top article .container--block.block03 .inner--wrap--category p {
        padding-top: 1em;
        margin-top: 1em;
        border-top: 1px solid #eee; }
        .top article .container--block.block03 .inner--wrap--category p.comment {
          padding-top: 0;
          margin-top: 0;
          border: none;
          font-size: clamp(11px, 1.09375vw, 14px);
          color: #949494; }
          .top article .container--block.block03 .inner--wrap--category p.comment span {
            font-weight: bold;
            color: #196BB4; }
  .top article .container--block.block04 {
    background: #fff;
    padding-bottom: 5em; }
    .top article .container--block.block04 .inner--wrap--category {
      box-shadow: none; }
      .top article .container--block.block04 .inner--wrap--category:nth-of-type(n+2) {
        padding-top: 2em;
        margin-top: 2em;
        border-top: 1px solid #eee; }
      .top article .container--block.block04 .inner--wrap--category dl {
        display: flex;
        justify-content: space-between;
        align-items: center; }
        .top article .container--block.block04 .inner--wrap--category dl dt {
          width: 2em;
          height: 2em;
          display: inline-flex;
          justify-content: center;
          align-items: center;
          font-size: clamp(16px, 1.5625vw, 20px);
          line-height: 1;
          text-align: center;
          color: #fff;
          background-color: #196BB4;
          border-radius: 5rem; }
        .top article .container--block.block04 .inner--wrap--category dl dd {
          width: 92.5%; }
        .top article .container--block.block04 .inner--wrap--category dl:nth-of-type(n+2) {
          margin-top: 1em; }
      .top article .container--block.block04 .inner--wrap--category .ttl dd {
        font-size: clamp(16px, 1.5625vw, 20px);
        font-weight: bold;
        color: #196BB4; }
      .top article .container--block.block04 .inner--wrap--category .txt dt {
        font-weight: bold;
        color: #196BB4;
        background-color: #DFEBF8; }

@media screen and (max-width: 767px) {
  .top article .main {
    height: 146.1333333333vw;
    max-height: 548px;
    background: url("../images/top/main_bg_sp.jpg") no-repeat center center/cover; }
    .top article .main .symbol {
      width: 44.2666666667vw;
      top: 15.5em;
      left: -3em; }
    .top article .main .inner {
      bottom: 5em; }
      .top article .main .inner h2 {
        width: 62.9333333333vw; }
      .top article .main .inner p {
        width: 88vw;
        margin-top: 2em; }
  .top article .lead {
    padding: 2.5em 0; }
    .top article .lead .inner {
      width: 88%; }
      .top article .lead .inner--wrap {
        padding: 2.5em 0; }
        .top article .lead .inner--wrap--ttl {
          width: 100%;
          font-size: clamp(22px, 5.8666666667vw, 28px); }
        .top article .lead .inner--wrap--txt {
          width: 85%;
          border-top: 1px solid #F2F2F2;
          padding: 2em 0 1em;
          margin: 2em auto 0; }
          .top article .lead .inner--wrap--txt .icon {
            width: 26.6666666667vw;
            bottom: 0;
            right: -1em; }
          .top article .lead .inner--wrap--txt p span {
            font-size: clamp(18px, 1.5625vw, 20px);
            font-weight: bold;
            color: #196BB4; }
  .top article .container--block:nth-of-type(n+2) {
    margin-top: 2em; }
  .top article .container--block .inner {
    width: 88%; }
    .top article .container--block .inner--main h2 {
      font-size: clamp(22px, 5.8666666667vw, 24px);
      line-height: 1.5;
      margin-top: 1.5em; }
      .top article .container--block .inner--main h2 span {
        font-size: clamp(60px, 16vw, 110px);
        opacity: .1; }
    .top article .container--block .inner--main h3 {
      width: 100%;
      font-size: clamp(26px, 6.9333333333vw, 30px); }
    .top article .container--block .inner--main p {
      font-size: clamp(16px, 4.2666666667vw, 18px);
      text-align: justify; }
    .top article .container--block .inner--wrap {
      margin-top: 2em; }
  .top article .container--block.block01 .inner--wrap .figure {
    padding: 0; }
  .top article .container--block.block01 .inner--wrap--category {
    width: 100%;
    margin-top: 1em; }
    .top article .container--block.block01 .inner--wrap--category dt,
    .top article .container--block.block01 .inner--wrap--category dd {
      flex-direction: column; }
    .top article .container--block.block01 .inner--wrap--category dt {
      width: 100%;
      font-size: clamp(20px, 5.3333333333vw, 20px); }
    .top article .container--block.block01 .inner--wrap--category dd {
      width: 100%;
      flex-direction: column;
      padding: 1.5em; }
      .top article .container--block.block01 .inner--wrap--category dd .comment {
        font-size: clamp(14px, 3.7333333333vw, 14px);
        margin-top: .5em; }
  .top article .container--block.block01 .inner .btn {
    width: 100%;
    margin: 2.5em auto 0; }
  .top article .container--block.block02 .inner--main {
    width: 105%;
    margin-left: -3.5%; }
    .top article .container--block.block02 .inner--main h3 {
      padding-left: .5em; }
  .top article .container--block.block02 .inner--wrap--category {
    width: 100%; }
    .top article .container--block.block02 .inner--wrap--category dt {
      width: 100%;
      font-size: clamp(24px, 6.4vw, 24px);
      font-weight: bold;
      border-top: 2px solid #196BB4;
      border-left: none; }
    .top article .container--block.block02 .inner--wrap--category dd {
      width: 100%; }
      .top article .container--block.block02 .inner--wrap--category dd .comment {
        font-size: clamp(14px, 3.7333333333vw, 14px);
        margin-top: .5em; }
  .top article .container--block.block03 .inner .decoration {
    width: 58.6666666667vw;
    top: 4em;
    left: -5.5em; }
  .top article .container--block.block03 .inner--wrap--category {
    width: 100%; }
    .top article .container--block.block03 .inner--wrap--category .label {
      font-size: clamp(20px, 5.3333333333vw, 20px); }
    .top article .container--block.block03 .inner--wrap--category .icon {
      width: 35%; }
    .top article .container--block.block03 .inner--wrap--category h4 {
      font-size: clamp(24px, 6.4vw, 24px); }
      .top article .container--block.block03 .inner--wrap--category h4 em {
        font-size: clamp(20px, 5.3333333333vw, 20px); }
    .top article .container--block.block03 .inner--wrap--category p.comment {
      font-size: clamp(14px, 3.7333333333vw, 14px);
      margin-top: .5em; }
  .top article .container--block.block04 {
    padding-bottom: 5em; }
    .top article .container--block.block04 .inner--wrap--category dl {
      align-items: flex-start; }
      .top article .container--block.block04 .inner--wrap--category dl dt {
        font-size: clamp(20px, 5.3333333333vw, 20px); }
      .top article .container--block.block04 .inner--wrap--category dl dd {
        width: 80%; }
    .top article .container--block.block04 .inner--wrap--category .ttl dd {
      font-size: clamp(20px, 5.3333333333vw, 20px); } }
