@charset "utf-8";

/*     defolt_css     */
body {
    font-family: 'Noto Sans JP', "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    padding: 0;
    color: #333;
}

/*     defolt_css     */


/*     reset css      */
html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
    display: block;
}

nav ul {
    list-style: none;
}

blockquote,
q {
    quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
    content: '';
    content: none;
}

a {
    margin: 0;
    padding: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
}

p {
    font-size: 1.1764705882352942vw;
    line-height: 2.35;
    font-size: 15px;
}

img {
    vertical-align: bottom;
}

/*     reset css      */

.sp {
    display: none;
}

.sp_nav {
    display: none;
}

.header_wrap {
    width: 100%;
    height: 100px;
    top: 0;
    position: fixed;
    margin: 0;
    z-index: 99;
    background: none;
    border-bottom: solid 1px #fff;
}

.header_wrap.page {
    width: 100%;
    height: 100px;
    top: 0;
    position: fixed;
    margin: 0;
    z-index: 99;
    background: none;
    border-bottom: solid 1px #333;
    background: #fff;
}

.header-inner {
    display: flex;
}

.header_menu_wrap {
    display: flex;
    flex-direction: column;
    width: 100%;
    align-items: flex-end;
    justify-content: center;
    padding: 0 25px;
}

.logo {
    width: 58px;
    margin-left: 17px;
    padding: 21.2px 0;
    z-index: 99;
}

.pc_nav li {
    top: 0;
    float: left;
    text-align: center;
    position: relative;
    font-family: "Outfit", sans-serif;

}

a.gnav {
    margin: 0 10px;
    color: #fff;
}

.btn_wrap {
    display: flex;
    align-items: center;
    margin-bottom: 5px;
}

.header_menu_wrap {
    display: flex;
    flex-direction: column;
    width: 100%;
    align-items: flex-end;
    justify-content: center;
    padding: 0 25px;
}

a.contact_btn {
    font-family: "Outfit", sans-serif;
    border: solid 1px;
    padding: 5px 40px;
    margin-left: 10px;
    border-radius: 20px;
    color: #fff;
}

.indta_wrap a {
    display: flex;
    align-items: center;
}

footer {
    background: #333;
}

a.arrow {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.logo_wrap {
    display: flex;
    align-items: center;
}

.footer_ttl {
    margin-left: 5%;
}

h2.footer_h2 {
    font-size: 25px;
    font-family: "Outfit", sans-serif;
    font-weight: 500;
    color: #fff;
    text-transform: uppercase;
}

.footer_menu_wrap {
    display: flex;
    justify-content: space-between;
}

.footer_menu_list {
    width: 31%;
}

.footer_menu_list.right {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.footer_menu_list a {
    color: #fff;
}

.menu_wrap {
    padding: 13px 0;
    border-bottom: solid 1px #4A4A4A;
}

a.arrow span {
    display: flex;
}

.footer_contact {
    display: flex;
    margin-left: auto;
    align-items: center;
}

p.copyright {
    color: #fff;
    font-size: 13px;
    padding: 30px 0;
}

.page_wrap {
    padding-top: 100px;
}

.header_menu_wrap.page a {
    color: #333 !important;
}

.page_mv .mv {
    width: 55%;
    margin-left: auto;
}

.left_txt_h1 {
    position: absolute;
    width: 73.52941176470588vw;
    margin: auto;
    left: 50%;
    transform: translate(-50%, -0%);
}

h1.default {
    font-family: "Outfit", sans-serif;
    font-size: 50px;
    font-weight: 500;
    text-transform: uppercase;
}

h1.default span {
    display: flex;
    flex-wrap: nowrap;
    font-size: 16px;
    font-weight: 500;
    font-family: 'Noto Sans JP', "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

h1.default span img {
    width: 20px;
    margin-right: 4px;
}

/********* CTA *********/

section.cta_wrap {
    background: url(../img/common/cta_bg.jpg);
    background-size: cover;
    background-position: center;
}

.cta.h2_wrap {
    align-items: flex-start;
}

.cta {
    width: 710px;
    margin: auto;
}

h2.default.cta {
    color: #fff;
    width: auto;
    margin-left: 0;
    margin-bottom: 40px;
}

h2.default.cta span {
    margin-bottom: 15px;
}

.cta_p_box {
    margin-top: 30px;
}

.cta_p_box p {
    color: #fff;
}

.cta_btn_wrap {
    width: 340px;
}

/********* CTA *********/

/********* パンくず *********/

.page_links {
    border-top: solid 1px;
    background: #222;
}

div#breadcrumb {
    max-width: 1080px;
    width: 90%;
    margin: auto;
}

#breadcrumb li {
    position: relative;
    float: left;
    padding: 8px;
    margin-top: 7px;
    line-height: 1;
    display: inline-block;
    font-size: 14px;
    text-decoration: underline;
    color: #828282;
}

#breadcrumb li a {
    color: #828282;
}

#breadcrumb li:not(:first-child):before {
    content: "/";
    position: absolute;
    left: -2.5px;
    font-size: 15px;
    top: 7px;
}

#breadcrumb li:last-child {
    text-decoration: none;
}

/********* パンくず *********/

/*********    SP    ********/

@media (max-width: 767px) {

    p {
        font-size: 4.102564102564102vw;
    }

    .sp {
        display: block;
    }

    .pc {
        display: none !important;
    }

    .sp_nav {
        display: block;
    }

    .header_menu_wrap {
        display: none;
    }

    .header_wrap {
        height: 75px;
        border-bottom: none;
    }

    .header_wrap.page {
        height: 75px;
    }

    .page_wrap {
        padding-top: 75px;
    }

    .menu_bars {
        content: url(../img/common/sp/menu_i.svg);
        width: 31px;
        height: 22.5px;
        padding: 0;
    }

    .menu_bars.menu_times,
    .header_wrap.page .menu_bars.menu_times {
        content: url(../img/common/sp/time_i.svg);
        width: 31px;
        height: 22.5px;
        padding: 0;
    }

    .header_wrap.page .menu_bars {
        content: url(../img/common/sp/menu_ib.svg);
        width: 30px;
        height: 22.5px;
        padding: 0;
    }

    .logo {
        width: 53px;
        margin-left: 10px;
        padding: 10.55px 0;
        z-index: 99;
    }

    #smart-nav {
        display: none;
    }

    .smart-nav {
        position: fixed;
        padding: 0;
        height: 100vh;
        width: 100%;
        left: 0;
        background: #333;
    }

    #navbutton {
        position: absolute;
        top: 0;
        width: unset;
        margin: 0 0 0 0;
        padding: 22px 14.8px;
        right: 0;
        background: unset;
        border: none;
    }

    .menu-item {
        width: 80%;
        margin: 0 0 0 10%;
        position: relative;
    }

    .smart-nav ul {
        margin: 120px 0 0;
        padding: 0;
        list-style: none;
    }

    .smart-nav li a:hover {
        opacity: 0.8;
    }

    nav.g_nav {
        display: none;
    }

    nav#header-nav {
        display: none;
    }

    .smart-nav li a {
        font-size: 4.5vw;
        padding: 15px 5px 10px 15px;
        text-align: left;
        display: flex;
        align-items: center;
        padding-left: 25px;
        position: relative;
    }

    .smart-nav li a:before {
        content: "";
        position: absolute;
        width: 5px;
        height: 1px;
        left: 15px;
        background: #fff;
    }

    svg#_レイヤー_1 {
        width: 80%;
    }

    .logo_wrap {
        flex-direction: column;
    }

    footer .logo {
        margin: 30px 0 10px 0;
        margin-left: 0;
        max-width: 73px;
        width: 73px;
    }

    h2.footer_h2 {
        font-size: 13px;
        letter-spacing: 0;
    }

    .contact.sp a.contact_btn {
        position: relative;
        margin-left: 0;
    }

    .contact.sp a.contact_btn:after {
        content: "";
        position: absolute;
        top: 50%;
        right: -15px;
        width: 30px;
        height: 1px;
        background: #fff;
    }

    .contact.sp a.contact_btn:hover::after {
        right: -5px;
    }

    footer .contact.sp {
        width: 175px;
        margin: 20px auto 0;
        text-align: center;
    }

    p.copyright {
        text-align: center;
        padding: 30px 0 10px;
    }

    footer .indta_wrap {
        width: 35px;
        margin: 15px auto 0;
    }

    .cta {
        width: 90%;
    }

    .cta.h2_wrap {
        width: 100%;
    }

    h2.default.cta {
        color: #fff;
        width: auto;
        margin-left: 0;
        margin-bottom: 0;
    }

    .cta_p_box {
        margin-top: 30px;
        margin-bottom: 20px;
    }

    .cta_btn_wrap {
        width: 100%;
        margin: auto;
    }

    .page_mv .default.h2_wrap {
        flex-direction: column-reverse;
    }

    .page_mv .mv {
        width: 94%;
        margin-left: auto;
    }

    .left_txt_h1 {
        position: relative;
        width: 100%;
    }

    .left_txt_h1 {
        position: relative;
        width: 95%;
        margin-top: 20px;
    }

    h1.default span {
        margin-top: 8px;
    }

    .footer_menu_wrap {
        flex-direction: column;
    }

    .footer_menu_list {
        width: 93%;
        margin: auto;
    }

    table.form_tbl.rec {
        width: 100%;
    }


}

/*********    SP    ********/