@charset "utf-8";
/* Reset */
/*
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  margin-top: 0;
  margin-right: 0;
  margin-left: 0;
  margin-bottom: 0;
  padding-top: 0;
  padding-right: 0;
  padding-left: 0;
  padding-bottom: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  height: auto;
  width: auto;
}
*/


p,ul,li,figure,h1, h2, h3, h4 {
    margin: 0;
    padding: 0;
}

div,
p,
small,
section,
figure {
    display: block;
}

html {
    font-size: 100%;
}

img {
    border: 0;
    vertical-align: top;
    max-width: 100%;
    height: auto;
}

li {
  list-style-type: none;
}

/* common */

a h3,
a img,
a {
  transition: 0.3s;
  opacity: 1;
}

a h3:hover,
a img:hover,
a:hover {
  transition: 0.3s;
  opacity: 0.7;
}

a,a:hover {
    text-decoration: none;
}

html {
    font-size: 62.5% !important;
    scroll-behavior: smooth;
}

body {
    width: 100%;
    font-family: "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Roboto, "Segoe UI", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    margin: 0;
    text-align: justify;
    word-break: break-all;
    overflow-wrap: break-word;
    word-wrap: break-word;
}

body {
    font-size: 16px;
    color: #000;
    margin: 0 auto;
    background-color: #fff;
}

.serif {
    font-family:
    "ヒラギノ明朝 ProN W3",
    "Hiragino Mincho ProN",
    "游明朝",
    "Yu Mincho",
    "MS P明朝",
    "MS PMincho",
    serif;
}

/* font controll class */

.norm_weight {
    font-weight: normal;
}

strong {
    font-weight: bold;
}

sub {
    font-size: 0.8em;
    vertical-align: bottom;
    position: relative;
    top: -0.15em;
}

/* headder */

/* SNS LINK */
.social_buttons {
    background-color: #333;
    padding: 7px 0 1px;
    text-align: center;
    position: relative;
    z-index: 1;
}
.social_buttons li {
    display: inline-block;
    float: none;
    vertical-align: top;
}

/* contents */

section {
    max-width: 107.4rem;
    margin: 0 auto;
}

#contents_top {
    background-color: #503b21;
}

#contents_top .cont_wrap {
    margin: 0 auto;
    padding-bottom: 0.5rem;
}

#contents_top .top_cont_box {
    padding-top: 0.5em;
}

#contents_top .lead_txt {
}

#contents_top .lead_txt p {
    max-width: 90rem;
    font-size: 1.8rem;
    font-weight: bold;
    color: #fff;
    line-height: 3.4rem;
    text-align: center;
    margin: 0 auto;
    padding-bottom: 1.5rem;
}

#contents_top .lead_txt small {
    display: block;
    max-width: 78rem;
    font-size: 1.2rem;
    color: #fff;
    padding-bottom: 0.5rem;
    text-align: right;
    line-height: 1.7rem;
    margin: 0 auto;
}

/* Section block Start */

section.sec_01
section.sec_02,
section.sec_03,
section.sec_04,
section.sec_05,
section.sec_end {
    max-width: 107.4rem;
    margin: 0 auto;
    padding: 0.5rem 0 0;
}

section h2 {
    text-align: center;
    background: url("sec_tit_bg.svg");
    background-position: center;
    background-repeat: no-repeat;
    background-size: 78.2rem auto;
    padding: 12rem 0 2.5rem;
    margin: 0.5em auto;
}

section p {
    max-width: 78rem;
    margin: 0 auto;
    font-size: 1.6rem;
    line-height: 3.2rem;
}

section .sec_ph {
    max-width: 73rem;
    display: flex;
    justify-content: space-between;
    padding: 2.5rem 2.5rem 0;
    margin: 3rem auto 0;
    background-color: #a58c72;
    border: #a58c72 0 solid;
    border-radius: 1.5rem;
}

section .sec_ph figure {
    max-width: 35.5rem;
}

section .sec_ph figcaption {
    text-align: center;
    font-size: 1.45rem;
    line-height: 1.7rem;
    padding: 1em 0;
    color: #fff;
}


section.sec_05 {
    background-color: #dadada;
    margin: 4rem auto 0;
    padding: 4rem 0;
}

section.sec_05 h2 {
    color: #1f2c5c;
    text-align: center;
    background-image: none;
    padding: 0;
    margin: 0;
}

section.sec_05 p {
    font-size: 1.6rem;
    color: #1f2c5c;
    line-height: 3.2rem;
}

section.sec_05 .sec_ph {
    background-color: #dadada;
    border: none;
    border-radius: 0;
    padding: 0;
}

section.sec_05 .official_link {
    display: block;
    text-align: center;
    margin-top: 4rem;
}

/* Section end */

section.sec_end_dit_box {
    background: #1f2c5c;
    margin: 0 auto;
    padding: 4rem 0;
    color: #fff;
}

section.sec_end_dit_box p {
    
    font-size: 1.6rem;
    font-weight: 700;
}
section.sec_end_dit_box figure {
    display: block;
    margin-bottom: 2rem;
    text-align: center;
}
section.sec_end_dit_box figure .logo_link {
    
}
section.sec_end_dit_box .info_box {
    text-align: center;
}
section.sec_end_dit_box .info_box h4 {
    font-size: 1.8rem;
    line-height: 3.2rem;
}
section.sec_end_dit_box .info_box p {
    max-width: 71rem;
    text-align: left;
    font-size: 1.5rem;
    line-height: 3.2rem;
    font-weight: normal;
}
section.sec_end_dit_box .info_box .txt_link {
    margin: 2rem 0;
    line-height: 3.2rem;
}
section.sec_end_dit_box .info_box .txt_link a {
    color: #fff;
}
section.sec_end_dit_box .info_box a.official_link {
    display: block;
    margin: 2rem auto;
}

.btn_top {
    width: 6rem;
    height: 6rem;
    display: block;
    margin: 0 auto;
    padding: 6rem 0 6rem;
}

/* footer */
#footer {
    max-width: 100%;
    display: block;
    background: #ffff;
    padding-top: 1em;
}
#footer div.localFooter {
    display: block;
    text-align: center;
    max-width: 94rem;
}
#footer #bpGlobalFooter {
    max-width: 94rem;
    text-align: center;
}

#footer #bpGlobalFooter.globalFooter ul li {
    padding-left: 0.5rem;
}


/* Devaice Switching */
@media screen and (max-width: 699px) {
  .dpc {
    display: none !important;
  }
}

@media screen and (min-width: 700px) {
  .dsp {
    display: none !important;
  }
}

br.pc {
  display: block;
}
@media screen and (max-width: 699px) {
  br.pc {
    display: none;
  }
}
br.sp {
  display: none;
}
@media screen and (max-width: 699px) {
  br.sp {
    display: block;
  }
}

/* Print CSS */
@media print {
    .dsp {
        display: none !important;
    }
    br.sp {
        display: none;
    }
    .header_logo {
        width: 21rem !important;
    }
    .header_wrap {
        padding: 0.955rem 0 !important;
    }
    .header_pr {
        width: 4rem !important;
    }
}


/* SP CSS */

@media screen and (max-width: 999px) {
    #contents_top .top_cont_box {
        padding: 0.5em 5vw 0;
    }
}

@media screen and (max-width: 959px) {
    #footer {
        padding: 1em;
    }
}

@media screen and (max-width: 899px) {
    section.sec_01,
    section.sec_02,
    section.sec_03,
    section.sec_04,
    section.sec_05,
    section.sec_end_dit_box {
        margin: 0 auto;
        padding: 0.5rem 5vw 0;
    }
    section.sec_04,
    section.sec_05,
    section.sec_end_dit_box {
        padding: 4rem 5vw;
    }
    section.sec_04 {
        padding-top: 0;
    }
    section .sec_ph {
        display: block;
    }
    section .sec_ph figure {
        max-width: 100%;
        margin-bottom: 0.8em;
    }
    section .sec_ph figcaption {
        padding: 0.5em 0.1em;
    }
}

@media screen and (max-width: 699px) {
    section h2 {
        padding: 10rem 0 4.5rem;
    }
    #contents_top .lead_txt p {
        text-align: left;
        font-weight: normal;
    }
    #contents_top .top_sub_txt {
        padding: 1em 2em;
    }
    
    #contents_top .top_cont_box .top_lead_sub p {
        line-height: 1.6em;
    }
    
    section.sec_05 h2 {
        font-size: 2rem;
        margin: 0 auto;
        padding-bottom: 0.5em;
    }
    
    section.sec_05 .official_link {
        margin: 0 auto;
        padding: 3rem 0 0;
    }
    
    section.sec_end_dit_box figure {
        padding: 0;
        align-items: center;
    }
    section.sec_end_dit_box figure div {
        width: 90vw;
        text-align: center;
    }

    section.sec_end_dit_box figure .logo_link img {
        width: 25em;
    }
    section.sec_end_dit_box .info_box a.official_link {
        margin: 0 auto;
        padding: 2.5rem 0;
        max-width: 90%;
    }
    section.sec_end_dit_box .info_box a.official_link.last {
        padding-bottom: 0;
    }
    .btn_top {
        padding: 3rem 0;
    }
}

@media screen and (max-width: 579px) {
    section.sec_end_dit_box figure .logo_link img {
        width: 70vw;
    }
}

@media screen and (max-width: 399px)  {
    small {
        font-size: 0.75em;
    }
}