@charset "UTF-8";

/* ------------------------------------------------------------
 RESET
------------------------------------------------------------ */
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, dialog, figure, /*footer,header,*/ menu, nav, section, time, mark, audio, video { margin:0; padding:0; border:0; outline:0; font-weight:normal; line-height:1; vertical-align:bottom; }
body { line-height: 1; }
ul, ol, dl { list-style: none; }
blockquote, q { quotes: none; }
blockquote:before, blockquote:after, q:before, q:after { content: ''; content: none; }
a { margin: 0; padding: 0; border: 0; color: #000; text-decoration: none; vertical-align: baseline; background: transparent;  outline: none; }
a:hover{ opacity:.8;}
img { vertical-align: bottom; width: 100%; height: auto;}
ins { background-color: #ff9; color: #000; text-decoration: none; }
mark { background-color: #ff9; color: #000; font-style: italic; font-weight: bold; }
del { text-decoration: line-through; }
abbr[title], dfn[title] { border-bottom: 1px dotted #000; cursor: help; }
table { border-collapse: collapse; border-spacing: 0; }
hr { display: block; height: 1px; border: 0; border-top: 1px solid #cccccc; margin: 1em 0; padding: 0; }
input, select { vertical-align: middle; }

/* 明朝 */
/* .fm{ font-family: "YuMincho", "游明朝", "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "ＭＳ 明朝", serif; } */

/* ゴシック */
/* .fg{ font-family: "游ゴシック", "YuGothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Arial MT", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS Gothic", sans-serif; } */



:root {
    --main-background-color: #f1f1f1;
    --background-color-dark: #000;
    --background-color-dark-light: #313131;
    --max-width: 960px;
    --border-line-dark: #000;
    --border-line-dark-light: #313131;
    --text-color-black: #000;
}

@media screen and (max-width:768px) {
    .pt-md-sp {
        padding-top: 80px!important;
    }
    .pb-md-sp {
        padding-bottom: 80px!important;
    }
}

.premium-creator-articleList {
    font-family: "yu-mincho-pr6n", sans-serif;
    font-weight: 400;
    font-style: normal;
    color: var(--text-color-black);
}

.background-gray {
    background: var(--main-background-color);
    margin: 0 calc(50% - 50vw);
	width: 100vw;
}
.background-main {
    background-image: url(https://wedding.mynavi.jp/ring/premium/images/uploads/174/2024/06/20/66740f34ec5ec.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    margin: 0 calc(50% - 50vw);
    width: 100vw;
}

.container {
    max-width: var(--max-width);
    margin: auto;
    padding-top: 120px;
    padding-bottom: 120px;
}
@media screen and (max-width:768px) {
    .container {
        padding: 60px 20px;
    }
}

/* Hero */
.hero-container {
    max-width: var(--max-width);
    margin: auto;
    padding-bottom: 120px;
}
@media screen and (max-width:768px) {
    .hero-container {
        padding-bottom: 60px;
    }
}


/* Section */

/* Title */
.section-title {
    font-family: "Libre Caslon Display", serif;
    font-weight: 400;
    font-size: 70px;
    line-height: 1.2;
    text-align: center;
    margin-bottom: 60px;
}
@media screen and (max-width:768px) {
    .section-title {
        font-size: 33px;
        margin-bottom: 32px;
    }
}

.section-title_row2 {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.section-description p {
    font-size: 20px;
    line-height: 1.7;
}
@media screen and (max-width:768px) {
    .section-description p {
        font-size: 14px;
    }
}

.title-sm {
    font-family: "yu-mincho-pr6n", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 20px;
}
@media screen and (max-width:768px) {
    .title-sm {
        font-size: 14px;
    }
}
.title-border {
    display: flex;
    align-items: center;
    width: 50%;
    margin: auto;
}
@media screen and (max-width:768px) {
    .title-border {
        width: 75%;
    }
}
.title-border::before,
.title-border::after {
    content: '';
    flex-grow: 1;
    height: 1px;
    background: var(--border-line-dark);
}
.title-border::before {
    margin-right: 30px;
}
@media screen and (max-width:768px) {
    .title-border::before {
        margin-right: 30px;
    }
}
.title-border::after {
    margin-left: 30px;
}

.card-list {
    margin-top: 60px;
}
@media screen and (max-width:768px) {
    .card-list {
        margin-top: 32px;
    }
}

.card-list ul {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
}
@media screen and (max-width:768px) {
    .card-list ul {
        grid-template-columns: repeat(2, 1fr);
        gap: 34px 16px;
    }
}
.card-subname {
    font-size: 18px;
    font-family: "Cormorant Infant", serif;
    font-weight: 500;
    font-style: normal;
    line-height: 1.4;
    text-align: center;
    margin-top: 16px;
}
.card-name {
    font-size: 18px;
    line-height: 1.4;
    text-align: center;
    margin-top: 8px;
}

/* article */
.article-list ul {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
}

.article-box {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    align-items: end;
    gap: 24px;
}
@media screen and (max-width:768px) {
    .article-box {
        grid-template-columns: 1fr;
    }
}

.article-info {
    display: flex;
    flex-direction: column;
}

.article-top {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
@media screen and (max-width:768px) {
    .article-top:has(.article-tag) {
        flex-direction: row-reverse;
        justify-content: space-between;
    }
}

.article-bottom {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-top: 6px;
}

.article-info .article-tag {
    background: var(--background-color-dark);
    color: #fff;
    font-family: "Cormorant Infant", serif;
    font-weight: 500;
    font-style: normal;
    font-size: 20px;
    line-height: 1.4;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 83px;
}
@media screen and (max-width:768px) {
    .article-info .article-tag {
        font-size: 14px;
        width: 60px;
    }
}

.article-info .article-date {
    font-family: "Cormorant Infant", serif;
    font-weight: 500;
    font-style: normal;
    font-size: 20px;
    line-height: 1.4;
}
@media screen and (max-width:768px) {
    .article-info .article-date {
        font-size: 14px;
    }
}

.article-info .article-name {
    font-size: 20px;
    line-height: 1.4;
}
@media screen and (max-width:768px) {
    .article-info .article-name {
        font-size: 16px;
    }
}

.article-info .article-title {
    font-size: 20px;
    line-height: 1.6;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    overflow: hidden;
}
@media screen and (max-width:768px) {
    .article-info .article-title {
        font-size: 14px;
    }
}

.link-list {
    margin-top: 120px;
}
@media screen and (max-width:768px) {
    .link-list {
        margin-top: 80px;
    }
}

.link-list ul {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}
@media screen and (max-width:768px) {
    .link-list ul {
        grid-template-columns: 1fr;
        gap: 8px;
    }
}

.link-list ul li a {
    height: 60px;
    background: var(--background-color-dark-light);
    color: #fff;
    font-size: 18px;
    font-family: "Cormorant Infant", serif;
    font-weight: 500;
    font-style: normal;
    line-height: 1.7;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 10px;
}
@media screen and (max-width:768px) {
    .link-list ul li a {
        font-size: 16px;
    }
}

.card-thumbnail img {
    width: 96%;
    height: auto;
    padding-top: 7px;
    padding-left: 8px;
}

.card-thumbnail-frame {
    position: relative;
}

.card-thumbnail-frame::before {
    content: "";
    position: absolute;
    background-image: url(https://wedding.mynavi.jp/ring/premium/images/uploads/174/2024/06/23/6677c3f06b745.png);
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    z-index: 1;
}

.wedding-link-button {
    margin-top: 60px;
}

.wedding-link-button a {
    background: var(--background-color-dark-light);
    color: #fff;
    font-size: 18px;
    font-weight: 500;
    line-height: 1.7;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 10px;
    max-width: 450px;
    width: 100%;
    height: 60px;
    margin: auto;
}
@media screen and (max-width:768px) {
    .wedding-link-button a {
        font-size: 16px;
    }
}

/* ページネーション */
.premium-creator-articleList .pagination-container ul {
    display: flex;
    justify-content: center;
    margin-top: 60px;
    gap: 8px;
}
.premium-creator-articleList .page-item a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 45px;
    height: 45px;
    border: 1px solid var(--background-color-dark);
}
.premium-creator-articleList .page-item.navi-active a {
    background: var(--background-color-dark-light);
    color: #fff;
}
