/* ============================================================
   blog.css — Blog listing + single post (v2 — upgraded)
   New: featured images, tags, TOC, progress bar, prev/next
   ============================================================ */

/* ── FILTERS ──────────────────────────────────────────────── */
.blog-filters{background:#fff;border-bottom:1px solid var(--border);padding:16px 0}
.blog-filter-inner{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.blog-search-form{display:flex;align-items:center;gap:8px}
.blog-search-wrap{position:relative}
.blog-search-wrap svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:15px;height:15px;pointer-events:none}
.blog-search-input{padding:9px 14px 9px 34px;border:1.5px solid var(--border);border-radius:var(--r-sm);font-size:13.5px;font-family:inherit;outline:none;width:250px;transition:border-color .2s;background:#fff;color:var(--text)}
.blog-search-input:focus{border-color:var(--accent)}
.blog-cats{display:flex;gap:8px;flex-wrap:wrap;flex:1}
.blog-cat-pill{padding:6px 14px;border-radius:100px;font-size:12.5px;font-weight:600;border:1.5px solid var(--border);color:var(--text-muted);background:#fff;text-decoration:none;transition:var(--t);white-space:nowrap}
.blog-cat-pill:hover,.blog-cat-pill.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.blog-tags-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding-top:12px;margin-top:4px;border-top:1px solid var(--border-2)}
.blog-tag-row{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:10px}
.blog-tag-pill{display:inline-block;padding:4px 10px;border-radius:100px;font-size:11.5px;font-weight:600;color:var(--accent);background:rgba(45,74,62,.07);border:1px solid rgba(45,74,62,.12);text-decoration:none;transition:var(--t);white-space:nowrap}
.blog-tag-pill:hover,.blog-tag-pill.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.blog-filter-notice{font-size:13px;color:var(--text-muted);margin-top:10px}
.blog-filter-notice strong{color:var(--text)}
.blog-clear-filter{color:var(--accent);margin-left:10px;text-decoration:none;font-weight:600}
.blog-meta-sep{color:var(--border);margin:0 2px}

/* ── LISTING ──────────────────────────────────────────────── */
.blog-main{padding:60px 0 80px}
.blog-cat{display:inline-flex;align-items:center;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--accent);background:rgba(45,74,62,.08);border:1px solid rgba(45,74,62,.15);padding:4px 12px;border-radius:100px}

/* Featured */
.blog-featured{display:grid;grid-template-columns:1fr 1fr;background:#fff;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);margin-bottom:48px;box-shadow:var(--shadow);transition:var(--transition)}
.blog-featured:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.blog-featured-img{position:relative;min-height:380px;background:linear-gradient(135deg,var(--accent),var(--dark));overflow:hidden}
.blog-featured-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.blog-featured:hover .blog-featured-img img{transform:scale(1.03)}
.blog-featured-body{padding:44px 36px;display:flex;flex-direction:column;gap:12px}
.blog-featured-title{font-size:clamp(18px,2.3vw,25px);font-weight:800;color:var(--dark);letter-spacing:-.03em;line-height:1.2}
.blog-featured-title a{color:inherit;text-decoration:none;transition:color .2s}
.blog-featured-title a:hover{color:var(--accent)}
.blog-excerpt{font-size:15px;color:var(--text-muted);line-height:1.7;flex:1}

/* Cards grid */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.blog-card{background:#fff;border-radius:var(--radius);overflow:hidden;border:1.5px solid transparent;transition:var(--transition);display:flex;flex-direction:column}
.blog-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:var(--shadow)}
.blog-card-img-link{display:block;text-decoration:none}
.blog-card-img{height:185px;background:linear-gradient(135deg,var(--accent),var(--dark));position:relative;overflow:hidden}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.blog-card:hover .blog-card-img img{transform:scale(1.05)}
.blog-img-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:.15}
.blog-img-placeholder svg{stroke:#fff}
.blog-card-cat{position:absolute;top:12px;left:12px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#fff;background:rgba(0,0,0,.4);backdrop-filter:blur(6px);padding:3px 10px;border-radius:100px}
.blog-card-body{padding:22px;flex:1;display:flex;flex-direction:column}
.blog-card-body h3{font-size:15px;font-weight:700;color:var(--dark);margin-bottom:8px;line-height:1.35}
.blog-card-body h3 a{color:inherit;text-decoration:none;transition:color .2s}
.blog-card-body h3 a:hover{color:var(--accent)}
.blog-card-excerpt{font-size:13px;color:var(--text-muted);line-height:1.65;flex:1;margin-bottom:14px}
.blog-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid var(--border-2);margin-top:auto}
.blog-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.blog-author,.blog-date{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-muted)}
.blog-author svg,.blog-date svg{width:12px;height:12px;flex-shrink:0}
.blog-read-more{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:700;color:var(--accent);text-decoration:none;transition:gap .2s;white-space:nowrap}
.blog-read-more:hover{gap:8px}

/* Pagination */
.blog-pagination{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:52px;flex-wrap:wrap}
.blog-pag-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:100px;font-size:13.5px;font-weight:600;text-decoration:none;border:1.5px solid var(--border);color:var(--text);background:#fff;transition:var(--transition)}
.blog-pag-btn:hover{border-color:var(--accent);color:var(--accent)}
.blog-pag-info{font-size:13px;color:var(--text-muted)}

/* ══════════════════════════════════════════════════════════════
   SINGLE POST
══════════════════════════════════════════════════════════════ */

.post-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:20px}
.post-meta-item{display:flex;align-items:center;gap:5px;font-size:13px;color:var(--text-muted)}
.post-meta-item svg{width:13px;height:13px;flex-shrink:0}
.post-meta-sep{color:var(--border)}
.post-grid{display:grid;grid-template-columns:1fr 300px;gap:56px;align-items:start}
.post-lead{font-size:18px;line-height:1.75;color:var(--text);font-style:italic;font-weight:300;padding:22px 26px;background:var(--bg);border-left:4px solid var(--accent);border-radius:0 var(--r-sm) var(--r-sm) 0;margin-bottom:36px}

/* TOC */
.post-toc{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:36px;overflow:hidden}
.post-toc-header{display:flex;align-items:center;gap:10px;padding:15px 20px;font-size:14px;font-weight:700;color:var(--dark);cursor:pointer;user-select:none;border-bottom:1px solid var(--border)}
.post-toc-header svg:first-child{stroke:var(--accent);flex-shrink:0}
.toc-chevron{margin-left:auto;transition:transform .25s;stroke:var(--text-muted)}
.post-toc.collapsed .toc-chevron{transform:rotate(-90deg)}
.post-toc.collapsed .post-toc-list{display:none}
.post-toc-list{list-style:none;padding:12px 20px;display:flex;flex-direction:column;gap:5px}
.post-toc-list li a{font-size:13.5px;color:var(--text-muted);text-decoration:none;transition:color .2s;display:block;line-height:1.45;padding:2px 0}
.post-toc-list li a:hover{color:var(--accent)}
.toc-2{padding-left:0}
.toc-3{padding-left:16px;font-size:13px}

/* Content */
.post-content{font-size:16px;line-height:1.9;color:#374151}
.post-content h2{font-size:clamp(20px,2.4vw,27px);font-weight:800;color:var(--dark);margin:48px 0 16px;letter-spacing:-.03em;padding-top:8px;border-top:1px solid var(--border-2)}
.post-content h3{font-size:20px;font-weight:700;color:var(--dark);margin:34px 0 12px}
.post-content h4{font-size:17px;font-weight:700;color:var(--dark);margin:24px 0 10px}
.post-content p{margin-bottom:22px}
.post-content ul,.post-content ol{margin:14px 0 22px 22px;display:flex;flex-direction:column;gap:8px}
.post-content li{font-size:15.5px;line-height:1.75}
.post-content ul li{list-style:disc}
.post-content ol li{list-style:decimal}
.post-content blockquote{border-left:4px solid var(--gold);padding:18px 24px;background:rgba(200,169,110,.06);border-radius:0 var(--r-sm) var(--r-sm) 0;margin:28px 0;font-style:italic;font-size:17px;color:var(--text)}
.post-content a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.post-content a:hover{opacity:.8}
.post-content img{max-width:100%;border-radius:var(--r);margin:24px 0;box-shadow:var(--shadow)}
.post-content code{background:var(--bg);padding:2px 7px;border-radius:4px;font-size:14px;font-family:monospace;color:var(--accent)}
.post-content pre{background:var(--dark);color:#e5e7eb;padding:22px;border-radius:var(--r);overflow-x:auto;margin:24px 0}
.post-content pre code{background:none;color:inherit;padding:0}
.post-content table{width:100%;border-collapse:collapse;margin:24px 0;font-size:14px}
.post-content th{background:var(--dark);color:#fff;padding:11px 14px;text-align:left;font-weight:600}
.post-content td{padding:10px 14px;border-bottom:1px solid var(--border)}
.post-content hr{border:none;border-top:1px solid var(--border);margin:40px 0}
.post-content strong{color:var(--dark);font-weight:700}

/* Tags */
.post-tags-section{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:36px;padding-top:24px;border-top:1px solid var(--border)}
.post-tags-label{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}

/* Author */
.post-author-card{display:flex;align-items:center;gap:18px;background:var(--bg);border-radius:var(--radius);padding:24px;margin-top:36px;border:1px solid var(--border)}
.post-author-avatar{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--gold));display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;color:#fff;flex-shrink:0;font-family:'Syne',sans-serif}

/* Share */
.post-share{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:24px}
.share-btn{display:inline-flex;align-items:center;gap:5px;padding:7px 13px;border-radius:100px;font-size:12.5px;font-weight:600;text-decoration:none;border:1.5px solid var(--border);color:var(--text);background:#fff;transition:var(--transition);cursor:pointer;font-family:inherit}
.share-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}

/* Prev / Next */
.post-prevnext{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:40px;padding-top:32px;border-top:1px solid var(--border)}
.prevnext-card{display:flex;flex-direction:column;gap:6px;padding:18px 20px;border:1.5px solid var(--border);border-radius:var(--radius);text-decoration:none;transition:var(--transition);background:#fff}
.prevnext-card:hover{border-color:var(--accent);background:rgba(45,74,62,.03)}
.prevnext-label{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}
.prevnext-next .prevnext-label{justify-content:flex-end}
.prevnext-title{font-size:14px;font-weight:700;color:var(--dark);line-height:1.4}
.prevnext-next .prevnext-title{text-align:right}

/* Sidebar */
.post-sidebar{position:sticky;top:90px;display:flex;flex-direction:column;gap:18px}

/* ══ RESPONSIVE ══ */
@media(max-width:1024px){
  .blog-featured{grid-template-columns:1fr}
  .blog-featured-img{min-height:240px}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
  .post-grid{grid-template-columns:1fr;gap:40px}
  .post-sidebar{position:static}
}
@media(max-width:768px){
  .blog-filter-inner{flex-direction:column;align-items:stretch}
  .blog-search-input{width:100%}
  .blog-grid{grid-template-columns:1fr}
  .blog-featured-body{padding:28px 22px}
  .blog-main{padding:40px 0 56px}
  .post-prevnext{grid-template-columns:1fr}
  .prevnext-next .prevnext-title,.prevnext-next .prevnext-label{text-align:left;justify-content:flex-start}
}

/* ── SIDEBAR CONSULTATION CARD (dark branded) ──────────────── */
.sidebar-consult-card {
  background: linear-gradient(160deg, #1a1f2e 0%, #2d4a3e 100%);
  border-radius: 16px;
  padding: 28px 24px;
  border: 1px solid rgba(255,255,255,.06);
  box-shadow: 0 8px 32px rgba(0,0,0,.18);
}
.sidebar-consult-badge {
  display: inline-flex;
  align-items: center;
  background: rgba(200,169,110,.15);
  border: 1px solid rgba(200,169,110,.3);
  color: #c8a96e;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  padding: 4px 12px;
  border-radius: 100px;
  margin-bottom: 14px;
}
.sidebar-consult-card h3,
.sidebar-consult-title {
  font-size: 17px;
  font-weight: 800;
  color: #ffffff !important;
  margin-bottom: 10px;
  line-height: 1.3;
  letter-spacing: -.02em;
}
.sidebar-consult-desc {
  font-size: 13px;
  color: rgba(255,255,255,.55) !important;
  line-height: 1.7;
  margin-bottom: 18px;
}
.sidebar-consult-benefits {
  display: flex;
  flex-direction: column;
  gap: 7px;
  margin-bottom: 20px;
}
.scb-item {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 12.5px;
  color: rgba(255,255,255,.65);
}
.scb-item svg { stroke: #c8a96e; flex-shrink: 0; }
.sidebar-consult-btn {
  width: 100%;
  padding: 13px 16px;
  background: #c8a96e;
  color: #1a1f2e;
  border: none;
  border-radius: 100px;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  font-family: inherit;
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  transition: background .2s, transform .15s;
}
.sidebar-consult-btn:hover {
  background: #d4b87a;
  transform: translateY(-1px);
}
.sidebar-consult-phone {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  font-size: 13px;
  color: rgba(255,255,255,.4) !important;
  text-decoration: none;
  transition: color .2s;
}
.sidebar-consult-phone:hover { color: rgba(255,255,255,.7) !important; }
.sidebar-consult-phone svg { stroke: rgba(255,255,255,.35); flex-shrink: 0; }