@charset "UTF-8";
/* Common CSS */
/* _setting CSS */
html, body {
  background: #fff;
  font-size: 10px;
}

* {
  box-sizing: border-box;
}

/* ___________________Font */
body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6,
pre, code, form, fieldset, legend, input, textarea, p, blockquote, th, td {
  color: #333333;
  font-family: "Hiragino Kaku Gothic Pro","ヒラギノ角ゴ Pro W3","メイリオ",Meiryo,"ＭＳ Ｐゴシック",Helvetica,Arial,Verdana;
}

/* ___________________Link */
a {
  color: #0b318f;
  text-decoration: none;
}
a:hover {
  text-decoration: underline;
}
a:hover img {
  opacity: 0.8;
}

sup {
  font-size: 1rem;
  vertical-align: super;
}

sub {
  font-size: 1rem;
  vertical-align: sub;
}

/* Desktops and laptops */
@media print, screen and (min-width: 751px) {
  .sp {
    display: none;
  }

  body {
    padding-top: 120px;
  }
  body::before {
    content: '';
    display: block;
    width: 100%;
    height: 8px;
    background: url(../images/common/future_line.jpg) left top no-repeat;
    background-size: 100% 8px;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1000;
  }

  /* ___________________Layout */
  .sec {
    width: 100%;
    margin: 0 auto;
    min-width: 1200px;
  }

  .common_inner {
    width: 100%;
    margin: 0 auto;
    min-width: 1200px;
  }

  /* ___________________header */
  #header {
    width: 100%;
    height: 120px;
    background-color: rgba(255, 255, 255, 0.6);
    position: fixed;
    top: 0;
    left: 0;
    z-index: 999;
    backdrop-filter: blur(10px);
  }
  #header .common_inner {
    padding: 54px 0 0 50px;
    position: relative;
  }
  #header .common_inner #logo {
    position: fixed;
    top: 30px;
    left: 40px;
    z-index: 10;
  }
  #header .common_inner #logo a {
    width: 430px;
    padding: 10px;
    display: block;
    background-color: transparent;
  }
  #header .common_inner #logo a img {
    width: 100%;
    height: auto;
  }
  #header .common_inner #btn_menu {
    width: 80px;
    height: 80px;
    padding-top: 50px;
    border-radius: 10px;
    border: none;
    text-align: center;
    box-shadow: 5px 5px 0 rgba(0, 0, 0, 0.2);
    background-color: #fff;
    outline: none;
    position: fixed;
    top: 15px;
    right: 20px;
    z-index: 10;
    display: block;
    transition: all 200ms linear;
  }
  #header .common_inner #btn_menu:hover {
    background-color: #0b318f;
  }
  #header .common_inner #btn_menu:before {
    content: '';
    display: block;
    width: 40px;
    height: 10px;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: #006de5;
    transform: translate3d(0, -16px, 0);
    transition: all 300ms cubic-bezier(0.175, 0.885, 0.32, 1.275);
  }
  #header .common_inner #btn_menu:after {
    content: '';
    display: block;
    width: 40px;
    height: 10px;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: #8edaff;
    transition: all 300ms cubic-bezier(0.175, 0.885, 0.32, 1.275);
  }
  #header .common_inner #btn_menu.on:before {
    transform: translate3d(0, -10px, 0) rotate(45deg);
  }
  #header .common_inner #btn_menu.on:after {
    transform: translate3d(0, -10px, 0) rotate(-45deg);
  }
  #header .common_inner #btn_menu span {
    color: #006de5;
    font-weight: bold;
    font-size: 1.5rem;
  }
  #header .common_inner #btn_mypage,
  #header .common_inner #btn_faq {
    width: 80px;
    height: 80px;
    position: fixed;
    top: 15px;
    right: 110px;
    z-index: 11;
  }
  #header .common_inner #btn_mypage a,
  #header .common_inner #btn_faq a {
    width: 100%;
    height: 100%;
    padding-top: 15px;
    border-radius: 10px;
    border: none;
    text-align: center;
    box-shadow: 5px 5px 0 rgba(0, 0, 0, 0.2);
    background-color: #fff;
    outline: none;
    display: block;
    transition: all 200ms linear;
  }
  #header .common_inner #btn_mypage a:hover,
  #header .common_inner #btn_faq a:hover {
    background-color: #8edaff;
  }
  #header .common_inner #btn_mypage a img,
  #header .common_inner #btn_faq a img {
    width: 24px;
    height: auto;
    display: block;
    margin: 0 auto;
  }
  #header .common_inner #btn_mypage a span,
  #header .common_inner #btn_faq a span {
    padding-top: 8px;
    display: inline-block;
    color: #006de5;
    font-weight: bold;
    font-size: 1.4rem;
  }
  #header .common_inner #btn_faq {
    right: 200px;
  }
  #header .common_inner #btn_faq a {
    padding-top: 18px;
  }
  #header .common_inner #btn_faq a img {
    width: 28px;
    height: auto;
    margin-bottom: 0;
  }
  #header .common_inner #btn_faq a span {
    margin-top: -2px;
    font-size: 1.2rem;
    line-height: 1.1;
  }
  #header .common_inner #link_holdings {
    position: absolute;
    top: 50px;
    right: 290px;
  }
  #header .common_inner #link_holdings a {
    color: #000;
    font-size: 1.4rem;
  }
  #header .common_inner #link_holdings a:before {
    content: '';
    background: url(../images/common/icon_link.svg) 0 0 no-repeat;
    background-size: 100% auto;
    display: inline-block;
    width: 12px;
    height: 12px;
    margin-right: 8px;
  }

  /* ___________________global navigation */
  #menu {
    width: 600px;
    height: 0;
    padding-left: 100px;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 5;
    overflow: hidden;
    pointer-events: none;
  }
  #menu .wrap {
    width: 600px;
    padding: 50px 300px 50px 50px;
    background-color: #006de5;
    border-radius: 0 0 0 30px;
    transform: translate3d(500px, 0, 0);
    transition: all 300ms cubic-bezier(0.175, 0.885, 0.32, 1.275);
    pointer-events: auto;
  }
  #menu .wrap #gnav li {
    border-bottom: dotted 1px #8edaff;
  }
  #menu .wrap #gnav li a {
    padding: 15px 0;
    display: block;
    color: #fff;
    font-size: 1.8rem;
    text-decoration: none;
    transition: all 200ms linear;
  }
  #menu .wrap #gnav li a:hover {
    color: #8edaff;
  }
  #menu .wrap #gnav_sub {
    padding-top: 20px;
  }
  #menu .wrap #gnav_sub li a {
    padding: 10px 0;
    display: block;
    color: #ddd;
    font-size: 1.6rem;
    text-decoration: none;
  }
  #menu .wrap #gnav_sub li a:hover {
    color: #fff;
  }
  #menu.on {
    height: auto;
  }
  #menu.on .wrap {
    transform: translate3d(0, 0, 0);
  }

  #menu_overlay {
    width: 100vw;
    height: 100vh;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 4;
    background-color: transparent;
    display: none;
  }
  #menu_overlay.on {
    display: block;
  }

  /* ___________________pankuzu */
  .pankuzu {
    min-width: 970px;
  }
  .pankuzu ul {
    width: calc(100% - 80px);
    padding: 20px;
    min-width: 970px;
    margin: 0 auto 80px auto;
    border: solid 1px #eee;
    border-radius: 8px;
  }
  .pankuzu ul li {
    margin-right: 3px;
    display: inline-block;
    font-size: 1.5rem;
  }
  .pankuzu ul li a {
    position: relative;
    display: inline-block;
    padding: 0 16px 0 0;
    vertical-align: middle;
    text-decoration: none;
    color: #333333;
  }
  .pankuzu ul li a::after {
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    content: "";
    vertical-align: middle;
    right: 3px;
    width: 4px;
    height: 4px;
    border-top: 1px solid #666;
    border-right: 1px solid #666;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
  }

  /* ___________________footer */
  #footer {
    margin: 100px auto 0 auto;
  }
  #footer .common_inner {
    min-height: 200px;
    display: flex;
  }
  #footer .common_inner .company {
    width: 520px;
    padding: 80px 0 10px 30px;
    margin-top: -15px;
    background-color: #006de5;
    border-radius: 0 20px 0 0;
  }
  #footer .common_inner .company dl {
    margin-bottom: 40px;
  }
  #footer .common_inner .company dl dt {
    margin-bottom: 10px;
    color: #fff;
    font-size: 1.4rem;
    font-weight: bold;
  }
  #footer .common_inner .company dl dd {
    color: #fff;
    font-size: 1.4rem;
    line-height: 1.4;
  }
  #footer .common_inner .company #copyrights {
    margin: 0 auto;
    color: #fff;
  }
  #footer .common_inner .fnav {
    width: calc(100% - 520px);
    padding-top: 30px;
    padding-bottom: 30px;
    display: flex;
    border-top: solid 2px #006de5;
  }
  #footer .common_inner .fnav ul {
    min-width: 100px;
    display: block;
    padding: 10px 0 0 40px;
  }
  #footer .common_inner .fnav ul li {
    margin: 0 0 15px 0;
  }
  #footer .common_inner .fnav ul li a {
    padding: 0;
    display: block;
    color: #333;
    font-size: 1.4rem;
    white-space: nowrap;
  }
  #footer .common_inner .fnav #group {
    min-width: calc(100% - 350px);
    padding: 20px 20px 0 30px;
  }
  #footer .common_inner .fnav #group ul {
    display: flex;
    justify-content: flex-end;
    align-items: center;
  }
  #footer .common_inner .fnav #group ul li a {
    padding: 0 20px;
    border: none;
  }
  #footer .common_inner .fnav #group ul li a img {
    width: auto;
    height: 40px;
  }

  /* ___________________UI */
  .common_btn {
    width: 320px;
  }
  .common_btn a {
    width: 100%;
    height: 68px;
    display: block;
    background: url(../images/common/icon_look.svg) 10px center no-repeat #006de5;
    background-size: 54px 54px;
    font-size: 2rem;
    line-height: 68px;
    color: #fff;
    font-weight: bold;
    text-align: center;
    text-decoration: none;
    border-radius: 60px;
    box-shadow: 6px 6px 0 rgba(0, 0, 0, 0.2);
  }
  .common_btn a:hover {
    opacity: 0.8;
  }

  /* ___________________layout */
  #wrapper {
    margin: 0 auto;
  }

  #sub {
    margin: 0 auto;
  }

  #main {
    margin: 0 auto;
  }
}
/* Smartphones (portrait and landscape) */
@media screen and (max-width: 1200px) {
  #header .common_inner #link_holdings {
    position: fixed;
  }
}
/* Smartphones (portrait and landscape) */
@media screen and (max-width: 1450px) {
  #footer .common_inner .fnav {
    display: block;
  }
  #footer .common_inner .fnav ul {
    display: block;
    padding-top: 0;
    padding-left: 40px;
  }
  #footer .common_inner .fnav ul li {
    margin: 0 0 20px 0;
    display: inline-block;
  }
  #footer .common_inner .fnav ul li a {
    padding: 0 10px;
    display: inline-block;
    color: #333;
    font-size: 1.4rem;
    border-right: solid 1px #006de5;
  }
  #footer .common_inner .fnav ul li:last-child a {
    border-right: none;
  }
  #footer .common_inner .fnav #group {
    padding: 10px 0 0 20px;
  }
  #footer .common_inner .fnav #group ul {
    display: flex;
    justify-content: flex-start;
  }
  #footer .common_inner .fnav #group ul li {
    display: block;
  }
  #footer .common_inner .fnav #group ul li a {
    border: none;
  }
}
/* Smartphones (portrait and landscape) */
@media screen and (max-width: 750px) {
  body {
    padding-top: 65px;
  }
  body::before {
    content: '';
    display: block;
    width: 100%;
    height: 8px;
    background: url(../images/common/future_line.jpg) left top no-repeat;
    background-size: 100% 4px;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1000;
  }

  .pc {
    display: none;
  }

  img {
    width: 100%;
    height: auto;
  }

  /* ___________________Smartphones Layout */
  .sec {
    width: 100%;
    margin: 0 auto;
  }

  .common_inner {
    width: 100%;
    margin: 0 auto;
  }

  /* ___________________Smartphones header */
  #header {
    width: 100%;
    height: 65px;
    background-color: rgba(255, 255, 255, 0.6);
    position: fixed;
    top: 0;
    left: 0;
    z-index: 999;
    backdrop-filter: blur(10px);
  }
  #header .common_inner {
    padding: 30px 0 0 20px;
    position: relative;
  }
  #header .common_inner #logo {
    width: 50%;
    position: fixed;
    top: 15px;
    left: 15px;
    z-index: 2;
  }
  #header .common_inner #logo a {
    width: 100%;
    padding: 10px 0 0 0;
    display: block;
    background-color: transparent;
  }
  #header .common_inner #logo a img {
    width: 100%;
    height: auto;
  }
  #header .common_inner #btn_menu {
    width: 48px;
    height: 48px;
    padding-top: 28px;
    border-radius: 10px;
    border: none;
    text-align: center;
    box-shadow: 3px 3px 0 rgba(0, 0, 0, 0.2);
    background-color: #fff;
    outline: none;
    position: fixed;
    top: 5px;
    right: 5px;
    z-index: 10;
    display: block;
    transition: all 200ms linear;
  }
  #header .common_inner #btn_menu:hover {
    background-color: #0b318f;
  }
  #header .common_inner #btn_menu:before {
    content: '';
    display: block;
    width: 25px;
    height: 5px;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: #006de5;
    transform: translate3d(0, -10px, 0);
    transition: all 300ms cubic-bezier(0.175, 0.885, 0.32, 1.275);
  }
  #header .common_inner #btn_menu:after {
    content: '';
    display: block;
    width: 25px;
    height: 5px;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: #8edaff;
    transition: all 300ms cubic-bezier(0.175, 0.885, 0.32, 1.275);
  }
  #header .common_inner #btn_menu.on:before {
    transform: translate3d(0, -5px, 0) rotate(45deg);
  }
  #header .common_inner #btn_menu.on:after {
    transform: translate3d(0, -5px, 0) rotate(-45deg);
  }
  #header .common_inner #btn_menu span {
    color: #006de5;
    font-weight: bold;
    font-size: 1rem;
  }
  #header .common_inner #btn_mypage,
  #header .common_inner #btn_faq {
    width: 48px;
    height: 48px;
    position: fixed;
    top: 5px;
    right: 57px;
    z-index: 11;
  }
  #header .common_inner #btn_mypage a,
  #header .common_inner #btn_faq a {
    width: 100%;
    height: 100%;
    padding-top: 10px;
    border-radius: 10px;
    border: none;
    text-align: center;
    box-shadow: 3px 3px 0 rgba(0, 0, 0, 0.2);
    background-color: #fff;
    outline: none;
    display: block;
    transition: all 200ms linear;
  }
  #header .common_inner #btn_mypage a:hover,
  #header .common_inner #btn_faq a:hover {
    background-color: #8edaff;
  }
  #header .common_inner #btn_mypage a img,
  #header .common_inner #btn_faq a img {
    width: 12px;
    height: auto;
    display: block;
    margin: 0 auto 2px auto;
  }
  #header .common_inner #btn_mypage a span,
  #header .common_inner #btn_faq a span {
    padding-top: 3px;
    display: inline-block;
    color: #006de5;
    font-weight: bold;
    font-size: 0.95rem;
  }
  #header .common_inner #btn_faq {
    right: 110px;
  }
  #header .common_inner #btn_faq a {
    padding-top: 10px;
  }
  #header .common_inner #btn_faq a img {
    width: 16px;
    height: auto;
    margin-bottom: 0;
  }
  #header .common_inner #btn_faq a span {
    margin-top: -1px;
    font-size: 0.8rem;
    line-height: 1.2;
  }
  #header .common_inner #link_holdings {
    position: absolute;
    top: 75px;
    right: 10px;
  }
  #header .common_inner #link_holdings a {
    color: #000;
    font-size: 1.0rem;
  }
  #header .common_inner #link_holdings a:before {
    content: '';
    background: url(../images/common/icon_link.svg) 0 0 no-repeat;
    background-size: 100% auto;
    display: inline-block;
    width: 12px;
    height: 12px;
    margin-right: 8px;
  }

  /* ___________________Smartphones global navigation */
  #menu {
    width: 95vw;
    height: 0;
    padding-left: 30px;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 5;
    overflow: hidden;
    pointer-events: none;
  }
  #menu .wrap {
    width: 600px;
    padding: 50px 300px 30px 40px;
    background-color: #006de5;
    border-radius: 0 0 0 30px;
    transform: translate3d(500px, 0, 0);
    transition: all 300ms cubic-bezier(0.175, 0.885, 0.32, 1.275);
    pointer-events: all;
  }
  #menu .wrap #gnav li {
    border-bottom: dotted 1px #8edaff;
  }
  #menu .wrap #gnav li a {
    padding: 10px 0;
    display: block;
    color: #fff;
    font-size: 1.8rem;
    text-decoration: none;
    transition: all 200ms linear;
  }
  #menu .wrap #gnav li a:hover {
    color: #8edaff;
  }
  #menu .wrap #gnav_sub {
    padding-top: 15px;
  }
  #menu .wrap #gnav_sub li a {
    padding: 8px 0;
    display: block;
    color: #ddd;
    font-size: 1.5rem;
    text-decoration: none;
  }
  #menu .wrap #gnav_sub li a:hover {
    color: #fff;
  }
  #menu.on {
    height: auto;
  }
  #menu.on .wrap {
    transform: translate3d(0, 0, 0);
  }

  #menu_overlay {
    width: 100vw;
    height: 100vh;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 4;
    background-color: transparent;
    display: none;
  }
  #menu_overlay.on {
    display: block;
  }

  /* ___________________pankuzu */
  .pankuzu {
    padding: 10px 0 10px 0;
    margin: 20px 0 20px 0;
    overflow-x: scroll;
    word-break: keep-all;
    white-space: nowrap;
  }
  .pankuzu ul {
    padding: 0 15px;
    word-break: keep-all;
  }
  .pankuzu ul li {
    margin-right: 3px;
    display: inline-block;
    font-size: 1.3rem;
  }
  .pankuzu ul li a {
    position: relative;
    display: inline-block;
    padding: 0 16px 0 0;
    vertical-align: middle;
    text-decoration: none;
    color: #333333;
  }
  .pankuzu ul li a::after {
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    content: "";
    vertical-align: middle;
    right: 3px;
    width: 4px;
    height: 4px;
    border-top: 1px solid #666;
    border-right: 1px solid #666;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
  }

  /* ___________________Smartphones footer */
  #footer {
    margin: 50px auto 0 auto;
  }
  #footer .common_inner {
    display: flex;
    flex-wrap: wrap;
  }
  #footer .common_inner .company {
    width: 100%;
    order: 2;
    padding: 30px 0 10px 30px;
    margin-top: -30px;
    background-color: #006de5;
  }
  #footer .common_inner .company dl {
    margin-bottom: 20px;
  }
  #footer .common_inner .company dl dt {
    margin-bottom: 10px;
    color: #fff;
    font-size: 1.4rem;
    font-weight: bold;
  }
  #footer .common_inner .company dl dd {
    color: #fff;
    font-size: 1.4rem;
    line-height: 1.4;
  }
  #footer .common_inner .company #copyrights {
    margin: 0 auto;
    color: #fff;
  }
  #footer .common_inner .fnav {
    width: 100%;
    padding: 0;
  }
  #footer .common_inner .fnav ul {
    display: none;
  }
  #footer .common_inner .fnav #group {
    width: 100%;
    margin: 0 auto 50px auto;
    padding: 30px 0 0 0;
    background-color: #fff;
  }
  #footer .common_inner .fnav #group ul {
    width: 100%;
    padding: 0 20px;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
  }
  #footer .common_inner .fnav #group ul li {
    width: 50%;
    order: 1;
    margin: 0 0 10px 0;
    text-align: center;
  }
  #footer .common_inner .fnav #group ul li img {
    width: auto;
    height: 30px;
    margin: 0 auto;
  }

  /* ___________________Smartphones UI */
  .common_btn {
    width: 320px;
    margin: 0 auto;
  }
  .common_btn a {
    width: 100%;
    height: 50px;
    display: block;
    background: url(../images/common/icon_look.svg) 10px center no-repeat #006de5;
    background-size: 30px auto;
    font-size: 1.8rem;
    line-height: 50px;
    color: #fff;
    font-weight: bold;
    text-align: center;
    text-decoration: none;
    border-radius: 60px;
    box-shadow: 6px 6px 0 rgba(0, 0, 0, 0.2);
  }
  .common_btn a:hover {
    opacity: 0.8;
  }
}
@media screen and (max-width: 320px) {
  #header .common_inner #logo a {
    width: 150px;
  }
}
