@charset "UTF-8";
@font-face {
  font-family: "NotoSansJP-Black";
  src: url(/okinawa/fonts/NotoSansJP/NotoSansJP-Black.woff) format("woff");
  font-display: swap;
}
@font-face {
  font-family: "NotoSansJP-Bold";
  src: url(/okinawa/fonts/NotoSansJP/NotoSansJP-Bold.woff) format("woff");
  font-display: swap;
}
@font-face {
  font-family: "NotoSansJP-Medium";
  src: url(/okinawa/fonts/NotoSansJP/NotoSansJP-Medium.woff) format("woff");
  font-display: swap;
}
@font-face {
  font-family: "NotoSansJP-Regular";
  src: url(/okinawa/fonts/NotoSansJP/NotoSansJP-Regular.woff) format("woff");
  font-display: swap;
}
@font-face {
  font-family: "NotoSerifJP-Regular";
  src: url(/okinawa/fonts/NotoSerifJP/NotoSerifJP-Regular.woff) format("woff");
  font-display: swap;
}
@font-face {
  font-family: "Oswald-Medium";
  src: url(/okinawa/fonts/Oswald/Oswald-Medium.woff) format("woff");
  font-display: swap;
}
/*16*1.75/2*/
/*=======*/
/* index */
/*=======*/
.index {
  /* メイン
  -----------------------------------*/
  /* news
  -----------------------------------*/
  /* strengths
  -----------------------------------*/
  /* business
  -----------------------------------*/
  /* company
  -----------------------------------*/
  /* entry
  -----------------------------------*/
}
.index .h-index01 {
  margin-bottom: 24px;
  font-family: "NotoSerifJP-Regular", "Oswald-Medium", sans-serif;
  font-size: 42px;
  line-height: 1.3;
  letter-spacing: 1px;
  color: #012936;
}
@media (max-width: 767px) {
  .index .h-index01 {
    font-size: 26px;
    text-align: center;
  }
}
.index .h-index02 {
  margin-bottom: 24px;
  font-family: "NotoSerifJP-Regular", "Oswald-Medium", sans-serif;
  font-size: 29px;
  line-height: 1.3;
  letter-spacing: 1px;
  color: #012936;
}
@media (max-width: 767px) {
  .index .h-index02 {
    margin-bottom: 16px;
    font-size: 20px;
  }
}
.index .main-sec .inner {
  position: relative;
  width: 95%;
  max-width: 1824px;
  margin: 0 auto;
  border-radius: 8px;
  overflow: hidden;
}
@media (max-width: 1023px) {
  .index .main-sec .inner {
    width: 100%;
    border-radius: 0;
  }
  .index .main-sec .inner .slider img {
    height: 400px;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: center;
       object-position: center;
  }
}
.index .main-sec .inner .h-main {
  position: absolute;
  width: 100%;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  z-index: 5;
  opacity: 0;
  -webkit-animation: fade-in 2.5s cubic-bezier(0.39, 0.575, 0.565, 1) 2s both;
          animation: fade-in 2.5s cubic-bezier(0.39, 0.575, 0.565, 1) 2s both;
}
.index .main-sec .inner .h-main .main-txt {
  display: block;
  color: #FFF;
  font-family: "NotoSansJP-Black", "Oswald-Medium", sans-serif;
  font-size: clamp(32px, 3.5087719298vw, 64px);
  line-height: 1;
  filter: drop-shadow(0 0 8px rgba(0, 0, 0, 0.75));
}
@media (max-width: 767px) {
  .index .main-sec .inner .h-main .main-txt {
    font-size: clamp(24px, 6.9333333333vw, 52px);
  }
}
.index .main-sec .inner .h-main .sub-txt {
  display: inline-block;
  margin-top: 24px;
  color: #FFF;
  font-family: "NotoSansJP-Bold", "Oswald-Medium", sans-serif;
  font-size: clamp(12px, 1.0964912281vw, 20px);
  line-height: 1.6;
  filter: drop-shadow(0 0 4px rgba(0, 0, 0, 0.75));
}
@media (max-width: 767px) {
  .index .main-sec .inner .h-main .sub-txt {
    font-size: clamp(10px, 3.4666666667vw, 26px);
  }
}
.index .main-sec .inner .wave {
  position: absolute;
  width: 100%;
  top: 0;
  left: 0;
  right: 0;
  margin: 0 auto;
}
.index .main-sec .inner .wave.wave01 {
  -webkit-animation: fade-in-left 1.5s cubic-bezier(0.39, 0.575, 0.565, 1) 0.8s both;
          animation: fade-in-left 1.5s cubic-bezier(0.39, 0.575, 0.565, 1) 0.8s both;
}
/* 丸ver
.index .main-sec .inner .h-main {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  color: #FFF;
  font-family: "NotoSansJP-Black", "Oswald-Medium", sans-serif;
  font-size: 46px;
  line-height: 55px;
  z-index: 5;
  opacity: 0;
  -webkit-animation: fade-in 2.5s cubic-bezier(0.39, 0.575, 0.565, 1) 2s both;
          animation: fade-in 2.5s cubic-bezier(0.39, 0.575, 0.565, 1) 2s both;
}
@media (max-width: 767px) {
  .index .main-sec .inner .h-main {
    width: 80%;
    font-size: 32px;
    line-height: 1.2;
  }
}
.index .main-sec .inner .h-main span {
  display: block;
  margin-top: 24px;
  font-family: "NotoSansJP-Medium", "Oswald-Medium", sans-serif;
  font-size: 13px;
  line-height: 25px;
}
@media (max-width: 767px) {
  .index .main-sec .inner .h-main span {
    font-size: 13px;
  }
}
*/
.index .main-sec .inner .circle01 {
  position: absolute;
  width: 60%;
  height: 0;
  top: 50%;
  left: 0;
  right: 0;
  margin: -30% auto 0;
  padding-bottom: 60%;
  background-color: rgba(0, 126, 166, 0.3);
  border-radius: 50%;
  opacity: 0;
  z-index: 1;
  -webkit-animation: fade-in 1s cubic-bezier(0.39, 0.575, 0.565, 1) 1s both;
          animation: fade-in 1s cubic-bezier(0.39, 0.575, 0.565, 1) 1s both;
}
@media (max-width: 767px) {
  .index .main-sec .inner .circle01 {
    width: 100%;
    margin-top: -50%;
    padding-bottom: 100%;
  }
}
.index .main-sec .inner .circle02 {
  position: absolute;
  width: 40%;
  height: 0;
  top: 50%;
  left: 0;
  right: 0;
  margin: -20% auto 0;
  padding-bottom: 40%;
  background-color: rgba(0, 126, 166, 0.5);
  border-radius: 50%;
  opacity: 0;
  z-index: 2;
  -webkit-animation: fade-in 1s cubic-bezier(0.39, 0.575, 0.565, 1) 1s both;
          animation: fade-in 1s cubic-bezier(0.39, 0.575, 0.565, 1) 1s both;
}
@media (max-width: 767px) {
  .index .main-sec .inner .circle02 {
    width: 80%;
    margin-top: -40%;
    padding-bottom: 80%;
  }
}
.index .news-sec {
  padding-top: 140px;
}
@media (max-width: 1023px) {
  .index .news-sec {
    padding-top: 80px;
  }
}
.index .news-sec .h-index01 {
  margin-bottom: 64px;
  text-align: center;
}
@media (max-width: 767px) {
  .index .news-sec .h-index01 {
    margin-bottom: 24px;
  }
}
.index .strengths-sec {
  padding-top: 180px;
}
@media (max-width: 1023px) {
  .index .strengths-sec {
    padding-top: 80px;
  }
}
.index .strengths-sec .h-index01 {
  margin-bottom: 64px;
  text-align: center;
}
@media (max-width: 767px) {
  .index .strengths-sec .h-index01 {
    margin-bottom: 24px;
  }
}
@media (max-width: 1023px) {
  .index .strengths-sec .list-strengths {
    display: block;
  }
}
.index .strengths-sec .list-strengths li {
  border-radius: 6px;
  background-color: #FFF;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.08);
  overflow: hidden;
}
@media (max-width: 1023px) {
  .index .strengths-sec .list-strengths li {
    width: 100%;
    display: flex;
  }
  .index .strengths-sec .list-strengths li figure {
    width: 45%;
  }
  .index .strengths-sec .list-strengths li .txt {
    width: 55%;
  }
}
@media (max-width: 480px) {
  .index .strengths-sec .list-strengths li {
    display: block;
  }
  .index .strengths-sec .list-strengths li figure {
    width: 100%;
  }
  .index .strengths-sec .list-strengths li .txt {
    width: 100%;
  }
}
.index .strengths-sec .list-strengths .txt {
  padding: 24px 30px 16px;
  text-align: center;
}
@media (max-width: 1023px) {
  .index .strengths-sec .list-strengths .txt {
    padding: 16px;
    text-align: left;
  }
}
.index .strengths-sec .list-strengths .txt dt {
  margin-bottom: 12px;
  font-family: "NotoSansJP-Bold", "Oswald-Medium", sans-serif;
  font-size: 22px;
  line-height: 1.4;
}
@media (max-width: 767px) {
  .index .strengths-sec .list-strengths .txt dt {
    font-size: 18px;
    text-align: center;
  }
}
@media (max-width: 1023px) {
  .index .strengths-sec .list-strengths .txt dd {
    line-height: 1.6;
  }
}
.index .strengths-sec .btn {
  margin-top: 64px;
  text-align: center;
}
@media (max-width: 767px) {
  .index .strengths-sec .btn {
    max-width: 300px;
    margin: 40px auto 0;
  }
}
.index .business-sec {
  padding-top: 100px;
}
@media (max-width: 1023px) {
  .index .business-sec {
    padding-top: 80px;
  }
}
.index .business-sec .inner {
  width: 96%;
  padding-top: 180px;
  padding-bottom: 100px;
  margin: 0 auto;
  background: #EFF2F5;
  border-radius: 6px;
  overflow: hidden;
}
@media (max-width: 1023px) {
  .index .business-sec .inner {
    padding-top: 40px;
    padding-bottom: 16px;
  }
}
.index .business-sec .h-area {
  display: flex;
  justify-content: space-between;
  margin-bottom: 64px;
}
@media (max-width: 767px) {
  .index .business-sec .h-area {
    display: block;
    margin-bottom: 24px;
  }
}
.index .business-sec .h-area .h-index01 {
  width: 32%;
}
@media (max-width: 767px) {
  .index .business-sec .h-area .h-index01 {
    width: 100%;
  }
}
.index .business-sec .h-area .txt {
  width: 66%;
}
@media (max-width: 767px) {
  .index .business-sec .h-area .txt {
    width: 100%;
  }
}
.index .business-sec .list-menu {
  justify-content: center;
}
.index .business-sec .list-menu li {
  margin-bottom: 32px;
}
@media (max-width: 1023px) {
  .index .business-sec .list-menu li {
    width: 48%;
    margin: 0 1% 24px !important;
  }
}
@media (max-width: 1023px) {
  .index .business-sec .list-menu li {
    width: 100%;
    margin: 0 0 16px !important;
  }
}
.index .business-sec .list-menu a {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  height: 100%;
  border-radius: 6px;
  overflow: hidden;
}
.index .business-sec .list-menu a figure {
  background-color: #012936;
  overflow: hidden;
}
.index .business-sec .list-menu a .title {
  display: flex;
  align-items: center;
  height: 100%;
  max-height: 4em;
  padding: 16px;
  margin-bottom: 0;
  background-color: #012936;
  font-size: 22px;
  color: #FFF;
  line-height: 1.4;
  font-family: "NotoSansJP-Bold", "Oswald-Medium", sans-serif;
  z-index: 2;
}
@media (max-width: 767px) {
  .index .business-sec .list-menu a .title {
    display: block;
    height: auto;
    max-height: initial;
    font-size: 16px;
  }
}
.index .business-sec .list-menu a:hover {
  text-decoration: none;
}
.index .business-sec .list-menu a:hover img {
  transform: scale(1.1);
  opacity: 1 !important;
}
.index .company-sec {
  padding-top: 180px;
}
@media (max-width: 1023px) {
  .index .company-sec {
    padding-top: 80px;
  }
}
@media (max-width: 767px) {
  .index .company-sec .com-wrap {
    display: block;
  }
  .index .company-sec .com-wrap .img {
    width: 100%;
    max-width: 400px;
    margin: 0 auto 24px;
  }
}
.index .company-sec .com-wrap .txt {
  max-width: 510px;
}
@media (max-width: 767px) {
  .index .company-sec .com-wrap .txt {
    width: 100%;
    max-width: 100%;
  }
  .index .company-sec .com-wrap .txt .h-index01 {
    text-align: center;
  }
  .index .company-sec .com-wrap .txt .btn {
    max-width: 300px;
    margin: 0 auto;
    text-align: center;
  }
}
.index .entry-sec {
  margin: 180px 0 88px;
}
@media (max-width: 1023px) {
  .index .entry-sec {
    margin: 80px 0 40px;
  }
}
.index .entry-sec .h-index01 {
  margin-bottom: 64px;
  text-align: center;
}
@media (max-width: 767px) {
  .index .entry-sec .h-index01 {
    margin-bottom: 24px;
  }
}
.index .entry-sec .h-index02 {
  color: #FFF;
}
.index .entry-sec .com-wrap {
  background-color: rgb(28, 153, 215);
  overflow: hidden;
}
@media (max-width: 1023px) {
  .index .entry-sec .com-wrap {
    display: block;
    border-radius: 6px;
  }
}
.index .entry-sec .com-wrap .img {
  position: relative;
  width: 50%;
}
@media (max-width: 1023px) {
  .index .entry-sec .com-wrap .img {
    width: 100%;
    margin: 0 auto;
  }
}
.index .entry-sec .com-wrap .img img {
  position: absolute;
  left: 0;
  top: 0;
  height: 110%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media (max-width: 1023px) {
  .index .entry-sec .com-wrap .img img {
    position: static;
    height: auto;
    -o-object-fit: contain;
       object-fit: contain;
  }
}
.index .entry-sec .com-wrap .txt {
  width: 50%;
  padding: 7%;
  color: #FFF;
  line-height: 2;
}
@media (max-width: 1023px) {
  .index .entry-sec .com-wrap .txt {
    width: 100%;
    padding: 24px;
  }
}
.index .entry-sec .com-wrap .txt .btn {
  margin-top: 32px;
}
@media (max-width: 1023px) {
  .index .entry-sec .com-wrap .txt .btn {
    margin-top: 24px;
    text-align: center;
  }
}
/*# sourceMappingURL=index.css.map */
