@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: bottom;
    max-width: 100%;
    height: auto;
    display: block;
}

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 */

p {
    font-feature-settings: "palt";
}

section {
    margin: 0 auto;
}

#contents_top {
    max-width: 100%;
    padding: 0;
    margin-bottom: 3.6rem;
}
#contents_top::before {
    display: block;
    margin: 0;
    content: " ";
    height: 1.3rem;
    width: 100%;
    background-color: #e50012;
}

#contents_top .cont_wrap {
    max-width: 107.4rem;
    margin: 0 auto;
}
#contents_top .cont_wrap .main_ph {
    
}

#contents_top .title_box,
#contents_top .top_cont_box,
section {
    max-width: 78rem;
    margin: 0 auto;
}

#contents_top .title_box {
    padding: 3rem 0 0;
}
#contents_top .title_box img {
    margin: 0 auto;
}

#contents_top .top_lead_wrap {
    max-width: 78rem;
    margin: 1em auto;
}
#contents_top .top_lead_wrap .lead_txt {
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 3.4rem;
}

#contents_top .top_lead_wrap .sub_txt {
    background-color: #d0d0d0;
    font-size: 1.6rem;
    line-height: 3.2rem;
    padding: 1em;
    margin-top: 1em;
}

/* Section block Start */


section .sec_01,
section .sec_02,
section .sec_03, 
section .sec_04 {
    display: flow-root;
    padding: 0;
}

section .sec_03, 
section .sec_04 {
    margin-top: 4rem;
}

section.sec_wrap h2 {
    max-width: 78rem;
    margin-bottom: 4rem;
}
section.sec_wrap h2.sec_tit_box {
    display: flex;
    justify-content: center;
}


section.sec_wrap .float_left {
    float: left;
    max-width: 45.5rem;
    margin-right: 1em;
    margin-bottom: 1em;
}

section.sec_wrap p {
    font-size: 1.6rem;
    line-height: 2em;
    padding-bottom: 1.6rem;
}

section.sec_wrap p span {
    font-weight: 600;
    padding-right: 1em;
}
section.sec_wrap p .intv_q {
    color: #7d7d7d;
}

section.sec_wrap .sec_ph {
    max-width: 58.8rem;
    margin: 1.6rem auto 0;
}

section .sub_sec_wrap {
    margin: 3rem auto 2rem;
}
section .sub_sec_wrap h3 {
    font-size: 1.4rem;
    font-weight: bold;
    text-align: center;
    background-color: #d0d0d0;
    padding: 0.3rem 0;
}
section .sub_sec_wrap ul {
    margin-top: 1rem;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
section .sub_sec_wrap li {
    display: block;
    max-width: 38rem;
    border: #000 1px solid;
    margin-bottom: 1rem;
}
section .sub_sec_wrap li h4 {
    font-size: 1.4rem;
    font-weight: bold;
    color: #fff;
    background-color: #e50012;
    padding: 0.3em 0 0.3em 1em;
}
section .sub_sec_wrap li p {
    font-size: 1.4rem;
    line-height: 2.6rem;
    color: #4c4948;
    padding: 1em;
}


section.sec_devider_box {
    max-width: 100%;
    background-color: #d0d0d0;
    margin-top: 1em;
}
section.sec_devider_box .sec_dev_ph {
    max-width: 78rem;
    margin: 0 auto;
}

section.sec_devider_box .sec_dev_ph img {
    margin: 0 auto;
}

section .bnr_box {
    margin-top: 0.5em;
}

/* Section end */

section.last_sec_wrap {
    max-width: 100%;
    background-color: #d0d0d0;
    padding: 3.5rem 0;
    margin: 5rem 0 2rem;
}

section.last_sec_wrap .info_box {
    margin: 0 auto;
    display: block;
}
section.last_sec_wrap .info_box li {
    width: 100%;
    display: flex;
    justify-content: center;
    line-height: 0;
    margin-bottom: 1em;
}
section.last_sec_wrap .info_box li:last-child {
    margin-top: 2em;
    margin-bottom: 0;
}

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

/* 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: 799px) {
  .dpc {
    display: none !important;
  }
}

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

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


/* Print CSS */
@media print {
    .dsp {
        display: none !important;
    }
    br.sp {
        display: none;
    }
    body {
        width: 100%; /* 全体の幅を100%に */
        margin: 0;
        padding: 0;
    }
    #contents_top .cont_wrap {
        padding: 0 5vw;
    }
    section {
        max-width: 78rem;
    }
    section.sub_sec .sec_box li {
        max-width: 49vw;
    }
    section .sub_sec_wrap li {
        max-width: 49%;
    }
    section.sec_devider_box {
        background-color: #d0d0d0;
    }
    section.sec_devider_box .sec_dev_ph img {
        width: 95%;
    }
    .btn_top {
        display: none;
    }
}

/* SP CSS */


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


@media screen and (max-width: 799px) {
    
    #contents_top .cont_wrap,
    #contents_top .top_lead_wrap {
        padding: 0 5vw;
    }

    #contents_top .top_cont_box .lead_txt p  {
        font-size: 1.6rem;
        line-height: 2em;
    }
}



@media screen and (max-width: 799px) {
    
    #contents_top .title_box {
        padding: 2rem 0 1rem;
    }
    #contents_top .top_lead_wrap .lead_txt {
        font-size: 1.7rem;
        line-height: 3rem;
    }
    section.sec_wrap,
    section.last_sec_wrap {
    margin: 0 auto;
    padding: 0 5vw;
    }
    
    section.sub_sec .sec_box {
        display: block;
    }
    section.sub_sec .sec_box li {
        max-width: 90vw;
    }
    section.sub_sec .sec_box li:first-child {
        margin-bottom: 4rem;
    }
    
    section.sec_wrap h2 {
        max-width: 90vw;
        margin-bottom: 2rem;
    }
    
    section.sec_wrap p {
        line-height: 1.8em;
    }
    
    section.sec_wrap h2.sec_tit_box {
        display: block;
    }
    
    section.sec_wrap h2.sec_tit_box img {
        max-width: 90vw;
    }
    
    section.sec_wrap .float_left {
        float: none;
        margin: 0 0 2rem;
        max-width: 90vw;
    }
    
    section .sub_sec_wrap li {
        max-width: 100%;
    }
    
    section .sec_01,
    section .sec_02,
    section .sec_03, 
    section .sec_04 {
        margin: 2rem auto;
    }
    section .sec_03 {
        margin-top: 3rem;
    }
    section .sec_03 {
        margin-bottom: 0rem;
    }
    section .sec_04 {
        margin-top: 0rem;
    }
    section .sec_02 .sec_dev_ph {
        margin-top: 1em;
    }
    
    section.last_sec_wrap {
        margin-top: 3rem;
        margin-bottom: 2rem;
    }
    section.last_sec_wrap .info_box {
        width: 100%;
        padding: 3rem 0;
    }
    
}


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