﻿:root {
  --sc-blog-card-bg: rgba(255,255,255,.94);
  --sc-blog-border: rgba(200,164,109,.24);
  --sc-blog-shadow: 0 14px 34px rgba(0,0,0,.08);
  --sc-blog-text: #1b1b1b;
  --sc-blog-muted: #5a5a5a;
}

.sc-bg-page-blog,
.sc-bg-page-blog-post {
  background-image: url(../images/background/contact-hero-office.jpg);
}

.blog-main { background: #f3f3f1; padding: 68px 0 74px; }
.blog-tools { margin-bottom: 24px; padding: 18px; border: 1px solid rgba(200,164,109,.24); border-radius: 14px; background: rgba(255,255,255,.94); box-shadow: 0 8px 24px rgba(0,0,0,.05); position: sticky; top: 88px; z-index: 35; backdrop-filter: blur(6px); }
.blog-tools.is-filtering { border-color: rgba(12,34,57,.26); box-shadow: 0 12px 28px rgba(12,34,57,.12); }
.blog-tools-head h2 { margin: 0 0 10px; font-size: 24px; font-weight: 800; color: #1b1b1b; }
.blog-tools-row { display: grid; grid-template-columns: 1fr auto; gap: 10px; align-items: center; }
.blog-tools-row input[type="search"] { width: 100%; height: 50px; border-radius: 10px; border: 1px solid rgba(12,34,57,.2); padding: 0 14px; font-size: 15px; color: #1b1b1b; background: #fff; }
.blog-tools-row input[type="search"]:focus { border-color: #0c2239; box-shadow: 0 0 0 3px rgba(12,34,57,.14); outline: none; }
.blog-tools-row button { height: 50px; min-width: 120px; border-radius: 10px; border: 1px solid rgba(12,34,57,.26); background: #0c2239; color: #fff; font-weight: 700; }
.blog-tools-row button:hover { filter: brightness(1.06); }
.blog-topic-chips { margin-top: 12px; display: flex; flex-wrap: wrap; gap: 8px; }
.blog-topic-chip { border: 1px solid rgba(12,34,57,.22); background: #fff; color: #1b1b1b; border-radius: 999px; padding: 6px 12px; font-size: 13px; line-height: 1; font-weight: 700; }
.blog-topic-chip:hover { border-color: rgba(12,34,57,.45); transform: translateY(-1px); transition: .2s ease; }
.blog-topic-chip span { color: #6d6d6d; font-weight: 600; }
.blog-topic-chip.is-active { background: #0c2239; color: #fff; border-color: #0c2239; }
.blog-topic-chip.is-active span { color: rgba(255,255,255,.82); }
.blog-search-state { margin-top: 10px; color: #5d5d5d; font-size: 14px; }
.blog-search-results { margin-top: 14px; padding-top: 12px; border-top: 1px solid rgba(200,164,109,.24); }
.blog-search-results h3 { margin: 0 0 10px; font-size: 18px; color: #1b1b1b; font-weight: 800; }
.blog-search-results-list { display: grid; grid-template-columns: 1fr; gap: 8px; }
.blog-search-hit { display: grid; gap: 4px; text-decoration: none; padding: 10px 12px; border-radius: 10px; border: 1px solid rgba(12,34,57,.12); background: #fff; color: #1b1b1b; }
.blog-search-hit strong { font-size: 15px; line-height: 1.35; }
.blog-search-hit span { font-size: 13px; color: #626262; line-height: 1.5; }
.blog-search-hit-date { font-size: 12px; color: #8a8a8a; }
.blog-hit { background: linear-gradient(180deg, rgba(255,234,157,.92), rgba(255,215,102,.82)); color: #1b1b1b; padding: 0 .18em; border-radius: .28em; box-decoration-break: clone; }
.blog-search-empty { padding: 10px 12px; border-radius: 10px; border: 1px dashed rgba(12,34,57,.24); color: #666; font-size: 14px; }
.blog-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 22px; }
.blog-card { display: flex; flex-direction: column; background: var(--sc-blog-card-bg); border: 1px solid var(--sc-blog-border); border-radius: 16px; overflow: hidden; box-shadow: var(--sc-blog-shadow); }
.blog-card-media { display: block; position: relative; overflow: hidden; }
.blog-card-media img { width: 100%; aspect-ratio: 16 / 9; object-fit: cover; display: block; }
.blog-card-body { padding: 18px 18px 20px; }
.blog-card-meta { font-size: 13px; color: #7d7d7d; margin-bottom: 8px; }
.blog-card h2 { margin: 0 0 10px; font-size: 22px; line-height: 1.25; font-weight: 800; }
.blog-card h2 a { color: var(--sc-blog-text); text-decoration: none; }
.blog-card p { margin: 0 0 14px; color: var(--sc-blog-muted); line-height: 1.72; font-size: 15px; }
.blog-card-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; }
.blog-badge { display: inline-flex; align-items: center; padding: 5px 10px; border-radius: 999px; border: 1px solid rgba(200,164,109,.46); color: #8a6a35; font-size: 12px; line-height: 1; background: rgba(200,164,109,.1); }
.blog-card-link { color: #0c2239; font-weight: 700; text-decoration: none; }
.blog-pagination { margin-top: 30px; display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; }
.blog-page-link { min-width: 42px; height: 42px; padding: 0 12px; display: inline-flex; align-items: center; justify-content: center; border-radius: 10px; border: 1px solid rgba(12,34,57,.2); background: #fff; color: #1d1d1d; text-decoration: none; font-weight: 700; }
.blog-page-link.current { background: #0c2239; color: #fff; border-color: #0c2239; }
.blog-breadcrumbs { background: #f3f3f1; border-bottom: 1px solid rgba(200,164,109,.22); }
.blog-breadcrumbs .container { padding-top: 14px; padding-bottom: 14px; display: flex; flex-wrap: wrap; gap: 8px; color: #5d5d5d; font-size: 14px; }
.blog-breadcrumbs a { color: #0c2239; text-decoration: none; }
.blog-post-main { background: #f3f3f1; padding: 38px 0 72px; }
.blog-post-card { background: rgba(255,255,255,.96); border: 1px solid var(--sc-blog-border); border-radius: 18px; box-shadow: var(--sc-blog-shadow); padding: 26px; }
.blog-post-head { margin-bottom: 14px; }
.blog-post-head time { display: inline-block; color: #6d6d6d; font-size: 14px; margin-bottom: 10px; }
.blog-post-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.blog-media-grid { margin-top: 14px; margin-bottom: 18px; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.blog-media-item { margin: 0; border-radius: 12px; overflow: hidden; background: #101010; }
.blog-media-item img,.blog-media-item video { width: 100%; display: block; aspect-ratio: 16 / 10; object-fit: cover; }
.blog-media-download { display: block; padding: 10px 12px; color: #fff; text-decoration: none; font-size: 13px; background: rgba(255,255,255,.08); }
.blog-post-content p { margin: 0 0 16px; color: #2a2a2a; font-size: 17px; line-height: 1.78; }
.blog-subtitles { margin-top: 20px; padding: 16px; border-radius: 12px; background: rgba(12,34,57,.05); border: 1px solid rgba(12,34,57,.12); }
.blog-subtitles h3 { margin: 0 0 8px; font-size: 18px; color: #1d1d1d; }
.blog-subtitles ul { margin: 0; padding-left: 18px; }
.blog-subtitles a { color: #0c2239; }
.blog-transcript { margin-top: 18px; padding: 16px; border-radius: 12px; background: rgba(200,164,109,.08); border: 1px solid rgba(200,164,109,.24); }
.blog-transcript h3 { margin: 0 0 10px; font-size: 18px; color: #1d1d1d; }
.blog-transcript p { margin: 0 0 10px; font-size: 15px; line-height: 1.7; color: #3a3a3a; }
.blog-transcript p:last-child { margin-bottom: 0; }
.blog-post-cta { margin-top: 24px; background: rgba(255,255,255,.95); border: 1px solid var(--sc-blog-border); border-radius: 16px; box-shadow: var(--sc-blog-shadow); padding: 24px; text-align: center; }
.blog-post-cta h2 { margin: 0 0 10px; font-size: 34px; font-weight: 800; }
.blog-post-cta p { margin: 0 auto 18px; max-width: 860px; color: #515151; font-size: 17px; line-height: 1.75; }
.blog-related { margin-top: 24px; }
.blog-related h2 { margin: 0 0 14px; font-size: 34px; font-weight: 800; color: #1b1b1b; }
.blog-related-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.blog-related-card { background: rgba(255,255,255,.95); border: 1px solid var(--sc-blog-border); border-radius: 14px; overflow: hidden; }
.blog-related-media img { width: 100%; aspect-ratio: 16 / 9; object-fit: cover; display: block; }
.blog-related-body { padding: 12px; }
.blog-related-body time { color: #7a7a7a; font-size: 12px; }
.blog-related-body h3 { margin: 6px 0 0; font-size: 17px; line-height: 1.35; }
.blog-related-body h3 a { color: #1b1b1b; text-decoration: none; }

@media (max-width: 1199px) {
  .blog-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .blog-related-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 767px) {
  .blog-main { padding: 40px 0 50px; }
  .blog-tools { padding: 14px; position: static; backdrop-filter: none; }
  .blog-tools-head h2 { font-size: 22px; }
  .blog-tools-row { grid-template-columns: 1fr; }
  .blog-tools-row button { width: 100%; }
  .blog-grid { grid-template-columns: 1fr; }
  .blog-card h2 { font-size: 21px; }
  .blog-media-grid { grid-template-columns: 1fr; }
  .blog-post-card { padding: 16px; }
  .blog-post-content p { font-size: 16px; }
  .blog-post-cta h2, .blog-related h2 { font-size: 28px; }
  .blog-related-grid { grid-template-columns: 1fr; }
}









