/* Page-specific overrides */

/* ===== HOMEPAGE ===== */
.home-hero { padding: 0; }
.home-hero .hero-sidebar-main { min-height: 100vh; }

/* ===== BLOG SINGLE ===== */
.blog-article { max-width: 760px; margin: 0 auto; }
.blog-article-header { margin-bottom: 48px; }
.blog-article-header h1 { font-size: clamp(28px, 4vw, 46px); line-height: 1.15; margin-bottom: 20px; }
.blog-article-meta { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; margin-bottom: 32px; }
.blog-article-meta .blog-date { font-size: var(--text-sm); color: var(--text-muted); }
.blog-article-divider { height: 1px; background: var(--border); margin: 32px 0; }
.blog-content h2 { font-size: var(--text-2xl); margin: 40px 0 16px; }
.blog-content h3 { font-size: var(--text-xl); margin: 32px 0 14px; color: var(--text-primary); }
.blog-content p  { font-size: var(--text-base); line-height: 1.8; margin-bottom: 1.5em; }
.blog-content ul,
.blog-content ol { padding-left: 24px; margin-bottom: 1.5em; }
.blog-content ul { list-style: disc; }
.blog-content ol { list-style: decimal; }
.blog-content li { font-size: var(--text-base); color: var(--text-secondary); margin-bottom: 8px; line-height: 1.7; }
.blog-content strong { color: var(--text-primary); }
.blog-content blockquote {
  border-left: 3px solid var(--indigo);
  padding: 16px 20px;
  background: var(--bg-secondary);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  margin: 24px 0;
}
.blog-content blockquote p { margin: 0; font-style: italic; color: var(--text-primary); }
.blog-content .checklist { list-style: none; padding-left: 0; }
.blog-content .checklist li { display: flex; gap: 10px; align-items: flex-start; }
.blog-content .checklist li::before { content: '✓'; color: var(--emerald); font-weight: 700; flex-shrink: 0; }
.blog-back {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: var(--text-sm); font-weight: 600; color: var(--text-muted);
  margin-bottom: 32px;
  transition: color var(--t-fast);
}
.blog-back:hover { color: var(--indigo); }

/* ===== SERVICE DETAIL PAGE ===== */
.service-what-includes { background: var(--bg-secondary); }
.service-approach { background: var(--bg-primary); }
.service-who { background: var(--bg-tertiary); }
.includes-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 20px; }
.includes-item {
  background: var(--bg-primary);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 24px;
  transition: border-color var(--t-fast);
}
.includes-item:hover { border-color: var(--border-hover); }
.includes-icon { font-size: 24px; margin-bottom: 12px; }
.includes-item h4 { font-size: var(--text-base); margin-bottom: 6px; }
.includes-item p  { font-size: var(--text-sm); margin: 0; }
.who-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 16px; }
.who-item {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 20px;
  display: flex; align-items: flex-start; gap: 12px;
}
.who-icon { font-size: 20px; flex-shrink: 0; margin-top: 2px; }
.who-item h4 { font-size: var(--text-base); margin-bottom: 4px; }
.who-item p  { font-size: var(--text-xs); color: var(--text-muted); margin: 0; }

/* ===== 404 PAGE ===== */
.page-404 {
  min-height: 100vh;
  display: flex; align-items: center; justify-content: center;
  text-align: center; padding: 40px;
}
.page-404 .error-code {
  font-size: 120px; font-weight: 900; line-height: 1;
  background: var(--gradient-primary);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 16px;
}
.page-404 h1 { font-size: var(--text-3xl); margin-bottom: 16px; }
.page-404 p  { font-size: var(--text-lg); margin-bottom: 32px; max-width: 480px; margin-inline: auto; }

/* ===== PRIVACY PAGE ===== */
.privacy-content h2 { font-size: var(--text-2xl); margin: 40px 0 16px; padding-top: 40px; border-top: 1px solid var(--border); }
.privacy-content h2:first-child { border-top: none; padding-top: 0; margin-top: 0; }
.privacy-content p, .privacy-content li { font-size: var(--text-base); line-height: 1.8; }
.privacy-content ul { padding-left: 24px; list-style: disc; margin-bottom: 1.5em; }
.privacy-content li { margin-bottom: 8px; color: var(--text-secondary); }

/* ===== SOCIAL MEDIA PAGE ===== */
.social-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 20px; max-width: 800px; margin: 0 auto; }
.social-card {
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 32px 24px;
  text-align: center; text-decoration: none;
  transition: all var(--t-base); display: flex; flex-direction: column; align-items: center; gap: 12px;
}
.social-card:hover { border-color: var(--border-hover); transform: translateY(-3px); }
.social-card i { font-size: 32px; }
.social-card span { font-size: var(--text-base); font-weight: 700; color: var(--text-primary); }
.social-card small { font-size: var(--text-sm); color: var(--text-muted); }
.social-li { color: #0077b5; }
.social-x  { color: #fff; }
.social-ig { color: #e1306c; }
.social-fb { color: #1877f2; }

/* ===== AI GRADIENT HERO PLACEHOLDERS ===== */
.ai-hero-visual {
  border-radius: var(--radius-xl);
  background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);
  border: 1px solid var(--border);
  min-height: 340px;
  display: flex; align-items: center; justify-content: center;
  font-size: 80px;
  position: relative; overflow: hidden;
}
.ai-hero-visual::before {
  content: '';
  position: absolute; top: -50px; right: -50px;
  width: 200px; height: 200px;
  background: radial-gradient(circle, rgba(99,102,241,0.2) 0%, transparent 70%);
}
.ai-hero-visual::after {
  content: '';
  position: absolute; bottom: -50px; left: -50px;
  width: 200px; height: 200px;
  background: radial-gradient(circle, rgba(34,211,238,0.15) 0%, transparent 70%);
}

/* Responsive pages */
@media (max-width: 768px) {
  .includes-grid { grid-template-columns: 1fr; }
  .page-404 .error-code { font-size: 80px; }
  .blog-article { padding-inline: var(--container-pad); }
}
