body {
  font-size: 16px;
  text-align: left;
  box-sizing: border-box; }
  body #contents #main #mainView {
    width: 100%;
    height: auto;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    position: relative;
    display: flex;
    flex-wrap: wrap;
    align-items: center; }
    body #contents #main #mainView .mainView-caption {
      position: absolute;
      right: 2%;
      bottom: 2%;
      color: #fff;
      font-size: 10px;
      letter-spacing: .03em; }
  body #contents #main h2, body #contents #main h3 {
    display: block;
    width: 100%;
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain; }
    body #contents #main h2 span, body #contents #main h3 span {
      display: none; }
  body #contents #main p.center {
    text-align: center; }
  body #contents #main p.color-blue {
    color: #555f7c !important; }
  body #contents #main p.main-lead-txt {
    font-size: 33px;
    line-height: 58px;
    letter-spacing: 0.125em; }
  body #contents #main p.main-lead-sub-txt {
    font-size: 24px;
    line-height: 51px;
    letter-spacing: 0.08em; }
  body #contents #main p.content-lead-txt {
    font-size: 24px;
    line-height: 36px;
    letter-spacing: 0.1em;
    margin-bottom: 70px; }
  body #contents #main p.content-sub-txt {
    font-size: 20px;
    line-height: 32px;
    letter-spacing: 0.1em;
    margin-bottom: 30px; }
  body #contents #main p.content-caption {
    font-size: 12px;
    line-height: 16px;
    letter-spacing: 0; }
  body #contents #main p.list-ttl {
    font-size: 18px;
    line-height: 30px;
    letter-spacing: 0.025em; }
    body #contents #main p.list-ttl > span {
      font-size: .8em;
      letter-spacing: 0.025em; }
  body #contents #main p.list-txt {
    font-size: 16px;
    line-height: 28px;
    letter-spacing: 0.05em; }
    body #contents #main p.list-txt > span {
      font-size: .8em;
      letter-spacing: 0.025em; }
    body #contents #main p.list-txt > sup {
      font-size: 12px;
      line-height: 16px;
      letter-spacing: 0; }
  body #contents #main article.bg-white, body #contents #main section.bg-white {
    background-color: #fff;
    background-image: url(../img/bg/bg-img-white.jpg);
    background-position: top;
    background-size: cover;
    background-attachment: fixed; }
    body #contents #main article.bg-white p, body #contents #main article.bg-white li, body #contents #main article.bg-white span, body #contents #main section.bg-white p, body #contents #main section.bg-white li, body #contents #main section.bg-white span {
      color: #040000; }
    body #contents #main article.bg-white_color, body #contents #main section.bg-white_color {
      background-color: #fff; }
      body #contents #main article.bg-white_color p, body #contents #main article.bg-white_color li, body #contents #main article.bg-white_color span, body #contents #main section.bg-white_color p, body #contents #main section.bg-white_color li, body #contents #main section.bg-white_color span {
        color: #040000; }
  body #contents #main article.bg-navy, body #contents #main section.bg-navy {
    background-color: #2b3e5c;
    background-image: url(../img/bg/bg-img-navy.jpg);
    background-position: top;
    background-size: cover; }
    body #contents #main article.bg-navy p, body #contents #main article.bg-navy li, body #contents #main article.bg-navy span, body #contents #main section.bg-navy p, body #contents #main section.bg-navy li, body #contents #main section.bg-navy span {
      color: #fff; }
    body #contents #main article.bg-navy_color, body #contents #main section.bg-navy_color {
      position: relative;
      width: 100%; }
      body #contents #main article.bg-navy_color:after, body #contents #main section.bg-navy_color:after {
        background-color: #2b3e5c;
        mix-blend-mode: multiply;
        content: '';
        display: block;
        width: 100%;
        height: 100%;
        position: absolute;
        left: 0;
        top: 0;
        z-index: 1; }
      body #contents #main article.bg-navy_color .content-detail, body #contents #main section.bg-navy_color .content-detail {
        position: relative;
        z-index: 99; }
      body #contents #main article.bg-navy_color p, body #contents #main article.bg-navy_color li, body #contents #main article.bg-navy_color span, body #contents #main section.bg-navy_color p, body #contents #main section.bg-navy_color li, body #contents #main section.bg-navy_color span {
        color: #fff; }
  body #contents #main article.bg-blue_color, body #contents #main section.bg-blue_color {
    position: relative;
    width: 100%; }
    body #contents #main article.bg-blue_color:after, body #contents #main section.bg-blue_color:after {
      background-color: #bccfd7;
      mix-blend-mode: multiply;
      content: '';
      display: block;
      width: 100%;
      height: 100%;
      position: absolute;
      left: 0;
      top: 0;
      z-index: 1; }
    body #contents #main article.bg-blue_color .content-detail, body #contents #main section.bg-blue_color .content-detail {
      position: relative;
      z-index: 99; }
    body #contents #main article.bg-blue_color p, body #contents #main article.bg-blue_color li, body #contents #main article.bg-blue_color span, body #contents #main section.bg-blue_color p, body #contents #main section.bg-blue_color li, body #contents #main section.bg-blue_color span {
      color: #231815; }
  body #contents #main article .content-detail, body #contents #main section .content-detail {
    width: 100%;
    margin: 0 auto; }
  body #contents #main article .flex2, body #contents #main article .flex3, body #contents #main section .flex2, body #contents #main section .flex3 {
    display: flex;
    flex-wrap: wrap;
    justify-content: center; }
    body #contents #main article .flex2 > div, body #contents #main article .flex2 > figure, body #contents #main article .flex2 > a, body #contents #main article .flex3 > div, body #contents #main article .flex3 > figure, body #contents #main article .flex3 > a, body #contents #main section .flex2 > div, body #contents #main section .flex2 > figure, body #contents #main section .flex2 > a, body #contents #main section .flex3 > div, body #contents #main section .flex3 > figure, body #contents #main section .flex3 > a {
      display: block; }
  body #contents #main article .grid2, body #contents #main article .grid4, body #contents #main article .grid3, body #contents #main article .grid3to2, body #contents #main article .grid3to1, body #contents #main article .grid6, body #contents #main section .grid2, body #contents #main section .grid4, body #contents #main section .grid3, body #contents #main section .grid3to2, body #contents #main section .grid3to1, body #contents #main section .grid6 {
    display: grid;
    gap: 40px; }
    body #contents #main article .grid2.nogap, body #contents #main article .grid4.nogap, body #contents #main article .grid3.nogap, body #contents #main article .grid3to2.nogap, body #contents #main article .grid3to1.nogap, body #contents #main article .grid6.nogap, body #contents #main section .grid2.nogap, body #contents #main section .grid4.nogap, body #contents #main section .grid3.nogap, body #contents #main section .grid3to2.nogap, body #contents #main section .grid3to1.nogap, body #contents #main section .grid6.nogap {
      gap: 0; }

/*PC ONLY*/
@media screen and (min-width: 751px) {
  body #contents #main article .content-detail, body #contents #main section .content-detail {
    max-width: 1000px;
    padding: 60px 0 120px; }
  body #contents #main article .flex2, body #contents #main section .flex2 {
    gap: 40px 48px; }
    body #contents #main article .flex2 > div, body #contents #main article .flex2 > figure, body #contents #main article .flex2 > a, body #contents #main section .flex2 > div, body #contents #main section .flex2 > figure, body #contents #main section .flex2 > a {
      width: calc(50% - 24px); }
  body #contents #main article .flex3, body #contents #main section .flex3 {
    gap: 40px 40px; }
    body #contents #main article .flex3 > div, body #contents #main article .flex3 > figure, body #contents #main article .flex3 > a, body #contents #main section .flex3 > div, body #contents #main section .flex3 > figure, body #contents #main section .flex3 > a {
      width: calc((100% - 80px) / 3); }
  body #contents #main article .grid2, body #contents #main section .grid2 {
    grid-template-columns: 1fr 1fr; }
  body #contents #main article .grid3, body #contents #main article .grid3to2, body #contents #main article .grid3to1, body #contents #main section .grid3, body #contents #main section .grid3to2, body #contents #main section .grid3to1 {
    grid-template-columns: 1fr 1fr 1fr; }
  body #contents #main article .grid4, body #contents #main section .grid4 {
    grid-template-columns: 1fr 1fr 1fr 1fr; }
  body #contents #main article .grid6, body #contents #main section .grid6 {
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr;
    gap: 17px; } }
/*SP ONLY*/
@media screen and (max-width: 750px) {
  body {
    font-size: 20px; }
    body #contents #main #mainView .mainView-caption {
      font-size: .8em; }
    body #contents #main p.main-lead-txt {
      font-size: 2em;
      line-height: 1.75em; }
    body #contents #main p.main-lead-sub-txt {
      padding-top: 30px;
      font-size: 1.75em;
      line-height: 1.75em; }
    body #contents #main p.content-lead-txt {
      font-size: 1.6em;
      line-height: 1.75em;
      margin-bottom: 40px; }
    body #contents #main p.content-sub-txt {
      font-size: 1.2em;
      line-height: 1.75em; }
    body #contents #main p.content-caption {
      font-size: 1em;
      line-height: 1.34em; }
    body #contents #main p.list-ttl {
      font-size: 1.5em;
      line-height: 1.75em; }
    body #contents #main p.list-txt {
      font-size: 1.2em;
      line-height: 1.75em; }
      body #contents #main p.list-txt > sup {
        font-size: 0.8em;
        line-height: 1.34em; }
    body #contents #main article .content-detail, body #contents #main section .content-detail {
      max-width: 98%;
      padding: 30px 0 60px; }
    body #contents #main article .flex2, body #contents #main section .flex2 {
      gap: 40px 0; }
      body #contents #main article .flex2 > div, body #contents #main article .flex2 > figure, body #contents #main article .flex2 > a, body #contents #main section .flex2 > div, body #contents #main section .flex2 > figure, body #contents #main section .flex2 > a {
        width: 80%; }
    body #contents #main article .flex3, body #contents #main section .flex3 {
      gap: 40px 40px; }
      body #contents #main article .flex3 > div, body #contents #main article .flex3 > figure, body #contents #main article .flex3 > a, body #contents #main section .flex3 > div, body #contents #main section .flex3 > figure, body #contents #main section .flex3 > a {
        width: calc(50% - 20px); }
    body #contents #main article .grid2, body #contents #main section .grid2 {
      grid-template-columns: 1fr; }
      body #contents #main article .grid2 > div, body #contents #main article .grid2 > figure, body #contents #main article .grid2 > a, body #contents #main section .grid2 > div, body #contents #main section .grid2 > figure, body #contents #main section .grid2 > a {
        width: 80%;
        margin: 0 auto; }
    body #contents #main article .grid3, body #contents #main section .grid3 {
      grid-template-columns: 1fr 1fr 1fr; }
    body #contents #main article .grid3to2, body #contents #main section .grid3to2 {
      width: 90%;
      margin: 0 auto;
      gap: 60px 20px;
      grid-template-columns: 1fr 1fr; }
    body #contents #main article .grid3to1, body #contents #main section .grid3to1 {
      grid-template-columns: 1fr;
      width: 90%;
      margin: 0 auto; }
    body #contents #main article .grid4, body #contents #main section .grid4 {
      width: 90%;
      margin: 0 auto;
      gap: 20px;
      grid-template-columns: 1fr 1fr; }
    body #contents #main article .grid6, body #contents #main section .grid6 {
      width: 90%;
      margin: 0 auto;
      gap: 15px;
      grid-template-columns: 1fr 1fr 1fr; } }

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