/* JomCloud blog — extends assets/styles.css (header, footer, .wrap, .btn reused). */

/* Language switch (EN ↔ BM) */
.lang-switch { max-width: 720px; margin: -8px auto 18px; font-size: .9rem; }
.lang-switch a { display: inline-flex; align-items: center; gap: 6px; padding: 4px 11px;
  border: 1px solid var(--hairline); border-radius: 999px; color: var(--indigo);
  font-weight: 500; text-decoration: none; }
.lang-switch a:hover { border-color: var(--indigo); }

/* Blog top nav: full menu, distinct from the main marketing nav. */
.blognav .nav-links { gap: 20px; }
.blognav .nav-links a.txt { font-size: .95rem; }
.blognav .tag-pill { font-size: .72rem; font-weight: 600; letter-spacing: .02em;
  text-transform: uppercase; color: var(--indigo); background: var(--indigo-tint);
  padding: 3px 9px; border-radius: 999px; margin-left: 8px; vertical-align: middle; }

/* ---- Index ---- */
.blog-hero { padding: 56px 0 26px; }
.blog-hero h1 { font-size: clamp(28px, 4vw, 40px); line-height: 1.08; letter-spacing: -.02em;
  margin: 12px 0 10px; font-weight: 600; }
.blog-hero p { color: var(--ink-mute); font-size: 1.05rem; max-width: 620px; }

.post-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 22px; padding: 14px 0 70px; }
.post-card { display: flex; flex-direction: column; background: #fff; border: 1px solid var(--hairline);
  border-radius: var(--radius-xl); overflow: hidden; transition: transform .15s ease, box-shadow .15s ease; }
.post-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-2); }
.post-card .pc-body { padding: 22px 22px 24px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.post-card .pc-cat { font-size: .72rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--indigo); }
.post-card h2 { font-size: 1.2rem; line-height: 1.3; margin: 0; font-weight: 600; color: var(--ink); }
.post-card h2 a { color: inherit; }
.post-card p { color: var(--ink-mute); font-size: .95rem; margin: 0; flex: 1; }
.post-card .pc-meta { font-size: .82rem; color: var(--ink-mute); margin-top: 6px; }
.post-card .pc-meta a { color: var(--indigo); font-weight: 500; }

.blog-empty { color: var(--ink-mute); padding: 20px 0 80px; }

/* ---- Single post ---- */
.crumbs { font-size: .85rem; color: var(--ink-mute); padding: 26px 0 0; }
.crumbs a { color: var(--indigo); }
.crumbs span { color: var(--ink-mute); }

.post-head { padding: 14px 0 8px; border-bottom: 1px solid var(--hairline); margin-bottom: 30px; }
.post-head .pc-cat { font-size: .74rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--indigo); }
.post-head h1 { font-size: clamp(28px, 4.4vw, 44px); line-height: 1.1; letter-spacing: -.022em;
  margin: 12px 0 14px; font-weight: 600; max-width: 18ch; }
.post-head .post-meta { font-size: .9rem; color: var(--ink-mute); display: flex; gap: 14px; flex-wrap: wrap; padding-bottom: 20px; }

.post-body { max-width: 720px; margin: 0 auto; font-size: 1.06rem; line-height: 1.72; color: var(--ink-2); }
.post-body > p:first-of-type { font-size: 1.16rem; color: var(--ink); }
.post-body h2 { font-size: 1.6rem; line-height: 1.2; letter-spacing: -.015em; color: var(--ink);
  font-weight: 600; margin: 2.1em 0 .55em; }
.post-body h3 { font-size: 1.22rem; color: var(--ink); font-weight: 600; margin: 1.6em 0 .4em; }
.post-body p { margin: 0 0 1.1em; }
.post-body a { color: var(--indigo); text-decoration: underline; text-underline-offset: 2px; text-decoration-thickness: 1px; }
.post-body ul, .post-body ol { margin: 0 0 1.2em; padding-left: 1.3em; }
.post-body li { margin: .4em 0; }
.post-body strong { font-weight: 600; color: var(--ink); }
.post-body blockquote { margin: 1.4em 0; padding: 4px 20px; border-left: 3px solid var(--indigo);
  color: var(--ink); background: var(--canvas-soft); border-radius: 0 10px 10px 0; }
.post-body table { width: 100%; border-collapse: collapse; margin: 1.4em 0; font-size: .98rem; }
.post-body th, .post-body td { text-align: left; padding: 10px 12px; border-bottom: 1px solid var(--hairline); }
.post-body th { background: var(--canvas-soft); font-weight: 600; color: var(--ink); }
.post-body img { max-width: 100%; height: auto; border-radius: var(--radius); border: 1px solid var(--hairline); }

/* FAQ */
.post-faq { max-width: 720px; margin: 2.4em auto 0; }
.post-faq h2 { font-size: 1.6rem; font-weight: 600; margin-bottom: .5em; }
.post-faq details { border: 1px solid var(--hairline); border-radius: var(--radius); padding: 4px 16px; margin: 10px 0; background: #fff; }
.post-faq summary { font-weight: 600; color: var(--ink); cursor: pointer; padding: 12px 0; list-style: none; }
.post-faq summary::-webkit-details-marker { display: none; }
.post-faq details[open] summary { border-bottom: 1px solid var(--hairline); }
.post-faq details p { color: var(--ink-2); padding: 12px 0 4px; margin: 0; }

/* CTA block */
.post-cta { max-width: 720px; margin: 3em auto 0; background: linear-gradient(135deg, var(--dark-900), var(--indigo));
  border-radius: var(--radius-xl); padding: 34px 32px; color: #fff; text-align: center; }
.post-cta h3 { font-size: 1.5rem; font-weight: 600; margin: 0 0 8px; color: #fff; }
.post-cta p { color: #d7dbf5; margin: 0 0 20px; }
.post-cta .btn-row { justify-content: center; }
.post-cta .btn.primary { background: #fff; color: var(--indigo); }
.post-cta .btn.primary:hover { background: #f1f0ff; }
.post-cta .btn.ghost { color: #fff; border-color: rgba(255,255,255,.4); }
.post-cta .btn.ghost:hover { background: rgba(255,255,255,.1); }

/* Post navigation / related */
.post-foot-links { max-width: 720px; margin: 2.6em auto 0; padding-top: 22px; border-top: 1px solid var(--hairline);
  font-size: .95rem; color: var(--ink-mute); }
.post-foot-links a { color: var(--indigo); font-weight: 500; }

@media (max-width: 560px) { .blognav .nav-links a.txt { display: inline; } }
