@charset "UTF-8";
/* blue */
/* orange */
/* gothic */
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500;700;900&family=Roboto:wght@100;300;400;500;700;900&display=swap");
body {
  position: relative;
  font-size: 16px;
  color: #333;
  line-height: 1;
  font-feature-settings: "palt";
  letter-spacing: 0.03em;
  /* gothic */
  font-family: 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro','メイリオ', 'Meiryo', '游ゴシック', 'Yu Gothic', 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
  font-family: 'Noto Sans JP', sans-serif; }

.no-scroll,
main {
  overflow: hidden; }

/* common */
.container h1 {
  position: absolute;
  clip: rect(1px, 1px, 1px, 1px);
  -webkit-clip-path: inset(0px 0px 99.9% 99.9%);
  clip-path: inset(0px 0px 99.9% 99.9%);
  overflow: hidden;
  height: 1px;
  width: 1px;
  padding: 0;
  border: 0; }

.container section {
  position: relative; }

@media screen and (min-width: 768px) {
  .container .view-sp {
    display: none; } }

@media screen and (max-width: 767px) {
  .container .view-pc {
    display: none; } }

/* --- width --- */
@media screen and (min-width: 768px) {
  [class*="wrap-"] {
    margin-left: auto;
    margin-right: auto; } }

@media screen and (max-width: 767px) {
  [class*="wrap-"] {
    width: auto; } }

/* liquid */
@media screen and (min-width: 768px) {
  .wrap-liquid {
    width: 84%; } }

/* fixed */
@media screen and (min-width: 768px) {
  .wrap-fixed {
    width: 980px; } }

/* info */
@media screen and (min-width: 768px) {
  .wrap-info {
    padding-top: 30px;
    width: 88%; } }

@media screen and (max-width: 767px) {
  .wrap-info {
    padding: 20px 15px 0;
    width: 100%; } }

/* --- global header --- */
.global-header {
  background: #fff; }
  .global-header.fixed {
    position: fixed;
    top: 0;
    left: 50%;
    transform: translate(-50%, 0);
    z-index: 90;
    filter: drop-shadow(1px 2px 4px rgba(0, 0, 0, 0.2)); }
  @media screen and (min-width: 768px) {
    .global-header.fixed {
      width: 1200px;
      border-bottom-right-radius: 14px;
      border-bottom-left-radius: 14px; }
    .global-header .inner {
      display: flex;
      align-items: center;
      padding: 15px 30px; }
    .global-header .global-menu li:first-child {
      display: none; }
    .global-header .global-menu a {
      padding: 15px;
      font-weight: 500; }
    .global-header .global-menu .current a {
      color: #fff;
      background: #1e4c9a; }
    .global-header .global-menu a:hover {
      color: #fff;
      background: #1e4c9a; } }
  @media screen and (max-width: 767px) {
    .global-header.fixed {
      width: 100%;
      transform: translate(-50%, 0); }
    .global-header .inner {
      display: flex;
      align-items: center;
      padding: 10px 15px 10px; }
    .global-header .global-menu {
      margin-left: auto; }
      .global-header .global-menu li:not(:last-child) {
        display: none; } }

/* --- global footer --- */
@media screen and (min-width: 768px) {
  .global-footer {
    padding: 60px 0 30px;
    border-top: 1px #ccc solid; }
    .global-footer .inner {
      display: flex;
      align-items: center; }
    .global-footer .global-menu a {
      padding-left: 20px; }
    .global-footer .global-menu a:hover {
      text-decoration: underline; } }

@media screen and (max-width: 767px) {
  .global-footer {
    padding: 50px 0 30px; }
    .global-footer .inner {
      padding: 0 15px; }
    .global-footer .global-menu {
      margin-top: 25px;
      text-align: center; }
      .global-footer .global-menu li + li {
        padding-top: 15px; } }

/* --- global menu --- */
.global-menu a {
  position: relative;
  display: block;
  color: #333; }

@media screen and (min-width: 768px) {
  .global-menu {
    margin-left: auto; }
    .global-menu ul {
      display: flex;
      align-items: center; }
      .global-menu ul li + li {
        margin-left: 10px; }
      .global-menu ul li:last-child {
        margin-left: 20px; } }

/* --- fixed menu --- */
@media screen and (min-width: 768px) {
  .horizontal-scroll-menu {
    display: none; } }

@media screen and (max-width: 767px) {
  .horizontal-scroll-menu {
    position: fixed;
    bottom: 0;
    opacity: 0;
    width: 100%;
    border-top: 1px #fff solid;
    border-bottom: 1px #1e4c9a solid;
    background: #1e4c9a;
    z-index: 998; }
    .horizontal-scroll-menu ul {
      display: flex; }
    .horizontal-scroll-menu li {
      width: 25%; }
    .horizontal-scroll-menu a {
      display: block;
      height: 100%;
      padding: 17px 10px;
      font-size: 12px;
      line-height: 1.4;
      color: #fff;
      font-weight: 500;
      text-align: center; }
    .horizontal-scroll-menu .current a {
      color: #1e4c9a;
      background: #fff; }
    .horizontal-scroll-menu.UpMove {
      animation: UpAnime 0.5s forwards; }
    .horizontal-scroll-menu.DownMove {
      animation: DownAnime 0.5s forwards; } }

/* logo */
.item-header-logo a {
  display: block; }
  @media screen and (min-width: 768px) {
    .item-header-logo a {
      padding: 4px;
      width: 240px; } }
  @media screen and (max-width: 767px) {
    .item-header-logo a {
      width: 50px; } }

.item-footer-logo a {
  display: block; }
  @media screen and (min-width: 768px) {
    .item-footer-logo a {
      padding: 4px;
      width: 200px; } }
  @media screen and (max-width: 767px) {
    .item-footer-logo a {
      margin: 0 auto;
      width: 180px; } }

/* copyright */
.item-copyright {
  color: #333;
  font-size: 14px;
  font-family: 'Avenir','Helvetica Neue','Helvetica','Arial', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro','メイリオ', 'Meiryo', '游ゴシック', 'Yu Gothic', 'ＭＳ Ｐゴシック', sans-serif;
  font-family: 'Roboto', sans-serif;
  font-weight: 400;
  letter-spacing: 1px;
  text-align: center; }
  @media screen and (min-width: 768px) {
    .item-copyright {
      margin-top: 40px; } }
  @media screen and (max-width: 767px) {
    .item-copyright {
      margin-top: 50px; } }

/* page top */
.item-pagetop {
  position: fixed;
  opacity: 0;
  transform: translateY(100px);
  z-index: 998; }
  .item-pagetop a {
    display: block;
    position: relative;
    color: #fff;
    text-decoration: none;
    background: #1e4c9a; }
  .item-pagetop .text {
    display: block;
    width: 100%;
    text-align: center;
    line-height: 1.4;
    letter-spacing: 1px; }
  .item-pagetop .arrow::before,
  .item-pagetop .arrow::after {
    position: absolute;
    content: '';
    width: 14px;
    height: 2px;
    display: inline-block;
    background: #fff;
    border-radius: 2px;
    transition: 1.6s; }
  .item-pagetop .arrow::before {
    left: calc(50% - 2px);
    transform: rotate(40deg); }
  .item-pagetop .arrow::after {
    right: calc(50% - 2px);
    transform: rotate(-40deg); }
  .item-pagetop.UpMove {
    animation: UpAnime 0.5s forwards; }
  .item-pagetop.DownMove {
    animation: DownAnime 0.5s forwards; }
  @media screen and (min-width: 768px) {
    .item-pagetop {
      right: 40px;
      padding-bottom: 30px; }
      .item-pagetop a {
        width: 90px;
        height: 90px;
        transition: 1s; }
      .item-pagetop .text {
        position: absolute;
        top: 40px;
        left: 0;
        font-size: 12px; }
      .item-pagetop .arrow::before,
      .item-pagetop .arrow::after {
        top: 20px;
        background: #fff; }
      .item-pagetop a:hover {
        background: #1e4c9a; }
        .item-pagetop a:hover .arrow::before,
        .item-pagetop a:hover .arrow::after {
          top: 12px; } }
  @media screen and (max-width: 767px) {
    .item-pagetop {
      display: none; } }

@keyframes UpAnime {
  from {
    opacity: 0;
    transform: translateY(100px); }
  to {
    opacity: 1;
    transform: translateY(0); } }

@keyframes DownAnime {
  from {
    opacity: 1;
    transform: translateY(0); }
  to {
    opacity: 1;
    transform: translateY(200px); } }

/* section */
[class*="block-"] {
  position: relative;
  line-height: 1.8; }
  [class*="block-"] .red {
    color: #c00; }
  [class*="block-"] a {
    padding: 0 4px;
    color: #1e4c9a;
    text-decoration: underline; }
    @media screen and (min-width: 768px) {
      [class*="block-"] a:hover {
        text-decoration: none; } }
  [class*="block-"] a[target="_blank"] {
    position: relative; }
    [class*="block-"] a[target="_blank"]::after {
      display: inline-block;
      padding-left: 4px;
      font-size: 12px;
      content: "\f35d";
      color: #1e4c9a;
      font-family: FontAwesome;
      transform: translateY(-8%); }
  [class*="block-"] .text-indent a[target="_blank"] {
    text-indent: 0; }

@media screen and (min-width: 768px) {
  .block-normal {
    padding: 120px 0 60px; } }

@media screen and (max-width: 767px) {
  .block-normal {
    padding: 40px 0 30px; } }

/* main visual */
.block-mainvisual {
  background-image: url(../imgs/mainvisual.png);
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: cover; }
  .block-mainvisual::before {
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    content: '';
    z-index: 0;
    background-color: rgba(200, 200, 200, 0.3); }
  .block-mainvisual .hand {
    position: absolute;
    bottom: 0;
    left: 0;
    background: url(../imgs/mainvisual-hand.png) no-repeat 50% 50%;
    background-size: contain; }
  .block-mainvisual .inner {
    display: flex;
    align-items: center;
    flex-direction: column;
    justify-content: center;
    max-width: 1140px;
    margin: 0 auto;
    text-align: center;
    position: relative;
    z-index: 1; }
  .block-mainvisual .box-area {
    background-color: rgba(90, 90, 90, 0.8); }
  .block-mainvisual .title-01 {
    color: #fff;
    font-weight: 900;
    letter-spacing: 0.6px;
    background: #1e4c9a; }
  .block-mainvisual .title-02 {
    color: #fff;
    font-weight: 900;
    letter-spacing: 1.2px; }
  .block-mainvisual .title-03 {
    color: #fff;
    font-weight: 700; }
  @media screen and (min-width: 768px) {
    .block-mainvisual .inner {
      height: 50vh; }
    .block-mainvisual .box-area {
      margin-top: 30px;
      padding: 35px; }
    .block-mainvisual .hand {
      width: 420px;
      height: 282px; }
    .block-mainvisual .title-01 {
      margin-top: 25px;
      padding: 5px 25px;
      font-size: 18px;
      border-radius: 40px; }
    .block-mainvisual .title-02 {
      font-size: 26px; }
    .block-mainvisual .title-03 {
      margin-top: 20px; } }
  @media screen and (max-width: 767px) {
    .block-mainvisual .inner {
      height: 60vh; }
    .block-mainvisual .box-area {
      margin-top: 60px;
      padding: 20px 10px; }
    .block-mainvisual .hand {
      width: 280px;
      height: 188px; }
    .block-mainvisual .title-01 {
      margin-top: 20px;
      padding: 10px 15px;
      font-size: 14px; }
    .block-mainvisual .title-03 {
      margin-top: 15px;
      font-size: 12px; } }

.block-mainvisual.post-head {
  background-position: 50% 46%; }
  .block-mainvisual.post-head .inner {
    height: 200px; }

/* --- ITEM LIST --- */
/* main headline */
.item-headline {
  text-align: center;
  font-weight: 700;
  letter-spacing: 0.4px; }
  .item-headline::after {
    display: block;
    content: '';
    margin: 0 auto;
    background: #1e4c9a; }
  @media screen and (min-width: 768px) {
    .item-headline {
      margin-bottom: 50px;
      font-size: 26px; }
      .item-headline::after {
        height: 3px;
        width: 60px;
        margin-top: 30px; } }
  @media screen and (max-width: 767px) {
    .item-headline {
      margin: 0 20px 30px;
      font-size: 22px; }
      .item-headline::after {
        height: 2px;
        width: 40px;
        margin-top: 20px; } }

.item-subtitle {
  color: #fff;
  font-variant: 500;
  background: #1e4c9a; }
  @media screen and (min-width: 768px) {
    .item-subtitle {
      padding: 5px 15px;
      font-size: 18px; } }
  @media screen and (max-width: 767px) {
    .item-subtitle {
      padding: 8px 15px;
      font-size: 16px;
      font-weight: 500; } }

/* - read text - */
@media screen and (min-width: 768px) {
  .item-read {
    margin-bottom: 50px;
    text-align: center; } }

@media screen and (max-width: 767px) {
  .item-read {
    margin-bottom: 30px; } }

/* - underline - */
.item-underline {
  padding-left: 3px;
  padding-right: 3px;
  background: linear-gradient(transparent 60%, yellow 30%); }

/* - layout - */
[class*="item-grid"] {
  display: flex;
  flex-wrap: wrap;
  align-content: flex-start; }
  [class*="item-grid"] .item-grid-unit {
    overflow: hidden; }
  @media screen and (min-width: 768px) {
    [class*="item-grid"] .item-grid-unit {
      position: relative;
      padding: 29px;
      border: 1px #ccc solid; }
      [class*="item-grid"] .item-grid-unit .title {
        font-size: 20px;
        font-weight: 500;
        line-height: 1; }
        [class*="item-grid"] .item-grid-unit .title .number {
          margin-right: 10px;
          font-size: 28px;
          font-weight: 700; }
      [class*="item-grid"] .item-grid-unit figure {
        margin-top: 20px; }
      [class*="item-grid"] .item-grid-unit .info-area {
        padding: 15px 5px 0; }
    [class*="item-grid"][class*="-column02"] .item-grid-unit {
      width: 49%; }
      [class*="item-grid"][class*="-column02"] .item-grid-unit:not(:nth-child(2n+2)) {
        margin-right: 2%; }
      [class*="item-grid"][class*="-column02"] .item-grid-unit:not(:nth-child(-n+2)) {
        margin-top: 2%; }
    [class*="item-grid"][class*="-column03"] .item-grid-unit {
      width: 32%; }
      [class*="item-grid"][class*="-column03"] .item-grid-unit:not(:nth-child(3n+3)) {
        margin-right: 2%; }
      [class*="item-grid"][class*="-column03"] .item-grid-unit:not(:nth-child(-n+3)) {
        margin-top: 2%; }
    [class*="item-grid"][class*="-column04"] .item-grid-unit {
      width: 23.5%; }
      [class*="item-grid"][class*="-column04"] .item-grid-unit:not(:nth-child(4n+4)) {
        margin-right: 2%; }
      [class*="item-grid"][class*="-column04"] .item-grid-unit:not(:nth-child(-n+4)) {
        margin-top: 2%; }
    [class*="item-grid"][class*="-column00"] {
      justify-content: center; }
      [class*="item-grid"][class*="-column00"] .item-grid-unit {
        justify-content: center;
        margin: 0 1%; } }
  @media screen and (max-width: 767px) {
    [class*="item-grid"] .item-grid-unit {
      padding-bottom: 30px;
      border-bottom: 2px #1e4c9a solid; }
      [class*="item-grid"] .item-grid-unit .inner {
        padding: 10px; }
      [class*="item-grid"] .item-grid-unit .title {
        padding-top: 20px;
        font-size: 18px;
        font-weight: 500;
        line-height: 1; }
        [class*="item-grid"] .item-grid-unit .title .number {
          margin-right: 10px;
          font-size: 22px;
          font-weight: 500; }
      [class*="item-grid"] .item-grid-unit figure {
        margin-top: 20px; }
      [class*="item-grid"] .item-grid-unit .info-area {
        padding: 15px 5px 0; }
    [class*="item-grid"][class*="-column0"] .item-grid-unit {
      width: 100%; }
      [class*="item-grid"][class*="-column0"] .item-grid-unit:not(:first-child) {
        margin-top: 10px; } }

/* - button - */
[class*="item-button"] a, [class*="item-button"] [type="button"], [class*="item-button"] [type="submit"] {
  display: block;
  width: 100%;
  color: #fff;
  line-height: 1;
  text-align: center;
  background: #e59f3c;
  border-radius: 6px; }
  [class*="item-button"] a:hover, [class*="item-button"] [type="button"]:hover, [class*="item-button"] [type="submit"]:hover {
    background: #e59f3c; }
  [class*="item-button"] a [class*="icon-"], [class*="item-button"] [type="button"] [class*="icon-"], [class*="item-button"] [type="submit"] [class*="icon-"] {
    position: relative;
    padding-right: 20px; }
    [class*="item-button"] a [class*="icon-"]::before, [class*="item-button"] [type="button"] [class*="icon-"]::before, [class*="item-button"] [type="submit"] [class*="icon-"]::before {
      display: block;
      position: absolute;
      right: 0;
      color: #fff;
      font-family: FontAwesome;
      transform: translateY(-50%);
      line-height: 1; }
  [class*="item-button"] a .icon-blank::before, [class*="item-button"] [type="button"] .icon-blank::before, [class*="item-button"] [type="submit"] .icon-blank::before {
    top: 54%;
    font-size: 12px;
    content: "\f35d"; }
  [class*="item-button"] a .icon-arrow::before, [class*="item-button"] [type="button"] .icon-arrow::before, [class*="item-button"] [type="submit"] .icon-arrow::before {
    top: 60%;
    font-size: 14px;
    content: "\f054"; }
  @media screen and (min-width: 768px) {
    [class*="item-button"] a, [class*="item-button"] [type="button"], [class*="item-button"] [type="submit"] {
      padding: 15px; } }
  @media screen and (max-width: 767px) {
    [class*="item-button"] a, [class*="item-button"] [type="button"], [class*="item-button"] [type="submit"] {
      padding: 10px;
      font-size: 14px; } }

.item-button.disable a, .item-button.disable [type="button"], .item-button.disable [type="submit"] {
  pointer-events: none;
  color: #e8e8e8;
  background: #ccc; }

/* --- each parts --- */
.area-flow .item-text {
  text-align: center;
  font-weight: 700; }

@media screen and (min-width: 768px) {
  .area-flow {
    padding: 30px 0 80px; }
    .area-flow .item-text {
      font-size: 30px;
      line-height: 2.2; }
    .area-flow .item-image {
      margin-top: 50px; } }

@media screen and (max-width: 767px) {
  .area-flow {
    padding: 20px 0 40px; }
    .area-flow .item-text {
      font-size: 16px;
      line-height: 1.8; }
    .area-flow .item-image {
      margin-top: 30px; } }

.area-mission {
  background: #1e4c9a; }
  .area-mission .inner {
    background: #fff; }
  @media screen and (min-width: 768px) {
    .area-mission {
      padding: 30px 0; }
      .area-mission .inner {
        padding: 80px 30px;
        border-radius: 20px; } }
  @media screen and (max-width: 767px) {
    .area-mission {
      padding: 20px 0; }
      .area-mission .inner {
        padding: 50px 20px;
        margin: 0 15px; } }

.campaign-info .item-button {
  margin-left: auto;
  margin-right: auto; }
  .campaign-info .item-button a {
    text-decoration: none; }

.campaign-info .item-text {
  text-align: center; }

@media screen and (min-width: 768px) {
  .campaign-info {
    margin-bottom: 50px; }
    .campaign-info .item-button {
      width: 340px; }
      .campaign-info .item-button a {
        padding: 25px;
        font-size: 20px;
        font-weight: 700; }
      .campaign-info .item-button a:hover {
        background: #1e4c9a; }
    .campaign-info .item-text {
      margin-top: 15px; } }

@media screen and (max-width: 767px) {
  .campaign-info {
    margin-bottom: 30px; }
    .campaign-info .item-button a {
      padding: 20px;
      font-size: 18px; } }

.campaign-read {
  color: #fff;
  background: #1e4c9a; }
  .campaign-read .text {
    font-weight: 500; }
  @media screen and (min-width: 768px) {
    .campaign-read {
      margin-bottom: 10px;
      padding: 30px; }
      .campaign-read .text {
        font-size: 18px; } }
  @media screen and (max-width: 767px) {
    .campaign-read {
      margin-bottom: 5px;
      padding: 20px; }
      .campaign-read .text {
        font-size: 16px; } }

p.text-indent,
ul.text-indent li {
  padding-left: 1em;
  text-indent: -1em;
  color: #666;
  font-size: 14px;
  line-height: 1.6; }

.list-dot li {
  position: relative;
  padding-left: 14px; }
  .list-dot li::before {
    position: absolute;
    top: 0;
    left: 0;
    content: '・'; }

.item-detail-list dt {
  font-weight: 500; }

.item-detail-list p.text-indent {
  margin-top: 3px; }

@media screen and (min-width: 768px) {
  .item-detail-list dd {
    padding-left: 1em; }
  .item-detail-list dd + dt {
    margin-top: 15px; } }

@media screen and (max-width: 767px) {
  .item-detail-list {
    padding-bottom: 60px; }
    .item-detail-list dt {
      font-size: 14px; }
    .item-detail-list dd {
      padding-left: 0.4em;
      font-size: 14px;
      line-height: 1.6; }
    .item-detail-list dd + dt {
      margin-top: 15px; } }

.item-detail-number {
  counter-reset: listnum;
  list-style: none;
  margin: 20px 0 10px; }
  .item-detail-number li::before {
    counter-increment: listnum;
    content: counter(listnum);
    padding-right: 10px;
    font-size: 18px;
    font-weight: 500; }

.point-area .text h3 {
  font-weight: 500; }

@media screen and (min-width: 768px) {
  .point-area {
    display: flex;
    align-items: center; }
    .point-area .text {
      padding-right: 20px; }
      .point-area .text h3 {
        margin-top: 30px;
        margin-bottom: 10px;
        font-size: 20px; }
    .point-area .image {
      width: 340px; } }

@media screen and (max-width: 767px) {
  .point-area .text h3 {
    margin-top: 25px;
    margin-bottom: 10px;
    font-size: 18px; }
  .point-area .image {
    margin-top: 20px;
    padding: 0 20px; } }

.iframe-area iframe {
  border: none;
  margin: 0;
  width: 100%; }

@media screen and (min-width: 768px) {
  .iframe-area .iframe-form {
    height: 2100px; }
  .iframe-area .iframe-contact {
    height: 1250px; } }

@media screen and (max-width: 767px) {
  .iframe-area .iframe-form {
    height: 2200px; }
  .iframe-area .iframe-contact {
    height: 1300px; } }

@media screen and (min-width: 768px) {
  .campaign-area .wrap-info + .item-subtitle {
    margin-top: 70px; } }

@media screen and (max-width: 767px) {
  .campaign-area .wrap-info + .item-subtitle {
    margin-top: 40px; } }

.block-side {
  transition: 0.4s;
  z-index: 99; }
  .block-side.fixed {
    position: fixed; }
  .block-side.hidden {
    right: -400px; }
  @media screen and (min-width: 768px) {
    .block-side {
      position: absolute;
      top: 0;
      right: -60px;
      width: 280px; }
      .block-side.active {
        right: 30px; }
      .block-side.hidden {
        right: -400px; } }
  @media screen and (max-width: 767px) {
    .block-side {
      position: fixed;
      top: 0;
      right: -220px;
      width: 280px; }
      .block-side.active {
        right: 15px; } }

.side-menu {
  color: #ddd;
  color: #d0d5dd;
  background: #fff;
  background: #eaf3ff;
  border-radius: 12px;
  box-shadow: 0 0 20px #ddd;
  box-shadow: 0 0 20px #d9e0ea; }
  .active .side-menu {
    color: #333;
    box-shadow: 0 0 10px #c3cfdf; }
  @media screen and (min-width: 768px) {
    .side-menu {
      padding: 20px; } }
  @media screen and (max-width: 767px) {
    .side-menu {
      padding: 10px;
      font-size: 12px;
      text-align: center; } }

/* ---------------- 未使用 ---------------- */
.tel-link a {
  padding-bottom: 1px;
  color: #1e4c9a;
  border-bottom: 1px #1e4c9a solid; }
