@charset "UTF-8";
/* Scss Document */
/* Color Palette */
/* Padding */
/* Heder Space */
/* Wrap */
/*-----------
Root
-------------*/
:root {
  --large: 8rem;
  --medium: 5rem;
  --small: 2rem;
  --transition: all 0.3s ease; }

@media screen and (max-width: 1024px) {
  :root {
    --large: 5rem;
    --medium: 3rem;
    --small: 1.5rem; } }
@media screen and (max-width: 640px) {
  :root {
    --large: 3rem;
    --medium: 2rem;
    --small: 1rem; } }
@font-face {
  font-family: 'NeuePlak';
  src: url("../fonts/woff2/NeuePlakTextforUnited-Rg.woff2") format("woff2"), url("../fonts/woff/NeuePlakTextforUnited-Rg.woff") format("woff");
  font-weight: 400; }
@font-face {
  font-family: 'NeuePlak';
  src: url("../fonts/woff2/NeuePlakTextforUnited-Bd.woff2") format("woff2"), url("../fonts/woff/NeuePlakTextforUnited-Bd.woff") format("woff");
  font-weight: 700; }
@font-face {
  font-family: 'NeuePlak';
  src: url("../fonts/woff2/NeuePlakTextforUnited-SmBd.woff2") format("woff2"), url("../fonts/woff2/NeuePlakTextforUnited-SmBd.woff") format("woff2");
  font-weight: 600; }
html, body {
  scroll-padding-top: 100px; }
  @media (max-width: 640px) {
    html, body {
      scroll-padding-top: 120px; } }

/* ------------------
背景・文字色用カラー指定 
------------------*/
.white {
  color: #ffffff; }

.black {
  color: #000000; }

.united-blue {
  color: #1414d2; }

.bg-united-blue {
  background: #1414d2;
  color: #ffffff; }

.bg-white {
  background-color: #ffffff;
  color: #000000; }

.bg-light-green {
  background: #dcfae6; }

.bg-dark-blue {
  background-color: #051464;
  color: #ffffff; }

.bg-medium-purple {
  background: #695fe6; }

.bg-light-tonal-gray {
  background-color: #f7f4f2; }

/* ------------------
アニメーション指定 
------------------*/
.fadeIn {
  opacity: 0;
  transform: translateY(50px);
  transition: all .75s 0s ease; }

.fadeIn.second {
  transition: all .75s 0.5s ease; }

.fadeInTtl {
  opacity: 0;
  transform: translateY(50px);
  transition: all .75s 0s ease; }

@keyframes show {
  from {
    opacity: 0; }
  to {
    opacity: 1; } }
@keyframes slideIn {
  0% {
    transform: translateX(180px);
    opacity: 0; }
  100% {
    transform: translateX(0); }
  40%,100% {
    opacity: 1; } }
.slideIn {
  animation: slideIn 1s cubic-bezier(0.25, 1, 0.5, 1) 1 forwards; }

/* ------------------
共通指定 
------------------*/
html {
  font-size: 62.5%;
  -webkit-text-size-adjust: 100%; }

body {
  font-family: 'NeuePlak', 'Open Sans', 'Noto Sans JP', 'hiragino kaku gothic pro', sans-serif;
  font-size: 1.6em;
  /*font-optical-sizing: auto;
  font-style: normal;*/ }
  @media (max-width: 640px) {
    body {
      /*font-size: 1.4em;*/ } }

h1 {
  text-align: center; }

h1, h2, h3, h4 h5 {
  line-height: 1.6;
  font-weight: 500; }

p {
  line-height: 1.6; }

a {
  color: #1414d2;
  text-decoration: none; }
  a .fas {
    margin: 0 .25rem;
    opacity: .4;
    transform: scale(0.8); }

a.cta {
  text-decoration: underline; }

a:hover {
  color: #0D0D8F; }

div, img {
  vertical-align: bottom; }

.note {
  font-size: 80%; }

.large-wrapper {
  width: 90%;
  max-width: 1440px;
  margin: auto; }

.small-wrapper {
  width: 90%;
  max-width: 1080px;
  margin: auto; }

.pic {
  width: 100%;
  height: auto; }

.pc-only {
  display: block; }
  @media (max-width: 1024px) {
    .pc-only {
      display: none; } }
  @media (max-width: 640px) {
    .pc-only {
      display: none; } }

.pcsp-only {
  display: block; }
  @media (max-width: 1024px) {
    .pcsp-only {
      display: none; } }
  @media (max-width: 640px) {
    .pcsp-only {
      display: block; } }

.pctab-only {
  display: block; }
  @media (max-width: 640px) {
    .pctab-only {
      display: none; } }

.tabsp-only {
  display: none; }
  @media (max-width: 1024px) {
    .tabsp-only {
      display: block; } }

.sp-only {
  display: none; }
  @media (max-width: 640px) {
    .sp-only {
      display: block; } }

.btn {
  display: inline-block;
  padding: 1.4rem 3rem 1.5rem 3rem;
  box-sizing: border-box;
  border-radius: 30px;
  text-align: center;
  color: #ffffff;
  font-weight: 500;
  background: #1414d2;
  border: 1px solid #FFF;
  transition: 0.3s;
  text-decoration: none;
  font-weight: 500; }
  @media (max-width: 640px) {
    .btn {
      padding: 1.5rem;
      margin: 1rem 0; } }
  .btn.navi {
    padding: 1.4rem 3rem 1.5rem 3rem; }
    @media (max-width: 640px) {
      .btn.navi {
        padding: .8rem 1.5rem; } }
  .btn:hover {
    /*border: solid 2px $medium-blue;*/
    background: #0D0D8F;
    color: #ffffff; }

.line-btn {
  color: #1414d2;
  border: solid 2px #1414d2;
  background: #fff;
  box-sizing: border-box;
  transition: .3s; }
  .line-btn:hover {
    background: #fff;
    color: #3D3077;
    border: solid 2px #3D3077; }

/* ------------------
Header
------------------*/
header {
  background: #ffffff;
  position: fixed;
  width: 100%;
  z-index: 999;
  top: 0;
  left: 0;
  transition: .3s;
  box-shadow: 0 0px 20px rgba(0, 0, 0, 0.3);
  vertical-align: middle;
  display: flex;
  align-items: center;
  /*padding-left:20px;*/ }
  header nav {
    margin: 0 auto;
    width: 96%;
    height: 90px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: .3s; }
    @media (max-width: 640px) {
      header nav {
        width: calc(100% - 3rem);
        height: 52px !important; } }
    @media (max-width: 640px) {
      header nav div {
        display: flex;
        align-items: center;
        justify-content: center;
        position: absolute;
        top: 0;
        right: -100vw;
        opacity: 0;
        width: 100%;
        height: 100vh;
        background: rgba(20, 20, 210, 0.9);
        transition: 0.3s; } }
    header nav div ul {
      display: flex; }
      @media (max-width: 640px) {
        header nav div ul {
          display: block;
          width: 90%;
          margin: auto;
          padding: 0 0 6rem; } }
      header nav div ul li {
        display: flex;
        align-items: center; }
        @media (max-width: 640px) {
          header nav div ul li {
            display: block; } }
        header nav div ul li a {
          padding: .75rem;
          font-weight: 600;
          font-size: 1.5rem;
          color: #1414d2;
          text-decoration: none; }
          @media (max-width: 640px) {
            header nav div ul li a {
              padding: 1.4rem 0;
              display: block;
              font-size: 2rem;
              color: #ffffff;
              text-align: center; } }
          header nav div ul li a span {
            font-weight: normal;
            font-size: 1rem;
            display: block;
            margin: 0 0 .3rem; }
            @media (max-width: 640px) {
              header nav div ul li a span {
                font-size: 3vw; } }
        header nav div ul li .btn {
          padding: 1.4rem;
          margin: 0 0 0 1rem;
          box-sizing: border-box;
          font-size: 1.4rem; }
          @media (max-width: 1412px) {
            header nav div ul li .btn {
              width: 100%;
              border: solid 2px #ffffff; } }
          @media (max-width: 640px) {
            header nav div ul li .btn {
              padding: 1.8rem 1rem; } }
        @media (max-width: 1412px) {
          header nav div ul li .line-btn {
            color: #ffffff;
            background: rgba(255, 255, 255, 0.2);
            border: solid 2px #ffffff; } }
        header nav div ul li:nth-last-child(3) a {
          border: none; }

#logo-united {
  width: 160px;
  height: auto;
  transition: .3s; }
  @media (max-width: 640px) {
    #logo-united {
      width: 80px !important; } }

a.active-link {
  position: relative;
  font-weight: 700;
  opacity: 1; }
  a.active-link span {
    font-weight: 700; }
  a.active-link:before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    background: #051464;
    width: calc(100% - 1.5rem);
    height: 2px; }
    @media (max-width: 1412px) {
      a.active-link:before {
        background: none; } }
  a.active-link:after {
    content: '';
    position: absolute;
    top: -2px;
    left: 50%;
    transform: translateX(-50%);
    background: #051464;
    width: calc(100% - 1.5rem);
    height: 2px; }
    @media (max-width: 1412px) {
      a.active-link:after {
        background: none; } }

/* ------------------
Global navigation button
------------------*/
@media (max-width: 640px) {
  .active {
    opacity: 1;
    visibility: visible;
    right: 0;
    overflow: scroll; }

  #g-nav-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 1.4rem;
    z-index: 99;
    transition: 0.3s; }
    #g-nav-btn div {
      width: 28px;
      height: 28px;
      position: relative;
      transition-duration: 1s; }
      #g-nav-btn div span {
        display: block;
        position: absolute;
        width: 28px;
        height: 2px;
        background: #1414d2;
        transition-duration: .2s; }
        #g-nav-btn div span:nth-child(1) {
          top: 4px; }
        #g-nav-btn div span:nth-child(2) {
          top: 50%;
          transform: translateY(-50%); }
        #g-nav-btn div span:nth-child(3) {
          bottom: 4px; }

  #g-nav-btn.active {
    transform: translateY(-50%); }
    #g-nav-btn.active span:nth-child(1) {
      top: 10px;
      transform: rotate(-45deg); }
    #g-nav-btn.active span:nth-child(2) {
      opacity: 0; }
    #g-nav-btn.active span:nth-child(3) {
      top: 10px;
      transform: rotate(45deg); } }
/* ------------------
Footer
------------------*/
footer {
  /*padding: 5rem 2rem;*/
  text-align: center;
  background: #051464;
  color: #ffffff;
  padding: 3rem 0;
  margin: 0 auto; }
  footer h1, footer h2 {
    color: #ffffff; }
  footer .footer-logo {
    width: 25%;
    max-width: 250px;
    margin: 0 auto;
    margin: 2rem auto; }
    @media (max-width: 640px) {
      footer .footer-logo {
        width: 40%; } }
  footer .footerdate {
    text-align: center;
    font-size: 2rem;
    margin: 1rem auto; }
