@charset "utf-8";

/* ==================================
COMMON
===================================== */
.pc-none {
    display: none !important;
}
.lato-font {
    font-family: 'Lato', sans-serif !important;
}
.heading-025 {
    position: relative;
    padding-top: .75em;
    color: #333333;
    font-size: 32px;
    font-weight: bold;
    margin-bottom: 30px;
}
.heading-025::before {
    position: absolute;
    bottom: .1em;
    left: 0;
    z-index: 0;
    color: rgba(105, 205, 216, 0.4);
    font-size: 60px;
    line-height: 1;
    content: attr(data-word);
    pointer-events: none;
    font-family: 'Lato', sans-serif !important;
}
.heading-025 span {
    position: relative;
    border-bottom: 4px solid #AAD877;
}
.btn-under-line {
    position: relative;
}
.btn-under-line a {
    position: relative;
    font-family: 'Lato', sans-serif;
    padding: 10px 75px 10px 0 !important;
}
.btn-under-line a span {
    padding-bottom: 5px;
    border-bottom: 2px solid #AAD877;
}
.btn-under-line a::before {
    content: "";
    position: absolute;
    display: inline-block;
    width: 40px;
    height: 40px;
    background-image: url(/dcms_media/image/btn-blue.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    transition: all .3s;
}
.btn-under-line a:hover:before {
    right: 0;
}
.common-header {
    background: -moz-linear-gradient(left, #69CDD8, #AAD877);
    background: -webkit-linear-gradient(left, #69CDD8, #AAD877);
    background: linear-gradient(to right, #69CDD8, #AAD877);
}
.rounded {
    border-radius: 10px !important;
}
.list-none {
    padding: 0;
    margin: 0;
}
.list-none li {
    list-style: none;
}

/* ==================================
HEADER
===================================== */
.company-name {
    font-size: 22px;
    font-weight: bold;
}
header .openbtn {
    display: none;
}
.page_index .bs_header-01.bs_header-01-drop.navbar-light .navbar-nav li:first-child a.nav-link {
    border-bottom: 2px solid #AAD877;
}
.bs_header-01.bs_header-01-drop .navbar-nav .nav-item {
  	display:-webkit-box;
  	display:-ms-flexbox;
  	display:flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}

/* ==================================
footer
===================================== */
.footer-menu {
    padding: 100px 0;
}
.footer-menu .lato-font {
    font-size: 22px;
    font-weight: 900;
}
.footer-menu a {
    color: #333;
}
.footer-menu a:hover {
    text-decoration: none;
}
.footer-address {
    margin-bottom: 20px;
    font-size: 14px;
}
.footer-menu .col {
    margin-bottom: 30px;
}
.footer-menu .list-unstyled {
    margin-top: 10px;
}
.footer-menu .list-unstyled li {
    position: relative;
    font-size: 14px;
    padding-left: 20px;
}
.footer-menu .list-unstyled li::before {
    position: absolute;
    content: "";
    width: 10px;
    height: 1px;
    background-color: #333;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
}


/* ==================================
TOP
===================================== */
.top-main {
    width: 100%;
    height: auto;
    position: relative;
    margin-top: -87px;
}
#top-video {
    width: 100%;
    height: 100%;
    position: relative;
    display: flex;
}
#top-video .mv-catchcopy {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 96%;
}
#top-video .mv-catchcopy h1, #top-video .mv-catchcopy p {
    text-align: center;
    color: #fff;
}
#top-video .mv-logo {
    width: 60%;
    margin: auto;
    animation: zoomIn 5s ease-in-out forwards;
    transform: scale(0,0);
}
@keyframes zoomIn {
    100% {
      transform: scale(1,1);
    }
}
#top-video .mv-logo img {
    width: 100%;
    height: auto;
}

@media only screen and (max-width: 991px) {
    .top-main {
        margin-top: auto;
    }
    .mv-catchcopy .main-title {
        font-size: 40px;
    }
}
@media only screen and (max-width: 820px) {
    #top-video .mv-logo {
        width: 50%;
    }
}
@media only screen and (max-width: 690px) {
.top-main {
    height: auto;
    margin-top: 0;
}
.mv-catchcopy .main-title {
    font-size: 20px;
}
.mv-catchcopy .sub-title {
    font-size: 14px;
}
#top-video .mv-logo {
    width: 40%;
}
}
.top-mv {
    margin-top: -87px;
}
.main-title {
    font-size: 60px;
}
.sub-title {
    font-size: 20px;
    font-weight: bold;
}
.top-service {
    position: relative;
    padding-top: 100px;
}
.top-service::before {
    position: absolute;
    content: "";
    background-color: #69CDD8;
    left: -5vw;
    top: -25vh;
    width: 700px;
    height: 700px;
    z-index: -1;
    border-radius: 100%;
}
.top-service::after {
    position: absolute;
    content: "";
    background-color: #AAD877;
    left: -7vw;
    bottom: 5vh;
    width: 400px;
    height: 400px;
    z-index: -1;
    border-radius: 100%;
}
.top-service  .heading-025::before {
    color: #fff;
}
.top-service .dlb_title-h3 {
    font-size: 30px;
    margin-bottom: 60px;
}
.service-block .col {
    margin-bottom: 60px;
}
.service-title {
    font-size: 24px;
    font-weight: bold;
    position: absolute;
    bottom: 0;
    left: 0;
    background-color: rgba(255, 255, 255, 0.8);
    padding: 22px 100px 22px 44px;
    margin: 0;
    border-radius: 0 0 0 10px;
}
.service-title::before {
    content: "";
    position: absolute;
    display: inline-block;
    width: 40px;
    height: 40px;
    background-image: url(/dcms_media/image/btn-black.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
    transition: all .3s;
}
.service-title:hover:before {
    right: 10px;
}
.service2 {
    margin-top: 40px;
}
.service3 {
    margin-top: -40px;
}
.service1 .img-fluid, .service2 .img-fluid, .service3 .img-fluid, .service4 .img-fluid {
    position: relative;
    cursor: pointer;
    overflow: hidden;
    width: 100%;
    border-radius: 10px;
}
.service1 .img-fluid img, .service2 .img-fluid img, .service3 .img-fluid img, .service4 .img-fluid img {
  height: auto;
  transition: transform .6s ease;
}
.service1 .img-fluid:hover img , .service2 .img-fluid:hover img , .service3 .img-fluid:hover img, .service4 .img-fluid:hover img {
  transform: scale(1.1); /* 拡大 */
}
.service1 a, .service2 a, .service3 a, .service4 a {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
}
.slider-font-wrap {
    padding: 200px 0 0;
    overflow: hidden;
    position: relative;
}
.slider-font-top {
    position: absolute;
    width: 100%;
    left: 0;
    top: 0;
}
.slider-font-top .slider-font {
  position: absolute;
  top: .2em;
  left:0;
  width: 15.2em;
  height: auto;
  color: #f4f4f4 !important;
  font-size: 120px;
  font-weight:400;
  line-height: 1!important;
  text-align: center;
  z-index: -1;
  white-space: nowrap;
  font-family: 'Lato', sans-serif;
}
.slider-font-top .slider-font.txt1 {
  left: 0;
  animation: flowimg 30s linear infinite;
  font-family: "Edu AU VIC WA NT Hand";
}
.slider-font-top .slider-font.txt2 {
  left: 15.2em;
  animation: flowimg 30s linear infinite;
  font-family: "Edu AU VIC WA NT Hand";
}
@keyframes flowimg {
  0% { transform: translateX(0); }
  100% { transform: translateX(-100%); }
}
.top-company {
    position: relative;
    margin-bottom: 100px;
    padding-top: 150px;
}
.top-company::before {
    position: absolute;
    content: "";
    background-color: #69CDD8;
    right: -15vw;
    top: 0;
    width: 670px;
    height: 670px;
    z-index: 0;
    border-radius: 100%;
}
.top-company-in {
    position: relative;
    padding: 80px 0 60px;
}
.top-company-in::before {
    position: absolute;
    content: "";
    background-color: #fff;
    top: 0;
    left: 0;
    width: 90vw;
    height: 100%;
    z-index: -1;
}
.top-company-in::after {
    position: absolute;
    content: "";
    background-color: #69CDD8;
    left: -1vw;
    top: -2vh;
    width: 50px;
    height: 50px;
    z-index: -1;
    border-radius: 100%;
}
.top-company .container {
    margin-top: 0;
    margin-bottom: 0;
}
.top-company .dlb_title-h3 {
    font-size: 30px;
    margin-bottom: 30px;
}
.top-company p {
    margin-bottom: 30px;
}
.top-company .img-block {
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 40vw;
}
.top-company .img-block .img-fluid {
    position: relative;
}
.top-company .img-block .img-fluid::before {
    position: absolute;
    content: "";
    background-color: #AAD877;
    left: -3vw;
    bottom: -4vh;
    width: 100px;
    height: 100px;
    z-index: -1;
    border-radius: 100%;
}
.top-company img {
    border-radius: 10px 0 0 10px;
}
.top-recruit-csr {
    position: relative;
}
.top-recruit-csr::before {
    position: absolute;
    content: "";
    background-color: #AAD877;
    right: -8vw;
    bottom: 20vh;
    width: 460px;
    height: 460px;
    z-index: 0;
    border-radius: 100%;
}
.top-recruit-csr::after {
    position: absolute;
    content: "";
    background-color: #69CDD8;
    left: -3vw;
    bottom: 30vh;
    width: 300px;
    height: 300px;
    z-index: -1;
    border-radius: 100%;
}
.top-recruit {
    position: relative;
    padding: 100px 0 80px;
}
.top-recruit::before {
    position: absolute;
    content: "";
    background-color: #AAD877;
    right: -3vw;
    top: 2vh;
    width: 130px;
    height: 130px;
    z-index: 0;
    border-radius: 100%;
}
.top-recruit-in {
    position: relative;
    padding: 80px 0 60px;
}
.top-recruit-in::before {
    position: absolute;
    content: "";
    background-color: #fff;
    top: 0;
    right: 0;
    width: 90vw;
    height: 100%;
    z-index: -1;
}
.top-recruit-in::after {
    position: absolute;
    content: "";
    background-color: #69CDD8;
    left: 40vw;
    top: -2vh;
    width: 50px;
    height: 50px;
    z-index: -1;
    border-radius: 100%;
}
.top-recruit .container {
    margin-top: 0;
    margin-bottom: 0;
}
.top-recruit .text-block {
    width: 50%;
    margin-left: auto;
}
.top-recruit .dlb_title-h3 {
    font-size: 30px;
    margin-bottom: 30px;
}
.top-recruit p {
    margin-bottom: 30px;
}
.top-recruit .img-block {
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    width: 40vw;
}
.top-recruit img {
    border-radius: 0 10px 10px 0;
}
.top-csr {
    padding-bottom: 40px;
}
.top-csr .bg_image {
    padding: 60px;
    position: relative;
    border-radius: 10px;
}
.top-csr .bg_image::before {
    position: absolute;
    content: "";
    width: 100%;
    height: 100%;
    background-color: rgba(255, 255, 255, 0.8);
    top: 0;
    left: 0;
    border-radius: 10px;
}
.top-csr .bg_image::after {
    position: absolute;
    content: "";
    background-color: #AAD877;
    left: -3vw;
    bottom: -4vh;
    width: 80px;
    height: 80px;
    z-index: -1;
    border-radius: 100%;
}
.top-partner {
    position: relative;
    padding: 150px 0 100px;
}
.top-partner::before {
    position: absolute;
    content: "";
    background-color: #69CDD8;
    left: -10vw;
    top: 0;
    width: 400px;
    height: 400px;
    z-index: -1;
    border-radius: 100%;
}
.top-partner::after {
    position: absolute;
    content: "";
    background-color: #69CDD8;
    left: 7vw;
    bottom: 0;
    width: 80px;
    height: 80px;
    z-index: -1;
    border-radius: 100%;
}
.top-partner.dlb_contents_wrap-single .dlb_contents_wrap-bg {
    background-size: cover;
}
.top-partner .bg-white {
    padding: 60px;
    border-radius: 10px;
    position: relative;
}
.top-partner .bg-white::before {
    position: absolute;
    content: "";
    background-color: #AAD877;
    right: -6vw;
    bottom: -8vh;
    width: 150px;
    height: 150px;
    z-index: -1;
    border-radius: 100%;
}
.top-partner h3 {
    font-weight: bold;
    font-size: 30px;
    margin-bottom: 30px;
}
.top-partner p {
    margin-bottom: 30px;
}
.top-news {
    margin-bottom: 100px;
}
.top-news .dlb_blog-image, .top-news .dlb_blog-data p {
    display: none !important;
}
.top-news .swiper-wrapper {
    display: block;
    height: auto;
}
.top-news .dlb_blog-item {
    border-top: 1px solid #69CDD8;
    padding: 16px 0 !important;
}
.top-news .dlb_blog-item:last-of-type {
    border-bottom: 1px solid #69CDD8;
}
.top-news .dlb_blog-item a {
    display: flex;
    align-items: center;
}
.top-news .dlb_title-h3 {
    margin-left: 100px;
    margin-bottom: 0;
    font-weight: normal;
    font-size: 16px !important;
}
.top-news .dlb_blog-badge {
    top: 50% !important;
    transform: translateY(-50%);
    right: auto !important;
    left: 100px;
    text-align: left !important;
}
.top-slider-block {
    padding: 100px 0 0;
    position: relative;
}
.top-slider-block::before {
    position: absolute;
    content: "";
    background-color: #69CDD8;
    right: 10vw;
    top: 0;
    width: 50px;
    height: 50px;
    z-index: -1;
    border-radius: 100%;
}
.top-slider-block::after {
    position: absolute;
    content: "";
    background-color: #AAD877;
    left: -7vw;
    top: 0;
    width: 400px;
    height: 400px;
    z-index: -1;
    border-radius: 100%;
}
/* スライダーのwrapper */
.top-slider .swiper-wrapper {
    transition-timing-function: linear;
}
  
  /* スライド */
.top-slider .swiper-slide {
    height: 300px !important; /* 高さを指定 */
    width: auto !important;
    margin: auto 10px;
}
  
  /* スライド内の画像 */
.top-slider .swiper-slide img {
    width: auto;
    height: 100%;
    border-radius: 10px;
}


/* ==================================
CTA
===================================== */
.contact-block {
    position: relative;
    padding: 50px;
    margin-top: 40px;
}
.contact-block::before {
    position: absolute;
    content: "";
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: -moz-linear-gradient(left, #69CDD8, #AAD877);
    background: -webkit-linear-gradient(left, #69CDD8, #AAD877);
    background: linear-gradient(to right, #69CDD8, #AAD877);
    opacity: 0.8;
}
.contact-block .bg-white {
    border-radius: 10px;
    padding: 60px;
    position: relative;
}
.contact-block .tel-block a {
    font-family: 'Lato', sans-serif !important;
    font-size: 50px;
    font-weight: bold;
    color: #333;
    text-decoration: none;
}
.contact-block .tel-block a:hover {
    color: #69CDD8;
}


/* ==================================
パンくず
===================================== */
#locator ol {
    padding: 0;
}

/* ==================================
改行
===================================== */
.br-pc {
    display: inline;
}
.br-sp {
    display: none;
}

/* ==================================
アンカーリンク
===================================== */
#dcms_layoutPageBlockPasteArea a[id] {
    padding-top: 140px;
    margin-top: -140px;
}
.dcms_editor #dcms_layoutPageBlockPasteArea a[id] {  
    display: inherit !important;
    padding-top: inherit !important;
    margin-top: inherit !important;
}/*管理画面の崩れ防止*/

/* ==================================
グラデーション
===================================== */
.grad-color {
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* ==================================
テキストシャドウ
===================================== */
.text-shadow {
    text-shadow: 2px 2px 2px rgba(0, 0, 0, 0.4);
}

/* ==================================
aタグの遅延
===================================== */
a, .t-default a {
    margin: 0;
    padding: 0;
    text-decoration: none;
    transition: all .2s ease 0s;
}

/* ==================================
背景画像を設定したい時
===================================== */
.bg_image {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}

/* ==================================
黒透過
===================================== */
.bg-black-shadow {
    position: relative;
}
.bg-black-shadow::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
}

/* ==================================
白透過
===================================== */
.bg-white-shadow {
    position: relative;
}
.bg-white-shadow::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(255, 255, 255, 0.5);
}

/* ==================================
table要素のborder-right
===================================== */
.main_table th {
    border-right: 1px solid #dee2e6;
}

/* ==================================
フローコンテンツの矢印の色（デフォルトはグレー）
===================================== */
.dlb_flow-5 .dlb_flow-item+.dlb_flow-item::before {
    border-color: #E2CB58 transparent transparent transparent !important;
}

/* ==================================
 横100% BGとテキストの背景画像の設定（コンテンツ31）
===================================== */
.dlb_contents_wrap-wide {
    background-size: cover;
}

/* ==================================
横並びコンテンツの崩れ修正（コンテンツ66/67）
===================================== */
.dlb_contents_overflow .dlb_contents_overflow-right:before, .dlb_contents_overflow .dlb_contents_overflow-left:before {
    top: 50% !important;
}

/* ==================================
アコーディオンの矢印の調整
===================================== */
.dlb_list_accordion .btn::before {
    content: "";
    position: absolute;
    width: 30px;
    height: 30px;
    background-color: #fff;
    top: 50%;
    right: 13px;
    transform: translateY(-50%);
}
.dlb_list_accordion .btn.collapsed::after {
    margin-top: -6px !important;
}
.dlb_list_accordion .btn::after {
    margin-top: -3px  !important;
}

/* ==================================
アコーディオンの中のボタンの矢印を消す
===================================== */
.accordion-in-btn .btn::after, .accordion-in-btn .btn::before {
    display: none !important;
}
.accordion-in-btn .btn {
    padding-right: 0 !important;
}


/* ==================================
ブログの見た目調整
===================================== */
.dlb_blog_column-4 .dlb_blog-data p {
    max-height: none !important;
}


/* ==================================
お知らせの見た目調整
===================================== */
.dlb_news-list dl {
    border-top: 1px solid #69CDD8;
    padding: 16px 0 !important;
}
.dlb_news-list dl:last-child {
    border-bottom: 1px solid #69CDD8;
    padding: 16px 0 !important;
}
.dlb_news-list .rss_title a {
    color: #333;
    text-decoration: none;
}
.dlb_news-list .rss_title a:hover {
    color: #69CDD8;
}
.page_news .dlb_news .rss_contents {
    display: block !important;
}

/* ==================================
お問い合わせ
===================================== */
#form_contact_main {
    width: 60% !important;
    margin: auto !important;
}
#form_intro p {
    width: 60% !important;
    margin: auto !important;
    margin-bottom: 40px !important;
}
#form_contact_main dd {
    width: 70% !important;
    margin-bottom: 0px !important;
}
#form_contact_main dt {
    width: 250px !important;
}
#form_contact_main dl {
    margin-bottom: 0px;
    padding: 30px 0 !important;
}
#contact-form #table_address tr td {
    padding: 8px !important;
}
#form_wrap {
    margin-bottom: 60px;
}
.contact-btn-block .btn a::before {
    content: "";
    background: url(/dcms_media/image/common/icon-mail.png) 0 0 no-repeat;
    width: 24px;
    height: 24px;
    display: inline-block;
    margin-right: 6px;
    vertical-align: middle;
}
.contact-btn-block .btn a:hover:before {
    width: 24px;
    height: 24px;
    background: url(/dcms_media/image/icon-mail-on.png) 0 0 no-repeat;
}
.form_area_wrap label {
    display: inline;
}

/* ==================================
業務システム分野
===================================== */
.page_system .dlb_contents_column-1 img, .dlb_contents_column-2 img {
    border-radius: 10px;
}
.system-case .d-flex {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
}
.system-case .img-title {
    height: 430px;
    margin-bottom: 10px;
}

/* ==================================
会社概要
===================================== */
.corporate-philosophy .border {
    border-width: 3px !important;
    border-radius: 10px;
}
.company-table table {
    width: 100%;
    table-layout: fixed;
    word-break: break-all;
    word-wrap: break-all;
}
.page_company .dlb_contents_float img {
    width: 320px;
}

/* ==================================
採用情報
===================================== */
.container .bg_image {
    position: relative;
}
.recruit-introduction .bg_image::before {
    position: absolute;
    content: "";
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background-color: rgba(0, 0, 0, 0.6);
    z-index: 1;
}
.recruit-introduction .bg_image p {
    position: relative;
    z-index: 1;
}
.number {
    font-size: 1.75rem;
    font-weight: bold;
}
.number .small {
    font-weight: bold;
    font-size: 1rem;
}
.career-plan .d-flex {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
}
.career-plan .d-flex p {
    margin-top: auto;
}
.career-plan .img-title {
    margin-bottom: 1rem;
    height: 250px;
}

/* ==================================
先輩社員の声
===================================== */
.page_voice .dlb_contents_image-left img, .page_voice .dlb_contents_image-right img {
    border-radius: 10px;
}

/* ==================================
ふわっと
===================================== */
.scroll-up {
    opacity: 0; 
    visibility: hidden;
    transform: translateY(50px);
    transition: all 1s;
  }
  .scroll-up.is-show {
    opacity: 1;
    visibility: visible;
    transform: translateY(0px);
  }
.share_top-link.active .top-link {
    display: block !important;
}
.share_top-link .top-link .btn a:hover:before {
    border-color: #69CDD8 !important;
}

@media only screen and (min-width: 992px) and (max-width: 1320px) {
    .top-mv {
        margin-top: -113px;
    }
}

@media only screen and (max-width: 991px) {
    .pc-block {
        display: none !important;
    }
    /* ==================================
    header
    ===================================== */
    .page_index .bs_header-01.bs_header-01-drop.navbar-light .navbar-nav li:first-child a.nav-link {
        border-bottom: none;
    }
    header .nav-item {
        position: relative;
        border-bottom: 2px solid #AAD877;
    }
    header .nav-item:last-child {
        border: none;
    }
    header .nav-item::before {
        content: "";
        position: absolute;
        display: inline-block;
        width: 30px;
        height: 30px;
        background-image: url(/dcms_media/image/btn-green.png);
        background-repeat: no-repeat;
        background-size: contain;
        background-position: center;
        right: 10px;
        top: 50%;
        transform: translateY(-50%);
        transition: all .3s;
        z-index: -1;
    }
    header .nav-item.dropdown::before {
        display: none;
    }
.mm_btn {
    position: absolute;
    width: 30px;
    height: 30px;
    top: 5px;
    right: 0px;
    -webkit-transition: all .3s ease 0s;
    -o-transition: all .3s ease 0s;
    transition: all .3s ease 0s;
  }
  .mm_btn.active::after {
    -webkit-transform: translateY(-50%) rotate(-45deg);
    transform: translateY(-50%) rotate(-45deg);
  }
  .mm_btn::after {
    content: "";
    position: relative;
    top: 50%;
    width: 8px;
    height: 8px;
    border-top: 2px solid #AAD877;
    border-right: 2px solid #AAD877;
    -webkit-transform: translateY(-50%) rotate(135deg);
    transform: translateY(-50%) rotate(135deg);
    position: absolute;
  }
    .dropdown-menu a.dropdown-item {
    padding: 10px !important;
}
    header .openbtn {
        display: block;
        position: relative;
        cursor: pointer;
        width: 45px;
        height: 45px;
        border-radius: 100%;
        background-color: #AAD877;
        margin-right: 10px;
    }
    header .openbtn span {
        display: inline-block;
        transition: all .4s;
        position: absolute;
        left: 50%;
        transform: translateX(-50%);
        height: 2px;
        background: #fff;
        width: 25px;
    }
    .btn.btn-arrow-after-main a::after {
        border-color: #AAD877 !important;
    }
    header .openbtn span:nth-of-type(1) {
        top: 10px;
    }
    header .openbtn span:nth-of-type(2) {
        top: 20px;
    }
    header .openbtn span:nth-of-type(3) {
        top: 30px;
    }
    header .openbtn.active span:nth-of-type(1) {
        transform: rotate(-45deg);
        left: 11px;
        top: 20px;
    }
    header .openbtn.active span:nth-of-type(2) {
        display: none;
    }
    header .openbtn.active span:nth-of-type(3) {
        transform: rotate(45deg);
        left: 11px;
        top: 20px;
    }
    .company-name {
        font-size: 16px;
    }
    /* ==================================
    top
    ===================================== */
    .main-title {
        font-size: 50px
    }
    .sub-title {
        font-size: 16px;
    }
    .top-service {
        padding-top: 80px;
    }
    .top-service::before{
        left: -15vw;
        top: -15vh;
        width: 500px;
        height: 500px;
    }
    .top-service .dlb_title-h3 {
        font-size: 20px;
    }
    .service-title {
        font-size: 20px;
        padding: 17px 80px 17px 24px;
    }
    .service-block .col {
        margin-bottom: 20px;
    }
    .top-company {
        padding-top: 120px;
    }
    .top-company::before {
        width: 470px;
        height: 470px;
    }
    .top-company .text-block {
        padding-left: 20px;
    }
    .top-company .text-block p {
        width: 85%;
    }
    .top-company .img-block {
        position: relative;
        right: 0;
        top: 0;
        transform: none;
        width: 90vw;
        margin-left: auto;
        margin-bottom: 30px;
    }
    .top-company .img-block .img-fluid::before {
        left: -20vw;
    }
    .top-recruit-csr::before {
        bottom: 30vh;
        width: 260px;
        height: 260px;
    }
    .top-recruit-csr::after {
        left: 5vw;
        bottom: 45vh;
        width: 200px;
        height: 200px;
    }
    .top-recruit .container {
        padding: 0;
        margin: 0;
    }
    .top-recruit .text-block {
        width: 100%;
    }
    .top-recruit .heading-025 {
        width: 85%;
        margin-left: auto;
    }
    .top-recruit .dlb_title-h3 {
        width: 85%;
        margin-left: auto;
    }
    .top-recruit .text-block p {
        width: 80%;
        margin-left: 15%;
    }
    .top-recruit .img-block {
        position: relative;
        top: 0;
        left: 0;
        transform: none;
        width: 90vw;
        margin-right: auto;
        margin-bottom: 20px;
    }
    .top-recruit .btn {
        margin-left: 15%;
    }
    .top-csr .bg_image {
        padding: 60px 40px;
    }
    .top-partner .container {
        max-width: none;
        width: 80%;
    }
}

@media only screen and (max-width: 820px) {
    .top-service {
        padding-top: 60px;
    }
    .top-company, .top-partner {
        padding-top: 80px;
    }
    .top-partner .container {
        width: 90%;
    }
    .top-company .dlb_title-h3, .top-recruit .dlb_title-h3 {
        font-size: 26px;
    }
    .top-recruit .heading-025 {
        width: 80%;
    }
    .top-recruit .dlb_title-h3 {
        width: 80%;
    }
    .top-recruit .text-block p, .top-recruit .btn {
        margin-left: 20%;
    }
    .top-partner h3 {
        font-size: 24px;
    }
    .top-partner .bg-white {
        padding: 40px;
    }
    .top-recruit-csr::after {
        left: -5vw;
    }
    .slider-font-wrap {
        padding: 200px 0 0;
    }
    .footer-menu .pc-none {
        display:-webkit-box;
        display:-ms-flexbox;
        display:flex !important;
    }
    .footer-menu .sp-none {
        display: none !important;
    }
}

@media only screen and (max-width: 690px) {
    /* ==================================
    common
    ===================================== */
    .heading-025 {
        font-size: 22px;
    }
    .heading-025::before {
        font-size: 44px;
    }
    .pc-none {
        display:-webkit-box;
        display:-ms-flexbox;
        display:flex !important;
    }
    .sp-none {
        display: none !important;
    }
    .slider-font-top .slider-font {
        font-size: 110px;
    }
    .privacy-table table {
        min-width: 600px;
    }

    /* ==================================
    footer
    ===================================== */
    .footer-menu {
        padding: 40px 0;
    }
    .list-unstyled {
        font-size: 14px;
    }
    .footer-menu .list-unstyled li {
        padding-left: 16px;
    }

    /* ==================================
    TOP
    ===================================== */
    .main-title {
        font-size: 24px;
    }
    .service-title {
        font-size: 18px;
    }
    .top-service {
        padding-top: 60px;
    }
    .top-service::before {
        left: -70vw;
        top: -35vh;
    }
    .top-service::after {
        left: -60vw;
        bottom: 55vh;
    }
    .top-service .dlb_title-h3 {
        font-size: 16px;
        margin-bottom: 30px;
    }
    .top-service .row {
        margin: auto;
    }
    .service-block .col {
        padding: 0;
    }
    .service2, .service3 {
        margin-top: 0;
    }
    .service4 {
        margin-bottom: 0;
    }
    .top-company {
        margin-bottom: 40px;
        padding-top: 80px;
    }
    .top-company-in {
        padding-bottom: 40px;
    }
    .top-company .dlb_title-h3 {
        font-size: 20px;
    }
    .top-company::before {
        width: 310px;
        height: 310px;
        right: -50vw;
    }
    .top-slider-block::after {
        width: 200px;
        height: 200px;
    }
    .top-slider-block::before {
        width: 25px;
        height: 25px;
        top: 8vh;
    }
    .top-slider .swiper-slide {
        height: 250px !important;
    }
    .top-recruit-csr::before {
        bottom: 50vh;
        right: -30vw;
        height: 200px;
        width: 200px;
    }
    .top-recruit-csr::after {
        left: -25vw;
        bottom: 130vh;
    }
    .top-recruit {
        padding-bottom: 40px;
    }
    .top-recruit::before {
        top: 8vh;
        width: 85px;
        height: 85px;
    }
    .top-recruit-in {
        padding: 40px 0;
    }
    .top-recruit-in::after {
        display: none;
    }
    .top-recruit .heading-025 {
        width: 85%;
    }
    .top-recruit .dlb_title-h3 {
        width: 85%;
        font-size: 20px;
    }
    .top-recruit .text-block p, .top-recruit .btn {
        margin-left: 15%;
    }
    .top-csr .bg_image {
        padding: 40px 20px;
        border-radius: 0;
    }
    .top-csr .bg_image::before {
        border-radius: 0;
    }
    .top-csr .bg_image::after {
        bottom: -8vh;  
    }
    .top-csr .text-right {
        text-align: left !important;
    }
    .top-partner {
        padding-top: 80px;
    }
    .top-partner::before {
        left: auto;
        right: -25vw;
        top: 0;
        width: 170px;
        height: 170px;
    }
    .top-partner.dlb_contents_wrap-single .dlb_contents_wrap-bg {
        height: 220px;
    }
    .top-partner .container {
        width: 100%;
    }
    .top-partner h3 {
        font-size: 22px;
    }
    .top-partner .bg-white {
        padding: 40px 20px;
    }
    .top-partner .bg-white::before {
        width: 88px;
        height: 88px;
    }
    .top-partner::after {
        left: -3vw;
        width: 50px;
        height: 50px;
    }
    .top-news {
        margin-bottom: 40px;
    }
    .top-news .dlb_blog-item a {
        display: block;
    }
    .top-news .dlb_title-h3 {
        margin-top: 10px;
    }
    .top-news .dlb_blog-badge {
        position: relative;
        left: 0;
        bottom: -20px;
        top: auto !important;
    }

    /* ==================================
    業務システム分野
    ===================================== */
    .system-case .img-title {
        height: auto;
    }
    .system-case th {
        width: 20%;
    }

    /* ==================================
    採用情報
    ===================================== */
    .career-plan .img-title {
        height: auto;
    }

    /* ==================================
    CTA
    ===================================== */
    .contact-block {
        padding: 40px 20px;
    }
    .contact-block .bg-white {
        padding: 30px 20px;
        text-align: center;
    }
    .contact-block .tel-block a {
        font-size: 30px;
    }
    .contact-block .tel-block img {
        width: 25px;
        height: auto;
    }
    .contact-block .heading-025::before {
        left: 50%;
        transform: translateX(-50%);
    }

    /* ==================================
    改行
    ===================================== */
    .br-sp {
        display: inline;
    }
    .br-pc {
        display: none;
    }
    /* ==================================
    アンカーリンク
    ===================================== */
    #dcms_layoutPageBlockPasteArea a[id] {
        padding-top: 100px;
        margin-top: -100px;
    }
    .btn.btn-anchor-link {
        padding-left: 0 !important;
    }
    /* ==================================
    パンくず
    ===================================== */
    #locator ol {
        padding: 0;
    }
    /* ==================================
    お知らせ
    ===================================== */
    .dlb_news .rss_date {
        padding-left: 0 !important;
    }
    /* ==================================
    お問い合わせ
    ===================================== */
    #form_contact_main {
        width: 90% !important;
    }
    #form_intro p {
        width: 90% !important;
        margin-bottom: 30px !important;
    }
    #form_contact_main dl {
        padding: 20px 0 !important;
    }
    #form_contact_main dd {
        width: 100% !important;
    }
    #privacy_txt {
        margin-top: 40px !important;
    }
    #form_wrap {
        margin-bottom: 40px;
    }
    #submit_button {
        display: flex;
        justify-content: center;
    }

    /* ==================================
    サイトマップ
    ===================================== */
    #sitemap {
        padding-left: 0 !important;
    }
}
