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

背景

------------------------*/
.wrap {
    width: 1170px;
    margin: auto;
}

.wrap-94 {
    width: 94%;
    max-width: 1600px;
    margin: auto;
}

@media screen and (max-width: 1279px) {
    .wrap, .wrap-94 {
        width: 960px;
        margin: auto;
    }
}

@media screen and (max-width: 1023px) {
    .wrap, .wrap-94 {
        width: 720px;
    }
}

@media screen and (max-width: 767px) {
    .wrap, .wrap-94 {
        width: auto;
        min-width: 272px;
        margin: 0 24px;
    }
}

.section {
    padding: 32px 0;
}

@media screen and (max-width: 767px) {
    .section {
        padding: 16px 0;
    }
}

.unit {
    margin-bottom: 32px;
}

@media (max-width: 767px) {
    .unit {
        margin-bottom: 16px;
    }
}

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

テーブル

------------------------*/
@media screen and (max-width: 767px) {
    .scroll-table {
        overflow: auto;
        white-space: nowrap;
    }

    .scroll-table:after {
        content: "※このテーブルは横にスクロールできます。";
        font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Yu Gothic", YuGothic, Verdana, Meiryo, "M+ 1p", sans-serif;
        font-size: 14px;
        color: #c3c3c3;
    }

    .scroll-table table {
        margin-bottom: 8px;
    }
}

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

ボタン

------------------------*/
/*
.button, .button:active, .button:focus {
    padding: 24px 100px;
    border-radius: 0;
    border-radius: 70px;
    background-color: #e96ec9;
    position: relative;
    display: inline-block;
    font-size: 16px;
    font-weight: 600;
    color: #fff;
    text-align: center;
    text-decoration: none;
}


@media (max-width: 1023px) {
    .button, .button:active, .button:focus {
        padding: 16px;
        display: block;
    }
}

.button::after {
    margin-top: -8px;
    content: "\f054";
    position: absolute;
    top: 50%;
    right: 1em;
    bottom: 0;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
}

.button:hover {
    opacity: .7;
    background-color: #cc36a5;
}

@media only screen and (max-width: 767px) {
  .button, .button:active, .button:focus {
    width: 100%;
    padding: 20px 8px;
    display: block;
  }
}
*/
input[type="submit"], input[type="button"] {
    cursor: pointer;
    border: none;
    border-radius: 0;
    -webkit-box-sizing: content-box;
    box-sizing: border-box;
    -webkit-appearance: button;
    appearance: button;
}

input[type="submit"]::-webkit-search-decoration, input[type="button"]::-webkit-search-decoration {
    display: none;
}

input[type="submit"]::focus, input[type="button"]::focus {
    outline-offset: -2px;
}

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

リスト

------------------------*/
.link li a {
    margin-left: 1em;
    display: block;
    text-decoration: none;
    text-indent: -1em;
}

.link li a:before {
    margin-right: .5em;
    content: "\f0da";
    font: normal normal normal 14px/1 FontAwesome;
    color: #e60013;
}

.list-mark li {
    position: relative;
}

.list-mark li::after {
    width: 6px;
    height: 6px;
    content: "";
    border-radius: 100%;
    background-color: #33b495;
    position: absolute;
    top: .6em;
    left: -1em;
    display: block;
}

.list-before li {
    padding-left: 2em;
    display: block;
    text-indent: -1em;
}

.list-before li:before {
    width: 1em;
    margin-right: 1em;
    margin-left: -1em;
    padding: 0;
    content: "\f061";
    display: block;
    float: left;
    font-family: "FontAwesome";
    color: #1e1e1e;
    text-align: center;
}

.list-after li {
    padding-right: 15px;
    position: relative;
}

.list-after li:after {
    margin-top: -12px;
    content: "";
    position: absolute;
    top: 50%;
    right: 10px;
    font-family: "FontAwesome";
    color: #007f2d;
}

.list-info {
    margin: 0;
}

.list-info li {
    margin-bottom: 8px;
    padding-left: 1em;
    list-style-type: none;
    display: block;
    font-size: 14px;
    text-indent: -.5em;
    text-align: left;
}

.list-info li:last-child {
    margin-bottom: 0;
}

.list-info li:before {
    width: .5em;
    margin-right: .5em;
    margin-left: -.5em;
    padding: 0;
    content: "※";
    display: block;
    float: left;
    text-align: center;
}

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

画像

------------------------*/
@media (min-width: 1025px) {
    a:hover img {
        opacity: .9;
        filter: alpha(opacity=90);
        -moz-opacity: .9;
    }
}

img {
    border: 0;
    vertical-align: bottom;
}

@media (min-width: 1279px) {
    img {
        max-width: 100%;
    }
}

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

google map

------------------------*/
@media screen and (max-width: 767px) {
    .gmap {
        height: 0;
        overflow: hidden;
        padding-bottom: 56.25%;
        position: relative;
    }

    .gmap iframe {
        position: absolute;
        left: 0;
        top: 0;
        height: 100%;
        width: 100%;
    }
}

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

Typography

------------------------*/
a {
    color: #0d0015;
}

a:hover {
    color: #2767c3;
}

@media(min-width: 768px) {
    a[href^="tel:"] {
        pointer-events: none;
    }
}

em, i {
    font-style: normal;
}

.red {
    color: #ca1b28;
}

h1, .h1, h2, .h2, h3, .h3 {
    line-height: 1.61;
}

@media only screen and (min-width: 768px) {
    .vertical-writing {
        -ms-writing-mode: tb-rl;
        -webkit-font-feature-settings: "pkna";
        font-feature-settings: "pkna";
        -webkit-writing-mode: vertical-rl;
        writing-mode: vertical-rl;
    }

    .vertical-writing b {
        -webkit-text-combine: horizontal;
        -ms-text-combine-horizontal: all;
        text-combine-upright: all;
        line-height: 0;
        letter-spacing: 0;
    }
}

.headlines {
    margin-bottom: 32px;
    padding-bottom: 24px;
    font-size: 32px;
    color: rgb(177, 146, 0);
    text-align: center;
}

@media screen and (max-width: 767px) {
    .headlines {
        margin-bottom: 16px;
        font-size: 29px;
    }
}

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

font-family

------------------------*/
@font-face {
    font-family: "Yu Gothic";
    font-weight: 100;
    src: local("Yu Gothic Medium");
}

@font-face {
    font-family: "Yu Gothic";
    font-weight: 200;
    src: local("Yu Gothic Medium");
}

@font-face {
    font-family: "Yu Gothic";
    font-weight: 300;
    src: local("Yu Gothic Medium");
}

@font-face {
    font-family: "Yu Gothic";
    font-weight: 400;
    src: local("Yu Gothic Medium");
}

@font-face {
    font-family: "Yu Gothic";
    font-weight: bold;
    src: local("Yu Gothic Bold");
}

@font-face {
    font-family: "Helvetica Neue";
    font-weight: 100;
    src: local("Helvetica Neue Regular");
}

@font-face {
    font-family: "Helvetica Neue";
    font-weight: 200;
    src: local("Helvetica Neue Regular");
}

html, body {
    font-family: -apple-system, BlinkMacSystemFont, arial, "Helvetica Neue", "Yu Gothic", YuGothic, Verdana, Meiryo, "M+ 1p", sans-serif;
}

@media all and (-ms-high-contrast: none) {
    html, body {
        font-family: arial, Verdana, Meiryo, sans-serif;
    }
}

@media all and (-ms-high-contrast: active) {
    html, body {
        font-family: arial, Verdana, Meiryo, sans-serif;
    }
}

h1, h2, h3, h4, h5, h6 {
    font-family: -apple-system, BlinkMacSystemFont, arial, "Helvetica Neue", "Yu Gothic", YuGothic, Verdana, Meiryo, "M+ 1p", sans-serif;
}

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

フォントサイズ

------------------------*/
html {
    font-size: 62.5%;
}

body {
    font-size: 16px;
    font-weight: 400;
    line-height: 1.618;
    color: #0d0015;
    letter-spacing: .05em;
    /*word-break: keep-all;*/
    line-break: strict;
    word-wrap: break-word;
    overflow-wrap: break-word;
    font-feature-settings: "palt";
    -webkit-font-smoothing: antialiased;
}

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

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

レイアウト

------------------------*/
.flex-end {
    align-items: flex-end;
    justify-content: flex-end;
}

.is-center {
    margin: 0;
    justify-content: center;
}

@media screen and (min-width: 768px) {
    .is-row.is-center {
        margin-left: -24px;
    }
}

.is-middle {
    align-items: center;
}

@media screen and (min-width: 768px) {
    .order01 {
        order: 1;
    }

    .order02 {
        order: 2;
    }

    .order03 {
        order: 3;
    }

    .order04 {
        order: 4;
    }

    .order05 {
        order: 5;
    }
}

.img-centered img, .img-centered picture {
    margin: 0 auto;
    display: block;
    text-align: center;
}

.btn-centered {
    text-align: center;
}

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

表示・非表示

------------------------*/
@media only screen and (max-width: 1199px) {
    body .view_pc {
        display: none !important;
    }
}

@media only screen and (min-width: 1025px) {
    body .view_tab, body .view_tab-sp {
        display:none!important
    }
}

@media only screen and (max-width: 767px) {
    body .view_pc-tab, body .view_tab, body .view_tabl {
        display: none !important;
    }
}

@media only screen and (min-width: 768px) and (max-width: 983px) {
    body .view_tabl {
        display: none !important;
    }
}

@media only screen and (min-width: 768px) and (max-width: 983px) {
    body .view_tabs {
        display: none !important;
    }
}

@media only screen and (min-width: 768px) {
    body .view_sp {
        display: none !important;
    }
}

@media print {
    body .view_tab, body .view_tabl, body .view_tabs, body .view_tab-sp, body .view_sp {
        display: none!important
    }
}
