/*
Theme Name: TechySEO Blog
Theme URI: https://techyseo.com
Author: TechySEO Team
Author URI: https://techyseo.com
Description: Official blog theme for TechySEO – Technical SEO Monitoring Platform. Matches the main TechySEO design with full dark/light mode support, responsive layouts, and SEO-optimized markup.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: techyseo
Tags: blog, dark-mode, custom-colors, custom-logo, custom-menu, featured-images, editor-style, sticky-post, threaded-comments
*/

/* ─────────────────────────────────────────────────────
   1. DESIGN TOKENS / CSS VARIABLES
───────────────────────────────────────────────────── */
:root {
  --bg: #0B1120;
  --bg2: #0F172A;
  --bg3: #111827;
  --card: #131e30;
  --card2: #1a2540;
  --border: rgba(255,255,255,0.07);
  --border2: rgba(255,255,255,0.12);
  --text: #F1F5F9;
  --text2: #94A3B8;
  --text3: #64748B;
  --primary: #2563EB;
  --primary-light: #60A5FA;
  --accent: #06B6D4;
  --accent-light: #67E8F9;
  --success: #10B981;
  --warning: #F59E0B;
  --danger: #EF4444;
  --gradient: linear-gradient(135deg, #2563EB 0%, #06B6D4 100%);
  --glow: 0 0 40px rgba(37,99,235,0.25);
  --shadow: 0 4px 24px rgba(0,0,0,0.3);
  --shadow-lg: 0 8px 48px rgba(0,0,0,0.5);
  --radius: 12px;
  --radius-lg: 16px;
}

[data-theme="light"] {
  --bg: #F8FAFC;
  --bg2: #F1F5F9;
  --bg3: #E2E8F0;
  --card: #FFFFFF;
  --card2: #F8FAFC;
  --border: rgba(0,0,0,0.07);
  --border2: rgba(0,0,0,0.12);
  --text: #0F172A;
  --text2: #475569;
  --text3: #94A3B8;
  --glow: 0 0 40px rgba(37,99,235,0.12);
  --shadow: 0 4px 24px rgba(0,0,0,0.08);
  --shadow-lg: 0 8px 48px rgba(0,0,0,0.12);
}

/* ─────────────────────────────────────────────────────
   2. RESET & BASE
───────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.6;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; }
a { color: var(--primary-light); text-decoration: none; }
a:hover { text-decoration: underline; }
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--card2); border-radius: 3px; }

/* ─────────────────────────────────────────────────────
   3. LAYOUT
───────────────────────────────────────────────────── */
.container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.blog-layout { display: grid; grid-template-columns: 1fr 320px; gap: 48px; padding: 60px 0; }
.content-area { min-width: 0; }
.sidebar-area { width: 320px; }

@media (max-width: 1024px) {
  .blog-layout { grid-template-columns: 1fr; }
  .sidebar-area { width: 100%; }
}

/* ─────────────────────────────────────────────────────
   4. HEADER
───────────────────────────────────────────────────── */
#site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(11,17,32,0.8);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border);
  transition: all 0.3s;
}
[data-theme="light"] #site-header {
  background: rgba(248,250,252,0.85);
  border-color: rgba(0,0,0,0.07);
}
#site-header.scrolled {
  background: rgba(11,17,32,0.97);
  box-shadow: 0 1px 0 rgba(37,99,235,0.15), 0 4px 24px rgba(0,0,0,0.3);
}
[data-theme="light"] #site-header.scrolled {
  background: rgba(248,250,252,0.97);
  box-shadow: 0 1px 0 rgba(0,0,0,0.05), 0 4px 24px rgba(0,0,0,0.06);
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 64px;
  gap: 24px;
}
.site-logo {
  display: flex; align-items: center; gap: 10px;
  text-decoration: none; flex-shrink: 0;
  font-weight: 800; font-size: 18px; color: var(--text);
}
.site-logo:hover { text-decoration: none; color: var(--text); }
.site-logo .theme-logo { display: block; width: 150px; height: auto; }
.site-logo .theme-logo-light { display: none; }
[data-theme="light"] .site-logo .theme-logo-dark { display: none; }
[data-theme="light"] .site-logo .theme-logo-light { display: block; }
.logo-icon {
  width: 34px; height: 34px; border-radius: 8px;
  background: var(--gradient);
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 900; color: #fff;
  flex-shrink: 0;
}
.site-logo span { color: var(--accent); }
.site-logo small {
  font-size: 10px; font-weight: 600; color: var(--accent);
  background: rgba(6,182,212,0.1); border: 1px solid rgba(6,182,212,0.2);
  padding: 2px 6px; border-radius: 4px; margin-left: 4px; vertical-align: middle;
}
.site-nav { display: flex; align-items: center; gap: 4px; flex: 1; justify-content: center; }
.site-nav a {
  font-size: 14px; font-weight: 500; color: var(--text2);
  padding: 6px 12px; border-radius: 8px;
  transition: all 0.2s; text-decoration: none;
}
.site-nav a:hover { color: var(--text); background: rgba(255,255,255,0.06); text-decoration: none; }
.site-nav a.active { color: var(--text); }
[data-theme="light"] .site-nav a:hover { background: rgba(0,0,0,0.05); }
.header-right { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.header-cta { display: inline-flex; }
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 7px;
  padding: 9px 18px; border-radius: 8px;
  font-weight: 600; font-size: 14px; cursor: pointer;
  transition: all 0.2s; text-decoration: none; border: none; letter-spacing: 0.01em;
}
.btn-ghost { background: transparent; color: var(--text2); border: 1px solid var(--border); }
.btn-ghost:hover { background: var(--card); color: var(--text); text-decoration: none; border-color: var(--border2); }
.btn-primary {
  background: var(--gradient); color: #fff;
  box-shadow: 0 4px 14px rgba(37,99,235,0.35);
}
.btn-primary:hover { transform: translateY(-1px); box-shadow: 0 6px 20px rgba(37,99,235,0.45); text-decoration: none; }
.theme-toggle {
  width: 38px; height: 38px; border-radius: 8px;
  background: var(--card); border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: all 0.2s; color: var(--text2); flex-shrink: 0;
}
.theme-toggle:hover { border-color: var(--primary); color: var(--primary-light); }
.theme-toggle svg { width: 15px; height: 15px; }
.icon-sun { display: none; }
.icon-moon { display: block; }
[data-theme="light"] .icon-sun { display: block; }
[data-theme="light"] .icon-moon { display: none; }
.mobile-menu-btn {
  display: none; width: 38px; height: 38px; border-radius: 8px;
  background: var(--card); border: 1px solid var(--border); color: var(--text2);
  align-items: center; justify-content: center; cursor: pointer;
  transition: all 0.2s;
}
.mobile-menu-btn:hover { border-color: var(--primary); color: var(--primary-light); }
.mobile-menu-btn svg { width: 20px; height: 20px; pointer-events: none; }
.mobile-menu-backdrop {
  position: fixed;
  inset: 64px 0 0 0;
  background: rgba(2, 6, 23, 0.56);
  backdrop-filter: blur(4px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.25s ease, visibility 0.25s ease;
  z-index: 98;
}
.mobile-menu-backdrop.is-open { opacity: 1; visibility: visible; pointer-events: auto; }
.mobile-menu-panel {
  position: fixed;
  top: 64px;
  right: 0;
  width: min(100vw, 380px);
  height: calc(100vh - 64px);
  background: var(--bg2);
  border-left: 1px solid var(--border);
  box-shadow: var(--shadow-lg);
  transform: translateX(100%);
  transition: transform 0.28s ease;
  z-index: 99;
  display: flex;
  flex-direction: column;
}
.mobile-menu-panel.is-open { transform: translateX(0); }
.mobile-menu-panel__header {
  padding: 18px 18px 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid var(--border);
}
.mobile-menu-panel__title { font-size: 15px; font-weight: 800; color: var(--text); }
.mobile-menu-close {
  width: 38px; height: 38px; border-radius: 10px;
  border: 1px solid var(--border); background: var(--card);
  color: var(--text2); display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer; font-size: 24px; line-height: 1; padding: 0;
}
.mobile-menu-panel__body { padding: 16px 18px 20px; display: flex; flex-direction: column; gap: 8px; overflow-y: auto; }
.mobile-menu-panel__body a {
  padding: 12px 14px; border-radius: 12px; color: var(--text2); font-size: 15px; font-weight: 600; text-decoration: none;
}
.mobile-menu-panel__body a:hover { background: var(--card); color: var(--text); }
.mobile-menu-panel__body .btn { margin-top: 8px; text-align: center; justify-content: center; }
.nav-divider { height: 1px; background: var(--border); margin: 8px 0; }

@media (max-width: 991.98px) {
  .site-nav { display: none; }
  .header-search { display: none; }
  .header-cta { display: none; }
  .mobile-menu-btn { display: flex; }
}

/* ─────────────────────────────────────────────────────
   5. HERO / PAGE BANNER
───────────────────────────────────────────────────── */
.blog-hero {
  padding: 80px 0 60px;
  background: linear-gradient(180deg, var(--bg2) 0%, var(--bg) 100%);
  border-bottom: 1px solid var(--border);
  position: relative;
  overflow: hidden;
}
.blog-hero::before {
  content:''; position:absolute; inset:0;
  background-image: linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px);
  background-size: 48px 48px; pointer-events: none;
}
[data-theme="light"] .blog-hero::before {
  background-image: linear-gradient(rgba(0,0,0,0.03) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(0,0,0,0.03) 1px, transparent 1px);
}
.blog-hero-glow {
  position: absolute; top: -60px; left: 50%; transform: translateX(-50%);
  width: 600px; height: 300px; pointer-events: none;
  background: radial-gradient(ellipse, rgba(37,99,235,0.15) 0%, transparent 70%);
}
.blog-hero-title {
  font-size: clamp(36px, 5vw, 52px); font-weight: 900;
  line-height: 1.1; letter-spacing: -0.03em; color: var(--text); margin-bottom: 16px;
}
.blog-hero-sub { font-size: 17px; color: var(--text2); max-width: 560px; }
.breadcrumb {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; color: var(--text3); margin-bottom: 20px; flex-wrap: wrap;
}
.breadcrumb a { color: var(--text3); text-decoration: none; }
.breadcrumb a:hover { color: var(--primary-light); }
.breadcrumb span { opacity: 0.4; }
.highlight { background: var(--gradient); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }

/* ─────────────────────────────────────────────────────
   6. POST CARDS (ARCHIVE / INDEX)
───────────────────────────────────────────────────── */
.posts-grid { display: flex; flex-direction: column; gap: 28px; }
.post-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius-lg); overflow: hidden;
  transition: all 0.3s; display: flex; flex-direction: column;
}
.post-card:hover { border-color: rgba(37,99,235,0.3); transform: translateY(-2px); box-shadow: var(--shadow); }
.post-card-inner { display: grid; grid-template-columns: 260px 1fr; }
.post-card-thumb {
  aspect-ratio: 4/3; overflow: hidden;
  background: linear-gradient(135deg, var(--card2) 0%, var(--bg2) 100%);
}
.post-card-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s; }
.post-card:hover .post-card-thumb img { transform: scale(1.03); }
.post-card-thumb-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center; font-size: 40px;
}
.post-card-body { padding: 28px 32px; display: flex; flex-direction: column; }
.post-meta { display: flex; align-items: center; flex-wrap: wrap; gap: 10px; margin-bottom: 12px; }
.post-cat {
  font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em;
  padding: 3px 10px; border-radius: 20px;
  background: rgba(37,99,235,0.12); color: var(--primary-light);
  text-decoration: none;
}
.post-cat:hover { background: rgba(37,99,235,0.2); text-decoration: none; }
.post-date { font-size: 12px; color: var(--text3); }
.post-read-time { font-size: 12px; color: var(--text3); }
.post-card-title { font-size: 20px; font-weight: 800; line-height: 1.3; color: var(--text); margin-bottom: 10px; }
.post-card-title a { color: inherit; text-decoration: none; }
.post-card-title a:hover { color: var(--primary-light); }
.post-card-excerpt { font-size: 14px; color: var(--text2); line-height: 1.7; flex: 1; margin-bottom: 18px; }
.post-card-footer { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 10px; }
.post-author { display: flex; align-items: center; gap: 9px; font-size: 13px; color: var(--text2); text-decoration: none; }
.post-author:hover { color: var(--text); text-decoration: none; }
.author-avatar {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--gradient); object-fit: cover;
  display: flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 800; color: #fff; flex-shrink: 0;
  overflow: hidden;
}
.post-card-footer .post-read-link {
  font-size: 13px; font-weight: 600; color: var(--primary-light);
  display: flex; align-items: center; gap: 4px; text-decoration: none;
}
.post-card-footer .post-read-link:hover { color: var(--accent-light); text-decoration: none; }
@media (max-width: 700px) {
  .post-card-inner { grid-template-columns: 1fr; }
  .post-card-thumb { aspect-ratio: 16/9; }
  .post-card-body { padding: 20px; }
}

/* Featured post */
.post-card.featured { border-color: rgba(37,99,235,0.25); }
.post-card.featured .post-card-title { font-size: 24px; }
.featured-badge {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 10px; font-weight: 800; text-transform: uppercase;
  padding: 3px 10px; border-radius: 20px;
  background: var(--gradient); color: #fff; margin-bottom: 8px;
}

/* ─────────────────────────────────────────────────────
   7. SINGLE POST
───────────────────────────────────────────────────── */
.single-hero {
  padding: 72px 0 48px;
  background: linear-gradient(180deg, var(--bg2) 0%, var(--bg) 100%);
  border-bottom: 1px solid var(--border);
}
.post-category-group { margin-bottom: 16px; display: flex; flex-wrap: wrap; gap: 8px; }
.single-title { font-size: clamp(28px, 4vw, 48px); font-weight: 900; line-height: 1.15; letter-spacing: -0.02em; color: var(--text); margin-bottom: 20px; max-width: 800px; }
.single-meta { display: flex; align-items: center; flex-wrap: wrap; gap: 14px; font-size: 14px; color: var(--text2); }
.single-author { display: flex; align-items: center; gap: 9px; text-decoration: none; color: var(--text2); }
.single-author:hover { color: var(--text); text-decoration: none; }
.single-author img, .single-author-av {
  width: 36px; height: 36px; border-radius: 50%; object-fit: cover;
  background: var(--gradient);
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; color: #fff;
  overflow: hidden;
}
.meta-divider { width: 3px; height: 3px; border-radius: 50%; background: var(--text3); }
.post-thumbnail { width: 100%; max-height: 480px; object-fit: cover; border-radius: var(--radius-lg); margin: 40px 0 0; display: block; }

/* Content */
.entry-content {
  font-size: 17px; line-height: 1.85; color: var(--text);
  max-width: 720px; margin-top: 44px;
}
.entry-content h2 { font-size: 28px; font-weight: 800; margin: 44px 0 16px; letter-spacing: -0.02em; }
.entry-content h3 { font-size: 22px; font-weight: 700; margin: 36px 0 12px; }
.entry-content h4 { font-size: 18px; font-weight: 700; margin: 28px 0 10px; }
.entry-content p { margin-bottom: 22px; }
.entry-content ul, .entry-content ol { margin: 0 0 22px 24px; }
.entry-content li { margin-bottom: 8px; }
.entry-content a { color: var(--primary-light); }
.entry-content a:hover { color: var(--accent-light); }
.entry-content blockquote {
  margin: 32px 0;
  padding: 20px 24px 20px 28px;
  border-left: 4px solid var(--primary);
  background: rgba(37,99,235,0.08);
  border-radius: 0 var(--radius) var(--radius) 0;
  font-style: italic; font-size: 18px; color: var(--text2);
}
.entry-content code {
  font-family: 'Fira Code', 'Consolas', monospace;
  font-size: 14px; background: var(--card2); padding: 2px 6px;
  border-radius: 4px; color: var(--accent);
}
.entry-content pre {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 24px; overflow-x: auto;
  margin-bottom: 22px;
}
.entry-content pre code { background: none; padding: 0; font-size: 14px; color: var(--text2); }
.entry-content img { border-radius: var(--radius); margin: 8px 0; }
.entry-content figure { margin: 32px 0; }
.entry-content figcaption { font-size: 13px; color: var(--text3); text-align: center; margin-top: 10px; }
.entry-content table { width: 100%; border-collapse: collapse; margin-bottom: 22px; }
.entry-content table th { font-weight: 700; padding: 10px 14px; background: var(--card2); border: 1px solid var(--border); text-align:left; }
.entry-content table td { padding: 10px 14px; border: 1px solid var(--border); }
.entry-content table tr:nth-child(even) td { background: rgba(255,255,255,0.02); }
.entry-content .wp-block-separator { height: 1px; background: var(--border); border: none; margin: 40px 0; }

/* Tags */
.post-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 40px; padding-top: 32px; border-top: 1px solid var(--border); }
.post-tags a {
  font-size: 12px; font-weight: 600; padding: 5px 12px; border-radius: 20px;
  background: var(--card2); border: 1px solid var(--border); color: var(--text2);
  text-decoration: none; transition: all 0.2s;
}
.post-tags a:hover { border-color: rgba(37,99,235,0.3); color: var(--primary-light); background: rgba(37,99,235,0.06); text-decoration: none; }

/* Author box */
.author-box {
  display: flex; gap: 20px; align-items: flex-start;
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 28px; margin-top: 48px;
}
.author-box-avatar {
  width: 72px; height: 72px; border-radius: 50%; flex-shrink: 0;
  object-fit: cover; background: var(--gradient); overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; font-weight: 900; color: #fff;
}
.author-box-info .author-role { font-size: 11px; font-weight: 700; color: var(--accent); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 4px; }
.author-box-info .author-name { font-size: 18px; font-weight: 800; color: var(--text); margin-bottom: 8px; }
.author-box-info .author-bio { font-size: 14px; color: var(--text2); line-height: 1.7; }

/* Post nav */
.post-navigation { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 48px; padding-top: 32px; border-top: 1px solid var(--border); }
.post-nav-item { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: 18px 20px; transition: all 0.2s; text-decoration: none; }
.post-nav-item:hover { border-color: rgba(37,99,235,0.3); text-decoration: none; }
.post-nav-item.next { text-align: right; }
.post-nav-label { font-size: 11px; font-weight: 700; color: var(--text3); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 6px; }
.post-nav-title { font-size: 14px; font-weight: 700; color: var(--text); line-height: 1.4; }
@media (max-width: 560px) { .post-navigation { grid-template-columns: 1fr; } }

/* ─────────────────────────────────────────────────────
   8. SIDEBAR
───────────────────────────────────────────────────── */
.sidebar-area { display: flex; flex-direction: column; gap: 24px; }
.widget {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 24px;
}
.widget-title { font-size: 13px; font-weight: 800; color: var(--text3); text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 18px; }
.widget-search-form { display: flex; gap: 8px; }
.widget-search-input {
  flex: 1; padding: 10px 14px; border-radius: 8px;
  background: var(--bg2); border: 1px solid var(--border); color: var(--text);
  font-family: inherit; font-size: 14px;
}
.widget-search-input:focus { outline: none; border-color: rgba(37,99,235,0.5); }
.widget-search-btn {
  padding: 10px 14px; border-radius: 8px;
  background: var(--primary); border: none; color: #fff; cursor: pointer; font-size: 14px;
}
.recent-posts-list { display: flex; flex-direction: column; gap: 14px; }
.recent-post { display: flex; gap: 12px; align-items: flex-start; text-decoration: none; }
.recent-post:hover .rp-title { color: var(--primary-light); }
.rp-thumb {
  width: 56px; height: 56px; border-radius: 8px; object-fit: cover; flex-shrink: 0;
  background: var(--card2); overflow: hidden;
}
.rp-thumb img { width: 100%; height: 100%; object-fit: cover; }
.rp-title { font-size: 13px; font-weight: 600; color: var(--text); line-height: 1.4; margin-bottom: 4px; transition: color 0.2s; }
.rp-date { font-size: 11px; color: var(--text3); }
.categories-list { display: flex; flex-direction: column; gap: 2px; }
.categories-list a { display: flex; align-items: center; justify-content: space-between; padding: 8px 10px; border-radius: 8px; font-size: 14px; color: var(--text2); text-decoration: none; transition: all 0.2s; }
.categories-list a:hover { background: rgba(37,99,235,0.08); color: var(--text); text-decoration: none; }
.cat-count { font-size: 12px; color: var(--text3); background: var(--card2); padding: 2px 7px; border-radius: 12px; }
.tags-cloud { display: flex; flex-wrap: wrap; gap: 8px; }
.tag-link { font-size: 12px; font-weight: 600; padding: 5px 12px; border-radius: 20px; background: var(--card2); border: 1px solid var(--border); color: var(--text2); text-decoration: none; transition: all 0.2s; }
.tag-link:hover { border-color: rgba(37,99,235,0.3); color: var(--primary-light); background: rgba(37,99,235,0.06); text-decoration: none; }
.newsletter-widget { background: linear-gradient(135deg, rgba(37,99,235,0.12) 0%, rgba(6,182,212,0.06) 100%); border-color: rgba(37,99,235,0.2); }
.newsletter-widget p { font-size: 14px; color: var(--text2); margin-bottom: 14px; }
.newsletter-form { display: flex; flex-direction: column; gap: 8px; }
.newsletter-input { padding: 10px 14px; border-radius: 8px; background: var(--bg); border: 1px solid var(--border2); color: var(--text); font-family: inherit; font-size: 14px; }
.newsletter-input:focus { outline: none; border-color: rgba(37,99,235,0.5); }
.newsletter-submit { padding: 10px; border-radius: 8px; background: var(--gradient); border: none; color: #fff; font-weight: 700; font-size: 14px; cursor: pointer; transition: all 0.2s; }
.newsletter-submit:hover { opacity: 0.9; }

/* ─────────────────────────────────────────────────────
   9. COMMENTS
───────────────────────────────────────────────────── */
.comments-area { margin-top: 60px; padding-top: 48px; border-top: 1px solid var(--border); max-width: 720px; }
.comments-title { font-size: 24px; font-weight: 800; color: var(--text); margin-bottom: 32px; }
.comment-list { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 24px; }
.comment-body { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: 20px; }
.comment-meta { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.comment-avatar { width: 36px; height: 36px; border-radius: 50%; background: var(--gradient); display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 700; color: #fff; overflow: hidden; }
.comment-author-name { font-size: 14px; font-weight: 700; color: var(--text); }
.comment-date { font-size: 12px; color: var(--text3); margin-left: auto; }
.comment-text { font-size: 14px; color: var(--text2); line-height: 1.7; }
.comment-reply-link { font-size: 12px; font-weight: 600; color: var(--primary-light); margin-top: 10px; display: inline-block; }
.children { padding-left: 24px; margin-top: 16px; display: flex; flex-direction: column; gap: 16px; }
.comment-respond { margin-top: 48px; }
.comment-respond-title { font-size: 20px; font-weight: 800; color: var(--text); margin-bottom: 24px; }
.comment-form { display: flex; flex-direction: column; gap: 16px; }
.comment-form-field { display: flex; flex-direction: column; gap: 6px; }
.comment-form-field label { font-size: 13px; font-weight: 600; color: var(--text2); }
.comment-form-field input, .comment-form-field textarea {
  padding: 11px 14px; border-radius: 8px;
  background: var(--card); border: 1px solid var(--border); color: var(--text);
  font-family: inherit; font-size: 14px;
}
.comment-form-field input:focus, .comment-form-field textarea:focus { outline: none; border-color: rgba(37,99,235,0.5); }
.comment-form-fields-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 560px) { .comment-form-fields-2col { grid-template-columns: 1fr; } }
.comment-form-submit { padding: 12px 28px; border-radius: 8px; background: var(--gradient); border: none; color: #fff; font-weight: 700; font-size: 15px; cursor: pointer; transition: all 0.2s; align-self: flex-start; }
.comment-form-submit:hover { opacity: 0.9; }

/* ─────────────────────────────────────────────────────
   10. PAGINATION
───────────────────────────────────────────────────── */
.pagination { display: flex; align-items: center; justify-content: center; gap: 6px; padding: 40px 0 20px; }
.page-numbers {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; border-radius: 8px;
  background: var(--card); border: 1px solid var(--border);
  font-size: 14px; font-weight: 600; color: var(--text2);
  text-decoration: none; transition: all 0.2s;
}
.page-numbers:hover { border-color: rgba(37,99,235,0.3); color: var(--primary-light); text-decoration: none; }
.page-numbers.current { background: var(--primary); border-color: var(--primary); color: #fff; }
.page-numbers.prev, .page-numbers.next { width: auto; padding: 0 16px; }

/* ─────────────────────────────────────────────────────
   11. NO RESULTS / 404
───────────────────────────────────────────────────── */
.not-found-wrap, .no-results-wrap {
  text-align: center; padding: 80px 24px;
}
.not-found-number { font-size: clamp(80px, 15vw, 160px); font-weight: 900; letter-spacing: -0.05em; background: var(--gradient); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; line-height: 1; }
.not-found-title { font-size: 28px; font-weight: 800; color: var(--text); margin: 16px 0 12px; }
.not-found-desc { font-size: 16px; color: var(--text2); max-width: 480px; margin: 0 auto 32px; }
.not-found-search { max-width: 400px; margin: 0 auto; display: flex; gap: 10px; }
.not-found-search input { flex: 1; padding: 11px 14px; border-radius: 8px; background: var(--card); border: 1px solid var(--border); color: var(--text); font-family: inherit; font-size: 14px; }
.not-found-search input:focus { outline:none; border-color: rgba(37,99,235,0.5); }

/* ─────────────────────────────────────────────────────
   12. FOOTER
───────────────────────────────────────────────────── */
.site-footer {
  background: var(--bg2); border-top: 1px solid var(--border);
  padding: 60px 0 0; margin-top: auto;
}
.footer-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 40px; margin-bottom: 40px; }
.footer-brand-desc { font-size: 14px; color: var(--text3); line-height: 1.7; margin-top: 12px; max-width: 220px; }
.footer-social { display: flex; gap: 8px; margin-top: 16px; }
.social-btn { width: 34px; height: 34px; border-radius: 8px; background: var(--card); border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; font-size: 14px; color: var(--text2); text-decoration: none; transition: all 0.2s; }
.social-btn:hover { border-color: rgba(37,99,235,0.3); color: var(--primary-light); text-decoration: none; }
.footer-col-title { font-size: 12px; font-weight: 800; color: var(--text3); text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 14px; }
.footer-links { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.footer-links a { font-size: 14px; color: var(--text2); text-decoration: none; transition: color 0.2s; }
.footer-links a:hover { color: var(--text); text-decoration: none; }
.footer-bottom { border-top: 1px solid var(--border); padding: 20px 0; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; }
.footer-copy { font-size: 13px; color: var(--text3); }
.footer-legal { display: flex; gap: 16px; }
.footer-legal a { font-size: 13px; color: var(--text3); text-decoration: none; }
.footer-legal a:hover { color: var(--text2); text-decoration: none; }
@media (max-width: 900px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .footer-grid { grid-template-columns: 1fr; } .footer-bottom { flex-direction: column; text-align:center; } }

/* ─────────────────────────────────────────────────────
   13. UTILITIES & ANIMATIONS
───────────────────────────────────────────────────── */
.text-center { text-align: center; }
.section-label { display: inline-block; font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.1em; color: var(--accent); margin-bottom: 12px; }
@keyframes fadeInUp { from { opacity:0; transform:translateY(20px); } to { opacity:1; transform:translateY(0); } }
.reveal { opacity: 0; transform: translateY(16px); transition: opacity 0.5s ease, transform 0.5s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

/* ─────────────────────────────────────────────────────
   14. WORDPRESS CORE CLASSES
───────────────────────────────────────────────────── */
.alignleft { float: left; margin: 0 24px 16px 0; }
.alignright { float: right; margin: 0 0 16px 24px; }
.aligncenter { display: block; margin: 0 auto 16px; text-align: center; }
.alignwide { margin: 0 -40px; }
.alignfull { margin: 0 calc(50% - 50vw); max-width: 100vw; width: 100vw; }
.wp-caption { margin-bottom: 16px; }
.wp-caption-text { font-size: 13px; color: var(--text3); text-align: center; margin-top: 8px; }
.sticky::before { content: '★ Featured'; font-size: 11px; font-weight: 700; color: var(--accent); text-transform: uppercase; letter-spacing: 0.08em; display: block; margin-bottom: 8px; }
.gallery { display: grid; gap: 8px; }
.gallery-columns-2 { grid-template-columns: repeat(2, 1fr); }
.gallery-columns-3 { grid-template-columns: repeat(3, 1fr); }
.gallery-item img { width: 100%; height: 100%; object-fit: cover; border-radius: 8px; }
.screen-reader-text { position: absolute; left: -9999em; width: 1px; height: 1px; overflow: hidden; }
