body{ 
    font-family: "Helvetica Neue", Helvetica, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", 游ゴシック, "Yu Gothic", メイリオ, Meiryo, "ＭＳ Ｐゴシック", sans-serif; 
    font-weight: 400; 
    font-size: 16px; 
    color: #202020;
  } 
  div.wrap{ 
      overflow: hidden; 
  } 
  .container { 
      max-width: 1080px; 
  } 
  @media screen and (max-width: 1010px){ 
    .container { 
        padding: 0 1.5rem; 
    } 
  } 
  @media screen and (max-width: 460px){ 
    nav.is-fixed-top .container { 
        padding: 0 1.5rem 0 0 ; 
    } 
  } 
  @media screen and (min-width:769px){
    .overwidth {
      margin: 0 -200% !important;
      padding: 0 200%;
    }
  }
  .has-image-centered { 
    margin-left: auto; 
    margin-right: auto; 
    display: block; 
  } 
  .has-margin-1{ 
      margin-top: 70px; 
      margin-bottom:70px; 
  } 
  .has-margin-2{ 
      margin-top: 60px; 
      margin-bottom:60px; 
  } 
  .has-margin-3{ 
      margin-top: 50px; 
      margin-bottom:50px; 
  } 
  .has-margin-4{ 
      margin-top: 40px; 
      margin-bottom:40px; 
  } 
  .has-margin-5{ 
      margin-top: 30px; 
      margin-bottom:30px; 
  } 
  .has-margin-6{ 
      margin-top: 20px; 
      margin-bottom:20px; 
  } 
  .has-margin-7{ 
      margin-top: 10px !important; 
      margin-bottom:10px !important; 
  } 
  .has-margin-top-150{ 
      margin-top: 150px; 
  } 
  .has-margin-top-100{ 
      margin-top: 100px; 
  } 
  .has-margin-top-1{ 
      margin-top: 70px; 
  } 
  .has-margin-top-2{ 
      margin-top: 60px; 
  } 
  .has-margin-top-3{ 
      margin-top: 50px !important; 
  } 
  .has-margin-top-4{ 
      margin-top: 40px; 
  } 
  .has-margin-top-5{ 
      margin-top: 30px; 
  } 
  .has-margin-top-6{ 
      margin-top: 20px; 
  } 
  .has-margin-top-7{ 
      margin-top: 10px !important; 
  } 
  .has-margin-bottom-1{ 
      margin-bottom: 70px !important; 
  } 
  .has-margin-bottom-2{ 
      margin-bottom: 60px !important; 
  } 
  .has-margin-bottom-3{ 
      margin-bottom: 50px !important; 
  } 
  .has-margin-bottom-4{ 
      margin-bottom: 40px !important; 
  } 
  .has-margin-bottom-5{ 
      margin-bottom: 30px !important; 
  } 
  .has-margin-bottom-6{ 
      margin-bottom: 20px !important; 
  } 
  .has-margin-bottom-7{ 
      margin-bottom: 10px; 
  } 
  .has-margin-bottom-90{ 
    margin-bottom: 90px !important; 
  } 
  .has-margin-bottom-100{ 
    margin-bottom: 100px !important; 
  } 
  .has-padding-1{ 
      padding-top: 70px; 
      padding-bottom:70px; 
  } 
  .has-padding-2{ 
      padding-top: 60px; 
      padding-bottom:60px; 
  } 
  .has-padding-3{ 
      padding-top: 50px; 
      padding-bottom:50px; 
  } 
  .has-padding-4{ 
      padding-top: 40px; 
      padding-bottom:40px; 
  } 
  .has-padding-5{ 
      padding-top: 30px; 
      padding-bottom:30px; 
  } 
  .has-padding-6{ 
      padding-top: 20px; 
      padding-bottom:20px; 
  } 
  .has-padding-7{ 
      padding-top: 10px; 
      padding-bottom:10px; 
  } 
  .has-padding-8{ 
    padding-top: 5px; 
    padding-bottom:5px; 
} 
  .has-padding-top-1{ 
      padding-top: 70px; 
  } 
  .has-padding-top-2{ 
      padding-top: 60px; 
  } 
  .has-padding-top-3{ 
      padding-top: 50px; 
  } 
  .has-padding-top-4{ 
      padding-top: 40px; 
  } 
  .has-padding-top-5{ 
      padding-top: 30px; 
  } 
  .has-padding-top-6{ 
      padding-top: 20px; 
  } 
  .has-padding-top-7{ 
      padding-top: 10px; 
  } 
  .has-padding-top-90{ 
    padding-top: 90px; 
  } 
  .has-padding-bottom-1{ 
      padding-bottom: 70px !important; 
  } 
  .has-padding-bottom-2{ 
      padding-bottom: 60px; 
  } 
  .has-padding-bottom-3{ 
      padding-bottom: 50px; 
  } 
  .has-padding-bottom-4{ 
      padding-bottom: 40px; 
  } 
  .has-padding-bottom-5{ 
      padding-bottom: 30px; 
  } 
  .has-padding-bottom-7{ 
      padding-bottom: 10px; 
  } 
  .has-padding-bottom-90{ 
    padding-bottom: 90px; 
  } 
  .has-padding-bottom-155{ 
      padding-bottom: 155px !important; 
  } 
  .reverse-row-order { 
    flex-direction: row-reverse; 
  } 
  .is-vertical-center { 
    display: flex; 
    align-items: center; 
  } 
  .columns.is-vcentered { 
    -webkit-box-align: center; 
       -ms-flex-align: center; 
          align-items: center; 
  } 

/* global-setting */ 
a img:hover, 
a:hover{ 
    opacity: .7; 
} 
@media screen and (min-width:1024px) { 
    nav.navbar .navbar-burger {
        display: block;
    }
}
@media screen and (max-width:550px) { 
    section .container{ 
        padding: 0 0.5rem; 
    } 
}

/* navbar */
nav.navbar {
    min-height: 90px;
    z-index: 401;
    background: #202020;
}
.navbar-item {
    background: #FFF;
    padding: .5rem 2.45rem;
}
.navbar-item img {
    max-height: 90px;
}

.navbar .navbar-brand>a.navbar-item:hover{
    background-color: #fff;
    opacity: 1;
}

.separator {
    position: relative;
    z-index:1;
    width: 60px;
    height: 90px;
    margin-left: -1px;
}
.separator:before {
    position: absolute;
    content: "";
    width: 60px;
    height: 90px;
    background-color: #fff;
    clip-path: polygon(100% 0, 0 0, 0 100%);
  }
   
  .separator:after {
    position: absolute;
    content: "";
    width: 60px;
    height: 90px;
    background-color: #202020;
    clip-path: polygon(100% 0, 0 100%, 100% 100%);
  }

  .navbar-menu{
    display: block;
}
.inquiry {
  position: absolute;
  top: 10px;
  right: 95px;
}

.hamburger {
  position: fixed;
  right: 15px;
  top: 10px;
  width: 70px;
  height: 69px;
  cursor: pointer;
  background: #e6e400;
  padding: 20px;
}

.menu-trigger,
.menu-trigger span {
  display: inline-block;
  transition: all .4s;
  box-sizing: border-box;
}
.menu-trigger {
  position: relative;
  width: 30px;
  height: 24px;
  background: none;
  border: none;
  appearance: none;
  cursor: pointer;
}
.menu-trigger span {
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #202020;
  border-radius: 4px;
}
.menu-trigger span:nth-of-type(1) {
  top: 0;
}
.menu-trigger span:nth-of-type(2) {
  top: 11px;
}
.menu-trigger span:nth-of-type(3) {
  bottom: 0;
}

.nav-open .menu-trigger span:nth-of-type(1){
  top: -9px;
}
.nav-open .menu-trigger span:nth-of-type(3) {
  bottom: -9px;
}


.menu-trigger span:nth-of-type(1) {
  animation: menu-bar01 .75s forwards;
}
@keyframes menu-bar01 {
  0% {
    transform: translateY(20px) rotate(45deg);
  }
  50% {
    transform: translateY(20px) rotate(0);
  }
  100% {
    transform: translateY(0) rotate(0);
  }
}
.menu-trigger span:nth-of-type(2) {
  transition: all .25s .25s;
  opacity: 1;
}
.menu-trigger span:nth-of-type(3) {
  animation: menu-bar02 .75s forwards;
}
@keyframes menu-bar02 {
  0% {
    transform: translateY(-20px) rotate(-45deg);
  }
  50% {
    transform: translateY(-20px) rotate(0);
  }
  100% {
    transform: translateY(0) rotate(0);
  }
}
.nav-open .menu-trigger span:nth-of-type(1) {
  animation: active-menu-bar01 .75s forwards;
}
@keyframes active-menu-bar01 {
  0% {
    transform: translateY(0) rotate(0);
  }
  50% {
    transform: translateY(20px) rotate(0);
  }
  100% {
    transform: translateY(20px) rotate(45deg);
  }
}
.nav-open .menu-trigger span:nth-of-type(2) {
  opacity: 0;
}
.nav-open .menu-trigger span:nth-of-type(3) {
  animation: active-menu-bar03 .75s forwards;
}
@keyframes active-menu-bar03 {
  0% {
    transform: translateY(0) rotate(0);
  }
  50% {
    transform: translateY(-20px) rotate(0);
  }
  100% {
    transform: translateY(-20px) rotate(-45deg);
  }
}

@media screen and (max-width: 1023px){
    .navbar-menu {
        padding: 0;
    }
  }

  @media screen and (max-width: 480px){
    .navbar-item img {
        height: 40px;
        width: 100%;
    }
    .navbar-item {
        background: #FFF;
        padding: .5rem .45rem;
    }
  }
  @media screen and (max-width: 375px){
    .navbar-item img {
        height: 45px;
        width: auto;
    }
    .navbar-item {
        background: #FFF;
        padding: .5rem .25rem;
    }
    .hamburger{
      right: 5px;
    }
    .inquiry{
      right: 80px;
    }
  }

/* keyvisual */
#main .section.keyvisual{
    padding-top: 0;
}
#main .keyvisual {
	height: 100vh;
	overflow: hidden;
	position: relative;
	width: 100%;
    background: url(../images/kv_patean.png) ,linear-gradient(to bottom, #48484817, rgb(54 54 54 / 44%));
    background-position: 90%;

}

#main .hero-body{
    position: relative;
}

.kv-bg {
	-webkit-transform: translateX(-50%);
	left: 50%;
	max-height: initial;
	max-width: initial;
	min-height: 100vh;
	min-width: 100%;
	position: absolute;
	top: 0;
	transform: translateX(-50%);
	z-index: -1;
  zoom: 1.2;
}
.kv-content {
	-webkit-transform: translate(-50%, -50%);
	left: 50%;
	position: absolute;
	text-align: center;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 100%;
	padding: 0 24px;
	z-index: 2;
}

.kv-title {
	color: #fff;
	font-size: 34px;
	font-weight: bold;
}

.hero-body a {
    position: absolute;
    bottom: 20px;
    left: 0;
    right: 0;
    margin: auto;
    z-index: 2;
    display: inline-block;
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
    text-decoration: none;
  }

  .hero-body a {
    padding-top: 70px;
    color: #fff;
    font-size: 20px;
}
  .hero-body a span {
    position: absolute;
    top: 0;
    left: 50%;
    width: 24px;
    height: 24px;
    margin-left: -12px;
    border-left: 1px solid #fff;
    border-bottom: 1px solid #fff;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    -webkit-animation: sdb 1.5s infinite;
    animation: sdb 1.5s infinite;
    box-sizing: border-box;
  }
  @-webkit-keyframes sdb {
    0% {
      -webkit-transform: rotate(-45deg) translate(0, 0);
      opacity: 0;
    }
    50% {
      opacity: 1;
    }
    100% {
      -webkit-transform: rotate(-45deg) translate(-20px, 20px);
      opacity: 0;
    }
  }
  @keyframes sdb {
    0% {
      transform: rotate(-45deg) translate(0, 0);
      opacity: 0;
    }
    50% {
      opacity: 1;
    }
    100% {
      transform: rotate(-45deg) translate(-20px, 20px);
      opacity: 0;
    }
  }

  @media screen and (max-width: 480px){
    .kv-title {
      font-size: 30px;
    }
  }

/* messageboxes */

section.messagebox{
    padding-top: 170px;
    padding-bottom: 140px;
    border-top: 15px solid #FFF;
}

section.messagebox h2 img{
    max-width: 507px;
}

section.messagebox p{
    color: #FFF;
}

section.messagebox p.subtitle{
    font-size: 32px;
    margin-top: 20px;
}

.btn,
a.btn,
button.btn {
  font-size: 1.2rem;
  line-height: 1.5;
  position: relative;
  display: inline-block;
  padding: 1rem 4rem;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  text-align: center;
  vertical-align: middle;
  text-decoration: none;
  color: #212529;
  border-radius: 0.5rem;
}

a.btn-svg {
  line-height: 54px;

  width: 204px;
  height: 54px;
  padding: 0;

  cursor: pointer;
  text-decoration: none;

  background-color: #e6e400;
}

a.btn-svg svg {
  position: absolute;
  top: 0;
  left: 0;

  width: 100%;
  height: 100%;
}

a.btn-svg svg rect {
  -webkit-transition: all 400ms ease;
  transition: all 400ms ease;

  stroke: #000;
  stroke-width: 2;
  stroke-dasharray: 200px, 16px;
  stroke-dashoffset: 70px;
}

a.btn-svg:hover svg rect {
  stroke-dashoffset: 284px;
}

a.btn-svg span {
  color: #000;
}

@media screen and (max-width: 768px){
    section.messagebox h2 img{
        max-width: 100%;
    }
}


/* message01 */
section.message01{
    background: url(../images/bg_message01.jpg);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
}

/* message02 */
section.message02{
    background: url(../images/bg_message02.jpg);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
}

/* message03 */
section.message03{
    background: url(../images/bg_message03.jpg);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
}

/* message04 */
section.message04{
    background: url(../images/bg_message04.jpg);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
}
/* message05 */
section.message05{
    background: url(../images/bg_message05.jpg);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
}

/* footer */

section.footer {
    background: #f2f000;
    padding: 0 0 1rem;
}
.footer_nav {
    background: url(../images/footer_bg.png);
}

body#main.footer_nav {
  border-top: 15px solid #fff;
}

.footer_nav a{
    font-size: 15px;
    color: #000;
}
.footer_nav a:hover{
  text-decoration: underline;
}
section.section.footer div:nth-child(2) ul{
    margin-left: 15px;
}

@media screen and (min-width: 769px){
    section.section.footer div:nth-child(3) ul{
        margin-left: -40px;
    }
}

@media screen and (max-width: 768px){
  section.section.footer div:nth-child(2) ul,
  section.section.footer div:nth-child(4) ul{
        margin-left: 30px;
    }
}



div.footer_nav ul li{
    position: relative;
    margin-bottom: 20px;
}

div.footer_nav li:before {
    content: "■";
    color: #fff;
    font-size: 5px;
    position: absolute;
    top: 18%;
    left: -10px;
}


/* side-action */

.side-action img:hover{
    -webkit-filter: brightness(1.2);
    -moz-filter: brightness(1.2);
    -o-filter: brightness(1.2);
    -ms-filter: brightness(1.2);
    filter: brightness(1.2);
}

.side-action a:hover,
a img:hover{
    opacity: 1;
}

@media screen and (min-width: 769px){
  .side-action {
    position: fixed;
    right: 0;
    top: 50%;
    max-width: 75px;
  }
}

@media screen and (max-width: 768px){
  .side-action {
    position: fixed;
    bottom: 4px;
    max-width: 70%;
  }
  .copyright{
    padding-bottom:90px ;
  }
}

/* pagetop */
.c-pageTop {
    position: fixed;
    right: 20px;
    bottom: 10px;
    z-index: 4900;
}

a.btn--circle {
    width: 60px;
    height: 60px;
    padding: 0;
    background: #fff;
    border-radius: 50%;
    -webkit-box-shadow: 0 3px 5px rgba(0, 0, 0, .3);
    box-shadow: 0 3px 5px rgba(0, 0, 0, .3);
  }
  
  a.btn--circle i {
    font-size: 150%;
    line-height: 60px;
    -webkit-transition: all .3s;
    transition: all .3s;
    letter-spacing: 0;
  }
  a.btn--circle:hover i {
    line-height: 55px;
  }


  /*sidemenu*/


  .global-nav {
    position: fixed;
    right: -350px;
    top: 0;
    width: 350px;
    height: 100vh;
    padding-top: 75px;
    /* background-color: #0009; */
    transition: all .6s;
    z-index: 301;
    overflow-y: auto;
    color: #000;
  }

  .global-nav__list {
    margin: 0;
    padding: 15px 0 0 0;
    list-style: none;
  }
  .global-nav__item {
    text-align: left;
    padding: 0 14px;
  }
  .global-nav__item{
    
  }
  .global-nav__item:before {
      content: "";
      /* background: url(../images/list01.png); */
      width: 7px;
      height: 7px;
      position: absolute;
      margin-top: 23px;
  }
  .global-nav__item:after {
    content: "";
    background-image: url(../images/arrow_right.png);
    background-repeat: no-repeat;
    background-size: contain;
    width: 10px;
    height: 21px;
    position: absolute;
    right: 25px;
    margin-top: -41px;
}
  .global-nav__item a,
  .global-nav__item label {
    display: block;
    padding: 20px 15px;
    text-decoration: none;
    color: #FFF;
    margin-left: 20px;
    background: #262726;
    border-bottom: 1px solid #606060;
  }
  .global-nav__item a:hover {
    background: #e6e400;
    color: #262726;
  }
  .global-nav__item:hover:after{
    background-image: url(../images/arrow_right_on.png);
  }
  .global-nav__btn img {
      max-width: 80%;
      margin: auto;
      display: block;
      margin-top: 15px;
  }
  .hamburger__line {
    position: absolute;
    left: 11px;
    width: 18px;
    height: 1px;
    background-color: #fff;
    transition: all .6s;
  }
  .hamburger__line--1 {
    top: 14px;
  }
  .hamburger__line--2 {
    top: 20px;
  }
  .hamburger__line--3 {
    top: 26px;
  }
  .black-bg {
    position: fixed;
    left: 0;
    top: 0;
    width: 100vw;
    height: 100vh;
    z-index: 100;
    background-color: #000;
    opacity: 0;
    visibility: hidden;
    transition: all .6s;
    cursor: pointer;
  }
  img#link0{
    position: fixed;
    visibility: hidden;
  }


  .nav-open .global-nav {
    right: 0;
  }
  .nav-open .black-bg {
    opacity: .8;
    visibility: visible;
  }
  .nav-open .hamburger__line--1 {
    transform: rotate(45deg);
    top: 20px;
  }
  .nav-open .hamburger__line--2 {
    width: 0;
    left: 50%;
  }
  .nav-open .hamburger__line--3 {
    transform: rotate(-45deg);
    top: 20px;
  }
  .nav-open img#link0 {
    visibility: visible;
    position: fixed;
    width: 50px;
    height: 50px;
    right: 10px;
    top: 10px;
}

  .global-nav__item.subnav:after{
    content:none;
  }

  .global-nav__item.subnav label{
    padding-bottom: 5px;
  }

  .global-nav__item.subnav label:after {
      content: url(../images/arrow_bottom.png);
      display: inline-block;
      vertical-align: middle;
      -webkit-transform: scale(0.3);
      transform: scale(0.3);
      position: absolute;
      right: 1px;
  }

  .global-nav__item.subnav input:checked + label:after{
      content: url(../images/arrow_top.png);
  }


  .acd-check{
      display: none;
  }
  .acd-label{
      display: block;
      margin-bottom: 1px;
      padding: 10px;
  }
  .acd-content{
      height: 0;
      opacity: 0;
      padding: 0 10px;
      transition: 0s;
      visibility: hidden;
  }
  .acd-check:checked + .acd-label + .acd-content{
      height: 450px;
      opacity: 1;
      padding: 10px;
      visibility: visible;
  }

  .subnav_title{
    margin-left: 20px;
    margin-top: 10px;
    margin-bottom: 5px;
  }

  .subnav_title:before {
      content: "";
      background: url(../images/list01.png);
      width: 7px;
      height: 7px;
      position: absolute;
      left: 25px;
      margin-top: 7px;
  }

  .subnav ul li a:before {
      content: "";
      background: url(../images/list01.png);
      width: 7px;
      height: 7px;
      position: absolute;
      left: 40px;
      margin-top: 8px;
  }

  .global-nav__item.subnav a{
    margin-left: 30px;
    padding: 10px 0;
  }

  .global-nav__item img{
      max-width: 220px;
  }

  /* subpage */

@media screen and (min-width: 1024px) {
  body.subpage .hero {
    padding: 5rem 1.5rem;
  }
}

nav.breadcrumb.has-succeeds-separator {
  background: #202020;
  padding: 0.6rem;
  margin-bottom: 0;
}
nav.breadcrumb a {
  color: #FFF;
  font-size: 14px;
}
nav.breadcrumb a:hover{
  color: #FFF;
  opacity: .7;
}
.breadcrumb li.is-active a {
  color: #FFF;
  cursor: default;
  pointer-events: none;
}
nav.breadcrumb a:hover{
  color: #e6e400;
}


/* page common */



.column.sectiontitle h2,
body.subpage .titlebox h2{
  font-size: 30px;
  border-bottom: 3px solid #e6e400;
}
@media screen and (max-width: 768px) {
  body.subpage .titlebox h2,
  body#about .notice h2{
    font-size: 26px;
  }
}

body.subpage section.titlebox .column.sectiontitle{
  background-position: center;
}



  /* page service */

body#service .keyvisual{
  background: url(../images/kv_service.jpg);
  background-size: cover;
}

#service section.section.bankin div.columns:nth-of-type(odd) .is-7,
#service section.section.toso div.columns:nth-of-type(odd) .is-7,
#service section.section.shaken div.columns:nth-of-type(odd) .is-7,
#service section.section.other div.columns:nth-of-type(odd) .is-7 {
  margin-left: -100px;
}
#service section.section.bankin div.columns:nth-of-type(even) .is-7,
#service section.section.toso div.columns:nth-of-type(even) .is-7,
#service section.section.shaken div.columns:nth-of-type(even) .is-7,
#service section.section.other div.columns:nth-of-type(even) .is-7 {
  margin-right: -100px;
}

@media screen and (max-width: 768px) {
  body#service .column.is-3 p {
    padding: 0px 15px;
  }
  body#service .column.sectiontitle{
    padding: 30px 30px !important;
  }
  section.section.bankin.overwidth,
  section.section.toso.overwidth,
  section.section.shaken.overwidth,
  section.section.pther.overwidth {
    padding-top: 0;
  }
}

@media screen and (min-width: 769px){
  body#service .column.is-offset-1{
    margin-left: 4.33333%;
  }
  body#service .columns.has-margin-top-5.reverse-row-order {
    margin-left: -5.93333%;
  }
  body#service .columns.row-order{
    margin-right: -11.63333%;
  }
}

body#service .column.sectiontitle{
  color: #fff;
  padding: 120px 100px;
}

body#service section.titlebox.service01 .column.sectiontitle{
  background: url(../images/bg_title_service01.jpg);
  background-size: cover;
  background-position: center;
}

body#service section.titlebox.service02 .column.sectiontitle{
  background: url(../images/bg_title_service02.jpg);
  background-size: cover;
  background-position: center;
}

body#service section.titlebox.service03 .column.sectiontitle{
  background: url(../images/bg_title_service03.jpg);
  background-size: cover;
  background-position: center;
}

body#service section.titlebox.service04 .column.sectiontitle{
  background: url(../images/bg_title_service04.jpg);
  background-size: cover;
  background-position: center;
}

body#service h3{
  background: #000;
  color: #e6e400;
  padding-left: 20px;
}

body#service h4{
  border-bottom: 1px solid #000;
  padding-bottom: 10px;
}

@media screen and (min-width: 769px){
  body#service .column.is-3.is-offset-2 {
    padding-left: 0;
  }
  body#service .column.is-3.is-offset-1{
    padding-right: 0;
  }
  body#service section.titlebox{
    margin-top: 80px !important;
  }
  body#service .column.shaken02.is-offset-2 {
    padding-left: 0;
  }
  body#service .column.sectiontitle h2{
    width: 50%;
  }
  body#service .column.sectiontitle p{
    width: 50%;
  }
}

  /* page about */

  body#about .keyvisual{
    background: url(../images/kv_about.jpg);
    background-size: cover;
    background-position: center;
  }
  body#about .contentarea{
    background: url(../images/bg_about.jpg);
    background-size: contain;
    background-repeat: no-repeat;
  }

  body#about section.subtitlebox{
    margin-bottom: 12vw !important;
  }
  body#about .notice{
    background: url(../images/bg_about_notice.jpg);
    background-size: contain;
  }

  #about .notice h2{
    font-size: 30px;
    border-bottom: 3px solid #fff;
  }

  body#about section.titlebox .about02{
    background: url(../images/bg_title_about02.jpg);
    background-size: cover;
    background-position: top 0px right 0px;
    min-height: 28vw;
  }
  body#about section.titlebox .about03{
    background: url(../images/bg_title_about03.jpg);
    background-size: cover;
    background-position: top 0px left 0px;
    min-height: 28vw;
  }
  body#about .column.sectiontitle{
    color: #fff;
    padding: 110px 50px 50px;
  }
  body#about a.btn-svg{
    background-color:transparent;
  }
  body#about a.btn-svg span{
    color: #fff;
  }
  body#about a.btn-svg svg rect{
    stroke: #fff;
  }

  @media screen and (max-width: 768px){
    body#about section.subtitlebox{
      background: #202020;
    }
    body#about section.titlebox .about02{
      background: url(../images/bg_title_about02_sp.png);
      background-size: contain;
      background-repeat: no-repeat;
    }
    body#about section.titlebox .about03{
      background: url(../images/bg_title_about03_sp.png);
      background-size: contain;
      background-repeat: no-repeat;
    }
  }


  @media screen and (min-width: 769px){
    .aboutimg{
      position: relative;
    }
    .aboutimg img{
      position: absolute;
      top:120px;
    }
  }
  @media screen and (max-width: 480px){
    body#about .column.sectiontitle{
      padding: 110px 1.5rem 50px;
    }
  }
  
  /* page staff */

  body#staff .keyvisual{
    background: url(../images/kv_staff.jpg);
    background-size: cover;
    background-position: center;
  }
  body#staff .contentarea{
    background: url(../images/bg_staff.jpg);
    background-size: contain;
    background-repeat: no-repeat;
  }

  body#staff .subtitlebox{
    margin-bottom: 50px !important;
  }

  body#staff .sectiontitle{
    padding-top: 0;
  }

  body#staff .sectiontitle h3{
    background: #ffff7c80;
    padding: 20px;
    font-weight: bold;
    font-size: 20px;
  }

  body#staff .staffinfo{
    background: #00000091;
    padding: 90px 55px;
    color: #fff;
    min-height: 500px;
  }
  body#staff .staffinfo h4{
    font-size: 1.2em;
  }
  body#staff .staffinfo h5{
    margin-top: 15px;
  }

  body#staff .staffinfo span{
    display: block;
    color: #e6e400;
    font-size: .8em;
    margin-bottom: 15px;
  }
  .column.staffprofile {
    min-height: 500px;
    background-position: right -150px top 0 !important;
}

  body#staff .staff01{
    background: url(../images/staff_01.jpg);
    background-size: cover;
  }
  body#staff .staff02{
    background: url(../images/staff_02.jpg);
    background-size: cover;
  }
  body#staff .staff03{
    background: url(../images/staff_03.jpg);
    background-size: cover;
  }
  body#staff .staff04{
    background: url(../images/staff_04.jpg);
    background-size: cover;
  }
  body#staff .staff05{
    background: url(../images/staff_05.jpg);
    background-size: cover;
  }
  body#staff .staff06{
    background: url(../images/staff_06.jpg);
    background-size: cover;
  }
  body#staff .staff07{
    background: url(../images/staff_07.jpg);
    background-size: cover;
  }
  body#staff .staff08{
    background: url(../images/staff_08.jpg);
    background-size: cover;
  }
  body#staff .staff09{
    background: url(../images/staff_09.jpg);
    background-size: cover;
  }
  body#staff .staff10{
    background: url(../images/staff_10.jpg);
    background-size: cover;
  }
  body#staff .staff11{
    background: url(../images/staff_11.jpg);
    background-size: cover;
  }
  body#staff .staff12{
    background: url(../images/staff_12.jpg);
    background-size: cover;
  }
  body#staff .staff13{
    background: url(../images/staff_13.jpg);
    background-size: cover;
    margin-bottom: 120px;
  }



  @media screen and (min-width: 1400px){
    .column.staffprofile {
      min-height: 500px;
      background-position: right 0px top 0 !important;
    }
  }

  @media screen and (min-width: 940px) and (max-width: 1285px){
    .staffprofile {
      background-position: right 0 center !important;
      background-repeat: no-repeat !important;
    }
  }
  @media screen and (min-width: 769px) and (max-width: 939px){
    .staffprofile {
      background-position: right -170px center !important;
      background-repeat: no-repeat !important;
    }
    .staffprofile.staff02,
    .staffprofile.staff07,
    .staffprofile.staff13{
      background-position: right -230px center !important;
    }
  }
  @media screen and (max-width: 768px){
    .staffprofile {
      background-position: right -92px center !important;
    }
    body#staff .staffinfo{
      padding: 180px 55px 0;
    }
  }

  .dailyschedule{
    background: url(../images/bg_schedule.jpg);
    background-size: contain;
  }

  .dailyschedule h2{
    font-size: 30px;
    border-bottom: 3px solid #e6e400;
  }

  .dailyschedule dt,
   .dailyschedule dd {
    padding: 10px;
    margin: 0 25px;
  }
  .dailyschedule dt{
    background: #e6e400;
    
  }
  .dailyschedule dt:first-child{
    margin-top: 20px;
  }
  .dailyschedule dt:not(:first-child){
    margin-top: 45px;
  }
  .dailyschedule dd{
    background: #fff;
    position: relative;
  }
  .dailyschedule dd:not(:last-child):after {
    content: "";
    position: absolute;
    top: 45px;
    left: 50%;
    width: 2px;
    height: 35px;
    background-color: black;
}

  /* page benefits */

  body#benefits .keyvisual{
    background: url(../images/kv_benefits.jpg);
    background-size: cover;
    background-position: center;
  }
  body#benefits .contentarea{
    background: url(../images/bg_benefits.jpg);
    background-size: contain;
    background-repeat: no-repeat;
  }

  .benefitslist h3{
    background: #e6e400;
    font-size: 25px;
    font-weight: bold;
    padding: 3px 20px;
    margin-bottom: 20px;
  }
  .benefitslist p{
    margin-bottom: 30px;
  }

  .license h3{
    font-size: 22px;
  }
  .license h3:before {
    content: "";
    font-size: 22px;
    display: inline-block;
    width: 18px;
    height: 18px;
    background: #e6e400;
    margin-right: 5px;
  }
  .license h4{
    background: #000;
    color: #e6e400;
    width: 150px;
    margin: 15px 0;
  }
  .license dd{
    border-bottom: 1px solid #000;
    padding-bottom: 15px;
    margin-bottom: 20px;
  }


  /* page rinen */

  body#rinen .keyvisual{
    background: url(../images/kv_rinen.jpg);
    background-size: cover;
    background-position: center;
  }
  body#rinen .contentarea{
    background: url(../images/bg_rinen.jpg);
    background-size: contain;
    background-repeat: no-repeat;
  }

  body#rinen{
    counter-reset: number 0;
  }

  .rinencard {
    background: #e6e400a1;
  }
  .rinencard h3{
    position: relative;
    padding-left: 70px;
  }
  .rinencard h3:before {
    content: " ";
    font-family: monospace, serif;
    font-weight: 100;
    color: #fff;
    display: block;
    font-size: 4em;
    position: absolute;
    left: 0;
    top: -11px;
}

body#rinen section:nth-child(2) h3:before{
  background: url(../images/rinen_no1.png);
  background-repeat: no-repeat;
  width: 38px;
  height: 80px;
}
body#rinen section:nth-child(3) h3:before{
  background: url(../images/rinen_no2.png);
  background-repeat: no-repeat;
  width: 62px;
  height: 80px;
}
body#rinen section:nth-child(4) h3:before{
  background: url(../images/rinen_no3.png);
  background-repeat: no-repeat;
  width: 62px;
  height: 80px;
  background-size: contain;
}
body#rinen section:nth-child(5) h3:before{
  background: url(../images/rinen_no4.png);
  background-repeat: no-repeat;
  width: 62px;
  height: 80px;
  background-size: contain;
}
body#rinen section:nth-child(6) h3:before{
  background: url(../images/rinen_no5.png);
  background-repeat: no-repeat;
  width: 62px;
  height: 80px;
  background-size: contain;
}

@media screen and (min-width: 1024px){
  .rinen02 p{
    min-height: 264px;
  }
}

  @media screen and (min-width: 769px){
    .rinencardwrap{
      display: flex;
      justify-content: center;
      align-items: center;
    }
    .rinencard h3 {
      min-height: 70px;
      display: flex;
      align-items: center;
  }
    .rinencard{
      max-width: 500px;
    }
    .rinencard.cardright{
      margin-left: -25vw;
      padding: 50px 80px;
    }
    .rinencard.cardleft{
      margin-right: -15vw;
      padding: 50px 80px;
      z-index: 0;
    }
    body#rinen .columns.reverse-row-order {
      margin-right: 8vw;
    }
  }

  @media screen and (max-width: 768px){
    .rinencard{
      padding: 30px 20px;
      margin-top: -8vw;
    }
    .rinencard h3{
      min-height: 70px;
      display: flex;
      align-items: center;
    }
    #rinen .section{
      padding-top: 0;
      padding-bottom: 0;
    }
  }
  .rinen02{
    background-image: url(../images/bg_rinen02.jpg);
    color: #FFF;
    background-size: contain;
    background-repeat: no-repeat;
    background-color: #202020;
  }
  .rinen02 h3{
    border-bottom: 3px solid #e6e400;
    font-size: 24px;
    margin-bottom: 15px;
  }

    /* page company */

  body#company .keyvisual{
    background: url(../images/kv_company.jpg);
    background-size: cover;
    background-position: center;
  }



  body#company .contentarea:first-of-type{
    background: url(../images/bg_company.jpg);
    background-size: contain;
    background-repeat: no-repeat;
  }
  body#company .contentarea:nth-of-type(2){
    background: url(../images/bg_access.jpg);
    background-size: cover;
    color: #FFF;
  }

  .companyinfo dl {
    display: flex;
    flex-flow: row wrap;
    width: 100%;
    }
  .companyinfo dt {
    flex-basis: 23%;
    padding: 10px;
    background-color: #202020;
    color: #e6e400;
    border-bottom: 2px solid #fff;
    border-right: 2px solid #fff ;
  }
  .companyinfo dd {
  flex-basis: 77%;
  padding: 10px;
  background-color: #eee;
  border-bottom: 2px solid #fff;
  }
  @media screen and (max-width: 768px) {
    .companyinfo dl {
    flex-flow: column;
    }
  }
  @media screen and (min-width: 769px) {
    .topmessage p{
      margin-left: 50px;
    }
  }

  .companyhistory dl {
    display: flex;
    flex-flow: row wrap;
    width: 100%;
  }
  .companyhistory dt {
    flex-basis: 23%;
    padding: 10px;
    background-color: #e6e400;
    color: #202020;
    border-bottom: 2px solid #fff;
    border-right: 2px solid #fff ;
  }
  .companyhistory dd {
  flex-basis: 77%;
  padding: 10px;
  background-color: #eee;
  border-bottom: 2px solid #fff;
  }
  @media screen and (max-width: 768px) {
    .companyhistory dl {
    flex-flow: column;
    }
  }

  .access h3{
    border-bottom: 1px solid #e6e400;
  }

  
  /* page privacy */

  body#privacy .keyvisual{
    background: url(../images/kv_privacy.jpg);
    background-size: cover;
    background-position: center;
  }

  body#privacy .contentarea:first-of-type{
    background: url(../images/bg_privacy.jpg);
    background-size: contain;
    background-repeat: no-repeat;
  }

  /* page saiyou */

  body#saiyou .keyvisual{
    background: url(../images/kv_saiyou.jpg);
    background-size: cover;
    background-position: center;
  }

  body#saiyou .contentarea:first-of-type{
    background: url(../images/bg_saiyou.jpg);
    background-size: contain;
    background-repeat: no-repeat;
  }

  .saiyouinfo h3{
    background: #202020;
    color: #e6e400;
    max-width: 250px;
  }

  .saiyouinfo p{
    border-bottom: 1px solid #000;
    padding-bottom: 20px;
    margin-bottom: 20px;
  }

  .saiyouimg img{
    max-width: 50%;
  }
  
  @media screen and (max-width: 768px) {
    .saiyouimg img{
      max-width: 80%;
    }
  }

  /* page contact */

  body#contact .keyvisual{
    background: url(../images/kv_contact.jpg);
    background-size: cover;
    background-position: center;
  }
  body#contact .contentarea{
    background: url(../images/bg_contact.jpg);
    background-size: contain;
    background-repeat: no-repeat;
  }

  .webform .req:before{
    content:"必須";
    display: inline-block;
    width: 40px;
    font-size: .8em;
    background: #e6e400;
    padding: 2px 5px;
  }

  .webform .any:before{
    content:"任意";
    display: inline-block;
    width: 40px;
    font-size: .8em;
    background: #ddd;
    padding: 2px 5px;
  }

  section.webform a.btn.btn-svg span{
    font-size: 16px;
  }

  
  input[type="radio"] {
    display: none;
  }
  
  .radio-text:before {
    content: "";
    display: inline-block;
    position: absolute;
    left: 0;
    width: 18px;
    height: 18px;
    margin-right: 6px;
    border-width: 1px;
    border-style: solid;
    border-radius: 50%;
    padding: 2px;
    background-clip: content-box;
  }
  .radio-text{
    padding-left: 20px;
    margin-right: 8px;
  }
  
  input[type="radio"]:not(:checked) + .radio-text:before {
    border-color: #72767b;
  }
  
  input[type="radio"]:checked + .radio-text:before {
    border-color: #eb6100;
    background-color: #eb6100;
  }
  .radio+.radio {
    margin-left: 0;
}

.webform a.has-underline{
  color: #202020;
  text-decoration: underline;
}