@charset "UTF-8";

/*-all-*/
body {
    font-family: "Zen Old Mincho", serif;
    font-weight: 400;
    font-style: normal;
    color: #DCDCDC;
    background-color: #2F4737;
}
.contents_inner {
    width: 1400px;
    max-width: 1400px;
}
.line {
    border: 1px solid #596C5F;
}
p {
    font-size:16px;
    font-weight:400;
    line-height: 3rem;
}
a img {
	transition : 0.2s;
	-webkit-transition :  0.2s;
	-moz-transition :  0.2s;
	-o-transition : 0.2s;
	-ms-transition :  0.2s;
}
a:hover img {
	opacity: 0.5;
}
header a img:hover {
    opacity: 1 !important;
}
a:hover {
	opacity: 0.5;
	text-decoration: none;
}
header a img:hover {
    opacity: 1 !important;
}
header a:hover {
    opacity: 1 !important;
}
@media screen and (max-width: 1400px) {
    .contents_inner {
        width: 90%;
    }
}
@media screen and (max-width: 640px) {
    p {
        font-size:13px;
        font-weight:400;
        line-height: 3rem;
    }
    .contents_inner {
        width: 90%;
    }
}
/*-TOP img-*/
#topimg_block {
    width: 100%;
    position: relative;
}
#topimg_block img {
    width:100%;
    object-fit:cover;
    object-position: top;
    height: 400px;
}
.page_title_box {
    position:relative;
}
.page_title_box .topomg_background_img h2 {
    font-size: 50px;
    font-weight: 400;
    letter-spacing: -0.05em;
    position: absolute;
    top: 2%;
    left: 2%;
    z-index: 10;
    display: flex;
    align-items: center;
    column-gap: 10px;
}
.topomg_background_img {
    background:url(../img/brand/prysm/bg_deco01.png);
    background-repeat: no-repeat;
    position: absolute;
    width: 100%;
    height: 600px;
    top: -75px;
}
@media screen and (max-width: 640px) {
    #topimg_block img {
        height: 200px;
    }
    .page_title_box  .topomg_background_img h2 {
        font-size: 5.6vw;
        top: 0;
        flex-direction: column;
        justify-content: center;
        align-items: flex-start;
        gap: 5px 0;
        height: 12vw;
    }
    .page_title_box .topomg_background_img h2 span {
        font-size: 3.2vw;
    }
    .topomg_background_img {
        background:url(../img/brand/bg_deco01_sp.png);
        background-repeat: no-repeat;
        background-size: contain;
        top: -12vw;
    }
}
/*-breadcrumbs-*/
#breadcrumbs {
    position: relative;
    margin: 35px 0 60px;
}
#breadcrumbs ul {
    display: flex;
    color: #97a39b;
    font-size: 13px;
}
#breadcrumbs ul li:not(:last-child)::after {
    content: ">";
    margin: 0 10px;
}
#breadcrumbs ul li a {
    color: #c1c8c3;
    text-decoration: underline;
}
@media screen and (max-width: 640px) {
    #breadcrumbs {
        margin: 20px 0 30px;
    }
    #breadcrumbs ul {
        font-size: 11px;
        width: 90%;
        margin: 0 auto;
    }
    #breadcrumbs ul li:not(:last-child)::after {
        margin: 0 5px;
    }
}
/*-intro_block-*/
#intro_block {
    position: relative;
    width: min(1400px, 90%);
    margin: 0 auto;
    padding: 100px 0;
    background: url(../img/brand/prysm/intro_bg.jpg) no-repeat center center/cover;
}
#intro_block .contents_inner {
    width: min(1100px, 90%);
    margin: 0 auto;
}
#intro_block img {
    width: min(950px,100%);
    display: block;
    margin: 0 auto 40px;
}
#intro_block p {
    width: min(750px,90%);
    margin: 0 auto;
    letter-spacing: 0;
    line-height: 1.875;
}
@media screen and (max-width: 640px) {
    #intro_block {
        padding: 50px 0;
    }
    #intro_block img {
        margin: 0 auto 20px;
    }
}
/*-menu-*/
#menu {
    width: min(1400px, 90%);
    padding: 40px 0;
    background: #dbe3dd;
    margin: 0 auto;
    border-bottom: 1px solid #2f4737;
}
#menu .contents_inner {
    width: min(1100px, 90%);
    margin: 0 auto;
}
#menu .row_box {
    align-items: center;
}
#menu .logo {
    width: 155px;
}
#menu ul {
    width: calc(100% - 155px);
    justify-content: center;
    gap: 60px;
}
#menu ul li a {
    display: block;
    color: #2f4737;
    font-size: 18px;
    line-height: 40px;
    padding-right: 50px;
    background: url(../img/brand/prysm/menu_arrow.svg) no-repeat right center/40px;
}
@media screen and (max-width: 1200px) {
    #menu .logo {
        width: 12.92vw;
    }
    #menu ul {
        width: calc(100% - 12.92vw);
        gap: 2.5vw;
    }
    #menu ul li a {
        font-size: 1.5vw;
        line-height: 3.33vw;
        padding-right: 4.17vw;
        background: url(../img/brand/prysm/menu_arrow.svg) no-repeat right center/3.33vw;
    }
}
@media screen and (max-width: 840px) {
    #menu .contents_inner > .row_box {
        flex-direction: column;
        row-gap: 20px;
    }
    #menu .logo {
        width: 155px;
    }
    #menu ul {
        width: min(450px,100%);
        gap: 40px;
    }
    #menu ul li a {
        font-size: 18px;
        line-height: 40px;
        padding-right: 50px;
        background: url(../img/brand/prysm/menu_arrow.svg) no-repeat right center/40px;
    }
}
@media screen and (max-width: 640px) {
    #menu {
        padding: 30px 0;
    }
    #menu .contents_inner > .row_box {
        row-gap: 15px;
    }
    #menu .logo {
        width: 120px;
    }
    #menu ul {
        width: min(380px,100%);
        gap: 20px;
    }
    #menu ul li a {
        font-size: 15px;
        line-height: 30px;
        padding-right: 35px;
        background: url(../img/brand/prysm/menu_arrow.svg) no-repeat right center/30px;
    }
}
/*-bg_color_box-*/
.bg_color_box {
    position: relative;
    width: min(1400px, 90%);
    margin: 0 auto;
    padding: 100px 0;
    border-bottom: 1px solid #2f4737;
    background: #dbe3dd url(../img/brand/bg_deco04.png) no-repeat center top/100%;
    color: #2f4737;
}
.bg_color_box .contents_inner {
    width: min(1100px, 90%);
    margin: 0 auto;
}
.bg_color_box h3 {
    font-size: 38px;
    font-weight: 500;
    line-height: 1.31;
    text-align: center;
    padding: 80px 0 30px;
    margin-bottom: 55px;
    position: relative;
    background: url(../img/brand/prysm/prysm_logo.png) no-repeat center top/155px;
}
.bg_color_box h3::after {
    content: "";
    position: absolute;
    width: 164px;
    height: 4px;
    background-color: #2f4737;
    bottom: 0;
    left: calc(50% - 82px);
}
.bg_color_box .inner:not(:last-child) {
    margin-bottom: 50px;
}
.bg_color_box .inner h4 {
    background: #007e40;
    color: #FFF;
    font-size: 22px;
    font-weight: 500;
    line-height: 1.4;
    text-align: center;
    padding: 15px 0;
    margin-bottom: 30px;
}
.bg_color_box .inner .ttl {
    font-size: 24px;
    font-weight: 500;
    line-height: 1.46;
    margin-bottom: 30px;
}
.bg_color_box .inner p {
    line-height: 1.875;
}
@media screen and (max-width: 840px) {
    .bg_color_box h3 {
        font-size: 32px;
    }
}
@media screen and (max-width: 640px) {
    .bg_color_box {
        padding: 50px 0;
        background: #dbe3dd url(../img/brand/bg_deco04.png) no-repeat center top/100%;
    }
    .bg_color_box h3 {
        font-size: 26px;
        padding: 50px 0 15px;
        margin-bottom: 30px;
        background: url(../img/brand/prysm/prysm_logo.png) no-repeat center top/110px;
    }
    .bg_color_box h3::after {
        width: 100px;
        height: 3px;
        left: calc(50% - 50px);
    }
    .bg_color_box .inner:not(:last-child) {
        margin-bottom: 30px;
    }
    .bg_color_box .inner h4 {
        font-size: 16px;
        padding: 10px 0;
        margin-bottom: 15px;
    }
    .bg_color_box .inner .ttl {
        font-size: 18px;
        margin-bottom: 15px;
    }
}
/*-sec01_block-*/
#sec01_block .copy {
    font-size: 20px;
    font-weight: 500;
    text-align: center;
    margin-bottom: 30px;
}
#sec01_block .text {
    width: 35%;
}
#sec01_block .image {
    width: 60%;
}
#sec01_block .note {
    font-size: 13px;
    font-family: "Noto Sans JP", sans-serif;
    line-height: 1.875;
    margin-top: 10px;
}
@media screen and (max-width: 840px) {
    #sec01_block .row_box {
        row-gap: 30px;
    }
    #sec01_block .text {
        width: 100%;
    }
    #sec01_block .image {
        width: 100%;
    }
}
@media screen and (max-width: 640px) {
    #sec01_block .copy {
        font-size: 16px;
        letter-spacing: -0.05em;
        margin-bottom: 15px;
    }
    #sec01_block .row_box {
        row-gap: 20px;
    }
    #sec01_block .note {
        font-size: 10px;
    }
}
/*--*/
#sec02_block .inner .row_box {
    flex-direction: row-reverse;
}
#sec02_block .inner .row_box .text {
    width: 47%;
    letter-spacing: -0.05em;
}
#sec02_block .inner .row_box .image {
    width: 50%;
}
@media screen and (max-width: 840px) {
    #sec02_block .inner .row_box {
        flex-direction: column;
        row-gap: 20px;
    }
    #sec02_block .inner .row_box .text {
        width: 100%;
    }
    #sec02_block .inner .row_box .image {
        width: 100%;
    }
}
@media screen and (max-width: 640px) {
    #sec02_block .flow {
        width: 260px;
        margin: 0 auto 30px;
    }
    #sec02_block .inner .row_box {
        row-gap: 15px;
    }
}
/*-sec03_block-*/
#sec03_block .inner:nth-of-type(1) img {
    display: block;
    width: min(550px,90%);
    margin: 0 auto;
}
#sec03_block .inner:nth-of-type(2) {
    flex-direction: row-reverse;
}
#sec03_block .inner:nth-of-type(2) .text {
    width: 47%;
}
#sec03_block .inner:nth-of-type(2) .image {
    width: 50%;
}
#sec03_block .inner:nth-of-type(3) .text {
    width: 37%;
}
#sec03_block .inner:nth-of-type(3) .image {
    width: 60%;
}
@media screen and (max-width: 840px) {
    #sec03_block .inner:nth-of-type(2) {
        flex-direction: column;
        row-gap: 20px;
    }
    #sec03_block .inner:nth-of-type(2) .text {
        width: 100%;
    }
    #sec03_block .inner:nth-of-type(2) .image {
        width: 100%;
    }
    #sec03_block .inner:nth-of-type(3) {
        flex-direction: column;
        row-gap: 20px;
    }
    #sec03_block .inner:nth-of-type(3) .text {
        width: 100%;
    }
    #sec03_block .inner:nth-of-type(3) .image {
        width: 100%;
    }
}
@media screen and (max-width: 640px) {
    #sec03_block .inner:nth-of-type(2) {
        row-gap: 15px;
    }
    #sec03_block .inner:nth-of-type(3) {
        row-gap: 15px;
    }
}
/*-#sec04_block-*/
#sec04_block .inner .text {
    width: 37%;
}
#sec04_block .inner .image {
    width: 58%;
}
@media screen and (max-width: 840px) {
    #sec04_block .inner {
        row-gap: 20px;
    }
    #sec04_block .inner .text {
        width: 100%;
    }
    #sec04_block .inner .image {
        width: 100%;
    }
}
@media screen and (max-width: 640px) {
    #sec04_block .inner {
        row-gap: 15px;
    }
}
