@charset "UTF-8";
/* CSS Document */

/*------------------------------------------------------

	common css

------------------------------------------------------*/
*,
*:before,
*:after {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box;
}

html {
    width: 100%;
    overflow-y: scroll;
    overflow-x: auto;
    font-size: 10px;
}

body {
    color: #38251a;
    font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", メイリオ, Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    word-break: break-all;
    line-height: 1.5;
    background-color: #fff;
    overflow: hidden;
}

ul {
    list-style: none;
}

ol {
    list-style: decimal;
}

img {
    vertical-align: bottom;
    width: auto;
    max-width: 100%;
    height: auto;
}

section section {
    margin: 0;
}

.pc {
    display: block;
}

.sp {
    display: none;
}

main {
    display: block;
}

@media (min-width: 768px) {
    body {
        min-width: 1140px;
        font-size: 16px;
    }

    a:hover {
        text-decoration: underline;
    }

    /*figure { margin-bottom: 60px; }*/
    a[href^="tel:"] {
        pointer-events: none;
        text-decoration: none;
        color: inherit;
    }
}

@media (max-width: 767px) {
    body {
        font-size: 14px;
    }

    section {
        margin-bottom: 70px;
    }

    .pc {
        display: none;
    }

    .sp {
        display: block;
    }

    /*figure { margin-bottom: 15px; }*/
}


/*------------------------------------------------------

		col

------------------------------------------------------*/
.colWrap {
    display: flex;
    display: -webkit-flex;
    flex-direction: row;
    -webkit-flex-direction: row;
    flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    justify-content: space-between;
    -webkit-justify-content: space-between;
    align-items: stretch;
    -webkit-align-items: stretch;
    align-content: stretch;
    -webkit-align-content: stretch;
}


/*------------------------------------------------------

		frame

------------------------------------------------------*/
.contents {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    position: relative;
}

.inner-cont {
    max-width: 910px;
    margin-left: auto;
    margin-right: auto;
}

@media (min-width: 768px) {
    .contents {
        max-width: 1100px;
    }
}

@media screen and (min-width:768px) and (max-width:1100px) {
    .contents {
        width: -webkit-calc(100% - 40px);
        width: calc(100% - 40px);
    }
}

@media (max-width: 767px) {
    .contents {
        margin-left: 15px;
        margin-right: 15px;
        width: auto;
    }
}


/*------------------------------------------------------

    pageTop

------------------------------------------------------*/
#page-top {
    position: fixed;
    font-size: 1.4rem;
    z-index: 999;
}

#page-top a {
    background: rgba(56, 37, 26, 0.80);
    text-decoration: none;
    color: #fff;
    padding: 10px 0 9px;
    text-align: center;
    display: block;
    border-radius: 5px;
}

@media (min-width: 768px) {
    #page-top {
        bottom: 20px;
        right: 20px;
    }

    #page-top a {
        width: 60px;
    }

    #page-top a:hover {
        text-decoration: none;
        background: #999;
    }
}

@media (max-width: 767px) {
    #page-top {
        bottom: 55px;
        right: 10px;
    }

    #page-top a {
        width: 50px;
    }
}


/*------------------------------------------------------

		header

------------------------------------------------------*/
header {
    position: relative;
}

header :hover {
    transition: 0.3s;
}

header #pcHeader {
    position: relative;
}

header .headLogo {
    width: 325px;
    position: absolute;
    top: 8px;
    left: 50px;
    transition: 0.3s;
}

header .headLogo:hover {
    opacity: 0.8;
}

header .headLogo img {
    width: 100%;
}

header .headInfo {
    height: 70px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
}

header .headTel {
    margin-right: 18px;
}

header .headTel a {
    cursor: default;
    color: #38251a;
    text-decoration: none;
    font-size: 3.2rem;
    line-height: 1;
    font-family: 'Barlow Semi Condensed', '游ゴシック Medium', '游ゴシック体', 'Yu Gothic Medium', YuGothic, 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
}

header .headTel p {
    font-size: 1.2rem;
    font-weight: bold;
}

header .globalNav {
    height: 60px;
    position: relative;
}

header .globalNav .mainNav {
    padding-right: 50px;
}

header .mainNav {
    font-size: 1.5rem;
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    position: relative;
}

header .mainNav::after {
    content: '';
    border-right: 1px solid #ccc;
    height: 22px;
    width: 1px;
    position: absolute;
    top: 50%;
    right: 50px;
    margin-top: -12px;
}

header .mainNav>li>a {
    position: relative;
    height: 60px;
    line-height: 60px;
    text-align: center;
    color: #000;
    text-decoration: none;
    display: block;
    transition: 0.3s;
    padding: 0 27px;
}

header .mainNav>li>a:hover {
    color: #f9a534;
}

header .mainNav>li>a::after {
    position: absolute;
    bottom: 15px;
    left: 0;
    right: 0;
    margin: 0 auto;
    content: '';
    width: 70%;
    height: 2px;
    background: linear-gradient(to right, #ee7215, #f9a534);
    ;
    transform: scale(0, 1);
    transform-origin: left;
    transition: transform .3s;
}

header .mainNav>li>a:hover::after {
    transform: scale(1, 1);
}

header .mainNav>li>a:before {
    content: '';
    border-left: 1px solid #ccc;
    height: 22px;
    width: 1px;
    position: absolute;
    top: 50%;
    left: 0;
    margin-top: -12px;
}

/* header .mainNav > li > a:last-child::after { content: ''; border-right: 1px solid #ccc; height: 22px; width: 1px; position: absolute; top: 50%; right: 0; margin-top: -12px; } */
header .mainNav>li:last-child>a {
    padding: 0 35px;
}

header .mainNav>li:last-child>a::after {
    width: 60%;
}

header .subNav {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    font-size: 1.4rem;
    margin-right: 40px;
}

header .subNav li {
    position: relative;
    padding-left: 16px;
}

header .subNav li:not(:first-child) {
    margin-left: 30px;
}

header .subNav li:before {
    content: '';
    position: absolute;
    top: 50%;
    left: 0;
    margin-top: -5px;
    border-top: 2px solid #ee7215;
    border-right: 2px solid #ee7215;
    transform: rotate(45deg);
    width: 9px;
    height: 9px;
}

header .subNav li a {
    text-decoration: none;
    color: #000;
    transition: 0.3s;
}

header .subNav li a:hover {
    text-decoration: underline;
    color: #ee7215;
}

header .btn_soudan {
    background: #38251a;
    font-size: 1.4rem;
    height: 24px;
    margin-right: 12px;
    color: #fff;
    padding: 0 10px;
    font-weight: bold;
    line-height: 24px;
}

header .btn_access {
    color: #fff;
    text-decoration: none;
    background: linear-gradient(to right, #ee7215, #f9a534);
    text-align: center;
    width: 180px;
    height: 100%;
    transition: 0.3s;
}

header .btn_access:hover {
    opacity: 0.8;
}

header .btn_access p {
    position: relative;
    font-weight: bold;
}

header .btn_access p::before {
    content: '';
    background: url(../images/icon_access.svg) no-repeat;
    position: absolute;
    width: 16px;
    height: 23px;
}

header #scrollNav {
    background: #fff;
    position: fixed;
    width: 100%;
    min-width: 1100px;
    z-index: 101;
    top: 0;
    left: 0;
    -moz-transform: translateY(-128px);
    -webkit-transform: translateY(-128px);
    -o-transform: translateY(-128px);
    -ms-transform: translateY(-128px);
    -webkit-transition: all 600ms cubic-bezier(0.165, 0.84, 0.44, 1);
    transition: all 600ms cubic-bezier(0.165, 0.84, 0.44, 1);
}

header #scrollNav.active {
    -moz-transform: translateY(0px);
    -webkit-transform: translateY(0px);
    -o-transform: translateY(0px);
    -ms-transform: translateY(0px);
    box-shadow: 0px 6px 6px -3px rgba(0, 0, 0, 0.3);
}

header #scrollNav .scrollNav_logo {
    width: 214px;
    padding-top: 7px;
}

header #scrollNav>div,
header #scrollNav>nav {
    max-width: 1100px;
    margin: 0 auto;
}

header #scrollNav .scrollNav_info {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

header #scrollNav .scrollNav_right {
    height: 50px;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

header #scrollNav .scrollNav_right .btn_access p {
    line-height: 50px;
}

header #scrollNav .headTel {
    margin-right: 12px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

header #scrollNav .headTel a {
    margin-right: 12px;
}

header #scrollNav .headTel p {
    display: inline-block;
}

header #scrollNav .mainNav a {
    padding: 0 18px;
}

header #scrollNav .mainNav li:last-child a {
    padding: 0 25px;
}

header #scrollNav .subNav {
    margin-right: 0;
}

header #scrollNav .subNav li:not(:first-child) {
    margin-left: 25px;
}

@media (max-width: 1400px) {
    header .headLogo {
        top: auto;
        bottom: 20px;
        left: 20px;
    }

    header .globalNav .mainNav {
        padding-right: 20px;
    }
}

@media (min-width: 768px) {
    header .btn_access {
        line-height: 70px;
    }

    header .btn_access p {
        margin-left: 20px;
    }

    header .btn_access p::before {
        top: 50%;
        left: 0;
        margin-top: -12px;
    }

    header .mainNav>li {
        height: 100%;
    }

    header .mainNavCont {
        display: none;
        position: absolute;
        top: 60px;
        left: 0;
        right: 0;
        background: rgba(255, 255, 255, 0.9);
        margin: 0 auto;
        z-index: 100;
        padding: 40px 0;
    }

    header .mainNavCont .mainNavContTitle {
        font-size: 3.2rem;
        font-family: 'Noto Serif JP', serif;
        width: 245px;
        letter-spacing: 1px;
    }

    header .mainNavCont .mainNavContTitle span {
        color: #ee7215;
        font-weight: bold;
        font-size: 1.6rem;
        display: block;
        font-family: '游ゴシック Medium', '游ゴシック体', 'Yu Gothic Medium', YuGothic, 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
    }

    header .mainNavCont .contents {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
    }

    header .mainNavCont .contents>div {
        width: calc(100% - 245px);
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
    }

    header .mainNavCont ul {
        border-left: 1px solid #f2efeb;
        max-width: 285px;
        width: 100%;
    }

    header .mainNavCont ul:last-of-type {
        border-right: 1px solid #f2efeb;
    }

    header .mainNavCont ul a {
        color: inherit;
        font-weight: bold;
        font-size: 1.8rem;
        text-decoration: none;
        position: relative;
        display: block;
        padding: 8px 20px;
    }

    header .mainNavCont ul a::after {
        content: '';
        position: absolute;
        top: 50%;
        right: 20px;
        margin-top: -5px;
        border-top: 2px solid #ee7215;
        border-right: 2px solid #ee7215;
        transform: rotate(45deg);
        width: 9px;
        height: 9px;
    }

    header .mainNavCont ul a:hover {
        text-decoration: underline;
        color: #ee7215;
    }

    header .mainNav li:nth-of-type(3) .mainNavCont ul:nth-of-type(2) {
        letter-spacing: -0.1em;
    }

    header .mainNav li:last-of-type .mainNavContSubTitle {
        font-size: 2.2rem;
        font-weight: bold;
        position: relative;
        padding-left: 15px;
    }

    header .mainNav li:last-of-type .mainNavContSubTitle::before {
        content: '';
        position: absolute;
        top: 3px;
        left: 0;
        width: 6px;
        height: 28px;
        background: #ee7215;
    }

    header .mainNav li:last-of-type .contents>div {
        display: block;
    }

    header .mainNav li:last-of-type .contents>div>div {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
    }

    header .mainNav li:last-of-type .contents>div>div:first-of-type {
        margin-bottom: 40px;
    }

    header .mainNav li.small a {
        font-size: 1.6rem;
    }
}

@media (max-width: 767px) {
    header #spHeader .spHeader_head {
        height: 54px;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
    }

    header #spHeader .spHeadLogo {
        width: 190px;
        margin: 0 auto;
    }

    header #spHeader .spMenuBtn {
        display: block;
        padding: 10px;
    }

    header #spHeader .spMenuBtn span {
        display: block;
        width: 24px;
        height: 3px;
        background: #38251a;
    }

    header #spHeader .spMenuBtn span:not(:last-child) {
        margin-bottom: 5px;
    }

    header #spHeader .btn_access {
        width: 54px;
        font-size: 1rem;
        padding: 10px 0;
    }

    header #spHeader .btn_access p {
        padding-top: 24px;
    }

    header #spHeader .btn_access p::before {
        top: 0;
        left: 0;
        right: 0;
        margin: 0 auto;
    }

    header #spHeader .spMenu {
        display: none;
    }

    header #spHeader .spMenu>a {
        color: #fff;
        font-size: 2.0rem;
        font-weight: bold;
        text-decoration: none;
        padding: 10px 0 10px 60px;
        position: relative;
    }

    header #spHeader .spMenu>a::after {
        content: '';
        position: absolute;
        top: 50%;
        right: 10px;
        margin-top: -5px;
        border-top: 2px solid #fff;
        border-right: 2px solid #fff;
        transform: rotate(45deg);
        width: 9px;
        height: 9px;
    }

    header #spHeader .spMenu>a:first-of-type {
        display: block;
        background: #ee7215;
    }

    header #spHeader .spMenu>a:last-of-type {
        display: block;
        background: #ee6115;
    }

    header #spHeader .spMenu>a:first-of-type::before {
        content: '';
        background: url(//resource.aichisogo.or.jp/common/images/icon_tel.svg) no-repeat;
        position: absolute;
        top: 50%;
        left: 20px;
        width: 25px;
        height: 27px;
        background-size: 100%;
        margin-top: -13px;
    }

    header #spHeader .spMenu>a:last-of-type::before {
        content: '';
        background: url(//resource.aichisogo.or.jp/common/images/icon_net.svg) no-repeat;
        position: absolute;
        top: 50%;
        left: 19px;
        width: 28px;
        height: 25px;
        background-size: 100%;
        margin-top: -12px;
    }

    header #spHeader .spMenu>a span {
        font-size: 1.5rem;
    }

    header #spHeader .spMenu>ul {
        background: #fff;
        font-size: 2.2rem;
    }

    header #spHeader .spMenu>ul li>ul {
        background: #f2efeb;
        font-size: 1.8rem;
    }

    header #spHeader .spMenu>ul li>ul li>ul {
        background: #ede7e1;
        font-size: 1.8rem;
    }

    header #spHeader .spMenu ul li {
        position: relative;
    }

    header #spHeader .spMenu ul li:not(:last-of-type) {
        border-bottom: 1px solid #fff;
    }

    header #spHeader .spMenu ul li a {
        display: block;
        padding: 11px 10px;
        font-weight: bold;
        text-decoration: none;
        color: inherit;
    }

    header #spHeader .spMenu ul li>ul,
    header #spHeader .spMenu ul li>ul li>ul {
        width: calc(100% + 50px);
    }

    header #spHeader .spMenu ul li.open,
    header #spHeader .spMenu ul li.close {
        padding-right: 50px;
    }

    header #spHeader .spMenu ul li:not(.close):not(.open) a::after {
        content: '';
        position: absolute;
        top: 50%;
        right: 20px;
        margin-top: -5px;
        border-top: 2px solid #ee7215;
        border-right: 2px solid #ee7215;
        transform: rotate(45deg);
        width: 9px;
        height: 9px;
    }

    header #spHeader .spMenu ul li>.btn {
        position: absolute;
        top: 12px;
        right: 13px;
        width: 24px;
        height: 24px;
        border: 1px solid #ee7215;
    }

    header #spHeader .spMenu ul li>.btn span {
        display: block;
        width: 16px;
        height: 2px;
        background: #ee7215;
        position: absolute;
        top: 0;
        right: 0;
        left: 0;
        bottom: 0;
        margin: auto;
        transition: all 0.3s;
    }

    header #spHeader .spMenu ul li.close>.btn span:last-of-type {
        transform: rotate(-90deg);
    }

    header #spHeader .spMenu ul li.open>.btn span:last-of-type {
        transform: rotate(0deg);
    }

}


/*------------------------------------------------------

    quickNav

------------------------------------------------------*/
#quickNav {
    border-top: 1px solid #fff;
    /*border-left: 1px solid #fff; */
    /* border-right: 1px solid #fff; */
    position: fixed;
    width: 100%;
    bottom: 0;
    left: 0;
    z-index: 2;
    background-color: #ee7215;
    border-bottom: none;
    -moz-transform: translateY(45px);
    -webkit-transform: translateY(45px);
    -o-transform: translateY(45px);
    -ms-transform: translateY(45px);
    -webkit-transition: all 600ms cubic-bezier(0.165, 0.84, 0.44, 1);
    transition: all 600ms cubic-bezier(0.165, 0.84, 0.44, 1);
}

#quickNav.active {
    -moz-transform: translateY(0px);
    -webkit-transform: translateY(0px);
    -o-transform: translateY(0px);
    -ms-transform: translateY(0px);
    box-shadow: 0px 6px 6px -3px rgba(0, 0, 0, 0.3);
}

#quickNav>div {
    text-align: center;
    width: 50%;
    position: relative;
}

#quickNav a {
    display: block;
    height: 100%;
    font-size: 1.1rem;
    color: #fff;
    text-decoration: none;
    height: 43px;
    line-height: 43px;
    font-weight: bold;
}

#quickNav a img {
    height: 20px;
    width: auto;
    vertical-align: -7px;
    margin-right: 8px;
}

#quickNav>div:first-child a {}

#quickNav>div:last-child a {}

#quickNav>div:first-child::after {
    content: '';
    position: absolute;
    width: 1px;
    height: 70%;
    background-color: #fff;
    right: 0;
    top: 15%;
}


@media (min-width: 768px) {
    #quickNav {
        display: none;
    }
}

@media (max-width: 767px) {}


/*------------------------------------------------------

		footer

------------------------------------------------------*/
footer {}

footer #footContact {
    background: #f2efeb;
}

footer #footContact .footContact_wrap {
    margin-bottom: 40px;
}

footer #footContact .footContact_wrap p {
    color: #fff;
}

footer #footContact .footContact_wrap>div {
    text-align: center;
}

footer #footContact .footContact_wrap .inner {
    max-width: 380px;
    margin: 0 auto;
}

footer #footContact .footContact_wrap .img {
    margin-bottom: 27px;
}

footer #footContact .footContact_tel {
    background: #ee7215;
}

footer #footContact .footContact_net {
    background: #ee6115;
}

footer #footContact .footContact_title {
    font-weight: bold;
    line-height: 1.2;
    border-top: 1px solid #fff;
    border-bottom: 1px solid #fff;
    font-family: 'Noto Serif JP', "ヒラギノ明朝 ProN W3", "Hiragino font-02 ProN", 游明朝, Yufont-02, HG 明朝E, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

footer #footContact .footContact_info {
    font-size: 1.4rem;
}

footer #footContact .footContact_info span {
    font-weight: bold;
    display: inline-block;
    text-align: left;
    margin-right: 10px;
}

footer #footContact .footContact_info a {
    cursor: default;
    color: #fff;
    text-decoration: none;
    font-family: 'Barlow Semi Condensed', '游ゴシック Medium', '游ゴシック体', 'Yu Gothic Medium', YuGothic, 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
}

footer #footContact .btn_contactNet {
    transition: 0.3s;
    color: #ee6115;
    text-decoration: none;
    background: #fff;
    font-weight: bold;
    position: relative;
    display: block;
    margin: 22px auto 0;
    box-shadow: 0 10px 15px rgba(0, 0, 0, 0.2);
}

footer #footContact .btn_contactNet::after {
    content: '';
    position: absolute;
    top: 50%;
    right: 10px;
    margin-top: -5px;
    width: 10px;
    height: 10px;
    border-top: 2px solid #ee7215;
    border-right: 2px solid #ee7215;
    transform: rotate(45deg);
}

footer #footContact .btn_contactNet:hover {
    background: #fbf5e2;
}

footer #footContact .footContact_link a {
    text-decoration: none;
    padding: 15px 0;
    display: block;
    background: #fff;
    text-align: center;
    transition: 0.3s;
}

footer #footContact .footContact_link a:hover {
    opacity: 0.8;
}

footer #footContact .footContact_link a span {
    font-size: 1.6rem;
    display: block;
}

footer #footContact .footContact_link a>div {
    padding: 12px 0;
}

footer #footContact .footContact_link p {
    position: relative;
    display: inline-block;
    text-align: left;
    color: #38251a;
    font-size: 2.8rem;
    padding-left: 70px;
    font-family: 'Noto Serif JP', "ヒラギノ明朝 ProN W3", "Hiragino font-02 ProN", 游明朝, Yufont-02, HG 明朝E, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

footer #footContact .footContact_link p::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 0;
    margin-top: -19px;
}

footer #footContact .footContact_link a:first-child p::before {
    background: url(../images/icon_list.svg) no-repeat;
    width: 50px;
    height: 44px;
}

footer #footContact .footContact_link a:last-child p::before {
    background: url(../images/icon_mail.svg) no-repeat;
    width: 58px;
    height: 38px;
}

footer #footAddress {
    font-style: normal;
    margin: 0 auto;
}

footer #footAddress p {
    font-weight: bold;
}

footer #footAddress p.office {
    font-size: 2.4rem;
}

footer #footAddress .footAddress_map iframe {
    height: 100%;
    width: 100%;
}

footer #footAddress .footAddress_info .office {
    margin-bottom: 30px;
}

footer #footLink {
    border-top: 5px solid #ee7215;
    background: #f2efeb;
    padding: 45px 0 35px;
}

footer #footLink li {
    margin-bottom: 10px;
    padding-left: 20px;
}

footer #footLink a {
    color: #38251a;
    text-decoration: none;
}

footer #footLink a:hover {
    text-decoration: underline;
}

footer #footLink .inner {
    max-width: 1030px;
    margin: 0 auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

footer #footLink .footLink_head {
    font-weight: bold;
    position: relative;
}

footer #footLink .footLink_head::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 0;
    margin-top: -5px;
    border-top: 2px solid #ee7215;
    border-right: 2px solid #ee7215;
    transform: rotate(45deg);
    width: 10px;
    height: 10px;
}

footer #copy {
    text-align: center;
    font-size: 1.2rem;
    padding: 6px 0;
    border-top: 1px solid #ee7215;
}

footer .linkWrap {}

footer .linkWrap .title {
    position: relative;
}

footer .linkWrap .title span {
    width: 200px;
    height: 32px;
    line-height: 32px;
    background-color: #38251a;
    display: inline-block;
    color: #fff;
    font-weight: bold;
    font-size: 1.8rem;
    padding-left: 12px;
}

footer .linkWrap .title::before {
    content: '';
    position: absolute;
    width: 100%;
    height: 2px;
    background-color: #ddd;
    left: 0;
    z-index: -1;
    top: 16px;
}

footer .linkWrap ul {
    justify-content: flex-start;
    -webkit-justify-content: flex-start;
}

footer .linkWrap ul li {
    border-bottom: 1px solid #ddd;
    position: relative;
}

footer .linkWrap ul li a {
    text-decoration: none;
    color: #38251a;
    text-decoration: none;
    font-weight: bold;
    display: block;
    padding: 0 8px 8px;
}

footer .linkWrap ul li::after {
    content: '';
    position: absolute;
    right: 4px;
    top: -webkit-calc(50% - 8px);
    top: calc(50% - 8px);
    width: 10px;
    height: 10px;
    border-top: 2px solid #38251a;
    border-right: 2px solid #38251a;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    z-index: -1;
}


@media (min-width: 768px) {
    footer #footContact {
        padding: 40px 0 80px;
    }

    footer #footContact>div {
        max-width: 1320px;
        margin: 0 auto;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
    }

    footer #footContact .footContact_wrap>div {
        width: 50%;
        padding: 33px 0 43px;
    }

    footer #footContact .footContact_title {
        padding: 20px 0;
    }

    footer #footContact .footContact_title p:first-child {
        font-size: 3.2rem;
    }

    footer #footContact .footContact_title p:last-child {
        font-size: 3.0rem;
    }

    footer #footContact .footContact_title p span {
        font-size: 3.6rem;
    }

    footer #footContact .footContact_info span {
        font-size: 1.6rem;
    }

    footer #footContact .footContact_info a {
        font-size: 4.8rem;
    }

    footer #footContact .footContact_link a {
        width: 50%;
    }

    footer #footContact .footContact_link a:first-child>div {
        border-right: 1px dotted #ee7215;
    }

    footer #footAddress {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
    }

    footer #footAddress>div {
        width: 50%;
    }

    footer #footAddress p {
        font-size: 1.8rem;
    }

    footer #footAddress .footAddress_info {
        padding: 40px 80px;
        min-height: 480px;
    }

    footer #footAddress .footAddress_info .address {
        margin-bottom: 50px;
    }

    footer #footContact .btn_contactNet {
        font-size: 1.4rem;
        width: 320px;
        height: 70px;
        line-height: 70px;
    }

    footer #footLink {
        margin-bottom: 60px;
    }

    footer .linkWrap {
        margin-bottom: 30px;
        padding-bottom: 0;
    }

    footer .linkWrap .title {
        margin-bottom: 30px;
    }

    footer .linkWrap ul li {
        width: calc(25% - 20px);
        font-size: 1.6rem;
        margin-bottom: 24px;
        display: inline-flex;
        display: -webkit-inline-flex;
        align-items: center;
        -webkit-align-items: center;
    }

    footer .linkWrap ul li a:hover {
        text-decoration: underline;
    }

    footer .linkWrap ul li:not(:nth-child(4n+4)) {
        margin-right: 20px;
    }

    footer #copy {
        margin-top: 80px;
    }

}

@media (max-width: 767px) {
    footer #footContact {
        padding: 20px 15px 50px;
    }

    footer #footContact .footContact_wrap>div {
        padding: 30px 0 35px;
    }

    footer #footContact .footContact_tel {
        margin-bottom: 20px;
    }

    footer #footContact .footContact_tel .img {
        width: 38px;
        margin: 0 auto 20px;
    }

    footer #footContact .footContact_net .img {
        width: 45px;
        margin: 0 auto 20px;
    }

    footer #footContact .footContact_title {
        padding: 15px 0;
    }

    footer #footContact .footContact_title p {
        font-size: 2.4rem;
    }

    footer #footContact .footContact_title p span {
        font-size: 2.8rem;
    }

    footer #footContact .footContact_info span {
        font-size: 1.3rem;
    }

    footer #footContact .footContact_info a {
        font-size: 3.9rem;
    }

    footer #footContact .btn_contactNet {
        font-size: 1.4rem;
        width: 250px;
        height: 55px;
        line-height: 55px;
    }

    footer #footContact .footContact_wrap .inner {
        max-width: 300px;
    }

    footer #footContact .footContact_info p {
        font-size: 1.2rem;
        white-space: nowrap;
    }

    footer #footContact .footContact_link a {
        padding: 18px 0;
    }

    footer #footContact .footContact_link a:first-child {
        border-bottom: 1px solid #ee7215;
    }

    footer #footContact .footContact_link p {
        font-size: 2.4rem;
    }

    footer #footContact .footContact_link a:first-child p {
        padding-left: 60px;
    }

    footer #footAddress p {
        font-size: 1.6rem;
    }

    footer #footAddress .footAddress_map {
        height: 375px;
    }

    footer #footAddress .footAddress_info {
        padding: 30px 15px;
        min-height: 370px;
    }

    footer #footAddress .footAddress_info .img {
        width: 334px;
        margin-bottom: 30px;
    }

    footer #footAddress .footAddress_info .address {
        margin-bottom: 30px;
    }

    footer #copy {
        border-top: 5px solid #ee7215;
        padding: 20px 20px 60px;
    }

    footer .linkWrap {
        margin-bottom: 40px;
        padding-bottom: 0;
    }

    footer .linkWrap .title {
        margin-bottom: 20px;
    }

    footer .linkWrap ul li {
        margin-bottom: 15px;
        width: 100%;
        font-size: 1.5rem;
        /*padding-bottom: 8px;*/
    }

    footer .linkWrap ul li a {
        display: block;
        height: 100%;
    }

}


/*------------------------------------------------------

		kv pageTitle

------------------------------------------------------*/
/* 画像あり */
.kv_img {
    position: relative;
    z-index: 0;
    width: 100%;
    background-image: url(../../honbu/common/images/kv_img.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.kv_img::before {
    content: '';
    background: rgba(0, 0, 0, 0.1);
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
}

.kv_img h1,
.kv_img .kv_text {
    color: #fff;
    letter-spacing: 0.2rem;
    z-index: 2;
}

.kv_img .main {
    display: block;
    font-weight: 700;
    display: inline-block;
    text-align: center;
    font-family: 'Noto Serif JP', "ヒラギノ明朝 ProN W3", "Hiragino font-02 ProN", 游明朝, Yufont-02, HG 明朝E, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    background: #38251a;
    padding: 8px 25px;
    margin-bottom: 15px;
    opacity: 0.95;
}

.kv_img .sub {
    display: block;
    font-weight: 700;
    text-align: center;
    font-family: 'Sorts Mill Goudy', "ヒラギノ明朝 ProN W3", "Hiragino font-02 ProN", 游明朝, Yufont-02, HG 明朝E, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    font-size: 1.7rem;
}

.kv_img .sub span {
    display: inline-block;
    min-width: 60px;
    background: linear-gradient(to right, #f9c73d, #ee7215);
    height: 24px;
    line-height: 24px;
    letter-spacing: normal;
    padding: 1px 10px;
}


@media (min-width: 768px) {
    .kv_img {
        height: 420px;
    }

    .kv_img .main {
        font-size: 3.6rem;
    }
}

@media (max-width: 767px) {
    .kv_img {
        height: 180px;
        margin-bottom: 20px;
    }

    .kv_img .main {
        font-size: 2.4rem;
        padding: 5px 15px;
    }
}


/* 画像なし */
.kv_noimg {
    background: #f2efeb;
    text-align: center;
}

.kv_noimg h1,
.kv_noimg .kv_text {
    font-weight: bold;
    letter-spacing: 0.5rem;
    font-family: 'Noto Serif JP', "ヒラギノ明朝 ProN W3", "Hiragino font-02 ProN", 游明朝, Yufont-02, HG 明朝E, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

@media (min-width: 768px) {
    .kv_noimg {
        padding: 51px 0;
    }

    .kv_noimg h1,
    .kv_noimg .kv_text {
        font-size: 3.8rem;
    }
}

@media (max-width: 767px) {
    .kv_noimg {
        padding: 17px 0;
        margin-bottom: 20px;
    }

    .kv_noimg h1,
    .kv_noimg .kv_text {
        font-size: 2.4rem;
    }
}


/*------------------------------------------------------

		breadcrumb

------------------------------------------------------*/
.breadcrumb-b {
    max-width: 1100px;
    margin: 0 auto;
}

.breadcrumb-b a {
    text-decoration: underline;
    color: #ee7215;
}

.breadcrumb-b ul {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.breadcrumb-b.bottom {
    position: relative;
}

.breadcrumb-b.bottom::after {
    content: '';
    background-image: linear-gradient(to right, rgba(204, 204, 204, 1), rgba(204, 204, 204, 1) 1px, rgba(204, 204, 204, 0) 1px, rgba(204, 204, 204, 0) 4px);
    background-repeat: repeat;
    background-size: 4px 1px;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 1px;
}

@media (min-width: 768px) {
    .breadcrumb-b {
        height: 70px;
        line-height: 70px;
    }

    .breadcrumb-b a:hover {
        text-decoration: none;
    }

    .breadcrumb-b.head {
        margin-bottom: 30px;
    }
}

@media (max-width: 767px) {
    .breadcrumb-b {
        padding: 0 15px;
    }

    .breadcrumb-b ul {
        height: 70px;
        padding-top: 10px;
        padding-bottom: 10px;
    }

    .breadcrumb-b.head {
        display: none;
    }
}


/*------------------------------------------------------

		title

------------------------------------------------------*/
[class^="title-"] a {
    color: inherit;
    text-decoration: none;
}

[class^="title-"] a:hover {
    text-decoration: underline;
}

.title-a {
    font-weight: bold;
    font-family: 'Noto Serif JP', "ヒラギノ明朝 ProN W3", "Hiragino font-02 ProN", 游明朝, Yufont-02, HG 明朝E, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    letter-spacing: 0.2rem;
    border-top: 3px solid #ee7215;
    position: relative;
}

.title-a::before {
    content: '';
    position: absolute;
    left: 0;
    background: #ee7215;
}

.title-a::after {
    content: '';
    background-image: linear-gradient(to right, rgba(204, 204, 204, 1), rgba(204, 204, 204, 1) 1px, rgba(204, 204, 204, 0) 1px, rgba(204, 204, 204, 0) 4px);
    background-repeat: repeat;
    background-size: 4px 1px;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 1px;
}

.title-b {
    font-weight: bold;
    font-family: 'Noto Serif JP', "ヒラギノ明朝 ProN W3", "Hiragino font-02 ProN", 游明朝, Yufont-02, HG 明朝E, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    letter-spacing: 0.1rem;
    position: relative;
}

.title-b::before {
    content: '';
    position: absolute;
    left: 0;
    background: #ee7215;
}

.title-c {
    font-weight: bold;
    padding-bottom: 10px;
    position: relative;
}

.title-c::before {
    content: '';
    background-image: linear-gradient(to right, rgba(56, 37, 26, 1), rgba(56, 37, 26, 1) 1px, rgba(56, 37, 26, 0) 1px, rgba(56, 37, 26, 0) 4px);
    background-repeat: repeat;
    background-size: 4px 1px;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 1px;
}

@media (min-width: 768px) {
    .title-a {
        font-size: 3.0rem;
        padding: 16px 0 16px 20px;
        margin-bottom: 30px;
    }

    .title-a::before {
        width: 8px;
        height: 8px;
        top: 35px;
    }

    .title-b {
        font-size: 2.4rem;
        padding-left: 17px;
        margin-bottom: 20px;
    }

    .title-b::before {
        width: 7px;
        height: calc(100% - 6px);
        top: 4px;
    }

    .title-c {
        font-size: 1.8rem;
        margin-bottom: 15px;
    }
}

@media (max-width: 767px) {
    .title-a {
        font-size: 2.2rem;
        padding: 8px 0 8px 15px;
        margin-bottom: 20px;
    }

    .title-a::before {
        width: 6px;
        height: 6px;
        top: 25px;
    }

    .title-b {
        font-size: 2.0rem;
        padding-left: 10px;
        margin-bottom: 10px;
    }

    .title-b::before {
        width: 5px;
        height: calc(100% - 7px);
        top: 4px;
    }

    .title-c {
        font-size: 1.6rem;
        margin-bottom: 10px;
    }
}


/*------------------------------------------------------

		catchcopy

------------------------------------------------------*/
.catchCopy {
    font-family: 'Noto Serif JP', "ヒラギノ明朝 ProN W3", "Hiragino font-02 ProN", 游明朝, Yufont-02, HG 明朝E, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    font-weight: bold;
    line-height: 2.0;
    letter-spacing: 0.1rem;
}

.catchCopy p {
    background: linear-gradient(transparent 55%, #f2efeb 0%);
    display: inline;
}

@media (min-width: 768px) {
    .catchCopy {
        font-size: 2.4rem;
    }
}

@media (max-width: 767px) {
    .catchCopy {
        font-size: 2.0rem;
    }
}


/*------------------------------------------------------

		list

------------------------------------------------------*/
.list,
.list-num {
    line-height: 2.0;
}

/*
.list a,
.list-num a { color: inherit; text-decoration: none; }*/
.list-num li {
    margin-left: 1.2em;
}

@media (min-width: 768px) {

    .list,
    .list-num {
        font-size: 1.6rem;
    }
}

@media (max-width: 767px) {

    .list,
    .list-num {
        font-size: 1.4rem;
    }
}


/*------------------------------------------------------

		sidebar

------------------------------------------------------*/
.sidebar a {
    color: inherit;
    text-decoration: none;
}

.sidebar a:hover {
    text-decoration: underline;
}

.sidebar .side-head {
    background: #f2efeb;
    position: relative;
    padding: 13px 20px;
    margin-bottom: 10px;
}

.sidebar .side-head::before {
    content: '';
    position: absolute;
    top: 13px;
    left: 10px;
    width: 5px;
    height: calc(100% - 28px);
    background: #38251a;
}

.sidebar ul {
    margin-bottom: 10px;
}

.sidebar ul li {
    position: relative;
}

.sidebar ul li::before {
    content: '';
    position: absolute;
    top: 50%;
    right: 3px;
    margin-top: -5px;
    width: 8px;
    height: 8px;
    border-top: 2px solid #ee7215;
    border-right: 2px solid #ee7215;
    transform: rotate(45deg);
}

.sidebar ul li::after {
    content: '';
    background-image: linear-gradient(to right, rgba(56, 37, 26, 1), rgba(56, 37, 26, 1) 1px, rgba(56, 37, 26, 0) 1px, rgba(56, 37, 26, 0) 4px);
    background-repeat: repeat;
    background-size: 4px 1px;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 1px;
}

.sidebar ul li a {
    display: block;
    padding: 10px;
}

.sidebar .side-archive {
    text-align: right;
}

@media (min-width: 768px) {
    .sidebar .side-wrap {
        margin-bottom: 60px;
    }

}

@media (max-width: 767px) {
    .sidebar .side-wrap:not(:last-of-type) {
        margin-bottom: 30px;
    }

}


/*------------------------------------------------------

		marker

------------------------------------------------------*/
.marker {
    position: relative;
    line-height: 2.0;
}

.marker::before {
    content: '';
    position: absolute;
    left: 0;
}

@media (min-width: 768px) {
    .marker {
        padding-left: 18px;
    }

    .marker::before {
        top: 11px;
        border-left: 11px solid #38251a;
        border-top: 5px solid transparent;
        border-bottom: 5px solid transparent;
    }
}

@media (max-width: 767px) {
    .marker {
        padding-left: 15px;
    }

    .marker::before {
        top: 9px;
        border-left: 10px solid #38251a;
        border-top: 4px solid transparent;
        border-bottom: 4px solid transparent;
    }
}


/*------------------------------------------------------

		text

------------------------------------------------------*/
div.text {
    padding: 0 10px;
}

div.text p,
div.text ul li,
div.text ol li {
    line-height: 2.0;
}

main a,
div.text a {
    color: #0071bc;
}

div.text a:hover {
    text-decoration: none;
}

.accent-a {
    color: #890202;
}

.font-tel {
    font-family: 'Barlow Semi Condensed', sans-serif;
}

@media (min-width: 768px) {
    div.text:not(.answer) {
        margin-bottom: 60px;
    }

    div.text p {
        margin-bottom: 20px;
    }
}

@media (max-width: 767px) {
    div.text {
        margin-bottom: 30px;
    }

    div.text p {}
}



/*------------------------------------------------------

		archive

------------------------------------------------------*/
.archive-list {}

.archive-list dl {}

.archive-list dt {
    font-weight: normal;
    font-family: 'Noto Serif JP', "ヒラギノ明朝 ProN W3", "Hiragino font-02 ProN", 游明朝, Yufont-02, HG 明朝E, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    letter-spacing: 0.2rem;
    margin-bottom: 5px;
    position: relative;
}

.archive-list dt a {
    color: inherit;
    text-decoration: none;
}

.archive-list dt a:hover {
    text-decoration: underline;
}

.archive-list dt::before {
    content: '';
    position: absolute;
    left: 0;
    background: #ee7215;
}

.archive-list dd {
    color: #666;
}

.archive-list dd a {
    color: #666;
    text-decoration: none;
}

.archive-list dd a:hover {
    text-decoration: underline;
}

.archive-list-b dl {
    border-bottom: 1px solid #e0d9ca;
    position: relative;
}

.archive-list-b dl:first-child {
    border-top: 1px solid #e0d9ca;
}

.archive-list-b dl dd a {
    color: inherit;
}

.archive-list-b dl dd a:hover {
    text-decoration: none;
}

.archive-list-b dl dd .title-b>a {
    transition: 0.3s;
}

.archive-list-b dl dd .title-b>a::after {
    content: '';
    position: absolute;
    top: 50%;
    right: 5px;
    border-top: 2px solid #ee7215;
    border-right: 2px solid #ee7215;
    transform: rotate(45deg);
    width: 10px;
    height: 10px;
    margin-top: -5px;
}

.archive-list-b dl dd .title-b>a:hover {
    opacity: 0.7;
}

.archive-list-b .title-b {
    margin-bottom: 0;
}

.archive-list-b .archive-date {
    margin-right: 27px;
    font-family: 'Noto Serif JP', "ヒラギノ明朝 ProN W3", "Hiragino font-02 ProN", 游明朝, Yufont-02, HG 明朝E, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

.archive-list-b .archive-cat {
    color: #444;
    background: #f2efeb;
    display: inline-block;
    padding: 0 11px;
    min-width: 70px;
    text-align: center;
}

.archive-list-b .archive-cat.important {
    background-color: #ed1c24;
    color: #fff;
}

/* pagination */
.pagination {
    margin-top: 100px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.pagination li {
    width: 40px;
    height: 40px;
    margin: 0 5px;
}

.pagination .page-link {
    text-decoration: none;
    color: inherit;
    display: block;
    height: 100%;
    border: 1px solid #38251a;
    line-height: 40px;
    text-align: center;
}

.pagination a.page-link:hover {
    text-decoration: underline;
}

.pagination .page-item.disabled:not(:first-child) .page-link {
    border: none;
}

.pagination .page-item:first-child .page-link,
.pagination .page-item:last-child .page-link {
    font-size: 2.5rem;
}

.pagination .page-item.active .page-link {
    background: #38251a;
    color: #fff;
}


@media (min-width: 768px) {
    .archive-list dl {
        margin-bottom: 28px;
    }

    .archive-list dt {
        font-size: 2.4rem;
        padding-left: 17px;
    }

    .archive-list dt::before {
        width: 7px;
        height: calc(100% - 10px);
        top: 5px;
    }

    .archive-list dd {
        font-size: 1.4rem;
    }

    .archive-list-b dl {
        padding: 30px 0;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
    }

    .archive-list-b dl dd {
        width: 813px;
    }

    .archive-list-b dl dd .text {
        margin: 10px 0 0;
    }

    .archive-list-b .title-b {
        font-size: 1.9rem;
    }

    .archive-list-b .archive-date {
        font-size: 1.8rem;
    }

    .pagination {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

}

@media (max-width: 767px) {
    .archive-list dl {
        margin-bottom: 15px;
    }

    .archive-list dt {
        font-size: 1.8rem;
        padding-left: 10px;
        line-height: 1.4;
    }

    .archive-list dt::before {
        width: 5px;
        height: calc(100% - 2px);
        top: 2px;
    }

    .archive-list dd {
        font-size: 1.2rem;
    }

    .archive-list-b dl {
        padding: 15px 0;
    }

    .archive-list-b dl dt {
        margin-bottom: 10px;
    }

    .archive-list-b dl dd {
        font-size: 1.6rem;
    }

    .archive-list-b dl dd .text {
        margin: 20px 0 0;
        padding: 0;
    }

    .archive-list-b .title-b {
        font-size: 1.9rem;
        padding-right: 10px;
    }

    .archive-list-b a .title-b {
        padding-right: 20px;
    }

    .archive-list-b .archive-date {
        font-size: 1.8rem;
    }

    .archive-list-b .archive-cat {
        font-size: 1.5rem;
    }

    .pagination li {
        margin: 0 5px 5px;
    }

}


/*------------------------------------------------------

		blog / column

------------------------------------------------------*/
.date {
    color: #ee7215;
    text-align: right;
    margin-bottom: 30px;
    line-height: 2.0;
}

.date a {
    color: #ee7215;
    text-decoration: none;
}

.date a:hover {
    text-decoration: underline;
}

.cta {
    width: 100%;
    background: #f2efeb;
    margin-bottom: 50px;
    border-radius: 5px;
}

.cta .inner {
    margin: auto;
    text-align: center;
}

.cta .cta_head {
    background: #ee7215;
    padding: 4px;
    color: #fff;
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
    letter-spacing: 0.2rem;
    border-radius: 5px 5px 0px 0px;
}

.cta .cta_head span {}

.cta .btn_wrap {
    font-family: 'Noto Serif JP', "ヒラギノ明朝 ProN W3", "Hiragino font-02 ProN", 游明朝, Yufont-02, HG 明朝E, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

.cta .top a {
    width: 100%;
    background: rgb(255, 255, 255);
    background: linear-gradient(180deg, rgba(255, 255, 255, 1) 0%, rgba(237, 231, 225, 1) 100%);
    display: block;
    padding: 13px;
    border: 1px solid #e0d5ca;
    border-radius: 5px;
    box-shadow: 0px 5px 0px 0px rgba(194, 176, 151, 1);
    color: #38251a;
    text-decoration: none;
}

.cta .top a span {
    position: relative;
    padding-left: 35px;
}

.cta .top a span:before {
    content: '';
    background-image: url(../images/icon_soudan.svg);
    position: absolute;
    left: -5px;
    top: 3px;
    width: 32px;
    height: 32px;
    background-size: cover;
    display: block;
}

.cta .btn_wrap .top:hover {
    opacity: 0.8;
}

@media (min-width: 768px) {

    /*.l_col-blog { margin-bottom: 150px; }*/
    .l_col-blog>*:first-child {
        width: calc((100% - 245px) - 40px);
    }

    .l_col-blog>*:last-child {
        width: 245px;
    }

    .l_col-blog>* article:not(:last-of-type) {
        margin-bottom: 150px;
    }

    .l_col-blog .date {
        margin-top: -30px;
    }

    .cta .cta_head {
        font-size: 3.2rem;
    }

    .cta .cta_head span {
        font-size: 2.6rem;
    }

    .cta .btn_wrap {
        padding: 20px 20px 25px 20px;
        max-width: 775px;
        margin: auto;
    }

    .cta .top a {
        margin-bottom: 20px;
        font-size: 2.8rem;
    }

    .cta .btn_wrap .bottom {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
    }

    /* .cta .btn_wrap .bottom .bottom_inner { box-shadow: 0 5px #000000; text-shadow: 1px 1px rgba(0,0,0,0.75); text-align: center; display: block; width: 50%; background: linear-gradient(to bottom, #946245, #38251a 50%); font-size: 2.4rem; border-radius: 7px; position: relative; line-height: 1.3; display: -webkit-box; display: -ms-flexbox; -webkit-box-align: center; -ms-flex-align: center; align-items: center;-webkit-box-pack: center; -ms-flex-pack: center; justify-content: center;} */
    .cta .btn_wrap .bottom .bottom_inner {
        text-align: center;
        display: block;
        width: 50%;
        font-size: 2.4rem;
        position: relative;
        line-height: 1.3;
    }

    .cta .btn_wrap .bottom .bottom_inner a {
        color: #fff;
        text-decoration: none;
        padding: 14px 0 15px;
        display: block;
        background: linear-gradient(to bottom, #946245, #38251a 50%);
        width: 100%;
        border-radius: 7px;
        box-shadow: 0 5px #000000;
        text-shadow: 1px 1px rgb(0 0 0 / 75%);
        min-height: 121px;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
    }

    .cta .btn_wrap .bottom .bottom_inner:first-of-type {
        margin-right: 25px;
    }

    .cta .btn_wrap .bottom .bottom_inner:last-of-type {
        transition: 0.3s;
    }

    .cta .btn_wrap .bottom .bottom_inner:last-of-type:hover {
        opacity: 0.8;
        transition: 0.3s;
    }

    .cta .btn_wrap .bottom .bottom_inner .tel {
        font-size: 2.8rem;
        letter-spacing: 0.14rem;
    }

    .cta .btn_wrap .bottom .bottom_inner .time {
        font-size: 1.4rem;
        display: block;
        line-height: 1;
        font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", メイリオ, Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
        margin-top: 10px;
    }

}

@media (max-width: 767px) {
    .l_col-blog>*:last-child {
        width: 100%;
    }

    .l_col-blog .date {
        margin-top: -10px;
    }

    .cta .cta_head {
        font-size: 2.8rem;
    }

    .cta .cta_head span {
        font-size: 2.2rem;
    }

    .cta .btn_wrap {
        padding: 10px 10px 15px 10px;
    }

    .cta .top a {
        margin-bottom: 10px;
        font-size: 2.2rem;
    }

    .cta .btn_wrap .bottom {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
        padding:
    }

    .cta .btn_wrap .bottom .bottom_inner {
        width: calc(50% - 3px);
        text-align: center;
    }

    .cta .btn_wrap .bottom .bottom_inner a {
        color: #fff;
        text-decoration: none;
        display: block;
        background: linear-gradient(to bottom, #946245, #38251a 50%);
        box-shadow: 0 5px #000000;
        padding: 9px 0;
        border-radius: 5px;
        width: 100%;
        min-height: 106px;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
    }

    .cta .btn_wrap .bottom .bottom_inner a span {
        display: block;
        position: relative;
        line-height: 1;
    }

    .cta .btn_wrap .bottom .bottom_inner .time {
        font-size: 1.2rem;
        margin-top: 10px;
    }

}


/*------------------------------------------------------

		btn

------------------------------------------------------*/
.btnWrap_yellow {
    background: #fbf5e2;
    padding: 34px 15px;
    text-align: center;
}

.btn_orange {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    text-decoration: none;
    color: #444;
    background: #fff;
    border: 1px solid #ee7215;
    border-radius: 3px;
    text-align: center;
    font-weight: bold;
    position: relative;
    line-height: 1.35;
    transition: 0.3s;
}

.btn_orange::after {
    content: '';
    position: absolute;
    top: 50%;
    right: 12px;
    margin-top: -5px;
    width: 10px;
    height: 10px;
    border-top: 2px solid #ee7215;
    border-right: 2px solid #ee7215;
    transform: rotate(45deg);
}

.btn_orange:hover {
    text-decoration: none;
    background: #fbf5e2;
}

.btn_brown {
    background: #38251a;
    color: #fff;
    text-decoration: none;
    font-weight: bold;
    text-align: center;
    position: relative;
    display: block;
    border-radius: 3px;
}

.btn_brown::after {
    content: '';
    position: absolute;
    top: 50%;
    right: 10px;
    margin-top: -5px;
    border-top: 2px solid #ee7215;
    border-right: 2px solid #ee7215;
    transform: rotate(45deg);
    width: 10px;
    height: 10px;
}

.btn-b {}

a.btn-a,
.btn-a {
    text-decoration: none;
    font-size: 1.6rem;
    color: #555;
    border: 1px solid #ccc;
    box-shadow: 0px 4px 0px 0px #ee7215;
    border-radius: 6px;
    padding: 12px 30px 12px 12px;
    position: relative;
    display: inline-block;
}

a.btn-a::before,
.btn-a::before {
    content: '';
    position: absolute;
    width: 16px;
    height: 16px;
    -webkit-border-radius: 3px;
    border-radius: 3px;
    background: #ee7215;
    right: 6px;
    top: calc(50% - 8px);
}

a.btn-a::after,
.btn-a::after {
    content: '';
    position: absolute;
    width: 7px;
    height: 7px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    right: 12px;
    top: calc(50% - 4px);
}

div.text a.btn-a,
div.text .btn-a {
    color: #555;
}

div.text a.btn-a:hover,
div.text .btn-a:hover {
    color: #fff;
}

@media (min-width: 768px) {
    .btn_orange {
        height: 80px;
        font-size: 1.8rem;
    }

    .btn_brown {
        font-size: 1.8rem;
        padding: 26px 0;
    }

    a.btn-a:hover,
    .btn-a:hover {
        color: #fff;
        box-shadow: none;
        text-decoration: none;
        top: 4px;
        background-color: #ee7215;
        border-color: #ee7215;
    }

    a.btn-a:hover::before,
    .btn-a:hover::before {
        background: #fff;
    }

    a.btn-a:hover::after,
    .btn-a:hover::after {
        border-color: #ee7215;
    }

    /*a.button2:hover { top: 4px; box-shadow: none; }*/

}

@media (max-width: 767px) {
    .btn_orange {
        height: 55px;
        font-size: 1.6rem;
    }

    .btn_brown {
        font-size: 1.6rem;
        padding: 15px 0;
    }

}


/*------------------------------------------------------

		dl

------------------------------------------------------*/
.dl-a {
    border-top: 2px solid #38251a;
}

.dl-a dt {
    font-weight: bold;
}

.dl-a dd {}

.dl-a dt,
.dl-a dd {
    border-bottom: 1px solid #ccc;
}

@media (min-width: 768px) {
    .dl-a {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .dl-a dt {
        width: 15%;
    }

    .dl-a dd {
        width: 85%;
    }

    .dl-a dt,
    .dl-a dd {
        padding: 15px 10px;
    }
}

@media (max-width: 767px) {
    .dl-a dt {}

    .dl-a dt {
        padding: 15px 10px;
    }

    .dl-a dd {
        padding: 15px 10px;
    }

}


/*------------------------------------------------------

		bg

------------------------------------------------------*/
/*
[class^='bg-'] p ,
[class^='bg-'] li { text-indent: -1.4rem; padding-left: 1.4rem; }
*/
.bg-yellow p,
.bg-yellow li {
    text-indent: -1.4rem;
    padding-left: 1.4rem;
}

.bg-yellow {
    background: #fbf5e2;
    padding: 20px;
    font-size: 1.4rem;
    line-height: 1.4;
}

.bg-yellow a {
    color: #0071bc;
}

.bg-yellow p {
    margin: 0;
    line-height: 1.4;
}

.bg-yellow li:not(:last-child),
.bg-yellow p:not(:last-child) {
    margin-bottom: 5px;
}

div.text .bg-yellow p,
div.text .bg-yellow li {
    line-height: 1.4;
}

hr {
    height: 1px;
    background-color: #e0d9ca;
    border: none;
    margin: 20px 0;
}


@media (min-width: 768px) {}

@media (max-width: 767px) {}



/*------------------------------------------------------

		table

------------------------------------------------------*/
[class^="table-"] th,
[class^="table-"] td {
    border-color: #38251a;
    padding: 15px;
    vertical-align: middle;
}

[class^="table-"] th {
    background: #f2efeb;
}

[class^="table-"] thead th {
    background: #e0d9ca;
}

[class^="table-"].left td {
    text-align: left;
}

[class^="table-"].center td {
    text-align: center;
}

[class^="table-"].right td {
    text-align: right;
}

[class^="table-"] .bg-yellow {
    margin-top: 10px;
}

.table-a th {
    text-align: left;
}

.table-a td {}

.table-scroll {
    margin: 0;
}


@media (min-width: 768px) {

    [class^="table-"] th,
    [class^="table-"] td {
        font-size: 2.0rem;
    }

}

@media (max-width: 767px) {

    [class^="table-"] th,
    [class^="table-"] td {
        font-size: 1.8rem;
    }

    .table-a tr th,
    .table-a tr td {
        border-bottom: none;
    }

    .table-a {
        border-bottom: 1px solid #38251a;
    }

    .table-scroll {
        overflow-x: scroll;
        white-space: nowrap;
    }

    .table-scroll .table-a th {
        border-top: 1px solid !important;
    }

    .table-scroll table th,
    .table-scroll table td {
        display: table-cell;
    }

}


/*------------------------------------------------------

		bubble

------------------------------------------------------*/
/*
[class*="bubble-"] { top: 50%; left: 0; color: #fff; display: inline-block; border-radius: 6px; position: absolute; text-align: center; padding: 6px 5px; box-shadow: 0px 0px 0px 2px #fff; }
[class*="bubble-"]::after { content: ''; border-bottom: 6px solid transparent; position: absolute; width: 6px; height: 6px; right: -6px; top: calc(50% - 6px); }
.bubble-a { background-color: #1FAB18; }
.bubble-a::after { border-left: 6px solid #1FAB18; border-top: 6px solid transparent; }
.bubble-b { }
.bubble-c { }

@media (min-width: 768px) {
  [class*="bubble-"] { font-size: 1.4rem; width: 85px; margin-top: -18px; }
  .bubble { padding-left: 120px; }
}

@media (max-width: 767px) {
  [class*="bubble-"] { font-size: 1.2rem; width: 70px; top: 0; }
  .bubble { padding-left: 90px; }
}
*/


/*------------------------------------------------------

    重要なお知らせ

------------------------------------------------------*/
#importantWrap {
    background-color: #ffd200;
}

#importantWrap .container.colWrap {
    display: flex;
    display: -webkit-flex;
    flex-direction: row;
    -webkit-flex-direction: row;
    flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    justify-content: space-between;
    -webkit-justify-content: space-between;
    align-items: stretch;
    -webkit-align-items: stretch;
    align-content: stretch;
    -webkit-align-content: stretch;
    max-width: 1100px;
    margin-left: auto;
    margin-right: auto;
}

#importantWrap .title {}

#importantWrap .title span {
    font-size: 1.2rem;
    color: #fff;
    background-color: #e84109;
    border-radius: 12px;
    display: inline-block;
    text-align: center;
    width: 100%;
    line-height: 2;
}

#importantWrap .body {
    font-size: 1.6rem;
    line-height: 1.6;
}

#importantWrap .body a {
    color: #0071bc;
}

@media (min-width: 768px) {
    #importantWrap {
        padding: 13px 0;
    }

    #importantWrap .title {
        width: 120px;
    }

    #importantWrap .body {
        width: calc(100% - 140px);
    }
}

@media (max-width: 767px) {
    #importantWrap {
        padding: 10px 0;
    }

    #importantWrap .container.colWrap {
        margin-left: 10px;
        margin-right: 10px;
    }

    #importantWrap .title {
        width: 100%;
        margin-bottom: 10px;
    }

    #importantWrap .body {
        width: 100%;
        font-size: 1.4rem;
    }
}



/*------------------------------------------------------

	h1タグ

------------------------------------------------------*/
#headH1 {
    line-height: 1.4;
    font-size: 1.2rem;
    font-weight: normal;
}


@media (min-width: 768px) {
    #headH1 {
        padding-left: 50px;
    }

}

@media (max-width: 767px) {
    #headH1 {
        padding: 0 10px;
    }
}



/*------------------------------------------------------



------------------------------------------------------*/

@media (min-width: 768px) {}

@media (max-width: 767px) {}





/*------------------------------------------------------

ASボタン追加

------------------------------------------------------*/


@import "https://use.fontawesome.com/releases/v5.13.0/css/all.css";

*,
*:before,
*:after {
    -webkit-box-sizing: inherit;
    box-sizing: inherit;
}

html {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    font-size: 62.5%;
}

/* 背景用*/
body {
    padding: 30px 10px;
}

.btn2,
a.btn2,
button.btn2 {
    font-size: 1.9rem;
    font-weight: 700;
    line-height: 2;
    position: relative;
    display: inline-block;
    padding: 1rem 4rem;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    text-align: center;
    vertical-align: middle;
    text-decoration: none;
    letter-spacing: 0.1em;
    color: #212529;
    border-radius: 0.5rem;
}

.btn2-wrap-pc-sp {
    max-width: 435px;
    margin: 0 auto 20px;
}

a.btn2-pc-sp {
    line-height: 1.4;

    width: 49.5%;
    padding: 1.25rem 0;

    color: #ffff;
}

a.btn2--contact {
    display: block;

    padding: 1.5rem 0;

    color: #fff;
    background: #ff7106;
    -webkit-box-shadow: 0 5px 0 #ee7215;
    box-shadow: 0 5px 0 #ee7215;
}

a.btn2--contact i {
    font-size: 2rem;
}

a.btn2--contact i.fa-position-left {
    font-size: 3rem;

    left: 2rem;
}

a.btn2--contact :hover {
    color: #fff;
}

a.btn2--tel {
    display: block;

    margin-top: 15px;
    padding: 1rem 0;

    color: #fff;
    background: #094;
    -webkit-box-shadow: 0 5px 0 #008039;
    box-shadow: 0 5px 0 #008039;
}

a.btn2--tel i {
    font-size: 2rem;
}

a.btn2--tel i.fa-position-left {
    font-size: 3rem;

    left: 2rem;
}

a.btn2--tel .number {
    line-height: 1;

    display: inline-block;

    margin-top: 0.5rem;
    padding: 0.25rem 2rem;

    letter-spacing: 0;

    color: #094;
    border-radius: 0.5rem;
    background: #fff;
}

a.btn2--tel:hover {
    color: #fff;
}

.fa-position-left {
    position: absolute;
    top: calc(50% - 0.5em);
    left: 1rem;
}

.fa-position-right {
    position: absolute;
    top: calc(50% - 0.5em);
    right: 1rem;
}


.box6 {
    padding: 1em 1.5em;
    margin: 2em 0;
    background-color: #fbf5e2;
    /*背景色*/
    border: 1px solid #eeeeee;
    /*枠線*/
    border-top: 4px solid #8e5723;
    ;
    /*上の線*/
    box-shadow: 0 -1px 0 rgba(255, 255, 255, 1) inset;
    color: #000000;
    /*文字色*/
}

.box6 p {
    margin: 0;
    padding: 0;
}


/*タイトル付き（ラベルボックス）*/
.box07 {
    margin: 2em auto;
    background-color: #fff;
    padding: 2em;
    position: relative;
    border: 2px solid #38251a;
}

.box07 .box-title {
    background-color: #fff;
    font-size: 1em;
    font-weight: 800;
    color: #38251a;
    padding: 0 5px;
    line-height: 1;
    position: absolute;
    top: -5px;
    left: 20px;
}


/* AS追加 CTA_05 */

.cta05-cvset {
    padding: 100px 0 0;
}

.cta05-cvset .cta05-inner {
    background-color: #f2efeb;
    padding: 10px 0 20px;
    position: relative;
    width: 100%;
    height: 100%;
    max-width: 1280px;
    margin-left: auto;
    margin-right: auto;
}

.cta05-cvset .cta05-inner ul {
    list-style: none;
    margin-top: 40px;
    padding-inline-start: 0;
    border: none;
    padding: 0;
}

.cta05-cvset-title {
    position: relative;
    font-size: 1.8em;
    line-height: 0.6em;
    font-weight: 800;
    font-style: normal;
    letter-spacing: .1em;
    position: absolute;
    top: -10px;
    left: 0;
    text-align: center;
    width: 100%;
}

.cta05-cvset-title .rikon {
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%);
    font-size: 20px;
    color: #da6d6c;
    white-space: nowrap;
    padding-bottom: 8px;
    margin-bottom: 16px;
}

.cta05-cvset-title .sozoku {
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%);
    font-size: 20px;
    color: #1fab18;
    white-space: nowrap;
    padding-bottom: 8px;
    margin-bottom: 16px;
}

.cta05-cvset-title .keiji {
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%);
    font-size: 20px;
    color: #ab2418;
    white-space: nowrap;
    padding-bottom: 8px;
    margin-bottom: 16px;
}


.cta05-cvset-list {
    display: flex;
    width: 97%;
    max-width: 780px;
    justify-content: space-between;
    margin: 0 auto;
}

.cta05-cvset-list li {
    max-width: 360px;
    width: 100%;
    margin: 0 5px;
}

.cta05-cvset-list img {
    width: 100%;
    text-align: center;
}

.cta05-button.dwl,
.cta05-button.etm {
    background-color: #fff;
    border: px solid #005fa0;
    color: #005fa0;
}

.cta05-button.dwl,
.cta05-button.dmo,
.cta05-button.etm {
    height: 96px;
    font-size: 24px;
    font-weight: bold;
    line-height: 1.4em;
    text-align: center;
    flex-direction: column;
    white-space: nowrap;
    text-decoration: none;
}

.cta05-button.dmo {
    background-color: #005fa0;
    border: 3px solid #005fa0;
    color: #fff;
}

.cta05-button {
    position: relative;
    display: flex;
    width: 100%;
    height: 72px;
    text-align: center;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    border-radius: 12px;
    margin: 0;
    box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 6px 10px -2px rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.2);
    transition: 0.2s ease-in-out;
}

.cta05-button.free::after {
    content: "一人で悩まず";
    position: absolute;
    display: block;
    top: -17px;
    right: 1px;
    width: 100px;
    height: 30px;
    font-size: 14px;
    font-weight: bold;
    line-height: 32px;
    text-align: center;
    background-color: #ff6d00;
    color: #fff;
    border-radius: 16px;
}

.cta05-button.dwl:hover,
.cta05-button.dmo:hover,
.cta05-button.etm:hover {
    background-color: #6bb6ff;
    box-shadow: 0 15px 30px -5px rgba(0, 0, 0, 0.15), 0 0 5px rgba(0, 0, 0, 0.1);
    transform: translateY(-4px);
}

.cta05-button.dwl small,
.cta05-button.dmo small,
.cta05-button.etm small {
    display: block;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.2em;
    letter-spacing: 0;
    margin-bottom: 4px;
    white-space: nowrap;
}

@media screen and (max-width: 768px) {
    .cta05-cvset .cta05-inner {
        padding: 40px 20px 32px;
    }

    .cta05-cvset-list {
        flex-direction: column;
        align-items: center;
        padding-bottom: 16px;
    }

    .cta05-button.dwl small,
    .cta05-button.dmo small,
    .cta05-button.etm small {
        font-size: 12px;
    }
}

/* AS追加 BlogCTA_05 */

#unique-container .cta05-cvset {
    padding: 100px 0 0;
}

#unique-container .cta05-cvset .cta05-inner ul {
    list-style-type: none;
    padding-left: 0;
    list-style: none;
    margin-top: 40px;
    padding-inline-start: 0;
    border: none;
    padding: 0;
}


#unique-container .cta05-cvset .cta05-inner ul {
    list-style: none;
    margin-top: 40px;
    padding-inline-start: 0;
    border: none;
    padding: 0;
}

#unique-container .cta05-cvset-title {
    position: relative;
    font-size: 1.8em;
    line-height: 0.6em;
    font-weight: 800;
    font-style: normal;
    letter-spacing: .1em;
    position: absolute;
    top: -10px;
    left: 0;
    text-align: center;
    width: 100%;
}

#unique-container .cta05-cvset-title .rikon {
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%);
    font-size: 20px;
    color: #da6d6c;
    white-space: nowrap;
    padding-bottom: 8px;
    margin-bottom: 16px;
}

#unique-container .cta05-cvset-title .sozoku {
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%);
    font-size: 20px;
    color: #1fab18;
    white-space: nowrap;
    padding-bottom: 8px;
    margin-bottom: 16px;
}

#unique-container .cta05-cvset-title .keiji {
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%);
    font-size: 20px;
    color: #ab2418;
    white-space: nowrap;
    padding-bottom: 8px;
    margin-bottom: 16px;
}

#unique-container .cta05-cvset-list {
    display: flex;
    width: 97%;
    max-width: 780px;
    justify-content: space-between;
    margin: 0 auto;
}

#unique-container .cta05-cvset-list li {
    max-width: 360px;
    width: 100%;
    margin: 0 5px;
}

#unique-container .cta05-cvset-list img {
    width: 100%;
    text-align: center;
}

#unique-container .cta05-button.dwl,
#unique-container .cta05-button.etm {
    background-color: #fff;
    border: px solid #005fa0;
    color: #005fa0;
}

#unique-container .cta05-button.dwl,
#unique-container .cta05-button.dmo,
#unique-container .cta05-button.etm {
    height: 96px;
    font-size: 24px;
    font-weight: bold;
    line-height: 1.4em;
    text-align: center;
    flex-direction: column;
    white-space: nowrap;
    text-decoration: none;
}

#unique-container .cta05-button.dmo {
    background-color: #005fa0;
    border: 3px solid #005fa0;
    color: #fff;
}

#unique-container .cta05-button {
    position: relative;
    display: flex;
    width: 100%;
    height: 72px;
    text-align: center;
    align-items: center;
    justify-content: center;
    text -decoration: none;
    border-radius: 12px;
    margin: 0;
    box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 6px 10px -2px rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.2);
    transition: 0.2s ease-in-out;
}

#unique-container .cta05-button.free::after {
    content: "一人で悩まず";
    position: absolute;
    display: block;
    top: -17px;
    right: 1px;
    width: 100px;
    height: 30px;
    font-size: 14px;
    font-weight: bold;
    line-height: 32px;
    text-align: center;
    background-color: #ff6d00;
    color: #fff;
    border-radius: 16px;
}



#unique-container .cta05-button.dwl:hover,
#unique-container .cta05-button.dmo:hover,
#unique-container .cta05-button.etm:hover {
    background-color: #6bb6ff;
    box-shadow: 0 15px 30px -5px rgba(0, 0, 0, 0.15), 0 0 5px rgba(0, 0, 0, 0.1);
    transform: translateY(-4px);
}

#unique-container .cta05-button.dwl small,
#unique-container .cta05-button.dmo small,
#unique-container .cta05-button.etm small {
    display: block;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.2em;
    letter-spacing: 0;
    margin-bottom: 4px;
    white-space: nowrap;
}

@media screen and (max-width: 768px) {
    #unique-container .cta05-cvset .cta05-inner {
        padding: 40px 20px 32px;
    }

    #unique-container .cta05-cvset-list {
        flex-direction: column;
        align-items: center;
        padding-bottom: 16px;
    }

    #unique-container .cta05-button.dwl small,
    #unique-container .cta05-button.dmo small,
    #unique-container .cta05-button.etm small {
        font-size: 12px;
    }
}

/*** タブメニューボタン***/


.tab-wrap {
    display: flex;
    flex-wrap: wrap;
}

.tab-wrap:after {
    content: '';
    width: 100%;
    height: 3px;
    background: ee7215;
    display: block;
    order: -1;
}

.tab-label {
    color: White;
    background: LightGray;
    font-weight: bold;
    text-shadow: 0 -1px 0 rgba(0, 0, 0, .2);
    white-space: nowrap;
    text-align: center;
    padding: 10px .1em;
    order: -1;
    position: relative;
    z-index: 1;
    cursor: pointer;
    border-radius: 5px 5px 0 0;
    flex: 1;
}

.tab-label:not(:last-of-type) {
    margin-right: 10px;
}

.tab-content {
    width: 100%;
    height: 0;
    overflow: hidden;
    opacity: 0;
}

/* アクティブなタブ */
.tab-switch:checked+.tab-label {
    background: #ee7215;
}

.tab-switch:checked+.tab-label+.tab-content {
    height: auto;
    overflow: auto;
    padding: 15px;
    opacity: 1;
    transition: .5s opacity;
    box-shadow: 0 0 3px rgba(0, 0, 0, .2);
}

/* ラジオボタン非表示 */
.tab-switch {
    display: none;
}

.container {
    max-width: 960px;
    margin: 0 auto;
    padding: 20px;
}

.row {
    display: flex;
    flex-direction: row;
    margin-bottom: 20px;
}

.column {
    flex: 1;
    padding: 10px;
    border: 1px solid black;
    text-align: center;
}

.row .column:not(:last-child) {
    margin-right: 20px;
}

/*** タブメニューボタンここまで***/





/*------------------------------------------------------



------------------------------------------------------*/

@media (min-width: 768px) {}

@media (max-width: 767px) {}


#cta04 {
    width: 100%;
    padding: 20px;
    background: #f2efeb;
    box-sizing: border-box;
    color: #fff;
    text-align: center;
    font-size: 120%;
}

#cta04 .cta04title {
    font-size: 1.6em;
    font-weight: 600;
    margin-top: 0;
    line-height: 1.3;
}

#cta04 img {
    margin-bottom: 20px;
}

#cta04 ul {
    margin: -30px 0 30px 0px;
    list-style: none;
    border: none;
    padding: 0;
}

#cta04 ul li:before {
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    color: silver;
    content: "\f105";
    padding-left: 0;
    margin-right: 15px;
    line-height: 1.8;
}

#cta04 a {
    width: 100%;
    height: 60px;
    margin: 0 auto;
    line-height: 62px;
    color: #005fa0;
    text-align: center;
    background: #fff;
    box-shadow: 0 4px 0 rgb(210, 210, 210);
    display: block;
    text-decoration: none;
    text-shadow: 0 1px 1px rgba(0, 0, 0, .09);
    -webkit-transition: .3s ease-in-out;
    -moz-transition: .3s ease-in-out;
    -o-transition: .3s ease-in-out;
    transition: .3s ease-in-out;
}

#cta04 a:hover {
    -webkit-transform: translateY(3px);
    transform: translateY(3px);
    box-shadow: none;
}

#cta04 .ctatext04 {
    display: inline-block;
    position: relative;
    margin: 0;
}

.ctatext04:before,
.ctatext04:after {
    display: inline-block;
    position: absolute;
    top: 50%;
    width: 22px;
    height: 2px;
    border-radius: 3px;
    background-color: #FFF;
    content: "";
    margin: auto -30px;
}

.ctatext04:before {
    transform: rotate(50deg);
}

.ctatext04:after {
    transform: rotate(-50deg);
    margin-left: 10px;
}

@media screen and (min-width: 768px) {
    #cta04 {
        padding: 50px 60px;
    }

    #cta04 img {
        max-width: 100%;
        height: auto;
        width: auto;
    }

    #cta04 ul {
        text-align: left;
    }
}

@media screen and (max-width: 600px) {
    #cta04 {
        padding: 20px 25px 40px;
        background: #707070;
    }

    #cta04 .cta04title {
        font-size: 1.1em;
        margin-top: 20px;
        line-height: 1.5;
    }

    #cta04 ul li {
        font-size: 0.8em;
        text-align: left;
        line-height: 1.4;
    }

    #cta04 .ctatext04 {
        font-size: 0.6em;
    }

    .ctatext04:before,
    .ctatext04:after {
        width: 15px;
    }

    #cta04 img {
        margin-bottom: 40px;
    }
}





/*------------------------------------------------------

フローチャートステップ

------------------------------------------------------*/



.Inner {
    margin-left: auto;
    margin-right: auto;
    max-width: 1200px;
}

p {
    margin: 0;
    padding: 0;
}

li {
    list-style: none;
}

.List-Item {
    border-top: 1px solid #ddd;
    width: 100%;
}

@media screen and (max-width: 540px) {
    .List-Item {
        border-top: 0;
    }
}

.List-Item:nth-of-type(1) {
    border-top: 0;
}

.List-Item-Content {
    margin-left: auto;
    margin-right: auto;
    padding-top: 30px;
    padding-bottom: 30px;
    max-width: 1100px;
    display: flex;
    align-items: center;
}

@media screen and (max-width: 540px) {
    .List-Item-Content {
        padding-top: 15px;
        padding-bottom: 15px;
        flex-wrap: wrap;
    }
}

.List-Item-Content.one {
    padding-top: 0;
}

.List-Item-Content-Number {
    position: relative;
    margin-right: 40px;
    border-radius: 50%;
    width: 80px;
    height: 80px;
    line-height: 80px;
    text-align: center;
    background: #8a663f;
    color: #fff;
    font-size: 36px;
}

@media screen and (max-width: 540px) {
    .List-Item-Content-Number {
        margin-right: 20px;
        width: 40px;
        height: 40px;
        line-height: 40px;
        font-size: 24px;
    }
}

.List-Item-Content-Number-Line {
    position: absolute;
    top: -36%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 4px;
    height: 66px;
    background: #8a663f;
}

@media screen and (max-width: 540px) {
    .List-Item-Content-Number-Line {
        top: -80%;
        width: 2px;
        height: 72px;
    }
}

.List-Item-Content-Title {
    margin-right: 48px;
    flex-basis: 298px;
    color: #8a663f;
    font-size: 24px;
}

@media screen and (max-width: 540px) {
    .List-Item-Content-Title {
        margin-right: 0;
        max-width: 230px;
        font-size: 18px;
    }
}

.List-Item-Content-Description {
    line-height: 1.5;
    font-size: 16px;
}

@media screen and (max-width: 540px) {
    .List-Item-Content-Description {
        margin-left: 60px;
        max-width: 260px;
        font-weight: normal;
        font-size: 13px;
    }
}


.box-011 {
    position: relative;
    max-width: px;
    margin: 1.9em auto 0;
    padding: 1em 1.5em;
    border: 2px solid #8a663f;
    border-radius: 3px;
}

.box-011 span {
    position: absolute;
    top: -1.9em;
    left: -2px;
    padding: .2em .8em;
    border-radius: 5px 5px 0 0;
    background-color: #8a663f;
    color: #fff;
}

.box-011 p {
    margin: 0;
    color: #333;
}





#cta05 {
    width: 100%;
    padding: 20px;
    background: #f2efeb;
    box-sizing: border-box;
    color: #fff;
    text-align: center;
    font-size: 120%;
}

#cta05 .cta05title {
    font-size: 1.6em;
    font-weight: 600;
    margin-top: 0;
    line-height: 1.3;
}

#cta05 img {
    margin-bottom: 20px;
}

#cta05 ul {
    margin: -30px 0 30px 0px;
    list-style: none;
    border: none;
    padding: 0;
}

#cta05 ul li:before {
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    color: silver;
    content: "\f105";
    padding-left: 0;
    margin-right: 15px;
    line-height: 1.8;
}

#cta05 a {
    width: 100%;
    height: 60px;
    margin: 0 auto;
    line-height: 62px;
    color: #fff;
    text-align: center;
    font-weight: 600;
    border-radius: 5px;
    background: #FF9800;
    box-shadow: 0 4px 0 rgb(210, 210, 210);
    display: block;
    text-decoration: none;
    text-shadow: 0 1px 1px rgba(0, 0, 0, .09);
    -webkit-transition: .3s ease-in-out;
    -moz-transition: .3s ease-in-out;
    -o-transition: .3s ease-in-out;
    transition: .3s ease-in-out;
}

#cta05 a:hover {
    -webkit-transform: translateY(3px);
    transform: translateY(3px);
    box-shadow: none;
}

#cta05 .ctatext05 {
    display: inline-block;
    position: relative;
    margin: 0;
}

.ctatext05:before,
.ctatext05:after {
    display: inline-block;
    position: absolute;
    top: 50%;
    width: 22px;
    height: 2px;
    border-radius: 3px;
    background-color: #FFF;
    content: "";
    margin: auto -30px;
}

.ctatext05:before {
    transform: rotate(50deg);
}

.ctatext05:after {
    transform: rotate(-50deg);
    margin-left: 10px;
}

@media screen and (min-width: 768px) {
    #cta05 {
        padding: 50px 60px;
    }

    #cta05 img {
        max-width: 100%;
        height: auto;
        width: auto;
    }

    #cta05 ul {
        text-align: left;
    }
}

@media screen and (max-width: 600px) {
    #cta05 {
        padding: 20px 25px 40px;
        background: #f2efeb;
    }

    #cta05 .cta05title {
        font-size: 1.1em;
        margin-top: 20px;
        line-height: 1.5;
    }

    #cta05 ul li {
        font-size: 0.8em;
        text-align: left;
        line-height: 1.4;
    }

    #cta05 .ctatext05 {
        font-size: 0.6em;
    }

    .ctatext05:before,
    .ctatext05:after {
        width: 15px;
    }

    #cta05 img {
        margin-bottom: 40px;
    }
}



/*------------------------------------------------------

    ダウンロードボタン

------------------------------------------------------*/


.button-062 {
    display: flex;
    justify-content: center;
    align-items: center;
    min-width: 45%;
    margin: 0 auto;
    padding: .9em 2em;
    border: none;
    border-radius: 5px;
    background-color: #2589d0;
    color: #fff;
    font-weight: 600;
    font-size: 1em;
}

.button-062:hover {
    background-color: 2589d0;
}

.button-062::before {
    width: 1em;
    height: 1em;
    margin-right: 10px;
    background: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%3E%3Cpath%20d%3D%22M15.6%208.4V1.2H8.4v7.198h-6l9.6%209.6%209.6-9.6h-6zM0%2020.4h24v2.4H0v-2.4z%22%20fill%3D%22%23fff%22%2F%3E%3C%2Fsvg%3E') no-repeat center;
    content: '';
}


/*------------------------------------------------------

    1列テーブル

------------------------------------------------------*/

.table_as2 {
    border-spacing: 0;
    border-collapse: separate;
}

.table_as2 th,
.table_as2 td {
    border-top: 1px solid #ddd;
    border-left: 1px solid #ddd;
}

.table_as2 th {
    padding: 5px 10px;
    background: #F5F5F5;
    color: #38251A;
}

.table_as2 td {
    padding: 2px 5px;
    background: #FCFCFC;
    color: #38251A;
}

.table_as2 th:last-child,
.table_as2 td:last-child {
    border-right: 1px solid #ddd;
}

.table_as2 tr:last-child th,
.table_as2 tr:last-child td {
    border-bottom: 1px solid #ddd;
}

.table_as2 tr:first-child :first-child {
    border-top-left-radius: 5px;
}

.table_as2 tr:first-child :last-child {
    border-top-right-radius: 5px;
}

.table_as2 tr:last-child :first-child {
    border-bottom-left-radius: 5px;
}

.table_as2 tr:last-child :last-child {
    border-bottom-right-radius: 5px;
}


/*------------------------------------------------------

    Q&A(CSSオンリー)

------------------------------------------------------*/


.qa-006 {
    max-width: 1500px;
    margin-bottom: 5px;
    border-bottom: 2px solid #d6dde3;
}

.qa-006 summary {
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    padding: 1em 2em 1em 3em;
    color: #333333;
    font-weight: 600;
    cursor: pointer;
}

.qa-006 summary::before,
.qa-006 p::before {
    position: absolute;
    left: 1em;
    font-weight: 600;
    font-size: 1.3em;
}

.qa-006 summary::before {
    color: #75bbff;
    content: "Q";
}

.qa-006 summary::after {
    transform: translateY(-25%) rotate(45deg);
    width: 7px;
    height: 7px;
    margin-left: 10px;
    border-bottom: 3px solid #333333b3;
    border-right: 3px solid #333333b3;
    content: '';
    transition: transform .5s;
}

.qa-006[open] summary::after {
    transform: rotate(225deg);
}

.qa-006 p {
    position: relative;
    transform: translateY(-10px);
    opacity: 0;
    margin: 0;
    padding: .3em 3em 1.5em;
    color: #333;
    transition: transform .5s, opacity .5s;
}

.qa-006[open] p {
    transform: none;
    opacity: 1;
}

.qa-006 p::before {
    color: #ff8d8d;
    line-height: 1.2;
    content: "A";
}