@charset "UTF-8";
html:not(.responsive) {
    /*    min-width: 1200px;*/
    /* viewport */
    width: 100%;
    /* viewport */
}

/*=============================================
 * body
 *=============================================*/
body {
    color: #000;
    font-family: "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro",
        "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", Osaka,
        "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    font-size: 16px;
    line-height: 1.87;
    letter-spacing: 0;
    background: #fff;
    min-width: inherit;
    min-height: inherit;
    max-height: 100%;
}

/*=============================================
 * fonts - DON'T EDIT
 *=============================================*/
.fnt-mincho {
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3",
        "Hiragino Mincho ProN", "HG明朝E", "メイリオ", Meiryo, "ＭＳ Ｐ明朝",
        "ＭＳ 明朝", serif;
}

.fnt-meiryo {
    font-family: "メイリオ", Meiryo, "ヒラギノ角ゴシックPro", "ＭＳ ゴシック",
        "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic",
        sans-serif;
}

.fnt-gothic {
    font-family: "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro",
        "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", Osaka,
        "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.fnt-UDShin{
    font-family: a-otf-ud-shin-go-pr6n, sans-serif;
    font-weight: 300;
    font-style: normal;
}

/*=============================================
 * .fnt - customs
 *=============================================*/
.fnt-notosans {
    font-family: "Noto Sans JP", sans-serif;
}

.fnt-opensans {
    font-family: "Open Sans", sans-serif;
}

.tc {
    text-align: center;
}

.tj {
    text-align: justify;
}

.tr {
    text-align: right;
}

.tl {
    text-align: left;
}

.fwb {
    font-weight: bold;
}

.disf {
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

em {
    font-style: normal;
}

strong {
    font-weight: normal;
}

.slick-slider {
    z-index: 0;
}

.slick-slider .slick-dots {
    line-height: 0;
    text-align: center;
}

.slick-slider .slick-dots li {
    display: inline-block;
}

.slick-slider .slick-dots button {
    font-size: 0;
    line-height: 0;
    cursor: pointer;
    border: none;
    cursor: pointer;
    border-radius: 50%;
    border: 1px solid #cd321d;
    background: none;
}

.slick-slider .slick-dots .slick-active button {
    background: #cd321d;
}

.slick-slider .slick-arrow {
    font-size: 0;
    line-height: 0;
    position: absolute;
    top: 0;
    border: none;
    outline: none;
    border-radius: 50%;
    cursor: pointer;
    background: url("../img/shared/prev.png");
    background-position: center center;
    background-repeat: no-repeat, repeat;
    background-size: cover;
    z-index: 1;
}

.slick-slider .slick-arrow.slick-prev {
    left: 0;
}

.slick-slider .slick-arrow.slick-next {
    right: 0;
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg);
}

.bgsec-parallax {
    position: relative;
    padding-top: 100%;
}

.img-parallax {
    clip: rect(0, auto, auto, 0);
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: -1;
}

.img-parallax img {
    width: 100%;
    height: 100vh !important;
    position: fixed;
    top: 0;
    left: 0;
    padding: 0;
    margin: 0;
    -o-object-fit: cover;
    object-fit: cover;
    z-index: -1;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
}
.hd-page{
    padding-top: 101px;
}
@media all and (min-width: 768px) {
    .pc {
        display: block;
    }
    .sp {
        display: none;
    }
    img {
        width: auto;
        max-width: 100%;
    }
    .disf-pc {
        display: -moz-flex;
        display: -ms-flex;
        display: -o-flex;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
    }
}

@media all and (max-width: 767px) {
    .pc {
        display: none;
    }
    .sp {
        display: block;
    }
}

/*=============================================
 * <main>
 *=============================================*/
main {
    clear: both;
    width: 100%;
    position: relative;
    overflow: hidden;
}

@media all and (min-width: 768px) {
    .wrap {
        width: 100%;
        max-width: 1200px;
    }
}

/*=============================================
 * <header>
 *=============================================*/
header {
    position: relative;
}

header .logo-fix {
    display: none;
}

header .hd-btn a {
    color: #00a0e9;
    font-weight: bold;
    letter-spacing: 0.5px;
    border: 2px solid #00a0e9;
    border-radius: 21.5px;
    padding: 4.5px 0;
    display: block;
    text-align: center;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

header .hd-btn a:hover {
    text-decoration: none;
    background: #009be4;
    color: #fff;
}

header .logo a {
    display: block;
}

header nav a {
    font-weight: bold;
    text-shadow: 0px 0px 8.5px rgba(255, 255, 255, 0.77);
    white-space: nowrap;
    position: relative;
}

header nav a:hover {
    opacity: 0.7;
    text-decoration: none;
}
header #sidebar {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 10;
    background: rgba(255, 255, 255, 0.5);
}
@media all and (min-width: 1024px) {
    /* header #sidebar {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: 10;
  } */
    header .inner {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        padding-top: 36px;
        padding-bottom: 10px;
    }
    header .inner .col-r {
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
    }
    header .logo a {
        width: 190px;
    }
    header .col-r {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
    }
    header nav {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
    }
    header nav a {
        font-size: 16px;
        margin: 0 10px;
    }
    header .hd-btn {
        margin-left: 35px;
    }
    header .hd-btn a {
        font-size: 16px;
        width: 166px;
    }
}

@media all and (max-width: 1080px) and (min-width: 1024px) {
    header .logo a {
        width: 150px;
    }
    header nav a {
        font-size: 14px;
        margin: 0 7px;
    }
    header .hd-btn {
        margin-left: 15px;
    }
    header .hd-btn a {
        font-size: 14px;
        width: 150px;
    }
}

/*=============================================
 * key
 *=============================================*/
#key {
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    position: relative;
}

/*=============================================
 * <footer>
 *=============================================*/
footer a:hover {
    opacity: 0.8;
    text-decoration: none;
}

footer .inner {
    font-size: 16px;
    line-height: 1.56;
    font-weight: 500;
}

footer .col-r {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    position: relative;
}

footer .logo {
    font-size: 18px;
    line-height: 1.2;
}

footer .logo small {
    font-size: 14px;
    margin-right: 5px;
    display: inline-block;
}

footer .vcard {
    margin-top: 5px;
}

footer .info dd {
    margin-left: 30px;
}

footer .privacy {
    white-space: nowrap;
}

footer .ft-bnr {
    margin-left: 30px;
}

/*=============================================
 * copyright
 *=============================================*/
address {
    background: #000;
    color: #fff;
    font-size: 12px;
    line-height: 2.08;
    padding: 12px 0;
}

@media all and (min-width: 991px) {
    footer .inner {
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        padding-top: 50px;
    }
    footer address {
        margin-top: 50px;
    }
}

@media all and (max-width: 990px) {
    footer .inner {
        padding-top: 35px;
    }
    footer .col-r {
        padding: 20px 0;
        margin-top: 30px;
    }
    footer .col-r:before {
        content: "";
        position: absolute;
        top: 0;
        left: -5%;
        right: -5%;
        border-top: 1px solid #d1d1d1;
    }
    footer .info .tel span {
        text-decoration: underline;
    }
}

/*--------------------navi + menu-toggle + ft-fixed-------------------*/
.menu-toggle {
    opacity: 0;
    visibility: hidden;
    position: fixed;
    width: 100%;
    top: 0;
    right: 0;
    bottom: 0;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    padding: 70px 0 0 0;
    transition: all 0.5s ease 0s;
    -moz-transition: all 0.5s ease 0s;
    -webkit-transition: all 0.5s ease 0s;
    z-index: 9;
    display: none;
    height: 0;
    background: rgba(255, 255, 255, 0.95);
}

@media all and (max-width: 1023px) {
    .hd-page{
        padding-top: 68px;
    }
    header .logo-fix {
        display: block;
    }
    header .logo {
        padding: 15px 0;
        width: 130px;
    }
    /* .inner-toggle{
    background: rgba(255, 255, 255, 0.95);
  } */
    .inner-toggle {
        /* padding: 0 0 25vw; */
        /* height: 100vh; */
    }
    .btn-close {
        background: #3c3c3c;
        color: #fff;
        font-weight: bold;
        text-align: center;
        font-size: 16px;
        padding: 10px 0;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        margin-top: 30px;
    }
    .btn-close i {
        display: inline-block;
        margin-right: 10px;
        width: 16px;
        line-height: 1;
    }
    .hamburger {
        padding: 10px 64px 0 14px;
        display: inline-block;
        cursor: pointer;
        -webkit-transition-property: opacity, -webkit-filter;
        transition-property: opacity, -webkit-filter;
        transition-property: opacity, filter;
        transition-property: opacity, filter, -webkit-filter;
        -webkit-transition-duration: 0.15s;
        transition-duration: 0.15s;
        -webkit-transition-timing-function: linear;
        transition-timing-function: linear;
        font: inherit;
        color: inherit;
        text-transform: none;
        background-color: transparent;
        border: 0;
        margin: 0;
        overflow: visible;
        position: fixed;
        top: 14px;
        right: 2%;
        z-index: 100;
        background: #3c3c3c;
        color: #fff;
        font-weight: bold;
        border-radius: 32px;
        font-family: "Noto Sans JP", sans-serif;
    }
    .hamburger:after {
        content: "メニュー";
        position: absolute;
        top: 50%;
        left: 46px;
        font-size: 12px;
        color: #fff;
        font-weight: bold;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%);
        font-family: "Noto Sans JP", sans-serif;
    }
    .hamburger .hamburger-box {
        width: 24px;
        height: 20px;
        display: inline-block;
        position: relative;
    }
    .hamburger .hamburger-inner {
        display: block;
        top: 50%;
        margin-top: -2px;
        top: 2px;
    }
    .hamburger .hamburger-inner,
    .hamburger .hamburger-inner::before,
    .hamburger .hamburger-inner::after {
        width: 24px;
        height: 3px;
        background: #fff;
        position: absolute;
        -webkit-transition-property: -webkit-transform;
        transition-property: -webkit-transform;
        transition-property: transform;
        transition-property: transform, -webkit-transform;
        -webkit-transition-duration: 0.15s;
        transition-duration: 0.15s;
        -webkit-transition-timing-function: ease;
        transition-timing-function: ease;
    }
    .hamburger .hamburger-inner::before,
    .hamburger .hamburger-inner::after {
        content: "";
        display: block;
    }
    .hamburger .hamburger-inner::before {
        top: 8px;
        -webkit-transition-property: opacity, -webkit-transform;
        transition-property: opacity, -webkit-transform;
        transition-property: transform, opacity;
        transition-property: transform, opacity, -webkit-transform;
        -webkit-transition-timing-function: ease;
        transition-timing-function: ease;
        -webkit-transition-duration: 0.15s;
        transition-duration: 0.15s;
    }
    .hamburger .hamburger-inner::after {
        top: 16px;
    }
    .hamburger.is-active .hamburger-inner {
        -webkit-transform: translate3d(0, 8px, 0) rotate(45deg);
        transform: translate3d(0, 8px, 0) rotate(45deg);
        border-radius: 5px;
    }
    .hamburger.is-active .hamburger-inner::before {
        -webkit-transform: rotate(-45deg) translate3d(-5.71429px, -6px, 0);
        transform: rotate(-45deg) translate3d(-5.71429px, -6px, 0);
        opacity: 0;
    }
    .hamburger.is-active .hamburger-inner::after {
        -webkit-transform: translate3d(0, -16px, 0) rotate(-90deg);
        transform: translate3d(0, -16px, 0) rotate(-90deg);
        border-radius: 5px;
    }
    body.nav--opened,
    body.nav--opened *,
    body.nav--opened *:hover,
    body.nav--opened *:focus,
    body.nav--opened *:active {
        /*    cursor: none !important;*/
        -ms-touch-action: none !important;
        touch-action: none !important;
        pointer-events: none !important;
    }
    body.nav--opened header .logo a,
    body.nav--opened .hamburger,
    body.nav--opened #menu-toggle,
    body.nav--opened #menu-toggle * {
        -ms-touch-action: auto !important;
        touch-action: auto !important;
        pointer-events: visible !important;
    }
    .nav--opened {
        overflow: hidden !important;
        -webkit-overflow-scrolling: touch !important;
        -ms-touch-action: none !important;
        touch-action: none !important;
        pointer-events: none !important;
    }
    .nav--opened #menu-toggle {
        opacity: 1;
        visibility: visible;
        pointer-events: visible;
        overflow: auto;
        display: block;
        height: auto;
    }
    .nav--opened #menu-toggle ul li {
        opacity: 1;
        -webkit-transform: matrix(1, 0, 0, 1, 0, 0);
        transform: matrix(1, 0, 0, 1, 0, 0);
    }
    .nav--opened .hamburger:after {
        content: "閉じる";
    }
    #menu-top .logo-fix {
        padding: 15px 4%;
        width: 130px;
    }
    #nav-top a:first-child {
        border-top: 1px solid #d1d1d1;
    }
    #nav-top a {
        border-bottom: 1px solid #595959;
        display: block;
        padding: 20px 4%;
    }
    #nav-top a:after {
        content: "";
        position: absolute;
        top: 50%;
        right: 4%;
        background-image: url(../img/shared/arrow_sp.png);
        background-position: right top;
        background-repeat: no-repeat;
        background-size: cover;
        width: 35px;
        height: 5px;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%);
    }
    .hd-btn {
        margin: 30px auto 0;
        max-width: 344px;
    }
}

@media all and (max-width: 375px) {
    .sp-375 {
        display: block;
    }
}

@-webkit-keyframes fadeInUp {
    from {
        opacity: 0;
        -webkit-transform: translate3d(0, 10px, 0);
        transform: translate3d(0, 10px, 0);
    }
    to {
        opacity: 1;
        -webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        -webkit-transform: translate3d(0, 10px, 0);
        transform: translate3d(0, 10px, 0);
    }
    to {
        opacity: 1;
        -webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }
}

.fadeInUp {
    -webkit-animation-name: fadeInUp;
    animation-name: fadeInUp;
    opacity: 0;
}

.fadeInUp[style] {
    opacity: 1;
}

.animated {
    -webkit-animation-duration: 1.2s;
    animation-duration: 1.2s;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
}

.animated.infinite {
    -webkit-animation-iteration-count: infinite;
    animation-iteration-count: infinite;
}

@media (prefers-reduced-motion) {
    .animated {
        -webkit-animation: unset !important;
        animation: unset !important;
        -webkit-transition: none !important;
        transition: none !important;
    }
}
#bread ul{
	text-align: right;
    margin: 20px 0 50px;
}

#bread li {
	font-size: 14px;
    font-weight: 500;
	color: #77716C;
	display: inline;
    position: relative;
    margin: 0 10px;
}
#bread li+li:before {
	 content: "";
    position: absolute;
    top: 3px;
    left: -13px;
    display: block;
    background: url("../img/shared/icon_anchr.png") no-repeat center top / cover;
    width: 7px;
    height: 12px;
    -webkit-transition-duration: .6s;
    -ms-transition-duration: .6s;
    -moz-transition-duration: .6s;
    transition-duration: .6s;
}
#bread li a {
}
#bread li a:hover {
	text-decoration: underline;
}
h2{
    font-weight: bold;
    font-size: 35px;
    line-height: 65px;
    border-bottom: 3px solid #009be4;
}
 h3{
    font-weight: bold;
    font-size: 30px;
    line-height: 35px;
   margin-top:35px;
}
h4{
    font-weight: bold;
    font-size: 20px;
    line-height: 35px;
   margin-top: 35px;
    color: #009be4;
}
h5{
    font-weight: bold;
    font-size: 20px;
    line-height: 35px;
   margin-top: 35px;
}
.list-style1 li{
    padding-left: 15px;
    position: relative;
    font-size: 18px;
    font-weight: 500;
}
.list-style1 li:before{
    content: "";
    position: absolute;
    top: 12px;
    left: 0;
    width: 8px;
    height: 8px;
    background:  #009be4;
}
.anchorlinks li a{
    text-decoration: underline;
    padding-left: 15px;
    position: relative;
}
.anchorlinks li a:before{
    content: "";
    position: absolute;
    top: 5px;
    left: 0;
    border-top: 4px solid transparent;
      border-bottom: 4px solid transparent;

      border-left: 8px solid #000;
}

 .anchorlinks li.active a,
.anchorlinks li a:hover{
    color: #009be4;
}
.anchorlinks li.active a:before,
.anchorlinks li a:hover:before{
      border-left: 8px solid #009be4;
}
.btn-style1 {
    background: #000 url("../img/shared/pdf.png") no-repeat center right 50px;
    color: #fff;
    font-weight: 500;
    font-size: 16px;
    line-height: 1.875;
    border-radius: 28px;
    display:block;
    width: 100%;
    max-width: 277px;
    padding: 11px 55px;
    position: relative;
    margin: 0 auto;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    border: 3px solid #000;
}
.btn2.btn-style1 {
    background: #000 url("../img/shared/icon_btn2.png") no-repeat center right 50px;
}
.btn2.btn-style1:hover{
    text-decoration: none;
    opacity: 0.8;
}
.btn-style1.active,
.btn-style1:hover {
    background: #fff url("../img/shared/pdf_on.png") no-repeat center right 50px;
    color: #000;
    text-decoration: none;
    border: 3px solid;
}
.btn-style2 {
    background: #000;
    color: #fff;
    font-weight: 500;
    font-size: 16px;
    line-height: 1.875;
    border-radius: 28px;
    display: block;
   width: 240px;
    padding: 11px 55px;
    position: relative;
    margin: 0 auto;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    border: 3px solid #000;
}
.btn-style2:after {
    content: "";
    position: absolute;
    top: 50%;
    right: 55px;
    background-image: url("../img/shared/arrow.png");
    background-position: center top;
    background-repeat: no-repeat;
    width: 27px;
    height: 8px;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}
.btn-style2.active,
.btn-style2:hover {
    color: #000;
    text-decoration: none;
    border: 3px solid;
    background: #fff;
}
.btn-style2.active:after,
.btn-style2:hover:after{
    background-image: url("../img/shared/arrow_on.png");
}
.btn-style3{
    display: block;
    width: 100%;
    border: 3px solid #009be4;
    border-radius: 28px;
    box-sizing: border-box;
    padding:10px 55px;
    background: url("../img/shared/note.png") no-repeat right 55px center;
    color: #009be4;
    font-size: 18px;
    line-height: 30px;
    font-weight: 500;
}
.btn-style3:hover,
.btn-style3.active{
    background:#009be4 url("../img/shared/note_on.png") no-repeat right 55px center;
    text-decoration: none;
    color: #fff;
}
.bx-table{
    margin-top: 50px;
}
.bx-table table{
    width: 100%;
    border-collapse: collapse;
        border-radius: 28px;
        border-style: hidden; /* hide standard table (collapsed) border */
        box-shadow: 0 0 0 1px #009be4; /* this draws the table border  */ 
}
.bx-table table thead th {
    background: #009be4;
    width: 30%;
    color: #fff;
    border-right: 1px solid #fff !important;
    text-align: left;
}
.bx-table table th:last-of-type{
    border-right: none !important ;
    border-radius: 0 28px 0 0;
}
.bx-table table th:first-of-type{
     border-radius: 28px 0 0 0;
    text-align: center;
    padding-left: 5px;
    padding-right: 5px;
}
.bx-table table th, #style .bx-table table td {
    line-height: 1.8;
    padding: 15px 35px 10px 35px;
    word-break: break-all;
    font-weight: 500;
}
.bx-table table td, .bx-table table tbody th{
    border: 1px solid #009be4;
}
.box-bar{
    margin-top: 60px;
}
 .progress-bar{
    display: flex;
    margin-top: 20px;
}
.progress-bar li{
    width: calc(100% / 3);
    text-align: center;
    color: #aaa;
    background: #f3f3f3;
    line-height: 40px;
    position: relative;
}
.progress-bar li:before{
    content: "";
    position: absolute;
    top: 0;
    right: -10px;
    z-index: 1;
    width: 0; 
      height: 0; 
      border-top: 20px solid transparent;
      border-bottom: 20px solid transparent; 
      border-left:10px solid #e7e7e7; 
}
.progress-bar li:last-of-type:before{
    display: none;
}
.progress-bar li.active{
    color: #fff;
    background: #009be4;
}
 .progress-bar li.confirm{
    color: #aaaaaa;
    background: #e6f6f9;
}
.progress-bar li.active:before{
    border-left-color:  #009be4;
}
.progress-bar li.confirm:before{
    border-left-color:  #e6f6f9;
}
.progress-bar li.next{
    background: #e7e7e7;
}
.box-pagination{
    margin-top: 40px;
}
.pagination{
    display: flex;
    justify-content: center;
    align-items: center;
    margin-top: 15px;
}
.pagination span{
    font-weight: 500;
    font-size: 18px;
    margin-right: 30px;
    min-width: 120px;
}
.pagination a {
    color: #000;
    display: inline-block;
    padding: 6px 16px;
    text-decoration: none;
    transition: background-color .3s;
    margin: 0 5px;
}
 .pagination a.active {
    background-color: #009be4;
    color: #fff;
    border-radius: 8px;
}
.pagination a.hover,
.pagination a:hover:not(.active) {
    background-color: #e6e6e6;
    border-radius: 8px;
}
.box-btn{
    display: flex;
    justify-content: center;
    margin-top: 50px;
}
.box-btn .btn-eff{
    max-width: 325px;
    width: 100%;
    margin: 0 10px;
    border-radius: 31px;
    text-align: center;
    color: #fff;
    font-size: 18px;
    line-height: 30px;
    font-weight: 500;
    padding: 16px 0;
    border: none;
    cursor: pointer;
}
.box-btn .btn-eff:hover{
    text-decoration: none;
    opacity: 0.8;
}
 .box-btn .btn-eff.submit{
    background-color: #000;
}
.box-btn .btn-eff.back{
    background-color: #b3b3b3;
}
.box-btn .btn-eff.send{
    background-color: #009be4;
}
.box-mail{
    margin-top: 50px;
}
.main-mail{
    margin-top: 30px;
}
 .main-mail .col{
    width: 60%;
    margin-bottom: 25px;
}
 .main-mail .col:last-of-type{
    width: 100%;
}
.main-mail dl dt{
    font-weight: 500;
    line-height: 30px;
    margin-bottom: 5px;
}
 .main-mail dl dt span{
    color: #fff;
    font-size: 12px;
    line-height: 30px;
    margin-left: 10px;
    padding: 3px 5px;
}
.main-mail dl dt .optional{
    background: #c1c1c1;
}
.main-mail dl dt .required{
    background: #c8000d;
}
 .main-mail textarea,
.main-mail input{
    display: block;
    width: 100%;
    box-sizing: border-box;
    padding: 10px 14px;
    border: 1px solid #b0b0b0;
    color: #000;
}
 .box-blockquote{
    margin-top: 50px;
}
blockquote {
    background: #fafafa;
    padding: 20px 40px 20px 140px;
    position: relative;
    color: #666;
}
.box-blockquote blockquote p{
    margin-top: 0;
   font-size: 15px;
    line-height: 36px;
    font-weight: 500;
}
  blockquote:before{
    content: "";
    position: absolute;
    top: 40px;
    left: 30px;
    background: url("../img/shared/blockquote.png") no-repeat center / cover;
    width: 86px;
    height: 70px;
}
ul.footer-link> li a{
    font-weight: bold;
    position: relative;
    padding-left: 10px;
}
ul.footer-link> li + li{
    margin-top: 30px;
}
ul.footer-link> li a:before{
    content: "";
    position: absolute;
    top: 5px;
    left: 0;
    background: url("../img/shared/arrow1.png") no-repeat center;
    width: 6px;
    height: 9px;
}
ul.footer-link li ul li a:before{
    display: none;
}
ul.footer-link> li ul li a{
    font-weight: 500;
    font-size: 14px;
}
 ul.footer-link li ul li{
    margin-top: 0;
}
.sidebar{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.sidebar .item{
    max-width: 330px;
    width: 100%;
}
h3.ttl-sidebar{
    font-family: 'Open Sans', sans-serif;
    font-size: 25px;
    line-height: 25px;
    border-bottom: 1px solid #44a6e5;
    color: #44a6e5;
    padding-bottom: 20px;
    margin-bottom: 20px;
}
.link-sidebar li{
    padding-left: 20px;
}
.link-sidebar a{
    position: relative;
}
.link-sidebar a:before{
    content: "";
    position: absolute;
    left: -15px;
    top: 4px;
    background: url("../img/shared/arrow2.png") no-repeat center / cover;
    color: #44a6e5;
    width: 7px;
    height: 8px;
}
.link-sidebar  a.link:before,
.tagcloud a:before{
    display: none;
}
.link-sidebar .tagcloud{
    padding-left: 20px;
}
.tagcloud a {
    display: inline-block;
    padding: 7px 10px;
    color: #666666;
    font-size: 14px !important;
    line-height: 1;
    border: 1px solid #cccccc;
    border-radius: 3px;
    transition: all .3s ease;
    -webkit-transition: all .3s ease;
    margin-bottom: 9px;
    letter-spacing: 0;
}
.tagcloud a.active,
.tagcloud a:hover{
    background: #eeeeee;
    text-decoration: none;
}
.tagcloud.on span{
    display: block;
    margin-top: 30px;
    color: #666666;
    font-size: 15px;
}

.toggle{
    margin-top: 25px;
    background: #f3fafc;
}
.toggle .toggle-link{
     padding: 20px 30px;
    font-size: 18px;
    font-weight: 500;
    color: #333;
}
.toggle .toggle-main{
    padding: 0 70px 50px;
    font-size: 15px;
    color: #666;
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif;
}
.toggle .toggle-link span{
    /* font-family: 'Open Sans', sans-serif; */
    font-family: a-otf-ud-shin-go-pr6n, sans-serif;
    font-weight: bold;
    text-shadow: 0px 0px 0px #009be4, 0px 0px 0px #009be4, 0px 0px 0px #009be4;
    font-size: 30px;
    line-height: 36px;
    text-transform: uppercase;
    /* color: #0ba2c7; */
    color: #009be4;
    margin-right: 15px;
}
.toggle .toggle-link:before{
    content: "";
    position: absolute;
    top: 20px;
    right: 30px;
    background: url("../img/shared/hidde.png") no-repeat center / cover;
    width: 32px;
    height: 32px;
    transition: background .5s;
}
.toggle.active .toggle-link:before{
    background: url("../img/shared/show.png") no-repeat center / cover;
}
.toggle .toggle-main a{
    color: #009be4;
    text-decoration: underline;
    position: relative;
    margin-left: 30px;
}
.toggle .toggle-main a:before{
    content: "";
    position: absolute;
    top: 5px;
    left: -15px;
    border-top: 3px solid transparent;
    border-bottom: 3px solid transparent;
    border-left: 7px solid #009be4;
}

@media all and (max-width: 767px){
    #bread ul{
        margin: 10px 0 30px;
    }
    h2{
        font-size: 25px;
        line-height: 33px;
    }
   h3{
        margin-top: 40px;
        font-size: 20px;
        line-height: 25px;
    }
    h4,
    h5{
        font-size: 18px;
    }
    .bx-table table th, #style .bx-table table td{
        padding: 15px 10px 10px 10px;
    }
    .btn-style3 {
        padding: 10px 15px;
    }
    .btn-style3,
    .btn-style3:hover,.btn-style3.active{
        background-position: right 15px center;
    }
    .pagination img{
        width: auto;
    }
    .box-btn{
        display: block;
    }
    .box-btn .btn-eff{
        display: block;
        margin-bottom: 15px;
    }
   blockquote{
        padding: 20px 15px 20px 67px;
    }
     blockquote:before{
        width: 42px;
        height: 28px;
        top: 20px;
        left: 10px;
    }
    ul.footer-link> li a{
        font-size: 14px;
    }
    ul.footer-link> li ul li a{
        font-size: 12px;
    }
     ul.footer-link> li + li{
        margin-top: 10px;
    }
     .toggle .toggle-link span img{
        width: auto;
    }
    .toggle .toggle-link{
        padding: 15px 45px 15px 15px;
    }
   .toggle .toggle-link:before{
        right: 10px;
    }
    .toggle .toggle-main{
        padding: 0 20px 40px 55px;
    }
}


