

@charset "UTF-8";

article, blockquote, body, dd, div, dl, dt, fieldset, figure, form, h1, h2, h3, h4, h5, h6, img, input, li, ol, p, pre, section, td, textarea, th, ul {
    margin: 0;
    padding: 0
}

table {
    border-collapse: collapse;
    border-spacing: 0
}

fieldset, img {
    border: 0
}

address, caption, cite, code, dfn, em, strong, th, var {
    font-style: normal;
    font-weight: normal
}

ol, ul {
    list-style: none
}

caption, th {
    text-align: left
}

h1, h2, h3, h4, h5, h6 {
    font-size: 100%;
    font-weight: normal
}

img {
    vertical-align: top
}

hr {
    display: none
}

a {
    border: none;
    outline: none;
    text-decoration: none
}

@font-face {
    font-family: "icomoon";
    src: url("../css/fonts/icomoon.eot?9bj0m8");
    src: url("../css/fonts/icomoon.eot?9bj0m8#iefix") format("embedded-opentype"), url("../css/fonts/icomoon.ttf?9bj0m8") format("truetype"), url("../css/fonts/icomoon.woff?9bj0m8") format("woff"), url("../css/fonts/icomoon.svg?9bj0m8#icomoon") format("svg");
    font-weight: normal;
    font-style: normal
}

[class*=" icon-"], [class^=icon-] {
    font-family: "icomoon" !important;
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale
}

.icon-mail:before {
    content: ""
}

.icon-gear:before {
    content: ""
}

.icon-people:before {
    content: ""
}

.icon-search:before {
    content: ""
}

.icon-home:before {
    content: ""
}

@font-face {
    font-family: "游明朝";
    src: local("Gentium Basic");
    unicode-range: U+0030-0039
}

* {
    box-sizing: border-box
}

html {
    width: 100%;
    height: 100%;
    scroll-behavior: smooth
}

body {
    font-family: "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
    font-weight: 500;
    font-size: 16px;
    line-height: 1.8;
    letter-spacing: 0.05rem;
    width: 100%;
    height: 100%;
    color: #005CB9;
    font-feature-settings: "palt";
    text-align: justify;
    text-justify: inter-ideograph
}

body a {
    transition: all 0.5s;
    color: #005CB9
}

body a:hover {
    color: #53a9ff
}

body#bgThinGray{
    background-color: #f4f4f4;
}

@media screen and (max-width:950px) {
    body {
        min-width: 100%;
        font-size: 16px
    }
}

::selection {
    background: #00366d;
    color: #fff
}

::-moz-selection {
    background: #00366d;
    color: #fff
}

#wrap {
    width: 100%;
    margin: 0 auto
}

@media screen and (max-width:950px) {
    #wrap {
        overflow: hidden
    }
}

#wrap #adLogo {
    float: left;
    width: 10%;
    position: relative
}

@media screen and (max-width:950px) {
    #wrap #adLogo img {
        width: 70px
    }
}

.flex {
    display: flex
}

.flex_jc-s {
    justify-content: space-between
}

.flex_jc-c {
    justify-content: center
}

.flex_jc-e {
    justify-content: flex-end
}

.flex_ai-c {
    align-items: center
}

.flex_wp_wp {
    flex-wrap: wrap
}

.flex_dr_co {
    flex-direction: column
}

.mb100 {
    margin-bottom: 100px !important
}

@media screen and (max-width:1100px) and (min-width:860px) {
    .mb100 {
        margin-bottom: 50px !important
    }
}

.mb50 {
    margin-bottom: 50px !important
}

@media screen and (max-width:1100px) and (min-width:860px) {
    .mb50 {
        margin-bottom: 25px !important
    }
}

.mb30 {
    margin-bottom: 30px !important
}

@media screen and (max-width:1100px) and (min-width:860px) {
    .mb30 {
        margin-bottom: 15px !important
    }
}

.mb20 {
    margin-bottom: 20px !important
}

@media screen and (max-width:1100px) and (min-width:860px) {
    .mb20 {
        margin-bottom: 10px !important
    }
}

.mb10 {
    margin-bottom: 10px !important
}

@media screen and (max-width:1100px) and (min-width:860px) {
    .mb10 {
        margin-bottom: 5px !important
    }
}

.inner {
    max-width: 1100px;
    margin: 0 auto
}

.faq.inner .btnWrap{
    display: none;
}

@media screen and (max-width:1100px) and (min-width:860px) {
    .inner {
        max-width: 100%;
        padding: 0 5%
    }
}

@media screen and (max-width:859px) {
    .inner {
        max-width: 100%;
        padding: 0 5%
    }
}

.inner11 {
    max-width: 1100px;
    margin: 0 auto
}

@media screen and (max-width:1100px) and (min-width:860px) {
    .inner11 {
        max-width: 100%;
        padding: 0 5%
    }
}

@media screen and (max-width:859px) {
    .inner11 {
        max-width: 100%;
        padding: 0 5%
    }
}

.inner70 {
    max-width: 700px;
    margin: 0 auto
}

@media screen and (max-width:1100px) and (min-width:860px) {
    .inner70 {
        max-width: 100%;
        padding: 0 5%
    }
}

@media screen and (max-width:859px) {
    .inner70 {
        max-width: 100%;
        padding: 0 5%
    }
}

.inner80 {
    max-width: 800px;
    margin: 0 auto
}

@media screen and (max-width:859px) {
    .inner80 {
        max-width: 100%;
        padding: 0 5%
    }
}

.inner90 {
    max-width: 900px;
    margin: 0 auto
}

@media screen and (max-width:859px) {
    .inner90 {
        max-width: 100%;
        padding: 0 5%
    }
}

.inner10 {
    max-width: 1000px;
    margin: 0 auto
}

@media screen and (max-width:859px) {
    .inner10 {
        max-width: 100%;
        padding: 0 5%
    }
}

.tit1 {
    font-size: 3.5rem;
    letter-spacing: 0.7rem;
    text-align: center;
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

@media screen and (max-width:859px) {
    .tit1 {
        font-size: 2rem;
        letter-spacing: 0.5rem;
        line-height: 1.3
    }
}

.btn1 {
    text-align: center
}

.btn1 a {
    background: #005CB9;
    color: #fff;
    font-size: 1.3rem;
    font-weight: bold;
    padding: 15px 50px;
    border-radius: 10px 10px;
    position: relative;
    overflow: hidden
}

.btn1 a:after {
    content: "";
    width: 100%;
    height: 100%;
    background: #DFE0E0;
    position: absolute;
    top: 0;
    left: -100%;
    transition: all 0.5s
}

.btn1 a:hover:after {
    content: "";
    top: 0;
    left: 0
}

.btnWrap {
    text-align: center
}

.btnWrap--margin-top{
    margin-top: 2.5em;
}
  
@media screen and (max-width:859px) {
    .btnWrap {
        padding: 0 5%
    }
}

.btn-1, .btn-flow {
    display: inline-block;
    padding: 7px 30px;
    border-radius: 10px 10px;
    color: #fff;
    text-transform: uppercase;
    font-size: 1.1rem;
    font-weight: bold;
    letter-spacing: 0.15rem;
    transition: all 0.3s;
    position: relative;
    overflow: hidden;
    z-index: 1
}

@media screen and (max-width:859px) {
    .btn-1, .btn-flow {
        font-size: 1rem;
        padding: 8px 20px;
        width: 100%;
        text-align: center
    }
}

.btn-1:after, .btn-flow:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #005CB9;
    border-radius: 10px 10px;
    z-index: -2
}

.btn-1:before, .btn-flow:before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0%;
    height: 100%;
    background-color: #00366d;
    transition: all 0.3s;
    border-radius: 10px 10px;
    z-index: -1
}

.btn-1:hover, .btn-flow:hover {
    color: #fff
}

.btn-1:hover:before, .btn-flow:hover:before {
    width: 100%
}

#header.bgcolor {
    background: rgba(255, 255, 255, 0.8);
    filter: drop-shadow(0px -18px 18px rgba(0, 0, 0, 0.2));
    padding: 8px 20px
}

#header.bgcolor #logo {
    width: 260px
}

#header.bgcolor #logo img {
    width: 80px
}

@media screen and (max-width:859px) {
    #header.bgcolor #logo {
        width: auto;
    }

    #header.bgcolor #logo img {
        width: 75px
    }
}

#header.hide {
    transform: translateY(-100%)
}

#header {
    padding: 20px;
    position: fixed;
    z-index: 10000;
    width: 100%;
    transition: 0.5s
}

@media screen and (max-width:859px) {
    #header {
        padding: 3px 5% 2px
    }
}

#header #logo {
    display: block
}

@media screen and (max-width:859px) {
    #header #logo {
        width: 75px
    }

    #header #logo img {
        width: 100%;
        height: auto
    }
}

@media screen and (min-width:860px) {
    #header #logo img {
        transition: all 0.5s
    }
}

#header #logo span {
    display: inline-block;
    font-size: 0.7rem;
    letter-spacing: 0.2em;
    line-height: 1.6;
    margin: 14px 0 0 15px;
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

@media screen and (max-width:859px) {
    #header #logo span {
        display: none
    }
}

@media screen and (max-width:1100px) and (min-width:860px) {
    #header #logo span {
        display: none
    }
}

#header #gnav {
    margin-top: 15px
}

#header #gnav ul li {
    margin-left: 30px
}

#header #gnav ul li a {
    font-size: 0.9rem;
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif;
    letter-spacing: 0.2rem
}

#header #gnav ul li.contact {
    position: relative;
}

#header #gnav ul li.contact .phone{
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif;
    position: absolute;
    left: 50%;
    bottom: -1.5em;
    transform: translateX(-50%);
    white-space: nowrap;
    text-align: center;
}

#header #gnav ul li.contact .phone .label{
    font-size: 12px;
    margin-right: 0.5em;
}

.home #header #gnav ul .phone{
    color: #fff;
    text-shadow: 0 0 3px #005CB9;
}

@media screen and (max-width:1100px) and (min-width:860px) {
    #header #gnav ul li {
        margin-left: 10px
    }

    #header #gnav ul li a {
        font-size: 0.8rem
    }
}

#header #gnav ul .contact a {
    display: inline-block;
    background: #005CB9;
    color: #fff;
    font-size: 0.8rem;
    padding: 0.5rem 1.25rem;
    margin-top: -8px;
    letter-spacing: 0.1rem;
    position: relative;
    overflow: hidden;
    z-index: 1;
    transition: all 0.3s
}

#header #gnav ul .contact a:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #005CB9;
    z-index: -2
}

#header #gnav ul .contact a:before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0%;
    height: 100%;
    background-color: #00366d;
    transition: all 0.3s;
    z-index: -1
}

#header #gnav ul .contact a:hover {
    color: #fff
}

#header #gnav ul .contact a:hover:before {
    width: 100%
}

@media screen and (max-width:859px) {
    #header #gnav {
        display: none
    }
}

.home #header.bgcolor {
    transform: translateY(126%) !important;
    background: rgba(255, 255, 255, 0.8) !important
}

@media screen and (max-width:859px) {
    .home #header.bgcolor {
        transform: translateY(88%) !important
    }
}

.home #header.bgcolor.hide {
    transform: translateY(25%) !important
}

@media screen and (max-width:859px) {
    .home #header.bgcolor.hide {
        transform: translateY(-13%) !important
    }
}

.home #header {
    transform: translateY(100%) !important;
    background: none !important
}

@media screen and (max-width:859px) {
    .home #header {
        margin-top: 42px
    }
}

.breadcrumbs {
    text-align: center;
    padding: 0 5% 50px 5%;
    font-size: 0.8rem
}

#footer {
    background: #005CB9;
    padding: 50px 50px 30px 50px
}

@media screen and (max-width:859px) {
    #footer {
        padding: 50px 0
    }

    #footer .f_logo {
        margin: 0 auto 40px
    }
}

#footer ul.flex {
    width: 900px;
    margin: 0 0 120px
}

@media screen and (max-width:859px) {
    #footer ul.flex {
        display: none
    }
}

#footer ul.flex li ul li a {
    color: #fff;
    line-height: 2.5
}

#footer ul.flex li ul li:first-child a {
    font-size: 1rem
}

#footer ul.flex li ul li:nth-child(n+2) {
    font-size: 0.85rem;
    position: relative;
    padding: 0 0 0 16px;
    vertical-align: middle;
    text-decoration: none
}

#footer ul.flex li ul li:nth-child(n+2):before {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    content: "";
    vertical-align: middle;
    left: 3px;
    width: 6px;
    height: 6px;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    transform: rotate(45deg)
}

#footer ul.flex li:last-child ul li {
    margin: 0 0 10px
}

#footer ul.flex li:last-child ul li a {
    background: #fff;
    color: #005CB9;
    font-size: 0.85rem;
    display: block;
    padding: 0 10px;
    text-align: center;
    border-radius: 5px 5px
}

#footer ul.flex li:last-child ul li a:hover {
    opacity: 0.7
}

#footer ul.flex li:last-child ul li:nth-child(n+2) {
    padding: 0
}

#footer ul.flex li:last-child ul li:nth-child(n+2):before {
    display: none
}

#footer ul.flex li:last-child ul .inversion a {
    background: #005CB9;
    color: #fff;
    border: 1px solid #fff
}

#footer small {
    color: #fff;
    display: block;
    font-size: 0.8rem;
    text-align: center
}

@media screen and (max-width:859px) {
    #footer small {
        font-size: 0.7rem
    }
}

.loaderWrap {
    background: #005CB9 url(../images/index/loading.svg) no-repeat center center;
    background-size: 40vh;
    height: 100%;
    left: 0;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 100000
}

#toggle {
    display: none;
    position: relative;
    z-index: 10000;
    margin: 3px 0 0 0 !important
}

@media screen and (max-width:859px) {
    #toggle {
        display: inline-block;
        vertical-align: middle;
    }
}

#toggle a:after, #toggle a:before {
    border-bottom: none !important
}

.menu-trigger, .menu-trigger span {
    display: inline-block;
    transition: all 0.4s
}

.menu-trigger {
    width: 60px;
    height: 50px;
    z-index: 9999
}

@media screen and (max-width:859px) {
    .menu-trigger {
        width: 60px;
        height: 60px;
        position: relative;
        margin-top: 4px;
    }
}

.menu-trigger span {
    position: absolute;
    z-index: 9999;
    left: 25%;
    width: 50%;
    height: 2px;
    background-color: #000;
    border-radius: 4px
}

.menu-trigger span:first-of-type {
    top: 22px
}

@media screen and (max-width:859px) {
    .menu-trigger span:first-of-type {
        top: 18px
    }
}

.menu-trigger span:nth-of-type(2) {
    top: 32px
}

@media screen and (max-width:859px) {
    .menu-trigger span:nth-of-type(2) {
        top: 29px
    }
}

.menu-trigger span:nth-of-type(3) {
    top: 42px
}

@media screen and (max-width:859px) {
    .menu-trigger span:nth-of-type(3) {
        top: 40px
    }
}

.menu-trigger.active span:first-of-type {
    transform: translateY(11px) rotate(-405deg)
}

.menu-trigger.active span:nth-of-type(2) {
    opacity: 0
}

.menu-trigger.active span:nth-of-type(3) {
    transform: translateY(-9px) rotate(45deg)
}

a.menu-trigger.active:hover span:first-of-type {
    top: 22px
}

a.menu-trigger.active:hover span:nth-of-type(3) {
    top: 42px
}

.closeWrap {
    position: absolute;
    top: 10px;
    right: 10px;
    background: rgba(0, 0, 0, 0.3);
    padding: 1px 9px 4px;
    border-radius: 20px 20px;
    cursor: pointer
}

@media screen and (max-width:859px) {
    .closeWrap {
        background: rgba(255, 255, 255, 0.3);
        top: 85vw;
        right: 50%;
        transform: translate(50%, 0)
    }
}

.closeWrap .dli-close {
    display: inline-block;
    vertical-align: middle;
    color: #fff;
    line-height: 1;
    width: 1em;
    height: 0.1em;
    background: currentColor;
    border-radius: 0.1em;
    position: relative;
    transform: rotate(45deg)
}

.closeWrap .dli-close:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: inherit;
    border-radius: inherit;
    transform: rotate(90deg)
}

#overlay {
    display: none
}

@media screen and (max-width:859px) {
    #overlay.active {
        opacity: 1;
        transition: all 0.5s;
        transition-timing-function: ease
    }

    #overlay {
        border-left: 5px solid #005CB9;
        display: none;
        transition: all 0.5s;
        height: 100%;
        width: 100%;
        position: fixed;
        top: 0;
        left: 0;
        z-index: 9999;
        background: #DFE0E0;
        overflow: scroll;
        padding: 90px 5% 0
    }

    #overlay ul li ul {
        margin: 0 0 5px
    }

    #overlay ul li ul li {
        padding: 0 0 0 0;
        margin: 0 5px 5px 0
    }

    #overlay ul li ul li a {
        padding: 10px 0 10px 17px;
        background: #005CB9;
        font-weight: bold;
        display: block;
        border-radius: 3px 3px
    }

    #overlay ul li ul li:first-child {
        width: 100%
    }

    #overlay ul li ul li:first-child a {
        font-size: 1.1rem;
        font-weight: bold;
        padding: 5px 0 5px 15px;
        background: none;
        position: relative
    }

    #overlay ul li ul li:first-child a:before {
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        margin: auto;
        content: "";
        vertical-align: middle;
        left: 3px;
        width: 6px;
        height: 6px;
        border-top: 1px solid #005CB9;
        border-right: 1px solid #005CB9;
        transform: rotate(45deg)
    }

    #overlay ul li ul li:nth-child(n+2) {
        font-size: 0.85rem;
        position: relative;
        padding: 0 0 0 0;
        vertical-align: middle;
        text-decoration: none;
        width: 100%
    }

    #overlay ul li ul li:nth-child(n+2) a {
        color: #fff
    }

    #overlay ul li ul li:nth-child(n+2):before {
        position: absolute;
        top: 0;
        bottom: 0;
        margin: auto;
        content: "";
        vertical-align: middle;
        left: 6px;
        width: 4px;
        height: 4px;
        border-top: 1px solid #005CB9;
        border-right: 1px solid #005CB9;
        transform: rotate(45deg)
    }

    #overlay .phone{
        font-size: 1.1rem;
        font-weight: bold;
        padding: 36px 0;
        color: #005CB9;
    }

    #overlay .label{
        font-size: 0.825rem;
        margin-right: 0.5em;
    }
}

#pageTop {
    position: fixed;
    bottom: 15px;
    right: 15px;
    z-index: 150;
    opacity: 0
}

#pageTop a {
    z-index: 999;
    background: #E6E6E6;
    width: 50px;
    height: 50px;
    display: block;
    position: relative
}

#pageTop a:after {
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 5px 10px 5px;
    border-color: transparent transparent #005CB9 transparent;
    position: absolute;
    top: calc(50% - 5px);
    left: calc(50% - 5px)
}

@media screen and (max-width:859px) {
    #pageTop {
        bottom: 15px
    }
}

#pageTop.rotate {
    opacity: 1;
    transition: all 0.5s
}

.home .slide-kv {
    margin: -118px 0 0 0;
    position: relative;
    overflow: hidden;
    z-index: -10
}

.home .slide-kv .slide {
    background: url(../images/index/slide1.jpg) no-repeat center center/cover;
    margin: 118px 0 0 0;
    position: relative;
    height: 950px
}

@media screen and (max-width:859px) {
    .home .slide-kv .slide {
        height: 700px
    }
}

.home .slide-kv .slide a img {
    width: 100%;
    height: auto
}

.home .slide-kv .slide .slick-index {
    height: 100%
}

.home .slide-kv .slide .slick-index .slick-list {
    height: 100%
}

.home .slide-kv .slide .slick-index .slick-list .slick-track {
    height: 100%
}

.home .slide-kv .slide .kv_txt2 {
    color: #fff;
    letter-spacing: 0.3rem;
    filter: drop-shadow(0px 0px 18px rgba(0, 0, 0, 0.2));
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif;
    position: absolute;
    bottom: 250px;
    left: 50%;
    transform: translate(-50%, 0);
    white-space: nowrap
}

.slide-kv__btn-box{
    position: absolute;
    width: 600px;
    left: 50%;
    transform: translateX(-50%);
    bottom: 50px;
    display: flex;
    justify-content: space-between;
}

.slide-kv__btn-box__btn{
    width: 240px;
    height: 80px;
}

.slide-kv__btn-box__btn a{
    display: flex;
    width: 100%;
    height: 100%;
    justify-content: center;
    align-items: center;
    border: 2px solid #fff;
    background-color: hsla(206, 90%, 50%, 0.40);
    color: #fff;
    transition: background-color 0.3s;
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif;
    font-size: 18px;
}

.slide-kv__btn-box__btn a:hover{
    background-color: hsla(206, 90%, 50%, 0.16);
    color: #fff;
}

@media screen and (max-width:859px) {
    .home .slide-kv .slide .kv_txt2 {
        letter-spacing: 0.1rem;
        bottom: 225px;
        text-align: center
    }

    .slide-kv__btn-box{
        width: 80%;
        bottom: 30px;
    }

    .slide-kv__btn-box__btn{
        width: 45%;
        max-width: 240px;
        height: 50px;
    }

    .slide-kv__btn-box__btn a{
        font-size: 16px;
    }
}

@media screen and (max-width:499px) {
    .slide-kv__btn-box{
        display: block;
        bottom: 10px;
    }

    .slide-kv__btn-box__btn{
        width: 100%;
        height: fit-content;
        margin: 0 auto 0.5em;
    }

    .slide-kv__btn-box__btn a{
        padding: 0.2em 0;
    }
}

.home .slide-kv .slide .leadWrap {
    background: #005CB9;
    color: #fff !important;
    padding: 50px 0;
    position: absolute;
    bottom: 0;
    text-align: center;
    width: 100%
}

.home .slide-kv .slide .leadWrap p {
    font-size: 1.2rem;
    line-height: 2;
    letter-spacing: 0.2rem;
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

@media screen and (max-width:859px) {
    .home .slide-kv .slide .leadWrap {
        padding: 25px 5%
    }

    .home .slide-kv .slide .leadWrap p {
        font-size: 1rem;
        line-height: 1.8;
        letter-spacing: 0.1rem;
        text-align: left;
        text-align: justify;
        text-justify: inter-ideograph
    }

    .home .slide-kv .slide .leadWrap p br {
        display: none
    }
}

.home .slide-kv .slide01 .kv_logo {
    height: 100%;
    margin: -113px 0 0 0
}

.home .slide-kv .slide01 .kv_logo img {
    width: 40vw;
    max-width: 600px;
    filter: drop-shadow(0px 0px 18px rgba(0, 0, 0, 0.2));
    margin-bottom: 30px;
}

@media screen and (max-width:859px) {
    .home .slide-kv .slide01 .kv_logo img {
        width: 65vw
    }
}

.home .slide-kv .slide01 .kv_txt {
    height: 100%;
    margin: -113px 0 0 0;
    filter: drop-shadow(0px 0px 18px rgba(0, 0, 0, 0.3))
}

.home .slide-kv .slide01 .kv_txt img {
    width: 60vw;
    max-width: 1000px;
    margin: 0 auto
}

@media screen and (max-width:859px) {
    .home .slide-kv .slide01 .kv_txt {
        margin: -88px 0 0 0
    }

    .home .slide-kv .slide01 .kv_txt img {
        width: 80vw
    }
}

.home .pickup {
    padding: 50px 0
}

@media screen and (max-width:859px) {
    .home .pickup {
        padding: 20px 5% 50px
    }
}

.home .pickup .tit1+p {
    font-size: 1.1rem;
    font-weight: bold;
    text-align: center;
    margin: 0 0 20px
}

@media screen and (max-width:859px) {
    .home .pickup .tit1+p {
        font-size: 0.9rem
    }
}

.home .pickup .slide-pickup {
    margin-bottom: 70px
}

.home .pickup .slide-pickup .c_cate {
    background: #DFE0E0;
    padding: 30px;
    border-radius: 10px 10px;
    margin: 0 15px;
    position: relative
}

@media screen and (max-width:859px) {
    .home .pickup .slide-pickup .c_cate {
        padding: 15px
    }
}

.home .pickup .slide-pickup .c_cate .case_no {
    font-size: 0.8rem;
    font-weight: bold;
    text-align: right
}

.home .pickup .slide-pickup .c_cate .post-categories {
    font-size: 1.1rem;
    background: #005CB9;
    padding: 3px 10px;
    margin: 0 0 20px;
    position: relative;
    z-index: 2;
    border-radius: 5px 5px
}

.home .pickup .slide-pickup .c_cate .post-categories li {
    display: inline-block;
    font-weight: bold
}

.home .pickup .slide-pickup .c_cate .post-categories li a {
    color: #fff;
    pointer-events: none
}

.home .pickup .slide-pickup .c_cate .post-categories li:nth-of-type(2) {
    display: none
}

.home .pickup .slide-pickup .c_cate .case li {
    font-size: 0.9rem;
    font-weight: bold;
    border-bottom: 1px solid #919595;
    padding: 8px 0 8px 35px
}

.home .pickup .slide-pickup .c_cate .case .area {
    background: url(../images/common/icon_area.svg) no-repeat left center;
    background-size: 25px
}

.home .pickup .slide-pickup .c_cate .case .management {
    background: url(../images/common/icon_management.svg) no-repeat left center;
    background-size: 25px
}

.home .pickup .slide-pickup .c_cate .case .sales {
    background: url(../images/common/icon_sales.svg) no-repeat left center;
    background-size: 25px
}

.home .pickup .slide-pickup .c_cate .case .transfer {
    background: url(../images/common/icon_transfer.svg) no-repeat left center;
    background-size: 25px
}

.home .pickup .slide-pickup .c_cate .case .department {
    background: url(../images/common/icon_department.svg) no-repeat left center;
    background-size: 25px
}

.home .pickup .slide-pickup .c_cate .cadse_link {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1
}

.home .pickup .slide-pickup .slide-arrow {
    width: 22px
}

.home .pickup .slide-pickup .slide-arrow img {
    width: 100%;
    height: auto
}

.home .pickup .slide-pickup .prev-arrow {
    position: absolute;
    top: 50%;
    left: -30px;
    transform: translate(0, -50%)
}

@media screen and (max-width:859px) {
    .home .pickup .slide-pickup .prev-arrow {
        left: -15px
    }
}

.home .pickup .slide-pickup .next-arrow {
    position: absolute;
    top: 50%;
    right: -30px;
    transform: translate(0, -50%)
}

@media screen and (max-width:859px) {
    .home .pickup .slide-pickup .next-arrow {
        right: -15px
    }
}

.home .pickup .slide-pickup .slick-dots {
    bottom: -45px
}

.home .pickup .slide-pickup .slick-dots li {
    margin: 0
}

.home .pickup .btnWrap .btn-1 {
    font-size: 1.5rem;
    padding: 12px 50px
}

@media screen and (max-width:859px) {
    .home .pickup .btnWrap .btn-1 {
        font-size: 0.85rem;
        padding: 8px 20px
    }
}

.home .column {
    padding: 80px 0
}

@media screen and (max-width:859px) {
    .home .column {
        padding: 40px 0 30px
    }
}

.home .column .slide-column {
    margin-bottom: 70px
}

.home .column .slide-column li {
    margin: 0 30px
}

.home .column .slide-column li .column_category {
    text-align: right;
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

.home .column .slide-column li .column_category span {
    background: #005CB9;
    color: #fff;
    display: inline-block;
    font-size: 0.8rem;
    padding: 2px 10px 1px;
    margin: 0 0 10px;
    border-radius: 5px 5px
}

.home .column .slide-column li figure {
    margin: 0 0 10px;
    border-radius: 15px 15px;
    overflow: hidden
}

.home .column .slide-column li figure img {
    width: 100%;
    height: auto
}

.home .column .slide-column li h3 {
    font-size: 1rem;
    font-weight: bold;
    line-height: 1.5
}

@media screen and (max-width:859px) {
    .home .column .slide-column li h3 br {
        display: none
    }
}

.home .column .slide-column .slide-arrow {
    width: 22px
}

.home .column .slide-column .slide-arrow img {
    width: 100%;
    height: auto
}

.home .column .slide-column .prev-arrow {
    position: absolute;
    top: 50%;
    left: -30px;
    transform: translate(0, -50%)
}

@media screen and (max-width:859px) {
    .home .column .slide-column .prev-arrow {
        left: 0
    }
}

.home .column .slide-column .next-arrow {
    position: absolute;
    top: 50%;
    right: -30px;
    transform: translate(0, -50%)
}

@media screen and (max-width:859px) {
    .home .column .slide-column .next-arrow {
        right: 0
    }
}

.home .column .slide-column .slick-dots {
    bottom: -45px
}

.home .column .slide-column .slick-dots li {
    margin: 0
}

.home .news {
    margin: 50px auto 100px
}

@media screen and (max-width:859px) {
    .home .news {
        margin: 0 auto 30px
    }
}

.home .news article {
    margin: 0 0 30px
}

.home .news article li a {
    background: #DFE0E0;
    padding: 10px;
    position: relative;
    margin: 0 0 10px;
    padding: 10px 0 10px 85px;
    display: block;
    line-height: 1.3
}

.home .news article li a:hover {
    background: #efefef
}

@media screen and (max-width:859px) {
    .home .news article li a {
        padding: 15px
    }
}

.home .news article li a .new-txt {
    position: absolute;
    background: #005CB9;
    color: #fff;
    font-size: 0.8rem;
    font-weight: bold;
    top: 12px;
    left: 12px;
    padding: 10px
}

@media screen and (max-width:859px) {
    .home .news article li a .new-txt {
        position: relative;
        top: 0;
        left: 0;
        font-size: 0.8rem;
        padding: 5px 8px;
        margin: 0 5px 7px 0;
        display: inline-block
    }
}

.home .news article li a time {
    font-size: 0.8rem
}

.home .news article li a p {
    font-weight: bold
}

@media screen and (max-width:859px) {
    .home .news article li a p {
        font-size: 1rem
    }
}

.home .dictionary {
    margin: 0 auto 100px
}

@media screen and (max-width:859px) {
    .home .dictionary {
        margin: 0 auto 50px
    }
}

.home .dictionary a img {
    width: 100%;
    height: auto
}

.home .dictionary a:hover {
    opacity: 0.6
}

.home #other {
    position: relative;
    z-index: 1000;
    margin: 1px 0 50px
}

@media screen and (max-width:859px) {
    .home #other {
        height: auto;
        margin: 1px 0 30px
    }
}

.home #other .wrap {
    width: 100%;
    margin: 0 auto
}

@media screen and (max-width:859px) {
    .home #other .wrap {
        width: 90%
    }
}

.home #other .wrap .title {
    font-size: 2vw;
    text-align: center;
    letter-spacing: 0.5em;
    padding: 25px 0;
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

.home #other .wrap .title span {
    position: relative
}

.home #other .wrap .title span:before {
    content: "";
    background: #005CB9;
    width: 70px;
    height: 1px;
    position: absolute;
    top: 0.7vw;
    left: -80px
}

.home #other .wrap .title span:after {
    content: "";
    background: #005CB9;
    width: 70px;
    height: 1px;
    position: absolute;
    top: 0.7vw;
    right: -75px
}

@media screen and (max-width:859px) {
    .home #other .wrap .title {
        font-size: 1.3rem;
        letter-spacing: 0.2em
    }

    .home #other .wrap .title span:before {
        display: none
    }

    .home #other .wrap .title span:after {
        display: none
    }
}

.home #other .grid figure {
    position: relative;
    float: left;
    overflow: hidden;
    background: #000;
    text-align: center;
    cursor: pointer
}

.home #other .grid figure img {
    position: relative;
    display: block;
    min-height: 100%;
    max-width: 100%;
    opacity: 0.8
}

.home #other .grid figure figcaption, .home #other .grid figure figcaption>a {
    padding: 2em;
    color: #fff;
    font-size: 1.25em;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden
}

.home #other .grid figure figcaption:after, .home #other .grid figure figcaption:before, .home #other .grid figure figcaption>a:after, .home #other .grid figure figcaption>a:before {
    pointer-events: none
}

.home #other .grid figure figcaption, .home #other .grid figure figcaption>a {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 11
}

.home #other ul li {
    width: calc((100% - 3px) / 4);
    margin-right: 1px
}

.home #other ul li:last-child {
    margin-right: 0
}

@media screen and (max-width:859px) {
    .home #other ul li {
        width: 100%;
        margin-bottom: 1%
    }

    .home #other ul li figure {
        height: 200px
    }
}

.home #other ul li figure.effect-sadie figcaption:before {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to bottom, rgba(0, 40, 150, 0) 0%, rgba(0, 40, 150, 0.8) 75%);
    content: "";
    opacity: 0;
    transform: translate3d(0, 50%, 0)
}

.home #other ul li figure.effect-sadie figcaption:after {
    position: absolute;
    top: -50%;
    left: 0;
    width: 100%;
    height: 100%;
    background: #005CB9;
    content: "";
    opacity: 0.4;
    transform: translate3d(0, 50%, 0)
}

.home #other ul li figure.effect-sadie h2 {
    position: absolute;
    top: 32%;
    left: 0;
    width: 100%;
    color: #fff;
    font-size: 1.7vw;
    font-weight: bold;
    line-height: 1.5;
    letter-spacing: 0.1em;
    z-index: 10;
    transition: transform 0.35s, color 0.35s;
    transform: translate3d(0, -50%, 0);
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

@media screen and (max-width:859px) {
    .home #other ul li figure.effect-sadie h2 {
        font-size: 1.3rem;
        top: 29%
    }
}

.home #other ul li figure.effect-sadie h3 {
    position: absolute;
    top: 64%;
    left: 15%;
    width: 70%;
    color: #fff;
    font-size: 1vw;
    font-weight: bold;
    line-height: 1.8;
    letter-spacing: 0.1em;
    text-align: left;
    z-index: 10;
    transition: transform 0.35s, color 0.35s;
    transform: translate3d(0, -50%, 0)
}

@media screen and (max-width:859px) {
    .home #other ul li figure.effect-sadie h3 {
        font-size: 0.9rem;
        top: 69%;
        left: 8%;
        width: 84%
    }
}

.home #other ul li figure.effect-sadie figcaption:before, .home #other ul li figure.effect-sadie p {
    transition: opacity 0.35s, transform 0.35s
}

.home #other ul li figure.effect-sadie p {
    position: absolute;
    bottom: 0;
    font-size: 0.8rem;
    left: 0;
    padding: 2em;
    width: 100%;
    opacity: 0;
    z-index: 10;
    transform: translate3d(0, 10px, 0)
}

.home #other ul li figure.effect-sadie:hover h2 {
    color: #fff;
    transform: translate3d(0, -50%, 0) translate3d(0, -40px, 0)
}

.home #other ul li figure.effect-sadie:hover h3 {
    color: #fff;
    transform: translate3d(0, -50%, 0) translate3d(0, -40px, 0)
}

.home #other ul li figure.effect-sadie:hover figcaption:before, .home #other ul li figure.effect-sadie:hover p {
    opacity: 1;
    transform: translate3d(0, 0, 0)
}

.home #other ul li figure.effect-sadie:hover figcaption:after {
    opacity: 0.5
}

.library #header, .page #header {
    transform: translateY(0);
    background: #fff
}

.library #header.hide, .page #header.hide {
    transform: translateY(-100%)
}

.library .titleWrap, .page .titleWrap {
    padding: 120px 0 0 0
}

@media screen and (max-width:859px) {
    .library .titleWrap, .page .titleWrap {
        padding: 80px 0 0 0
    }
}

.library .titleWrap .title, .page .titleWrap .title {
    padding: 150px 0;
    text-align: center
}

@media screen and (max-width:859px) {
    .library .titleWrap .title, .page .titleWrap .title {
        padding: 80px 0
    }
}

.library .titleWrap .title h1, .page .titleWrap .title h1 {
    color: #fff;
    font-size: 5rem;
    letter-spacing: 1.5rem;
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif;
    filter: drop-shadow(0 0 18px rgba(0, 0, 0, 0.3))
}

@media screen and (max-width:1100px) and (min-width:860px) {
    .library .titleWrap .title h1, .page .titleWrap .title h1 {
        font-size: 5rem;
        letter-spacing: 1rem
    }
}

@media screen and (max-width:859px) {
    .library .titleWrap .title h1, .page .titleWrap .title h1 {
        font-size: 3rem;
        letter-spacing: 0.5rem
    }
}

.library .titleWrap .lead, .page .titleWrap .lead {
    background: #DFE0E0;
    color: #005CB9;
    padding: 40px 0;
    text-align: center;
    width: 100%;
    display: block
}

.library .titleWrap .lead p, .page .titleWrap .lead p {
    font-size: 1.2rem;
    line-height: 1.8;
    letter-spacing: 0.2rem;
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

@media screen and (max-width:859px) {
    .library .titleWrap .lead, .page .titleWrap .lead {
        padding: 25px 5%
    }

    .library .titleWrap .lead p, .page .titleWrap .lead p {
        font-size: 1rem;
        line-height: 1.8;
        letter-spacing: 0.1rem
    }
}

.service .titleWrap .title {
    background: url(../images/service/title_img.jpg) no-repeat center center/cover;
    background-attachment: fixed
}

@media screen and (max-width:859px) {
    .service .titleWrap .title {
        background-attachment: scroll
    }
}

.service .menu {
    background: url(../images/service/menu_bg.jpg) no-repeat center center/cover;
    background-attachment: fixed;
    padding: 200px 0 50px
}

@media screen and (max-width:859px) {
    .service .menu {
        overflow: hidden;
        padding: 100px 30px 50px
    }
}

.service .menu .inner80 {
    border: 4px solid #005CB9;
    position: relative;
    height: 800px;
    margin: 0 auto 70px;
    border-radius: 100% 100%
}

@media screen and (max-height:800px) {
    .service .menu .inner80 {
        transform: scale(0.7) !important;
        margin: -120px auto -50px
    }
}

@media screen and (max-height:800px) and (max-width:859px) {
    .service .menu .inner80 {
        transform: scale(0.9) !important;
        margin: -30px auto 0
    }
}

@media screen and (max-width:859px) {
    .service .menu .inner80 {
        height: 300px;
        margin: 0 auto
    }
}

.service .menu .inner80 .tit1 {
    position: relative
}

@media screen and (max-width:859px) {
    .service .menu .inner80 .tit1 {
        font-size: 1.5rem
    }
}

.service .menu .inner80 .tit1:before {
    content: "";
    position: absolute;
    bottom: 0px;
    width: 240px;
    opacity: 0.3;
    height: 120px;
    background: url(../images/common/icon_service.svg) no-repeat center bottom
}

@media screen and (max-width:859px) {
    .service .menu .inner80 .tit1:before {
        width: 100px;
        height: 60px
    }
}

.service .menu .inner80 .service-item li {
    position: absolute
}

.service .menu .inner80 .service-item li a {
    background: #005CB9;
    width: 270px;
    height: 270px;
    color: #fff;
    font-size: 1.3rem;
    font-weight: bold;
    letter-spacing: 0.2rem;
    text-align: center;
    border-radius: 100% 100%
}

.service .menu .inner80 .service-item li a:hover {
    background-color: #00366d;
    transform: scale(0.95)
}

@media screen and (max-width:859px) {
    .service .menu .inner80 .service-item li a {
        font-size: 0.8rem;
        font-weight: bold;
        letter-spacing: 0;
        width: 130px;
        height: 130px
    }
}

.service .menu .inner80 .service-item .service-1 {
    left: 50%;
    top: 0;
    transform: translate(-50%, -50%)
}

.service .menu .inner80 .service-item .service-2 {
    right: -13%;
    top: 17%
}

.service .menu .inner80 .service-item .service-3 {
    right: 3%;
    bottom: -4%
}

@media screen and (max-width:859px) {
    .service .menu .inner80 .service-item .service-3 {
        bottom: -10%
    }
}

.service .menu .inner80 .service-item .service-4 {
    left: 3%;
    bottom: -4%
}

@media screen and (max-width:859px) {
    .service .menu .inner80 .service-item .service-4 {
        bottom: -10%
    }
}

.service .menu .inner80 .service-item .service-5 {
    left: -13%;
    top: 17%
}

.service #strengths {
    padding: 60px 0 0 0 !important
}

@media screen and (max-width:859px) {
    .service #strengths {
        padding: 40px 0 0 0 !important
    }
}

.service #flow, .service #rewards, .service #strengths, .service #support {
    margin: 70px 0;
    overflow: hidden
}

@media screen and (max-width:859px) {
    .service #flow, .service #rewards, .service #strengths, .service #support {
        padding: 0
    }
}

.service #flow .tit1, .service #rewards .tit1, .service #strengths .tit1, .service #support .tit1 {
    margin-bottom: 20px;
    margin-left: calc(50% - 500px);
    text-align: left
}

@media screen and (max-width:1100px) and (min-width:860px) {
    .service #flow .tit1, .service #rewards .tit1, .service #strengths .tit1, .service #support .tit1 {
        font-size: 3rem;
        margin: 0 5% 50px
    }
}

@media screen and (max-width:859px) {
    .service #flow .tit1, .service #rewards .tit1, .service #strengths .tit1, .service #support .tit1 {
        font-size: 1.8rem;
        margin: 0 5% 20px;
        letter-spacing: 0.1rem
    }
}

.service #flow .point, .service #rewards .point, .service #strengths .point, .service #support .point {
    color: #005CB9;
    margin: 0 0 100px
}

@media screen and (max-width:859px) {
    .service #flow .point, .service #rewards .point, .service #strengths .point, .service #support .point {
        margin: 0 0 70px;
        position: relative
    }
}

.service #flow .point .inner10, .service #rewards .point .inner10, .service #strengths .point .inner10, .service #support .point .inner10 {
    position: relative
}

.service #flow .point .inner10 .vertical-txt, .service #rewards .point .inner10 .vertical-txt, .service #strengths .point .inner10 .vertical-txt, .service #support .point .inner10 .vertical-txt {
    position: absolute;
    top: 0;
    left: -7.5%;
    writing-mode: vertical-rl;
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: vertical-rl;
    border-right: 2px solid #005CB9;
    padding: 20px 0px;
    font-size: 1.2rem;
    white-space: nowrap;
    z-index: 10;
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

.service #flow .point .inner10 .vertical-txt span, .service #rewards .point .inner10 .vertical-txt span, .service #strengths .point .inner10 .vertical-txt span, .service #support .point .inner10 .vertical-txt span {
    transform: rotate(-90deg);
    display: inline-block
}

.service #flow .point .inner10 .vertical-txt h5, .service #rewards .point .inner10 .vertical-txt h5, .service #strengths .point .inner10 .vertical-txt h5, .service #support .point .inner10 .vertical-txt h5 {
    display: inline-block;
    letter-spacing: 0.2rem;
    margin-top: 15px
}

@media screen and (max-width:859px) {
    .service #flow .point .inner10 .vertical-txt, .service #rewards .point .inner10 .vertical-txt, .service #strengths .point .inner10 .vertical-txt, .service #support .point .inner10 .vertical-txt {
        position: relative;
        writing-mode: horizontal-tb;
        -webkit-writing-mode: horizontal-tb;
        -ms-writing-mode: horizontal-tb;
        left: 0;
        border-right: none;
        border-top: 2px solid #005CB9;
        padding: 0 0 30px;
        font-size: 0.9rem;
        line-height: 1
    }

    .service #flow .point .inner10 .vertical-txt span, .service #rewards .point .inner10 .vertical-txt span, .service #strengths .point .inner10 .vertical-txt span, .service #support .point .inner10 .vertical-txt span {
        transform: rotate(0);
        margin-right: 10px
    }

    .service #flow .point .inner10 .vertical-txt h5, .service #rewards .point .inner10 .vertical-txt h5, .service #strengths .point .inner10 .vertical-txt h5, .service #support .point .inner10 .vertical-txt h5 {
        letter-spacing: 0.1rem;
        margin-top: 10px
    }
}

.service #flow .point h3, .service #rewards .point h3, .service #strengths .point h3, .service #support .point h3 {
    font-size: 2.2rem;
    font-weight: 800;
    letter-spacing: 0.4rem;
    line-height: 1.4;
    margin: 0 0 20px;
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

@media screen and (max-width:859px) {
    .service #flow .point h3, .service #rewards .point h3, .service #strengths .point h3, .service #support .point h3 {
        font-size: 1.4rem;
        margin: 0 0 10px
    }
}

.service #flow .point .point-txt, .service #rewards .point .point-txt, .service #strengths .point .point-txt, .service #support .point .point-txt {
    background: #DFE0E0;
    padding: 30px 0;
    margin: 0 0 30px
}

@media screen and (max-width:859px) {
    .service #flow .point .point-txt, .service #rewards .point .point-txt, .service #strengths .point .point-txt, .service #support .point .point-txt {
        padding: 30px 5%;
        margin: 0 0 20px
    }
}

.service #flow .point .point-txt .point-inner, .service #rewards .point .point-txt .point-inner, .service #strengths .point .point-txt .point-inner, .service #support .point .point-txt .point-inner {
    margin-left: calc(50% - 500px)
}

@media screen and (max-width:1100px) and (min-width:860px) {
    .service #flow .point .point-txt .point-inner, .service #rewards .point .point-txt .point-inner, .service #strengths .point .point-txt .point-inner, .service #support .point .point-txt .point-inner {
        margin-left: 5%
    }
}

@media screen and (max-width:859px) {
    .service #flow .point .point-txt .point-inner, .service #rewards .point .point-txt .point-inner, .service #strengths .point .point-txt .point-inner, .service #support .point .point-txt .point-inner {
        margin-left: 0;
        flex-wrap: wrap
    }
}

.service #flow .point .point-txt .point-inner div, .service #rewards .point .point-txt .point-inner div, .service #strengths .point .point-txt .point-inner div, .service #support .point .point-txt .point-inner div {
    width: 55%
}

@media screen and (max-width:1100px) and (min-width:860px) {
    .service #flow .point .point-txt .point-inner div, .service #rewards .point .point-txt .point-inner div, .service #strengths .point .point-txt .point-inner div, .service #support .point .point-txt .point-inner div {
        width: 65%
    }
}

@media screen and (max-width:859px) {
    .service #flow .point .point-txt .point-inner div, .service #rewards .point .point-txt .point-inner div, .service #strengths .point .point-txt .point-inner div, .service #support .point .point-txt .point-inner div {
        width: 100%
    }
}

.service #flow .point .point-txt .point-inner div h4, .service #rewards .point .point-txt .point-inner div h4, .service #strengths .point .point-txt .point-inner div h4, .service #support .point .point-txt .point-inner div h4 {
    font-size: 1.6rem;
    font-weight: bold;
    margin: 0 0 20px;
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

@media screen and (max-width:859px) {
    .service #flow .point .point-txt .point-inner div h4, .service #rewards .point .point-txt .point-inner div h4, .service #strengths .point .point-txt .point-inner div h4, .service #support .point .point-txt .point-inner div h4 {
        font-size: 1.3rem
    }
}

.service #flow .point .point-txt .point-inner div h4+p, .service #rewards .point .point-txt .point-inner div h4+p, .service #strengths .point .point-txt .point-inner div h4+p, .service #support .point .point-txt .point-inner div h4+p {
    font-size: 1rem;
    font-weight: bold
}

@media screen and (max-width:859px) {
    .service #flow .point .point-txt .point-inner div h4+p, .service #rewards .point .point-txt .point-inner div h4+p, .service #strengths .point .point-txt .point-inner div h4+p, .service #support .point .point-txt .point-inner div h4+p {
        font-size: 1rem
    }
}

.service #flow .point .point-txt .point-inner figure, .service #rewards .point .point-txt .point-inner figure, .service #strengths .point .point-txt .point-inner figure, .service #support .point .point-txt .point-inner figure {
    width: 480px;
    margin: -130px 0 0 0;
    padding: 0 50px
}

.service #flow .point .point-txt .point-inner figure img, .service #rewards .point .point-txt .point-inner figure img, .service #strengths .point .point-txt .point-inner figure img, .service #support .point .point-txt .point-inner figure img {
    width: 100%;
    height: auto
}

@media screen and (max-width:1100px) and (min-width:860px) {
    .service #flow .point .point-txt .point-inner figure, .service #rewards .point .point-txt .point-inner figure, .service #strengths .point .point-txt .point-inner figure, .service #support .point .point-txt .point-inner figure {
        padding: 0;
        width: 30%
    }
}

@media screen and (max-width:859px) {
    .service #flow .point .point-txt .point-inner figure, .service #rewards .point .point-txt .point-inner figure, .service #strengths .point .point-txt .point-inner figure, .service #support .point .point-txt .point-inner figure {
        position: absolute;
        top: 0%;
        right: 50px;
        margin: 0 0 0 0;
        width: 20%;
        padding: 0
    }
}

.service #flow .point .btnWrap, .service #rewards .point .btnWrap, .service #strengths .point .btnWrap, .service #support .point .btnWrap {
    text-align: left
}

.service #flow .point-2, .service #rewards .point-2, .service #strengths .point-2, .service #support .point-2 {
    margin: 0 0 200px
}

@media screen and (max-width:859px) {
    .service #flow .point-2, .service #rewards .point-2, .service #strengths .point-2, .service #support .point-2 {
        margin: 0 0 100px
    }
}

.service #flow .point-2 .point-txt .point-inner figure, .service #rewards .point-2 .point-txt .point-inner figure, .service #strengths .point-2 .point-txt .point-inner figure, .service #support .point-2 .point-txt .point-inner figure {
    margin: -240px 0 0 0
}

@media screen and (max-width:859px) {
    .service #flow .point-2 .point-txt .point-inner figure, .service #rewards .point-2 .point-txt .point-inner figure, .service #strengths .point-2 .point-txt .point-inner figure, .service #support .point-2 .point-txt .point-inner figure {
        margin: 0
    }
}

.service #flow .point-2 .point-txt .box, .service #rewards .point-2 .point-txt .box, .service #strengths .point-2 .point-txt .box, .service #support .point-2 .point-txt .box {
    background: #005CB9;
    color: #fff;
    padding: 40px 100px 40px 40px;
    position: relative;
    margin-left: calc(50% - 500px);
    margin-top: 30px;
    margin-bottom: -100px
}

@media screen and (max-width:1100px) and (min-width:860px) {
    .service #flow .point-2 .point-txt .box, .service #rewards .point-2 .point-txt .box, .service #strengths .point-2 .point-txt .box, .service #support .point-2 .point-txt .box {
        margin-left: 5%
    }
}

@media screen and (max-width:859px) {
    .service #flow .point-2 .point-txt .box, .service #rewards .point-2 .point-txt .box, .service #strengths .point-2 .point-txt .box, .service #support .point-2 .point-txt .box {
        padding: 15px;
        margin-left: 0;
        margin-top: 20px;
        margin-bottom: 0
    }
}

.service #flow .point-2 .point-txt .box h4, .service #rewards .point-2 .point-txt .box h4, .service #strengths .point-2 .point-txt .box h4, .service #support .point-2 .point-txt .box h4 {
    display: inline-block;
    font-size: 3rem;
    letter-spacing: 0.5rem;
    margin: 0 10px 20px
}

@media screen and (max-width:859px) {
    .service #flow .point-2 .point-txt .box h4, .service #rewards .point-2 .point-txt .box h4, .service #strengths .point-2 .point-txt .box h4, .service #support .point-2 .point-txt .box h4 {
        font-size: 1.6rem;
        margin: 0 0 10px
    }
}

.service #flow .point-2 .point-txt .box h4+p, .service #rewards .point-2 .point-txt .box h4+p, .service #strengths .point-2 .point-txt .box h4+p, .service #support .point-2 .point-txt .box h4+p {
    display: inline-block;
    font-weight: normal
}

.service #flow .point-2 .point-txt .box h4+p span, .service #rewards .point-2 .point-txt .box h4+p span, .service #strengths .point-2 .point-txt .box h4+p span, .service #support .point-2 .point-txt .box h4+p span {
    font-size: 0.8rem
}

@media screen and (max-width:859px) {
    .service #flow .point-2 .point-txt .box h4+p, .service #rewards .point-2 .point-txt .box h4+p, .service #strengths .point-2 .point-txt .box h4+p, .service #support .point-2 .point-txt .box h4+p {
        font-size: 0.9rem;
        margin: 0 0 10px
    }
}

.service #flow .point-2 .point-txt .box .point-table, .service #rewards .point-2 .point-txt .box .point-table, .service #strengths .point-2 .point-txt .box .point-table, .service #support .point-2 .point-txt .box .point-table {
    max-width: 1000px;
    height: 300px;
    text-align: left;
    margin-bottom: 20px
}

@media screen and (max-width:859px) {
    .service #flow .point-2 .point-txt .box .point-table, .service #rewards .point-2 .point-txt .box .point-table, .service #strengths .point-2 .point-txt .box .point-table, .service #support .point-2 .point-txt .box .point-table {
        max-width: 1000px;
        height: auto
    }
}

.service #flow .point-3 .point-txt .point-inner div h5, .service #flow .point-3 .point-txt .point-inner div h5+p, .service #rewards .point-3 .point-txt .point-inner div h5, .service #rewards .point-3 .point-txt .point-inner div h5+p, .service #strengths .point-3 .point-txt .point-inner div h5, .service #strengths .point-3 .point-txt .point-inner div h5+p, .service #support .point-3 .point-txt .point-inner div h5, .service #support .point-3 .point-txt .point-inner div h5+p {
    font-size: 1rem;
    font-weight: bold
}

@media screen and (max-width:859px) {
    .service #flow .point-3 .point-txt .point-inner div h5, .service #flow .point-3 .point-txt .point-inner div h5+p, .service #rewards .point-3 .point-txt .point-inner div h5, .service #rewards .point-3 .point-txt .point-inner div h5+p, .service #strengths .point-3 .point-txt .point-inner div h5, .service #strengths .point-3 .point-txt .point-inner div h5+p, .service #support .point-3 .point-txt .point-inner div h5, .service #support .point-3 .point-txt .point-inner div h5+p {
        font-size: 1rem
    }
}

.service #flow .point-3 .point-txt .point-inner div h5+p, .service #rewards .point-3 .point-txt .point-inner div h5+p, .service #strengths .point-3 .point-txt .point-inner div h5+p, .service #support .point-3 .point-txt .point-inner div h5+p {
    margin: 0 0 10px
}

.service #flow .point-3 .point-txt .point-inner figure, .service #rewards .point-3 .point-txt .point-inner figure, .service #strengths .point-3 .point-txt .point-inner figure, .service #support .point-3 .point-txt .point-inner figure {
    margin: -90px 0 0 0
}

@media screen and (max-width:859px) {
    .service #flow .point-3 .point-txt .point-inner figure, .service #rewards .point-3 .point-txt .point-inner figure, .service #strengths .point-3 .point-txt .point-inner figure, .service #support .point-3 .point-txt .point-inner figure {
        margin: 0
    }
}

.service #flow .tit1, .service #rewards .tit1, .service #support .tit1 {
    font-size: 3rem;
    margin-bottom: 30px
}

@media screen and (max-width:859px) {
    .service #flow .tit1, .service #rewards .tit1, .service #support .tit1 {
        font-size: 2rem;
        margin-bottom: 0
    }
}

.service #rewards .point .point-txt .inner10 div h4 {
    font-size: 1.6rem;
    font-weight: bold;
    margin: 0 0 20px;
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

@media screen and (max-width:859px) {
    .service #rewards .point .point-txt .inner10 div h4 {
        font-size: 1.3rem
    }
}

.service #rewards .point .point-txt .box {
    background: #fff;
    padding: 40px 100px 40px 40px;
    position: relative;
    margin-left: calc(50% - 500px);
    margin-top: 30px
}

@media screen and (max-width:859px) {
    .service #rewards .point .point-txt .box {
        padding: 0;
        overflow: scroll;
        margin-left: 0;
        margin-top: 20px
    }

    .service #rewards .point .point-txt .box:before {
        content: "→表示は横スクロールすることが可能です。";
        color: #000;
        background: #DFE0E0;
        font-size: 0.8rem;
        width: 700px;
        padding: 5px;
        display: block
    }
}

.service #rewards .point .point-txt .box .point-table {
    background: #fff;
    width: 100%;
    max-width: 1200px;
    text-align: center;
    font-size: 0.9rem;
    line-height: 1.3rem
}

@media screen and (max-width:859px) {
    .service #rewards .point .point-txt .box .point-table {
        width: 700px;
        line-height: 1.3rem
    }
}

.service #rewards .point .point-txt .box .point-table tr {
    border-bottom: 1px solid #005CB9
}

.service #rewards .point .point-txt .box .point-table tr td, .service #rewards .point .point-txt .box .point-table tr th {
    padding: 1rem
}

@media screen and (max-width:859px) {
    .service #rewards .point .point-txt .box .point-table tr td, .service #rewards .point .point-txt .box .point-table tr th {
        padding: 0.5rem;
        font-size: 0.8rem
    }
}

.service #rewards .point .point-txt .box .point-table tr th {
    background: #005CB9;
    color: #fff;
    text-align: center;
    border-right: 1px solid #fff
}

.service #rewards .point .point-txt .box .point-table tr th:last-child {
    border-right: none
}

.service #rewards .point .point-txt .box .point-table tr td {
    border-right: 1px solid #005CB9
}

.service #rewards .point .point-txt .box .point-table tr td:last-child {
    border-right: none
}

.service #rewards .point .point-txt .box .point-table tr td:nth-of-type(4) {
    text-align: left;
    background: #ecf5ff
}

.service #rewards .point .point-txt .box .point-table tr td:nth-of-type(4) span {
    color: #EE87B4;
    font-weight: bold
}

.service #rewards .point .point-txt .box .point-table .gcf {
    transition: all 0.5s
}

.service #rewards .point .point-txt .box .point-table .gcf.active {
    background: #005CB9;
    color: #fff;
    font-weight: bold
}

.service #rewards .point .point-txt .box .point-table .gcf.active td {
    border-right: 1px solid #fff
}

.service #rewards .point .point-txt .box .point-table .gcf.active td:last-child {
    border-right: none
}

.service #rewards .point .point-txt .box .point-table .gcf.active td:nth-of-type(4) {
    background: #005CB9
}

.service #rewards .point-1 {
    margin: 0
}

@media screen and (max-width:859px) {
    .service #flow {
        margin: 0 0 100px
    }
}

.service #flow .point {
    margin: 0
}

.service #flow .point .point-txt {
    margin: 0 0 130px
}

@media screen and (max-width:859px) {
    .service #flow .point .point-txt {
        margin: 0 0 20px
    }
}

.service #flow .point .point-txt .point-inner figure {
    margin: -220px 0 0 0
}

@media screen and (max-width:859px) {
    .service #flow .point .point-txt .point-inner figure {
        margin: -40px 0px 0 0;
        width: 30%;
        right: 10px
    }
}

.service #flow .point .point-txt .box {
    background: #005CB9;
    padding: 40px 100px 40px 40px;
    position: relative;
    margin-left: calc(50% - 500px);
    margin-bottom: -100px
}

@media screen and (max-width:859px) {
    .service #flow .point .point-txt .box {
        overflow: scroll;
        margin-left: 0;
        margin-top: 0;
        padding: 10px;
        margin-bottom: 0
    }
}

.service #flow .flow-overlay {
    display: none;
    counter-reset: number 0;
    background: rgba(255, 255, 255, 0.8);
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 100000;
    overflow: scroll;
    padding: 80px 0
}

@media screen and (max-width:859px) {
    .service #flow .flow-overlay {
        padding: 40px 0
    }
}

.service #flow .flow-overlay .closeWrap {
    position: fixed
}

.service #flow .flow-overlay .wrap {
    width: 1000px;
    margin: 0 auto 80px;
    filter: drop-shadow(0px -18px 18px rgba(0, 0, 0, 0.3))
}

@media screen and (max-width:859px) {
    .service #flow .flow-overlay .wrap {
        width: 100%
    }
}

.service #flow .flow-overlay .wrap .title {
    background: #005CB9;
    text-align: center
}

.service #flow .flow-overlay .wrap .title h5 {
    color: #fff;
    font-size: 3rem;
    font-weight: bold;
    padding: 50px 0;
    letter-spacing: 0.4rem
}

@media screen and (max-width:859px) {
    .service #flow .flow-overlay .wrap .title h5 {
        font-size: 2rem;
        letter-spacing: 0.2rem;
        padding: 20px 0
    }
}

.service #flow .flow-overlay .wrap .content {
    background: #DFE0E0;
    color: #005CB9;
    font-size: 1.5rem;
    font-weight: bold;
    padding: 50px;
    margin: 0 0 100px
}

@media screen and (max-width:859px) {
    .service #flow .flow-overlay .wrap .content {
        padding: 15px;
        margin: 0 0 50px
    }
}

.service #flow .flow-overlay .wrap .content .overlayTimeline {
    padding: 3rem 5rem
}

@media screen and (max-width:859px) {
    .service #flow .flow-overlay .wrap .content .overlayTimeline {
        padding: 1rem
    }
}

.service #flow .flow-overlay .wrap .content .overlayTimeline-item {
    position: relative;
    border-left: 1px solid #005CB9;
    padding: 0 0 60px 30px
}

@media screen and (max-width:859px) {
    .service #flow .flow-overlay .wrap .content .overlayTimeline-item {
        padding: 0 0 30px 25px
    }
}

.service #flow .flow-overlay .wrap .content .overlayTimeline-item:before {
    content: "";
    display: block;
    width: 30px;
    height: 30px;
    position: absolute;
    left: 0;
    top: 0;
    border-radius: 100%;
    background-color: #005CB9;
    transform: translateX(-50%) translateY(0%)
}

.service #flow .flow-overlay .wrap .content .overlayTimeline-item:after {
    counter-increment: number 1;
    content: counter(number) " ";
    color: #fff;
    font-size: 1rem;
    font-weight: bold;
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    transform: translateX(-50%) translateY(0)
}

.service #flow .flow-overlay .wrap .content .overlayTimeline-item:last-child .overlayTimeline-content {
    position: relative
}

.service #flow .flow-overlay .wrap .content .overlayTimeline-item:last-child .overlayTimeline-content:after {
    content: "";
    position: absolute;
    bottom: -132px;
    left: -41px;
    width: 20px;
    height: 20px;
    border-top: 1px solid #005CB9;
    border-right: 1px solid #005CB9;
    transform: rotate(135deg)
}

@media screen and (max-width:859px) {
    .service #flow .flow-overlay .wrap .content .overlayTimeline-item:last-child .overlayTimeline-content:after {
        bottom: -188px;
        left: -37px
    }
}

.service #flow .flow-overlay .wrap .content .overlayTimeline .overlayTimeline-content {
    font-size: 1.8rem;
    font-weight: bold;
    color: #005CB9;
    margin: 0 0 20px;
    line-height: 1;
    text-orientation: upright
}

@media screen and (max-width:859px) {
    .service #flow .flow-overlay .wrap .content .overlayTimeline .overlayTimeline-content {
        font-size: 1.3rem;
        padding: 5px 0 0 0
    }
}

.service #flow .flow-overlay .wrap .content .overlayTimeline .overlayTimeline-content+p {
    color: #005CB9;
    font-size: 1rem;
    font-weight: normal
}

.service #flow .flow-overlay .wrap .btn-close {
    margin: 0 auto;
    width: 250px;
    background: #005CB9;
    text-align: center
}

.service #flow .flow-overlay .wrap .btn-close p {
    cursor: pointer;
    display: block;
    padding: 10px 0 8px;
    color: #fff;
    font-size: 1rem;
    font-weight: bold;
    letter-spacing: 0.4rem;
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

.service #support .point .point-txt .point-inner div p {
    font-size: 1srem;
    font-weight: bold
}

@media screen and (max-width:859px) {
    .service #support .point .point-txt .point-inner div p {
        font-size: 1rem;
        margin-bottom: 10px
    }
}

.service #support .point .point-txt .point-inner figure {
    margin: -200px 0 0 0;
    padding: 0
}

@media screen and (max-width:859px) {
    .service #support .point .point-txt .point-inner figure {
        margin: -50px 0px 0 0;
        width: 25%;
        right: -10px
    }
}

.service #support .point .point-txt .box {
    background: #005CB9;
    padding: 40px 100px 40px 40px;
    position: relative;
    margin-left: calc(50% - 500px);
    margin-top: 30px;
    margin-bottom: -150px
}

@media screen and (max-width:859px) {
    .service #support .point .point-txt .box {
        padding: 20px;
        margin: 0
    }
}

.service #support .point .point-txt .box h4 {
    color: #fff;
    font-size: 2rem;
    font-weight: bold
}

@media screen and (max-width:859px) {
    .service #support .point .point-txt .box h4 {
        font-size: 1.3rem
    }
}

.service #support .point .point-txt .box h4+p {
    color: #fff;
    font-size: 1.2rem;
    font-weight: bold
}

.service #support .point .point-txt .box h4+p span {
    font-size: 0.9rem;
    font-weight: normal
}

@media screen and (max-width:859px) {
    .service #support .point .point-txt .box h4+p {
        font-size: 1rem;
        margin-bottom: 10px
    }

    .service #support .point .point-txt .box h4+p span {
        font-size: 0.8rem;
        display: block
    }
}

.service #support .point .point-txt .box small {
    color: #fff
}

.service #support .point .point-txt .box .timeline {
    padding: 3rem 0 3rem 40px
}

@media screen and (max-width:859px) {
    .service #support .point .point-txt .box .timeline {
        padding: 10px
    }
}

@media screen and (max-width:859px) {
    .service #support .point .point-txt .box .timeline-item {
        padding: 0 0 15px 18px
    }

    .service #support .point .point-txt .box .timeline-item .timeline-content {
        line-height: 1.4
    }
}

.service #support .point .point-txt .box .timeline-item:before {
    content: "";
    display: block;
    width: 20px;
    height: 20px;
    position: absolute;
    left: 0;
    top: 0;
    border-radius: 100%;
    background-color: #fff;
    transform: translateX(-50%) translateY(-50%)
}

@media screen and (max-width:859px) {
    .service #support .point .point-txt .box .timeline-item:before {
        transform: translateX(-50%) translateY(0)
    }
}

.service #support .point .point-txt .box .timeline-item:after {
    content: " ";
    display: none
}

.service #support .point .point-txt+p {
    font-size: 1.4rem;
    font-weight: bold;
    margin-left: calc(50% - 500px);
    margin-top: 130px;
    margin-bottom: 50px
}

.service #support .point .point-txt+p span {
    font-style: 1rem
}

@media screen and (max-width:859px) {
    .service #support .point .point-txt+p {
        font-size: 1rem;
        margin: 10px 5%
    }
}

.service #support .point .case_study {
    margin-left: calc(50% - 500px);
    margin-bottom: 50px
}

@media screen and (max-width:859px) {
    .service #support .point .case_study {
        margin: 0 5% 10px
    }
}

.service #support .point .case_study li {
    width: calc(95% / 3)
}

.service #support .point .case_study li img {
    width: 100%;
    height: auto;
    margin: 0 0 10px
}

.service #support .point .case_study li p {
    font-size: 1.3rem;
    font-weight: bold;
    line-height: 1.5;
    text-align: center;
    padding: 0 40px
}

@media screen and (max-width:859px) {
    .service #support .point .case_study li p {
        font-size: 0.9rem;
        line-height: 1.3;
        padding: 0
    }

    .service #support .point .case_study li p br {
        display: none
    }
}

.service #support .point-2 .point-txt .point-inner h5, .service #support .point-2 .point-txt .point-inner ul.flex {
    font-size: 1rem;
    font-weight: bold
}

@media screen and (max-width:859px) {
    .service #support .point-2 .point-txt .point-inner h5, .service #support .point-2 .point-txt .point-inner ul.flex {
        font-size: 1rem
    }
}

@media screen and (max-width:859px) {
    .service #support .point-2 .point-txt .point-inner ul.flex {
        margin-bottom: 10px
    }
}

.service #support .point-2 .point-txt .point-inner ul.flex li {
    width: 30%
}

.service #support .point-2 .point-txt .point-inner ul.flex li:nth-of-type(2n) {
    width: 70%
}

@media screen and (max-width:859px) {
    .service #support .point-2 .point-txt .point-inner ul.flex li {
        width: 100%
    }

    .service #support .point-2 .point-txt .point-inner ul.flex li:nth-of-type(2n) {
        width: 100%
    }
}

body {
    counter-reset: number 0
}

.timeline {
    padding: 3rem 5rem;
    color: #fff
}

@media screen and (max-width:859px) {
    .timeline {
        padding: 20px 0 30px 20px
    }
}

.timeline .txt, .timeline h3 {
    color: #005CB9;
    background: #fff;
    font-size: 1.2rem !important;
    padding: 30px 10px;
    letter-spacing: 0.2rem !important;
    margin: -20px 0px 0 -30px !important;
    writing-mode: vertical-rl;
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: vertical-rl;
    height: 300px;
    position: relative
}

@media screen and (max-width:859px) {
    .timeline .txt, .timeline h3 {
        writing-mode: horizontal-tb;
        -webkit-writing-mode: horizontal-tb;
        -ms-writing-mode: horizontal-tb;
        height: auto;
        padding: 5px 10px
    }
}

.timeline .txt span, .timeline h3 span {
    text-orientation: upright
}

.timeline .txt:after, .timeline h3:after {
    content: "";
    width: 100px;
    border-top: 1px solid #fff;
    position: absolute;
    top: 20px;
    left: 0
}

@media screen and (max-width:859px) {
    .timeline .txt:after, .timeline h3:after {
        border-top: none;
        border-left: 1px solid #fff
    }
}

@media screen and (max-width:859px) {
    .timeline h3 {
        margin: -15px 5px 20px -15px !important
    }
}

.timeline .txt {
    font-weight: bold;
    margin: -20px 0px 0 0 !important
}

.timeline .txt:after {
    content: "";
    display: none
}

@media screen and (max-width:859px) {
    .timeline .txt {
        margin: 0 !important
    }
}

.timeline-item {
    position: relative;
    border-left: 1px solid #fff;
    padding: 0 0 30px 30px
}

@media screen and (max-width:859px) {
    .timeline-item {
        padding: 0 0 20px 25px
    }
}

.timeline-item:before {
    content: "";
    display: block;
    width: 30px;
    height: 30px;
    position: absolute;
    left: 0;
    top: 0;
    border-radius: 100%;
    background-color: #fff;
    transform: translateX(-50%) translateY(-50%)
}

@media screen and (max-width:859px) {
    .timeline-item:before {
        transform: translateX(-50%) translateY(0)
    }
}

.timeline-item:after {
    counter-increment: number 1;
    content: counter(number) " ";
    color: #005CB9;
    font-weight: bold;
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    transform: translateX(-50%) translateY(-50%)
}

@media screen and (max-width:859px) {
    .timeline-item:after {
        transform: translateX(-50%) translateY(0)
    }
}

@media screen and (max-width:859px) {
    .timeline-item:last-child {
        padding: 0 0 30px 30px
    }
}

.timeline-item:last-child .timeline-content {
    position: relative
}

.timeline-item:last-child .timeline-content:after {
    content: "";
    position: absolute;
    top: -41px;
    right: -3.5vw;
    width: 20px;
    height: 20px;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    transform: rotate(45deg)
}

@media screen and (max-width:859px) {
    .timeline-item:last-child .timeline-content:after {
        top: 37px;
        left: -41px;
        transform: rotate(135deg)
    }
}

.timeline .timeline-content {
    font-size: 1.3rem;
    font-weight: bold;
    writing-mode: vertical-rl;
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: vertical-rl;
    text-orientation: upright;
    height: 350px
}

@media screen and (max-width:859px) {
    .timeline .timeline-content {
        font-size: 1rem;
        writing-mode: horizontal-tb;
        -webkit-writing-mode: horizontal-tb;
        -ms-writing-mode: horizontal-tb;
        height: auto
    }
}

@media (min-width:860px) {
    .timeline {
        display: table;
        table-layout: fixed;
        width: 100%
    }

    .timeline-item {
        display: table-cell;
        vertical-align: top;
        padding: 0;
        border-top: 1px solid #fff;
        border-bottom: 0;
        border-left: 0
    }

    .timeline-content {
        transform: translateX(-50%);
        text-align: left;
        display: block;
        max-width: 70%
    }

    .timeline-content {
        margin-top: 30px
    }
}

.library {}

.library .titleWrap .title {
    background: url(../images/library/title_img.jpg) no-repeat center center/cover;
    background-attachment: fixed
}

@media screen and (max-width:859px) {
    .library .titleWrap .title {
        background-attachment: scroll
    }
}

.library .choice {
    padding: 50px 0
}

@media screen and (max-width:859px) {
    .library .choice {
        padding: 30px 0
    }
}

.library .choice h3 {
    font-size: 2rem;
    font-weight: bold;
    margin-bottom: 50px;
    text-align: center
}

@media screen and (max-width:859px) {
    .library .choice h3 {
        font-size: 1.3rem;
        margin-bottom: 25px
    }
}

.library .choice .searchandfilter {
    margin: 30px auto
}

.library .choice .searchandfilter h4 {
    font-size: 1.2rem;
    font-weight: bold;
    margin-bottom: 5px;
    padding: 0
}

.library .choice .searchandfilter ul li {
    padding: 0
}

.library .choice .sf-field-post-meta-area>ul {
    display: -ms-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -moz-flex;
    display: -ms-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    flex-wrap: wrap;
    margin-bottom: 30px
}

.library .choice .sf-field-post-meta-area>ul>li {
    width: 15.8%;
    text-align: center;
    font-size: 16px;
    margin: 0 0.4% 8px
}

@media screen and (max-width:859px) {
    .library .choice .sf-field-post-meta-area>ul>li {
        width: 24.2%;
        font-size: 14px
    }
}

.library .choice .searchandfilter li[data-sf-field-input-type=checkbox] label, .library .choice .searchandfilter li[data-sf-field-input-type=radio] label, .library .choice .searchandfilter li[data-sf-field-input-type=range-checkbox] label, .library .choice .searchandfilter li[data-sf-field-input-type=range-radio] label {
    padding-left: 5px
}

.library .choice .sf-field-post-meta-area .sf-input-checkbox {
    opacity: 0;
    width: 1px;
    display: none
}

.library .choice .sf-field-post-meta-area .sf-option-active {
    background: #666 !important
}

.library .choice .sf-field-post-meta-area .sf-option-active label {
    background: #666 !important
}

.library .choice .sf-field-post-meta-area label {
    background: #005CB9;
    cursor: pointer;
    color: #fff;
    display: block;
    font-weight: bold;
    padding: 10px 0
}

.library .choice .sf-field-post-meta-case_type>ul, .library .choice .sf-field-post-meta-categorykind>ul, .library .choice .sf-field-post-meta-conditions>ul, .library .choice .sf-field-post-meta-diagnosis>ul {
    display: -ms-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -moz-flex;
    display: -ms-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    flex-wrap: wrap;
    margin-bottom: 15px
}

.library .choice .sf-field-post-meta-case_type>ul>li, .library .choice .sf-field-post-meta-categorykind>ul>li, .library .choice .sf-field-post-meta-conditions>ul>li, .library .choice .sf-field-post-meta-diagnosis>ul>li {
    font-size: 16px;
    color: #000;
    display: inline-block;
    margin: 0 40px 10px 0
}

.library .choice .sf-field-post-meta-case_type {
    display: none
}

.library .pickup {
    padding: 50px 0 100px;
    background: #DFE0E0
}

@media screen and (max-width:859px) {
    .library .pickup {
        padding: 20px 5% 50px
    }
}

.library .pickup .tit1 {
    font-size: 3rem;
    margin: 0 0 30px
}

@media screen and (max-width:859px) {
    .library .pickup .tit1 {
        font-size: 2rem;
        margin: 0 0 15px
    }
}

.library .pickup .tit1+p {
    text-align: center;
    margin: 0 0 20px
}

@media screen and (max-width:859px) {
    .library .pickup .tit1+p {
        font-size: 1.2rem
    }
}

.library .pickup .slide-pickup {
    margin-bottom: 100px
}

@media screen and (max-width:859px) {
    .library .pickup .slide-pickup {
        margin-bottom: 70px
    }
}

.library .pickup .slide-pickup .c_cate {
    background: #fff;
    padding: 30px;
    border-radius: 10px 10px;
    margin: 0 15px;
    position: relative
}

@media screen and (max-width:859px) {
    .library .pickup .slide-pickup .c_cate {
        padding: 15px
    }
}

.library .pickup .slide-pickup .c_cate h5 {
    font-size: 1.1rem;
    font-weight: bold;
    background: #005CB9;
    color: #fff;
    padding: 3px 10px;
    margin: 0 0 20px;
    position: relative;
    text-align: center;
    z-index: 2;
    border-radius: 5px 5px
}

.library .pickup .slide-pickup .c_cate .case li {
    font-size: 0.9rem;
    font-weight: bold;
    border-bottom: 1px solid #919595;
    padding: 8px 0 8px 35px
}

.library .pickup .slide-pickup .c_cate .case .area {
    background: url(../images/common/icon_area.svg) no-repeat left center;
    background-size: 25px
}

@media screen and (max-width:859px) {
    .library .pickup .slide-pickup .c_cate .case .area {
        width: 100% !important;
        text-align: left
    }
}

.library .pickup .slide-pickup .c_cate .case .management {
    background: url(../images/common/icon_management.svg) no-repeat left center;
    background-size: 25px
}

.library .pickup .slide-pickup .c_cate .case .sales {
    background: url(../images/common/icon_sales.svg) no-repeat left center;
    background-size: 25px
}

.library .pickup .slide-pickup .c_cate .case .transfer {
    background: url(../images/common/icon_transfer.svg) no-repeat left center;
    background-size: 25px
}

.library .pickup .slide-pickup .c_cate .case .department {
    background: url(../images/common/icon_department.svg) no-repeat left center;
    background-size: 25px
}

.library .pickup .slide-pickup .c_cate .case .conditions {
    background: url(../images/common/icon_conditions.svg) no-repeat left center;
    background-size: 25px;
    border-bottom: none
}

.library .pickup .slide-pickup .c_cate .case .conditions-content {
    padding: 0 0 8px 0
}

.library .pickup .slide-pickup .c_cate .case .conditions-content ul li {
    border-bottom: none;
    padding: 0 0 0 11px
}

.library .pickup .slide-pickup .c_cate .case .conditions-content ul li:before {
    position: relative;
    top: 0;
    left: -4px;
    display: inline-block;
    width: 0.7rem;
    height: 0.7rem;
    content: "";
    border-radius: 100%;
    background: #005CB9
}

.library .pickup .slide-pickup .c_cate .cadse_link {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1
}

.library .pickup .slide-pickup .slide-arrow {
    width: 22px
}

.library .pickup .slide-pickup .slide-arrow img {
    width: 100%;
    height: auto
}

.library .pickup .slide-pickup .prev-arrow {
    position: absolute;
    top: 50%;
    left: -30px;
    transform: translate(0, -50%)
}

@media screen and (max-width:859px) {
    .library .pickup .slide-pickup .prev-arrow {
        left: -15px
    }
}

.library .pickup .slide-pickup .next-arrow {
    position: absolute;
    top: 50%;
    right: -30px;
    transform: translate(0, -50%)
}

@media screen and (max-width:859px) {
    .library .pickup .slide-pickup .next-arrow {
        right: -15px
    }
}

.library .pickup .slide-pickup .slick-dots {
    bottom: -45px
}

.library .pickup .slide-pickup .slick-dots li {
    margin: 0
}

.library .result {
    padding: 50px 0;
    background: #DFE0E0
}

.library .result .inner {
    background: #fff;
    padding: 30px
}

@media screen and (max-width:859px) {
    .library .result .inner {
        padding: 20px 3%
    }
}

.library .result .inner .result_tit {
    font-size: 1.6rem;
    font-weight: bold;
    margin-bottom: 30px;
    text-align: center
}

.library .result .case_table {
    font-weight: bold;
    width: 100%;
    margin: 0 auto
}

@media screen and (max-width:859px) {
    .library .result .case_table {
        font-size: 0.6rem
    }
}

.library .result .case_table tr td {
    padding: 0.5rem;
    line-height: 1.2;
    border-right: 2px solid #005CB9;
    border-bottom: 2px solid #005CB9;
    vertical-align: middle;
    color: #005CB9
}

.library .result .case_table tr td:last-child {
    border-right: none
}

@media screen and (max-width:859px) {
    .library .result .case_table tr td {
        border-right: 1px solid #005CB9;
        border-bottom: 1px solid #005CB9;
        padding: 0.1rem
    }
}

.library .result .case_table tr:first-of-type td {
    background-color: #005CB9;
    color: #fff;
    border-right: 2px solid #fff;
    text-align: center;
    vertical-align: middle
}

.library .result .case_table tr:first-of-type td:last-child {
    border-right: none
}

@media screen and (max-width:859px) {
    .library .result .case_table tr td {
        width: 15%;
    }
    .library .result .case_table tr:first-of-type td {
        border-right: 1px solid #fff
    }
}

.library .result .case_type {
    width: 15%;
    text-align: center;
    vertical-align: middle;
    display: none
}

.library .result .case_number {
    width: 10%;
    text-align: center;
    vertical-align: middle
}

.library .result .area {
    width: 15%;
    text-align: center;
    vertical-align: middle
}

.library .result .management_organization {
    width: 10%;
    text-align: center;
    vertical-align: middle
}

@media screen and (max-width:859px) {
    .library .result .management_organization {
        display: none
    }
}

.library .result .transfer_money {
    width: 15%;
    text-align: center;
    vertical-align: middle
}

.library .result .detail_link {
    width: 15%;
    text-align: center;
    vertical-align: middle
}

.library .result .link_btn {
    display: block;
    padding: 0.3vw 0.6vw;
    background-color: #005CB9;
    color: #fff;
    border-radius: 4px
}

.library .result .transfer01 {
    background-color: #ffffff
}

.library .result .transfer02 {
    background-color: #e8f2f4
}

.library .result .top_about_msg {
    font-size: 20px !important;
    font-weight: bold;
    margin-bottom: 30px !important
}

.library .result .text01>li {
    margin-bottom: 50px
}

.library .result .text01>li:last-of-type {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 0
}

.library .result .text01>li>ul {
    list-style: disc;
    text-align: left
}

.library .result .about_section {
    margin-bottom: 10px;
    font-weight: bold;
    font-size: 18px
}

.library .result .campany_info {
    margin-top: 80px
}

.library .result .campany_info>table {
    margin: 50px auto 0 auto
}

.library .result .campany_info>table>tbody>tr>td {
    padding: 10px
}

.library .result .campany_info>table>tbody>tr>td:first-of-type {
    font-weight: bold
}

.library .result .campany_info td table td:nth-of-type(2) {
    padding-left: 20px
}

.library .result #introduction #adviser_area .cnt_img {
    text-align: right
}

.library .result #introduction #adviser_area .cnt_img img {
    width: 60%
}

.library .result .sp_only {
    display: none
}

@media screen and (max-width:859px) {
    .library .sp_only {
        display: block
    }

    .library .case_table {
        width: 90%;
        margin: 0 auto
    }

    .library .case_table tr td {
        padding: 0.89vw 1.18vw;
        vertical-align: middle;
        color: #000000;
        letter-spacing: 0
    }

    .library .case_table tr:first-of-type td {
        background-color: #005eb8;
        color: #ffffff;
        text-align: center;
        vertical-align: middle
    }

    .library .case_type {
        width: 15%;
        text-align: center;
        vertical-align: middle
    }

    .library .case_number {
        width: 10%;
        text-align: center;
        vertical-align: middle
    }

    .library .area {
        width: 18% !important;
        text-align: center;
        vertical-align: middle
    }

    .library .management_organization {
        width: 10%;
        text-align: center;
        vertical-align: middle
    }

    .library .transfer_money {
        width: 15%;
        text-align: center;
        vertical-align: middle
    }

    .library .detail_link {
        width: 15%;
        text-align: center;
        vertical-align: middle
    }

    .library .link_btn {
        display: block;
        padding: 0.3vw 0.6vw;
        background-color: #005eb8;
        color: #ffffff;
        border-radius: 0.7vw
    }

    .library .transfer01 {
        background-color: #ffffff
    }

    .library .transfer02 {
        background-color: #e8f2f4
    }

    .library .top_about_msg {
        font-size: 15px !important;
        font-weight: bold
    }

    .library .text01>li {
        margin-bottom: 20px
    }

    .library .text01>li:last-of-type {
        margin-bottom: 0
    }

    .library .text01>li>ul {
        list-style: disc;
        text-align: left;
        padding-left: 20px
    }

    .library .about_section {
        margin-bottom: 5px;
        font-weight: bold;
        font-size: 15px
    }

    .library .campany_info {
        margin-top: 80px
    }

    .library .campany_info>table {
        margin: 28px auto 0 auto;
        font-size: 15px
    }

    .library .campany_info>table>tbody>tr>td {
        border: 1px solid #666666;
        padding: 10px
    }

    .library .campany_info>table>tbody>tr>td:first-of-type {
        font-weight: bold;
        width: 30%
    }

    .library .campany_info td table td:first-of-type {
        width: 44%
    }

    .library .campany_info td table td:nth-of-type(2) {
        padding-left: 5px
    }

    .library .site-content {
        padding-top: 72px
    }
}

.introduction .titleWrap .title {
    background: url(../images/company/title_img.jpg) no-repeat center center/cover;
    background-attachment: fixed
}

@media screen and (max-width:859px) {
    .introduction .titleWrap .title {
        background-attachment: scroll
    }
}

.introduction .concept {
    background: #DFE0E0;
    padding: 70px 0
}

@media screen and (max-width:859px) {
    .introduction .concept {
        padding: 20px 0
    }
}

.introduction .concept .box {
    padding: 100px 30px;
    text-align: center;
    position: relative
}

.introduction .concept .box .tit1 {
    margin-bottom: 30px
}

.introduction .concept .box p {
    font-size: 1.4vw;
    letter-spacing: 0.3rem;
    line-height: 2.2;
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

@media screen and (max-width:859px) {
    .introduction .concept .box {
        padding: 50px 20px
    }

    .introduction .concept .box p {
        font-size: 1rem;
        letter-spacing: 0.1rem;
        line-height: 2;
        text-align: left
    }

    .introduction .concept .box p br {
        display: none
    }
}

.introduction .concept .mission {
    background: #fff url(../images/company/mission_bg.jpg) no-repeat center center/cover;
    background-blend-mode: multiply;
    background-attachment: fixed;
    margin-right: 100px;
    margin-bottom: -80px;
    z-index: 10
}

.introduction .concept .mission p {
    text-shadow: 0 0 4px white
}

@media screen and (max-width:859px) {
    .introduction .concept .mission {
        margin-right: 5%;
        margin-bottom: -40px
    }
}

.introduction .concept .weare {
    padding: 150px 0 100px;
    background: #005CB9 url(../images/company/weare_bg.jpg) no-repeat center center/cover;
    background-blend-mode: multiply;
    background-attachment: fixed;
    color: #fff;
    margin-left: 100px
}

@media screen and (max-width:859px) {
    .introduction .concept .weare {
        padding: 90px 20px 50px;
        margin-left: 5%
    }
}

.introduction #member {
    padding: 50px
}

@media screen and (max-width:859px) {
    .introduction #member {
        padding: 30px 0
    }
}

.introduction #member .tit1 {
    margin-bottom: 50px
}

@media screen and (max-width:859px) {
    .introduction #member .tit1 {
        margin-bottom: 30px
    }
}

.introduction #member ul li {
    color: #000;
    width: calc(33.3% - 60px / 3 );
    margin: 0 30px 80px 0
}

.introduction #member ul li:nth-child(3n) { 
    margin-right: 0;
}

/* .introduction #member ul li:nth-of-type(2n) { 
    margin: 0 0 80px
}*/

@media screen and (max-width:859px) {
    .introduction #member ul li {
        width: 100%;
        margin: 30px 0 0;
    }

    .introduction #member ul li:first-child { 
        margin-top: 0;
    }

    /* .introduction #member ul li:nth-of-type(2n) { 
        margin: 0 0 30px
    }*/
}

.introduction #member ul li figure {
    margin-bottom: 20px
}

.introduction #member ul li figure img {
    width: 100%;
    height: auto
}

.introduction #member ul li .name {
    font-size: 2.5rem;
    line-height: 1.5;
    /* margin-bottom: 20px; */
    font-family: "游明朝", "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

/* .introduction #member ul li .name span { 
    font-size: 0.9rem;
    display: block
}*/

/* 202305 add  */
@media screen and (min-width:860px) { 

    .introduction #member ul li:not(:nth-child(2n)) .name {
        margin-top: 18px;
    }
}

.director {
    font-size: 0.9rem ;
    line-height: 1;
    font-family: "游明朝", "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

.represent {
    font-size: 0.8rem;
    line-height: 1;
    display: block;
    margin-top: 3px;
    font-family: "游明朝", "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

.career {
    word-break: break-all;
    margin-top: 10px;
}
/* 202305 add ここまで */

.introduction #member ul li .btnWrap {
    text-align: left
}


.introduction #member ul li .btnWrap .btn-1 {
    font-size: 1rem;
    padding: 5px 40px;
    margin-top: 10px
}


.introduction #profile {
    padding: 70px 0
}

@media screen and (max-width:859px) {
    .introduction #profile {
        padding: 30px 0
    }

    .introduction #profile tr iframe{
        width: 100%;
    }
    
}

.introduction #profile .tit1 {
    margin-bottom: 50px
}

@media screen and (max-width:859px) {
    .introduction #profile .tit1 {
        margin-bottom: 25px
    }
}

.introduction #profile .tit1 span {
    font-size: 1.5rem;
    display: block
}

.introduction #profile table {
    width: 100%
}

.introduction #profile table tr {
    border-top: 1px solid #005CB9
}

.introduction #profile table tr:last-child {
    border-bottom: 1px solid #005CB9
}

.introduction #profile table tr td, .introduction #profile table tr th {
    padding: 1.5rem 3rem
}

@media screen and (max-width:859px) {
    .introduction #profile table tr td, .introduction #profile table tr th {
        padding: 0.5rem
    }
}

.introduction #profile table tr th {
    border-right: 1px solid #005CB9;
    width: 20%
}

.introduction #profile table tr th span {
    width: 8rem;
    display: block;
    margin: 0 auto;
    height: 1.8rem;
    text-align: justify;
    text-justify: inter-ideograph
}

.introduction #profile table tr th span:after {
    content: "";
    display: inline-block;
    width: 100%
}

@media screen and (max-width:859px) {
    .introduction #profile table tr th {
        border-right: none;
        border-bottom: 1px solid #005CB9;
        width: 100%;
        display: block
    }
}

.introduction #profile table tr td {
    width: 80%
}

@media screen and (max-width:859px) {
    .introduction #profile table tr td {
        width: 100%;
        display: block;
        text-align: center
    }
}

.introduction #access {
    color: #000;
    padding: 0 0 200px
}

@media screen and (max-width:859px) {
    .introduction #access {
        padding: 0 0 100px
    }
}

.introduction #access iframe {
    width: 100%;
    filter: grayscale(60%)
}

.introduction #access h4 {
    font-size: 1.2rem;
    font-weight: bold;
    margin-bottom: 5px
}

.introduction #access .btnWrap {
    text-align: left;
    margin-bottom: 30px
}

.introduction #access .btnWrap .btn-1 {
    font-size: 1.1rem;
    padding: 5px 40px;
    margin-top: 10px
}

.introduction #access .officeimage li {
    width: 49%
}

.introduction #access .officeimage li img {
    width: 100%;
    height: auto
}

.category .titleWrap,.tax-postTag .titleWrap {
    text-align: center;
    padding: 120px 0 50px
}

@media screen and (max-width:859px) {
    .category .titleWrap,.tax-postTag .titleWrap {
        padding: 50px 0
    }
}

.category .titleWrap .title,.tax-postTag .titleWrap .title {
    background: url(../images/common/icon_service.svg) no-repeat 30px center;
    background-size: 95px;
    padding: 0 0 0px 200px;
    width: 480px;
    margin: 60px auto
}

.category .titleWrap .title h1,.tax-postTag .titleWrap .title h1 {
    color: #005CB9;
    font-size: 4rem;
    line-height: 1.2;
    text-align: left;
    letter-spacing: 1.5rem;
    padding: 8px 0 0 0;
    filter: drop-shadow(0 0 18px rgba(0, 0, 0, 0));
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

.category .titleWrap .title h1 span,.tax-postTag .titleWrap .title h1 span {
    font-size: 2rem;
    display: block;
    letter-spacing: 0.2rem
}

@media screen and (max-width:859px) {
    .category .titleWrap .title h1,.tax-postTag .titleWrap .title h1 {
        font-size: 2.5rem;
        letter-spacing: 1rem
    }

    .category .titleWrap .title h1 span,.tax-postTag .titleWrap .title h1 span {
        font-size: 1.1rem
    }
}

@media screen and (max-width:859px) {
    .category .titleWrap .title,.tax-postTag .titleWrap .title {
        background-size: 60px;
        padding: 23px 0 30px 120px;
        width: 90%;
        margin: 30px auto
    }
}

@media screen and (max-width:859px) {
    .category .titleWrap .lead_text,.tax-postTag .titleWrap .lead_text {
        padding: 0 5%;
        text-align: left
    }
}

.category .titleWrap dl,.tax-postTag .titleWrap dl {
    width: fit-content;
    margin: 0 auto
}

.category .titleWrap dl dt,.tax-postTag .titleWrap dl dt {
    font-weight: bold;
    margin-right: 10px;
}

.category .titleWrap dl dd,.tax-postTag .titleWrap dl dd {
    width: 220px;
    margin-right: 10px;
}

.category .recommend {
    background: #005CB9;
    padding: 30px 0 10px;
    margin: 0 0 10px;
    overflow: hidden
}

.category .recommend h2 {
    color: white;
    font-size: 1.3rem;
    letter-spacing: 0.2em;
    margin: 0 0 30px;
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

.category .recommend .slide-recommend {
    margin-bottom: 70px
}

.category .recommend .slide-recommend li {
    margin: 0 30px
}

.category .recommend .slide-recommend li figure {
    margin: 0 0 10px;
    border-radius: 15px 15px;
    overflow: hidden
}

.category .recommend .slide-recommend li figure img {
    width: 100%;
    height: auto
}

.category .recommend .slide-recommend li h3 {
    color: #fff;
    font-weight: bold;
    line-height: 1.5;
    text-align: left
}

@media screen and (max-width:859px) {
    .category .recommend .slide-recommend li h3 br {
        display: none
    }
}

.category .recommend .slide-recommend .slide-arrow {
    width: 22px
}

.category .recommend .slide-recommend .slide-arrow img {
    width: 100%;
    height: auto
}

.category .recommend .slide-recommend .prev-arrow {
    position: absolute;
    top: 50%;
    left: -30px;
    transform: translate(0, -50%)
}

@media screen and (max-width:859px) {
    .category .recommend .slide-recommend .prev-arrow {
        left: 5px
    }
}

.category .recommend .slide-recommend .next-arrow {
    position: absolute;
    top: 50%;
    right: -30px;
    transform: translate(0, -50%)
}

@media screen and (max-width:859px) {
    .category .recommend .slide-recommend .next-arrow {
        right: 5px
    }
}

.category .recommend .slide-recommend .slick-dots {
    bottom: -45px
}

.category .recommend .slide-recommend .slick-dots li {
    margin: 0
}

.category .article {
    padding: 50px 0;
}
.article_wrap{
background-color: #F3F7FA;
}


@media screen and (max-width:859px) {
    .category .article {
        padding: 40px 5% 30px
    }
}

@media screen and (max-width:859px) {
    .category .article ul {
        /* margin-bottom: 30px */
    }
}

.category .article ul li {
    width: calc(92% / 3);
    margin: 0 4% 70px 0;
    position: relative;
}
.category .article>ul>li {
    background-color: white;
    border-radius: 8px;
    position: relative;
    z-index: 0;
}
.category .article>ul>li .bglink{
    display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    z-index: 0;
}

.category .article ul li:nth-of-type(3n) {
    margin: 0 0 70px 0
}

.category .article ul.tags {
    margin-top: 6px;
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    padding: 0 0px;
}
.category .article ul.tags li{
    margin: 0!important;
    width: fit-content;
    line-height: 1;
}
.category .article ul.tags li a{
    border: 1px solid #27b1db;
    font-size: 12px;
    display: block;
    padding: 6px 3px;
    line-height: 1;
    color: #27b1db;
    transition: ease .3s;
}
.category .article ul.tags li a:hover{
    opacity: .6;
}

.postTxtLink{
    font-size: 14px;
    color: #333;
}

@media screen and (max-width:859px) {
    .category .article ul li {
        width: calc(95% / 2);
        margin: 0 5% 30px 0
    }
    .category .article ul.tags li a{
        font-size: 10px;
    }
    .category .article ul li:nth-of-type(2n) {
        margin: 0 0 30px 0
    }

    .category .article ul li:nth-of-type(3n) {
        margin: 0 5% 30px 0
    }

    .category .article ul li:nth-of-type(6n) {
        margin: 0 0 30px 0
    }

    .category .article ul li div.flex_wp_wp .date, .category .article ul li div.flex_wp_wp ul {
        width: 100%
    }

    .category .article ul li div.flex_wp_wp ul {
        margin: 0
    }
}

.category .article ul li .date {
    font-size: 0.85rem
}

.category .article ul li .column_category_ul {
    position: relative;
}
.category .article ul li .column_category {
    width: 100%;
    margin: 0;
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif;
}


.category .article ul li .column_category span {
    /* background: #005CB9;
    color: #fff;
    font-size: 0.8rem;
    padding: 2px 10px 1px;
    border-radius: 5px 5px; */
    /* transform: translateY(-50%); */
    font-weight: 700;
    position: absolute;
    transform: translateY(-50%);
    font-family: "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;;
    display: inline-block;
    padding: 8px;
    color: #fff;
    font-size: 14px;
    line-height: 100%;
    letter-spacing: 1px;
    background: #27b1db;
    left: 20px;
    /* border-radius: 2px; */
    /* width: ; */
}

@media screen and (max-width:859px) {
    .category .article ul li .column_category span {
        border-radius: 3px 3px
    }
}

.category .article ul li figure {
    /* margin: 0 0 10px; */
    border-radius: 8px 8px 0 0;
    overflow: hidden
}

@media screen and (max-width:859px) {
    .category .article ul li figure {
        border-radius: 10px 10px 0 0;
    }
}

.category .article ul li figure img {
    width: 100%;
    height: auto;
    aspect-ratio: 1.7/1;
    object-fit: cover;
}

.category .article ul li h3 {
    font-weight: bold;
    line-height: 1.5
}
.category .article ul li h3 a:hover{
    text-decoration: underline;
}

@media screen and (max-width:859px) {
    .category .article ul li h3 br {
        font-size: 0.9rem;
        display: none
    }
}

.category .article ul li.case_buy, .category .article ul li.case_clinic, .category .article ul li.case_nursing, .category .article ul li.case_pharmacy, .category .article ul li.case_sale, .category .article ul li.dictionary, .category .article ul li.ma_column, .category .article ul li.news_a, .category .article ul li.news_a, .category .article ul li.news_b, .category .article ul li.news_c, .category .article ul li.positive_buy {
    margin: 0;
    width: 100%;
    background: #005CB9;
    color: #fff;
    display: inline-block;
    font-size: 0.9rem;
    font-weight: bold;
    text-align: right;
    padding: 3px 15px;
    margin: 0 0 10px;
    border-radius: 7px 7px
}

@media screen and (max-width:859px) {
    .category .article ul li.case_buy, .category .article ul li.case_clinic, .category .article ul li.case_nursing, .category .article ul li.case_pharmacy, .category .article ul li.case_sale, .category .article ul li.dictionary, .category .article ul li.ma_column, .category .article ul li.news_a, .category .article ul li.news_a, .category .article ul li.news_b, .category .article ul li.news_c, .category .article ul li.positive_buy {
        border-radius: 3px 3px
    }
}

.single .titleWrap {
    text-align: center;
    padding: 80px 0
}

@media screen and (max-width:859px) {
    .single .titleWrap {
        padding: 50px 0 0
    }
}

.single .titleWrap .title {
    background: url(../images/common/icon_service.svg) no-repeat 30px center;
    background-size: 50px;
    padding: 0 0 0px 110px;
    width: 630px;
    margin: 60px auto 0
}

@media screen and (max-width:859px) {
    .single .titleWrap .title {
        background-size: 40px;
        padding: 10px 0 10px 80px;
        width: 100%;
        margin: 40px auto 20px
    }
}

.single .titleWrap .title h1 {
    color: #005CB9;
    font-size: 4rem;
    line-height: 1.2;
    text-align: left;
    letter-spacing: 1rem;
    padding: 8px 0 0 0;
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

.single .titleWrap .title h1 span {
    font-size: 2rem;
    letter-spacing: 0.2rem;
    display: inline-block;
    margin: 0 15px 0 0;
    vertical-align: middle
}

@media screen and (max-width:859px) {
    .single .titleWrap .title h1 {
        font-size: 2rem;
        letter-spacing: 0.5rem
    }

    .single .titleWrap .title h1 span {
        font-size: 1rem;
        margin: 0 7px 0 0
    }
}

.single .titleWrap .title2 {
    margin: 60px auto 0
}

.single .titleWrap .title2 h1 {
    font-size: 3rem;
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

.single .titleWrap .title+p {
    font-size: 1.3rem;
    line-height: 2;
    letter-spacing: 0.2rem;
    margin-bottom: 50px;
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

.single .article {
    padding: 0 0 150px
}

.single .news_nav li {
    z-index: 1;
}

/* .casestudies{
    background-color: #eee;
    padding-top: 40px;
    padding-bottom: 40px;
} */
.casestudies .article.inner90{
   max-width: 960px;
    background-color: #fff;
    padding: 20px 0;
    margin-bottom: 30px;
}

.casestudies .news_nav figure{
    border-radius: 0px 30px;

    background-color: white;
}
.casestudies .news_nav{
    position: relative;
    /* content: '';
    background-color: #fff; */
}

/* .casestudies .news_nav::before{
    content: '';
    display: block;
    background-color: #eee;
    position: absolute;
    width: 100vw;
    height: 250px;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    z-index: 0;
} */

.casestudies .article{
    padding-top: 20px;
    padding-right: 30px!important;
    padding-left: 30px!important;
    background-color: white;
}


@media screen and (max-width:859px) {
    .single .article {
        padding: 0 5% 50px
    }
    .casestudies .news_nav::before{
        content: unset;
    }
    
    .casestudies .article{
        background-color: white;
    }
    .casestudies{
        background-color: white;
        padding: 0px 0;
    }
    .casestudies .article.inner90{
        margin-bottom: 0;
    }
    
}

.single .article figure {
    border-radius: 30px 30px;
    overflow: hidden;
    margin-bottom: 50px
}

@media screen and (max-width:859px) {
    .single .article figure {
        border-radius: 10px 10px;
        margin-bottom: 20px
    }
}

.single .article figure img {
    width: 100%;
    height: auto
}

.single .article time {
    display: block;
    font-weight: bold;
    text-align: right;
    margin-bottom: 30px
}

@media screen and (max-width:859px) {
    .single .article time {
        margin-bottom: 15px
    }
}

.single .article .single_category {
    background: #005CB9;
    color: #fff;
    font-size: 0.9rem;
    line-height: 1;
    padding: 8px 10px;
    margin: 0 auto 20px;
    width: 380px;
    display: block;
    text-align: center;
    border-radius: 5px 5px;
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

.single .article ul.tags{
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: flex-start;
    margin-bottom: 20px;
}
.single .article ul.tags li{
    width: fit-content;
}
@media screen and (max-width:859px) {
    .single .article .single_category {
        padding: 3px 10px;
        width: 100%
    }
}

.single .article h1 {
    text-align: center;
    font-size: 1.8rem;
    letter-spacing: 0.1rem;
    line-height: 1.5;
    margin-bottom: 50px;
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

@media screen and (max-width:859px) {
    .single .article h1 {
        font-size: 1.5rem;
        letter-spacing: 0.2rem;
        margin-bottom: 20px
    }
}

.single .article h2 {
    font-size: 1.5rem;
    font-weight: bold;
    letter-spacing: 0.2rem
}

@media screen and (max-width:859px) {
    .single .article h2 {
        font-size: 1.3rem
    }
}

.single .article h3 {
    font-size: 1.3rem;
    font-weight: bold;
    letter-spacing: 0.2rem
}

@media screen and (max-width:859px) {
    .single .article h3 {
        font-size: 1.2rem
    }
}

.single .article h4 {
    font-size: 1.1rem;
    font-weight: bold
}

@media screen and (max-width:859px) {
    .single .article h4 {
        font-size: 1.1rem
    }
}

.single .article h5 {
    font-size: 1rem;
    font-weight: bold
}

@media screen and (max-width:859px) {
    .single .article h5 {
        font-size: 1rem
    }
}

.single .article p {
    color: #000;
    font-size: 1rem;
    line-height: 1.8rem;
    margin: 5px 0
}

@media screen and (max-width:859px) {
    .single .article p {
        line-height: 2rem
    }
}

.single .article strong {
    font-weight: bold
}

.single .article img {
    max-width: 100%;
    height: auto
}

.single .article .aligncenter {
    margin: 0 auto;
    display: inherit
}

.single .article .alignright {
    display: inherit;
    margin: 0 0 0 auto
}

@media screen and (max-width:859px) {
    .single .article a {
        word-break: break-all
    }
}

.single .news_nav {
    margin: 30px 0;
    padding: 20px 0 0 0;
    border-top: 1px solid #005CB9
}

.single .news_nav li {
    max-width: 47%;
    line-height: 1.5
}

.single .news_nav li a {
    font-size: 0.85rem;
    font-weight: bold
}

.single .case_no_container {
    text-align: center
}

.single .case_no_container a button {
    padding: 20px 80px;
    border: none;
    background: #005CB9;
    color: #fff;
    pointer-events: auto;
    cursor: pointer;
    margin: 50px auto
}

.access .titleWrap {
    text-align: center;
    padding: 120px 0 50px
}

@media screen and (max-width:859px) {
    .access .titleWrap {
        padding: 50px 0 0
    }
}

.access .titleWrap .title {
    padding: 50px 0
}

.access .titleWrap .title h1 {
    color: #005CB9;
    font-size: 2.5rem;
    letter-spacing: 0.5rem
}

@media screen and (max-width:859px) {
    .access .titleWrap .title h1 {
        font-size: 1.6rem;
        letter-spacing: 0.2rem
    }
}

.access .inner10 {
    margin: 0 auto 130px
}

@media screen and (max-width:859px) {
    .access .inner10 {
        margin: 0 auto 30px
    }
}

.access .inner10 h3 {
    font-size: 1.7rem;
    margin-bottom: 30px;
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif;
    counter-reset: number 0
}

@media screen and (max-width:859px) {
    .access .inner10 h3 {
        font-size: 1.3rem;
        margin-bottom: 15px
    }
}

.access .inner10 h4 {
    color: #000;
    font-size: 1.1rem;
    margin-bottom: 15px;
    padding: 0 0 0 30px;
    position: relative
}

.access .inner10 h4:before {
    counter-increment: number 1;
    content: counter(number) ". ";
    position: absolute;
    color: #005CB9;
    font-weight: bold;
    top: 0;
    left: 0
}

.access .inner10 h4+div {
    margin-bottom: 60px
}

@media screen and (max-width:859px) {
    .access .inner10 h4+div {
        margin-bottom: 20px
    }
}

.access .inner10 .column2 p {
    width: 48%
}

@media screen and (max-width:859px) {
    .access .inner10 .column2 p {
        width: 100%
    }
}

.access .inner10 .column2 .mr40 {
    margin-right: 40px
}

@media screen and (max-width:859px) {
    .access .inner10 .column2 .mr40 {
        margin-right: 0
    }
}

.access .inner10 .column2 .w20 {
    width: 27%
}

@media screen and (max-width:859px) {
    .access .inner10 .column2 .w20 {
        width: 100%
    }
}

.access .inner10 .column3 p {
    width: 31%
}

@media screen and (max-width:859px) {
    .access .inner10 .column3 p {
        width: 100%
    }
}

.access .inner10 p {
    color: #000;
    font-size: 1.1rem;
    margin-bottom: 10px
}

.access .inner10 img {
    width: 100%;
    height: auto
}

.access iframe {
    width: 100%
}

.check .titleWrap .title, .complete .titleWrap .title, .contact .titleWrap .title {
    background: url(../images/contact/title_img.jpg) no-repeat center center/cover;
    background-attachment: fixed;
    display: none
}

@media screen and (max-width:859px) {
    .check .titleWrap .title, .complete .titleWrap .title, .contact .titleWrap .title {
        background-attachment: scroll
    }
}

.check .form, .complete .form, .contact .form {
    background: #DFE0E0;
    padding: 80px 0
}

@media screen and (max-width:859px) {
    .check .form, .complete .form, .contact .form {
        padding: 5%
    }
}

.check .form .inner90, .complete .form .inner90, .contact .form .inner90 {
    background: #fff;
    padding: 60px 100px 100px
}

@media screen and (max-width:859px) {
    .check .form .inner90, .complete .form .inner90, .contact .form .inner90 {
        padding: 20px
    }
}

.check .form .inner90 .lead, .complete .form .inner90 .lead, .contact .form .inner90 .lead {
    text-align: center;
    margin-bottom: 60px
}

@media screen and (max-width:859px) {
    .check .form .inner90 .lead, .complete .form .inner90 .lead, .contact .form .inner90 .lead {
        font-size: 1rem;
        text-align: left;
        margin-bottom: 30px
    }
}

.check .form .inner90 .lead span, .complete .form .inner90 .lead span, .contact .form .inner90 .lead span {
    font-weight: bold;
    font-size: 1.5rem;
    line-height: 2
}

@media screen and (max-width:859px) {
    .check .form .inner90 .lead span, .complete .form .inner90 .lead span, .contact .form .inner90 .lead span {
        line-height: 1.3;
        padding: 13px 0;
        display: inline-block
    }
}

.check .form .inner90 .first_text, .complete .form .inner90 .first_text, .contact .form .inner90 .first_text {
    display: none
}

.check .form .inner90 dl, .complete .form .inner90 dl, .contact .form .inner90 dl {
    margin-bottom: 20px
}

@media screen and (max-width:859px) {
    .check .form .inner90 dl, .complete .form .inner90 dl, .contact .form .inner90 dl {
        margin-bottom: 10px
    }
}

.check .form .inner90 dl dt, .complete .form .inner90 dl dt, .contact .form .inner90 dl dt {
    color: #000;
    font-weight: bold;
    margin-bottom: 5px
}

.check .form .inner90 dl dt span, .complete .form .inner90 dl dt span, .contact .form .inner90 dl dt span {
    color: #005CB9
}

.check .form .inner90 dl dt span.error, .complete .form .inner90 dl dt span.error, .contact .form .inner90 dl dt span.error {
    color: #B70000;
    display: inline-block
}

@media screen and (max-width:859px) {
    .check .form .inner90 dl dt, .complete .form .inner90 dl dt, .contact .form .inner90 dl dt {
        font-size: 1rem
    }
}

.check .form .inner90 dl dd .wpcf7-form-control, .complete .form .inner90 dl dd .wpcf7-form-control, .contact .form .inner90 dl dd .wpcf7-form-control {
    border: none;
    background: #DFE0E0;
    color: #005CB9;
    font-size: 1.2rem;
    padding: 0.8rem;
    width: 100%
}

.check .form .inner90 dl dd .wpcf7-form-control-code, .complete .form .inner90 dl dd .wpcf7-form-control-code, .contact .form .inner90 dl dd .wpcf7-form-control-code {
    border: none;
    background: #DFE0E0;
    color: #005CB9;
    font-size: 1.2rem;
    padding: 0.8rem
}

.check .form .inner90 dl dd .ECM_CheckboxInput, .complete .form .inner90 dl dd .ECM_CheckboxInput, .contact .form .inner90 dl dd .ECM_CheckboxInput {
    padding: 12px 0;
    display: flex;
    align-items: center;
    cursor: pointer;
    width: 35%
}

@media screen and (max-width:859px) {
    .check .form .inner90 dl dd .ECM_CheckboxInput, .complete .form .inner90 dl dd .ECM_CheckboxInput, .contact .form .inner90 dl dd .ECM_CheckboxInput {
        padding: 8px 0;
        width: 100%
    }
}

.check .form .inner90 dl dd .ECM_CheckboxInput-Input, .complete .form .inner90 dl dd .ECM_CheckboxInput-Input, .contact .form .inner90 dl dd .ECM_CheckboxInput-Input {
    margin: 0;
    width: 0;
    opacity: 0
}

.check .form .inner90 dl dd .ECM_CheckboxInput-Input:checked+.ECM_CheckboxInput-DummyInput, .complete .form .inner90 dl dd .ECM_CheckboxInput-Input:checked+.ECM_CheckboxInput-DummyInput, .contact .form .inner90 dl dd .ECM_CheckboxInput-Input:checked+.ECM_CheckboxInput-DummyInput {
    background: #005CB9
}

.check .form .inner90 dl dd .ECM_CheckboxInput-Input:checked+.ECM_CheckboxInput-DummyInput:before, .complete .form .inner90 dl dd .ECM_CheckboxInput-Input:checked+.ECM_CheckboxInput-DummyInput:before, .contact .form .inner90 dl dd .ECM_CheckboxInput-Input:checked+.ECM_CheckboxInput-DummyInput:before {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    width: 40%;
    height: 4px;
    border-radius: 2px;
    transform: translate(-5px, 2px) rotateZ(-135deg);
    transform-origin: 2px 2px;
    background: #FFFFFF
}

.check .form .inner90 dl dd .ECM_CheckboxInput-Input:checked+.ECM_CheckboxInput-DummyInput:after, .complete .form .inner90 dl dd .ECM_CheckboxInput-Input:checked+.ECM_CheckboxInput-DummyInput:after, .contact .form .inner90 dl dd .ECM_CheckboxInput-Input:checked+.ECM_CheckboxInput-DummyInput:after {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    width: 76%;
    height: 4px;
    border-radius: 2px;
    transform: translate(-5px, 2px) rotateZ(-45deg);
    transform-origin: 2px 2px;
    background: #FFFFFF
}

.check .form .inner90 dl dd .ECM_CheckboxInput-DummyInput, .complete .form .inner90 dl dd .ECM_CheckboxInput-DummyInput, .contact .form .inner90 dl dd .ECM_CheckboxInput-DummyInput {
    position: relative;
    top: 0;
    left: 0;
    display: block;
    width: 28px;
    height: 28px;
    border: solid 2px transparent;
    background: #DFE0E0
}

.check .form .inner90 dl dd .ECM_CheckboxInput-LabelText, .complete .form .inner90 dl dd .ECM_CheckboxInput-LabelText, .contact .form .inner90 dl dd .ECM_CheckboxInput-LabelText {
    margin-left: 12px;
    display: block;
    color: #000
}

.check .form .inner90 dl dd textarea, .complete .form .inner90 dl dd textarea, .contact .form .inner90 dl dd textarea {
    width: 100%;
    border: none;
    background: #DFE0E0
}

.check .form .inner90 dl.flex, .complete .form .inner90 dl.flex, .contact .form .inner90 dl.flex {
    margin-bottom: 0
}

.check .form .inner90 #privacy_txt, .complete .form .inner90 #privacy_txt, .contact .form .inner90 #privacy_txt {
    font-size: 1.2rem;
    font-weight: bold;
    color: #000;
    margin-bottom: 10px
}

.check .form .inner90 #privacy_txt a, .complete .form .inner90 #privacy_txt a, .contact .form .inner90 #privacy_txt a {
    color: #005CB9;
    text-decoration: underline
}

@media screen and (max-width:859px) {
    .check .form .inner90 #privacy_txt, .complete .form .inner90 #privacy_txt, .contact .form .inner90 #privacy_txt {
        font-size: 1rem
    }
}

.check .form .inner90 #privacy_txt2, .complete .form .inner90 #privacy_txt2, .contact .form .inner90 #privacy_txt2 {
    color: #000;
    margin-bottom: 30px
}

.check .form .inner90 .submit_btn, .complete .form .inner90 .submit_btn, .contact .form .inner90 .submit_btn {
    text-align: center;
    margin-right: 10px
}

.check .form .inner90 .btn_back, .check .form .inner90 .send_ok, .complete .form .inner90 .btn_back, .complete .form .inner90 .send_ok, .contact .form .inner90 .btn_back, .contact .form .inner90 .send_ok {
    padding: 20px 80px;
    border: none;
    background: #005CB9;
    color: #fff;
    pointer-events: auto;
    cursor: pointer
}

/* formデザイン変更 */
.form-section{
    max-width: 700px;
    margin: 0 auto;
}

.form-element__text,
.page.contact .form .form-element__textarea{
    border: 1px solid #e0e0e0;
    background: #fff;
    border-radius: 5px 5px;
    padding: 0.8rem;
    width: 100%;
    font-size: 16px;
}

.form-element__text::placeholder,
.page.contact .form .form-element__textarea::placeholder{
    font-size: 15px;
    color: #aaa;
}

.page.contact .form .form-element .form-element__tag{
    color: #fff;
    background: #b30000;
    font-weight: bold;
    font-size: 14px;
    padding: 0.15rem;
    margin-left: 0.4rem;
}

.page.check .form #privacy_txt2,
.page.check .form .form-element .form-element__tag{
    display: none;
}

.form-element__send{
    padding: 20px 80px;
    border: none;
    background: #ff6900;
    pointer-events: auto;
    cursor: pointer;
    color: #fff;
    font-size: 16px;
    font-weight: bold;
    transition: opacity 0.3s;
    box-shadow: 0 3px 10px rgba(0,0,0, 0.2);
    border-radius: 0;
    -webkit-appearance: none;
}

.form-element__send:hover{
    opacity: 0.8;
}

@media screen and (max-width:859px) {
    .cp_ipcheck .mwform-checkbox-field {
        display: block;
        width: 100%
    }

    .cp_ipcheck .horizontal-item+.horizontal-item {
        margin-left: 0;
        display: block;
        width: 100%
    }
}

.recruit .titleWrap .title {
    background: url(../images/recruit/title_img.jpg) no-repeat center center/cover;
    background-attachment: fixed
}

@media screen and (max-width:859px) {
    .recruit .titleWrap .title {
        background-attachment: scroll
    }
}

.recruit .content {
    padding: 70px 0;
    text-align: center
}

@media screen and (max-width:859px) {
    .recruit .content {
        padding: 50px 5%;
        text-align: left
    }
}

.recruit .content .tit1 {
    font-size: 3rem
}

@media screen and (max-width:859px) {
    .recruit .content .tit1 {
        font-size: 1.5rem
    }
}

.recruit .content .btnWrap {
    margin-bottom: 80px
}

@media screen and (max-width:859px) {
    .recruit .content .btnWrap {
        margin-bottom: 40px
    }
}

.recruit .content .slide li img {
    width: 100%;
    height: auto
}

.dictionary .titleWrap {
    text-align: center;
    padding: 120px 0 50px
}

@media screen and (max-width:859px) {
    .dictionary .titleWrap {
        padding: 50px 0 30px
    }
}

.dictionary .titleWrap .title {
    background: url(../images/common/icon_dictionary.svg) no-repeat 30px center;
    background-size: 170px;
    padding: 23px 0 30px 240px;
    width: 530px;
    margin: 60px auto
}

@media screen and (max-width:859px) {
    .dictionary .titleWrap .title {
        background-size: 80px;
        padding: 23px 0 30px 140px;
        width: 100%;
        margin: 30px auto
    }
}

.dictionary .titleWrap .title h1 {
    color: #005CB9;
    font-size: 4rem;
    line-height: 1.2;
    text-align: left;
    letter-spacing: 1.5rem;
    padding: 8px 0 0 0;
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif;
    filter: drop-shadow(0 0 0 rgba(0, 0, 0, 0))
}

.dictionary .titleWrap .title h1 span {
    font-size: 2rem;
    display: block;
    letter-spacing: 0.2rem
}

@media screen and (max-width:859px) {
    .dictionary .titleWrap .title h1 {
        font-size: 3rem;
        letter-spacing: 1rem
    }
}

@media screen and (max-width:859px) {
    .dictionary .titleWrap .lead_text {
        padding: 0 5%;
        text-align: left
    }
}

.dictionary .titleWrap dl {
    width: 300px;
    margin: 0 auto
}

.dictionary .titleWrap dl dt {
    font-weight: bold
}

.dictionary .titleWrap dl dd {
    width: 220px
}

.dictionary .titleWrap .dictionary-search h4 {
    font-size: 1.3rem;
    font-weight: bold
}

.dictionary .titleWrap .dictionary-search h4+ul {
    display: flex;
    justify-content: center;
    margin-bottom: 20px
}

.dictionary .titleWrap .dictionary-search h4+ul li .sf-input-checkbox {
    transform: scale(1.7)
}

.dictionary .titleWrap .dictionary-search h4+ul li .sf-label-checkbox {
    padding-left: 10px;
    margin-right: 20px;
    font-size: 1.2rem;
    font-weight: bold
}

.dictionary .titleWrap .dictionary-search h4+ul li .sf-label-checkbox .sf-count {
    font-size: 0.8rem;
    font-weight: normal;
    padding-left: 0
}


/* ーーーーーー　追加新規開業　ーーーーーー */
.newOpen {
    font-size: 1.2rem;
    font-weight: 600;
}

.newOpen__banner{
    margin-top: 24px;
    background-color: white;
    border-radius: 8px;
    width: 100%;
    letter-spacing: 0.8px;
    line-height: 1.4;
    font-size: 0.85rem;
    text-align: center;
    padding: 7px 10px;
    min-width: 190px;
    transition: ease .1s;
}
.newOpen__banner:hover{
    opacity: .7;
}


.newOpen__bannerImg {
    width: 160px;
}

/* ーーーーーー　追加新規開業 フッター　ーーーーーー */
.f_logo {
    display: flex;
    flex-direction: column;
    align-items: center;
}


@media screen and (max-width:859px) {
    .dictionary .titleWrap .dictionary-search h4+ul {
        flex-wrap: wrap;
        margin: 0 10%
    }

    .dictionary .titleWrap .dictionary-search h4+ul li {
        width: calc(80% / 5);
        margin: 0 5% 5% 0
    }

    .dictionary .titleWrap .dictionary-search h4+ul li:nth-of-type(5n) {
        margin: 0 0 5% 0
    }

    .dictionary .titleWrap .dictionary-search h4+ul li a {
        font-size: 1.5rem;
        display: block;
        padding: 5px 10px;
        width: 100%
    }
}

.dictionary .titleWrap .dictionary-search .sf-field-search {
    display: flex;
    justify-content: center
}

@media screen and (max-width:859px) {
    .dictionary .titleWrap .dictionary-search .sf-field-search {
        flex-wrap: wrap
    }
}

.dictionary .titleWrap .dictionary-search .sf-field-search h4 {
    margin-right: 15px
}

.dictionary .titleWrap .dictionary-search .sf-field-search h4+label {
    position: relative
}

.dictionary .titleWrap .dictionary-search .sf-field-search h4+label:after {
    content: "";
    background: url(../images/common/icon_search.svg) no-repeat center center;
    background-size: 100%;
    position: absolute;
    width: 25px;
    height: 25px;
    top: 8px;
    right: 10px
}

.dictionary .titleWrap .dictionary-search .sf-field-search .sf-input-text {
    font-size: 1.5rem;
    padding: 0.5rem;
    border: none;
    background: #DFE0E0
}

.dictionary .titleWrap .dictionary-search .searchwrap {
    width: 530px;
    margin: 0 auto
}

@media screen and (max-width:859px) {
    .dictionary .titleWrap .dictionary-search .searchwrap {
        width: 100%;
        padding: 0 5%
    }
}

.dictionary .titleWrap .dictionary-search .searchwrap #searchform {
    margin: 0 auto 60px auto
}

@media screen and (max-width:859px) {
    .dictionary .titleWrap .dictionary-search .searchwrap #searchform {
        flex-wrap: wrap
    }
}

.dictionary .titleWrap .dictionary-search .searchwrap #searchform p {
    font-size: 1.3rem;
    font-weight: bold;
    padding: 5px 10px 0 0
}

@media screen and (max-width:859px) {
    .dictionary .titleWrap .dictionary-search .searchwrap #searchform p {
        font-size: 1.3rem;
        margin-bottom: 10px;
        width: 100%
    }
}

.dictionary .titleWrap .dictionary-search .searchwrap #searchform #keywords {
    background: #DFE0E0;
    border: none;
    padding: 0.8rem 1.5rem;
    font-size: 1.2rem
}

@media screen and (max-width:859px) {
    .dictionary .titleWrap .dictionary-search .searchwrap #searchform #keywords {
        width: 85%
    }
}

.dictionary .titleWrap .dictionary-search .searchwrap #searchform #searchBtn {
    background: #DFE0E0;
    padding: 0 12px;
    width: 50px
}

@media screen and (max-width:859px) {
    .dictionary .titleWrap .dictionary-search .searchwrap #searchform #searchBtn {
        width: 15%
    }
}

.dictionary .content {
    background: #DFE0E0;
    padding: 80px 0
}

@media screen and (max-width:859px) {
    .dictionary .content {
        padding: 5%
    }
}

.dictionary .content .inner {
    background: #fff;
    padding: 20px 100px 60px
}

@media screen and (max-width:859px) {
    .dictionary .content .inner {
        padding: 15px
    }
}

.dictionary .content .inner #result {
    text-align: center;
    font-size: 1.5rem;
    margin: 30px 0 15px 0
}

.dictionary .content .inner #result span {
    font-size: 2rem;
    font-weight: bold;
    padding: 0 5px
}

.dictionary .content .inner dl {
    border-bottom: 2px dashed #005CB9;
    padding: 30px 0
}

@media screen and (max-width:859px) {
    .dictionary .content .inner dl {
        flex-wrap: wrap
    }
}

.dictionary .content .inner dl dt {
    font-size: 1.2rem;
    font-weight: bold;
    width: 20%;
    text-align: center;
    line-height: 1.5;
    margin-right: 5%
}

@media screen and (max-width:859px) {
    .dictionary .content .inner dl dt {
        width: 100%;
        margin-right: 0;
        margin-bottom: 20px
    }
}

.dictionary .content .inner dl dt span {
    display: block;
    font-size: 0.8rem
}

.dictionary .content .inner dl dd {
    color: #000;
    font-weight: bold;
    width: 75%;
    line-height: 2
}

@media screen and (max-width:859px) {
    .dictionary .content .inner dl dd {
        font-size: 1rem;
        line-height: 1.8;
        width: 100%
    }
}

.faq .titleWrap {
    text-align: center;
    padding: 120px 0 50px
}

@media screen and (max-width:859px) {
    .faq .titleWrap {
        padding: 50px 0 0 0
    }
}

.faq .titleWrap .title {
    padding: 70px 0
}

.faq .titleWrap .title h1 {
    color: #005CB9;
    font-size: 3rem;
    line-height: 1.2;
    text-align: center;
    letter-spacing: 0.5rem;
    padding: 8px 0 0 0;
    filter: drop-shadow(0 0 18px rgba(0, 0, 0, 0));
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

@media screen and (max-width:859px) {
    .faq .titleWrap .title h1 {
        font-size: 2rem
    }
}

.faq .content {
    margin-bottom: 100px
}

@media screen and (max-width:859px) {
    .faq .content {
        margin-bottom: 50px
    }
}

.faq .content dl {
    font-weight: bold;
    line-height: 1.5;
    margin-bottom: 10px
}

.faq .content dl dt {
    padding: 0 0 0 1.5em;
    position: relative;
    cursor: pointer;
    background-color: #005CB9;
    color: #fff;
    padding: 1.5rem 2rem 1.5rem 3.5rem;
    border-radius: 5px 5px;
    transition: all 0.5s
}

@media screen and (max-width:859px) {
    .faq .content dl dt {
        padding: 1rem 3rem 1rem 3rem
    }
}

.faq .content dl dt:before {
    position: absolute;
    top: 1rem;
    left: 1.5rem;
    content: "Q";
    display: inline-block;
    color: #fff;
    font-size: 1.5rem
}

@media screen and (max-width:859px) {
    .faq .content dl dt:before {
        top: 0.5rem;
        left: 1rem
    }
}

.faq .content dl dt:after {
    position: absolute;
    right: 20px;
    top: 28px;
    content: "";
    background: url(../images/faq/icon_puls.svg) no-repeat center center;
    width: 20px;
    height: 20px;
    transition: all 0.5s
}

@media screen and (max-width:859px) {
    .faq .content dl dt:after {
        right: 15px;
        top: 18px
    }
}

.faq .content dl dt:hover {
    background-color: #0075ec
}

.faq .content dl dt.clicked:after {
    transform: rotate(135deg)
}

.faq .content dl dd {
    display: none;
    font-size: 0.9rem;
    padding: 1.5rem 1.5rem 1.5rem 3.5rem;
    position: relative;
    background-color: #DFE0E0;
    border-radius: 5px 5px;
    margin: 0 0 20px
}

@media screen and (max-width:859px) {
    .faq .content dl dd {
        padding: 1rem 1rem 1rem 3rem
    }
}

.faq .content dl dd:before {
    position: absolute;
    top: 1rem;
    left: 1.5rem;
    content: "A";
    display: block;
    color: #005CB9;
    margin: 0 0.5em 0px 0;
    font-size: 1.5rem
}

@media screen and (max-width:859px) {
    .faq .content dl dd:before {
        top: 0.5rem;
        left: 1rem
    }
}

.guidelines .titleWrap, .privacy .titleWrap {
    text-align: center;
    padding: 120px 0 50px
}

@media screen and (max-width:859px) {
    .guidelines .titleWrap, .privacy .titleWrap {
        padding: 50px 0 0 0
    }
}

.guidelines .titleWrap .title, .privacy .titleWrap .title {
    padding: 70px 0
}

.guidelines .titleWrap .title h1, .privacy .titleWrap .title h1 {
    color: #005CB9;
    font-size: 3rem;
    line-height: 1.2;
    text-align: center;
    letter-spacing: 0.5rem;
    padding: 8px 0 0 0;
    filter: drop-shadow(0 0 18px rgba(0, 0, 0, 0));
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

@media screen and (max-width:859px) {
    .guidelines .titleWrap .title h1, .privacy .titleWrap .title h1 {
        font-size: 1.8rem
    }
}

.guidelines .inner90 p, .privacy .inner90 p {
    color: #000
}

.guidelines .inner90 h3, .privacy .inner90 h3 {
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif;
    font-size: 2rem;
    margin: 30px 0 10px
}

@media screen and (max-width:859px) {
    .guidelines .inner90 h3, .privacy .inner90 h3 {
        font-size: 1.6rem
    }
}

.guidelines .inner90 h4, .privacy .inner90 h4 {
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif;
    font-size: 1.5rem;
    margin: 50px 0 10px
}

@media screen and (max-width:859px) {
    .guidelines .inner90 h4, .privacy .inner90 h4 {
        font-size: 1.3rem
    }
}

.guidelines .inner90 ul, .privacy .inner90 ul {
    color: #000;
    list-style-type: disc;
    padding-left: 1.5rem
}

.guidelines .inner90 ul li, .privacy .inner90 ul li {
    margin-bottom: 5px
}

.guidelines .inner90 ol, .privacy .inner90 ol {
    color: #000;
    list-style-type: decimal;
    padding-left: 1.5rem
}

.guidelines .inner90 ol li, .privacy .inner90 ol li {
    margin-bottom: 5px
}

.mail-magazine .titleWrap {
    text-align: center;
    padding: 120px 0 50px
}

@media screen and (max-width:859px) {
    .mail-magazine .titleWrap {
        padding: 50px 0 0 0
    }
}

.mail-magazine .titleWrap .title {
    padding: 70px 0
}

.mail-magazine .titleWrap .title h1 {
    color: #005CB9;
    font-size: 3rem;
    line-height: 1.2;
    text-align: center;
    letter-spacing: 0.5rem;
    padding: 8px 0 0 0;
    filter: drop-shadow(0 0 18px rgba(0, 0, 0, 0));
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

@media screen and (max-width:859px) {
    .mail-magazine .titleWrap .title h1 {
        font-size: 2rem
    }
}

.mail-magazine .content {
    width: 600px;
    margin: 0 auto 100px
}

.mail-magazine .content p {
    color: #000;
    margin-bottom: 30px
}

@media screen and (max-width:859px) {
    .mail-magazine .content {
        width: 100%;
        margin: 0 auto 50px
    }

    .mail-magazine .content p {
        margin-bottom: 15px
    }
}

.mail-magazine .content .bmform_outer1063404 {
    width: 600px !important
}

@media screen and (max-width:859px) {
    .mail-magazine .content .bmform_outer1063404 {
        width: 90% !important
    }
}

.mail-magazine .content .bmform_outer1063404 .bmform_inner1063404 {
    border: none
}

.mail-magazine .content .bmform_outer1063404 .bmform_inner1063404 .bmform_head1063404 {
    height: 50px
}

.mail-magazine .content .bmform_outer1063404 .bmform_inner1063404 .bmform_head1063404 .bm_headetext1063404 {
    font-size: 18px;
    padding: 10px 10px 0 10px
}

.mail-magazine .content .bmform_outer1063404 .bmform_inner1063404 .bmform_body1063404 {
    background: #DFE0E0;
    padding: 30px 50px 50px
}

@media screen and (max-width:859px) {
    .mail-magazine .content .bmform_outer1063404 .bmform_inner1063404 .bmform_body1063404 {
        padding: 20px 30px 30px
    }
}

.mail-magazine .content .bmform_outer1063404 .bmform_inner1063404 .bmform_body1063404 .bmform_introtxt1063404 {
    font-size: 1rem
}

.mail-magazine .content .bmform_outer1063404 .bmform_inner1063404 .bmform_body1063404 #tblFieldData1063404 {
    font-size: 1rem;
    color: #005CB9
}

.mail-magazine .content .bmform_outer1063404 .bmform_inner1063404 .bmform_body1063404 .bmform_frm1063404 {
    border: none;
    font-size: 1.2rem;
    width: 100%;
    padding: 0.8rem;
    margin-bottom: 10px
}

.mail-magazine .content .bmform_outer1063404 .bmform_inner1063404 .bmform_body1063404 .bmform_submit1063404 {
    padding: 10px 30px;
    background: #005CB9;
    color: #fff;
    border: none;
    font-weight: bold
}

.mail-magazine .content #tblRequiredField1063404 {
    width: 600px
}

@media screen and (max-width:859px) {
    .mail-magazine .content #tblRequiredField1063404 {
        width: 90%
    }
}

.mail-magazine .content #tblRequiredField1063404 tr td {
    font-size: 15px !important
}

.error404 .titleWrap {
    text-align: center;
    padding: 120px 0 50px
}

@media screen and (max-width:859px) {
    .error404 .titleWrap {
        padding: 50px 0 0 0
    }
}

.error404 .titleWrap .title {
    padding: 70px 0
}

.error404 .titleWrap .title h1 {
    color: #005CB9;
    font-size: 3rem;
    line-height: 1.2;
    text-align: center;
    letter-spacing: 0.5rem;
    padding: 8px 0 0 0;
    filter: drop-shadow(0 0 18px rgba(0, 0, 0, 0));
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

@media screen and (max-width:859px) {
    .error404 .titleWrap .title h1 {
        font-size: 2rem
    }
}

.error404 .inner70 {
    margin: 0 auto 100px
}

@media screen and (max-width:859px) {
    .error404 .inner70 {
        margin: 0 auto 50px
    }
}

.lead_text {
    font-size: 1.1rem;
    line-height: 2;
    letter-spacing: 0.2rem;
    margin-bottom: 50px;
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif
}

@media screen and (max-width:859px) {
    .lead_text {
        font-size: 1rem;
        line-height: 1.8;
        letter-spacing: 0.1rem;
        margin-bottom: 25px
    }
}

.spbr {
    display: none
}

@media screen and (max-width:859px) {
    .spbr {
        display: block
    }
}

.cp_ipselect {
    overflow: hidden;
    width: 100%;
    text-align: center
}

.cp_ipselect select {
    font-size: 1rem;
    width: 100%;
    padding-right: 1em;
    cursor: pointer;
    text-indent: 0.01px;
    text-overflow: ellipsis;
    border: none;
    outline: none;
    background: transparent;
    background-image: none;
    box-shadow: none;
    -webkit-appearance: none;
    appearance: none
}

.cp_ipselect select::-ms-expand {
    display: none
}

.cp_ipselect.cp_sl05 {
    position: relative;
    border-radius: 2px;
    background: #DFE0E0
}

.cp_ipselect.cp_sl05:before {
    position: absolute;
    top: 24px;
    right: 0.8em;
    width: 0;
    height: 0;
    padding: 0;
    content: "";
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-top: 6px solid #005CB9;
    pointer-events: none
}

@media screen and (max-width:859px) {
    .cp_ipselect.cp_sl05:before {
        top: 15px
    }
}

.cp_ipselect.cp_sl05 select {
    padding: 18px 38px 18px 15px;
    color: #005CB9
}

@media screen and (max-width:859px) {
    .cp_ipselect.cp_sl05 select {
        padding: 10px 35px 10px 15px
    }
}

.wp-pagenavi {
    text-align: center
}

.wp-pagenavi a {
    text-decoration: none
}

.wp-pagenavi a, .wp-pagenavi span {
    font-weight: 600;
    position: relative;
    padding: 10px;
    z-index: 2;
    display: inline-block;
    border: none
}

.wp-pagenavi a.is-current, .wp-pagenavi span.is-current {
    background: transparent
}

.wp-pagenavi a.is-current:before, .wp-pagenavi span.is-current:before {
    display: none
}

.wp-pagenavi a.is-current:hover, .wp-pagenavi span.is-current:hover {
    color: #00419b
}

.wp-pagenavi a:hover, .wp-pagenavi span:hover {
    color: rgba(0, 65, 155, 0.7)
}

.wp-pagenavi a:hover:before, .wp-pagenavi span:hover:before {
    background: rgba(255, 255, 255, 0.7)
}

.wp-pagenavi a.first, .wp-pagenavi a.last, .wp-pagenavi span.pages {
    background: transparent;
    color: #00419b
}

.wp-pagenavi a.first:before, .wp-pagenavi a.last:before, .wp-pagenavi span.pages:before {
    display: none
}

.wp-pagenavi a.first:hover, .wp-pagenavi a.last:hover, .wp-pagenavi span.pages:hover {
    color: #00419b
}

.wp-pagenavi span.current:before {
    content: "";
    background: #DFE0E0;
    width: 28px;
    height: 28px;
    line-height: 1.4;
    border-radius: 100px;
    position: absolute;
    left: 0px;
    right: 0;
    top: 0;
    bottom: 0;
    z-index: -1;
    margin: auto
}

.p-pagination__next, .p-pagination__prev {
    display: inline-block;
    vertical-align: middle;
    text-decoration: none;
    font-weight: 600
}

.p-pagination__next:hover, .p-pagination__prev:hover {
    color: rgba(0, 65, 155, 0.7)
}

.p-pagination__prev {
    margin-right: 10px
}

.p-pagination__next {
    margin-left: 10px
}

.p-pagination__dots {
    background: transparent;
    color: #00195a
}


/* 2023/02/22 追記 */
.pickUpPost{margin-top: 80px; margin-bottom: 40px; padding: 40px 0; background-color: #efefef; text-align: left;}
.pickUpPost__inner .mb20{margin-bottom: 20px;}
.pickUpPost__content{display: flex; column-gap: 30px;}
.pickUpPost__content .img{width: 60.66666%; position: relative;}
.pickUpPost__content .img img{width: 100%; object-fit: cover; aspect-ratio: 1.7/1; height: 100%;}
.pickUpPost__content .text{width: calc(39.33333% - 30px); display: flex; flex-direction: column;}
.pickUpPost__content .ttl{font-size: 24px; font-weight: 400; font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif;}
.pickUpPost__content .cat{margin-bottom: 15px;}
.pickUpPost__content .cat ul{display: flex; flex-wrap: wrap; gap: 8px;}
.pickUpPost__content .cat li{width: fit-content; position: relative; display: flex;  background-color: #005CB9; color: white; padding: 6px 10px; border-radius: 3px; font-size: 14px; line-height: 1;}
.pickUpPost__content .date{margin-bottom: 18px;}
.pickUpPost__content .tags{position: absolute; width: calc(100% - 20px); display: flex; bottom: 10px; left: 50%; padding: 0 0px; transform: translateX(-50%); gap: 15px;}
.pickUpPost__content .tags li a{background-color: white; color: #333; padding: 6px 10px; font-size: 14px; border-radius: 4px; box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.4); font-weight: 700;}
.pickUpPost__content .content{margin-bottom: 15px; font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif;}
.pickUpPost__content .button{font-size: 18px; font-weight: 700; box-shadow: 1px 1px 2px rgba(0, 0, 0, 0.3); background-color: #005CB9; padding: 8px 30px; color: white; border-radius: 6px; display: flex; width: fit-content; margin-top: auto;}

.cd_label{margin-bottom: 12px;}
.cd_label span{border: 1px solid #005CB9; border-radius: 4px; padding: 2px 4px; width: 96px; text-align: center; display: inline-block; margin-right: 8px; font-size: 14px; font-weight: bold;}
.cd_label2{margin-bottom: 4px; font-size: 18px; color: #333; line-height: 1.4; font-weight: 500; position: relative;}
.cd_label2 span{display: inline-block; margin-right: 4px; width: 96px; }
.cd_label2--s{margin-bottom: 2px; color: #6b8292; line-height: 1.2; font-size: 12px;}
.pickUpPost__content{position: relative;}
.pickUpPost__content:before{content: "PickUp";position: absolute;top: -20px;left: -26px;z-index: 11;font-weight: bold;transform: rotate( -12deg ); font-size: 24px;}
.pickUpPost__content.new:before{content: "NEW";}
.category .article ul li .column_text_contents {padding: 20px; min-height: 199px; display: flex; flex-direction: column;}
.category .article ul li .column_text_contents h3 a{font-weight: 700;color: #333;font-size: 18px;line-height: 1.6; position: relative; z-index: 1;}
.category .article ul li .column_text_contents--bottom {margin-top: auto; position: relative;}
.category .article>ul>li .bglink::before{position: absolute; bottom: 20px; right: 20px; border-radius: 20px; content: ''; background-image: url(../images/common/arrow.svg); width: 24px; height: 24px; display: block; background-position: center center; background-repeat: no-repeat; background-size: 8px; background-color: #244059; transition: ease .3s;}
.category .article>ul>li:hover ::before{background-color: #27b1db; transition: ease .3s;}
.category .article ul li .date{color: #27b1db;}
.columnNews_links{margin-bottom: 40px; display: flex; max-width: 680px; margin-right: auto; margin-left: auto; column-gap: 40px; padding-top: 20px;}
.columnNews_links_item{width: calc(50% - 20px); /*background-color: #005CB9;*/ border: 1px solid #005CB9; color: #005CB9; font-weight: 700; font-size: 20px; padding: 10px; }
.columnNews_links_item.cur{background-color: #005CB9; color: white;}
.columnNews_links_item:hover{background-color: #005CB9; color: white; opacity: unset;}
#selectPost{padding-top: 40px;}

@media screen and (max-width:859px) {
    .category .recommend{margin: 30px 0 30px;}
    #selectPost{padding-top: 0px;}
    .selectPostCat{flex-wrap: wrap; row-gap: 12px;}
    .selectPostCat dt{width: 30%;}
    .selectPostCat dd{width: 70%;}
    .pickUpPost{margin-bottom: 20px;}
    .pickUpPost__inner .mb20{margin-bottom: 12px!important;}
    .pickUpPost__content{flex-direction: column;}
    .pickUpPost__content .img,.pickUpPost__content .text{width: 100%;}
    .pickUpPost__content .tags{flex-wrap: wrap; gap: 4px; }
    .pickUpPost__content .tags li{display: flex;}
    .pickUpPost__content .tags li a{font-size: 10px; line-height: 1.2; padding: 3px;}
    .pickUpPost__content .button{font-size: 14px;}
    .cd_label2{margin-bottom: 4px; font-size: 14px;}
    .cd_label2 span{display: block; margin-right: 0; width: auto;}
    .pickUpPost__content:before{font-size: 12px;top: -8px;left: -8px;}
    .category .article ul li .column_text_contents{padding: 20px 12px;}
    .category .article ul li .column_text_contents {min-height: 160px;}
    .category .article ul li .column_text_contents h3{line-height: 1.2;}
    .category .article ul li .column_text_contents h3 a{font-size: 13px; line-height: 1.2;}
    .category .article ul li .column_text_contents .postTxtLink{display: none;}
    .category .article>ul>li .bglink::before{bottom: 12px; right: 12px;}
    .category .article>ul>li .bglink::before{width: 18px; height: 18px; background-size: 4px;}
    .category .article ul li .column_category span{font-size: 12px; padding: 8px; font-weight: 400;}
    .columnNews_links{column-gap: 20px; padding: 20px; margin-bottom: 10px;}
    .columnNews_links_item{width: calc(50% - 10px);font-size: 14px; padding: 6px; }

}
/* 2023/02/22 追記 */

/* 2023/04/22 */
.case_ar_wrapper .gccols1 {
    width: 156px;
}
.case_ar_wrapper .gccols2 {
    width: 156px;
}
.case_ar_wrapper .sales {
    text-align: center;
}
/* 2023/04/22 */

/* 2023/06/08 追記：コラムページ */
.column-detail h1 span {
    display: block;
    font-size: 1.4rem;
    color: #333;
}

.column-detail h2 {
    padding: 0.4em 0.3em;/*文字の上下 左右の余白*/
    color: #494949;/*文字色*/
    background: #f4f4f4;/*背景色*/
    border-left: solid 5px #7db4e6;/*左線*/
    border-bottom: solid 3px #d7d7d7;/*下線*/
    margin-top: 50px;
    margin-bottom: 20px;
    letter-spacing: 0.2rem;
}

.column-detail h3 {
    margin-top: 10px;
    margin-bottom: 10px;
    color: #000;
    font-weight: bold;
}

.column-detail h4 {
    text-align: center;
}

.column-detail p {
    margin-top: 10px;
}

.column-detail ul li {
    margin-top: 10px;
    font-size: 1rem;
    color: #005CB9;
    font-weight: bold;
    line-height: .8;
}

@media screen and (max-width: 600px) {
    .column-detail h1 span {
        font-size: 1.2rem;
    }
    
    .column-detail ul li {
        font-size: 0.8rem;
    }
    
}
/* 2023/06/08 追記：コラムページ ここまで */

/* 2023/12/12 追記：コラムページ内テーブル用 ここから */
.column-detail table {
    border-collapse: collapse;
    margin: 10px auto 0;
    padding: 0;
    width: 100%;
}
.column-detail table th {
    padding: 10px 8px 10px 16px;
    background-color: #5892cc;
    text-align: center;
    vertical-align: middle;
    color: #fff;
    font-weight: bold;
    font-size: 18px;
    border: 1px solid rgba(0,0,0,0.15);
}
.column-detail table th:first-child {
    border-left: none;
}
.column-detail table th:last-child {
    border-right: none;
}
.column-detail table td {
    padding: 10px 8px 10px 24px;
    background-color: #f4f4f4;
    text-align: left;
    vertical-align: middle;
    color: #333;
    font-weight: bold;
    font-size: 18px;
    border: 1px solid rgba(0,0,0,0.15);
}
.column-detail table td:first-child {
    border-left: none;
}
.column-detail table td:last-child {
    border-right: none;
}
@media screen and (max-width: 600px) {
    .column-detail table {
    border-collapse: collapse;
    margin: 10px auto 0;
    padding: 0;
    width: 100%;
    }
    .column-detail table th {
        padding: 8px 4px 8px 4px;
        background-color: #5892cc;
        text-align: center;
        vertical-align: middle;
        color: #fff;
        font-weight: bold;
        font-size: 14px;
        border: 1px solid rgba(0,0,0,0.15);
    }
    .column-detail table th:first-child {
        border-left: none;
    }
    .column-detail table th:last-child {
        border-right: none;
    }
    .column-detail table td {
        padding: 8px 4px 8px 4px;
        background-color: #f4f4f4;
        text-align: left;
        vertical-align: middle;
        color: #333;
        font-weight: bold;
        font-size: 14px;
        border: 1px solid rgba(0,0,0,0.15);
    }
    .column-detail table td:first-child {
        border-left: none;
    }
    .column-detail table td:last-child {
        border-right: none;
    }

}
/* 2023/12/12 追記：コラムページ内テーブル用 ここまで */

/* 2023/06/20 追記：事例集ページ*/
.single .casestudies-detail h2 {
    padding: 4px 8px;
    color: #005CB9;
    text-decoration: underline;
    font-size: 18px;
}
.single .casestudies-detail h3 {
    padding: 4px 8px;
    color: #005CB9;
    background: #f4f4f4;
    font-size: 18px;
}
.single .casestudies-detail h5 {
   color: #333;
   text-align: center;
   font-weight: normal;
}
.single .casestudies-detail p {
    font-size: 18px;
}
@media screen and (max-width: 600px) {
    .single .casestudies-detail h2 {
        font-size: 16px;
    }
    .single .casestudies-detail h3 {
        font-size: 16px;
    }
    .single .casestudies-detail h5 {
        font-size: 14px;
    }
    .single .casestudies-detail p {
        font-size: 14px;
        line-height: 2rem;
    }
    
}
/* 2023/06/20 追記：事例集ページここまで*/

/* 電話表記 */
.form__lead{
    text-align: center;
    font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif;
}

.form__lead__text{
    margin-bottom: 0.5em;
}

.block-phone{
    display: inline-block;
    text-align: center;
    margin-top: 20px;
    margin-bottom: 40px;
}

.block-phone a{
    display: inline-block;
    color: #005CB9;
    background: #efefef;
    border-radius: 100px 100px;
    text-align: center;
    padding: 12px 24px;
    font-size: 20px;
    line-height: 32px;
    font-weight: bold;
    cursor: pointer;
    box-shadow: 0 3px 10px rgba(0,0,0,0.2);
}

.block-phone a:hover{
    color: #005CB9;
}

.block-phone__icon{
    margin-right: 0.25em;
}

.sp-phone-btn,
.sp-nav{
    display: none;
}

@media screen and (max-width: 859px) {
    .sp-nav{
        display: block;
    }

    .sp-phone-btn{
        display: inline-block;
        margin: 0;
    }
    
    .sp-phone-btn a{
        padding: 12px;
        background: #efefef;
        border-radius: 100px 100px;
        font-size: 18px;
        line-height: 27px;
        box-shadow: none;
        text-align: center;
    }
    
    .sp-phone-btn__icon{
        color: #b30000;
        margin: 0;
    }
}

/* 2025/08/15 追記：資料請求ページ */
/* ===== layout ===== */
.downloadWrap{
  display:flex;
  gap: 1rem clamp(18px, 4vw, 42px);
  margin-bottom: 3rem;
}
.download__item{
  flex: 3;
  overflow: hidden;
}
.download__form{
  flex: 2;
  min-width: 340px;
  color: initial;
}
.download__item .intro,
.download__item .desc,
.download__item .explain p,
.download__item .explain .numlist,
.download__form{
  color: #000;
}

@media screen and (max-width:859px) {
  .downloadWrap{
    flex-direction: column;
  }
  .download__form{
    min-width: auto;
  }
}
/* ===== Left: Content ===== */
.download__item {
	font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", "Meiryo", serif;
}

.download__item .text{
  font-size: .96em;
  margin-bottom: 2em;
}
.download__item .title{
  font-size: clamp(28px, 2.18vw, 36px);
  line-height: 1.25;
  margin: 0 0 .5em;
  font-weight: 800;
}
.download__item .subtitle{
	color: #000;
  font-weight: 700;
  margin-bottom: .25em;
}
.download__item .mainimg{
  background: #fff;
  margin-block: 1.2rem;
  overflow: hidden;
}
.download__item .mainimg img {
  max-width: 100%;
}
.download__item .explain{
  margin-block: 1.6rem;
}
.download__item .explain .headding{
  position:relative;
  font-size: 1.4em;
  font-weight:800;
  margin-bottom: 1rem;
}
.download__item .explain .headding::after{
  content:"";
  position:absolute;
  left:0;
  bottom:0;
  width: 100%;
  height:1px;
  border-bottom: dashed 4px #D8D8D8;
  padding-bottom: 20px;
}
.download__item .numlist{
  counter-reset: c;
  list-style:none;
  color: initial;
  padding:0;
  margin:.5rem 0 0 0;
}
.download__item .numlist li{
  position:relative;
  counter-increment:c;
  margin:.4em 0;
  padding-left:2.2em;
}
.download__item .numlist li::before{
  content: counter(c) ".";
  position:absolute;
  left:0;
  top:0;
  width:1.8em;
  height:1.8em;
  display:inline-grid;
  place-items:center;
  font-weight:700;
}
/* ===== Right: Form Card ===== */
.download__form .form-wrap{
  background: #efefef;
  border-radius: 8px;
  font-size: 0.96rem;
  padding: clamp(16px, 3.5vw, 28px);
}
.download__form .first_text{
  margin-bottom: 1.2rem;
}
.download__form .form-element .form-element__tag {
  color: #fff;
  background: #b30000;
  font-weight: bold;
  font-size: 12px;
  padding: 0.15em 0.2rem;
  margin-left: 0.4rem;
  border-radius: 4px;
}
.download__form .form-element__textarea {
  border: 1px solid #e0e0e0;
  background: #fff;
  border-radius: 5px 5px;
  padding: 0.8rem;
  width: 100%;
  font-size: 16px;
}
.download__form .status_radio label {
  display: flex;
  align-items: flex-start;
}
.download__form .status_radio  input {
  margin-top: 7px;
}
.download__form dl {
  margin-bottom: 20px;
}
.download__form dl dt {
  font-weight: bold;
  margin-bottom: 5px
}
.download__form dl dt span {
  color: #005CB9
}
.download__form dl dt span.error {
  color: #B70000;
  display: inline-block
}
.download__form .submit_box{
  margin-top: 26px;
}
/* 2023/06/20 追記：事例集ページ ここまで */