@charset "UTF-8";
/* CSS Document */
body {
  background-color: #FFFFFF;
}
header {
  background-color: #fff;
  padding: 30px 50px;
  display: flex;
  justify-content: space-between;
  align-items: center
}
header figure {
  width: 380px;
}
.head-name {
  font-weight: 500;
  font-size: 1.8rem
}
@media screen and (max-width: 743px) {
  header {
    background-color: #fff;
    padding: 15px
  }
  header figure {
    width: 190px;
  }
  .head-name {
    font-weight: 500;
    font-size: 1.0rem;
    line-height: 1.4;
    text-align: right;
  }
}
.f-banner {
  width: 48%
}
@media screen and (max-width: 743px) {
  .f-banner {
    width: 100%;
    margin-bottom: 20px
  }
}
/* ////////////////////////////////// */
/* メインビジュアル */
/* ////////////////////////////////// */
#mv {
  position: relative;
  background: url("../img/fv-bg.jpg") no-repeat center top/cover;
  width: 100%;
  height: 630px;
}
#mv .blk-h1 {
  position: absolute;
  left: 10%;
  top: 50%;
  transform: translateY(-50%);
  padding-bottom: 170px;
}
#mv .blk-h1 span {
  font-size: 2.2rem
}
#mv .logo-mv {
  display: block;
  max-width: 400px;
  margin-bottom: 40px
}
#mv h1 {
  font-size: 5.6rem;
  font-weight: 500
}
#mv h2 {
  font-size: 3.4rem;
  font-weight: 500;
  color: #193472;
  margin-bottom: 25px;
}
#mv .h1sub {
  font-size: 3.0rem;
  font-weight: 500
}
#mv .h2sub {
  font-size: 1.8rem;
  max-width: 560px;
  position: absolute;
  bottom: 105px;
  left: 10%;
}
@media screen and (max-width: 743px) {
  #mv .blk-h1 {
    width: 100%;
    position: static;
    background: url(../img/fv-bg_sp.jpg) no-repeat left bottom / 100%;
    padding: 10% 5% 0;
    transform: unset;
    height: 430px;
  }
  #mv {
    position: relative;
    background: none;
    width: 100%;
    height: auto;
  }
  #mv .logo-mv {
    max-width: 160px;
    margin: 0 auto;
    margin-bottom: 20px
  }
  #mv h1 {
    font-size: 2.0rem;
  }
  #mv h2 {
    font-size: 2.0rem;
    text-align: center;
    white-space: nowrap;
  }
  #mv .h2sub {
    font-size: 1.5rem;
    margin-bottom: 0;
    padding: 30px 5% 60px;
    position: static;
    background-color: #193472;
    color: #FFFFFF;
    max-width: unset;
    line-height: 2.0;
    letter-spacing: 0.2em;
  }
  #mv .h1sub {
    font-size: 1.5rem;
    text-align: center;
    text-shadow: 1px 1px 0 rgba(255, 255, 255, 0.5), -1px -1px 0 rgba(255, 255, 255, 0.5), -1px 1px 0 rgba(255, 255, 255, 0.5), 1px -1px 0 rgba(255, 255, 255, 0.5), 0px 1px 0 rgba(255, 255, 255, 0.5), 0-1px 0 rgba(255, 255, 255, 0.5), -1px 0 0 rgba(255, 255, 255, 0.5), 1px 0 0 rgba(255, 255, 255, 0.5);
  }
  #mv .blk-h1 span {
    font-size: 1.0rem
  }
}
#mv-read {
  padding: 100px 0 160px 0;
  background-color: #193472;
}
@media screen and (max-width: 743px) {
  #mv-read {
    padding: 60px 0 80px 0;
    margin-bottom: 30px;
  }
}
#mv-read .inner {
  margin: 0 auto;
  max-width: 800px;
  width: 90%;
}
#mv-read .blk-h2 {
  margin: 0;
  line-height: 1;
  margin-bottom: 70px;
}
#mv-read .blk-h2 .lato-txt {
  display: block;
  font-size: 6.0rem;
  color: #FFFFFF;
  font-family: "Lato", sans-serif;
  font-weight: 300;
  font-style: italic;
  margin-bottom: 30px;
}
#mv-read .blk-h2 .sub-txt {
  display: block;
  color: #FFFFFF;
  position: relative;
  padding-left: 45px;
}
#mv-read .blk-h2 .sub-txt::before {
  content: "";
  width: 28px;
  height: 1px;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  transform: rotate(180deg);
  background-color: #FFFFFF;
}
#mv-read h3 {
  color: #FFFFFF;
  font-size: 3.0rem;
  text-align: center;
  margin-bottom: 50px;
}
#mv-read h3 span {
  display: block;
  font-size: 2.2rem;
}
#mv-read p {
  color: #FFFFFF;
  max-width: 720px;
  margin: 0 auto 70px;
}
#mv-read .useflow-img {
  text-align: center;
}
#mv-read .useflow-img img {
  width: 100%;
  height: auto;
}
#mv-read dl {
  display: flex;
  width: 100%;
  margin-bottom: 60px;
  flex-wrap: nowrap;
}
#mv-read dt {
  margin-right: 50px;
  font-size: 1.8rem;
  width: 300px;
  display: block
}
#mv-read dt .blkh4 {
  position: relative;
  background-color: #fff;
  color: #193472;
  text-align: center;
  border-radius: 10px;
  font-size: 2.2rem;
  padding: 10px 20px;
}
#mv-read dt .blkh4 .icon {
  position: absolute;
  width: 65px;
  bottom: 0;
  left: -28px
}
#mv-read dd {
  width: calc(100% - 350px);
  color: #fff;
}
@media screen and (max-width: 743px) {
  #mv-read figure {
    margin-bottom: 30px
  }
  .mv-read-txt {
    padding: 0 5%
  }
  #mv-read .blk-h2 {
    text-align: center;
  }
  #mv-read .blk-h2 {
    margin: 0 0 50px 0;
  }
  #mv-read .blk-h2 .lato-txt {
    font-size: 3.5rem;
    margin-bottom: 20px;
  }
  #mv-read .blk-h2 .sub-txt {
    padding: 0 25px;
    font-size: 1.2rem;
    text-align: center;
    display: inline-block;
  }
  #mv-read .blk-h2 .sub-txt::before {
    width: 14px;
  }
  #mv-read .blk-h2 .sub-txt::after {
    content: "";
    width: 14px;
    height: 1px;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    margin: auto;
    transform: rotate(180deg);
    background-color: #FFFFFF;
  }

  #mv-read p {
    margin-bottom: 50px;
  }
  #mv-read h3 {
    font-size: 2.0rem;
    margin-bottom: 40px;
  }
  #mv-read h3 span {
    font-size: 1.4rem;
  }
  #mv-read dl {
    display: flex;
    width: 94%;
    margin: 0 auto 60px auto;
    flex-wrap: wrap;
  }
  #mv-read dt {
    width: 100%;
    margin-right: 0
  }
  #mv-read dd {
    width: 100%;
    font-size: 1.3rem;
    letter-spacing: 0.14em;
    text-align: justify;
  }
  #mv-read dt .blkh4 {
    border-radius: 5px;
    font-size: 1.3rem;
    padding: 7px 0;
    display: block;
    text-align: center;
    margin-bottom: 15px;
    margin-left: 15px
  }
  #mv-read dt .blkh4 .icon {
    width: 50px;
    left: -20px
  }
}
/* ////////////////////////////////// */
/* パンフレットバナー */
/* ////////////////////////////////// */
.side-bnr {
  position: fixed;
  right: 0;
  bottom: 10%;
  width: 290px;
  height: 100px;
  background-color: #e2850c;
  border: 2px solid #FFFFFF;
  border-right: none;
  border-radius: 100vh 0 0 100vh;
  box-shadow: 3px 3px 15px 0px #5f5f5f80;
  z-index: 999;
}
.side-bnr a {
  text-decoration: none;
  width: 100%;
  height: 100%;
  padding: 10px 0 10px 40px;
  display: flex;
  align-items: center;
  justify-content: left;
}
.side-bnr a:before {
  content: "";
  display: inline-block;
  background-image: url("../img/icon_pamphlet.svg");
  background-repeat: no-repeat;
  background-size: contain;
  width: 55px;
  height: 39px;
  margin-right: 24px;
}
.side-bnr a span {
  color: #FFFFFF;
  line-height: 1.5;
  font-size: 2.0rem;
}
@media screen and (max-width: 743px) {
  .side-bnr {
    width: 13.5em;
    height: auto;
    bottom: 3%;
  }
  .side-bnr a {
    padding: 0.5em 0 0.5em 2em
  }
  .side-bnr a span {
    font-size: 1.2rem;
  }
  .side-bnr a:before {
    content: "";
    width: 3.0em;
    height: 2.0em;
    margin-right: 0.5em;
  }
}

/* ////////////////////////////////// */
/* SA-N-POについて */
/* ////////////////////////////////// */
#about {
  position: relative;
  max-width: 800px;
  width: 90%;
  margin: 140px auto 60px;
}
#about .blk-h2 {
  margin: 0;
  line-height: 1;
  margin-bottom: 40px;
}
#about .blk-h2 .lato-txt {
  display: block;
  font-size: 6.0rem;
  color: #0063a6;
  font-family: "Lato", sans-serif;
  font-weight: 300;
  font-style: italic;
  margin-bottom: 30px;
}
#about .blk-h2 .sub-txt {
  display: block;
  color: #0063a6;
  position: relative;
  padding-left: 45px;
}
#about .blk-h2 .sub-txt::before {
  content: "";
  width: 28px;
  height: 1px;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  transform: rotate(180deg);
  background-color: #000000;
}
#about .table dl {
  display: flex;
  justify-content: space-between;
  border-top: 1px solid #e6e6e6;
}
#about .table dl:last-child {
  border-bottom: 1px solid #e6e6e6;
}
#about .table dt {
  background-color: #015994;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  color: #FFFFFF;
  font-size: 1.8rem;
  width: 200px;
  margin: 10px 0;
  border-radius: 3px;
  text-align: center;
}
#about .table dt span {
  display: block;
  font-size: 1.2rem;
  margin-top: 10px;
}
#about .table dd {
  width: calc(100% - 230px);
}
#about .table dd ul {
  max-width: 530px;
}
#about .table dd li {
  font-size: 1.6rem;
  border-bottom: 1px dashed #e6e6e6;
  padding: 20px 0 20px 1em;
  line-height: 2;
}
#about .table dd li span {
  font-size: 1.4rem;
}
#about .table dd li:last-child {
  border-bottom: none;
}
#about .table dd li::before {
  content: "";
  display: inline-block;
  margin-left: -1em;
  background-image: url("../img/icon-maru.svg");
  background-repeat: no-repeat;
  width: 8px;
  height: 8px;
  vertical-align: middle;
  margin-right: 1rem;
}
#about .table dl:nth-child(2) dd li {
  line-height: 1.5;
}
#about .table dl:nth-child(2) dd li span {
  letter-spacing: 0.18rem;
}
#about .table dl:last-child dd {
  padding: 20px 0;
}
#about .table dl:last-child dd li {
  border-bottom: none;
  padding: 0 0 0 1em;
}
#about article {
  margin-bottom: 120px;
  margin-right: 100px
}
#about article h3 {
  position: relative;
  font-size: 3rem;
  margin-bottom: 40px;
  margin-left: 100px;
  color: #0063a6;
}
#about article h3::before {
  content: "";
  position: absolute;
  top: 50%;
  left: -100px;
  transform: translateY(-50%);
  width: 55px;
  height: 1px;
  background-color: #000000
}
#about article .article-txt,
#about article .list-txt {
  margin-left: 100px;
}
#about article .article-txt {
  margin-bottom: 30px;
  line-height: 2.2;
  text-align: justify;
}
#about article .list-txt {
  margin-bottom: 7px;
  letter-spacing: 0.1em;
  display: flex;
}
#about article .list-txt li:first-child {
  margin-right: 20px;
  margin-bottom: 5px;
}

#about article .list-txt li:first-child span {
  background-color: #e6e6e6;
  font-size: 1.3rem;
  border-radius: 3px;
  display: inline-block;
  padding: 8px 15px;
  line-height: 1;
}

@media screen and (max-width: 743px) {
  #about {
    margin: 70px auto 90px;
  }
  #about .blk-h2 {
    margin: 0 0 60px 0;
    text-align: center;
  }
  #about .blk-h2 .lato-txt {
    font-size: 3.5rem;
    margin-bottom: 20px;
  }
  #about .blk-h2 .sub-txt {
    padding: 0 25px;
    font-size: 1.2rem;
    display: inline-block;
  }
  #about .blk-h2 .sub-txt::before {
    width: 14px;
  }
  #about .blk-h2 .sub-txt::after {
    content: "";
    width: 14px;
    height: 1px;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    margin: auto;
    transform: rotate(180deg);
    background-color: #000000;
  }
  #about .table dl {
    flex-wrap: wrap;
    padding-top: 20px;
  }
  #about .table dt {
    width: 100%;
    min-height: 3.5em;
    padding: 0.5em 0;
    margin: 0 0;
    font-size: 1.6rem;
  }
  #about .table dt span {
    font-size: 1.0rem;
  }
  #about .table dd {
    width: 100%;
  }
  #about .table dd li {
    font-size: 1.4rem;
  }
  #about .table dd li span {
    font-size: 1.2rem;
  }
  #about .table dl:nth-child(2) dd li {
    line-height: 1.8;
  }
  #about article {
    margin-bottom: 60px;
    margin-right: 10%
  }
  #about article h3 {
    font-size: 1.7rem;
    margin-bottom: 20px;
    margin-left: 10%;
  }
  #about article h3::before {
    content: "";
    position: absolute;
    top: 50%;
    left: -11%;
    transform: translateY(-50%);
    width: 5%;
    height: 1px;
    background-color: #000000
  }
  #about article .article-txt,
  #about article .list-txt {
    margin-left: 10%;
  }
  #about article .article-txt {
    font-size: 1.3rem;
    margin-bottom: 20px;
    line-height: 2.2;
    letter-spacing: 0.18em;
    text-align: justify;
  }

  #about article .list-txt {
    margin-bottom: 7px;
    font-size: 1.3rem;
  }
  #about article .list-txt li:first-child {
    width: 55px;
    margin-right: 10px;
  }
  #about article .list-txt li:nth-child(2) {
    width: calc(100% - 65px);
    line-height: 1.5
  }
  #about article .list-txt li:first-child span {
    background-color: #e6e6e6;
    font-size: 1.0rem;
    border-radius: 3px;
    display: inline-block;
    padding: 5px 10px;
    line-height: 1;
  }
}


/* ////////////////////////////////// */
/* アクセス */
/* ////////////////////////////////// */

#access {
  padding-bottom: 200px
}
#access .section-mv {
  position: relative;
  background: url("../img_kogo/access-01.jpg") no-repeat top center/cover;
  width: 100%;
  height: 350px;
  margin-bottom: 50px;
}
@media screen and (max-width: 743px) {
  #access .section-mv {
    background: url("../img_kogo/access-01sp.jpg") no-repeat center/cover;
    height: 250px;
    margin-bottom: 50px;
  }
}

#access .inner {
  max-width: 1200px;
  width: 90%;
  margin: 0 auto;
}
#access .blk-map-txt {
  text-align: center;
  margin-bottom: 40px;
}
#access .blk-map-txt figure {
  max-width: 320px;
  margin: 0 auto 40px auto;
}
@media screen and (max-width: 743px) {
  #access {
    padding-bottom: 100px
  }
  #access .blk-map-txt figure {
    max-width: 200px;
    margin: 0 auto 20px auto;
  }
  #access .blk-map-txt {
    margin-bottom: 50px;
  }
}

#access .banner {
  text-align: center;
}
#access .blk-ggmap {
  position: relative;
}

#access .blk-ggmap .gg-deco {
  position: absolute;
  width: 160px;
  top: -30px;
  right: 30px;
  z-index: 20
}
@media screen and (max-width: 743px) {
  #access .blk-ggmap .gg-deco {
    position: absolute;
    width: 80px;
    top: -20px;
    right: 10px;
    z-index: 20
  }
}

.tel-access {
  margin-top: 10px;
  font-size: 2.8rem;
  font-weight: 500;
  line-height: 1.5
}

.tel-access span {
  font-size: 1.4rem;
}


/* ////////////////////////////////// */
#youtube {
  margin-bottom: 160px
}
#youtube .inner {
  margin: 0 auto;
  max-width: 960px;
  width: 90%;
}
.blk-youtube {
  display: block;
  margin: 0 auto;
  margin-bottom: 100px;
  max-width: 960px;
  width: 90%;
}
.youtube {
  position: relative;
  width: 70%;
  aspect-ratio: 16 / 9;
  margin: 0 auto;
}
.youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}
.youtube-txt {
  font-size: 20px;
  text-align: center;
  margin: 15px 0 15px 0
}
@media screen and (max-width: 743px) {
  #youtube {
    margin-bottom: 120px
  }
  .blk-youtube {
    margin-bottom: 60px;
  }
  .youtube-txt {
    font-size: 12px;
    margin: 10px 0 10px 0
  }
  .youtube {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    margin: 0 auto;
  }
}
#marimo .bt-marimo a {
  display: block;
  color: #00307c;
  max-width: 400px;
  width: 90%;
  font-size: 2.3rem;
  background-color: #fff;
  border-radius: 40px;
  text-align: center;
  padding: 20px 0;
  line-height: 1;
  font-weight: 600;
  position: relative;
  bottom: -32px;
  background-image: url("../img/arrow01.png");
  background-repeat: no-repeat;
  background-position: left 30px center;
  background-size: 42px;
  margin-bottom: 20px
}
#marimo .bt-jigyo a {
  display: block;
  color: #fff;
  max-width: 400px;
  width: 90%;
  font-size: 1.7rem;
  text-align: left;
  padding: 2px 0 0 105px;
  line-height: 1;
  font-weight: 400;
  position: relative;
  bottom: -32px;
  margin-top: 15px;
  background-image: url("../img/arrow03.png");
  background-repeat: no-repeat;
  background-position: left 60px top;
  background-size: 25px;
  height: 28px;
}
@media screen and (max-width: 743px) {
  #marimo .bt-marimo a {
    display: block;
    color: #00307c;
    max-width: 250px;
    width: 90%;
    font-size: 1.4rem;
    background-color: #fff;
    margin: 0 auto;
    text-align: center;
    padding: 15px 0;
    line-height: 1;
    font-weight: 600;
    position: relative;
    bottom: -32px;
    background-image: url("../img/arrow01.png");
    background-repeat: no-repeat;
    background-position: left 25px center;
    background-size: 20px;
  }
  #marimo .bt-jigyo a {
    display: block;
    color: #fff;
    max-width: 400px;
    width: 90%;
    font-size: 1.4rem;
    text-align: left;
    padding: 0 0 0 95px;
    line-height: 1;
    font-weight: 400;
    position: relative;
    bottom: -32px;
    background-image: url("../img/arrow03.png");
    background-repeat: no-repeat;
    background-position: left 60px top;
    background-size: 18px;
    height: 18px;
  }
}
#marimo .section-mv {
  position: relative;
  background: linear-gradient(90deg, #0080cc, #00307c);
  padding: 0 0 140px 0
}
#marimo .section-mv .bg-japan {
  position: absolute;
  top: 0;
  left: 0;
  background-image: url("../img/foooter-01.png");
  background-repeat: no-repeat;
  background-position: top -30px right 20px;
  width: 100%;
  height: 100%;
  z-index: 1;
}
@media screen and (max-width: 743px) {
  #marimo .section-mv {
    padding: 0 0 100px 0
  }
  #marimo .section-mv .bg-japan {
    position: absolute;
    top: 0;
    left: 0;
    background-image: url("../img/foooter-01.png");
    background-repeat: no-repeat;
    background-position: top -30px right 20px;
    background-size: 500px;
    width: 100%;
    height: 100%;
    z-index: 1;
  }
}
#marimo .ttl-marimo {
  position: relative;
  max-width: 620px;
  padding: 30px 40px 30px 80px;
  background-color: #FFFFFF;
  top: -80px;
  z-index: 3;
}
@media screen and (max-width: 743px) {
  #marimo .ttl-marimo {
    position: relative;
    max-width: 80%;
    padding: 15px 30px 15px 30px;
    background-color: #FFFFFF;
    top: -30px;
    z-index: 3;
  }
}
#marimo .section-mv article {
  position: relative;
  color: #fff;
  max-width: 1200px;
  width: 90%;
  margin: 0 auto;
  z-index: 2
}
#marimo .section-mv article h3 {
  font-size: 2.6rem;
  margin-bottom: 30px;
  position: relative;
}
#marimo .section-mv article h3::before {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: -6%;
  width: 4%;
  height: 1px;
  background-color: #ffffff;
}
#marimo .section-mv article .h3read {
  font-size: 2.8rem
}
@media screen and (max-width: 743px) {
  #marimo .section-mv article {
    padding-top: 10px;
    position: relative;
    color: #fff;
    max-width: 1200px;
    width: 80%;
    margin: 0 auto;
    z-index: 2
  }
  #marimo .section-mv article h3 {
    font-size: 1.3rem;
    margin-bottom: 15px;
  }
  #marimo .section-mv article h3::before {
    content: "";
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: -13%;
    width: 8%;
    height: 1px;
    background-color: #ffffff;
  }
  #marimo .section-mv article .h3read {
    font-size: 1.5rem;
    line-height: 1.8
  }
}
#marimo .group-marimo01,
#marimo .group-marimo02 {
  max-width: 1200px;
  width: 90%;
  margin: 0 auto;
}
#marimo .group-marimo01 {
  position: relative;
  top: -40px;
  z-index: 2;
  margin-bottom: 60px;
}
@media screen and (max-width: 743px) {
  #marimo .group-marimo01 {
    top: -30px;
    margin-bottom: 20px;
  }
}
#marimo .group-marimo01 article {
  background-color: rgba(0, 48, 124, 0.70);
  padding: 10px 15px;
  line-height: 1.5;
  color: #fff;
  position: absolute;
  width: 100%;
  bottom: 0;
}
#marimo .group-marimo01 article h5 {
  font-size: 1.6rem;
}
#marimo .group-marimo01 article .h5sub {
  font-size: 1.3rem;
}
@media screen and (max-width: 743px) {
  #marimo .group-marimo01 article h5 {
    font-size: 1.3rem;
  }
  #marimo .group-marimo01 article .h5sub {
    font-size: 1.1rem;
  }
}
#marimo .group-marimo01 h4 {
  background-color: #00307c;
  padding: 30px 40px;
  color: #fff;
  font-size: 2.4rem;
  margin-bottom: 50px
}
#marimo .group-marimo01 .f-w-g01 {
  width: 31%;
  position: relative
}
@media screen and (max-width: 743px) {
  #marimo .group-marimo01 h4 {
    padding: 10px 25px;
    font-size: 1.5rem;
    margin-bottom: 20px
  }
  #marimo .group-marimo01 .f-w-g01 {
    width: 100%;
    margin-bottom: 10px
  }
}
#marimo .group-marimo02 {
  padding: 0 0 100px 0
}
#marimo .group-marimo02 .f-w-g02 {
  width: 23%;
  margin-bottom: 40px
}
@media screen and (max-width: 743px) {
  #marimo .group-marimo02 {
    padding: 0 0 50px 0
  }
  #marimo .group-marimo02 .f-w-g02 {
    width: 47%;
    margin-bottom: 20px
  }
}
#marimo .group-marimo02 h4 {
  font-size: 2.4rem;
  color: #00307c;
  margin-bottom: 50px
}
#marimo .group-marimo02 h5 {
  font-size: 1.8rem;
  margin-top: 10px
}
#marimo .group-marimo02 .h5sub {
  font-size: 1.4rem;
}
@media screen and (max-width: 743px) {
  #marimo .group-marimo02 h4 {
    font-size: 1.5rem;
    margin-bottom: 30px
  }
  #marimo .group-marimo02 h5 {
    font-size: 1.2rem;
    line-height: 1.4
  }
  #marimo .group-marimo02 .h5sub {
    font-size: 1.0rem;
  }
}
footer {
  background-color: #fff;
  padding: 50px 0;
}
footer .inner {
  max-width: 1200px;
  width: 90%;
  margin: 0 auto;
  font-size: 1.0rem
}
@media screen and (max-width: 743px) {
  footer {
    background-color: #fff;
    padding: 25px 0;
  }
  footer .f-w-f {
    width: 100%;
    text-align: center;
    margin-bottom: 3px
  }
}
#privacy {
  max-width: 1200px;
  width: 90%;
  margin: 0 auto;
  padding: 100px 0 200px 0;
}
@media screen and (max-width: 743px) {
  #privacy {
    max-width: 1200px;
    width: 90%;
    margin: 0 auto;
    padding: 40px 0 70px 0;
  }
}
#privacy h2.ttl-privacy {
  font-size: 3.4rem;
  font-weight: 500;
  margin-bottom: 30px;
}
#privacy .blk-h2 {
  margin-bottom: 50px
}
#privacy article {
  background-color: #fff;
  padding: 80px 70px;
  margin-bottom: 30px;
}
@media screen and (max-width: 743px) {
  #privacy h2.ttl-privacy {
    font-size: 1.9rem;
    font-weight: 500;
    margin-bottom: 10px;
  }
  #privacy .blk-h2 {
    margin-bottom: 50px
  }
  #privacy article {
    padding: 30px 20px;
    margin: 0 -5%;
    margin-bottom: 20px;
  }
}
#privacy article .blk-indent {
  padding-left: 30px;
}
@media screen and (max-width: 743px) {
  #privacy article .blk-indent {
    padding-left: 25px;
  }
}
#privacy article h3.ttl-privacy {
  font-size: 2.2rem;
  font-weight: 500;
  margin-bottom: 20px;
  color: #0063a6;
}
@media screen and (max-width: 743px) {
  #privacy article h3.ttl-privacy {
    font-size: 1.7rem;
    line-height: 1.6
  }
}
#privacy article dl {
  margin-bottom: 50px
}
#privacy article dl dt {
  padding: 15px 25px;
  margin-bottom: 15px;
  font-size: 1.6rem;
  font-weight: 500;
  background-color: #0063a6;
  color: #fff;
}
#privacy article dl dd {
  padding-left: 25px
}
@media screen and (max-width: 743px) {
  #privacy article dl {
    margin-bottom: 30px
  }
  #privacy article dl dt {
    padding: 10px 15px;
    margin-bottom: 10px;
    font-size: 1.4rem;
    line-height: 1.5;
  }
  #privacy article dl dd {
    padding-left: 5px
  }
}
#privacy article dl dd ul li {
  padding-left: 1em;
  text-indent: -1em;
  margin-bottom: 5px
}
#privacy article dl dd ul.num-list li {
  padding-left: 1.9em;
  text-indent: -1.9em;
}
#privacy .num-list-sin {
  padding-left: 1.9em;
  text-indent: -1.9em;
}
#privacy .frame-privacy {
  border: 1px solid #eee;
  padding: 20px;
}
@media screen and (max-width: 743px) {
  #privacy .frame-privacy {
    padding: 15px;
  }
}
#privacy article dl dd .note {
  font-size: 1.4rem;
  margin-bottom: 40px
}
@media screen and (max-width: 743px) {
  #privacy article dl dd .note {
    font-size: 1.2rem;
    margin-bottom: 20px
  }
}
#privacy article dl dd .note a {
  text-decoration: underline;
}
.btn-privacy {
  display: inline-block;
  line-height: 1;
  padding: 10px 30px;
  font-size: 1.5rem;
  border-radius: 20px;
  margin-bottom: 20px;
  background: url("../img/arrow02.png") #f2f2f2 no-repeat left 15px center/5px 7px;
}
@media screen and (max-width: 743px) {
  .btn-privacy {
    font-size: 1.3rem;
  }
}
@media screen and (max-width: 400px) {
  .wide-img {
    display: block !important;
    max-width: 330px;
    width: 100%;
    margin: 0 auto;
    padding: 0 !important
  }
}
.bnr_marimo {
  margin-top: 80px;
  max-width: 350px;
  margin-left: 25px;
  box-shadow: 0 2px 3px #00307c;
}
@media screen and (max-width: 743px) {
  .bnr_marimo {
    max-width: 245px;
    width: 100%;
    margin: 0 auto;
    margin-top: 70px;
  }
}
.rec-banner {
  max-width: 700px;
  margin: 0 auto
}
.mv-portal {
  background-image: url("../../../img/mv-pratal.jpg");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center top;
  height: 850px;
  width: 100%;
  position: relative;
}
@media screen and (max-width: 743px) {
  .mv-portal {
    background-image: url("../../../img/mv-pratal_sp.jpg");
    height: 620px;
    background-position: center top;
  }
}
.blk-h1-portal {
  width: 90%;
  margin: 0 auto;
  padding: 100px 0;
  text-align: center;
}
.blk-h1-portal .portal-ttl {
  font-size: 4.8rem;
  font-weight: 500;
  line-height: 1;
  margin-bottom: 40px
}
.blk-h1-portal .portal-read {
  font-size: 2.3rem;
  line-height: 2.3;
  letter-spacing: 0.18em
}
@media screen and (max-width: 743px) {
  .blk-h1-portal {
    padding: 50px 0;
  }
  .blk-h1-portal .portal-ttl {
    font-size: 3.0rem;
    margin-bottom: 25px
  }
  .blk-h1-portal .portal-read {
    font-size: 1.3rem;
    line-height: 2.0;
    letter-spacing: 0.08em
  }
}
.inner-portal02 {
  max-width: 860px;
  width: 90%;
  margin: 0 auto;
}
.inner-portal {
  max-width: 860px;
  width: 90%;
  margin: 0 auto;
  position: absolute;
  bottom: 120px;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (max-width: 743px) {
  .inner-portal {
    bottom: 40px;
  }
}
.logo-portal {
  font-size: 5rem;
  text-align: center;
  padding-top: 90px;
  max-width: 530px;
  margin: 0 auto;
  filter: drop-shadow(0 0 5px #113005);
}
.logo-portal02 {
  font-size: 5rem;
  text-align: center;
  padding-top: 90px;
  max-width: 380px;
  margin: 0 auto;
  filter: drop-shadow(0 0 5px #113005);
}
@media screen and (max-width: 743px) {
  .logo-portal {
    padding-top: 40px;
    font-size: 2.9rem;
    width: 90%;
    line-height: 1.3;
    margin: 0 auto;
  }
  .logo-portal02 {
    padding-top: 40px;
    font-size: 2.9rem;
    width: 68%;
    line-height: 1.3;
    margin: 0 auto;
  }
}
.f-w-portal {
  font-weight: 500;
  font-size: 2.0rem;
  color: #fff;
  text-align: center;
  margin: 0 0 20px 0;
  width: 48%;
}
.f-w-portal:last-child {
  margin: 0;
}
.f-w-portal span {
  font-size: 1.6rem;
}
.f-w-portal span.saiki {
  display: inline-block;
  margin-bottom: 2px;
}
.f-w-portal .btn-portal a {
  display: inline-block;
  background-color: #004ea2;
  width: 100%;
  padding: 8px 20px 10px 20px;
  line-height: 1.2;
  border-radius: 80px;
  border: 2px solid #ffffff;
  box-shadow: 0 3px 2px 0 rgba(0, 0, 0, .25);
}
@media screen and (max-width: 743px) {
  .f-w-portal {
    font-size: 1.5rem;
    margin: 0 auto 15px auto;
    max-width: 300px;
    width: 100%;
  }
  .f-w-portal:last-child {
    margin: 0 auto 0 auto;
  }
  .f-w-portal .btn-portal a {
    padding: 5px 15px 8px 15px;
    line-height: 1.2;
  }
  .f-w-portal span {
    font-size: 1.1rem;
  }
}