/* bm-blog.css — premium overrides for blog pages
   Loaded after style.css. Scoped under .bm-blog-page where possible. */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400&family=Inter:wght@300;400;500;600&family=Noto+Sans+Thai:wght@300;400;500;600&display=swap');

.bm-blog-page {
    --ivory:    #fbf8f3;
    --cream:    #f5efe6;
    --gold:     #b8924a;
    --gold-2:   #d4af37;
    --brown:    #3a2a20;
    --line:     #e6dccd;
    --muted:    #7a6650;
    background-color: var(--ivory);
    color: var(--brown);
    font-family: 'Inter', system-ui, -apple-system, sans-serif;
    line-height: 1.7;
}
.bm-blog-page :lang(th),
.bm-blog-page[lang="th"] {
    font-family: 'Noto Sans Thai', 'Inter', system-ui, sans-serif;
    line-height: 1.85;
}

.bm-blog-page h1,
.bm-blog-page h2,
.bm-blog-page h3 {
    font-family: 'Cormorant Garamond', 'Noto Sans Thai', serif;
    color: var(--brown);
    letter-spacing: 0.01em;
    line-height: 1.25;
}
.bm-blog-page[lang="th"] h1,
.bm-blog-page[lang="th"] h2,
.bm-blog-page[lang="th"] h3 {
    font-family: 'Noto Sans Thai', 'Cormorant Garamond', serif;
    font-weight: 500;
}

/* Hero */
.bm-hero {
    background: var(--cream);
    border-bottom: 1px solid var(--line);
    padding: 56px 0 44px;
}
.bm-hero .container { max-width: 920px; }
.bm-eyebrow {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.22em;
    color: var(--gold);
    margin-bottom: 16px;
    font-weight: 500;
}
.bm-hero h1 {
    font-size: 44px;
    font-weight: 500;
    margin: 0 0 18px;
}
.bm-blog-page[lang="th"] .bm-hero h1 { font-size: 36px; font-weight: 600; }
.bm-hero .bm-excerpt {
    font-family: 'Cormorant Garamond', 'Noto Sans Thai', serif;
    font-size: 21px;
    font-style: italic;
    color: var(--muted);
    line-height: 1.5;
    margin: 0;
    max-width: 720px;
}
.bm-blog-page[lang="th"] .bm-hero .bm-excerpt {
    font-family: 'Noto Sans Thai', serif;
    font-style: normal;
    font-size: 18px;
}
.bm-meta {
    margin-top: 22px;
    font-size: 13px;
    color: var(--muted);
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    align-items: center;
}
.bm-meta a, .bm-lang-switch a {
    color: var(--gold);
    border-bottom: 1px solid transparent;
    transition: border-color .2s;
}
.bm-meta a:hover, .bm-lang-switch a:hover { border-color: var(--gold); }
.bm-lang-switch {
    display: inline-flex;
    gap: 8px;
    align-items: center;
    font-size: 12px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}
.bm-lang-switch span.sep { color: var(--line); }
.bm-lang-switch .active {
    color: var(--brown);
    font-weight: 600;
    border-bottom: 1px solid var(--brown);
}

/* Banner */
.bm-banner {
    width: 100%;
    aspect-ratio: 16 / 9;
    background: var(--cream);
    border-radius: 0;
    overflow: hidden;
    margin: 0 0 0;
}
.bm-banner img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Article body */
.bm-article {
    padding: 56px 0 72px;
}
.bm-article .container { max-width: 720px; }
.bm-article h2 {
    font-size: 28px;
    font-weight: 500;
    margin: 44px 0 14px;
    color: var(--brown);
}
.bm-blog-page[lang="th"] .bm-article h2 { font-size: 24px; font-weight: 600; }
.bm-article h3 {
    font-size: 20px;
    font-weight: 600;
    margin: 28px 0 8px;
    color: var(--brown);
}
.bm-article p {
    font-size: 17px;
    margin: 0 0 18px;
    color: #2f2218;
}
.bm-blog-page[lang="th"] .bm-article p { font-size: 16px; }
.bm-article ul, .bm-article ol {
    margin: 0 0 22px 22px;
    padding: 0;
}
.bm-article li {
    font-size: 17px;
    margin: 0 0 8px;
    color: #2f2218;
}
.bm-blog-page[lang="th"] .bm-article li { font-size: 16px; }
.bm-article strong {
    font-weight: 600;
    color: var(--brown);
}
.bm-article em {
    font-style: italic;
    color: var(--brown);
}
.bm-article a {
    color: var(--gold);
    border-bottom: 1px solid rgba(184,146,74,.4);
    transition: border-color .2s;
}
.bm-article a:hover { border-color: var(--gold); }
.bm-article blockquote {
    border-left: 3px solid var(--gold);
    padding: 8px 0 8px 22px;
    margin: 28px 0;
    font-family: 'Cormorant Garamond', 'Noto Sans Thai', serif;
    font-style: italic;
    font-size: 22px;
    color: var(--brown);
    line-height: 1.45;
}
.bm-blog-page[lang="th"] .bm-article blockquote {
    font-family: 'Noto Sans Thai', serif;
    font-style: normal;
    font-size: 18px;
    line-height: 1.7;
}
.bm-article hr {
    border: none;
    border-top: 1px solid var(--line);
    margin: 40px 0;
}

/* Tags */
.bm-tags {
    margin: 36px 0 0;
    padding-top: 24px;
    border-top: 1px solid var(--line);
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.bm-tag {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--muted);
    padding: 6px 12px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: var(--cream);
}

/* CTA */
.bm-cta {
    background: var(--cream);
    border-top: 1px solid var(--line);
    padding: 48px 0;
    text-align: center;
}
.bm-cta h2 {
    font-family: 'Cormorant Garamond', 'Noto Sans Thai', serif;
    font-size: 30px;
    font-weight: 500;
    margin: 0 0 10px;
    color: var(--brown);
}
.bm-blog-page[lang="th"] .bm-cta h2 { font-family: 'Noto Sans Thai', serif; font-weight: 600; font-size: 24px; }
.bm-cta p {
    font-size: 15px;
    color: var(--muted);
    margin: 0 0 22px;
}
.bm-btn {
    display: inline-block;
    padding: 12px 26px;
    background: var(--brown);
    color: var(--ivory);
    border: none;
    border-radius: 0;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    font-size: 12px;
    font-weight: 500;
    transition: background .25s;
}
.bm-btn:hover { background: var(--gold); }
.bm-btn-line { background: #06C755; }
.bm-btn-line:hover { background: #04a847; }

/* Back link */
.bm-back {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--gold);
    margin-bottom: 22px;
    display: inline-block;
}
.bm-back:hover { color: var(--brown); }

/* List page (blog.html) */
.bm-list-hero { text-align: center; padding: 64px 0 32px; background: var(--cream); border-bottom: 1px solid var(--line); }
.bm-list-hero h1 { font-size: 52px; font-weight: 500; margin: 0 0 12px; color: var(--brown); font-family: 'Cormorant Garamond', 'Noto Sans Thai', serif; }
.bm-blog-page[lang="th"] .bm-list-hero h1 { font-family: 'Noto Sans Thai', serif; font-weight: 600; font-size: 40px; }
.bm-list-hero .bm-excerpt { max-width: 640px; margin: 0 auto; font-style: italic; color: var(--muted); font-family: 'Cormorant Garamond', 'Noto Sans Thai', serif; font-size: 19px; }
.bm-blog-page[lang="th"] .bm-list-hero .bm-excerpt { font-family: 'Noto Sans Thai', serif; font-style: normal; font-size: 16px; }

.bm-list { padding: 56px 0 72px; }
.bm-list .container { max-width: 1080px; }
.bm-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0,1fr));
    gap: 38px;
}
@media (max-width: 760px) { .bm-grid { grid-template-columns: 1fr; } }
.bm-card {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 0;
    overflow: hidden;
    transition: transform .28s, box-shadow .28s;
}
.bm-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 18px 40px -22px rgba(58,42,32,.25);
}
.bm-card a.bm-card-link { display: block; color: inherit; }
.bm-card .bm-card-image {
    aspect-ratio: 16 / 9;
    background: var(--cream);
    overflow: hidden;
}
.bm-card .bm-card-image img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .6s; }
.bm-card:hover .bm-card-image img { transform: scale(1.04); }
.bm-card .bm-card-body { padding: 24px 26px 28px; }
.bm-card .bm-card-cat {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.2em;
    color: var(--gold);
    margin-bottom: 10px;
}
.bm-card .bm-card-title {
    font-family: 'Cormorant Garamond', 'Noto Sans Thai', serif;
    font-size: 24px;
    font-weight: 500;
    line-height: 1.3;
    color: var(--brown);
    margin: 0 0 10px;
}
.bm-blog-page[lang="th"] .bm-card .bm-card-title { font-family: 'Noto Sans Thai', serif; font-weight: 600; font-size: 21px; }
.bm-card .bm-card-excerpt { font-size: 15px; color: var(--muted); margin: 0 0 14px; }
.bm-card .bm-card-meta { font-size: 12px; color: var(--muted); border-top: 1px solid var(--line); padding-top: 12px; }

/* Container override (use existing site .container width) */
.bm-blog-page .container { width: 100%; max-width: 1120px; margin: 0 auto; padding: 0 22px; }
