@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;200;300;400;500;600;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Lato:wght@300;400;700;900&display=swap");
/*------------------------------------------------------------
	デフォルトスタイル
------------------------------------------------------------*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td {
  margin: 0;
  padding: 0;
  background: transparent;
  border: 0;
  outline: 0;
  font-size: 1em; }

html {
  font-size: 62.5%; }

body, table, input, textarea, select, option {
  font-family: 'Noto Sans JP', sans-serif; }

article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary {
  display: block; }

ol, ul {
  list-style: none; }

blockquote, q {
  quotes: none; }

:focus {
  outline: 0; }

ins {
  text-decoration: none; }

del {
  text-decoration: line-through; }

img {
  vertical-align: top;
  max-width: 100%; }

/*------------------------------------------------------------
	汎用スタイル
------------------------------------------------------------*/
/* clearfix */
.clearfix:after {
  content: "";
  display: block;
  clear: both; }

a {
  color: #000;
  text-decoration: none;
  transition: .3s;
  -webkit-transition: .3s; }
  a:link {
    color: #000;
    text-decoration: none; }
  a:visited {
    color: #000; }
  a:hover {
    color: #000; }
  a:active {
    color: #000; }

/*------------------------------------------------------------
	レイアウト
------------------------------------------------------------*/
body {
  color: #000;
  font-size: 1.4rem;
  font-weight: 300;
  line-height: 1.5;
  text-size-adjust: none;
  -webkit-text-size-adjust: none;
  background-color: #fff; }
  body.fixed {
    position: fixed;
    width: 100%;
    height: 100%; }

#container {
  text-align: left; }

#main {
  margin-bottom: 150px; }

a[href^="tel:"] {
  cursor: default;
  pointer-events: none; }

@media screen and (min-width: 768px) {
  .sp {
    display: none !important; } }
@media screen and (max-width: 767px) {
  #main {
    margin-bottom: 100px; }

  a:hover, a:hover img {
    opacity: 1 !important; }

  .pc {
    display: none !important; }

  a[href^="tel:"] {
    cursor: pointer;
    pointer-events: auto; } }
/*------------------------------------------------------------
	ヘッダー
------------------------------------------------------------*/
#gHeader {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  z-index: 100; }
  #gHeader.fix {
    background-color: #fff; }
  #gHeader h1 {
    margin-left: 32px; }
    @media screen and (max-width: 1200px) {
      #gHeader h1 {
        margin-left: 8px; } }
  #gHeader .menu {
    display: none; }
  #gHeader .custom-nav {
    width: calc(100% - 200px); }
    @media screen and (max-width: 1200px) {
      #gHeader .custom-nav {
        width: calc(100% - 180px); } }
    @media screen and (min-width: 1001px) {
      #gHeader .custom-nav {
        display: block !important; } }
    #gHeader .custom-nav .custom-login {
      margin-right: 32px;}
      @media screen and (max-width: 1200px) {
        #gHeader .custom-nav .custom-login {
          margin-right: 8px; } }
    #gHeader .custom-nav nav ul {
      display: flex; }
      #gHeader .custom-nav nav ul li {
        margin-right: 28px; }
        @media screen and (max-width: 1200px) {
          #gHeader .custom-nav nav ul li {
            margin-right: 14px; } }
        #gHeader .custom-nav nav ul li a {
          position: relative; }
          #gHeader .custom-nav nav ul li a:after {
            content: '';
            opacity: 0;
            display: inline-block;
            position: absolute;
            left: 0;
            bottom: -5px;
            width: 100%;
            height: 3px;
            -webkit-transition: all 0.2s;
            transition: all 0.2s;
            background-color: #0055A2; }
          @media screen and (min-width: 768px) {
            #gHeader .custom-nav nav ul li a:hover:after {
              opacity: 1; } }
    #gHeader .custom-nav .custom-btn {
      margin-right: 30px; }
      #gHeader .custom-nav .custom-btn a {
        width: 231px;
        height: 50px;
        font-size: 1.6rem; }
      @media screen and (max-width: 1100px) {
        #gHeader .custom-nav .custom-btn {
          margin-right: 15px;
          width: 15vw; }
          #gHeader .custom-nav .custom-btn a {
            width: 100%; } }
  @media screen and (max-width: 1000px) {
    #gHeader {
      position: static;
      left: auto;
      top: auto; }
      #gHeader .h-box {
        position: fixed;
        left: 0;
        top: 0;
        width: 100%;
        height: 56px;
        background-color: #fff;
        display: flex;
        align-items: center;
        justify-content: space-between;
        z-index: 100; }
        #gHeader .h-box h1 {
          margin-left: 12px;
          width: 110px; }
        #gHeader .h-box .r-box {
          display: flex;
          justify-content: flex-end; }
          #gHeader .h-box .r-box .custom-login {
            width: 80px; }
        #gHeader .h-box .menu {
          padding-top: 5px;
          width: 56px;
          height: 56px;
          display: flex;
          justify-content: center;
          align-items: center;
          cursor: pointer;
          box-sizing: border-box; }
      #gHeader .custom-nav {
        opacity: 0;
        transform: translateX(100px);
        pointer-events: none;
        visibility: hidden;
        position: fixed;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        overflow-y: auto;
        background-color: #fff;
        transition: all 0.5s;
        z-index: 90; }
        #gHeader .custom-nav.open {
          opacity: 1;
          -webkit-transform: translateX(0);
          transform: translateX(0);
          pointer-events: all;
          visibility: visible; }
        #gHeader .custom-nav > div {
          height: 100%;
          display: block !important; }
        #gHeader .custom-nav nav ul {
          max-width: 164px;
          margin: 0 auto 92px;
          padding-top: 130px;
          display: block; }
          #gHeader .custom-nav nav ul li {
            margin: 0 0 33px;
            font-size: 1.8rem; }
            #gHeader .custom-nav nav ul li a {
              display: block; }
        #gHeader .custom-nav .custom-btn {
          margin: 0 auto 30px;
          width: 293px; }
          #gHeader .custom-nav .custom-btn a {
            height: 66px;
            font-size: 2rem; }
        #gHeader .custom-nav .custom-login {
          display: none; } }

/* ==========================================================================
  footer
========================================================================== */
.custom-sec__wrap.custom-contact .custom-container__wrap {
  padding: 100px 15px 95px; }
  @media screen and (max-width: 767px) {
    .custom-sec__wrap.custom-contact .custom-container__wrap {
      padding: 70px 15px 60px; } }
  .custom-sec__wrap.custom-contact .custom-container__wrap h3 {
    margin-bottom: 48px;
    font-size: 2.8rem;
    text-align: center; }
    .custom-sec__wrap.custom-contact .custom-container__wrap h3 small {
      font-size: 1.4rem; }
    @media screen and (max-width: 767px) {
      .custom-sec__wrap.custom-contact .custom-container__wrap h3 {
        margin-bottom: 50px;
        font-size: 2.4rem;
        line-height: 1.6; } }
  .custom-sec__wrap.custom-contact .custom-container__wrap .container {
    max-width: 800px; }
    .custom-sec__wrap.custom-contact .custom-container__wrap .container .row {
      justify-content: space-between !important; }
      .custom-sec__wrap.custom-contact .custom-container__wrap .container .row .col-md {
        margin-left: 0 !important;
        padding: 0 !important;
        width: 49.2%;
        flex: none;
        letter-spacing: 0.1em; }
        .custom-sec__wrap.custom-contact .custom-container__wrap .container .row .col-md:first-child a:after {
          display: none !important; }
        .custom-sec__wrap.custom-contact .custom-container__wrap .container .row .col-md:last-child {
          margin-right: 0 !important; }
      @media screen and (max-width: 767px) {
        .custom-sec__wrap.custom-contact .custom-container__wrap .container .row {
          margin: 0 auto;
          max-width: 294px;
          display: block !important; }
          .custom-sec__wrap.custom-contact .custom-container__wrap .container .row .col-md {
            margin: 25px 0 0;
            width: auto; } }

.custom-sec__wrap.custom-contact .custom-plus {
  line-height: 1.6; }

@media (max-width: 575px) {
  .custom-sec__wrap.custom-contact .custom-plus {
    font-size: 1.375rem; } }
@media (min-width: 576px) and (max-width: 767px) {
  .custom-sec__wrap.custom-contact .custom-plus {
    font-size: 1.5rem; } }
.custom-sec__wrap.custom-contact .custom-plus:after {
  content: '';
  display: inline-block;
  width: 18px;
  height: 18px;
  -webkit-transform: translateX(3rem) translateY(-3.5rem);
  transform: translateX(3rem) translateY(-3.5rem);
  background-image: url(../img/top/plus_mark@2x.png);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: 0 0; }

@media (min-width: 768px) {
  .custom-sec__wrap.custom-contact .custom-plus:after {
    -webkit-transform: translateX(0) translateY(-1.3rem);
    transform: translateX(0) translateY(-1.3rem); } }
.custom-container__wrap.custom-footer {
  font-size: 1.2rem;
  background-color: #0055A2; }

.custom-container__wrap.custom-footer .custom-py {
  max-width: 1000px;
  padding-top: 60px;
  padding-bottom: 50px; }

@media (max-width: 575px) {
  .custom-container__wrap.custom-footer .custom-py {
    padding-left: 30px;
    padding-right: 30px; } }
@media (min-width: 576px) and (max-width: 767px) {
  .custom-container__wrap.custom-footer .custom-py {
    padding-left: 40px;
    padding-right: 40px; } }
@media (min-width: 768px) {
  .custom-container__wrap.custom-footer .custom-py {
    padding-top: 8rem;
    padding-bottom: 5.5rem; } }
.custom-container__wrap.custom-footer .custom-logo {
  margin-bottom: 3rem; }

@media (min-width: 768px) {
  .custom-container__wrap.custom-footer .custom-logo {
    margin: 0; } }
.custom-container__wrap.custom-footer .custom-logo a {
  display: inline-block;
  width: 90%; }

@media (min-width: 576px) and (max-width: 767px) {
  .custom-container__wrap.custom-footer .custom-logo a {
    width: 100%; } }
@media (min-width: 768px) and (max-width: 991px) {
  .custom-container__wrap.custom-footer .custom-logo a {
    width: 90%; } }
@media (min-width: 992px) and (max-width: 1199px) {
  .custom-container__wrap.custom-footer .custom-logo a {
    width: 70%;
    max-width: 268px; } }
@media (min-width: 1200px) {
  .custom-container__wrap.custom-footer .custom-logo a {
    width: 70%;
    max-width: 268px; } }
.custom-container__wrap.custom-footer .custom-logo img {
  width: 100%; }
  @media screen and (max-width: 767px) {
    .custom-container__wrap.custom-footer .custom-logo img {
      width: 226px; } }

@media (min-width: 768px) {
  .custom-container__wrap.custom-footer .custom-bg {
    padding: 3rem 0 2rem;
    background-color: rgba(0, 24, 62, 0.5); }
    .custom-container__wrap.custom-footer .custom-bg .container {
      max-width: 1000px; } }
@media screen and (max-width: 767px) {
  .custom-container__wrap.custom-footer .custom-bg .container {
    padding: 0 !important; } }
.custom-container__wrap.custom-footer .custom-bg .custom-col, .custom-container__wrap.custom-footer .custom-bg .custom-col2 {
  padding: 18px 0;
  font-size: 1.4rem;
  background-color: rgba(0, 24, 62, 0.5); }

@media (min-width: 768px) {
  .custom-container__wrap.custom-footer .custom-bg .custom-col, .custom-container__wrap.custom-footer .custom-bg .custom-col2 {
    padding: 0;
    background-color: rgba(255, 255, 255, 0); } }
.custom-container__wrap.custom-footer .custom-bg .custom-col {
  margin-bottom: 0.2rem; }

@media (min-width: 768px) {
  .custom-container__wrap.custom-footer .custom-bg .col-md {
    margin-bottom: 0;
    font-size: 1.6rem;
    letter-spacing: 0.05em;
    line-height: 1.1; }
    .custom-container__wrap.custom-footer .custom-bg .col-md a:after {
      margin-top: -5px;
      right: 5rem; }

  .custom-container__wrap.custom-footer .custom-bg .custom-col {
    border-right: 1px rgba(0, 85, 162, 0.3) solid; } }
.custom-container__wrap.custom-footer .custom-nav {
  margin-bottom: 0;
  color: rgba(255, 255, 255, 0.3); }

.custom-container__wrap.custom-footer .custom-nav li {
  margin-bottom: 35px; }

@media (min-width: 768px) {
  .custom-container__wrap.custom-footer .custom-nav li {
    margin-bottom: 1.4rem;
    font-size: 1.4rem; } }
.custom-container__wrap.custom-footer .custom-nav li:last-child {
  margin: 0; }

.custom-container__wrap.custom-footer a.custom-btn span:nth-of-type(2) {
  font-size: 2rem;
  line-height: 1.8; }
  @media screen and (max-width: 359px) {
    .custom-container__wrap.custom-footer a.custom-btn span:nth-of-type(2) {
      font-size: 1.8rem; } }

@media (min-width: 768px) and (max-width: 991px) {
  .custom-container__wrap.custom-footer a.custom-btn span:nth-of-type(2) {
    font-size: 1.0625rem; } }
@media (min-width: 992px) and (max-width: 1199px) {
  .custom-container__wrap.custom-footer a.custom-btn span:nth-of-type(2) {
    font-size: 1.25rem; } }
@media (min-width: 1200px) {
  .custom-container__wrap.custom-footer a.custom-btn span:nth-of-type(2) {
    font-size: 2rem; } }
.custom-container__wrap.custom-footer .copyright {
  padding: 40px 0 !important;
  letter-spacing: 0.05em; }
  @media screen and (max-width: 767px) {
    .custom-container__wrap.custom-footer .copyright {
      padding: 26px 0 !important;
      font-size: 1rem;
      line-height: 1.6; } }

.custom-container__wrap.custom-footer .custom-btn-top {
  position: absolute;
  right: 1rem;
  bottom: 1rem;
  width: 59px;
  height: 59px;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s; }
  .custom-container__wrap.custom-footer .custom-btn-top img {
    width: 100%; }
  @media screen and (max-width: 359px) {
    .custom-container__wrap.custom-footer .custom-btn-top {
      width: 50px;
      height: 50px; } }

@media (min-width: 768px) {
  .custom-container__wrap.custom-footer .custom-btn-top:hover {
    cursor: pointer;
    -webkit-transform: translateY(-15px);
    transform: translateY(-15px); } }
@media (min-width: 576px) and (max-width: 767px) {
  .custom-container__wrap.custom-footer .custom-btn-top {
    right: 1rem;
    bottom: 1rem;
    width: 59px;
    height: 59px; } }
@media (min-width: 768px) {
  .custom-container__wrap.custom-footer .custom-btn-top {
    bottom: 2rem;
    width: 105px;
    height: 105px; } }
@media (min-width: 992px) and (max-width: 1199px) {
  .custom-container__wrap.custom-footer .custom-btn-top {
    bottom: 2rem; } }
@media (min-width: 1200px) {
  .custom-container__wrap.custom-footer .custom-btn-top {
    bottom: 4rem;
    right: 2rem; } }
/*------------------------------------------------------------
	common
------------------------------------------------------------*/
/* fade-up */
.fade-up {
  opacity: 0;
  visibility: hidden;
  -webkit-transform: translateY(15px);
  transform: translateY(15px);
  -webkit-transition: opacity 1.0s, -webkit-transform 1.0s;
  transition: opacity 1.0s, -webkit-transform 1.0s;
  transition: opacity 1.0s, transform 1.0s;
  transition: opacity 1.0s, transform 1.0s, -webkit-transform 1.0s; }

.fade-up.on {
  opacity: 1;
  visibility: visible;
  -webkit-transform: translateY(0);
  transform: translateY(0); }

/* en */
.en {
  font-family: 'Lato', sans-serif; }

/* custom-bg-lblue */
.btn.custom-icon--blank::after, a.custom-icon--blank::after {
  content: '';
  position: absolute;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: 0 0; }

a.custom-icon--blank:after {
  top: 50%;
  right: 4rem;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 11px;
  height: 11px;
  background-image: url(../img/common/icon_data.png); }

@media (min-width: 768px) and (max-width: 991px) {
  a.custom-icon--blank:after {
    right: 1rem !important; } }
@media (min-width: 992px) and (max-width: 1199px) {
  a.custom-icon--blank:after {
    right: 2rem !important; } }
@media (min-width: 1200px) {
  a.custom-icon--blank:after {
    right: 4rem; } }
.custom-bg-lblue {
  background-color: #F2F4F9; }

a.custom-btn--blue {
  position: relative;
  z-index: 1;
  display: inline-block;
  width: 100%;
  padding: 24px 20px !important;
  font-size: 1.8rem;
  border-radius: 60px;
  background: #3b76d6;
  background: -webkit-gradient(linear, left top, left bottom, from(#3b76d6), to(#003489));
  background: -webkit-linear-gradient(top, #3b76d6 0%, #003489 100%);
  background: linear-gradient(180deg, #3b76d6 0%, #003489 100%);
  color: #fff;
  text-decoration: none; }

a.custom-btn--blue::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  border-radius: 60px;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  border: 1px #fff60a solid;
  background: #fff60a;
  background: -webkit-gradient(linear, left top, left bottom, from(#fff60a), to(#fff60a));
  background: -webkit-linear-gradient(top, #fff60a 0%, #fff60a 100%);
  background: linear-gradient(180deg, #fff60a 0%, #fff60a 100%);
  opacity: 0;
  -webkit-transition: opacity 0.2s;
  transition: opacity 0.2s; }

@media (min-width: 768px) {
  a.custom-btn--blue:hover::before {
    opacity: 1;
    -webkit-transform: translateX(-1px);
    transform: translateX(-1px); } }
@media (min-width: 768px) {
  a.custom-btn--blue:hover {
    color: #0055A2; } }
a.custom-btn--bdr-blue {
  font-size: 0.875rem;
  border: 1px #0055A2 solid;
  border-radius: 100px;
  -webkit-transition: all 0.3s;
  transition: all 0.3s; }

a.custom-btn--bdr-blue:hover {
  color: #fff;
  background-color: #0055A2;
  text-decoration: none; }

a.custom-link-bdr {
  color: #0055A2;
  text-decoration: underline; }
  @media screen and (min-width: 768px) {
    a.custom-link-bdr:hover {
      text-decoration: none; } }

a .custom-icon--blank-inline {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center; }

@media (min-width: 768px) {
  a .custom-icon--blank-inline {
    display: inline; } }
a .custom-icon--blank-inline:after {
  content: '';
  display: inline-block;
  width: 11px;
  height: 11px;
  margin-left: 1rem;
  background-image: url(../img/common/icon_data.png);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: 0 0; }

a.custom-hover {
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s; }

a.custom-hover:hover {
  opacity: 0.7;
  text-decoration: none; }

/* custom-container__wrap */
.custom-container__wrap.custom-bg--blue {
  background-color: #0055A2; }

/* row > custom-mx */
@media (max-width: 575px) {
  .row.custom-mx-row-sp {
    margin-left: 0;
    margin-right: 0; } }
@media (min-width: 576px) and (max-width: 767px) {
  .row.custom-mx-row-sp {
    margin-left: 0;
    margin-right: 0; } }
/* custom-text-blue */
.custom-text-blue {
  color: #0055A2; }

/* custom-h2 */
.custom-h2 {
  /* margin: 158px 0 18px; */
  margin: 0px 0 18px;
  color: #0055A2;
  font-size: 4rem;
  font-weight: 300; }
  @media screen and (max-width: 767px) {
    .custom-h2 {
      margin-top: 100px;
      font-size: 3.6rem; } }

.heading01 {
  margin-bottom: 31px;
  position: relative;
  color: #1B55A2;
  font-size: 3.4rem;
  font-weight: 700;
  line-height: 1.2;
  text-align: center; }
  .heading01 small {
    font-size: 1.8rem; }
  .heading01 .en {
    margin-bottom: -78px;
    display: block;
    font-size: 18rem;
    font-weight: 900;
    line-height: 1;
    opacity: 0.08; }
  @media screen and (max-width: 767px) {
    .heading01 {
      margin-bottom: 15px;
      font-size: 2.4rem;
      line-height: 1.5; }
      .heading01 .en {
        margin-bottom: -55px;
        font-size: 9rem; }
      .heading01 small {
        font-size: 1.6rem; } }

/* container */
.container {
  /* max-width: 854px; */ }
  @media screen and (max-width: 767px) {
    .container {
      padding: 0 10px; } }

.custom-text-blue {
  color: #0055A2; }

.custom-bg-blue {
  background-color: #0055A2; }

/* custom-btn */
.custom-btn a {
  /* width: 293px; */
  height: 63px;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  font-size: 1.8rem;
  letter-spacing: 0.1em;
  font-weight: bold;
  border-radius: 60px;
  background: linear-gradient(180deg, #3b76d6 0%, #003489 100%); }
  @media screen and (min-width: 768px) {
    .custom-btn a:hover {
      color: #0055A2;
      background: #FFF60A; } }
  @media screen and (max-width: 767px) {
    .custom-btn a {
      width: 255px;
      height: 66px;
      font-size: 2rem; } }

/* index */
#main.index {
  margin-bottom: 0; }
  #main.index .main-visual {
    padding: 89px 0 0;
    position: relative;
    background: #EFF8FF;
    overflow: hidden; }
    #main.index .main-visual:after {
      position: absolute;
      left: -6.3%;
      bottom: 20px;
      width: 27.5%;
      height: 27.5vw;
      background: url("../img/index/main_bg.png") no-repeat left top/100% 100%;
      content: ""; }
    #main.index .main-visual .container {
      display: flex;
      max-width: 1230px;
      position: relative;
      z-index: 1; }
      @media all and (max-width: 1140px) {
        #main.index .main-visual .container {
          align-items: flex-end; } }
      #main.index .main-visual .container .txt-box {
        margin: 38px 0;
        width: 480px;
        position: relative;
        z-index: 1; }
        #main.index .main-visual .container .txt-box h2 {
          margin-bottom: 17px; }
        #main.index .main-visual .container .txt-box p {
          margin-bottom: 30px;
          font-size: 1.5rem;
          line-height: 1.87; }
        @media screen and (max-width: 1060px) {
          #main.index .main-visual .container .txt-box {
            width: 338px; } }
      #main.index .main-visual .container .main-img {
        margin: 0 -97px 0 -106px;
        flex: 1; }
        @media all and (max-width: 1400px) {
          #main.index .main-visual .container .main-img {
            margin-right: 0; } }
        @media all and (max-width: 1140px) {
          #main.index .main-visual .container .main-img {
            margin-bottom: 60px; } }
    @media screen and (max-width: 767px) {
      #main.index .main-visual {
        padding: 97px 0 49px; }
        #main.index .main-visual:after {
          display: none; }
        #main.index .main-visual .container {
          display: block; }
          #main.index .main-visual .container .txt-box {
            margin: 0;
            width: 290px; }
            #main.index .main-visual .container .txt-box h2 {
              margin-bottom: 10px; }
            #main.index .main-visual .container .txt-box p {
              margin-bottom: 18px;
              font-size: 1.3rem;
              line-height: 1.85; }
          #main.index .main-visual .container .main-img {
            margin: -5px -13px 0 -34px; } }
  #main.index .container {
    max-width: 1030px; }
  #main.index .txt-line {
    padding-bottom: 9px;
    font-weight: bold;
    background: url("../img/index/txt_bg.png") repeat-x left bottom; }
    @media screen and (max-width: 767px) {
      #main.index .txt-line {
        padding-bottom: 4px;
        background-size: 8px auto; } }
  #main.index .mid-txt {
    margin-bottom: 56px;
    line-height: 1.71;
    text-align: center; }
    #main.index .mid-txt:last-child {
      margin-bottom: 0; }
    @media screen and (max-width: 767px) {
      #main.index .mid-txt {
        margin-bottom: 30px; } }
  #main.index .about {
    padding: 97px 0 110px;
    background: linear-gradient(180deg, #fff 0%, #EFF8FF 50%, #EFF8FF 100%); }
    #main.index .about .container {
      position: relative; }
    #main.index .about h2 {
      margin-bottom: 48px;
      font-size: 4.6rem;
      text-align: left; }
    #main.index .about .info-list {
      margin-right: -100px;
      text-align: right; }
      @media all and (max-width: 1400px) {
        #main.index .about .info-list {
          margin-right: 0; } }
      #main.index .about .info-list li {
        margin-bottom: 19px;
        display: inline-flex;
        width: 695px;
        align-items: center; }
        #main.index .about .info-list li .ttl {
          margin-right: -54px;
          padding-bottom: 2px;
          position: relative;
          z-index: 1;
          width: 108px;
          height: 108px;
          display: flex;
          align-content: center;
          justify-content: center;
          align-items: center;
          color: #fff;
          font-size: 2rem;
          font-weight: bold;
          background-color: #0055A2;
          border-radius: 50%;
          box-sizing: border-box; }
          #main.index .about .info-list li .ttl > span {
            display: block;
            text-align: center;
            line-height: 1; }
          #main.index .about .info-list li .ttl .num {
            font-size: 2.7rem; }
        #main.index .about .info-list li .txt {
          flex: 1;
          padding: 22px 15px 22px 85px;
          color: #0055A2;
          font-size: 2.4rem;
          text-align: left;
          background-color: #fff;
          border-radius: 51px;
          box-shadow: 0 0 20px rgba(191, 203, 224, 0.3); }
        #main.index .about .info-list li:first-child {
          margin-right: 27.7%; }
        #main.index .about .info-list li:nth-child(2) {
          margin-right: 18.5%; }
        #main.index .about .info-list li:nth-child(3) {
          margin-right: 9%; }
    #main.index .about .mid-img {
      position: absolute;
      left: 15px;
      bottom: -24px; }
      @media all and (max-width: 1400px) {
        #main.index .about .mid-img {
          left: -10px; } }
    @media screen and (max-width: 1060px) {
      #main.index .about .info-list li {
        width: 69vw; }
      #main.index .about .mid-img {
        width: 120px; } }
    @media screen and (max-width: 767px) {
      #main.index .about {
        padding: 23px 0 40px;
        background: linear-gradient(180deg, #fff 0%, #EFF8FF 30%, #EFF8FF 100%); }
        #main.index .about h2 {
          margin-bottom: 20px;
          font-size: 2.4rem; }
        #main.index .about .info-list {
          text-align: left; }
          #main.index .about .info-list li {
            margin-bottom: 15px;
            display: flex;
            width: auto; }
            #main.index .about .info-list li .ttl {
              margin-right: -28px;
              width: 58px;
              height: 58px;
              font-size: 1.3rem; }
              #main.index .about .info-list li .ttl > span {
                line-height: 1.1; }
              #main.index .about .info-list li .ttl .num {
                font-size: 1.6rem; }
            #main.index .about .info-list li .txt {
              padding: 11px 15px 11px 45px;
              font-size: 1.3rem;
              box-shadow: 0 0 10px rgba(191, 203, 224, 0.3); }
            #main.index .about .info-list li:first-child {
              margin-right: 0; }
            #main.index .about .info-list li:nth-child(2) {
              margin-right: 0; }
            #main.index .about .info-list li:nth-child(3) {
              margin-right: 0; }
        #main.index .about .mid-img {
          margin: 10px auto 0;
          position: static;
          left: auto;
          bottom: auto;
          width: 108px; } }
  #main.index .bg-sec {
    padding: 83px 0 77px;
    text-align: center;
    background: #1B55A2 url("../img/index/arrow.png") no-repeat center top -2px/179px auto;
    overflow: hidden; }
    #main.index .bg-sec p {
      margin-bottom: 21px;
      color: #fff;
      font-size: 3.4rem;
      font-weight: bold;
      line-height: 1.47; }
    #main.index .bg-sec .custom-btn a {
      margin: 0 auto;
      width: 392px;
      height: 74px;
      color: #0055A2;
      background: #FFF60A; }
      @media screen and (min-width: 768px) {
        #main.index .bg-sec .custom-btn a:hover {
          color: #fff;
          background: linear-gradient(180deg, #3b76d6 0%, #003489 100%); } }
    @media screen and (max-width: 767px) {
      #main.index .bg-sec {
        padding: 60px 0 40px;
        background-position: center top;
        background-size: 120px auto; }
        #main.index .bg-sec p {
          font-size: 2.2rem;
          line-height: 1.36; }
        #main.index .bg-sec .custom-btn a {
          width: 294px;
          font-size: 1.8rem; } }
  #main.index .feature {
    padding: 8px 0 84px;
    position: relative;
    overflow: hidden;
    background-color: #EDF3F9; }
    #main.index .feature .mid-txt {
      margin-bottom: 18px;
      font-size: 1.4rem;
      text-align: center; }
    #main.index .feature .point-list {
      display: flex;
      flex-wrap: wrap; }
      #main.index .feature .point-list li {
        margin: 2.53% 2.53% 0 0;
        width: 23.1%;
        height: 230px;
        padding: 5px;
        display: flex;
        align-items: center;
        justify-content: center;
        text-align: center;
        background-color: #fff;
        box-shadow: 0 0 20px rgba(191, 203, 224, 0.3);
        box-sizing: border-box; }
        #main.index .feature .point-list li:nth-child(4n) {
          margin-right: 0; }
        #main.index .feature .point-list li h3 {
          margin-bottom: 10px;
          color: #0055A2;
          font-size: 2.7rem;
          font-weight: 300;
          line-height: 1.44; }
          #main.index .feature .point-list li h3.small {
            font-size: 2.6rem; }
          #main.index .feature .point-list li h3:last-child {
            margin-bottom: 0; }
        #main.index .feature .point-list li p {
          font-size: 1.5rem; }
        @media screen and (max-width: 1060px) {
          #main.index .feature .point-list li {
            height: 23vw; }
            #main.index .feature .point-list li h3 {
              font-size: 2.5vw; }
              #main.index .feature .point-list li h3.small {
                font-size: 2.4vw; }
            #main.index .feature .point-list li p {
              font-size: 1.5vw; } }
    @media screen and (max-width: 767px) {
      #main.index .feature {
        padding: 35px 0 60px; }
        #main.index .feature .mid-txt {
          margin-bottom: 45px;
          font-size: 1.3rem; }
        #main.index .feature .point-list {
          display: block;
          margin: 0 auto;
          max-width: 210px; }
          #main.index .feature .point-list li {
            margin: 30px 0 0;
            width: auto;
            height: 210px;
            padding: 5px;
            box-shadow: 0 0 20px rgba(191, 203, 224, 0.3); }
            #main.index .feature .point-list li h3 {
              margin-bottom: 10px;
              font-size: 2.4rem !important;
              line-height: 1.5; }
            #main.index .feature .point-list li p {
              font-size: 1.3rem; } }
  #main.index .message {
    padding: 103px 0 110px; }
    #main.index .message h2 {
      margin-bottom: 44px; }
    #main.index .message .container {
      max-width: 826px; }
    #main.index .message .mid-img {
      margin-bottom: 45px; }
      #main.index .message .mid-img img {
        width: 100%; }
    #main.index .message .info-box {
      margin: 0 15px 27px 0;
      display: flex; }
      #main.index .message .info-box ul {
        flex: 1; }
        #main.index .message .info-box ul li {
          position: relative;
          display: inline-block;
          color: #1B55A2;
          font-size: 1.8rem;
          font-weight: bold;
          line-height: 2;
          text-decoration: underline; }
          @media screen and (max-width: 1060px) {
            #main.index .message .info-box ul li {
              font-size: 1.6rem; } }
          #main.index .message .info-box ul li:after {
            display: none;
            position: absolute;
            left: 0;
            bottom: 7px;
            width: 100%;
            height: 1px;
            background-color: #1B55A2;
            content: ""; }
          #main.index .message .info-box ul li span {
            padding: 2px 5px 4px;
            display: inline-block;
            border-radius: 50%;
            color: #fff;
            font-size: 1.2rem;
            line-height: 1;
            vertical-align: 2px;
            background-color: #1B55A2; }
      #main.index .message .info-box .info-img {
        margin-top: -8px;
        width: 135px; }
    #main.index .message h3 {
      margin-bottom: 13px;
      padding-bottom: 17px;
      font-size: 2.4rem;
      line-height: 1.2;
      border-bottom: 1px solid #0055A2; }
    #main.index .message .txt-dl {
      margin-bottom: 12px;
      line-height: 1.7; }
      #main.index .message .txt-dl dt {
        float: left;
        font-weight: 300; }
      #main.index .message .txt-dl dd {
        margin-right: -5px;
        padding-left: 8em; }
    #main.index .message .notes {
      font-size: 1.2rem; }
    @media screen and (max-width: 767px) {
      #main.index .message {
        padding: 58px 0 60px; }
        #main.index .message h2 {
          margin-bottom: 20px; }
        #main.index .message .mid-img {
          margin: 0 24px 26px; }
        #main.index .message .info-box {
          margin: 0 0 28px;
          display: block; }
          #main.index .message .info-box ul li {
            font-size: 1.6rem; }
            #main.index .message .info-box ul li:after {
              display: none; }
            #main.index .message .info-box ul li span {
              font-size: 1rem; }
          #main.index .message .info-box .info-img {
            display: none; }
        #main.index .message h3 {
          margin-bottom: 13px;
          padding-bottom: 10px;
          font-size: 1.8rem; }
        #main.index .message .txt-dl {
          margin-bottom: 15px;
          font-size: 1.3rem;
          line-height: 1.85; }
          #main.index .message .txt-dl dd {
            padding-left: 8.2em; } }
      @media screen and (max-width: 767px) and (max-width: 374px) {
        #main.index .message .txt-dl dd {
          padding-left: 7.8em; } }

  #main.index .flow {
    padding: 74px 0 80px;
    background-color: #EDF3F9; }
    #main.index .flow h2 {
      margin-bottom: 44px; }
    #main.index .flow .flow-box {
      padding-right: 102px;
      position: relative; }
      @media screen and (max-width: 1060px) {
        #main.index .flow .flow-box {
          padding-right: 80px; } }
      #main.index .flow .flow-box .flow-list > li {
        padding-bottom: 36px;
        display: flex;
        background: url("../img/common/arrow01.png") no-repeat left 56% bottom 11px/34px auto; }
        #main.index .flow .flow-box .flow-list > li:last-child {
          padding-bottom: 0; }
        #main.index .flow .flow-box .flow-list > li .num {
          width: 90px;
          display: flex;
          align-items: center;
          justify-content: center;
          text-align: center;
          color: #fff;
          font-family: 'Lato', sans-serif;
          background-color: #0055A2;
          border-radius: 10px 0 0 10px; }
          #main.index .flow .flow-box .flow-list > li .num > span {
            line-height: 1; }
            #main.index .flow .flow-box .flow-list > li .num > span span {
              display: block;
              font-size: 3.6rem;
              font-weight: bold;
              line-height: 0.9; }
        #main.index .flow .flow-box .flow-list > li .txt-box {
          padding: 15px 0;
          flex: 1;
          min-height: 124px;
          display: flex;
          align-items: center;
          background-color: #fff;
          border-radius: 0 10px 10px 0; }
          #main.index .flow .flow-box .flow-list > li .txt-box .ttl {
            height: 69px;
            margin-right: 26px;
            width: 215px;
            display: flex;
            justify-content: center;
            align-items: center;
            text-align: center;
            color: #0055A2;
            font-size: 2.2rem;
            line-height: 1.25;
            font-weight: bold;
            border-right: 1px solid #0055A2; }
            @media screen and (max-width: 1060px) {
              #main.index .flow .flow-box .flow-list > li .txt-box .ttl {
                margin-right: 10px;
                width: 140px;
                font-size: 2rem; } }
          #main.index .flow .flow-box .flow-list > li .txt-box .txt {
            padding-right: 10px;
            flex: 1;
            line-height: 1.7; }
            #main.index .flow .flow-box .flow-list > li .txt-box .txt li {
              text-indent: -1.1em;
              padding-left: 1.1em; }
      #main.index .flow .flow-box .side-txt li {
        position: absolute;
        right: 0;
        top: 0;
        width: 56px; }
        #main.index .flow .flow-box .side-txt li:last-child {
          top: auto;
          bottom: 0; }
    @media screen and (max-width: 767px) {
      #main.index .flow {
        padding: 40px 0 25px; }
        #main.index .flow h2 {
          margin-bottom: 32px; }
        #main.index .flow .flow-box {
          margin: 0 auto;
          max-width: 355px;
          padding-right: 52px; }
          #main.index .flow .flow-box .flow-list > li {
            padding-bottom: 44px;
            background-position: left 60% bottom 16px; }
            #main.index .flow .flow-box .flow-list > li .num {
              width: 40px;
              font-size: 1rem;
              border-radius: 5px 0 0 5px; }
              #main.index .flow .flow-box .flow-list > li .num > span span {
                margin-top: 3px;
                font-size: 2.4rem; }
            #main.index .flow .flow-box .flow-list > li .txt-box {
              padding: 12px 10px;
              min-height: inherit;
              display: block;
              border-radius: 0 5px 5px 0;
              box-shadow: 0 0 10px rgba(191, 203, 224, 0.3); }
              #main.index .flow .flow-box .flow-list > li .txt-box .ttl {
                height: auto;
                margin: 0 0 5px;
                width: auto;
                display: block;
                text-align: left;
                font-size: 1.6rem;
                border-right: none; }
              #main.index .flow .flow-box .flow-list > li .txt-box .txt {
                padding-right: 0;
                font-size: 1.2rem;
                line-height: 1.5; }
          #main.index .flow .flow-box .side-txt li {
            top: -4px;
            width: 40px; }
            #main.index .flow .flow-box .side-txt li:last-child {
              top: auto;
              bottom: -5px; } }
  #main.index .faq {
    padding: 72px 0 100px; }
    #main.index .faq h2 {
      margin-bottom: 43px; }
    #main.index .faq .qa-dl dt, #main.index .faq .qa-dl dd p {
      min-height: 120px;
      display: flex;
      align-items: center;
      padding: 35px 10% 58px 10%;
      font-size: 1.6rem;
      line-height: 1.5;
      background-color: #fff;
      box-sizing: border-box; }
      #main.index .faq .qa-dl dt:before, #main.index .faq .qa-dl dd p:before {
        margin-right: 35px;
        padding-bottom: 8px;
        width: 64px;
        min-width: 64px;
        height: 64px;
        color: #0055A2;
        font-size: 3rem;
        line-height: 1;
        display: flex;
        justify-content: center;
        align-items: center;
        box-sizing: border-box;
        border: 1px solid #0055A2;
        border-radius: 50%;
        content: "A"; }
    #main.index .faq .qa-dl dt {
      margin-bottom: 2px;
      padding: 25px 10% 25px 10%;
      color: #0055A2;
      font-weight: bold;
      cursor: pointer;
      background: rgba(0, 85, 162, 0.07) url("../img/index/icon_plus.png") no-repeat right 7% center/20px auto; }
      @media screen and (min-width: 768px) {
        #main.index .faq .qa-dl dt:hover {
          opacity: 0.7; } }
      #main.index .faq .qa-dl dt.on {
        background-image: url("../img/index/icon_minus.png"); }
      #main.index .faq .qa-dl dt:before {
        top: 28px;
        color: #fff;
        font-weight: 300;
        background-color: #0055A2;
        content: "Q"; }
    #main.index .faq .qa-dl dd {
      display: none; }
    @media screen and (max-width: 767px) {
      #main.index .faq {
        padding: 60px 0; }
        #main.index .faq h2 {
          margin-bottom: 25px; }
        #main.index .faq .qa-dl dt, #main.index .faq .qa-dl dd p {
          min-height: 120px;
          padding: 16px 30px 25px 30px;
          font-size: 1.2rem; }
          #main.index .faq .qa-dl dt:before, #main.index .faq .qa-dl dd p:before {
            margin-right: 25px;
            padding-bottom: 5px;
            width: 35px;
            min-width: 35px;
            height: 35px;
            font-size: 1.8rem; }
        #main.index .faq .qa-dl dt {
          margin-bottom: 2px;
          padding: 16px 65px 16px 30px;
          min-height: 70px;
          background-position: right 30px center;
          background-size: 17px auto; }
        #main.index .faq .qa-dl dd p {
          align-items: flex-start; } }

/* form */
#form .contact-box {
  display: none; }

.mail-form p.text-center {
  margin-bottom: 50px;
  color: #333;
  line-height: 2.1; }
.mail-form .bg-box {
  margin-bottom: 75px; }
  .mail-form .bg-box .py-5 {
    padding: 40px 0 !important; }
  .mail-form .bg-box .col-xl-6 {
    max-width: 75%;
    flex: 0 0 75%;
    border-radius: 10px !important; }
.mail-form dt {
  margin-bottom: 8px !important;
  font-size: 1.8rem; }
  .mail-form dt span {
    margin-left: 8px !important;
    padding: 0 9px 1px !important;
    font-size: 1.2rem;
    font-weight: normal;
    border-radius: 2px;
    vertical-align: 1px; }
  .mail-form dt .custom-check-free {
    background-color: #E6E6E6; }
.mail-form dd {
  margin-bottom: 45px; }
  .mail-form dd .input-item, .mail-form dd select, .mail-form dd textarea {
    padding: 10px 24px;
    width: 100%;
    height: 50px;
    color: #000;
    font-size: 1.6rem;
    box-sizing: border-box;
    border: 1px solid rgba(0, 85, 162, 0.3);
    border-radius: 0;
    appearance: none;
    -webkit-appearance: none; }
    .mail-form dd .input-item::-ms-input-placeholder, .mail-form dd select::-ms-input-placeholder, .mail-form dd textarea::-ms-input-placeholder {
      color: rgba(34, 34, 34, 0.2);
      opacity: 1; }
    .mail-form dd .input-item:-ms-input-placeholder, .mail-form dd select:-ms-input-placeholder, .mail-form dd textarea:-ms-input-placeholder {
      color: rgba(34, 34, 34, 0.2);
      opacity: 1; }
    .mail-form dd .input-item::-moz-placeholder, .mail-form dd select::-moz-placeholder, .mail-form dd textarea::-moz-placeholder {
      color: rgba(34, 34, 34, 0.2);
      opacity: 1; }
    .mail-form dd .input-item::-webkit-input-placeholder, .mail-form dd select::-webkit-input-placeholder, .mail-form dd textarea::-webkit-input-placeholder {
      color: rgba(34, 34, 34, 0.2);
      opacity: 1; }
    .mail-form dd .input-item.wid-short, .mail-form dd select.wid-short, .mail-form dd textarea.wid-short {
      width: 184px; }
    .mail-form dd .input-item.wid-short02, .mail-form dd select.wid-short02, .mail-form dd textarea.wid-short02 {
      width: 221px; }
  .mail-form dd select {
    background: url("../img/common/select_bg.png") no-repeat right 20px center/11px auto; }
  .mail-form dd select::-ms-expand {
    display: none; }
  .mail-form dd textarea {
    height: 266px; }
  .mail-form dd placeholder-shown {
    color: rgba(34, 34, 34, 0.2); }
  .mail-form dd .line {
    margin: 0 12px;
    color: #222;
    font-size: 1.6rem;
    font-weight: 500; }
  .mail-form dd .custom-btn {
    margin-left: 28px;
    padding: 9px;
    width: 122px;
    color: #fff;
    font-size: 1.5rem;
    font-weight: bold;
    letter-spacing: 0.1em;
    display: inline-block;
    text-align: center;
    border-radius: 21px;
    text-decoration: none;
    cursor: pointer; }
    @media screen and (min-width: 768px) {
      .mail-form dd .custom-btn:hover {
        color: #0055A2;
        background-color: #FFF60A; } }
  .mail-form dd.dd-style {
    margin-bottom: 58px; }
.mail-form .custom-agree {
  margin: 90px 0 30px; }
  .mail-form .custom-agree .custom-check-box {
    margin: 6px 9px 0 0; }
    .mail-form .custom-agree .custom-check-box input {
      display: none; }
    .mail-form .custom-agree .custom-check-box span {
      width: 26px;
      height: 26px;
      display: inline-block;
      background: url("../img/common/check_bg.png") no-repeat left top/26px auto; }
    .mail-form .custom-agree .custom-check-box input[type="checkbox"]:checked + span {
      background-image: url("../img/common/check_on_bg.png"); }
  .mail-form .custom-agree .custom-icon {
    display: inline-block;
    color: #222;
    font-size: 1.6rem; }
    .mail-form .custom-agree .custom-icon:after {
      margin-left: 10px;
      line-height: 0;
      font-size: 0;
      display: inline-block;
      width: 12px;
      height: 12px;
      background: url("../img/common/icon_data_black.png") no-repeat right top/12px auto;
      content: ""; }
  .mail-form .custom-agree a {
    color: #222;
    font-size: 1.6rem;
    text-decoration: underline; }
    @media screen and (min-width: 768px) {
      .mail-form .custom-agree a:hover {
        text-decoration: none; } }
.mail-form .custom-btn-submit input {
  margin: 0 auto;
  display: flex;
  width: 392px;
  height: 74px;
  font-size: 1.8rem;
  font-weight: bold;
  letter-spacing: 0.1em;
  justify-content: center;
  align-items: center;
  color: #fff;
  background: #0055A2;
  transition: all 0.3s;
  border: none;
  appearance: none;
  -webkit-appearance: none;
  border-radius: 37px; }
  @media screen and (min-width: 768px) {
    .mail-form .custom-btn-submit input:hover {
      color: #0055A2;
      background-color: #FFF60A !important; } }
  .mail-form .custom-btn-submit input:disabled {
    background: #ccc; }
    @media screen and (min-width: 768px) {
      .mail-form .custom-btn-submit input:disabled:hover {
        color: #fff;
        background-color: #ccc !important; } }
@media screen and (max-width: 767px) {
  .mail-form {
    max-width: 540px; }
    .mail-form .col-12 {
      padding: 0; }
    .mail-form p.text-center {
      margin-bottom: 44px;
      line-height: 1.7; }
    .mail-form .bg-box {
      margin: 0 auto 65px;
      max-width: 88%; }
      .mail-form .bg-box .py-5 {
        padding: 32px 0 !important; }
      .mail-form .bg-box .col-xl-6 {
        max-width: 100%;
        flex: 0 0 100%; }
        .mail-form .bg-box .col-xl-6 .text-md-right {
          margin: 0 auto;
          width: 75%; }
        .mail-form .bg-box .col-xl-6 .custom-text-blue {
          margin-bottom: 10px !important; }
        .mail-form .bg-box .col-xl-6 .small {
          font-size: 1.2rem; }
    .mail-form dt {
      margin-bottom: 8px !important;
      font-size: 1.8rem; }
      .mail-form dt span {
        margin-left: 25px !important; }
    .mail-form dd {
      margin-bottom: 47px; }
      .mail-form dd .input-item, .mail-form dd select, .mail-form dd textarea {
        padding: 10px 23px; }
        .mail-form dd .input-item.wid-short, .mail-form dd select.wid-short, .mail-form dd textarea.wid-short {
          width: calc(50% - 43px); }
        .mail-form dd .input-item.wid-short02, .mail-form dd select.wid-short02, .mail-form dd textarea.wid-short02 {
          width: 50%; }
      .mail-form dd textarea {
        height: 172px; }
      .mail-form dd .line {
        margin: 0 8px; }
      .mail-form dd .custom-btn {
        margin: 10px 0 0; }
      .mail-form dd select {
        background-position: right 12px center; }
    .mail-form .custom-agree {
      margin: 50px 0 55px; }
      .mail-form .custom-agree .custom-icon {
        display: block; }
    .mail-form .custom-btn-submit input {
      margin: 0 auto;
      max-width: 294px;
      width: 100%;
      height: 74px; } }

.confirm h2 {
  margin-bottom: 95px; }
.confirm .custom-form {
  margin: 0 auto 94px;
  max-width: 595px; }
  .confirm .custom-form > div {
    margin-bottom: 54px !important;
    display: flex; }
    .confirm .custom-form > div dt {
      width: 201px; }
    .confirm .custom-form > div dd {
      margin-bottom: 0;
      flex: 1;
      color: #333;
      font-size: 1.8rem;
      line-height: 1.67; }
.confirm .txt-link {
  margin-top: 23px;
  text-align: center; }
  .confirm .txt-link a {
    font-size: 1.6rem;
    text-decoration: underline; }
    @media screen and (min-width: 768px) {
      .confirm .txt-link a:hover {
        text-decoration: none; } }
@media screen and (max-width: 767px) {
  .confirm h2 {
    margin-bottom: 55px;
    font-size: 2.9rem; } }
  @media screen and (max-width: 767px) and (max-width: 374px) {
    .confirm h2 {
      font-size: 2.6rem; } }
@media screen and (max-width: 767px) {
  .confirm .custom-form {
    margin-bottom: 50px; }
    .confirm .custom-form > div {
      margin-bottom: 30px !important;
      display: block; }
      .confirm .custom-form > div dt {
        width: auto; }
      .confirm .custom-form > div dd {
        font-size: 1.6rem; } }

.thankyou {
  min-height: calc(100vh - 613px); }
  .thankyou h2 {
    margin-bottom: 52px;
    font-size: 3rem;
    line-height: 1.47; }
  .thankyou p {
    color: #333;
    font-size: 1.6rem;
    line-height: 1.875; }
  .thankyou .btn {
    margin: 0 auto;
    padding: 0;
    display: block;
    width: 392px; }
    .thankyou .btn a {
      display: flex;
      height: 74px;
      font-size: 1.8rem;
      font-weight: bold;
      letter-spacing: 0.1em;
      justify-content: center;
      align-items: center;
      color: #fff;
      background: #0055A2;
      border-radius: 50px; }
      @media screen and (min-width: 768px) {
        .thankyou .btn a:hover {
          color: #0055A2;
          background-color: #FFF60A !important; } }
  @media screen and (max-width: 767px) {
    .thankyou {
      min-height: inherit; }
      .thankyou h2 {
        margin-bottom: 30px;
        font-size: 2.6rem; }
      .thankyou p {
        font-size: 1.4rem; } }
    @media screen and (max-width: 767px) and (max-width: 374px) {
      .thankyou p {
        font-size: 1.3rem; } }
  @media screen and (max-width: 767px) {
      .thankyou .btn {
        max-width: 540px;
        width: 100%; }
        .thankyou .btn a {
          height: 64px;
          font-size: 1.8rem; } }

strong {
  font-weight: bold;
}











/* 下層用のCSSが準備されていないので、同系のページから転用 */


/* ==========================================================================
  component
========================================================================== */
/* font */
.custom-ff-lato {
  font-family: "Lato", sans-serif;
}

/* marker */
.custom-marker {
  background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(0%, #FFF60A));
  background: -webkit-linear-gradient(transparent 60%, #FFF60A 0%);
  background: linear-gradient(transparent 60%, #FFF60A 0%);
  display: inline;
  /*横に余白をつけたり、下にずらしたりするときは以下のpaddingを調整してください*/
  padding: 0 2px 4px;
}

/* small */
@media (max-width: 575px) {
  .custom-small {
    font-size: 0.9375rem;
  }
}

@media (min-width: 576px) and (max-width: 767px) {
  .custom-small {
    font-size: 0.9375rem;
  }
}

@media (min-width: 768px) {
  .custom-small {
    font-size: 1.125rem;
  }
}

/* custom-h3-sp */
@media (max-width: 575px) {
  .custom-h3-sp {
    font-size: 1.375rem;
  }
}

@media (min-width: 576px) and (max-width: 767px) {
  .custom-h3-sp {
    font-size: 1.5rem;
  }
}

/* custom-text-blue */
.custom-text-blue {
  color: #0055A2;
}

/* custom-bg-blue */
.custom-bg-blue {
  background-color: #0055A2;
}

/* custom-bg-lblue */
.custom-bg-lblue {
  background-color: #F2F4F9;
}

/* custom-d-block 910px以下 block */
.custom-d-block--nav {
  display: block;
}

@media (min-width: 911px) {
  .custom-d-block--nav {
    display: none;
  }
}

/* custom-d-none--nav 910px以上 none */
.custom-d-none--nav {
  display: none;
}

@media (min-width: 911px) {
  .custom-d-none--nav {
    display: block;
  }
}

/* custom-btn */
.btn.custom-btn--yel, .btn.custom-btn--login, .btn.custom-btn--link, .btn.custom-btn--blueonly {
  width: 80%;
  font-size: 1.125rem;
  border-radius: 3.75rem;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

@media (min-width: 768px) {
  .btn.custom-btn--yel, .btn.custom-btn--login, .btn.custom-btn--link, .btn.custom-btn--blueonly {
    width: 100%;
  }
}

.btn.custom-icon--blank, a.custom-icon--blank {
  position: relative;
}

.btn.custom-icon--blank:after, a.custom-icon--blank:after {
  content: '';
  position: absolute;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: 0 0;
}

.btn.custom-btn--yel {
  color: #0055A2;
  background-color: #FFF60A;
}

.btn.custom-btn--yel:hover {
  background-color: #fff;
}

.btn.custom-btn--login {
  color: #E60012;
  border: 1px #E60012 solid;
  background-color: #fff;
}

.btn.custom-btn--login:hover {
  color: #fff;
  background-color: #E60012;
}

.btn.custom-btn--link {
  color: #0055A2;
  border: 1px #0055A2 solid;
  background-color: #fff;
}

.btn.custom-btn--link:hover {
  color: #fff;
  background-color: #0055A2;
}

.btn.custom-btn--blueonly {
  width: 100%;
  background-color: #0055A2;
}

.btn.custom-btn--blueonly:hover {
  opacity: 0.7;
}

@media (min-width: 768px) {
  .btn.custom-btn {
    width: 100%;
  }
}

.btn.custom-icon--blank:after {
  top: 50%;
  right: 3rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 11px;
  height: 11px;
  background-image: url(/seino/uriPlus/assets/img/common/icon_blank@2x.png);
}

a {
  display: block;
}

a.custom-icon--blank:after {
  top: 50%;
  right: 1rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 11px;
  height: 11px;
  background-image: url(/seino/uriPlus/assets/img/common/icon_blank@2x.png);
}

@media (min-width: 768px) and (max-width: 991px) {
  a.custom-icon--blank:after {
    right: 1rem;
  }
}

@media (min-width: 992px) and (max-width: 1199px) {
  a.custom-icon--blank:after {
    right: 2rem;
  }
}

@media (min-width: 1200px) {
  a.custom-icon--blank:after {
    right: 4rem;
  }
}

a.custom-btn--blue {
  position: relative;
  z-index: 1;
  display: inline-block;
  width: 100%;
  padding: 10px 20px;
  border-radius: 60px;
  background: #3b76d6;
  background: -webkit-gradient(linear, left top, left bottom, from(#3b76d6), to(#003489));
  background: -webkit-linear-gradient(top, #3b76d6 0%, #003489 100%);
  background: linear-gradient(180deg, #3b76d6 0%, #003489 100%);
  color: #fff;
  text-decoration: none;
}

a.custom-btn--blue::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  border-radius: 60px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  border: 1px #fff60a solid;
  background: #fff60a;
  background: -webkit-gradient(linear, left top, left bottom, from(#fff60a), to(#fff60a));
  background: -webkit-linear-gradient(top, #fff60a 0%, #fff60a 100%);
  background: linear-gradient(180deg, #fff60a 0%, #fff60a 100%);
  opacity: 0;
  -webkit-transition: opacity 0.2s;
  transition: opacity 0.2s;
}

@media (min-width: 768px) {
  a.custom-btn--blue:hover::before {
    opacity: 1;
    -webkit-transform: translateX(-1px);
            transform: translateX(-1px);
  }
}

@media (min-width: 768px) {
  a.custom-btn--blue:hover {
    color: #0055A2;
  }
}

a.custom-btn--bdr-blue {
  /* font-size: 0.875rem; */
  font-size: 1.4rem;
  border: 1px #0055A2 solid;
  border-radius: 100px;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

a.custom-btn--bdr-blue:hover {
  color: #fff;
  background-color: #0055A2;
  text-decoration: none;
}

a.custom-link-bdr {
  color: #0055A2;
  text-decoration: underline;
}

a .custom-icon--blank-inline {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}

@media (min-width: 768px) {
  a .custom-icon--blank-inline {
    display: inline;
  }
}

a .custom-icon--blank-inline:after {
  content: '';
  display: inline-block;
  width: 11px;
  height: 11px;
  margin-left: 1rem;
  background-image: url(/seino/uriPlus/assets/img/common/icon_blank@2x.png);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: 0 0;
}

a.custom-hover {
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}

a.custom-hover:hover {
  opacity: 0.7;
  text-decoration: none;
}

/* custom-container__wrap */
.custom-container__wrap.custom-bg--blue {
  background-color: #0055A2;
}

/* row > custom-mx */
@media (max-width: 575px) {
  .row.custom-mx-row-sp {
    margin-left: 0;
    margin-right: 0;
  }
}

@media (min-width: 576px) and (max-width: 767px) {
  .row.custom-mx-row-sp {
    margin-left: 0;
    margin-right: 0;
  }
}

/* 下層共通 */
.page-underlayer .main {
  height: 100%;
  max-height: 100%;
  padding-top: 56px;
}

@media (min-width: 911px) {
  .page-underlayer .main {
    padding-top: 77px;
  }
}

.page-underlayer .main.custom-main-bottom {
  padding-bottom: 100px;
}

@media (min-width: 768px) {
  .page-underlayer .main.custom-main-bottom {
    padding-bottom: 180px;
  }
}

.page-underlayer .main.custom-main-bottom-none {
  padding-bottom: 0;
}

.page-underlayer .main .custom-h2__wrap .custom-h2 {
  font-size: 2.25rem;
}

@media (min-width: 768px) {
  .page-underlayer .main .custom-h2__wrap .custom-h2 {
    font-size: 2.5rem;
  }
}

.page-underlayer .main .custom-h2__wrap > span {
  font-size: 0.875rem;
  line-height: 1.8;
}


/* ==========================================================================
  voice
========================================================================== */
.page-underlayer.page-voice .custom-sec__wrap.voice {
  padding-bottom: 5rem;
}

@media (min-width: 768px) {
  .page-underlayer.page-voice .custom-sec__wrap.voice {
    padding-bottom: 1rem;
  }
}

.page-underlayer.page-voice .custom-sec__wrap.voice .custom-case .custom-case-block {
  width: 100%;
  margin-bottom: 3rem;
}

@media (min-width: 768px) {
  .page-underlayer.page-voice .custom-sec__wrap.voice .custom-case .custom-case-block {
    width: 30%;
  }
}

.page-underlayer.page-voice .custom-sec__wrap.voice .custom-case .custom-case-block a {
  display: block;
  overflow: hidden;
  height: 100%;
  border-radius: 10px;
  color: #333;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
}

.page-underlayer.page-voice .custom-sec__wrap.voice .custom-case .custom-case-block a:hover {
  text-decoration: none;
  -webkit-box-shadow: 0 3px 15px rgba(191, 203, 224, 0.3);
          box-shadow: 0 3px 15px rgba(191, 203, 224, 0.3);
}

.page-underlayer.page-voice .custom-sec__wrap.voice .custom-case .custom-case-block a .custom-case-inner .custom-case-photo {
  margin: 0;
}

.page-underlayer.page-voice .custom-sec__wrap.voice .custom-case .custom-case-block a .custom-case-inner .custom-case-photo img {
  width: 100%;
}

.page-underlayer.page-voice .custom-sec__wrap.voice .custom-case .custom-case-block a .custom-case-inner .custom-case-texts__wrap {
  padding: 1em;
}

.page-underlayer.page-voice .custom-sec__wrap.voice .custom-case .custom-case-block a .custom-case-inner .custom-case-texts {
  font-size: 0.875rem;
}

.page-underlayer.page-voice .custom-sec__wrap.voice .custom-case .custom-case-block a .custom-case-inner .custom-case-company {
  font-size: 0.625rem;
}

.custom-details-body {
  padding: 3rem 0 8rem;
}

@media (min-width: 768px) {
  .custom-details-body {
    padding: 5rem 0 8rem;
  }
}

.custom-details-body .custom-photo {
  overflow: hidden;
  border-radius: 10px;
}

.custom-details-body .custom-photo img {
  width: 100%;
}

.custom-details-body .custom-company .custom-company-name {
  margin-top: 5px;
  font-size: 1.2rem;
  /* font-size: 0.875rem; */
  line-height: 1.8rem;
}

@media (min-width: 768px) {
  .custom-details-body .custom-company .custom-company-name {
    font-size: 1.4rem;
  }
}

.custom-details-body .custom-company .custom-company-logo {
  width: 84px;
}

@media (min-width: 768px) {
  .custom-details-body .custom-company .custom-company-logo {
    width: 100%;
  }
}

.custom-details-body .custom-company .custom-company-logo img {
  width: 100%;
}

@media (min-width: 768px) and (max-width: 991px) {
  .custom-details-body .custom-company .custom-company-logo img {
    max-width: 100px;
  }
}

@media (min-width: 992px) and (max-width: 1199px) {
  .custom-details-body .custom-company .custom-company-logo img {
    max-width: 130px;
  }
}

@media (min-width: 1200px) {
  .custom-details-body .custom-company .custom-company-logo img {
    max-width: 150px;
  }
}

.custom-details-body .custom-h2 {
  font-size: 1.125rem;
  color: #0055A2;
  line-height: 1.5;
}

@media (min-width: 768px) {
  .custom-details-body .custom-h2 {
    /* font-size: 2.125rem; */
    font-size: 3.4rem;
    line-height: 1.4;
  }
}

.custom-details-body .custom-texts {
  line-height: 1.6;
}

@media (max-width: 575px) {
  .custom-details-body .custom-texts {
    font-size: 0.8125rem;
  }
}

@media (min-width: 576px) and (max-width: 767px) {
  .custom-details-body .custom-texts {
    font-size: 0.8125rem;
  }
}

@media (min-width: 768px) {
  .custom-details-body .custom-texts {
    line-height: 1.8;
    font-size: 1.15em;
  }
}

.custom-details-body .custom-btn {
  margin-top: 4rem;
}

@media (min-width: 768px) {
  .custom-details-body .custom-btn {
    margin-top: 7rem;
  }
}

