/*-----------------------------------------------------------------------

    header

-----------------------------------------------------------------------*/
.h_logo {
    line-height: 0;
    z-index: 10;
}
.h_logo img {
    height: 40px;
}
.h_wrap {
    align-items: center;
    flex-direction: row;
    width: 100%;
    height: 60px;
    padding: 0 5%;
    /* position: absolute; */
    z-index: 990;
}
header.page-header {
    /* position: absolute; */
    top: 0; left: 0; right: 0;
    z-index: 999;
    transition: .3s all;
}
/* pagetop */
.pagetop {
    display: none;
    width: 50px;
    position: fixed;
    bottom: 20px; right: 20px;
    z-index: 100;
}
.pagetop a {
    transition: all .3s;
}
.pagetop.fixed a {
    pointer-events: all;
    opacity: 1;
}

/* ▼aside-sns */
.aside-sns {
    padding: 12px;
    background-color: rgba(255, 255, 255, .9);
    position: fixed;
    bottom: 80px; right: 0;
    z-index: 999;
}
.aside-sns li:not(:last-child) {
    margin-bottom: 10px;
}


/*▼sp_nav*/
#nav_toggle {
    position: fixed;
    top: 15px; right: 15px;
    padding: 15px 15px;
    background-color: var(--main-color);
    z-index: 999;
    transition: all .3s;
    border: 1px solid #fff;
}
#nav_toggle:hover {
    box-shadow: 0px 0px 0 0 #fff;
}
#nav_toggle span {
    display: block;
    width: 30px;
    height: 2px;
    margin: 0 auto;
    background-color: #fff;
    transition: .3s;
}
#nav_toggle span:not(:last-child) {
    margin-bottom: 8px;
}
#nav_toggle.active span:nth-of-type(1) {
    -webkit-transform: translate3d(0px, 10px, 0) rotate(45deg);
    transform: translate3d(0px, 10px, 0) rotate(45deg);
}
#nav_toggle.active span:nth-of-type(2) {
    opacity: 0;
}
#nav_toggle.active span:nth-of-type(3) {
    -webkit-transform: translate3d(0px, -10px, 0) rotate(-45deg);
    transform: translate3d(0px, -10px, 0) rotate(-45deg);
}
.g_nav {
    overflow-y: scroll;
    visibility: hidden;
    width: 100%;
    height: 100%;
    padding: 80px 5% 50%;
    background-color: #fff;
    position: fixed;
    top: 0; bottom: 0; left: 0; right: 0;
    transition: 0.5s ease-in-out;
    z-index: 997;
    -webkit-overflow-scrolling: touch;
}
.g_nav .partition {
    border-bottom: 1px solid;
    margin-bottom: 10px;
    padding-bottom: 10px;
}
.g_nav-logo {
    width: auto;
    height: auto;
    position: absolute;
    top: 15px; left: 5%;
}
.g_nav-logo img {
    height: 40px;
}
.h_nav li {
    width: 100%;
    padding: 10px 0 10px 20px;
    font-weight: bold;
    line-height: 1.5;
}
/* .h_nav li a.current {
    display: inline-block;
    padding: 0 5px;
    background: linear-gradient(var(--catch-color),var(--catch-color)) no-repeat bottom / 100% 30%;
} */
.g_nav .h_logo {
    margin-bottom: 25px;
}
.g_nav .aside-info {
    align-items: center;
    justify-content: center;
    margin: 30px 0 0;
    text-align: center;
}
.aside-info {
    align-items: center;
    justify-content: center;
}
.aside-info .common-info_cnt {
    display: flex;
    flex-flow: column;
    align-items: center;
}
.aside-info .header-detail_info {
    align-items: center;
    margin: 0 0 15px;
}
.aside-info .header-detail_info li:not(:last-child) {
    margin-right: 10px;
}
.aside-info .common-info_list {
    align-items: center;
    justify-content: center;
    width: 100%;
    margin: 20px 0 0;
}
.g_nav .common-info_tel {
    text-align: center;
}
.g_nav .common-info_contact.css-fixed::after {
    background-image: url(../images/common/button_deco02.png);
}
.g_nav .common-info_sns {
    margin: 15px 0 0;
}
.g_nav {
    opacity: 0;
    pointer-events: none;
}
.g_nav.open {
    visibility: visible;
    opacity: 1;
    pointer-events: all;
}
.g_nav .h_nav {
    transform: translateX(30vw);
    transition: all .4s;
    opacity: 0;
}
.g_nav.open ul {
    transform: translateX(0);
    opacity: 1;
}

/* drawer-nav */
.drawer-nav {
    background: #fff url(../images/top/case_cnt_deco01.png) no-repeat top;
}
.drawer-logo {
    /* width: 30%; */
    width: 50%;
    margin-top: -8%;
}
.drawer-nav {
    z-index: 100;
}
.drawer-nav .sns-list {
    justify-content: center;
    margin: 0;
}
.drawer-nav .drawer-menu > li > .drawer-menu-item {
    color: inherit;
}
.drawer-current {
    border-bottom-color: inherit !important;
    border-right-color: inherit !important;
}
.drawer-nav .drawer-menu > li > .drawer-menu-item {
    line-height: 1.3;
    font-size: 1.4rem;
}
.drawer-address li {
    margin-bottom: 13px;
}
.drawer-info {
    width: calc(100% + 20px);
    margin: 30px -10px 0;
}
.drawer-info .common-info_contact {
    display: flex;
    margin: 0 auto;
}
.common-info .common-btn {
    width: 150px;
    height: 34px;
    font-size: 1.3rem;
}
.level1 {
    padding-bottom: 2%;
}
.level1 li {
    padding: 0 2% !important;
}
.level1 li .drawer-dropdown-menu-item::before {
    content: '';
    display: inline-block;
    width: 12px;
    height: 1px;
    margin: 0 8px 0;
    border-bottom: 1px solid;
    vertical-align: 5px;
}

/*-----------------------------------------------------------------------

    key

-----------------------------------------------------------------------*/
.key {
    align-items: center;
    justify-content: center;
    background: url(../images/top/main_vis01.jpg) no-repeat center / cover;
    position: relative;
}
.key::before {
    content: '';
    width: 100%;
    height: 100%;
    background: url(../images/top/main_vis.jpg) no-repeat center / cover;
    position: absolute;
    z-index: -1;
}
.key::after {
    content: '';
    width: 100%;
    height: 10px;
    background: url(../images/common/key/deco01.jpg) no-repeat center / auto 100%;
    position: absolute;
    bottom: 0; left: 0; right: 0;
    z-index: 10;
}
.key {
    width: 100%;
    height: 200px;
    position: relative;
}
/* ▼page */
#top .key {
    height: 320px;
}
/* ▲page */
.carousel-cell {
    align-items: center;
    justify-content: flex-start;
}
.key_vis {
    width: 100%;
    height: 100%;
    margin: 0 0 0 auto;
    background: url(../images/top/main_vis01.jpg) no-repeat center / cover;
}
.key_ttl {
    display: flex;
    align-items: center;
    justify-content: center;
    width: auto;
    position: absolute;
    z-index: 10;
}
#top .key_ttl img {
    width: 240px;
}
body:not(#top) .key_ttl img {
    height: 70px;
}
.key_ttl-sub {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    font-size: 1.9rem;
    text-align: center;
    letter-spacing: 0em;
    position: absolute;
    left: 20px;
    z-index: 10;
}
.key_ttl-sub img {
    height: 26px;
}
.key_ttl-sub span {
    width: 270px;
    text-align: center;
}
.key_ttl-sub::before {
    content: '';
    width: 270px;
    height: 92.666667px;
    background: url(../images/common/catch/deco01.png) no-repeat center / contain;
    position: absolute;
    left: 0;
    z-index: -1;
    opacity: 0.95;
}


/*-----------------------------------------------------------------------

    footer

-----------------------------------------------------------------------*/
.footer_wrap {
    align-items: center;
    padding: 40px 0 30px;
}
.footer-main {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    width: 100%;
}
.footer-main .footer-ttl {
    width: 200px;
    margin: 0 auto 20px;
}
.footer-detail {
    margin: 20px 0 0;
}
.footer-detail .common-info {
    justify-content: flex-end;
}
.footer-detail .footer-info_adr {
    margin: 0 0 20px;
    text-align: center;
}
.footer-detail .common-info_open {
    margin: 0 0 20px;
    text-align: center;
    line-height: 1.5;
}
.footer-detail .common-info_open span {
    display: block;
    width: 300px;
    margin: 0 auto 8px;
}
.footer-detail .common-info_guide {
    align-items: center;
    justify-content: center;
}
.footer-detail .common-info_guide li:not(:last-child) {
    margin-right: 20px;
}
.footer-detail .common-info_guide .common-btn.css-type {
    width: 225px;
    height: 34px;
    font-size: 1.3rem;
}
/* footer-nav */
.footer-nav {
    padding: 40px 0;
    background-image: repeating-linear-gradient(135deg, #effce3, #effce3 8px, #fff 8px, #fff 14px);
}
.footer-nav .flex {
    justify-content: center;
    line-height: 1;
}
.footer-nav .flex:nth-child(n+2) {
    margin-top: 20px;
}
.footer-nav .flex li {
    display: flex;
    align-items: center;
}
.footer-nav .flex li:nth-child(n+2)::before {
    content: '';
    display: inline-block;
    width: 10px;
    height: 10px;
    margin: 0 11px;
    background-color: var(--main-color);
    border-radius: 50%;
}

/* ▼copyright */
.copyright {
    padding: 15px 0;
    color: #fff;
    background-color: var(--main-color);
    font-size: 1.2rem;
    text-align: center;
}


/*-----------------------------------------------------------------------

    main

-----------------------------------------------------------------------*/
/*
    page-top
--------------------*/
/* ▼topWorrie */
.topWorrie {
    width: calc(100% - 40px);
    margin: 50px auto 0;
    border-radius: 20px;
    background-color: var(--main-color);
}
.topWorrie-ttl {
    width: calc(100% + 40px);
    margin: 0 -20px 30px;
    font-size: clamp(1.8rem,4.8vw,2rem);
    text-align: center;
    position: relative;
    text-shadow: 0 0 1px #fff, 0 0 1px #fff, 0 0 1px #fff, 0 0 1px #fff, 0 0 1px #fff;
    z-index: 20;
}
.topWorrie-ttl span {
    color: #fff;
    border-bottom: 2px dashed;
    text-shadow: none;
    filter: drop-shadow(0 0 3px var(--sub-color));
}
.topWorrie-list {
    padding-top: 10px;
    position: relative;
    z-index: 10;
}
.topWorrie-list::before {
    content: '';
    width: 125px;
    height: 170px;
    margin: auto;
    background: url(../images/top/worrie_illust01.png) no-repeat top / 100% auto;
    position: absolute;
    left: 0; right: 0; top: -130px;
    z-index: -1;
    opacity: 1;
}
.topWorrie-list li {
    display: flex;
    align-items: center;
    width: 100%;
    padding: 10px 20px;
    background-color: #fff;
    border-radius: 15px;
    font-size: 1.5rem;
    line-height: 1.3;
    letter-spacing: 0.05em;
}
.topWorrie-list li:not(:last-child) {
    margin-bottom: 10px;
}
.topWorrie-list li::before {
    content: '';
    width: 24px;
    height: 24px;
    flex: 0 0 auto;
    margin: 0 15px 0 0;
    background: url(../images/common/check01.png) no-repeat center / contain;
}
.topWorrie-list li span {
    background: linear-gradient(rgba(41, 173, 56, .2),rgba(41, 173, 56, .2)) no-repeat center bottom 2px / 100% 10px;
}
/* ▼topAbout */
.topAbout-ttl {
    margin: 0 0 70px;
    padding: 19px 0 0;
    height: 90px;
    font-size: 2rem;
    text-align: center;
    background: url(../images/top/about_ttl_bg.png) no-repeat center / contain;
    position: relative;
}
.topAbout-ttl::before {
    content: '';
    width: 114.666667px;
    height: 78px;
    margin: auto;
    background: url(../images/top/about_illust01.png) no-repeat center / contain;
    position: absolute;
    top: 60px; left: 0px;
    z-index: -1;
}
.topAbout-ttl span {
    display: block;
    color: var(--main-color);
    font-size: 112.5%;
}
.topAbout-greeting {
    flex-direction: row-reverse;
    align-items: center;
}
.topAbout-greeting_img {
    position: relative;
}
.topAbout-greeting_img::before {
    content: '';
    width: 61.5px;
    height: 117.5px;
    background: url(../images/top/about_illust02.png) no-repeat center / contain;
    position: absolute;
    bottom: calc(100% - 8px); right: 10px;
    z-index: 10;
}
.topAbout-greeting_cnt {
    width: 100%;
    margin: 25px 0 0;
    line-height: 2.2;
}
/* ▼topStrength */
.topStrength {
    padding-top: 0;
}
.topStrength-block {
    align-items: flex-end;
    width: calc(100% + 20px);
    margin: 0 -10px;
    padding: 30px 20px 30px;
    border-radius: 20px;
    background-color: #e5f7ff;
    position: relative;
}
.topStrength-block_img {
    width: 120px;
    margin: -60px auto 0;
}
.topStrength-block_cnt {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
}
.topStrength-block_txt {
    width: 100%;
    margin: 20px 0 0;
    line-height: 2;
    order: 2;
}
.topStrength-block_desc {
    width: 100%;
    margin-top: -25px;
    order: 1;
}
.topStrength-block_desc_ttl {
    margin: 0 auto 30px;
    padding: 20px 0;
    color: #fff;
    background-color: var(--main-color);
    font-size: 1.6rem;
    text-align: center;
    border-radius: 15px;
    position: relative;
    letter-spacing: 0.02em;
}
.topStrength-block_desc_ttl .font-img {
    display: none;
    position: absolute;
    right: -30px; bottom: 0;
    transform: translateY(50%) scale(0.7);
    z-index: 20;
}
.topStrength-block_desc_ttl::before {
    content: '';
    width: 42px;
    height: 42px;
    background: url(../images/top/about_block_ttl_illust01.png) no-repeat center / contain;
    position: absolute;
    top: -20px; left: -15px;
    z-index: 10;
}
.topStrength-block_desc_ttl::after {
    content: '';
    width: 0;
    height: 0;
    margin: auto;
    border-style: solid;
    border-width: 12.5px 14px 0 14px;
    border-color: var(--main-color) transparent transparent transparent;
    position: absolute;
    top: 100%; left: 0; right: 0;
}
.topStrength-block_desc_list {
    width: 315px;
    margin: 0 auto 0;
}
.topStrength-block_desc_list li {
    width: 49%;
    color: #fff;
    background-color: #ff667f;
    border-radius: 15px;
    font-size: 2.2rem;
    line-height: 1;
    position: relative;
    transition: all .3s;
    box-shadow: 0 0 0 0px var(--main-color);
}
.topStrength-block_desc_list li:hover {
    box-shadow: 0 0 0 4px var(--main-color);
}
.topStrength-block_desc_list li a {
    padding: 16px 25px 18px;
    border-radius: 15px;
}
.topStrength-block_desc_list li a::before {
    content: '';
    display: inline-block;
    width: 38px;
    height: 38px;
    margin: auto;
    background: url(../images/top/about_block_maru01.png) no-repeat center / contain;
    position: absolute;
    top: 0; bottom: 0; left: 13px;
    pointer-events: none;
}
.topStrength-block_desc_list li::after {
    content: '';
    width: 66.666667px;
    height: 76px;
    background: url(../images/top/about_block_yes01.png) no-repeat bottom / contain;
    position: absolute;
    bottom: 0; right: 15px;
    z-index: 10;
    pointer-events: none;
}
.topStrength-block_desc_list li:nth-child(2) {
    background-color: #004ba8;
}
.topStrength-block_desc_list li:nth-child(2) a::before {
    background-image: url(../images/top/about_block_batu01.png);
}
.topStrength-block_desc_list li:nth-child(2)::after {
    background-image: url(../images/top/about_block_no01.png);
}
.topStrength-block:not(:last-child) {
    margin-bottom: 40px;
}
.topStrength-block:nth-of-type(1) .topStrength-block_img {
    width: 130px;
}
.topStrength-block:nth-of-type(even) {
    flex-direction: row-reverse;
}
.topStrength-block:nth-of-type(even) .topStrength-block_desc_list li::after {
    background-image: url(../images/top/about_block_yes02.png);
}
.topStrength-block:nth-of-type(even) .topStrength-block_desc_list li:nth-child(2)::after {
    background-image: url(../images/top/about_block_no02.png);
}
/* ▼topStory */
.topStory {
    width: calc(100% - 40px);
    margin: 0 auto 50px;
    padding: 40px 0;
    border-radius: 20px;
    background-color: var(--main-color);
}
.topStory_wrap {
    position: relative;
}
.topStory-ttl .font-img img {
    height: 26px;
}
.topStory-cnt {
    width: 100%;
}
.topStory-cnt .story_post time,
.topStory-cnt .story_post .story_post-txt {
    color: #fff;
}
.topStory-cnt .story_post .story_post-tag {
    color: var(--catch-color);
    background-color: #fff;
}
.topStory-btn {
    margin-top: 30px;
}

/*
    page-about
--------------------*/
/* ▼aboutStrength */
.aboutStrength .common-ttl .font-img img {
    height: 40px;
}
.aboutStrength-block {
    flex-direction: row-reverse;
}
.aboutStrength-block_cnt {
    width: 100%;
    margin: 30px 0 0;
}
.aboutStrength-block_cnt-ttl {
    margin: 0 0 20px;
    padding: 14px 20px 14px 50px;
    color: #fff;
    background-color: var(--main-color);
    border-radius: 15px;
    font-size: 1.7rem;
    position: relative;
}
.aboutStrength-block_cnt-ttl::before {
    content: '';
    width: 60px;
    height: 60px;
    background: url(../images/about/strength_num01.png) no-repeat center / contain;
    position: absolute;
    top: -20px; left: -20px;
}
.aboutStrength-block_cnt-txt {
    line-height: 2.1875;
}
.aboutStrength-block:not(:last-child) {
    margin-bottom: 40px;
}
.aboutStrength-block:nth-of-type(2) .aboutStrength-block_cnt-ttl::before {
    background-image: url(../images/about/strength_num02.png);
}
.aboutStrength-block:nth-of-type(3) .aboutStrength-block_cnt-ttl::before {
    background-image: url(../images/about/strength_num03.png);
}
.aboutStrength-block:nth-of-type(4) .aboutStrength-block_cnt-ttl::before {
    background-image: url(../images/about/strength_num04.png);
}
.aboutStrength-block:nth-of-type(5) .aboutStrength-block_cnt-ttl::before {
    background-image: url(../images/about/strength_num05.png);
}

/*
    pagebeginner
--------------------*/
/* ▼beginnerMenu */
.beginnerMenu .common-ttl .font-img img {
    height: 50px;
}
.beginnerMenu .common-ttl::before {
    content: '';
    width: 76.25px;
    height: 58.75px;
    background: url(../images/beginner/menu_illust01.png) no-repeat center / contain;
    position: absolute;
    top: 25px; left: calc(50% - 170px);
}
.beginnerMenu-txt {
    margin: 0 0 40px;
    line-height: 2;
    position: relative;
}
.beginnerMenu-txt::before {
    content: '';
    width: 89px;
    height: 100px;
    background: url(../images/beginner/menu_illust02.png) no-repeat center / contain;
    position: absolute;
    bottom: -80px; right: 10px;
}
.beginnerMenu-txt p::after {
    content: '';
    display: inline-block;
    width: 100px;
    height: 1px;
}
.beginnerMenu-block {
    width: 45%;
    position: relative;
}
.beginnerMenu-block:nth-child(odd)::before {
    content: '';
    display: block;
    width: 1px;
    height: 95%;
    margin: auto;
    border-right: 1px dotted;
    position: absolute;
    top: 0; bottom: 0; left: calc(110% + 0px);
}
.beginnerMenu-block:not(:nth-last-child(-n+2)) {
    margin-bottom: 50px;
}
.beginnerMenu-block:not(:nth-last-child(-n+2))::after {
    content: '';
    width: 100%;
    height: 1px;
    border-bottom: 1px dotted;
    position: absolute;
    top: calc(100% + 25px);
}
.beginnerMenu-block_ttl {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 60px;
    margin: 0 0 25px;
    color: #fff;
    background-color: var(--main-color);
    border-radius: 15px;
    font-size: 1.7rem;
    line-height: 1.2;
    text-align: center;
    position: relative;
}
.beginnerMenu-block_ttl br {
    display: block;
}
.beginnerMenu-block_ttl::after {
    content: '';
    width: 0;
    height: 0;
    margin: auto;
    border-style: solid;
    border-width: 12px 14px 0 14px;
    border-color: var(--main-color) transparent transparent transparent;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
}
.beginnerMenu-block_list li {
    display: flex;
    align-items: center;
    line-height: 1.5;
}
.beginnerMenu-block_list li:not(:last-child) {
    margin-bottom: 9px;
}
.beginnerMenu-block_list li::before {
    content: '';
    width: 10px;
    height: 10px;
    margin: 0 0.3em 0 0;
    border-radius: 50%;
    background-color: var(--catch-color);
}
.beginnerMenu-block_price {
    margin: 22px 0 0;
    padding: 15px 0;
    background-color: #f0f0f0;
    border-radius: 15px;
    line-height: 1;
    color: var(--sub-color);
    font-size: 1.4rem;
    font-weight: bold;
    text-align: center;
}
.beginnerMenu-block_price span {
    font-size: 115%;
}
.beginnerMenu-block:nth-of-type(2) .beginnerMenu-block_ttl {
    background-color: #0098e2;
}
.beginnerMenu-block:nth-of-type(2) .beginnerMenu-block_ttl::after {
    border-top-color: #0098e2;
}
.beginnerMenu-block:nth-of-type(3) .beginnerMenu-block_ttl {
    background-color: #0072c8;
}
.beginnerMenu-block:nth-of-type(3) .beginnerMenu-block_ttl::after {
    border-top-color: #0072c8;
}
.beginnerMenu-block:nth-of-type(4) .beginnerMenu-block_ttl {
    background-color: var(--sub-color);
}
.beginnerMenu-block:nth-of-type(4) .beginnerMenu-block_ttl::after {
    border-top-color: var(--sub-color);
}
/* ▼beginnerScene */
.beginnerScene {
    margin-bottom: 50px;
    padding: 50px 0;
    border-radius: 30px;
    background-color: #e5f7ff;
}
.beginnerScene .common-lead {
    font-size: 1.8rem;
}
.beginnerScene-list li {
    width: 49%;
}
.beginnerScene-list li:nth-child(n+3) {
    margin-top: 6%;
}
.beginnerScene-list_capt {
    width: 100%;
    margin: 10px 0 0;
    padding: 13px 0;
    color: #fff;
    background-color: var(--sub-color);
    text-align: center;
    font-size: 1.4rem;
    font-weight: bold;
    border-radius: 10px;
    line-height: 1;
}

/*
    page-voice
--------------------*/
/* ▼beginnerNav */
.beginnerNav {
    margin-top: 50px;
}
.beginnerNav_wrap {
    padding: 30px 20px;
    border-radius: 20px;
    background-image: repeating-linear-gradient(135deg, #e5f7ff, #e5f7ff 12px, #fff 12px, #fff 24px);
}
.beginnerNav ul.flex {
    display: block;
}
.beginnerNav ul.flex li:not(:last-child) {
    margin-bottom: 15px;
}
.beginnerNav .common-btn {
    width: 260px;
    height: 50px;
    font-size: 1.6rem;
}
/* ▼voiceMain */
.voiceMain .common-ttl {
    margin-bottom: 0;
}
.voiceMain .common-ttl .font-img img {
    height: 26px;
}
.voiceMain_wrap {
    width: 100%;
}
.voiceMain-block {
    width: 100%;
    padding: 30px 20px;
    border-radius: 20px;
}
.voiceMain-block:nth-of-type(even) {
    background-color: #e5f7ff;
}
.voiceMain-block_img {
    width: 100%;
}
.voiceMain-block_img .c_ofi {
    padding-top: 82.6087%;
}
.voiceMain-block_cnt {
    width: 100%;
    margin: 25px 0 0;
}
.voiceMain-block_cnt .common-lead {
    margin: 0 0 15px;
    padding: 14px 20px;
    text-align: left;   
    font-size: 1.8rem;
}
.voiceMain-block_cnt-table {
    width: 100%;
    margin: 0 0 15px;
}
.voiceMain-block_cnt-table tr {
    display: flex;
}
.voiceMain-block_cnt-table tr:not(:last-child) {
    margin-bottom: 15px;
}
.voiceMain-block_cnt-table th {
    width: 130px;
    padding: 6px 20px 6px 20px;
    border-radius: 10px;
    color: #fff;
    background-color: var(--sub-color);
    font-weight: bold;
    text-align: left;
}
.voiceMain-block_cnt-table td {
    flex: 1;
    padding: 6px 20px;
    word-break: break-all;
}
.voiceMain-block_cnt-desc {
    width: 100%;
}
.voiceMain-block_cnt-desc:not(:last-child) {
    margin-bottom: 30px;
}
.voiceMain-block_cnt-desc_ttl {
    margin: 0 0 10px;
    padding: 10px 20px;
    border-radius: 10px;
    color: #fff;
    background-color: var(--sub-color);
    font-size: 1.6rem;
}
.voiceMain-block_cnt-desc_txt {
    line-height: 2.1875;
    letter-spacing: 0.03em;
}
.voiceMain-block_cnt-desc_lead {
    margin: 20px 0 20px;
    font-weight: bold;
    color: var(--main-color);
    font-size: 1.7rem;
    line-height: 1.75;
}

















































/*
    sectionBanner
--------------------*/
/* ▼sectionBanner */
.sectionBanner {
    padding: 40px 0;
    background: url(../images/top/contact_bg.jpg) no-repeat center right 30% / cover;
}
.sectionBanner-ttl {
    position: relative;
    filter: drop-shadow(0 0 3px #d1edff) drop-shadow(0 0 3px #d1edff);
}
.sectionBanner-ttl br {
    display: block;
}
.sectionBanner-ttl .font-img img {
    height: 40px;
}
.sectionBanner-ttl::before {
    content: '';
    width: 83.5px;
    height: 92.5px;
    margin: auto;
    background: url(../images/top/contact_illust01.png) no-repeat center / contain;
    position: absolute;
    left: calc(50% - 150px); top: 35px;
}
.sectionBanner-info {
    align-items: center;
    justify-content: center;
}
.sectionBanner-info li {
    margin: 5px;
}
.sectionBanner-info li img {
    height: 40px;
}


/*
    page-company
--------------------*/
/* ▼companyGreeting */
.companyGreeting {
    padding-bottom: 0;
}
.companyGreeting .common-ttl .font-img img {
    height: 40px;
}
.companyGreeting-block_img {
    width: 220px;
    margin: 0 auto;
}
.companyGreeting-block_cnt {
    width: 100%;
    margin: 30px 0 0;
}
.companyGreeting-block_cnt-ttl {
    font-size: 1.7rem;
}
/* ▼companyHistory */
.companyHistory {
    background-color: rgba(255, 153, 0, .1);
}
.companyHistory_wrap {
    padding: 30px 20px;
    border: 5px solid;
    border-image: repeating-linear-gradient(to right, #ffe3b7, #ffe3b7 5px, #ffe6bf 5px, #ffe6bf 10px) 10;
    background-color: #fff;
}
.companyHistory .common-table tr {
    flex-wrap: wrap;
}
.companyHistory .common-table th {
    width: 130px;
    font-weight: bold;
}
.companyHistory .common-table td {
    flex: auto;
    width: 100%;
}



/* ▼companyInfo */
.companyInfo {
}
.companyInfo .common-ttl .font-img img {
    height: 37px;
}
.companyInfo-block {
}
.companyInfo-list {
    margin: 40px 0 0;
}
.companyInfo-list li {
    width: 100%;
}
.companyInfo-list li img {
    width: 100%;
}
.companyInfo-list li:nth-child(n+2) {
    margin-top: 15px;
}
.companyInfo-access {
    margin: 30px 0 0;
}
.companyInfo-access_ttl {
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 0 15px;
    font-size: 1.8rem;
}
.companyInfo-access_ttl::before {
    content: '';
    width: 14px;
    height: 19px;
    margin: 0 8px 0 0;
    background: url(../images/common/ico_access.png) no-repeat center / contain;
}
.companyInfo-map {
    width: 100%;
    height: 220px;
}
/* ▼companyInfo-route */
.companyInfo-route {
    margin-top: 40px;
}
.companyInfo-route_txt {
}
.companyInfo-route_txt span {
    display: block;
    font-weight: bold;
    font-size: 1.6rem;
    text-align: center;
}
.companyInfo-route_ttl {
    margin: 50px 0 30px;
    padding: 10px 0;
    background-color: rgba(255, 153, 0, .3);
    border-radius: 3px;
    font-size: 1.8rem;
    font-weight: bold;
    text-align: center;
    letter-spacing: 0.12em;
    line-height: 1;
}
.companyInfo-route_list li {
    width: 100%;
    max-width: 300px;
    margin: 0 auto;
}
.companyInfo-route_list li:nth-child(n+2) {
    margin-top: 30px;
}
.companyInfo-route_list-capt {
    display: flex;
    margin: 12px 0 0;
    font-weight: 500;
    line-height: 1.75;
}
.companyInfo-route_list-capt::before {
    content: "①";
    display: inline-block;
    margin: 0 3px 0 0;
    color: var(--main-color);
}
.companyInfo-route_list li:nth-child(2) .companyInfo-route_list-capt::before {
    content: "②";
}
.companyInfo-route_list li:nth-child(3) .companyInfo-route_list-capt::before {
    content: "③";
}
.companyInfo-route_list li:nth-child(4) .companyInfo-route_list-capt::before {
    content: "④";
}
.companyInfo-route_list li:nth-child(5) .companyInfo-route_list-capt::before {
    content: "⑤";
}
.companyInfo-route_list li:nth-child(6) .companyInfo-route_list-capt::before {
    content: "⑥";
}




/* ▼story */
.story_cnt {
    width: 100%;
    margin: 0 auto;
}
.story_post {
    transition: all .1s;
}
.story_post:not(:last-child) {
    margin-bottom: 15px;
}
.story_post a.flex {
    align-items: center;
    justify-content: flex-start;
    padding-bottom: 15px;
    border-bottom: 1px solid var(--main-color);
    color: var(--main-color);
    font-size: 1.6rem;
    line-height: 1;
    letter-spacing: 0;
    position: relative;
    font-weight: 500;
}
/* .story_post a.flex::after {
    content: '';
    width: 8px;
    height: 8px;
    margin: auto;
    border-top: 2px solid;
    border-right: 2px solid;
    position: absolute;
    top: 0; bottom: 0; right: 28px;
    transform: rotate(45deg);
    transition: all .3s;
} */
.story_post-cnt {
    width: calc(100% - 138px);
}
.story_post time {
    display: inline-block;
    margin: 0 15px 0 0;
    padding: 4px 0 6px;
    color: var(--catch-color);
    font-weight: bold;
    text-align: center;
}
.story_post .story_post-tag {
    display: inline-block;
    margin: 5px 10px 5px 0;
    padding: 4px 5px;
    color: #fff;
    background-color: var(--sub-color);
    font-size: 1.2rem;
    font-weight: bold;
    text-align: center;
}
.story_post .story_post-txt {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    display: block;
    width: 100%;
    margin: 10px 0 0;
    color: var(--font-color);
}

/*==========================================
一覧ぺージ用カテゴリ(セレクトボックス)
===========================================*/
.category-select {
    overflow: hidden;
    width: 55%;
    margin-left: auto;
    text-align: center;
    margin-bottom: 5%;
    position: relative;
    border-radius: 2px;
    border: 2px solid var(--main-color);
    background: #fff;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
  }
  .category-select:before {
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    /* Safari用 */
    transform: translateY(-50%);
    z-index: 10;
    right: .8em;
    width: 0;
    height: 0;
    padding: 0;
    content: '';
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-top: 6px solid var(--main-color);
    pointer-events: none;
  }
  .category-select select {
    width: 100%;
    padding-right: 1em;
    cursor: pointer;
    text-indent: .01px;
    text-overflow: ellipsis;
    border: none;
    outline: none;
    background: transparent;
    background-image: none;
    -webkit-box-shadow: none;
    box-shadow: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    padding: 6px 38px 6px 8px;
    color: #4c372c;
    font-family: "Noto Sans JP", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
  }
  .category-select select::-ms-expand {
    display: none;
  }
  

/*
    page-contact
--------------------*/
/* ▼contactGreeting */
.contactGreeting-lead {
    margin: 0 0 30px;
    padding: 25px 20px;
    background-color: rgba(255, 153, 0, .1);
}
.contactGreeting .common-info {
    width: 100%;
    margin: 0 auto 50px;
}
.contactGreeting .common-info_open {
    margin-top: 20px;
}
.contactGreeting .common-info_telSub {
    width: 270px;
    margin: 0 auto 10px;
    font-size: 1.6rem;
}
.contactGreeting .common-info_open li {
    margin: 5px;
}

.input_big {
    width: 100%;
}
.input_mid {
    width: 70%;
}
.input_min {
    width: 28%;
    max-width: 85px;
}
.contact-form-table {
    color: var(--font-color);
    font-size: 14px;
    line-height: 2;
    letter-spacing: 0;
}
.contact-form-table td,
.contact-form-table th{
    vertical-align: middle;
    font-weight: 500;
}
.contact-form-table th {
    font-weight: bold;
    text-align: left;
}
.contact-form-table td a {
    display: inline;
    text-decoration: underline;
}
/* ▼button */
.contact_submits button,
.contact_submits input[type='button'],
.contact_submits input[type='submit'] {
    margin: 7px;
    padding: 1em 2em;
    font-size: 16px;
    border: none;
    -webkit-appearance: none;
    transition: all 0.4s ease;
    color: #fff;
    background-color: var(--main-color);
}
.contact-form-table td div:not(:last-child) {
    margin: 0 0 5px;
}
.contact_submits.flex {
    display: flex;
    align-items: center;
    justify-content: center;
}
.contact-privacy {
    width: 100%;
    height: 200px;
    margin: 0 auto 30px;
    border: 1px solid var(--main-color);
}
.contact-privacy iframe {
    width: 100%;
    height: 100%;
}
.contact-main .top-trial {
    margin: 0 0 60px;
    padding: 60px 0 60px;
}
.contact-form-table,
.contact-form-table tbody,
.contact-form-table tr,
.contact-form-table th,
.contact-form-table td {
    width: auto;
    display: block;
}
.contact-form-table tr {
    margin: 0 0 15px;
    border: 1px solid var(--main-color);
}
.contact-form-table th {
    padding: 0 0 0 20px;
    line-height: 40px;
    color: #fff;
    background-color: var(--main-color);
}
.contact-form-table td {
    padding: 15px 15px;
    background-color: #fff;
}
.contact-form-table .input_table tr:last-child {
    text-align: center;
}
.required-mark {
    float: none;
    margin: 0 0 0 15px;
    padding: 2px 7px 3px;
    vertical-align: 2px;
}
.contact-form-table input[type='submit']:not(:last-child) {
    margin-bottom: 20px;
}
.contact_submits {
    font-size: 14px;
}
.contact-privacy {
    height: 200px;
}
