@charset "UTF-8";
/* CSS Document */
/* 文字サイズ */
.txt_size5 {
  font-size: 5em;
  line-height: 1.5em !important; }
  @media screen and (max-width: 480px) {
    .txt_size5 {
      font-size: 4em; } }

.txt_size4 {
  font-size: 3em;
  line-height: 1.5em !important; }
  @media screen and (max-width: 480px) {
    .txt_size4 {
      font-size: 2em; } }

.txt_size3 {
  font-size: 1.8em;
  line-height: 1.5em !important; }
  @media screen and (max-width: 480px) {
    .txt_size3 {
      font-size: 1.5em; } }

.txt_size2 {
  font-size: 1.5em;
  line-height: 1.8em !important; }
  @media screen and (max-width: 700px) {
    .txt_size2 {
      font-size: 1.25em;
      line-height: 1.8em !important; } }

.topctt p {
  padding-bottom: 1em; }
  .topctt p.txt_size5 {
    padding-bottom: 0.2em; }
  .topctt p.txt_size4 {
    padding-bottom: 0.75em; }
    .topctt p.txt_size4:has(+ .txt_size5) {
      padding-bottom: 0; }
  .topctt p.txt_size3 {
    padding-bottom: 0.375em; }
  .topctt p.txt_size2 {
    padding-bottom: 0.3125em; }

/* 欧文 */
.eg {
  font-family: gazzetta-variable, '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'Meiryo UI', 'メイリオ', Meiryo, sans-serif;
  font-style: normal;
  font-weight: normal; }

/* 欧文大きめ */
.egl {
  font-family: gazzetta-variable, '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'Meiryo UI', 'メイリオ', Meiryo, sans-serif;
  font-style: normal;
  font-weight: normal;
  font-size: 1.2em; }

/* 欧文+日本語混在フォント */
.egjp {
  font-family: gazzetta-variable, source-han-sans-japanese, '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'Meiryo UI', 'メイリオ', Meiryo, sans-serif; }

/* 文字寄せ */
.center {
  text-align: center; }

.right {
  text-align: right; }

.left {
  text-align: left; }

/* 見出し */
.topctt h2, .topctt h3 {
  font-size: 1em;
  font-weight: 700;
  padding-bottom: 2em;
  color: #1d2087; }
  .topctt h2:last-child, .topctt h3:last-child {
    padding-bottom: 0; }
  .topctt h2:first-child, .topctt h3:first-child {
    padding-top: 0; }
  .topctt h2.topttl, .topctt h3.topttl {
    font-size: 2.5em; }
  .topctt h2 span, .topctt h3 span {
    display: block;
    line-height: 1.5em; }
    .topctt h2 span.txt_size4, .topctt h2 span.txt_size5, .topctt h3 span.txt_size4, .topctt h3 span.txt_size5 {
      font-weight: 900; }
      .topctt h2 span.txt_size4.eg, .topctt h2 span.txt_size5.eg, .topctt h3 span.txt_size4.eg, .topctt h3 span.txt_size5.eg {
        font-weight: normal;
        font-variation-settings: "wght" 700; }
    .topctt h2 span.eg, .topctt h3 span.eg {
      font-family: gazzetta-variable, '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'Meiryo UI', 'メイリオ', Meiryo, sans-serif;
      font-style: normal;
      font-weight: normal;
      font-weight: normal;
      font-variation-settings: "wght" 700;
      line-height: 1.25em !important; }
.topctt .innerbox h2:first-child, .topctt .innerbox h3:first-child {
  padding-top: 0; }
.topctt.top_bg3 h2, .topctt.top_bg3 h3 {
  color: #fff; }

/* 強調 */
.strong {
  display: inline-block !important;
  background: rgba(0, 0, 0, 0) -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(0%, #fff927)) repeat scroll 0 0;
  background: rgba(0, 0, 0, 0) -webkit-linear-gradient(transparent 60%, #fff927 0%) repeat scroll 0 0;
  background: rgba(0, 0, 0, 0) -moz-linear-gradient(transparent 60%, #fff927 0%) repeat scroll 0 0;
  background: rgba(0, 0, 0, 0) -o-linear-gradient(transparent 60%, #fff927 0%) repeat scroll 0 0;
  background: rgba(0, 0, 0, 0) linear-gradient(transparent 60%, #fff927 0%) repeat scroll 0 0;
  line-height: 1.3em;
  font-size: 1.1em; }
  .strong.red {
    background: rgba(0, 0, 0, 0) -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(0%, #f6593f)) repeat scroll 0 0;
    background: rgba(0, 0, 0, 0) -webkit-linear-gradient(transparent 60%, #f6593f 0%) repeat scroll 0 0;
    background: rgba(0, 0, 0, 0) -moz-linear-gradient(transparent 60%, #f6593f 0%) repeat scroll 0 0;
    background: rgba(0, 0, 0, 0) -o-linear-gradient(transparent 60%, #f6593f 0%) repeat scroll 0 0;
    background: rgba(0, 0, 0, 0) linear-gradient(transparent 60%, #f6593f 0%) repeat scroll 0 0; }

.color {
  color: #009fe8; }
  .color.strong {
    background: transparent; }

.color_tc {
  color: #090a37; }

.deco {
  display: inline-block;
  font-family: senobi-gothic, source-han-sans-japanese, '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'Meiryo UI', 'メイリオ', Meiryo, sans-serif;
  font-weight: 700;
  letter-spacing: -0.3em;
  font-size: 1.2em; }

strong {
  font-size: 1.3em;
  font-weight: 900; }
  strong.eg {
    font-family: gazzetta-variable, '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'Meiryo UI', 'メイリオ', Meiryo, sans-serif;
    font-style: normal;
    font-weight: normal;
    display: inline-block;
    position: relative;
    bottom: -0.08em; }

h2 .txt_size4 strong,
h2 .txt_size5 strong,
h3 .txt_size4 strong,
h3 .txt_size5 strong {
  font-weight: 900; }

.bold {
  font-weight: 700; }
  .bold.eg {
    font-weight: 700; }

.semi {
  font-weight: 700; }

/* 改行 */
.npbr {
  display: inline !important; }
  @media screen and (max-width: 1051px) {
    .npbr {
      display: block !important; } }

.tbbr {
  display: inline !important; }
  @media screen and (max-width: 700px) {
    .tbbr {
      display: block !important; } }

.spbr {
  display: inline !important; }
  @media screen and (max-width: 480px) {
    .spbr {
      display: block !important; } }

@media screen and (min-width: 481px) {
  .minsp_br {
    display: block !important; } }
@media screen and (max-width: 480px) {
  .minsp_br {
    display: inline !important; } }

@media screen and (max-width: 480px) {
  .spno {
    display: none; } }

.il_block {
  display: inline-block !important; }

/* リストリセット */
.topctt ul {
  list-style: none inside; }

/* 横並びテキスト+画像 */
.topctt .imgtxt {
  width: 100%;
  position: relative;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  overflow: hidden;
  padding-top: 8em;
  margin: 0 auto; }
  @media screen and (max-width: 1051px) {
    .topctt .imgtxt {
      width: 100% !important; } }
  @media screen and (max-width: 480px) {
    .topctt .imgtxt {
      padding-top: 3em; } }
  .topctt .imgtxt .txtbox {
    position: relative;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box; }
    @media screen and (max-width: 700px) {
      .topctt .imgtxt .txtbox {
        padding-bottom: 2em; } }
    .topctt .imgtxt .txtbox p:last-child {
      padding-bottom: 0; }
  .topctt .imgtxt .imgbox {
    position: relative; }
    .topctt .imgtxt .imgbox img {
      width: 100%;
      height: auto; }
  .topctt .imgtxt.float .imgbox {
    float: left;
    padding-right: 2em;
    padding-bottom: 1em; }
    @media screen and (max-width: 700px) {
      .topctt .imgtxt.float .imgbox {
        width: 100% !important;
        padding-bottom: 1.5em;
        padding-right: 0; } }
  .topctt .imgtxt.float .txtbox {
    width: 100% !important; }
  .topctt .imgtxt.float.rvbox .imgbox {
    float: right;
    padding-right: 0;
    padding-left: 2em; }
    @media screen and (max-width: 700px) {
      .topctt .imgtxt.float.rvbox .imgbox {
        padding-left: 0; } }
  .topctt .imgtxt.flex {
    display: -ms-flexbox;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-pack: justify;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -ms-flex-align: stretch;
    -webkit-box-align: stretch;
    -webkit-align-items: stretch;
    align-items: stretch; }
    .topctt .imgtxt.flex .txtbox {
      display: -ms-flexbox;
      display: -webkit-box;
      display: -webkit-flex;
      display: flex;
      -ms-flex-align: center;
      -webkit-box-align: center;
      -webkit-align-items: center;
      align-items: center; }
      @media screen and (max-width: 700px) {
        .topctt .imgtxt.flex .txtbox {
          width: 100% !important;
          display: -ms-flexbox;
          display: -webkit-box;
          display: -webkit-flex;
          display: flex;
          -ms-flex-align: center;
          -webkit-box-align: center;
          -webkit-align-items: center;
          align-items: center;
          -ms-flex-pack: center;
          -webkit-box-pack: center;
          -webkit-justify-content: center;
          justify-content: center; } }
    @media screen and (max-width: 700px) {
      .topctt .imgtxt.flex .imgbox {
        width: 100% !important;
        padding-bottom: 1.5em; } }
    .topctt .imgtxt.flex.rvbox {
      display: -ms-flexbox;
      display: -webkit-box;
      display: -webkit-flex;
      display: flex;
      -webkit-flex-wrap: wrap;
      flex-wrap: wrap;
      -ms-flex-direction: row-reverse;
      -webkit-box-orient: horizontal;
      -webkit-box-direction: reverse;
      -webkit-flex-direction: row-reverse;
      flex-direction: row-reverse; }
    @media screen and (max-width: 700px) {
      .topctt .imgtxt.flex.txt1st {
        display: -ms-flexbox;
        display: -webkit-box;
        display: -webkit-flex;
        display: flex;
        -webkit-flex-wrap: wrap;
        flex-wrap: wrap;
        -ms-flex-direction: column-reverse;
        -webkit-box-orient: vertical;
        -webkit-box-direction: reverse;
        -webkit-flex-direction: column-reverse;
        flex-direction: column-reverse; }
        .topctt .imgtxt.flex.txt1st .imgbox {
          padding-bottom: 0; } }
  .topctt .imgtxt.layered {
    display: block; }
    .topctt .imgtxt.layered .txtbox {
      width: auto !important;
      display: -ms-flexbox;
      display: -webkit-box;
      display: -webkit-flex;
      display: flex;
      -ms-flex-align: center;
      -webkit-box-align: center;
      -webkit-align-items: center;
      align-items: center;
      position: absolute;
      top: 0;
      left: 60%;
      right: 0;
      bottom: 0;
      margin: auto;
      z-index: 2; }
      @media screen and (max-width: 1051px) {
        .topctt .imgtxt.layered .txtbox {
          position: absolute;
          top: 0;
          left: 45%;
          right: 0;
          bottom: 0; } }
      @media screen and (max-width: 700px) {
        .topctt .imgtxt.layered .txtbox {
          width: 80% !important;
          position: relative;
          -webkit-box-sizing: border-box;
          -moz-box-sizing: border-box;
          box-sizing: border-box;
          margin: 0;
          margin-top: -20%;
          left: 20%; } }
  @media screen and (max-width: 700px) and (min-width: 481px) {
    .topctt .imgtxt.layered .txtbox .left {
      text-align: right; } }

      @media screen and (max-width: 480px) {
        .topctt .imgtxt.layered .txtbox {
          width: 100% !important;
          margin-top: -10%;
          left: 0; } }
    .topctt .imgtxt.layered .imgbox {
      width: 70% !important;
      padding-right: 30%; }
      @media screen and (max-width: 700px) {
        .topctt .imgtxt.layered .imgbox {
          width: 60% !important;
          padding-right: 40%; } }
      @media screen and (max-width: 480px) {
        .topctt .imgtxt.layered .imgbox {
          width: 80% !important;
          padding-left: 20%;
          padding-right: 0; } }
    .topctt .imgtxt.layered.rvbox .txtbox {
      position: absolute;
      top: 0;
      left: 0;
      right: 60%;
      bottom: 0; }
      @media screen and (max-width: 1051px) {
        .topctt .imgtxt.layered.rvbox .txtbox {
          position: absolute;
          top: 0;
          left: 0;
          right: 45%;
          bottom: 0; } }
      @media screen and (max-width: 700px) {
        .topctt .imgtxt.layered.rvbox .txtbox {
          right: 0;
          position: relative;
          -webkit-box-sizing: border-box;
          -moz-box-sizing: border-box;
          box-sizing: border-box; } }
  @media screen and (max-width: 700px) and (min-width: 481px) {
    .topctt .imgtxt.layered.rvbox .txtbox .left {
      text-align: left; } }

    .topctt .imgtxt.layered.rvbox .imgbox {
      padding-left: 30%;
      padding-right: 0; }
      @media screen and (max-width: 700px) {
        .topctt .imgtxt.layered.rvbox .imgbox {
          padding-left: 40%;
          padding-right: 0; } }
      @media screen and (max-width: 480px) {
        .topctt .imgtxt.layered.rvbox .imgbox {
          padding-left: 20%;
          padding-right: 0; } }

/* タイトルの次に来た場合 */
.topctt h2 + .imgtxt,
.topctt h3 + .imgtxt,
.topctt h4 + .imgtxt,
.topctt h5 + .imgtxt {
  padding-top: 6em; }
  @media screen and (max-width: 480px) {
    .topctt h2 + .imgtxt,
    .topctt h3 + .imgtxt,
    .topctt h4 + .imgtxt,
    .topctt h5 + .imgtxt {
      padding-top: 3em; } }

/* Scss Document */
.topctt .topmenu {
  width: 100%;
  position: relative;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  padding-top: 4em; }
  .topctt .topmenu:first-child {
    padding-top: 0; }
  .topctt .topmenu ul {
    width: 100%;
    position: relative;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    display: -ms-flexbox;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: stretch;
    -webkit-box-align: stretch;
    -webkit-align-items: stretch;
    align-items: stretch;
    margin: -3em auto 0 auto; }
    @media screen and (max-width: 1051px) {
      .topctt .topmenu ul {
        margin-top: -6%; } }
    @media screen and (max-width: 700px) {
      .topctt .topmenu ul {
        width: 100% !important; } }
    @media screen and (max-width: 480px) {
      .topctt .topmenu ul {
        margin-top: -3em !important; } }
    .topctt .topmenu ul li {
      position: relative;
      -webkit-box-sizing: border-box;
      -moz-box-sizing: border-box;
      box-sizing: border-box;
      line-height: 1.5em;
      margin-top: 3em; }
      @media screen and (max-width: 1051px) {
        .topctt .topmenu ul li {
          margin-top: 6%; } }
      @media screen and (max-width: 480px) {
        .topctt .topmenu ul li {
          margin-top: 3em; } }
      .topctt .topmenu ul li a {
        text-decoration: none !important;
        color: #090a37; }
        .topctt .topmenu ul li a h2, .topctt .topmenu ul li a h3 {
          color: #009fe8; }
        .topctt .topmenu ul li a:hover img {
          opacity: 1;
          filter: alpha(opacity=70);
          -webkit-transform: scale(1.05);
          -moz-transform: scale(1.05);
          -ms-transform: scale(1.05);
          -o-transform: scale(1.05);
          transform: scale(1.05); }
      .topctt .topmenu ul li .topmenuimg,
      .topctt .topmenu ul li .topmenutxt {
        padding-top: 1em; }
        .topctt .topmenu ul li .topmenuimg:first-child,
        .topctt .topmenu ul li .topmenutxt:first-child {
          padding-top: 0; }
      .topctt .topmenu ul li .topmenuimg {
        width: 100%;
        position: relative;
        -webkit-box-sizing: border-box;
        -moz-box-sizing: border-box;
        box-sizing: border-box; }
        .topctt .topmenu ul li .topmenuimg img {
          width: 100%;
          height: auto; }
      .topctt .topmenu ul li .topmenutxt {
        width: 100%;
        position: relative;
        -webkit-box-sizing: border-box;
        -moz-box-sizing: border-box;
        box-sizing: border-box; }
        .topctt .topmenu ul li .topmenutxt h2, .topctt .topmenu ul li .topmenutxt h3 {
          padding-bottom: 0.5em;
          line-height: 1.3em; }
          .topctt .topmenu ul li .topmenutxt h2:last-child, .topctt .topmenu ul li .topmenutxt h3:last-child {
            padding-bottom: 0; }
        .topctt .topmenu ul li .topmenutxt p {
          font-weight: 500;
          padding-bottom: 0 !important; }
          .topctt .topmenu ul li .topmenutxt p + p {
            padding-top: 0.3em !important; }
          .topctt .topmenu ul li .topmenutxt p + h2, .topctt .topmenu ul li .topmenutxt p h3 {
            padding-top: 0.5em; }
          .topctt .topmenu ul li .topmenutxt p:last-child {
            padding-bottom: 0; }
    .topctt .topmenu ul.menu_type2 {
      margin-top: -10%; }
      @media screen and (max-width: 1051px) {
        .topctt .topmenu ul.menu_type2 {
          margin-top: -6%; } }
      @media screen and (max-width: 480px) {
        .topctt .topmenu ul.menu_type2 {
          margin-top: -3em !important; } }
      .topctt .topmenu ul.menu_type2 li {
        width: 47%;
        position: relative;
        margin-top: 10%; }
        @media screen and (max-width: 1051px) {
          .topctt .topmenu ul.menu_type2 li {
            width: 47%; } }
        @media screen and (max-width: 1051px) {
          .topctt .topmenu ul.menu_type2 li {
            margin-top: 6%; } }
        @media screen and (min-width: 481px) {
          .topctt .topmenu ul.menu_type2 li {
            margin-right: 6%; }
            .topctt .topmenu ul.menu_type2 li:nth-child(2n) {
              margin-right: 0; } }
        @media screen and (max-width: 480px) {
          .topctt .topmenu ul.menu_type2 li {
            margin-top: 3em;
            width: 100%; } }
      .topctt .topmenu ul.menu_type2.broken li:nth-child(2) {
        padding: 4em;
        padding-top: 20em; }
        @media screen and (max-width: 700px) {
          .topctt .topmenu ul.menu_type2.broken li:nth-child(2) {
            padding: 2em;
            padding-top: 10em; } }
        @media screen and (max-width: 480px) {
          .topctt .topmenu ul.menu_type2.broken li:nth-child(2) {
            padding: 0;
            padding-left: 2em; } }
      .topctt .topmenu ul.menu_type2.broken li:nth-child(3) {
        padding: 2em;
        padding-top: 0;
        margin-top: -8em;
        right: -6em; }
        @media screen and (max-width: 1051px) {
          .topctt .topmenu ul.menu_type2.broken li:nth-child(3) {
            right: 0; } }
        @media screen and (max-width: 700px) {
          .topctt .topmenu ul.menu_type2.broken li:nth-child(3) {
            margin-top: -4em; } }
        @media screen and (max-width: 480px) {
          .topctt .topmenu ul.menu_type2.broken li:nth-child(3) {
            padding: 0;
            margin-top: 3em; } }
      @media screen and (max-width: 480px) {
        .topctt .topmenu ul.menu_type2.broken li:nth-child(4) {
          padding-left: 3em; } }
    @media screen and (max-width: 1051px) {
      .topctt .topmenu ul.menu_type3 {
        width: 100% !important; } }
    .topctt .topmenu ul.menu_type3 li {
      width: 30%;
      position: relative; }
      @media screen and (min-width: 1050px) {
        .topctt .topmenu ul.menu_type3 li {
          margin-right: 5%; }
          .topctt .topmenu ul.menu_type3 li:nth-child(3n) {
            margin-right: 0; } }
      @media screen and (max-width: 1051px) {
        .topctt .topmenu ul.menu_type3 li {
          width: 32%; } }
  @media screen and (max-width: 1051px) and (min-width: 481px) {
    .topctt .topmenu ul.menu_type3 li {
      margin-right: 2%; }
      .topctt .topmenu ul.menu_type3 li:nth-child(3n) {
        margin-right: 0; } }

      @media screen and (max-width: 480px) {
        .topctt .topmenu ul.menu_type3 li {
          width: 100%; } }
    .topctt .topmenu ul.menu_type4 li {
      width: 23%;
      position: relative; }
      @media screen and (min-width: 1050px) {
        .topctt .topmenu ul.menu_type4 li {
          margin-right: calc( 8% / 3 ); }
          .topctt .topmenu ul.menu_type4 li:nth-child(4n) {
            margin-right: 0; } }
      @media screen and (max-width: 1051px) {
        .topctt .topmenu ul.menu_type4 li {
          width: 47%; } }
  @media screen and (max-width: 1051px) and (min-width: 481px) {
    .topctt .topmenu ul.menu_type4 li {
      margin-right: 6%; }
      .topctt .topmenu ul.menu_type4 li:nth-child(2n) {
        margin-right: 0; } }

      @media screen and (max-width: 480px) {
        .topctt .topmenu ul.menu_type4 li {
          width: 100%; } }
    .topctt .topmenu ul li.li_nomargin {
      margin-top: 0; }
.topctt h2 + .topmenu {
  padding-top: 2em; }

/* 流れ */
.topctt .flowbox {
  padding-top: 2em; }
  .topctt .flowbox ul {
    width: 100%;
    position: relative;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    display: -ms-flexbox;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: stretch;
    -webkit-box-align: stretch;
    -webkit-align-items: stretch;
    align-items: stretch;
    margin-top: -2%;
    counter-reset: flownumb; }
    @media screen and (max-width: 700px) {
      .topctt .flowbox ul {
        margin-top: -3em; } }
    .topctt .flowbox ul li {
      background: #fff;
      color: #090a37;
      border: #009fe8 solid 0.3em;
      border-radius: 1em;
      position: relative;
      -webkit-box-sizing: border-box;
      -moz-box-sizing: border-box;
      box-sizing: border-box;
      padding: 1.5em;
      overflow: visible;
      margin-top: calc( 2% + 3em ); }
@media screen and (max-width: 1051px) and (min-width: 701px) {
  .topctt .flowbox ul li {
    padding: 1.5em 0.5em; } }

      @media screen and (max-width: 700px) {
        .topctt .flowbox ul li {
          margin-top: 6em; } }
      .topctt .flowbox ul li .flowctt {
        width: 100%;
        position: relative;
        -webkit-box-sizing: border-box;
        -moz-box-sizing: border-box;
        box-sizing: border-box;
        overflow: visible; }
        @media screen and (max-width: 700px) {
          .topctt .flowbox ul li .flowctt {
            display: -ms-flexbox;
            display: -webkit-box;
            display: -webkit-flex;
            display: flex;
            -webkit-flex-wrap: wrap;
            flex-wrap: wrap;
            -ms-flex-pack: justify;
            -webkit-box-pack: justify;
            -webkit-justify-content: space-between;
            justify-content: space-between;
            -ms-flex-align: stretch;
            -webkit-box-align: stretch;
            -webkit-align-items: stretch;
            align-items: stretch; } }
        @media screen and (max-width: 480px) {
          .topctt .flowbox ul li .flowctt {
            display: block; } }
        .topctt .flowbox ul li .flowctt .ttl_numb {
          font-size: 1em;
          position: absolute;
          top: -3.5em;
          left: 50%;
          right: auto;
          bottom: auto;
          box-sizing: border-box;
          z-index: 5;
          background: #009fe8;
          border: #fff solid 0.3em;
          border-radius: 50%;
          width: 4em;
          height: 4em;
          line-height: 0;
          display: -ms-flexbox;
          display: -webkit-box;
          display: -webkit-flex;
          display: flex;
          -ms-flex-align: center;
          -webkit-box-align: center;
          -webkit-align-items: center;
          align-items: center;
          -ms-flex-pack: center;
          -webkit-box-pack: center;
          -webkit-justify-content: center;
          justify-content: center;
          padding-bottom: 0;
          -webkit-transform: translate(-50%, 0);
          -moz-transform: translate(-50%, 0);
          -ms-transform: translate(-50%, 0);
          -o-transform: translate(-50%, 0);
          transform: translate(-50%, 0); }
          @media screen and (max-width: 700px) {
            .topctt .flowbox ul li .flowctt .ttl_numb {
              width: 6em;
              height: 6em;
              left: 50%; } }
          .topctt .flowbox ul li .flowctt .ttl_numb.numboff {
            display: none; }
          .topctt .flowbox ul li .flowctt .ttl_numb .numb {
            font-family: gazzetta-variable, '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'Meiryo UI', 'メイリオ', Meiryo, sans-serif;
            font-style: normal;
            font-weight: normal;
            font-size: 1.5em;
            font-weight: 700;
            line-height: 1em;
            opacity: 1;
            filter: alpha(opacity=100);
            -webkit-transform: translate(0, -0.1em);
            -moz-transform: translate(0, -0.1em);
            -ms-transform: translate(0, -0.1em);
            -o-transform: translate(0, -0.1em);
            transform: translate(0, -0.1em); }
            @media screen and (max-width: 700px) {
              .topctt .flowbox ul li .flowctt .ttl_numb .numb {
                font-size: 2.5em; } }
            .topctt .flowbox ul li .flowctt .ttl_numb .numb::before {
              color: #fff;
              counter-increment: flownumb;
              content: counter(flownumb,decimal-leading-zero); }
        .topctt .flowbox ul li .flowctt .imgbpx {
          width: 100%;
          position: relative;
          -webkit-box-sizing: border-box;
          -moz-box-sizing: border-box;
          box-sizing: border-box;
          padding-bottom: 1em;
          z-index: 2; }
          @media screen and (max-width: 700px) {
            .topctt .flowbox ul li .flowctt .imgbpx {
              width: 48%; } }
          @media screen and (max-width: 480px) {
            .topctt .flowbox ul li .flowctt .imgbpx {
              width: 90%;
              margin-left: 5%; } }
          .topctt .flowbox ul li .flowctt .imgbpx img {
            width: 100%;
            height: auto; }
        @media screen and (max-width: 700px) {
          .topctt .flowbox ul li .flowctt .txtbox {
            width: 48%;
            font-size: 1.5em;
            display: -ms-flexbox;
            display: -webkit-box;
            display: -webkit-flex;
            display: flex;
            -ms-flex-align: center;
            -webkit-box-align: center;
            -webkit-align-items: center;
            align-items: center; } }
        @media screen and (max-width: 480px) {
          .topctt .flowbox ul li .flowctt .txtbox {
            width: 100%;
            padding-left: 0;
            padding-top: 0; } }
        .topctt .flowbox ul li .flowctt .txtbox .flow_ttl {
          line-height: 1.5em; }
          .topctt .flowbox ul li .flowctt .txtbox .flow_ttl .eg {
            font-weight: 700; }
        .topctt .flowbox ul li .flowctt .txtbox p {
          line-height: 1.5em;
          padding-top: 1em; }
          .topctt .flowbox ul li .flowctt .txtbox p:first-child {
            padding-top: 0; }
      .topctt .flowbox ul li::after {
        font-family: "Font Awesome 5 Free";
        content: "\f054";
        font-weight: 900;
        font-size: 1em;
        position: absolute;
        top: 0;
        left: auto;
        right: -1.35em;
        bottom: 0;
        margin: auto;
        display: -ms-flexbox;
        display: -webkit-box;
        display: -webkit-flex;
        display: flex;
        -ms-flex-align: center;
        -webkit-box-align: center;
        -webkit-align-items: center;
        align-items: center;
        color: #009fe8; }
        @media screen and (max-width: 1051px) {
          .topctt .flowbox ul li::after {
            right: -0.9em; } }
        @media screen and (max-width: 700px) {
          .topctt .flowbox ul li::after {
            position: absolute;
            top: auto;
            left: 0;
            right: auto;
            bottom: -1.35em;
            display: -ms-flexbox;
            display: -webkit-box;
            display: -webkit-flex;
            display: flex;
            -ms-flex-align: center;
            -webkit-box-align: center;
            -webkit-align-items: center;
            align-items: center;
            -ms-flex-pack: center;
            -webkit-box-pack: center;
            -webkit-justify-content: center;
            justify-content: center;
            width: 100%;
            content: "\f078";
            font-size: 2em; } }
      .topctt .flowbox ul li:last-child::after {
        display: none;
        content: none; }
    .topctt .flowbox ul.flow_type2 li {
      width: 49%;
      margin-right: 2%; }
      .topctt .flowbox ul.flow_type2 li:nth-child(2n) {
        margin-right: 0; }
        .topctt .flowbox ul.flow_type2 li:nth-child(2n)::after {
          display: none;
          content: none; }
      @media screen and (max-width: 700px) {
        .topctt .flowbox ul.flow_type2 li {
          width: 100%;
          margin-right: 0; } }
    .topctt .flowbox ul.flow_type3 li {
      width: 32%;
      margin-right: 2%; }
      .topctt .flowbox ul.flow_type3 li:nth-child(3n) {
        margin-right: 0; }
        .topctt .flowbox ul.flow_type3 li:nth-child(3n)::after {
          display: none;
          content: none; }
      @media screen and (max-width: 700px) {
        .topctt .flowbox ul.flow_type3 li {
          width: 100%;
          margin-right: 0; } }
    .topctt .flowbox ul.flow_type4 li {
      width: 23.5%;
      margin-right: 2%; }
      .topctt .flowbox ul.flow_type4 li:nth-child(4n) {
        margin-right: 0; }
        .topctt .flowbox ul.flow_type4 li:nth-child(4n)::after {
          display: none;
          content: none; }
      @media screen and (max-width: 700px) {
        .topctt .flowbox ul.flow_type4 li {
          width: 100%;
          margin-right: 0; } }
    .topctt .flowbox ul.flow_type5 li {
      width: 18.4%;
      margin-right: 2%; }
      .topctt .flowbox ul.flow_type5 li:nth-child(5n) {
        margin-right: 0; }
        .topctt .flowbox ul.flow_type5 li:nth-child(5n)::after {
          display: none;
          content: none; }
      @media screen and (max-width: 700px) {
        .topctt .flowbox ul.flow_type5 li {
          width: 100%;
          margin-right: 0; } }
    .topctt .flowbox ul.flow_type6 li {
      width: 15%;
      margin-right: 2%; }
      .topctt .flowbox ul.flow_type6 li:nth-child(6n) {
        margin-right: 0; }
        .topctt .flowbox ul.flow_type6 li:nth-child(6n)::after {
          display: none;
          content: none; }
      @media screen and (max-width: 700px) {
        .topctt .flowbox ul.flow_type6 li {
          width: 100%;
          margin-right: 0; } }
.topctt.top_bg1 .flowbox ul li {
  background: #e1f0f9; }
  .topctt.top_bg1 .flowbox ul li .flowctt .ttl_numb {
    background: #e1f0f9; }
.topctt.top_bg3 .flowbox ul li::after {
  color: #fff; }

/* Scss Document */
.bgtxtbox.dark {
  color: #fff; }
.bgtxtbox h2 {
  font-size: 1em;
  padding-bottom: 3em; }
  .bgtxtbox h2 span {
    display: block;
    line-height: 1.5em; }

/* トップページセクション */
.topctt {
  width: 100%;
  position: relative;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box; }
  .topctt:not(#topsec_nmpost):not(#topsec_grid):not(#topsec_abst) a {
    text-decoration: underline; }
  .topctt .btn a {
    text-decoration: none; }
  .topctt.topnop {
    padding-top: 0; }
  .topctt.bottomnop {
    padding-bottom: 0; }
  .topctt .topnop {
    padding-top: 0 !important; }
  .topctt.top_bg1 {
    background-color: transparent; }
  .topctt.top_bg2 {
    background-color: #e1f0f9; }
  .topctt.top_bg3 {
    background-color: #009fe8;
    color: #fff; }
    .topctt.top_bg3 a {
      color: #fff; }

/* テキストブロック */
.topctt .txt_block {
  padding-top: 4em; }
  .topctt .txt_block:first-child {
    padding-top: 0; }
.topctt h2 + .txt_block,
.topctt h3 + .txt_block {
  padding-top: 0; }
.topctt .innerbox {
  z-index: 5; }
  .topctt .innerbox .txt_block {
    padding-top: 4em; }
    .topctt .innerbox .txt_block:first-child {
      padding-top: 0; }
  .topctt .innerbox h2 + .txt_block,
  .topctt .innerbox h3 + .txt_block {
    padding-top: 0; }

/* 画像ブロック */
@media screen and (max-width: 700px) {
  .topctt .img_block img {
    width: 100% !important; } }
.topctt .img_block a:hover img {
  opacity: 1;
  filter: alpha(opacity=70); }

/* =======================================================================================================================
　　　　　　　　　Q&A
======================================================================================================================= */
.faq-ctt {
  /* -------------------------- Q&Aリスト ------------------------------------------- */
  /* -------------------------- リンクボタン ------------------------------------------- */ }
  .faq-ctt ul.qa_list {
    width: 100%;
    position: relative;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    list-style: none inside; }
    .faq-ctt ul.qa_list li.qa_set {
      width: 100%;
      position: relative;
      -webkit-box-sizing: border-box;
      -moz-box-sizing: border-box;
      box-sizing: border-box;
      background: #fff;
      margin-bottom: 1em;
      border-radius: 0.5em;
      overflow: hidden;
      /* テキスト ------------------------------------------- */
      /* 開閉動作 ------------------------------------------- */ }
      .top_bg1 .faq-ctt ul.qa_list li.qa_set {
        background: #e1f0f9; }
      .faq-ctt ul.qa_list li.qa_set label {
        cursor: pointer; }
      .faq-ctt ul.qa_list li.qa_set .qa_txt {
        width: 100%;
        position: relative;
        -webkit-box-sizing: border-box;
        -moz-box-sizing: border-box;
        box-sizing: border-box;
        /* Q */
        /* A */ }
        .faq-ctt ul.qa_list li.qa_set .qa_txt .question {
          width: 100%;
          position: relative;
          -webkit-box-sizing: border-box;
          -moz-box-sizing: border-box;
          box-sizing: border-box;
          font-size: 1.1em;
          font-weight: 400;
          line-height: 2em;
          background: #fff;
          padding: 1.2em;
          text-indent: -1.9em;
          padding-left: 3.45em;
          padding-right: 4em;
          -webkit-transition: 1s ease;
          -moz-transition: 1s ease;
          -ms-transition: 1s ease;
          -o-transition: 1s ease;
          transition: 1s ease; }
          .top_bg1 .faq-ctt ul.qa_list li.qa_set .qa_txt .question {
            background: #e1f0f9; }
          .faq-ctt ul.qa_list li.qa_set .qa_txt .question::before {
            content: "Q";
            font-weight: 700;
            font-size: 1.5em;
            padding-right: 0.5em;
            color: #009fe8; }
          .faq-ctt ul.qa_list li.qa_set .qa_txt .question::after {
            font-size: 2em;
            font-weight: 300;
            text-indent: 0;
            line-height: 1em;
            content: "+";
            box-sizing: border-box;
            width: 1em;
            height: 1em;
            border-radius: 50%;
            border: #009fe8 solid 0.05em;
            color: #009fe8;
            display: -ms-flexbox;
            display: -webkit-box;
            display: -webkit-flex;
            display: flex;
            -ms-flex-align: center;
            -webkit-box-align: center;
            -webkit-align-items: center;
            align-items: center;
            -ms-flex-pack: center;
            -webkit-box-pack: center;
            -webkit-justify-content: center;
            justify-content: center;
            position: absolute;
            top: auto;
            left: auto;
            right: 0.6em;
            bottom: 0.6em;
            -webkit-transition: 1s ease;
            -moz-transition: 1s ease;
            -ms-transition: 1s ease;
            -o-transition: 1s ease;
            transition: 1s ease;
            opacity: 0.5;
            filter: alpha(opacity=70);
            padding-bottom: 0.1em; }
        .faq-ctt ul.qa_list li.qa_set .qa_txt p.answer {
          width: 100%;
          position: relative;
          -webkit-box-sizing: border-box;
          -moz-box-sizing: border-box;
          box-sizing: border-box;
          height: auto;
          max-height: 0;
          overflow: hidden;
          padding: 0;
          -webkit-transition: 1s ease;
          -moz-transition: 1s ease;
          -ms-transition: 1s ease;
          -o-transition: 1s ease;
          transition: 1s ease; }
          .faq-ctt ul.qa_list li.qa_set .qa_txt p.answer span {
            display: block;
            width: 100%;
            position: relative;
            -webkit-box-sizing: border-box;
            -moz-box-sizing: border-box;
            box-sizing: border-box;
            padding: 1.5em;
            text-indent: -1.8em;
            padding-left: 3.8em;
            line-height: 1.5em; }
            .faq-ctt ul.qa_list li.qa_set .qa_txt p.answer span::before {
              content: "A";
              font-size: 1.5em;
              font-weight: 700;
              padding-right: 0.5em;
              color: #f6593f; }
      .faq-ctt ul.qa_list li.qa_set .qa_open {
        position: absolute;
        top: 0;
        left: 0;
        right: auto;
        bottom: auto;
        z-index: 10;
        opacity: 0;
        filter: alpha(opacity=70); }
        .faq-ctt ul.qa_list li.qa_set .qa_open:checked + .qa_txt {
          /* Q */
          /* A */ }
          .faq-ctt ul.qa_list li.qa_set .qa_open:checked + .qa_txt .question {
            font-weight: 700;
            background: #009fe8;
            color: #fff; }
            .faq-ctt ul.qa_list li.qa_set .qa_open:checked + .qa_txt .question::before {
              color: #fff; }
            .faq-ctt ul.qa_list li.qa_set .qa_open:checked + .qa_txt .question::after {
              content: "-";
              padding-bottom: 0.3em;
              color: #fff;
              border-color: #fff; }
          .faq-ctt ul.qa_list li.qa_set .qa_open:checked + .qa_txt p.answer {
            max-height: 50em; }
  .faq-ctt .btn {
    padding-top: 2em; }

/* ===========================================================================================================
　　　　　　　　　WP Lightbox2 調整
=========================================================================================================== */
/* ================= オーバーレイ ============================================================ */
#overlay {
  background: transparent url("/images/bg_popup.gif") repeat 0 0 !important; }

/* ================= ポップアップ領域 ============================================================ */
#lightbox {
  font-size: 16px;
  font-size: 1vw;
  width: 50em;
  height: 22em;
  left: calc( 50% - 25em ) !important;
  display: -ms-flexbox;
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
  -ms-flex-align: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  align-items: center;
  /* -------------------------- テキストコンテナ ------------------------------------------- */
  /* -------------------------- 画像コンテナ ------------------------------------------- */ }
  @media screen and (min-width: 2200px) {
    #lightbox {
      font-size: 22px;
      line-height: 2.5em; } }
  @media screen and (max-width: 1051px) {
    #lightbox {
      font-size: 14px;
      font-size: 1.4vw; } }
  @media screen and (max-width: 700px) {
    #lightbox {
      font-size: 13px;
      font-size: 2vw; } }
  @media screen and (max-width: 480px) {
    #lightbox {
      font-size: 13px;
      font-size: 3vw; } }
  @media screen and (max-width: 700px) {
    #lightbox {
      width: 40em;
      height: 32em;
      left: calc( 50% - 20em ) !important; } }
  @media screen and (max-width: 480px) {
    #lightbox {
      width: 24em;
      height: 37em;
      left: calc( 50% - 12em ) !important; } }
  #lightbox #imageDataContainer,
  #lightbox #outerImageContainer {
    font-family: source-han-sans-japanese, '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'Meiryo UI', 'メイリオ', Meiryo, sans-serif;
    font-style: normal;
    font-size: 16px;
    font-size: 1vw;
    width: 100% !important;
    height: auto !important;
    box-sizing: border-box;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto; }
    @media screen and (min-width: 2200px) {
      #lightbox #imageDataContainer,
      #lightbox #outerImageContainer {
        font-size: 22px;
        line-height: 2.5em; } }
    @media screen and (max-width: 1051px) {
      #lightbox #imageDataContainer,
      #lightbox #outerImageContainer {
        font-size: 14px;
        font-size: 1.4vw; } }
    @media screen and (max-width: 700px) {
      #lightbox #imageDataContainer,
      #lightbox #outerImageContainer {
        font-size: 13px;
        font-size: 2vw; } }
    @media screen and (max-width: 480px) {
      #lightbox #imageDataContainer,
      #lightbox #outerImageContainer {
        font-size: 13px;
        font-size: 3vw; } }
  #lightbox #imageDataContainer {
    background: #fff;
    border-radius: 1em; }
    #lightbox #imageDataContainer #imageData {
      position: absolute;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      margin: auto;
      box-sizing: border-box;
      padding-left: 40%;
      display: -ms-flexbox;
      display: -webkit-box;
      display: -webkit-flex;
      display: flex;
      -ms-flex-align: center;
      -webkit-box-align: center;
      -webkit-align-items: center;
      align-items: center;
      display: -ms-flexbox !important;
      display: -webkit-box !important;
      display: -webkit-flex !important;
      display: flex !important;
      /* 説明テキスト ------------------------------------------- */
      /* 閉じるボタン ------------------------------------------- */ }
      @media screen and (max-width: 700px) {
        #lightbox #imageDataContainer #imageData {
          padding-left: 0;
          padding-top: 15em; } }
      #lightbox #imageDataContainer #imageData #imageDetails {
        width: 100%;
        position: relative;
        -webkit-box-sizing: border-box;
        -moz-box-sizing: border-box;
        box-sizing: border-box;
        padding-right: 5em;
        /* キャプション */
        /* ナンバー表示 */ }
        @media screen and (max-width: 700px) {
          #lightbox #imageDataContainer #imageData #imageDetails {
            padding: 0 5em; } }
        @media screen and (max-width: 480px) {
          #lightbox #imageDataContainer #imageData #imageDetails {
            padding: 0 2em; } }
        #lightbox #imageDataContainer #imageData #imageDetails #caption #titleText {
          font-weight: 500;
          line-height: 1.5em; }
          @media screen and (max-width: 480px) {
            #lightbox #imageDataContainer #imageData #imageDetails #caption #titleText {
              line-height: 1.4em; } }
          #lightbox #imageDataContainer #imageData #imageDetails #caption #titleText strong {
            font-weight: 700;
            display: inline-block;
            padding-bottom: 0.5em; }
          #lightbox #imageDataContainer #imageData #imageDetails #caption #titleText br + i,
          #lightbox #imageDataContainer #imageData #imageDetails #caption #titleText br + b {
            padding-top: 0.35em; }
          #lightbox #imageDataContainer #imageData #imageDetails #caption #titleText b,
          #lightbox #imageDataContainer #imageData #imageDetails #caption #titleText i {
            display: inline-block;
            font-size: 0.9em;
            font-weight: 400;
            font-style: normal;
            line-height: 1.3em;
            padding-left: 1em;
            text-indent: -1em;
            padding-bottom: 0.35em;
            color: #009fe8; }
            #lightbox #imageDataContainer #imageData #imageDetails #caption #titleText b::before,
            #lightbox #imageDataContainer #imageData #imageDetails #caption #titleText i::before {
              content: "●"; }
          #lightbox #imageDataContainer #imageData #imageDetails #caption #titleText b {
            color: #26bc8a; }
          #lightbox #imageDataContainer #imageData #imageDetails #caption #titleText img {
            width: auto;
            height: 3em;
            position: absolute;
            top: 0;
            left: auto;
            right: 4em;
            bottom: auto; }
            @media screen and (max-width: 700px) {
              #lightbox #imageDataContainer #imageData #imageDetails #caption #titleText img {
                right: 5em; } }
            @media screen and (max-width: 480px) {
              #lightbox #imageDataContainer #imageData #imageDetails #caption #titleText img {
                right: 1em; }
                #lightbox #imageDataContainer #imageData #imageDetails #caption #titleText img.sp_maxwidth {
                  width: 9em;
                  height: auto;
                  top: 1em; } }
            #lightbox #imageDataContainer #imageData #imageDetails #caption #titleText img + strong {
              padding-top: 2em; }
        #lightbox #imageDataContainer #imageData #imageDetails #numberDisplay {
          display: none !important; }
      #lightbox #imageDataContainer #imageData #bottomNav #bottomNavClose {
        width: 2em !important;
        position: absolute;
        top: -3em;
        left: auto;
        right: -2em;
        bottom: auto;
        padding-bottom: 0 !important;
        /* 閉じるボタン画像 */ }
        #lightbox #imageDataContainer #imageData #bottomNav #bottomNavClose #jqlb_closelabel {
          width: 3em !important;
          height: 3em;
          background: url("/images/btn_close.svg") no-repeat 0 0/contain; }
  #lightbox #outerImageContainer {
    background-color: transparent; }
    #lightbox #outerImageContainer #imageContainer {
      position: absolute;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      margin: auto;
      box-sizing: border-box;
      padding-right: 60%;
      display: -ms-flexbox;
      display: -webkit-box;
      display: -webkit-flex;
      display: flex;
      -ms-flex-align: center;
      -webkit-box-align: center;
      -webkit-align-items: center;
      align-items: center;
      /* 画像 ------------------------------------------- */
      /* ナビゲーション ------------------------------------------- */ }
      @media screen and (max-width: 700px) {
        #lightbox #outerImageContainer #imageContainer {
          padding-right: 0;
          padding-bottom: 17em;
          display: -ms-flexbox;
          display: -webkit-box;
          display: -webkit-flex;
          display: flex;
          -ms-flex-align: center;
          -webkit-box-align: center;
          -webkit-align-items: center;
          align-items: center;
          -ms-flex-pack: center;
          -webkit-box-pack: center;
          -webkit-justify-content: center;
          justify-content: center; } }
      @media screen and (max-width: 480px) {
        #lightbox #outerImageContainer #imageContainer {
          padding-bottom: 22em; } }
      #lightbox #outerImageContainer #imageContainer img {
        width: 100% !important; }
        @media screen and (max-width: 700px) {
          #lightbox #outerImageContainer #imageContainer img {
            width: 50% !important; } }
        @media screen and (max-width: 480px) {
          #lightbox #outerImageContainer #imageContainer img {
            width: 95% !important; } }
      #lightbox #outerImageContainer #imageContainer #hoverNav a {
        background-size: 3em auto;
        /* 戻る */
        /* 進む */ }
        #lightbox #outerImageContainer #imageContainer #hoverNav a#prevLink {
          background-position: 3em 50%; }
          #lightbox #outerImageContainer #imageContainer #hoverNav a#prevLink:hover {
            background: url("/images/btn_prev.svg") no-repeat 1em 50%/2em auto; }
          @media screen and (max-width: 700px) {
            #lightbox #outerImageContainer #imageContainer #hoverNav a#prevLink {
              background: url("/images/btn_prev.svg") no-repeat 1em 50%/2em auto; } }
          @media screen and (max-width: 480px) {
            #lightbox #outerImageContainer #imageContainer #hoverNav a#prevLink {
              background-position: 1em 25%; }
              #lightbox #outerImageContainer #imageContainer #hoverNav a#prevLink:hover {
                background-position: 1em 25%; } }
        #lightbox #outerImageContainer #imageContainer #hoverNav a#nextLink {
          background-position: right 3em top 50%; }
          #lightbox #outerImageContainer #imageContainer #hoverNav a#nextLink:hover {
            background: url("/images/btn_next.svg") no-repeat right 1em top 50%/2em auto; }
          @media screen and (max-width: 700px) {
            #lightbox #outerImageContainer #imageContainer #hoverNav a#nextLink {
              background: url("/images/btn_next.svg") no-repeat right 1em top 50%/2em auto; } }
          @media screen and (max-width: 480px) {
            #lightbox #outerImageContainer #imageContainer #hoverNav a#nextLink {
              background-position: right 1em top 25%; }
              #lightbox #outerImageContainer #imageContainer #hoverNav a#nextLink:hover {
                background-position: right 1em top 25%; } }

/* =============================== 要約入り投稿一覧 =================================================================== */
.top_abst {
  /* -------------------------- 一覧エリア ------------------------------------------- */ }
  .top_abst ul {
    list-style: none inside;
    width: 100%;
    position: relative; }
    .top_abst ul li {
      width: 100%;
      box-sizing: border-box;
      margin-bottom: 2.08em;
      background: #fff;
      overflow: hidden;
      border-radius: 1em; }
      .top_abst ul li a {
        display: block;
        width: 100%;
        position: relative;
        -webkit-transition: 0.3s ease-in-out;
        -moz-transition: 0.3s ease-in-out;
        -ms-transition: 0.3s ease-in-out;
        -o-transition: 0.3s ease-in-out;
        transition: 0.3s ease-in-out;
        text-decoration: none !important;
        /* マウスオーバー ------------------------------------------- */ }
        .top_abst ul li a figure {
          position: relative;
          -webkit-box-sizing: border-box;
          -moz-box-sizing: border-box;
          box-sizing: border-box;
          width: 100%;
          min-height: 19em;
          margin-bottom: 0;
          display: -ms-flexbox;
          display: -webkit-box;
          display: -webkit-flex;
          display: flex;
          -ms-flex-align: center;
          -webkit-box-align: center;
          -webkit-align-items: center;
          align-items: center;
          /* 画像 ------------------------------------------- */
          /* テキスト ------------------------------------------- */ }
          @media screen and (max-width: 750px) {
            .top_abst ul li a figure {
              display: block; } }
          .top_abst ul li a figure .imgbox {
            display: block;
            width: 31.9%;
            position: absolute;
            top: 0;
            left: 0;
            right: auto;
            bottom: 0;
            margin: auto;
            overflow: hidden;
            line-height: 0; }
            @media screen and (max-width: 750px) {
              .top_abst ul li a figure .imgbox {
                width: 100%;
                position: relative;
                -webkit-box-sizing: border-box;
                -moz-box-sizing: border-box;
                box-sizing: border-box; } }
            .top_abst ul li a figure .imgbox img.img_max100 {
              object-position: 50% 50%;
              font-family: 'object-fit: cover; object-position: 50% 50%;'; }
          .top_abst ul li a figure figcaption {
            width: 68.1%;
            padding: 4.167em;
            margin-left: 31.9%;
            box-sizing: border-box;
            color: #090a37;
            -webkit-transition: 0.3s ease;
            -moz-transition: 0.3s ease;
            -ms-transition: 0.3s ease;
            -o-transition: 0.3s ease;
            transition: 0.3s ease;
            /* 見出し */
            /* 強調 */
            /* 段落 */ }
            @media screen and (max-width: 750px) {
              .top_abst ul li a figure figcaption {
                width: 100%;
                padding: 2em;
                margin-left: 0; } }
            .top_abst ul li a figure figcaption h3 {
              font-size: 1.7em;
              font-weight: 700;
              line-height: 1.5em;
              padding-bottom: 0.25em; }
            .top_abst ul li a figure figcaption strong {
              font-weight: 400;
              line-height: 1.5em;
              display: block;
              padding-bottom: 1em; }
            .top_abst ul li a figure figcaption p {
              line-height: 1.5em; }
              .top_abst ul li a figure figcaption p:last-child {
                padding-bottom: 0; }
        .top_abst ul li a:hover {
          text-decoration: none; }
          .top_abst ul li a:hover figure {
            /* 画像 */
            /* テキスト */ }
            .top_abst ul li a:hover figure span img.img_max100 {
              -webkit-transform: scale(1.1);
              -moz-transform: scale(1.1);
              -ms-transform: scale(1.1);
              -o-transform: scale(1.1);
              transform: scale(1.1);
              opacity: 1;
              filter: alpha(opacity=70); }
            .top_abst ul li a:hover figure figcaption {
              color: #009fe8; }

/* =============================== 要約入り投稿一覧 =================================================================== */
#topsec_grid {
  /* -------------------------- 記事エリア ------------------------------------------- */ }
  #topsec_grid .top_grid {
    width: 100%;
    position: relative; }
    #topsec_grid .top_grid .gridbox {
      margin-bottom: 4.5em;
      /* グリッド ------------------------------------------- */ }
      #topsec_grid .top_grid .gridbox ul {
        list-style: none inside;
        width: 100%;
        position: relative;
        display: grid;
        grid-template-rows: 23em 23em;
        grid-template-columns: 1fr 27.66% 17% 17%;
        -ms-grid-rows: 23em 23em;
        -ms-grid-columns: 1fr 27.66% 17% 17%; }
        @media screen and (max-width: 750px), screen and (max-height: 450px) {
          #topsec_grid .top_grid .gridbox ul {
            grid-template-rows: 46em 23em 23em;
            grid-template-columns: 50% 12.5% 12.5% 12.5% 12.5%;
            -ms-grid-rows: 46em 23em 23em;
            -ms-grid-columns: 50% 12.5% 12.5% 12.5% 12.5%; } }
        @media screen and (max-width: 480px) {
          #topsec_grid .top_grid .gridbox ul {
            grid-template-rows: 46em 30em 23em 23em;
            grid-template-columns: 50% 50%;
            -ms-grid-rows: 46em 30em 23em 23em;
            -ms-grid-columns: 50% 50%; } }
        #topsec_grid .top_grid .gridbox ul li {
          box-sizing: border-box;
          display: -ms-flexbox;
          display: -webkit-box;
          display: -webkit-flex;
          display: flex;
          -webkit-flex-wrap: wrap;
          flex-wrap: wrap;
          -ms-flex-align: stretch;
          -webkit-box-align: stretch;
          -webkit-align-items: stretch;
          align-items: stretch;
          overflow: hidden;
          /* リンク ------------------------------------------- */
          /* 各アイテム ------------------------------------------- */ }
          #topsec_grid .top_grid .gridbox ul li a {
            width: 100%;
            position: relative;
            background: #fff;
            color: #090a37;
            display: -ms-flexbox;
            display: -webkit-box;
            display: -webkit-flex;
            display: flex;
            -webkit-flex-wrap: wrap;
            flex-wrap: wrap;
            -ms-flex-align: stretch;
            -webkit-box-align: stretch;
            -webkit-align-items: stretch;
            align-items: stretch;
            border-radius: 1em;
            overflow: hidden;
            /* アイテム内レイアウト ------------------------------------------- */ }
            #topsec_grid .top_grid .gridbox ul li a figure {
              width: 100%;
              position: relative;
              overflow: hidden;
              position: relative;
              display: -ms-flexbox;
              display: -webkit-box;
              display: -webkit-flex;
              display: flex;
              -webkit-flex-wrap: wrap;
              flex-wrap: wrap;
              margin-bottom: 0;
              /* サムネイル画像 ------------------------------------------- */
              /* 文字 ------------------------------------------- */ }
              #topsec_grid .top_grid .gridbox ul li a figure .gridimg {
                display: block;
                width: 100%;
                position: relative;
                z-index: 2;
                overflow: hidden; }
                #topsec_grid .top_grid .gridbox ul li a figure .gridimg::before {
                  display: block;
                  content: ""; }
                #topsec_grid .top_grid .gridbox ul li a figure .gridimg .gridimginner {
                  position: absolute;
                  top: 0;
                  left: 0;
                  right: 0;
                  bottom: 0;
                  margin: auto; }
              #topsec_grid .top_grid .gridbox ul li a figure figcaption {
                display: block;
                width: 100%;
                position: relative;
                box-sizing: border-box;
                padding: 1em;
                -webkit-box-flex: 1;
                -webkit-flex: 1;
                -ms-flex: 1;
                flex: 1;
                display: -ms-flexbox;
                display: -webkit-box;
                display: -webkit-flex;
                display: flex;
                -ms-flex-align: center;
                -webkit-box-align: center;
                -webkit-align-items: center;
                align-items: center; }
                #topsec_grid .top_grid .gridbox ul li a figure figcaption div {
                  width: 100%;
                  position: relative;
                  /* 日付 ------------------------------------------- */
                  /* タイトル ------------------------------------------- */ }
                  #topsec_grid .top_grid .gridbox ul li a figure figcaption div .date {
                    font-family: gazzetta-variable, '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'Meiryo UI', 'メイリオ', Meiryo, sans-serif;
                    font-style: normal;
                    font-weight: normal;
                    width: 100%;
                    display: block;
                    font-size: 2em;
                    font-weight: 600;
                    line-height: 1em;
                    color: #009fe8;
                    padding-bottom: 0.2em;
                    -webkit-transition: 0.3s ease;
                    -moz-transition: 0.3s ease;
                    -ms-transition: 0.3s ease;
                    -o-transition: 0.3s ease;
                    transition: 0.3s ease; }
                    #topsec_grid .top_grid .gridbox ul li a figure figcaption div .date .year {
                      display: inline-block;
                      padding-right: 0.5em;
                      font-size: 0.625em;
                      font-weight: 400; }
                  #topsec_grid .top_grid .gridbox ul li a figure figcaption div .gridttl {
                    width: 100%;
                    display: block;
                    line-height: 2em; }
            #topsec_grid .top_grid .gridbox ul li a:hover {
              color: #009fe8;
              text-decoration: none; }
              #topsec_grid .top_grid .gridbox ul li a:hover figure {
                /* サムネイル画像 ------------------------------------------- */
                /* 文字 ------------------------------------------- */ }
                #topsec_grid .top_grid .gridbox ul li a:hover figure .gridimg .gridimginner img {
                  -webkit-transform: scale(1.1);
                  -moz-transform: scale(1.1);
                  -ms-transform: scale(1.1);
                  -o-transform: scale(1.1);
                  transform: scale(1.1);
                  opacity: 1;
                  filter: alpha(opacity=70); }
                #topsec_grid .top_grid .gridbox ul li a:hover figure figcaption div .date {
                  color: #009fe8; }
          #topsec_grid .top_grid .gridbox ul li:nth-child(1) {
            grid-row: 1 / 3;
            grid-column: 1 / 2;
            -ms-grid-row: 1;
            -ms-grid-column: 1;
            -ms-grid-row-span: 2;
            padding-right: 2.08em; }
            #topsec_grid .top_grid .gridbox ul li:nth-child(1) a figure .gridimg::before {
              padding-top: 100%; }
            #topsec_grid .top_grid .gridbox ul li:nth-child(1) a figure figcaption div .gridttl {
              height: 3.5em;
              overflow: hidden;
              text-align: justify; }
              #topsec_grid .top_grid .gridbox ul li:nth-child(1) a figure figcaption div .gridttl::before, #topsec_grid .top_grid .gridbox ul li:nth-child(1) a figure figcaption div .gridttl::after {
                position: absolute;
                background: #fff; }
              #topsec_grid .top_grid .gridbox ul li:nth-child(1) a figure figcaption div .gridttl::before {
                content: "…";
                bottom: 0;
                right: 0;
                color: #090a37; }
              #topsec_grid .top_grid .gridbox ul li:nth-child(1) a figure figcaption div .gridttl::after {
                content: "";
                height: 100%;
                width: 100%; }
              #topsec_grid .top_grid .gridbox ul li:nth-child(1) a figure figcaption div .gridttl::before {
                bottom: -0.5em; }
          #topsec_grid .top_grid .gridbox ul li:nth-child(2) {
            grid-row: 1 / 3;
            grid-column: 2 / 3;
            -ms-grid-row: 1;
            -ms-grid-column: 2;
            -ms-grid-row-span: 2;
            padding-right: 2.08em; }
            #topsec_grid .top_grid .gridbox ul li:nth-child(2) a figure {
              -ms-flex-direction: column-reverse;
              -webkit-box-orient: vertical;
              -webkit-box-direction: reverse;
              -webkit-flex-direction: column-reverse;
              flex-direction: column-reverse;
              -ms-flex-line-pack: justify;
              -webkit-align-content: space-between;
              align-content: space-between; }
              @media screen and (max-width: 480px) {
                #topsec_grid .top_grid .gridbox ul li:nth-child(2) a figure {
                  -ms-flex-direction: column;
                  -webkit-box-direction: column;
                  -webkit-flex-direction: column;
                  flex-direction: column; } }
              #topsec_grid .top_grid .gridbox ul li:nth-child(2) a figure .gridimg::before {
                padding-top: 133.33%; }
              #topsec_grid .top_grid .gridbox ul li:nth-child(2) a figure figcaption {
                overflow: hidden;
                text-align: justify; }
                #topsec_grid .top_grid .gridbox ul li:nth-child(2) a figure figcaption::before, #topsec_grid .top_grid .gridbox ul li:nth-child(2) a figure figcaption::after {
                  position: absolute;
                  background: #fff; }
                #topsec_grid .top_grid .gridbox ul li:nth-child(2) a figure figcaption::before {
                  content: "…";
                  bottom: 0;
                  right: 0;
                  color: #090a37; }
                #topsec_grid .top_grid .gridbox ul li:nth-child(2) a figure figcaption::after {
                  content: "";
                  height: 100%;
                  width: 100%; }
                #topsec_grid .top_grid .gridbox ul li:nth-child(2) a figure figcaption::before {
                  right: 1em;
                  bottom: 2.5em;
                  z-index: 1; }
                #topsec_grid .top_grid .gridbox ul li:nth-child(2) a figure figcaption::after {
                  content: none; }
                #topsec_grid .top_grid .gridbox ul li:nth-child(2) a figure figcaption div::after {
                  position: absolute;
                  background: #fff;
                  content: "";
                  height: 100%;
                  width: 100%;
                  z-index: 1; }
                #topsec_grid .top_grid .gridbox ul li:nth-child(2) a figure figcaption div .gridttl {
                  max-height: 8.5em;
                  overflow: hidden; }
          #topsec_grid .top_grid .gridbox ul li:nth-child(3) {
            grid-row: 1 / 2;
            grid-column: 3 / 5;
            -ms-grid-row: 1;
            -ms-grid-column: 3;
            -ms-grid-column-span: 2;
            padding-bottom: 1.04em; }
            #topsec_grid .top_grid .gridbox ul li:nth-child(3) a figure {
              -ms-flex-pack: justify;
              -webkit-box-pack: justify;
              -webkit-justify-content: space-between;
              justify-content: space-between;
              -ms-flex-align: stretch;
              -webkit-box-align: stretch;
              -webkit-align-items: stretch;
              align-items: stretch; }
              #topsec_grid .top_grid .gridbox ul li:nth-child(3) a figure .gridimg {
                width: 50%; }
              #topsec_grid .top_grid .gridbox ul li:nth-child(3) a figure figcaption {
                width: 50%;
                overflow: hidden;
                text-align: justify; }
                #topsec_grid .top_grid .gridbox ul li:nth-child(3) a figure figcaption::before, #topsec_grid .top_grid .gridbox ul li:nth-child(3) a figure figcaption::after {
                  position: absolute;
                  background: #fff; }
                #topsec_grid .top_grid .gridbox ul li:nth-child(3) a figure figcaption::before {
                  content: "…";
                  bottom: 0;
                  right: 0;
                  color: #090a37; }
                #topsec_grid .top_grid .gridbox ul li:nth-child(3) a figure figcaption::after {
                  content: "";
                  height: 100%;
                  width: 100%; }
                #topsec_grid .top_grid .gridbox ul li:nth-child(3) a figure figcaption::before {
                  right: 1em;
                  bottom: 1.5em;
                  z-index: 1; }
                #topsec_grid .top_grid .gridbox ul li:nth-child(3) a figure figcaption::after {
                  content: none; }
                #topsec_grid .top_grid .gridbox ul li:nth-child(3) a figure figcaption div::after {
                  position: absolute;
                  background: #fff;
                  content: "";
                  height: 100%;
                  width: 100%;
                  z-index: 1; }
                #topsec_grid .top_grid .gridbox ul li:nth-child(3) a figure figcaption div .gridttl {
                  max-height: 16.5em;
                  overflow: hidden; }
          #topsec_grid .top_grid .gridbox ul li:nth-child(4) {
            grid-row: 2 / 3;
            grid-column: 3 / 4;
            -ms-grid-row: 2;
            -ms-grid-column: 3;
            padding-top: 1.04em;
            padding-right: 1.04em; }
            #topsec_grid .top_grid .gridbox ul li:nth-child(4) a figure .gridimg::before {
              padding-top: 100%; }
            #topsec_grid .top_grid .gridbox ul li:nth-child(4) a figure figcaption div .gridttl {
              width: 14em;
              height: 1.5em;
              width: 100%;
              white-space: nowrap;
              overflow: hidden;
              text-overflow: ellipsis;
              -o-text-overflow: ellipsis;
              /* Opera9,10対応 */ }
          #topsec_grid .top_grid .gridbox ul li:nth-child(5) {
            grid-row: 2 / 3;
            grid-column: 4 / 5;
            -ms-grid-row: 2;
            -ms-grid-column: 4;
            padding-top: 1.04em;
            padding-left: 1.04em; }
            #topsec_grid .top_grid .gridbox ul li:nth-child(5) a figure .gridimg::before {
              padding-top: 100%; }
            #topsec_grid .top_grid .gridbox ul li:nth-child(5) a figure figcaption div .gridttl {
              width: 14em;
              height: 1.5em;
              width: 100%;
              white-space: nowrap;
              overflow: hidden;
              text-overflow: ellipsis;
              -o-text-overflow: ellipsis;
              /* Opera9,10対応 */ }
          #topsec_grid .top_grid .gridbox ul li:nth-child(n + 6) {
            display: none; }
          @media screen and (max-width: 750px), screen and (max-height: 450px) {
            #topsec_grid .top_grid .gridbox ul li:nth-child(1) {
              grid-row: 1 / 2;
              grid-column: 1 / 3;
              -ms-grid-row: 1;
              -ms-grid-column: 1;
              -ms-grid-column-span: 2;
              padding-right: 1em;
              padding-bottom: 1em; }
            #topsec_grid .top_grid .gridbox ul li:nth-child(2) {
              grid-row: 1 / 2;
              grid-column: 3 / 6;
              -ms-grid-row: 1;
              -ms-grid-column: 3;
              -ms-grid-column-span: 3;
              padding-right: 0;
              padding-bottom: 1em; }
            #topsec_grid .top_grid .gridbox ul li:nth-child(3) {
              grid-row: 2 / 3;
              grid-column: 1 / 6;
              -ms-grid-row: 2;
              -ms-grid-column: 1;
              -ms-grid-column-span: 4;
              padding-bottom: 1em; }
            #topsec_grid .top_grid .gridbox ul li:nth-child(4) {
              grid-row: 3 / 4;
              grid-column: 1 / 2;
              -ms-grid-row: 3;
              -ms-grid-column: 1;
              padding-top: 0;
              padding-right: 0.5em; }
              #topsec_grid .top_grid .gridbox ul li:nth-child(4) a figure .gridimg::before {
                padding-top: 50%; }
            #topsec_grid .top_grid .gridbox ul li:nth-child(5) {
              grid-row: 3 / 4;
              grid-column: 2 / 6;
              -ms-grid-row: 3;
              -ms-grid-column: 2;
              -ms-grid-column-span: 4;
              padding-top: 0;
              padding-left: 0.5em; }
              #topsec_grid .top_grid .gridbox ul li:nth-child(5) a figure .gridimg::before {
                padding-top: 50%; } }
          @media screen and (max-width: 480px) {
            #topsec_grid .top_grid .gridbox ul li:nth-child(1) {
              grid-row: 1 / 2;
              grid-column: 1 / 3;
              -ms-grid-row: 1;
              -ms-grid-column: 1;
              -ms-grid-column-span: 2;
              padding-right: 0;
              padding-bottom: 1em; }
              #topsec_grid .top_grid .gridbox ul li:nth-child(1) a figure .gridimg::before {
                padding-top: 100%; }
            #topsec_grid .top_grid .gridbox ul li:nth-child(2) {
              grid-row: 2 / 3;
              grid-column: 1 / 3;
              -ms-grid-row: 2;
              -ms-grid-column: 1;
              -ms-grid-column-span: 2;
              padding-right: 0; }
              #topsec_grid .top_grid .gridbox ul li:nth-child(2) a {
                background: transparent; }
                #topsec_grid .top_grid .gridbox ul li:nth-child(2) a figure .gridimg::before {
                  padding-top: 60%; }
                #topsec_grid .top_grid .gridbox ul li:nth-child(2) a figure figcaption {
                  border-bottom-left-radius: 1em;
                  border-bottom-right-radius: 1em;
                  overflow: hidden;
                  background: #fff; }
                  #topsec_grid .top_grid .gridbox ul li:nth-child(2) a figure figcaption::before {
                    bottom: 1.75em; }
                  #topsec_grid .top_grid .gridbox ul li:nth-child(2) a figure figcaption div .gridttl {
                    max-height: 6.5em; }
            #topsec_grid .top_grid .gridbox ul li:nth-child(3) {
              grid-row: 3 / 4;
              grid-column: 1 / 3;
              -ms-grid-row: 3;
              -ms-grid-column: 1;
              -ms-grid-column-span: 2; }
              #topsec_grid .top_grid .gridbox ul li:nth-child(3) a figure figcaption::before {
                bottom: 1.75em; }
            #topsec_grid .top_grid .gridbox ul li:nth-child(4) {
              grid-row: 4 / 5;
              grid-column: 1 / 2;
              -ms-grid-row: 4;
              -ms-grid-column: 1; }
              #topsec_grid .top_grid .gridbox ul li:nth-child(4) a figure .gridimg::before {
                padding-top: 100%; }
            #topsec_grid .top_grid .gridbox ul li:nth-child(5) {
              grid-row: 4 / 5;
              grid-column: 2 / 3;
              -ms-grid-row: 4;
              -ms-grid-column: 2; }
              #topsec_grid .top_grid .gridbox ul li:nth-child(5) a figure .gridimg::before {
                padding-top: 100%; } }

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