@charset "UTF-8";
@import url("https://fonts.googleapis.com/css?family=Work+Sans");

a,
a img {
    transition-duration: 0.5s;
}

a:hover,
a img:hover {
    transition-duration: 0.5s;
    opacity: 0.7;
    filter: alpha(opacity=70);
    -ms-filter: "alpha(opacity=70)";
}

#page-body {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.animated {
    animation-duration: 1s;
    animation-fill-mode: both;
}

@keyframes fadeIn {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

.fadeIn {
    animation-name: fadeIn;
}

@keyframes fadeInUp {
    0% {
        opacity: 0;
        transform: translateY(20px);
    }

    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

.fadeInUp {
    animation-name: fadeInUp;
}

@keyframes fadeInLeft {
    0% {
        opacity: 0;
        transform: translateX(-20px);
    }

    100% {
        opacity: 1;
        transform: translateX(0);
    }
}

.fadeInLeft {
    animation-name: fadeInLeft;
}

@keyframes slideInDown {
    0% {
        opacity: 0;
        transform: translateY(-2000px);
    }

    100% {
        transform: translateY(0);
    }
}

.slideInDown {
    animation-name: slideInDown;
}

.content_wrap {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-feature-settings: "palt";
    margin: 0 auto;
    padding: 0;
    font-smoothing: antialiased;
    font-size: 14px;
    line-height: 1.8 !important;
}

@media screen and (min-width: 980px) {
    .content_wrap {
        font-size: 18px;
    }
}

.content_wrap * {
    box-sizing: border-box;
}

@keyframes auto-fade_kf {
    0% {
        opacity: 1;
    }

    20% {
        opacity: 0;
    }

    60% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

/* Utility */
.u-none {
    display: none;
}

@media screen and (min-width: 980px) {
    .u-md-block {
        display: block;
    }
}

@media screen and (min-width: 768px) {
    .u-sm-block {
        display: block;
    }
}

@media screen and (min-width: 768px) {
    .u-sm-inline {
        display: inline;
    }
}

@media screen and (min-width: 980px) {
    .u-md-inline {
        display: inline;
    }
}

.u-table {
    display: table;
}

@media screen and (min-width: 980px) {
    .u-md-table {
        display: table;
    }
}

@media screen and (min-width: 480px) {
    .u-xs-none {
        display: none;
    }
}

@media screen and (min-width: 768px) {
    .u-sm-none {
        display: none;
    }
}

@media screen and (min-width: 980px) {
    .u-md-none {
        display: none;
    }
}




/*menu*/
.main_contents .main_body .main_block {
    background-color: #ffffff;
    padding-bottom: 3%;
    margin-bottom: 7%
}

#kt_navi_box {
    width: 100%;
    list-style: none;
    margin: 0 auto 0;
    overflow: hidden;
}

@media (max-width: 768px) {
    p-header__navigation #kt_navi_box {
        height: 298px;
        padding-bottom: 3px;
    }
}

.ini_navigation_pc {
    display: list-item;
}

.ini_navigation_sp {
    display: none;
}

@media (max-width: 768px) {
    .ini_navigation_pc {
        display: none;
    }

    .ini_navigation_sp {
        display: list-item;
    }
}

.fixed {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 9999;
}

#kt_navi_box.fixed {
    background: #ffffff;
}

@media (max-width: 768px) {
    #kt_navi_box.fixed {
        background: transparent;
    }
}

.fixed #fixedbox {
    max-width: 890px;
    margin-top: 0;
}

#fixedbox {
    max-width: 1400px;
    margin: auto;
    transition: 0.7s;
}

#fixedbox .p-header__navigation {
    width: 100%;
    max-width: 1400px;
    height: 57px;
    margin: 2% auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

@media (max-width: 768px) {
    #fixedbox .p-header__navigation {
        background: #ffffff;
    }
}

#fixedbox .p-header__navigation li {
    font-family: 游明朝, "Yu Mincho", YuMincho, Ryumin Medium KL, "リュウミン M-KL", "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, HiraMinProN-W3, HiraMinPro-W3, "ヒラギノ明朝 ProN W3", "ヒラギノ明朝 Pro W3", "ＭＳ 明朝", "Sawarabi Mincho", serif, Didot, Didot LT STD, Hoefler Text, Garamond, Times New Roman;
    font-size: 3em;
    font-weight: bold;
    color: #236785;
    /*border-top: solid 2px #d7d7d7;*/
    -webkit-flex: 0 1 33%;
    -ms-flex: 0 1 33%;
    flex: 0 1 33%;
    -webkit-flex: 0 1 calc(80% / 3);
    -ms-flex: 0 1 calc(80% / 3);
    flex: 0 1 calc(80% / 3);
    max-width: 375px;
    /*height: 90px;*/
    margin: 0 1%;
}

@media (max-width: 768px) {
    #fixedbox .p-header__navigation li {
        font-size: 1.5em;
        height: 40px;
        margin: 0 1%;
    }
}

#fixedbox .p-header__navigation a {
    position: relative;
}

#fixedbox .p-header__navigation li a {
    color: #236785;
}

.fixed #fixedbox .p-header__navigation {
    margin: 0 auto 0;
}

.fixed #fixedbox .p-header__navigation li {
    font-size: 2em;
    -webkit-flex: 0 1 33%;
    -ms-flex: 0 1 33%;
    flex: 0 1 33%;
    -webkit-flex: 0 1 calc(80% / 3);
    -ms-flex: 0 1 calc(80% / 3);
    flex: 0 1 calc(80% / 3);
}

@media (max-width: 768px) {
    .fixed #fixedbox .p-header__navigation li {
        font-size: 1em;
        height: 120px;
        max-width: 175px;
        min-width: 175px;
    }

    .fixed #fixedbox .p-header__navigation {
        height: 120px;
    }

    #kt_navi_box {
        height: 150px;
    }
}

@media (max-width: 560px) {
    .fixed #fixedbox .p-header__navigation li {
        height: 92px;
        max-width: 135px;
        min-width: 135px;
    }

    .fixed #fixedbox .p-header__navigation {
        height: 92px;
    }

    #kt_navi_box {
        height: 130px;
    }
}

@media (max-width: 480px) {
    .fixed #fixedbox .p-header__navigation li {
        height: 80px;
        max-width: 124px;
        min-width: 100px;
    }

    .fixed #fixedbox .p-header__navigation {
        height: 85px;
    }

    #kt_navi_box {
        height: 120px;
    }
}



@media (max-width: 768px) {
    #fixedbox .p-header__navigation li {
        -webkit-flex: 0 1 30%;
        -ms-flex: 0 1 30%;
        flex: 0 1 30%;
        -webkit-flex: 0 1 calc(90% / 3);
        -ms-flex: 0 1 calc(90% / 3);
        flex: 0 1 calc(90% / 3);
    }
}


/*initialJewelry*/
.item01 {
    background-color: #f7f7f3;
    width: 100%;
    padding: 2% 0 5% 0;
    margin: 0 auto;
}
.item01 .initial_inner .initial_flexbox {
    width: 90%;
    max-width: 1000px;
    margin: 0% auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    align-items: flex-end;
}
.item01 .initial_inner .initial_inner_l {
    width: 45.5%;
    margin: 0 4% 0 0;
    display: flex;
    flex-direction: column;
}
.initial_inner_l .hover-parent {
    width: 100%;
}
.p-main .item01 .initial_inner .initial_inner_l h3 {
    width: 100%;
    margin: 0 auto 9%;
}
.item01 .initial_inner .initial_inner_r {
    width: 50.5%;
    margin: 0% auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: space-between;
}

.item02 {
    background-color: #fff;
}
.item02 .initial_flexbox {
    flex-direction: row-reverse !important;
}
.item02 .initial_inner .initial_inner_l {
    margin: 0 0 0 4%;
}

.item03 {
    width: 100%;
    max-width: 1000px;
    margin: 5% auto 0;
}
.item03 .item {
    width: 90%;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
}
.item03 .item figure {
    width: 48%;
}
.item03 p {
    text-align: center;
    margin: 5% auto 8%;
    font-size: 1.05em;
    width: 90%;
}

@media (max-width: 768px) {
    .item01 {
    padding: 5% 0 8% 0;
 }
    .item03 .item figure {
        width: 46%;
    }
    .item03 p {
    text-align: left;
    margin: 8% auto 10%;
}
}

@media screen and (max-width: 768px) {
    .item01 {
        padding: 5% auto 4% auto;
    }
    .item01 .initial_inner .initial_inner_r {
        width: 100%;
        margin: 0 auto;
    }
    .item01 .initial_inner .initial_inner_l {
        width: 100%;
        margin: 0 auto;
    }
    .p-main .item01 .initial_inner .initial_inner_l h3 {
        margin: 8% auto 0;
    }
}


.item01 .initial_inner .initial_inner_r figure:nth-child(2n+0) {
    margin-right: 0;
}

.hover-parent {
    width: 46%;
    height: auto;
    position: relative;
    margin-bottom: 30px;
    overflow: hidden;
    margin: 8% 8% 0 0;
}
.initial_inner_r .hover-parent .hover-mask, .initial_inner_l .hover-parent .hover-mask,.item .hover-parent .hover-mask {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: rgba(0, 0, 0, 0.6);
    opacity: 0;
    color: #fff;
    display: flex;
    align-items: center;
    text-align: center;
    transition: all 0.6s ease;
}
.initial_inner_r .hover-parent .hover-mask a, .initial_inner_l .hover-parent .hover-mask a, .item .hover-parent .hover-mask a {
    color: #fff;
    width: 100%;
    display: inline-block;
    font-size: 1.2em;
    font-family: 'Noto Sans JP', sans-serif;
}
.initial_inner_r .hover-parent .hover-mask a span, .initial_inner_l .hover-parent .hover-mask a span,.item .hover-parent .hover-mask a span {
    letter-spacing: 0.1em;
}

.item .hover-parent {
    margin: 0;
}


.view_more {
    width: 46%;
    margin-top: 8%;
}
.view_more a {
    color: #fff;
    height: 100%;
    width: 100%;
    background-color: #06413b;
    font-family: 'Noto-sans', sans-serif;
    font-size: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
    position: relative;
}
.view_more a::after {
    content: '';
    width: 10px;
    height: 10px;
    border-top: solid 1px #fff;
    border-right: solid 1px #fff;
    position: absolute;
    right: 10%;
    top: 48%;
    transform: rotate(45deg);
}
.view_more a {
    text-decoration: none;
}

.initial_inner_r .hover-parent img {
    width: 100%;
}

.initial_inner_r .hover-parent .hover-mask:hover, .initial_inner_l .hover-parent .hover-mask:hover, .item .hover-parent .hover-mask:hover {
    opacity: 1;
    transition: all 0.6s ease;
}
.initial_inner_r .hover-parent .hover-mask a:hover, .initial_inner_l .hover-parent .hover-mask a:hover, .item .hover-parent .hover-mask a:hover {
    opacity: 1;
    text-decoration: none;
}


@media (max-width: 768px) {
    .initial_inner_r .hover-parent .hover-mask a, .initial_inner_l .hover-parent .hover-mask a, .item .hover-parent .hover-mask a {
        font-size: 0.9em;
    }
}

@media (max-width: 768px) {
figcaption.hover-mask {
    position: unset !important;
    background: unset !important;
    opacity: 1 !important;
    transform: unset !important;
    height: unset !important;
    margin-top: 5%;
}
figcaption.hover-mask a{
    color: #000 !important;
}
}

.gift_wrap {
    width: 90%;
    max-width: 1000px;
    margin: 0 auto;
    border: solid 1px #b7a067;
    outline: solid 2px #b7a067;
    outline-offset: 3px;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    margin-bottom: 5%;
}
.gift_wrap .gift_l {
    width: 60%;
    padding: 6% 4%;
    font-size: 16px;
    line-height: 2.0em;
}
.gift_r {
    width: 36%;
    margin-right: 4%;
}
.gift_wrap h4 {
    color: #06403b;
    font-size: 1.4em;
    font-weight: bold;
    margin-bottom: 4%;
    line-height: 1.7em;
}
.gift_wrap span {
    font-size: 0.8em;
}
.gift_wrap p {
    margin-bottom: 0;
}
@media (max-width: 768px) {
    .gift_wrap {
        width: 90%;
        flex-direction: column-reverse;
        align-items: center;
        padding: 10% 0;
        line-height: 1.8em !important;
        margin-bottom: 10%;
    }
    .gift_l, .gift_r {
        width: 80% !important;
        margin: 0 auto;
        padding:0 !important;
    }
    .gift_wrap h4 {
        margin: 8% auto 2%;
    }
}



/* PageDesign */
.p-main {
    font-family: a-otf-ryumin-pr6n, serif;
    font-weight: 300;
    font-style: normal;
    color: #101a2f;
}

.p-main h2 {
    margin: 0;
    background: #fff;
    text-align: center;
}

.p-main h2 img {
    width: 100%;
    max-width: 1170px;
}

.p-main h3 {
    margin-bottom: 3%;
    text-align: center;
    font-size: 1.8em;
    width: 90%;
    margin: 0 auto 5%;
}

.p-main #pearl h3 {
    margin-top: 8%;
}

@media screen and (min-width: 980px) {
    .p-main h3 {
        font-size: 3.2em;
    }
}

.content_wrap {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-feature-settings: "palt";
    margin: 0 auto;
    padding: 0;
    font-smoothing: antialiased;
    font-size: 14px;
    line-height: 1.8 !important;
}

@media screen and (min-width: 980px) {
    .content_wrap {
        font-size: 18px;
    }
}

.content_wrap * {
    box-sizing: border-box;
    text-align: center;
}

.contents_wrap {
    margin-bottom: 5%;
}

.contents_wrap.w_all {
    background: #f7f7f3;
    padding: 5% 0 5%;
}

.contents_wrap.w1000,
.contents_wrap.w_all .w_all__inner {
    width: 95%;
    margin: 0 auto;
}

@media screen and (min-width: 980px) {
    .contents_wrap {
        margin-bottom: 0;
    }

    .contents_wrap.w1000,
    .contents_wrap.w_all .w_all__inner {
        max-width: 1000px;
    }

    .contents_wrap.w_all {
        padding: 0 auto 8% auto;
    }
}

.contents_wrap.w1000>p,
.contents_wrap.w_all .w_all__inner>p {
    margin-bottom: 12%;
    text-align: center;
    font-size: 1.1em;
    line-height: 1.7em;
    letter-spacing: 0.1em;
}

.contents_wrap.w1000>p.lead_text {
    margin: 8% auto;
    text-align: center;
    font-size: 1.2em;
    line-height: 1.9em;
}

.contents_wrap.w1000>p.lead_text a {
    display: block;
    width: 80%;
    max-width: 500px;
    margin: 8% auto 15%;
}

@media screen and (min-width: 980px) {

    .contents_wrap.w1000>p,
    .contents_wrap.w_all .w_all__inner>p {
        font-size: 2.1em;
    }

    .contents_wrap.w1000>p.lead_text {
        text-align: center;
        font-size: 1.3em;
    }
}

.p-main #stone {
    margin: 0 auto 8% auto;
}

.item_list {
    width: 100%;
    max-width: 1000px;
    margin: 0 auto 8%;
}

.item_list li {
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    width: 100%;
    margin: 0 auto 10%;
    text-align: center;
}

.item_list li:nth-child(even) {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
}

.item_list li>div {
    width: 50%;
    max-width: 500px;
    position: relative;
}

.item_list .item_text {
    width: 95%;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}

.item_list .item_link {
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    width: 95%;
    max-width: 350px;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}

.item_list .item_link a:hover {
    text-decoration: none;
}

.item_list .item_link li {
    width: 46%;
    max-width: 160px;
    margin-bottom: 0;
    font-size: 0.7em;
    line-height: 1.5em;
}

.item_list .item_link img {
    margin-bottom: 5%;
}

.item_list .item_link .item_btn {
    display: block;
    margin-top: 5%;
    padding: 3% 0;
    background: #fff;
    color: #ffffff;
}

#pearl .item_list_txt {
    text-align: center;
    margin-bottom: 4%;
}

.item_list li p,
.item_list_txt li,
.item_list .item_link {
    font-family: 'Noto Sans JP', "ヒラギノ角ゴ Pro W6", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", MS PGothic, sans-serif;
    font-size: 0.7em;
    line-height: 1.8em;
}

.item_list_txt li {
    margin-top: 3%;
}

.item_list li p span {
    font-size: 1.2em;
}

.item_list li h4 {
    margin-bottom: 0;
    font-size: 1.9em;
    font-weight: normal;
    line-height: 0.9em;
}

.item_list li h4 span {
    font-size: 0.6em;
    font-weight: normal;
}

@media screen and (min-width: 980px) {
    .item_navi li {
        font-size: 1.5em;
    }

    .item_list {
        margin: 0 auto 8%;
    }

    .item_list li {
        margin: 0 0 10%;
    }

    .item_list li p,
    .item_list_txt li {
        font-size: 1.1em;
    }

    .item_list li p span {
        font-size: 1.5em;
    }

    .item_list li h4 {
        margin-bottom: 6%;
        font-size: 5em;
        line-height: 0.7em;
    }

    .item_list li h4 span {
        font-size: 0.55em;
    }

    .item_list .item_link li {
        font-size: 1.6em;
        line-height: 1.5em;
    }

    .item_list .item_link img {
        margin-bottom: 10%;
    }
}

.p-main a.p-btn {
    display: block;
    width: 90%;
    max-width: 600px;
    margin: 4% auto 0;
    padding: 25px 0.3%;
    background-color: #06413b;
    text-align: center;
    font-family: 'Noto Sans JP', "ヒラギノ角ゴ Pro W6", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", MS PGothic, sans-serif;
    font-size: 16px;
    color: #FFFFFF;
    position: relative;
}

.p-main a.p-btn::after {
    content: '';
    width: 10px;
    height: 10px;
    border-top: solid 1px #fff;
    border-right: solid 1px #fff;
    position: absolute;
    right: 5%;
    top: 42%;
    transform: rotate(45deg);
}

.p-main a.p-btn a,
.p-main a.p-btn:hover,
.p-main a.p-btn:focus,
.p-main a.p-btn a:hover,
.p-main a.p-btn a:focus {
    text-decoration: none;
    opacity: 0.7;
}

@media (min-width: 980px) {
    .p-main a.p-btn {
        font-size: 1.4em;
        letter-spacing: 2px;
    }
}

.ini_br_sp {
    display: none;
}

@media (max-width: 480px) {
    .ini_br_sp {
        display: inline;
    }
}

/* 注意文言 */
.attention-txt-pc {
    font-family: 'Noto Sans JP', "ヒラギノ角ゴ Pro W6", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", MS PGothic, sans-serif;
}