:root{ --sf-blog-max: 2400px; --sf-blog-gutter: 32px; }
/* Allow blog pages to use more horizontal space than the default site wrap. */
main.wrap{ max-width: none; padding-left: var(--sf-blog-gutter); padding-right: var(--sf-blog-gutter); }
/* Blog pages should use the available screen width while keeping comfortable gutters */
.blog-wrap{
  width: 100%;
  max-width: min(var(--sf-blog-max), calc(100vw - (var(--sf-blog-gutter) * 2)));
  margin: 0 auto;
}
.blog-hero{ display:flex; align-items:flex-start; justify-content:space-between; gap:12px; }
.blog-hero h1{ margin:0; font-size:20px; letter-spacing:-.2px; }
.blog-hero p{ margin:6px 0 0; color: var(--muted); }
/* Responsive cards: 3-up on most desktops, 2-up on smaller, 1-up on mobile. */
.blog-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap:14px;
}
@media (min-width: 1100px){
  .blog-grid{ grid-template-columns: repeat(3, minmax(0,1fr)); }
}
@media (min-width: 1600px){
  .blog-grid{ grid-template-columns: repeat(4, minmax(0,1fr)); }
}
.blog-card{ display:flex; flex-direction:column; gap:10px; }
.blog-card .blog-thumb{ width:100%; height:180px; background:#f8fafc; border-radius:14px; border:1px solid var(--border); overflow:hidden; display:flex; align-items:center; justify-content:center; padding:10px; }
.blog-card .blog-thumb img{ width:100%; height:100%; object-fit:contain; object-position:center; display:block; }
.blog-meta{ display:flex; gap:10px; align-items:center; color: var(--muted); font-size: 9.5pt; }
.blog-tag{ display:inline-flex; align-items:center; gap:6px; padding:4px 10px; border-radius:999px; background: var(--accentSoft); border:1px solid rgba(255,45,178,.22); color: var(--ink); font-weight:700; font-size:9.5pt; }
.blog-post h1{ margin: 0 0 8px; font-size: 24px; letter-spacing:-.25px; }
.blog-post .blog-date{ color: var(--muted); margin-bottom: 10px; }
.blog-post .blog-feature{ margin: 10px 0 14px; border-radius: 16px; overflow:hidden; border:1px solid var(--border); background:#f8fafc; display:flex; align-items:center; justify-content:center; padding:18px; }
.blog-post .blog-feature img{ width:100%; max-height:420px; height:auto; object-fit:contain; object-position:center; display:block; margin:0 auto; }
.blog-content{ font-size: 10.5pt; line-height: 1.55; }
.blog-content p{ margin: 10px 0; }
.blog-content h2{ margin: 18px 0 8px; font-size: 16px; }
.blog-content h3{ margin: 16px 0 6px; font-size: 13px; }
.blog-content ul, .blog-content ol{ padding-left: 22px; }
.blog-content a{ color: var(--accentHover); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 2px; }
.blog-cta{ margin-top: 16px; padding: 14px; border-radius: 18px; border:1px solid rgba(255,45,178,.24); background: rgba(255,45,178,.08); }
.blog-cta h3{ margin:0 0 6px; }
.blog-cta p{ margin:0 0 12px; color: var(--muted); }
.blog-cta .btn{ display:inline-flex; align-items:center; justify-content:center; padding:10px 14px; border-radius: 12px; border:1px solid rgba(255,45,178,.35); background: var(--accent); color:#fff; font-weight:800; }
.blog-cta .btn:hover{ filter:brightness(.97); text-decoration:none; }

/* Editor */
.sf-editor{ border:1px solid var(--border); border-radius: 14px; background: var(--surface); overflow:hidden; }
.sf-editor-toolbar{ display:flex; flex-wrap:wrap; gap:6px; padding:10px; border-bottom:1px solid var(--border); background: rgba(2,6,23,.02); }
.sf-editor-toolbar button, .sf-editor-toolbar select, .sf-editor-toolbar input[type=color]{ height: 32px; border-radius: 10px; border:1px solid var(--border); background:#fff; padding: 0 10px; font-weight:700; }
.sf-editor-toolbar button{ cursor:pointer; }
.sf-editor-toolbar button:hover{ filter:brightness(.98); }
.sf-editor-toolbar .is-accent{ background: var(--accent); color:#fff; border-color: rgba(255,45,178,.35); }
.sf-editor-area{ min-height: 280px; padding: 12px; outline:none; font-size: 10.5pt; line-height: 1.55; }
.sf-editor-area:focus{ box-shadow: 0 0 0 .25rem rgba(255,45,178,.14); }
.sf-form-row{ display:grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (max-width: 820px){ .sf-form-row{ grid-template-columns: 1fr; } }
.sf-help{ color: var(--muted); font-size: 9.5pt; margin-top: 6px; }

/* Filters */
.blog-chip{
  display:inline-flex;
  align-items:center;
  padding:6px 12px;
  border-radius:999px;
  border:1px solid rgba(15,23,42,.16);
  background:#fff;
  color:#0f172a;
  text-decoration:none;
  font-weight:800;
  font-size: 10pt;
}
.blog-chip:hover{ border-color:rgba(255,45,178,.55); box-shadow:0 0 0 3px rgba(255,45,178,.10); }
.blog-chip.active{ border-color:rgba(255,45,178,.85); background:rgba(255,45,178,.08); color: var(--accentHover); }
