/*!*******************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./src/sass/components.scss ***!
  \*******************************************************************************************************************/
@charset "UTF-8";
/* ============================================================
   SUITEPRESS — COMPLETE COMPONENT STYLES  v2
   Every component: light-mode default, dark-mode via tokens
   ============================================================ */
/* ════════════════════════════════════════════════════════════
   0. GLOBAL SHARED PATTERNS
   ════════════════════════════════════════════════════════════ */
/* Header height token — used by fixed header offset and sticky sidebars */
:root {
  --header-height: 72px;
}

/* Push page content below the fixed header */
#page {
  padding-top: var(--header-height);
}

/* Container */
.container, .sp-container {
  width: 100%;
  max-width: var(--container-xl);
  margin-inline: auto;
  padding-inline: clamp(16px, 4vw, 40px);
}

/* Common section wrapper */
.blog-section,
.wordpress-tutorials-section,
.courses-learning-section,
.featured-posts-carousel,
#suitepress-cover-container,
.footer-subscription-card,
.footer-main-section,
.footer-bottom-section {
  position: relative;
}

/* Shared section-header pattern (used across every home section) */
.section-header {
  text-align: center;
  margin-bottom: clamp(40px, 5vw, 64px);
}

.section-badge span,
.section-badge > * {
  display: inline-block;
  background: rgba(var(--color-primary-rgb), 0.1) !important;
  color: var(--color-primary-600) !important;
  padding: 6px 18px;
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  font-family: var(--font-ui);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  margin-bottom: var(--space-4);
  border: 1px solid rgba(var(--color-primary-rgb), 0.2);
}

.section-header .section-title,
.section-title {
  font-family: var(--font-heading) !important;
  font-size: clamp(28px, 4vw, 48px) !important;
  font-weight: var(--font-extrabold) !important;
  line-height: var(--leading-snug) !important;
  color: var(--color-text-primary) !important;
  letter-spacing: var(--tracking-tight) !important;
  margin-bottom: var(--space-4) !important;
}

/* Gradient accent text used in section titles */
.text-accent {
  background: linear-gradient(135deg, var(--color-primary-500) 0%, var(--color-primary-400) 60%, var(--color-accent-500) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.section-header .section-description,
.section-description {
  font-size: var(--text-md) !important;
  color: var(--color-text-muted) !important;
  line-height: var(--leading-relaxed) !important;
  max-width: 600px;
  margin: 0 auto !important;
}

/* Generic CTA buttons reused across sections */
.view-all-btn,
.section-cta .view-all-btn,
.carousel-cta .view-all-btn {
  display: inline-flex !important;
  align-items: center;
  gap: var(--space-2);
  background: var(--color-primary-500) !important;
  color: #fff !important;
  padding: var(--space-3) var(--space-8) !important;
  border-radius: var(--radius-full) !important;
  font-weight: var(--font-semibold) !important;
  font-size: var(--text-sm) !important;
  font-family: var(--font-ui);
  text-decoration: none;
  box-shadow: var(--shadow-primary-glow) !important;
  transition: background-color var(--duration-normal) var(--ease-default), transform var(--duration-fast) var(--ease-out), box-shadow var(--duration-normal) !important;
}

.view-all-btn:hover,
.section-cta .view-all-btn:hover,
.carousel-cta .view-all-btn:hover {
  background: var(--color-primary-600) !important;
  color: #fff !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 12px 36px rgba(var(--color-primary-rgb), 0.35) !important;
}

/* Category badge overlay (on card images) */
.category-badge {
  display: inline-flex;
  align-items: center;
  background: rgba(255, 255, 255, 0.92) !important;
  backdrop-filter: blur(8px);
  color: var(--color-primary-600) !important;
  padding: 4px 12px !important;
  border-radius: var(--radius-full) !important;
  font-size: var(--text-xs) !important;
  font-weight: var(--font-semibold) !important;
  font-family: var(--font-ui);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border: 1px solid rgba(var(--color-primary-rgb), 0.15);
}

/* Read-more buttons used across blog cards and carousel */
.read-more-btn {
  display: inline-flex !important;
  align-items: center;
  gap: var(--space-2) !important;
  padding: var(--space-2) var(--space-4) !important;
  background: rgba(var(--color-primary-rgb), 0.08) !important;
  color: var(--color-primary-600) !important;
  border-radius: var(--radius-full) !important;
  font-weight: var(--font-semibold) !important;
  font-size: var(--text-sm) !important;
  text-decoration: none;
  transition: background-color var(--duration-normal), color var(--duration-normal), transform var(--duration-normal) !important;
}

.read-more-btn:hover {
  background: var(--color-primary-500) !important;
  color: #fff !important;
  transform: translateX(0) !important;
}

.read-more-btn svg,
.read-more-btn i {
  transition: transform var(--duration-normal) var(--ease-out);
  font-size: 12px !important;
}

.read-more-btn:hover svg,
.read-more-btn:hover i {
  transform: translateX(3px);
}

/* ════════════════════════════════════════════════════════════
   4. BUTTONS
   ════════════════════════════════════════════════════════════ */
.btn, button.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-ui);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  line-height: 1;
  white-space: nowrap;
  text-decoration: none;
  cursor: pointer;
  border: 1.5px solid transparent;
  border-radius: var(--radius-md);
  padding: var(--space-2) var(--space-5);
  height: 40px;
  transition: background-color var(--duration-normal) var(--ease-default), color var(--duration-normal), border-color var(--duration-normal), box-shadow var(--duration-normal), transform var(--duration-fast) var(--ease-out);
  user-select: none;
}

.btn:focus-visible {
  outline: 2px solid var(--color-primary-500);
  outline-offset: 2px;
}

.btn:disabled, .btn[aria-disabled=true] {
  opacity: 0.45;
  pointer-events: none;
}

.btn-primary {
  background: var(--color-primary-500);
  color: #fff !important;
  border-color: var(--color-primary-500);
  box-shadow: var(--shadow-sm);
}

.btn-primary:hover {
  background: var(--color-primary-600);
  border-color: var(--color-primary-600);
  box-shadow: var(--shadow-primary-glow);
  color: #fff !important;
  transform: translateY(-1px);
}

.btn-primary:active {
  transform: translateY(0);
  box-shadow: var(--shadow-xs);
}

.btn-secondary {
  background: transparent;
  color: var(--color-primary-600) !important;
  border-color: var(--color-primary-300);
}

.btn-secondary:hover {
  background: rgba(var(--color-primary-rgb), 0.06);
  border-color: var(--color-primary-400);
  color: var(--color-primary-700) !important;
}

.btn-ghost {
  background: transparent;
  color: var(--color-text-secondary) !important;
  border-color: transparent;
}

.btn-ghost:hover {
  background: var(--color-gray-100);
  color: var(--color-text-primary) !important;
}

.btn-sm {
  height: 32px;
  padding: var(--space-1) var(--space-4);
  font-size: var(--text-xs);
}

.btn-lg {
  height: 52px;
  padding: var(--space-3) var(--space-8);
  font-size: var(--text-md);
  border-radius: var(--radius-lg);
}

.btn-pill {
  border-radius: var(--radius-full) !important;
}

/* Section CTA buttons (used in tutorials & courses) */
.tutorials-cta .cta-actions .btn-primary,
.courses-cta .cta-actions .btn-primary,
.cta-actions .btn-primary {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-7);
  border-radius: var(--radius-full);
  font-weight: var(--font-semibold);
  font-size: var(--text-sm);
  font-family: var(--font-ui);
  text-decoration: none;
  transition: background-color var(--duration-normal), transform var(--duration-fast), box-shadow var(--duration-normal);
  border: 1.5px solid transparent;
  cursor: pointer;
  background: var(--color-primary-500) !important;
  color: #fff !important;
  border-color: var(--color-primary-500) !important;
  box-shadow: var(--shadow-sm);
}

.tutorials-cta .cta-actions .btn-primary:hover,
.courses-cta .cta-actions .btn-primary:hover,
.cta-actions .btn-primary:hover {
  background: var(--color-primary-600) !important;
  border-color: var(--color-primary-600) !important;
  box-shadow: var(--shadow-primary-glow) !important;
  transform: translateY(-2px);
  color: #fff !important;
}

.tutorials-cta .cta-actions .btn-secondary,
.courses-cta .cta-actions .btn-secondary,
.cta-actions .btn-secondary {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-7);
  border-radius: var(--radius-full);
  font-weight: var(--font-semibold);
  font-size: var(--text-sm);
  font-family: var(--font-ui);
  text-decoration: none;
  border: 1.5px solid var(--color-border-strong);
  background: transparent;
  color: var(--color-text-secondary) !important;
  transition: border-color var(--duration-normal), background-color var(--duration-normal), color var(--duration-normal), transform var(--duration-fast);
}

.tutorials-cta .cta-actions .btn-secondary:hover,
.courses-cta .cta-actions .btn-secondary:hover,
.cta-actions .btn-secondary:hover {
  border-color: var(--color-primary-400) !important;
  background: rgba(var(--color-primary-rgb), 0.06) !important;
  color: var(--color-primary-600) !important;
  transform: translateY(-1px);
}

/* ════════════════════════════════════════════════════════════
   5. BADGES, TAGS & PILLS
   ════════════════════════════════════════════════════════════ */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  font-family: var(--font-ui);
  border-radius: var(--radius-md);
  line-height: 1.5;
  letter-spacing: 0.01em;
  white-space: nowrap;
}

.badge-primary {
  background: rgba(var(--color-primary-rgb), 0.1);
  color: var(--color-primary-700);
}

.badge-success {
  background: var(--color-success-light);
  color: var(--color-success-dark);
}

.badge-warning {
  background: var(--color-warning-light);
  color: var(--color-warning-dark);
}

.badge-error {
  background: var(--color-error-light);
  color: var(--color-error-dark);
}

.badge-neutral {
  background: var(--color-gray-100);
  color: var(--color-gray-700);
}

.badge-accent {
  background: var(--color-accent-100);
  color: var(--color-accent-700);
}

.tag {
  display: inline-flex;
  align-items: center;
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--color-text-secondary);
  background: var(--color-gray-100);
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  text-decoration: none;
  cursor: pointer;
  transition: background-color var(--duration-fast), color var(--duration-fast), border-color var(--duration-fast);
}

.tag:hover, .tag.active {
  background: rgba(var(--color-primary-rgb), 0.08);
  color: var(--color-primary-600);
  border-color: rgba(var(--color-primary-rgb), 0.2);
}

.tag-outline {
  background: transparent;
  border-color: var(--color-border-default);
}

.tag-outline:hover {
  background: rgba(var(--color-primary-rgb), 0.06);
  border-color: var(--color-primary-300);
}

.pill {
  border-radius: var(--radius-full) !important;
}

/* ════════════════════════════════════════════════════════════
   7. WORDPRESS TUTORIALS SECTION
   ════════════════════════════════════════════════════════════ */
.wordpress-tutorials-section {
  padding: var(--section-padding-y) 0;
  background: var(--color-bg-base) !important;
  overflow: hidden;
}

.wordpress-tutorials-section .section-background {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}

.wordpress-tutorials-section .section-background .bg-shape {
  position: absolute;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(var(--color-primary-rgb), 0.06), transparent 70%);
  filter: blur(40px);
}

.wordpress-tutorials-section .section-background .bg-shape.shape-1 {
  width: 300px;
  height: 300px;
  top: 10%;
  left: 5%;
}

.wordpress-tutorials-section .section-background .bg-shape.shape-2 {
  width: 200px;
  height: 200px;
  bottom: 20%;
  right: 8%;
}

.wordpress-tutorials-section .section-background .bg-shape.shape-3 {
  width: 150px;
  height: 150px;
  top: 60%;
  left: 80%;
}

.wordpress-tutorials-section .container {
  position: relative;
  z-index: 2;
}

.wordpress-tutorials-section .tutorials-content-wrapper {
  margin-bottom: var(--space-10);
}

/* Tutorials CTA card */
.tutorials-cta {
  background: var(--color-bg-elevated) !important;
  border: 1px solid var(--color-border-default) !important;
  border-radius: var(--radius-2xl) !important;
  padding: clamp(32px, 4vw, 56px) !important;
  text-align: center;
  box-shadow: var(--shadow-md) !important;
  position: relative;
  overflow: hidden;
}

/* Top accent line */
.tutorials-cta::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--color-primary-500), var(--color-accent-500));
}

.tutorials-cta .cta-content {
  margin-bottom: var(--space-8) !important;
}

.tutorials-cta .cta-content h3 {
  font-family: var(--font-heading) !important;
  font-size: var(--text-2xl) !important;
  font-weight: var(--font-bold) !important;
  color: var(--color-text-primary) !important;
  margin-bottom: var(--space-2) !important;
}

.tutorials-cta .cta-content p {
  font-size: var(--text-md) !important;
  color: var(--color-text-muted) !important;
  margin: 0 !important;
}

.tutorials-cta .cta-actions {
  display: flex;
  gap: var(--space-3);
  justify-content: center;
  flex-wrap: wrap;
}

/* ════════════════════════════════════════════════════════════
   8. COURSES / HOW COURSE SECTION
   ════════════════════════════════════════════════════════════ */
.courses-learning-section {
  padding: var(--section-padding-y) 0;
  background: var(--color-bg-subtle) !important;
  overflow: hidden;
}

.courses-learning-section .section-background {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}

.courses-learning-section .container {
  position: relative;
  z-index: 2;
}

/* Categories grid */
.course-categories {
  margin-bottom: var(--space-12);
}

.categories-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}

@media (max-width: 1023px) {
  .categories-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 639px) {
  .categories-grid {
    grid-template-columns: 1fr;
  }
}
/* Category card */
.category-card {
  background: var(--color-bg-elevated) !important;
  border: 1px solid var(--color-border-default) !important;
  border-radius: var(--radius-xl) !important;
  padding: var(--space-6) !important;
  box-shadow: var(--shadow-sm) !important;
  /* Override legacy animation */
  opacity: 1 !important;
  transform: none !important;
  animation: none !important;
  transition: transform var(--duration-normal) var(--ease-out), box-shadow var(--duration-normal) var(--ease-out), border-color var(--duration-normal) !important;
}

.category-card:hover {
  transform: translateY(-5px) !important;
  box-shadow: var(--shadow-lg) !important;
  border-color: rgba(var(--color-primary-rgb), 0.25) !important;
}

.category-card .category-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: var(--space-4) !important;
}

.category-card .category-icon {
  width: 52px;
  height: 52px;
  background: rgba(var(--color-primary-rgb), 0.1) !important;
  border-radius: var(--radius-lg) !important;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(var(--color-primary-rgb), 0.15);
}

.category-card .category-icon i {
  font-size: 1.4rem !important;
  color: var(--color-primary-500) !important;
}

.category-card .level-badge {
  padding: 4px 10px !important;
  border-radius: var(--radius-md) !important;
  font-size: var(--text-xs) !important;
  font-weight: var(--font-semibold) !important;
  font-family: var(--font-ui);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.category-card .level-badge.beginner {
  background: rgba(16, 185, 129, 0.1) !important;
  color: #059669 !important;
}

.category-card .level-badge.intermediate {
  background: rgba(var(--color-primary-rgb), 0.1) !important;
  color: var(--color-primary-600) !important;
}

.category-card .level-badge.advanced {
  background: rgba(245, 158, 11, 0.1) !important;
  color: #d97706 !important;
}

.category-card h4 {
  font-family: var(--font-heading) !important;
  font-size: var(--text-lg) !important;
  font-weight: var(--font-bold) !important;
  color: var(--color-text-primary) !important;
  margin-bottom: var(--space-2) !important;
  line-height: var(--leading-snug) !important;
}

.category-card p {
  color: var(--color-text-muted) !important;
  font-size: var(--text-sm) !important;
  line-height: var(--leading-relaxed) !important;
  margin-bottom: var(--space-4) !important;
}

.category-card .category-meta {
  display: flex;
  gap: var(--space-4);
  font-size: var(--text-xs) !important;
  color: var(--color-primary-600) !important;
  font-weight: var(--font-semibold) !important;
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-border-subtle);
}

/* Courses CTA */
.courses-cta {
  background: linear-gradient(135deg, var(--color-secondary-950) 0%, var(--color-secondary-900) 50%, #1f2d3d 100%) !important;
  color: #fff;
  padding: clamp(32px, 4vw, 56px) !important;
  border-radius: var(--radius-2xl) !important;
  text-align: center;
  box-shadow: var(--shadow-xl) !important;
  position: relative;
  overflow: hidden;
}

.courses-cta::before {
  content: "";
  position: absolute;
  width: 400px;
  height: 400px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(var(--color-primary-rgb), 0.12), transparent 70%);
  top: -200px;
  right: -100px;
  pointer-events: none;
}

.courses-cta .cta-content {
  margin-bottom: var(--space-8) !important;
  position: relative;
  z-index: 2;
}

.courses-cta .cta-content h3 {
  font-family: var(--font-heading) !important;
  font-size: var(--text-2xl) !important;
  font-weight: var(--font-bold) !important;
  color: #fff !important;
  margin-bottom: var(--space-2) !important;
}

.courses-cta .cta-content p {
  color: rgba(255, 255, 255, 0.7) !important;
  font-size: var(--text-md) !important;
  margin: 0 !important;
}

.courses-cta .cta-actions {
  display: flex;
  gap: var(--space-3);
  justify-content: center;
  flex-wrap: wrap;
  position: relative;
  z-index: 2;
}

.courses-cta .cta-actions .btn-primary {
  background: var(--color-primary-500) !important;
  color: #fff !important;
  border-color: var(--color-primary-500) !important;
}

.courses-cta .cta-actions .btn-secondary {
  background: rgba(255, 255, 255, 0.1) !important;
  color: rgba(255, 255, 255, 0.9) !important;
  border-color: rgba(255, 255, 255, 0.25) !important;
}

.courses-cta .cta-actions .btn-secondary:hover {
  background: rgba(255, 255, 255, 0.18) !important;
  color: #fff !important;
  border-color: rgba(255, 255, 255, 0.4) !important;
}

/* ════════════════════════════════════════════════════════════
   9. POSTS CAROUSEL SECTION
   ════════════════════════════════════════════════════════════ */
#posts_carousel_home.featured-posts-carousel {
  padding: var(--section-padding-y) 0;
  background: var(--color-bg-base) !important;
  overflow: hidden;
}

.featured-posts-carousel .carousel-container {
  position: relative;
  z-index: 2;
}

.featured-posts-carousel .carousel-background {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}

.featured-posts-carousel .bg-dot {
  position: absolute;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(var(--color-primary-rgb), 0.06), transparent 70%);
  filter: blur(30px);
}

.featured-posts-carousel .bg-dot.dot-1 {
  width: 200px;
  height: 200px;
  top: 10%;
  left: 5%;
}

.featured-posts-carousel .bg-dot.dot-2 {
  width: 150px;
  height: 150px;
  bottom: 15%;
  right: 8%;
}

.featured-posts-carousel .bg-dot.dot-3 {
  width: 100px;
  height: 100px;
  top: 55%;
  left: 80%;
}

/* Carousel navigation bar */
.carousel-navigation {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-6) !important;
  gap: var(--space-3);
}

.carousel-navigation .nav-btn {
  width: 44px !important;
  height: 44px !important;
  background: var(--color-bg-elevated) !important;
  border: 1.5px solid var(--color-border-default) !important;
  border-radius: var(--radius-full) !important;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--color-text-secondary) !important;
  font-size: 14px;
  transition: background-color var(--duration-normal), color var(--duration-normal), border-color var(--duration-normal), transform var(--duration-fast) !important;
  flex-shrink: 0;
}

.carousel-navigation .nav-btn:hover:not(:disabled) {
  background: var(--color-primary-500) !important;
  color: #fff !important;
  border-color: var(--color-primary-500) !important;
  transform: scale(1.08) !important;
}

.carousel-navigation .nav-btn:disabled {
  opacity: 0.35;
  cursor: not-allowed;
}

.carousel-navigation .carousel-indicators {
  display: flex;
  gap: var(--space-2);
  flex: 1;
  justify-content: center;
}

.carousel-navigation .indicator {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-border-strong);
  cursor: pointer;
  transition: background-color var(--duration-normal), transform var(--duration-normal);
}

.carousel-navigation .indicator.active {
  background: var(--color-primary-500);
  transform: scale(1.3);
  width: 24px;
  border-radius: var(--radius-full);
}

/* Carousel scroll area */
.posts-carousel {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: calc(33.333% - 1rem);
  gap: var(--space-5) !important;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scrollbar-width: none;
  margin-bottom: var(--space-10) !important;
  padding: var(--space-2) 2px !important;
  -webkit-overflow-scrolling: touch;
}

.posts-carousel::-webkit-scrollbar {
  display: none;
}

@media (max-width: 1023px) {
  .posts-carousel {
    grid-auto-columns: calc(50% - 0.75rem);
  }
}
@media (max-width: 639px) {
  .posts-carousel {
    grid-auto-columns: calc(100% - 0.5rem);
    gap: var(--space-4) !important;
  }
}
/* Post card */
.post-card {
  background: var(--color-bg-elevated) !important;
  border-radius: var(--radius-xl) !important;
  border: 1px solid var(--color-border-default) !important;
  box-shadow: var(--shadow-sm) !important;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  scroll-snap-align: start;
  /* Override legacy animation */
  opacity: 1 !important;
  transform: none !important;
  animation: none !important;
  transition: transform var(--duration-normal) var(--ease-out), box-shadow var(--duration-normal) var(--ease-out), border-color var(--duration-normal) !important;
}

.post-card:hover {
  transform: translateY(-5px) !important;
  box-shadow: var(--shadow-lg) !important;
  border-color: rgba(var(--color-primary-rgb), 0.25) !important;
}

.post-card .post-card-image {
  position: relative;
  overflow: hidden;
  height: 200px !important;
}

.post-card .post-card-image .post-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0 !important;
  transition: transform var(--duration-slow) var(--ease-out) !important;
}

.post-card:hover .post-card-image .post-image {
  transform: scale(1.05) !important;
}

.post-card .post-card-image .post-image-placeholder {
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, rgba(var(--color-primary-rgb), 0.08) 0%, rgba(var(--color-accent-rgb), 0.06) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-primary-400);
  font-size: 2.5rem;
}

.post-card .post-card-image .category-badge {
  position: absolute;
  top: var(--space-3);
  left: var(--space-3);
}

.post-card .post-card-content {
  padding: var(--space-5) !important;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.post-card .post-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-3) !important;
  font-size: var(--text-xs) !important;
  color: var(--color-text-muted) !important;
  gap: var(--space-2);
}

.post-card .post-meta .post-date {
  font-weight: var(--font-medium) !important;
}

.post-card .post-meta .post-author {
  opacity: 0.8;
}

.post-card .post-title {
  margin-bottom: var(--space-4) !important;
  flex: 1;
}

.post-card .post-title a {
  font-family: var(--font-heading) !important;
  font-size: var(--text-md) !important;
  font-weight: var(--font-semibold) !important;
  color: var(--color-text-primary) !important;
  text-decoration: none;
  line-height: var(--leading-snug) !important;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  transition: color var(--duration-normal) !important;
}

.post-card:hover .post-title a {
  color: var(--color-primary-600) !important;
}

.post-card .post-card-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: var(--space-3) !important;
  border-top: 1px solid var(--color-border-subtle) !important;
  margin-top: auto;
}

.post-card .post-stats .comments {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  color: var(--color-text-muted) !important;
  font-size: var(--text-xs) !important;
}

/* Carousel CTA */
.carousel-cta {
  text-align: center;
}

/* ════════════════════════════════════════════════════════════
   10. BLOG PAGE (archive / category)
   ════════════════════════════════════════════════════════════ */
.sp-blog-page-container .sp-blog-hero {
  background: linear-gradient(135deg, var(--color-secondary-950) 0%, var(--color-secondary-800) 60%, #1f2d3d 100%) !important;
  padding: clamp(60px, 8vw, 100px) 0 clamp(40px, 5vw, 60px) !important;
}

.sp-blog-page-container .sp-blog-title {
  font-family: var(--font-heading) !important;
  font-weight: var(--font-extrabold) !important;
  background: linear-gradient(135deg, #ffffff 0%, var(--color-primary-200) 100%) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
}

.sp-blog-page-container .sp-category-tag {
  background: rgba(var(--color-primary-rgb), 0.15) !important;
  border-color: rgba(var(--color-primary-rgb), 0.3) !important;
}

.sp-blog-page-container .sp-category-tag:hover {
  background: rgba(var(--color-primary-rgb), 0.3) !important;
}

.sp-blog-page-container .sp-search-btn {
  background: var(--color-primary-500) !important;
}

.sp-blog-page-container .sp-blog-grid {
  gap: var(--space-6) !important;
}

.sp-blog-card {
  background: var(--color-bg-elevated) !important;
  border: 1px solid var(--color-border-default) !important;
  border-radius: var(--radius-xl) !important;
  box-shadow: var(--shadow-xs) !important;
  transition: transform var(--duration-normal) var(--ease-out), box-shadow var(--duration-normal), border-color var(--duration-normal) !important;
}

.sp-blog-card:hover {
  transform: translateY(-4px) !important;
  box-shadow: var(--shadow-lg) !important;
  border-color: rgba(var(--color-primary-rgb), 0.25) !important;
}

.sp-blog-card:hover .sp-blog-thumbnail {
  transform: scale(1.05) !important;
}

.sp-blog-card-title {
  font-family: var(--font-heading);
  font-weight: var(--font-bold) !important;
}

.sp-blog-title-link {
  color: var(--color-text-primary) !important;
  transition: color var(--duration-normal) !important;
}

.sp-blog-card:hover .sp-blog-title-link {
  color: var(--color-primary-600) !important;
}

.sp-blog-card-meta {
  color: var(--color-text-muted) !important;
  font-size: var(--text-xs) !important;
}

.sp-blog-card-excerpt {
  color: var(--color-text-muted) !important;
  font-size: var(--text-sm) !important;
  line-height: var(--leading-relaxed) !important;
}

.sp-blog-card-footer {
  border-top: 1px solid var(--color-border-subtle) !important;
}

.sp-reading-time {
  background: var(--color-gray-100) !important;
  color: var(--color-text-muted) !important;
  border-radius: var(--radius-md) !important;
}

/* Pagination */
.suitepress-pagination a,
.suitepress-pagination span {
  font-family: var(--font-ui) !important;
  font-size: var(--text-sm) !important;
  font-weight: var(--font-semibold) !important;
  border-radius: var(--radius-lg) !important;
  border: 1.5px solid var(--color-border-default) !important;
  color: var(--color-text-secondary) !important;
  background: var(--color-bg-elevated) !important;
  transition: border-color var(--duration-normal), background-color var(--duration-normal), color var(--duration-normal), transform var(--duration-fast) !important;
}

.suitepress-pagination a:hover {
  border-color: var(--color-primary-400) !important;
  color: var(--color-primary-600) !important;
  background: rgba(var(--color-primary-rgb), 0.06) !important;
  transform: translateY(-1px) !important;
}

.suitepress-pagination .current {
  background: var(--color-primary-500) !important;
  border-color: var(--color-primary-500) !important;
  color: #fff !important;
  box-shadow: var(--shadow-primary-glow) !important;
}

/* ════════════════════════════════════════════════════════════
   11. SINGLE POST
   ════════════════════════════════════════════════════════════ */
/* ── Page wrapper ── */
.sp-blog-single {
  padding-block: clamp(40px, 5vw, 72px) !important;
  background: var(--color-bg-base) !important;
}

/* ── Two-column grid: override legacy 350px sidebar to a nicer proportion ── */
.sp-blog-container {
  display: grid !important;
  grid-template-columns: 1fr 320px !important;
  gap: clamp(32px, 4vw, 56px) !important;
  align-items: start !important;
  margin-top: 0 !important;
  margin-bottom: clamp(40px, 5vw, 72px) !important;
}

@media (max-width: 1024px) {
  .sp-blog-container {
    grid-template-columns: 1fr !important;
  }
}
/* ── Article card shell ── */
.sp-single-article {
  background: var(--color-bg-base) !important;
  border-radius: var(--radius-2xl) !important;
  overflow: visible !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

/* All four article section wrappers must be full-width block elements.
   Gutenberg block styles and Bootstrap can set max-width / padding-inline
   on content wrappers — override all of them here. */
.sp-article-header,
.sp-article-meta,
.sp-article-content,
.sp-article-footer {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  float: none !important;
  padding-inline: 0 !important;
  margin-inline: 0 !important;
}

/* Same for the inner content div to prevent WP block styles narrowing it */
.sp-entry-content {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

/* ── Featured image ── */
.sp-entry-image {
  border-radius: var(--radius-2xl) !important;
  overflow: hidden !important;
  margin-bottom: var(--space-8) !important;
  box-shadow: var(--shadow-md) !important;
  aspect-ratio: 16/9 !important;
}

.sp-entry-image .sp-entry-image-link {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
}

.sp-entry-image .sp-entry-image-figure {
  margin: 0 !important;
  width: 100% !important;
  height: 100% !important;
}

.sp-entry-image .sp-entry-image-img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  border-radius: var(--radius-2xl) !important;
  display: block !important;
  transition: transform var(--duration-slow) var(--ease-out) !important;
}

.sp-entry-image:hover .sp-entry-image-img {
  transform: scale(1.03) !important;
}

/* ── Article header: title above meta ── */
.sp-entry-header {
  margin-bottom: var(--space-6) !important;
}

.sp-entry-title {
  font-family: var(--font-heading) !important;
  font-size: clamp(28px, 4vw, 52px) !important;
  font-weight: var(--font-extrabold) !important;
  line-height: var(--leading-snug) !important;
  color: var(--color-text-primary) !important;
  letter-spacing: var(--tracking-tight) !important;
  margin-bottom: var(--space-5) !important;
}

.sp-entry-title-link {
  color: inherit !important;
  text-decoration: none !important;
}

.sp-entry-title-link:hover {
  color: var(--color-primary-600) !important;
}

/* ── Meta row ── */
.sp-article-meta {
  margin-bottom: var(--space-4) !important;
}

.sp-entry-meta {
  margin-bottom: var(--space-8) !important;
  padding-bottom: var(--space-6) !important;
  border-bottom: 1px solid var(--color-border-subtle) !important;
}

.sp-meta-items {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: var(--space-2) !important;
  font-size: var(--text-sm) !important;
  color: var(--color-text-muted) !important;
}

.sp-meta-items a {
  color: var(--color-text-secondary) !important;
  text-decoration: none !important;
  font-weight: var(--font-medium) !important;
  transition: color var(--duration-fast) !important;
}

.sp-meta-items a:hover {
  color: var(--color-primary-600) !important;
}

.sp-meta-items .sp-meta-separator {
  color: var(--color-border-strong) !important;
  font-size: 10px !important;
  line-height: 1 !important;
}

/* Reading time pill in meta */
.sp-meta-items .sp-reading-time,
.sp-reading-time {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  background: rgba(var(--color-primary-rgb), 0.08) !important;
  color: var(--color-primary-600) !important;
  padding: 3px 10px !important;
  border-radius: var(--radius-full) !important;
  font-size: var(--text-xs) !important;
  font-weight: var(--font-semibold) !important;
  font-family: var(--font-ui) !important;
  border: none !important;
}

/* ── Body content ── */
.sp-entry-content {
  font-size: var(--text-md) !important;
  line-height: var(--leading-relaxed) !important;
  color: var(--color-text-secondary) !important;
}

.sp-entry-content > * {
  margin-bottom: var(--space-6) !important;
}

.sp-entry-content h1,
.sp-entry-content h2,
.sp-entry-content h3,
.sp-entry-content h4,
.sp-entry-content h5,
.sp-entry-content h6 {
  font-family: var(--font-heading) !important;
  color: var(--color-text-primary) !important;
  font-weight: var(--font-bold) !important;
  line-height: var(--leading-snug) !important;
  margin-top: var(--space-10) !important;
  margin-bottom: var(--space-4) !important;
}

.sp-entry-content h2 {
  font-size: var(--text-2xl) !important;
}

.sp-entry-content h3 {
  font-size: var(--text-xl) !important;
}

.sp-entry-content h4 {
  font-size: var(--text-lg) !important;
}

.sp-entry-content p {
  margin-bottom: var(--space-6) !important;
}

.sp-entry-content a {
  color: var(--color-primary-600) !important;
  text-decoration: none !important;
  font-weight: var(--font-medium) !important;
  border-bottom: 1px solid rgba(var(--color-primary-rgb), 0.3) !important;
  transition: color var(--duration-fast), border-color var(--duration-fast) !important;
}

.sp-entry-content a:hover {
  color: var(--color-primary-700) !important;
  border-bottom-color: var(--color-primary-500) !important;
}

.sp-entry-content ul,
.sp-entry-content ol {
  padding-left: var(--space-6) !important;
  margin-block: var(--space-6) !important;
}

.sp-entry-content ul li,
.sp-entry-content ol li {
  margin-bottom: var(--space-2) !important;
  color: var(--color-text-secondary) !important;
}

.sp-entry-content blockquote {
  border-left: 4px solid var(--color-primary-500) !important;
  background: var(--color-primary-50) !important;
  padding: var(--space-5) var(--space-6) !important;
  border-radius: 0 var(--radius-lg) var(--radius-lg) 0 !important;
  margin-block: var(--space-8) !important;
  font-style: italic !important;
  color: var(--color-text-secondary) !important;
}

.sp-entry-content blockquote p {
  margin-bottom: 0 !important;
}

.sp-entry-content img {
  max-width: 100% !important;
  height: auto !important;
  border-radius: var(--radius-xl) !important;
  margin-block: var(--space-8) !important;
  box-shadow: var(--shadow-sm) !important;
}

.sp-entry-content .wp-block-image {
  margin-block: var(--space-8) !important;
}

.sp-entry-content .wp-block-image figcaption {
  text-align: center !important;
  font-size: var(--text-xs) !important;
  color: var(--color-text-muted) !important;
  margin-top: var(--space-2) !important;
  font-style: italic !important;
}

.sp-entry-content .sp-page-links {
  margin-top: var(--space-8) !important;
  padding: var(--space-5) !important;
  background: var(--color-bg-subtle) !important;
  border-radius: var(--radius-lg) !important;
  font-size: var(--text-base) !important;
  border: 1px solid var(--color-border-subtle) !important;
}

/* ── Article footer (tags / reading time on archive) ── */
.sp-entry-footer {
  margin-top: var(--space-10) !important;
  padding-top: var(--space-6) !important;
  border-top: 1px solid var(--color-border-subtle) !important;
}

.sp-footer-content {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: var(--space-4) !important;
}

.sp-footer-content .sp-read-more a,
.sp-read-more-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: var(--space-2) !important;
  background: rgba(var(--color-primary-rgb), 0.08) !important;
  color: var(--color-primary-600) !important;
  padding: var(--space-2) var(--space-4) !important;
  border-radius: var(--radius-full) !important;
  font-weight: var(--font-semibold) !important;
  font-size: var(--text-sm) !important;
  text-decoration: none !important;
  transition: background-color var(--duration-normal), color var(--duration-normal) !important;
}

.sp-footer-content .sp-read-more a:hover,
.sp-read-more-btn:hover {
  background: var(--color-primary-500) !important;
  color: #fff !important;
}

.sp-footer-content .sp-post-meta {
  font-size: var(--text-sm) !important;
  color: var(--color-text-muted) !important;
}

/* ── Article navigation (prev / next) — fix legacy .sp-nav-links selectors ── */
.sp-article-navigation {
  margin-block: var(--space-12) !important;
  padding-block: var(--space-8) !important;
  border-top: 1px solid var(--color-border-subtle) !important;
  border-bottom: 1px solid var(--color-border-subtle) !important;
}

.sp-nav-links {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: var(--space-4) !important;
}

@media (max-width: 640px) {
  .sp-nav-links {
    grid-template-columns: 1fr !important;
  }
}
.sp-nav-links .sp-prev-link a,
.sp-nav-links .sp-next-link a {
  display: block !important;
  padding: var(--space-5) var(--space-6) !important;
  background: var(--color-bg-subtle) !important;
  border: 1px solid var(--color-border-default) !important;
  border-radius: var(--radius-xl) !important;
  text-decoration: none !important;
  color: var(--color-text-secondary) !important;
  font-family: var(--font-ui) !important;
  font-weight: var(--font-semibold) !important;
  font-size: var(--text-sm) !important;
  transition: background-color var(--duration-normal), border-color var(--duration-normal), color var(--duration-normal), transform var(--duration-fast) !important;
  position: relative !important;
}

.sp-nav-links .sp-prev-link a {
  padding-left: 52px !important;
}

.sp-nav-links .sp-next-link a {
  padding-right: 52px !important;
  text-align: right !important;
}

.sp-nav-links .sp-prev-link a::before {
  content: "←" !important;
  position: absolute !important;
  left: var(--space-5) !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  font-size: 18px !important;
  color: var(--color-primary-500) !important;
  transition: color var(--duration-fast) !important;
}

.sp-nav-links .sp-next-link a::after {
  content: "→" !important;
  position: absolute !important;
  right: var(--space-5) !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  font-size: 18px !important;
  color: var(--color-primary-500) !important;
  transition: color var(--duration-fast) !important;
}

.sp-nav-links .sp-prev-link a:hover,
.sp-nav-links .sp-next-link a:hover {
  background: var(--color-primary-500) !important;
  border-color: var(--color-primary-500) !important;
  color: #fff !important;
  transform: translateY(-2px) !important;
  box-shadow: var(--shadow-primary-glow) !important;
}

.sp-nav-links .sp-prev-link a:hover::before,
.sp-nav-links .sp-next-link a:hover::after {
  color: rgba(255, 255, 255, 0.85) !important;
}

@media (max-width: 640px) {
  .sp-nav-links .sp-prev-link a,
  .sp-nav-links .sp-next-link a {
    padding: var(--space-4) var(--space-5) !important;
    text-align: center !important;
  }
  .sp-nav-links .sp-prev-link a::before,
  .sp-nav-links .sp-next-link a::after {
    display: none !important;
  }
}
/* ── Sidebar ── */
.sp-blog-sidebar {
  position: sticky !important;
  top: clamp(80px, 10vw, 100px) !important;
}

.sp-blog-sidebar-inner > * {
  background: var(--color-bg-elevated) !important;
  border: 1px solid var(--color-border-default) !important;
  border-radius: var(--radius-xl) !important;
  padding: var(--space-6) !important;
  margin-bottom: var(--space-5) !important;
}

.sp-blog-sidebar-inner .widget-title {
  font-family: var(--font-heading) !important;
  font-size: var(--text-base) !important;
  font-weight: var(--font-bold) !important;
  color: var(--color-text-primary) !important;
  padding-bottom: var(--space-3) !important;
  margin-bottom: var(--space-4) !important;
  border-bottom: 2px solid var(--color-primary-500) !important;
  text-transform: uppercase !important;
  letter-spacing: var(--tracking-caps) !important;
  font-size: var(--text-xs) !important;
}

.sp-blog-sidebar-inner .widget ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.sp-blog-sidebar-inner .widget ul li {
  border-bottom: 1px solid var(--color-border-subtle) !important;
  padding-block: var(--space-2) !important;
}

.sp-blog-sidebar-inner .widget ul li:last-child {
  border-bottom: none !important;
}

.sp-blog-sidebar-inner .widget a {
  color: var(--color-text-secondary) !important;
  text-decoration: none !important;
  font-size: var(--text-sm) !important;
  font-weight: var(--font-medium) !important;
  transition: color var(--duration-fast) !important;
}

.sp-blog-sidebar-inner .widget a:hover {
  color: var(--color-primary-600) !important;
}

/* ════════════════════════════════════════════════════════════
   11b. TABLE OF CONTENTS WIDGET
   ════════════════════════════════════════════════════════════ */
#sp-toc-widget {
  background: var(--color-bg-elevated) !important;
  border: 1px solid var(--color-border-default) !important;
  border-radius: var(--radius-xl) !important;
  padding: var(--space-5) var(--space-5) var(--space-4) !important;
  margin-bottom: var(--space-5) !important;
  /* Accent left stripe */
  border-left: 3px solid var(--color-primary-500) !important;
}

/* Header row: title + collapse toggle */
.sp-toc-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-4);
}

.sp-toc-title {
  font-family: var(--font-ui) !important;
  font-size: var(--text-xs) !important;
  font-weight: var(--font-bold) !important;
  text-transform: uppercase !important;
  letter-spacing: var(--tracking-caps) !important;
  color: var(--color-text-primary) !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
}

/* Collapse chevron button */
.sp-toc-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border: none;
  background: rgba(var(--color-primary-rgb), 0.08);
  color: var(--color-text-muted);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background-color var(--duration-fast), color var(--duration-fast), transform var(--duration-normal) var(--ease-out);
  flex-shrink: 0;
}

.sp-toc-toggle:hover {
  background: rgba(var(--color-primary-rgb), 0.15);
  color: var(--color-primary-600);
}

.sp-toc-toggle--collapsed svg {
  transform: rotate(180deg);
}

/* Numbered list */
.sp-toc-list {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  counter-reset: toc-counter;
}

.sp-toc-item {
  counter-increment: toc-counter;
  border-bottom: 1px solid var(--color-border-subtle) !important;
  padding: 0 !important;
  margin: 0 !important;
}

.sp-toc-item:last-child {
  border-bottom: none !important;
}

.sp-toc-link {
  display: flex;
  align-items: baseline;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-1) !important;
  font-size: var(--text-sm) !important;
  font-weight: var(--font-medium) !important;
  color: var(--color-text-secondary) !important;
  text-decoration: none !important;
  border: none !important;
  border-radius: var(--radius-md);
  transition: color var(--duration-fast), background-color var(--duration-fast) !important;
  line-height: var(--leading-snug);
}

/* Counter number prefix */
.sp-toc-link::before {
  content: counter(toc-counter, decimal-leading-zero);
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
  font-family: var(--font-ui);
  color: var(--color-primary-400);
  min-width: 22px;
  flex-shrink: 0;
  line-height: inherit;
}

.sp-toc-link:hover {
  color: var(--color-primary-600) !important;
  background: rgba(var(--color-primary-rgb), 0.06) !important;
}

/* Active section highlight */
.sp-toc-link--active {
  color: var(--color-primary-600) !important;
  font-weight: var(--font-semibold) !important;
  background: rgba(var(--color-primary-rgb), 0.08) !important;
}

.sp-toc-link--active::before {
  color: var(--color-primary-600) !important;
}

/* ════════════════════════════════════════════════════════════
   12. FORMS & INPUTS
   ════════════════════════════════════════════════════════════ */
.sp-form-group {
  margin-bottom: var(--space-5);
}

.sp-label {
  display: block;
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  color: var(--color-text-primary);
  margin-bottom: var(--space-2);
  font-family: var(--font-ui);
}

.sp-input, .sp-textarea, .sp-select {
  width: 100%;
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-text-primary);
  background: var(--color-bg-base);
  border: 1.5px solid var(--color-border-default);
  border-radius: var(--radius-lg);
  padding: var(--space-2) var(--space-4);
  height: 42px;
  transition: border-color var(--duration-normal), box-shadow var(--duration-normal);
  outline: none;
  appearance: none;
}

.sp-textarea {
  height: auto;
  min-height: 120px;
  resize: vertical;
  padding-block: var(--space-3);
}

.sp-input:focus, .sp-textarea:focus, .sp-select:focus {
  border-color: var(--color-primary-400);
  box-shadow: 0 0 0 3px rgba(var(--color-primary-rgb), 0.12);
}

.sp-input.error, .sp-textarea.error {
  border-color: var(--color-error);
}

.sp-helper-text {
  display: block;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-top: var(--space-1);
}

.sp-error-text {
  display: block;
  font-size: var(--text-xs);
  color: var(--color-error);
  margin-top: var(--space-1);
}

/* ════════════════════════════════════════════════════════════
   13. FOOTER (all 3 sections)
   ════════════════════════════════════════════════════════════ */
.suitepress-theme-footer {
  color: rgba(255, 255, 255, 0.75);
}

/* Subscription card */
.footer-subscription-card {
  padding: clamp(40px, 6vw, 80px) 0;
  background: var(--color-bg-subtle) !important;
  margin-bottom: 0 !important;
  margin-top: 0 !important;
  position: static !important;
  z-index: auto !important;
}

.footer-subscription-card .subscription-card {
  background: linear-gradient(135deg, var(--color-secondary-950) 0%, var(--color-secondary-900) 50%, #1a2a35 100%) !important;
  border-radius: var(--radius-2xl) !important;
  padding: clamp(32px, 5vw, 56px) clamp(24px, 4vw, 56px) !important;
  position: static !important;
  transform: none !important;
  box-shadow: var(--shadow-xl) !important;
  max-width: 860px;
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
  align-items: center;
}

@media (max-width: 767px) {
  .footer-subscription-card .subscription-card {
    grid-template-columns: 1fr !important;
    gap: var(--space-6) !important;
    text-align: center;
  }
}
.footer-subscription-card .card-content {
  display: contents;
}

.footer-subscription-card .contents-subform {
  flex-direction: column !important;
  align-items: flex-start !important;
}

.footer-subscription-card .card-text h4 {
  font-family: var(--font-heading) !important;
  font-size: var(--text-2xl) !important;
  font-weight: var(--font-bold) !important;
  color: #fff !important;
  line-height: var(--leading-snug) !important;
  margin-bottom: var(--space-2) !important;
}

.footer-subscription-card .card-text p {
  color: rgba(255, 255, 255, 0.7) !important;
  font-size: var(--text-base) !important;
}

.footer-subscription-card input[type=email] {
  background: rgba(255, 255, 255, 0.1) !important;
  border: 1.5px solid rgba(255, 255, 255, 0.2) !important;
  border-radius: var(--radius-lg) !important;
  color: #fff !important;
  font-size: var(--text-base) !important;
  padding: var(--space-3) var(--space-4) !important;
  backdrop-filter: blur(10px) !important;
  transition: border-color var(--duration-normal), background-color var(--duration-normal) !important;
}

.footer-subscription-card input[type=email]:focus {
  outline: none !important;
  border-color: var(--color-primary-400) !important;
  background: rgba(255, 255, 255, 0.15) !important;
}

.footer-subscription-card input[type=email]::placeholder {
  color: rgba(255, 255, 255, 0.5) !important;
}

.footer-subscription-card .btn, .footer-subscription-card input[type=submit], .footer-subscription-card button[type=submit] {
  background: var(--color-primary-500) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--radius-lg) !important;
  font-weight: var(--font-semibold) !important;
  padding: var(--space-3) var(--space-6) !important;
  cursor: pointer;
  transition: background-color var(--duration-normal), transform var(--duration-fast), box-shadow var(--duration-normal) !important;
}

.footer-subscription-card .btn:hover, .footer-subscription-card input[type=submit]:hover, .footer-subscription-card button[type=submit]:hover {
  background: var(--color-primary-600) !important;
  transform: translateY(-1px) !important;
  box-shadow: var(--shadow-primary-glow) !important;
}

/* Main footer */
.footer-main-section {
  background: var(--color-secondary-950) !important;
  padding: clamp(48px, 6vw, 80px) 0 0 !important;
}

.footer-main-section .footer-content-wrapper {
  display: grid !important;
  grid-template-columns: 1fr 2fr !important;
  gap: var(--space-16) !important;
  padding-bottom: clamp(40px, 5vw, 64px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

@media (max-width: 1023px) {
  .footer-main-section .footer-content-wrapper {
    grid-template-columns: 1fr !important;
    gap: var(--space-10) !important;
  }
}
.footer-main-section .lets-talk-heading.wave-text,
.footer-main-section .lets-talk-heading {
  font-family: var(--font-heading) !important;
  font-size: clamp(28px, 3.5vw, 44px) !important;
  font-weight: var(--font-extrabold) !important;
  line-height: var(--leading-snug) !important;
  margin-bottom: var(--space-4) !important;
  background: linear-gradient(135deg, #ffffff 0%, var(--color-primary-300) 100%) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
}

.footer-main-section .lets-talk-heading.wave-text span {
  font-size: inherit !important;
  animation: sp-wave 2s ease-in-out infinite;
  display: inline-block;
  -webkit-text-fill-color: #fff !important;
}

.footer-main-section .footer-widgets-columns {
  display: grid !important;
  grid-template-columns: 1fr 1fr 1fr !important;
  gap: var(--space-8) !important;
}

@media (max-width: 767px) {
  .footer-main-section .footer-widgets-columns {
    grid-template-columns: 1fr 1fr !important;
  }
}
@media (max-width: 479px) {
  .footer-main-section .footer-widgets-columns {
    grid-template-columns: 1fr !important;
  }
}
.footer-main-section .widget-title {
  display: block;
  font-family: var(--font-ui) !important;
  font-size: var(--text-xs) !important;
  font-weight: var(--font-semibold) !important;
  color: #fff !important;
  letter-spacing: var(--tracking-caps) !important;
  text-transform: uppercase !important;
  margin-bottom: var(--space-5) !important;
  background: none !important;
  -webkit-text-fill-color: unset !important;
}

.footer-main-section .widget-title::after {
  display: none;
}

.footer-main-section .footer-menu, .footer-main-section .widget ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.footer-main-section .footer-menu li, .footer-main-section .widget ul li {
  margin-bottom: var(--space-2) !important;
}

.footer-main-section .footer-menu li a, .footer-main-section .widget ul li a {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  color: rgba(255, 255, 255, 0.55) !important;
  font-size: var(--text-sm) !important;
  font-weight: var(--font-medium) !important;
  text-decoration: none;
  padding-block: 2px;
  transition: color var(--duration-normal), transform var(--duration-normal) !important;
}

.footer-main-section .footer-menu li a:hover, .footer-main-section .widget ul li a:hover {
  color: #fff !important;
  transform: translateX(4px) !important;
}

.footer-cta-column .cta-content .lets-talk-heading {
  font-family: var(--font-heading) !important;
  font-size: clamp(22px, 2.5vw, 32px) !important;
  font-weight: var(--font-bold) !important;
  color: #ffffff !important;
  background: none !important;
  -webkit-text-fill-color: #b36a3a !important;
  line-height: var(--leading-snug) !important;
}

/* Footer bottom */
.footer-bottom-section {
  background: var(--color-secondary-950) !important;
  padding: var(--space-6) 0 !important;
  border-top: 1px solid rgba(255, 255, 255, 0.08) !important;
}

.footer-bottom-section .footer-bottom-content {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-4);
}

@media (max-width: 767px) {
  .footer-bottom-section .footer-bottom-content {
    flex-direction: column;
    text-align: center;
  }
}
.footer-bottom-section .copyright span {
  font-size: var(--text-sm);
  color: rgba(255, 255, 255, 0.45);
}

.footer-bottom-section .footer-links-menu ul {
  display: flex !important;
  gap: var(--space-5) !important;
  list-style: none !important;
  padding: 0 !important;
  flex-wrap: wrap;
}

@media (max-width: 767px) {
  .footer-bottom-section .footer-links-menu ul {
    justify-content: center !important;
  }
}
.footer-bottom-section .footer-links-menu ul li a {
  color: rgba(255, 255, 255, 0.45) !important;
  font-size: var(--text-xs) !important;
  text-decoration: none;
  transition: color var(--duration-normal) !important;
}

.footer-bottom-section .footer-links-menu ul li a:hover {
  color: rgba(255, 255, 255, 0.85) !important;
}

.footer-bottom-section .social-links {
  display: flex;
  gap: var(--space-2);
}

.footer-bottom-section .social-icon {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.08) !important;
  color: rgba(255, 255, 255, 0.55) !important;
  border-radius: var(--radius-md) !important;
  text-decoration: none;
  font-size: 14px;
  transition: background-color var(--duration-normal), color var(--duration-normal), transform var(--duration-normal) !important;
}

.footer-bottom-section .social-icon:hover {
  background: var(--color-primary-500) !important;
  color: #fff !important;
  transform: translateY(-2px) !important;
}

/* ════════════════════════════════════════════════════════════
   14. UTILITY COMPONENTS
   ════════════════════════════════════════════════════════════ */
/* Back to top */
#sp-back-to-top {
  position: fixed;
  bottom: var(--space-8);
  right: var(--space-8);
  width: 44px;
  height: 44px;
  background: var(--color-primary-500);
  color: white;
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-lg);
  z-index: var(--z-raised);
  opacity: 0;
  transform: translateY(12px);
  pointer-events: none;
  transition: opacity var(--duration-normal), transform var(--duration-normal), background-color var(--duration-normal);
}

#sp-back-to-top.visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

#sp-back-to-top:hover {
  background: var(--color-primary-600);
  transform: translateY(-2px);
}

/* Hide native browser scrollbar — replaced by custom horizontal progress bar */
html {
  scrollbar-width: none; /* Firefox */
}

html::-webkit-scrollbar {
  display: none; /* Chrome / Safari / Edge */
}

/* Horizontal reading progress bar (left → right) */
#sp-progress-bar {
  position: fixed;
  top: 0;
  left: 0;
  height: 4px;
  width: 0%;
  background: linear-gradient(90deg, var(--color-primary-500), var(--color-accent-500, var(--color-primary-400)));
  z-index: 99999;
  transition: width 80ms linear;
  pointer-events: none;
  border-radius: 0 2px 2px 0;
  box-shadow: 0 0 8px rgba(var(--color-primary-rgb), 0.45);
}

/* Breadcrumbs */
.sp-breadcrumbs {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-6);
}

.sp-breadcrumbs a {
  color: var(--color-text-muted);
  transition: color var(--duration-normal);
}

.sp-breadcrumbs a:hover {
  color: var(--color-primary-500);
}

.sp-breadcrumbs .current {
  color: var(--color-text-primary);
  font-weight: var(--font-medium);
}

/* Skeleton */
.sp-skeleton {
  background: linear-gradient(90deg, var(--color-gray-100) 25%, var(--color-gray-50) 50%, var(--color-gray-100) 75%);
  background-size: 200% 100%;
  animation: sp-shimmer 1.5s ease-in-out infinite;
  border-radius: var(--radius-md);
}

/* Toast */
.sp-toast-container {
  position: fixed;
  top: var(--space-5);
  right: var(--space-5);
  z-index: var(--z-toast);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.sp-toast {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  max-width: 360px;
  animation: sp-toast-in var(--duration-slow) var(--ease-bounce);
}

.sp-toast.sp-toast-success {
  border-left: 3px solid var(--color-success);
}

.sp-toast.sp-toast-error {
  border-left: 3px solid var(--color-error);
}

.sp-toast.sp-toast-warning {
  border-left: 3px solid var(--color-warning);
}

/* Top banner */
.sp-top-banner {
  background: linear-gradient(135deg, var(--color-secondary-950) 0%, #1a2a35 50%, var(--color-primary-900) 100%);
  color: rgba(255, 255, 255, 0.9);
  font-size: var(--text-sm);
  padding: var(--space-2) 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.sp-banner-btn-primary {
  background: var(--color-primary-500) !important;
  border-radius: var(--radius-md) !important;
}

.sp-banner-btn-primary:hover {
  background: var(--color-primary-400) !important;
}

/* ════════════════════════════════════════════════════════════
   15. SCROLL REVEAL (applied to cards via JS)
   ════════════════════════════════════════════════════════════ */
.sp-reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity var(--duration-slower) var(--ease-out), transform var(--duration-slower) var(--ease-out);
}

.sp-reveal.sp-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ════════════════════════════════════════════════════════════
   17. ADDON PAGE  (Template: Addons by Category)
   ════════════════════════════════════════════════════════════ */
/* ── Hero ── */
.suitepress-addons-hero {
  position: relative;
  padding: clamp(80px, 8vw, 120px) 0 clamp(60px, 6vw, 96px);
  background: linear-gradient(135deg, var(--color-secondary-950) 0%, var(--color-secondary-900) 55%, #1a2a35 100%) !important;
  overflow: hidden;
  color: #fff;
}

/* Decorative radial glow */
.suitepress-addons-hero::before {
  content: "";
  position: absolute;
  top: -120px;
  right: -80px;
  width: 560px;
  height: 560px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(var(--color-primary-rgb), 0.18) 0%, transparent 70%);
  pointer-events: none;
}

.suitepress-addons-hero::after {
  content: "";
  position: absolute;
  bottom: -80px;
  left: -60px;
  width: 360px;
  height: 360px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(var(--color-primary-rgb), 0.1) 0%, transparent 70%);
  pointer-events: none;
}

.suitepress-addons-hero .hero-content {
  position: relative;
  z-index: 1;
}

/* Badge pill */
.suitepress-addons-hero .hero-badge {
  margin-bottom: var(--space-5) !important;
}

.suitepress-addons-hero .hero-badge .badge {
  display: inline-flex !important;
  align-items: center;
  gap: var(--space-2);
  background: rgba(var(--color-primary-rgb), 0.18) !important;
  color: var(--color-primary-300, #f0a882) !important;
  border: 1px solid rgba(var(--color-primary-rgb), 0.35) !important;
  border-radius: var(--radius-full) !important;
  padding: 7px 20px !important;
  font-family: var(--font-ui) !important;
  font-size: var(--text-xs) !important;
  font-weight: var(--font-semibold) !important;
  letter-spacing: var(--tracking-caps) !important;
  text-transform: uppercase !important;
  box-shadow: none !important;
}

/* Title */
.suitepress-addons-hero .hero-title {
  font-family: var(--font-heading) !important;
  font-size: clamp(32px, 5vw, 60px) !important;
  font-weight: var(--font-extrabold) !important;
  line-height: var(--leading-snug) !important;
  letter-spacing: var(--tracking-tight) !important;
  color: #fff !important;
  background: none !important;
  -webkit-text-fill-color: unset !important;
  margin-bottom: var(--space-5) !important;
}

/* Description */
.suitepress-addons-hero .hero-description {
  font-size: var(--text-lg) !important;
  line-height: var(--leading-relaxed) !important;
  color: rgba(255, 255, 255, 0.72) !important;
  max-width: 580px !important;
  margin-inline: auto !important;
  margin-bottom: clamp(40px, 6vw, 64px) !important;
}

.suitepress-addons-hero .hero-description p {
  margin-bottom: 0 !important;
  color: white !important;
}

/* Stats row */
.suitepress-addons-hero .hero-stats {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 0 !important;
  margin-top: 0 !important;
  border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
  padding-top: clamp(28px, 4vw, 40px) !important;
}

.suitepress-addons-hero .hero-stats .stat-item {
  flex: 1 !important;
  text-align: center !important;
  padding: 0 clamp(16px, 3vw, 40px) !important;
  border-right: 1px solid rgba(255, 255, 255, 0.12) !important;
  box-shadow: none !important;
}

.suitepress-addons-hero .hero-stats .stat-item:last-child {
  border-right: none !important;
}

.suitepress-addons-hero .hero-stats .stat-item .stat-number {
  display: block !important;
  font-family: var(--font-heading) !important;
  font-size: clamp(28px, 4vw, 42px) !important;
  font-weight: var(--font-extrabold) !important;
  color: var(--color-primary-400, #e08a69) !important;
  background: none !important;
  -webkit-text-fill-color: unset !important;
  line-height: 1.1 !important;
  margin-bottom: var(--space-1) !important;
}

.suitepress-addons-hero .hero-stats .stat-item .stat-label {
  display: block !important;
  font-family: var(--font-ui) !important;
  font-size: var(--text-xs) !important;
  font-weight: var(--font-medium) !important;
  text-transform: uppercase !important;
  letter-spacing: var(--tracking-caps) !important;
  color: rgba(255, 255, 255, 0.5) !important;
  box-shadow: none !important;
  padding: 0 !important;
}

@media (max-width: 640px) {
  .suitepress-addons-hero .hero-stats {
    flex-direction: column !important;
    gap: var(--space-6) !important;
    border-top: none !important;
  }
  .suitepress-addons-hero .hero-stats .stat-item {
    border-right: none !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
    padding: var(--space-4) 0 !important;
    width: 100% !important;
  }
  .suitepress-addons-hero .hero-stats .stat-item:last-child {
    border-bottom: none !important;
  }
}
/* ── Grid section wrapper ── */
.sp-addons-section {
  padding: clamp(56px, 8vw, 96px) 0 !important;
  background: var(--color-bg-subtle) !important;
}

/* Section sub-header (category name + description) */
.sp-addons-section .sp-section-header,
.sp-addons-section .sp-container > .sp-section-header {
  text-align: center !important;
  margin-bottom: clamp(40px, 5vw, 64px) !important;
}

.sp-addons-section .sp-section-badge {
  display: inline-flex !important;
  align-items: center;
  background: rgba(var(--color-primary-rgb), 0.1) !important;
  color: var(--color-primary-600) !important;
  border: 1px solid rgba(var(--color-primary-rgb), 0.2) !important;
  padding: 6px 18px !important;
  border-radius: var(--radius-full) !important;
  font-family: var(--font-ui) !important;
  font-size: var(--text-xs) !important;
  font-weight: var(--font-semibold) !important;
  letter-spacing: var(--tracking-caps) !important;
  text-transform: uppercase !important;
  margin-bottom: var(--space-3) !important;
}

.sp-addons-section .sp-section-description {
  font-size: var(--text-md) !important;
  color: var(--color-text-muted) !important;
  max-width: 580px !important;
  margin-inline: auto !important;
  line-height: var(--leading-relaxed) !important;
}

/* ── Addon grid ── */
.sp-addons-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: var(--space-6) !important;
  margin-bottom: var(--space-10) !important;
}

@media (max-width: 1100px) {
  .sp-addons-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 640px) {
  .sp-addons-grid {
    grid-template-columns: 1fr !important;
    gap: var(--space-4) !important;
  }
}
/* ── Addon card ── */
.sp-addon-card {
  background: var(--color-bg-elevated) !important;
  border: 1px solid var(--color-border-default) !important;
  border-radius: var(--radius-2xl) !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  box-shadow: var(--shadow-sm) !important;
  transition: transform var(--duration-normal) var(--ease-out), box-shadow var(--duration-normal) var(--ease-out), border-color var(--duration-normal) !important;
}

.sp-addon-card:hover {
  transform: translateY(-5px) !important;
  box-shadow: var(--shadow-xl) !important;
  border-color: rgba(var(--color-primary-rgb), 0.4) !important;
}

/* Image area */
.sp-addon-header {
  position: relative !important;
}

.sp-addon-image {
  position: relative !important;
  height: 200px !important;
  overflow: hidden !important;
  background: var(--color-gray-100) !important;
}

.sp-addon-image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  transition: transform var(--duration-slow) var(--ease-out) !important;
}

.sp-addon-card:hover .sp-addon-image img {
  transform: scale(1.06) !important;
}

/* Hover overlay */
.sp-addon-overlay {
  position: absolute !important;
  inset: 0 !important;
  background: rgba(var(--color-primary-rgb), 0.88) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  opacity: 0 !important;
  transition: opacity var(--duration-normal) var(--ease-out) !important;
}

.sp-addon-card:hover .sp-addon-overlay {
  opacity: 1 !important;
}

.sp-addon-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: var(--space-2) !important;
  background: #fff !important;
  color: var(--color-primary-600) !important;
  padding: var(--space-2) var(--space-5) !important;
  border-radius: var(--radius-full) !important;
  font-family: var(--font-ui) !important;
  font-weight: var(--font-semibold) !important;
  font-size: var(--text-sm) !important;
  text-decoration: none !important;
  transition: transform var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) !important;
}

.sp-addon-btn:hover {
  transform: translateY(-2px) !important;
  box-shadow: var(--shadow-md) !important;
  color: var(--color-primary-700) !important;
}

/* Card body */
.sp-addon-body {
  padding: var(--space-5) var(--space-5) 0 !important;
  flex: 1 !important;
}

/* Tags row */
.sp-addon-meta {
  margin-bottom: var(--space-3) !important;
}

.sp-addon-tags {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: var(--space-2) !important;
}

.sp-tag {
  display: inline-flex !important;
  align-items: center !important;
  background: rgba(var(--color-primary-rgb), 0.08) !important;
  color: var(--color-primary-600) !important;
  border: 1px solid rgba(var(--color-primary-rgb), 0.15) !important;
  padding: 3px 10px !important;
  border-radius: var(--radius-full) !important;
  font-family: var(--font-ui) !important;
  font-size: var(--text-xs) !important;
  font-weight: var(--font-semibold) !important;
  box-shadow: none !important;
}

/* Title + version row */
.sp-addon-title-section {
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-start !important;
  gap: var(--space-3) !important;
  margin-bottom: var(--space-3) !important;
}

.sp-addon-title {
  font-family: var(--font-heading) !important;
  font-size: var(--text-lg) !important;
  font-weight: var(--font-bold) !important;
  color: var(--color-text-primary) !important;
  line-height: var(--leading-snug) !important;
  margin: 0 !important;
  flex: 1 !important;
}

.sp-addon-version {
  display: inline-block !important;
  background: var(--color-gray-100) !important;
  color: var(--color-text-muted) !important;
  border: 1px solid var(--color-border-subtle) !important;
  padding: 2px 8px !important;
  border-radius: var(--radius-md) !important;
  font-family: var(--font-mono) !important;
  font-size: 11px !important;
  font-weight: var(--font-medium) !important;
  white-space: nowrap !important;
  flex-shrink: 0 !important;
}

/* Description */
.sp-addon-description {
  font-size: var(--text-sm) !important;
  line-height: var(--leading-relaxed) !important;
  color: var(--color-text-muted) !important;
  margin-bottom: var(--space-4) !important;
}

/* Compatibility feature row */
.sp-addon-features {
  display: flex !important;
  flex-direction: column !important;
  gap: var(--space-2) !important;
  margin-bottom: var(--space-4) !important;
}

.sp-feature {
  display: flex !important;
  align-items: center !important;
  gap: var(--space-2) !important;
  font-size: var(--text-xs) !important;
  color: var(--color-text-muted) !important;
  font-family: var(--font-ui) !important;
}

.sp-feature svg {
  color: #10b981 !important;
  flex-shrink: 0 !important;
  width: 14px !important;
  height: 14px !important;
}

/* Card footer CTA */
.sp-addon-footer {
  padding: var(--space-4) var(--space-5) var(--space-5) !important;
  margin-top: auto !important;
}

.sp-addon-cta {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: var(--space-2) !important;
  background: var(--color-primary-500) !important;
  color: #fff !important;
  padding: var(--space-3) var(--space-5) !important;
  border-radius: var(--radius-full) !important;
  font-family: var(--font-ui) !important;
  font-size: var(--text-sm) !important;
  font-weight: var(--font-semibold) !important;
  text-decoration: none !important;
  width: 100% !important;
  text-align: center !important;
  box-shadow: var(--shadow-primary-glow) !important;
  transition: background-color var(--duration-normal), transform var(--duration-fast) var(--ease-out), box-shadow var(--duration-normal) !important;
}

.sp-addon-cta:hover {
  background: var(--color-primary-600) !important;
  color: #fff !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 10px 32px rgba(var(--color-primary-rgb), 0.35) !important;
}

.sp-addon-cta svg {
  transition: transform var(--duration-fast) var(--ease-out) !important;
}

.sp-addon-cta:hover svg {
  transform: translateX(3px) !important;
}

/* ── Results count ── */
.sp-results-count {
  text-align: center !important;
  padding: var(--space-6) 0 !important;
}

.sp-results-count p {
  font-size: var(--text-sm) !important;
  color: var(--color-text-muted) !important;
}

.sp-results-count p strong {
  color: var(--color-primary-600) !important;
  font-weight: var(--font-semibold) !important;
}

/* ── No results state ── */
.sp-addons-section .sp-no-results {
  text-align: center !important;
  padding: clamp(60px, 10vw, 100px) var(--space-5) !important;
  max-width: 480px !important;
  margin-inline: auto !important;
}

.sp-addons-section .sp-no-results .sp-no-results-icon {
  width: 80px !important;
  height: 80px !important;
  border-radius: var(--radius-2xl) !important;
  background: var(--color-gray-100) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 auto var(--space-6) !important;
  color: var(--color-text-disabled) !important;
}

.sp-addons-section .sp-no-results h3 {
  font-family: var(--font-heading) !important;
  font-size: var(--text-xl) !important;
  font-weight: var(--font-bold) !important;
  color: var(--color-text-primary) !important;
  margin-bottom: var(--space-3) !important;
}

.sp-addons-section .sp-no-results p {
  font-size: var(--text-sm) !important;
  color: var(--color-text-muted) !important;
  line-height: var(--leading-relaxed) !important;
  margin-bottom: var(--space-6) !important;
}

.sp-addons-section .sp-no-results .sp-btn,
.sp-addons-section .sp-no-results .sp-btn-primary {
  display: inline-flex !important;
  align-items: center !important;
  background: var(--color-primary-500) !important;
  color: #fff !important;
  padding: var(--space-3) var(--space-7) !important;
  border-radius: var(--radius-full) !important;
  font-family: var(--font-ui) !important;
  font-weight: var(--font-semibold) !important;
  font-size: var(--text-sm) !important;
  text-decoration: none !important;
  box-shadow: var(--shadow-primary-glow) !important;
  transition: background-color var(--duration-normal), transform var(--duration-fast) !important;
}

.sp-addons-section .sp-no-results .sp-btn:hover,
.sp-addons-section .sp-no-results .sp-btn-primary:hover {
  background: var(--color-primary-600) !important;
  transform: translateY(-2px) !important;
}

/* ════════════════════════════════════════════════════════════
   18. SEARCH RESULTS PAGE
   ════════════════════════════════════════════════════════════ */
/* ── Page wrapper ── */
.sp-search-page {
  background: var(--color-bg-primary) !important;
  min-height: 80vh !important;
}

/* ── Hero ── */
.sp-search-hero {
  background: linear-gradient(135deg, #1a1f2e 0%, #0f1219 60%, #1c1016 100%) !important;
  position: relative !important;
  overflow: hidden !important;
  padding: clamp(3rem, 8vw, 5rem) 0 clamp(2.5rem, 6vw, 4rem) !important;
}

.sp-search-hero::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: radial-gradient(ellipse 60% 70% at 10% 50%, rgba(var(--color-primary-rgb), 0.12) 0%, transparent 60%), radial-gradient(ellipse 40% 50% at 90% 30%, rgba(var(--color-primary-rgb), 0.08) 0%, transparent 55%) !important;
  pointer-events: none !important;
}

.sp-search-hero .container {
  position: relative !important;
  z-index: 1 !important;
}

.sp-search-hero-eyebrow {
  display: inline-block !important;
  font-family: var(--font-ui) !important;
  font-size: var(--text-xs) !important;
  font-weight: var(--font-semibold) !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: var(--color-primary-400) !important;
  background: rgba(var(--color-primary-rgb), 0.12) !important;
  border: 1px solid rgba(var(--color-primary-rgb), 0.25) !important;
  padding: var(--space-1) var(--space-3) !important;
  border-radius: var(--radius-full) !important;
  margin-bottom: var(--space-4) !important;
}

.sp-search-hero-title {
  font-family: var(--font-heading) !important;
  font-size: clamp(1.75rem, 4vw, 2.75rem) !important;
  font-weight: var(--font-bold) !important;
  color: #fff !important;
  line-height: var(--leading-tight) !important;
  margin: 0 0 var(--space-3) !important;
}

.sp-search-hero-sub {
  font-size: var(--text-base) !important;
  color: rgba(255, 255, 255, 0.65) !important;
  line-height: var(--leading-relaxed) !important;
  margin: 0 !important;
  max-width: 520px !important;
}

/* ── Main layout ── */
.sp-search-main {
  padding-block: var(--space-10) !important;
}

.suitepress-search.sp-search-layout {
  display: grid !important;
  grid-template-columns: 280px 1fr !important;
  gap: var(--space-8) !important;
  align-items: start !important;
  max-width: 100% !important;
  width: 100% !important;
}

/* ── Filter sidebar ── */
suitepress-filters.sp-search-filters-col {
  display: flex !important;
  flex-direction: column !important;
  gap: var(--space-3) !important;
  position: sticky !important;
  top: calc(var(--header-height, 72px) + var(--space-4)) !important;
}

/* Clear all filters */
suitepress-clear-all-filters.clear-all-filters {
  display: block !important;
}

.clear-all-filters button,
suitepress-clear-all-filters button {
  width: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: var(--space-2) !important;
  padding: var(--space-2) var(--space-4) !important;
  background: transparent !important;
  border: 1px solid var(--color-border-default) !important;
  border-radius: var(--radius-lg) !important;
  font-family: var(--font-ui) !important;
  font-size: var(--text-sm) !important;
  font-weight: var(--font-medium) !important;
  color: var(--color-text-secondary) !important;
  cursor: pointer !important;
  transition: border-color var(--duration-normal), color var(--duration-normal), background var(--duration-normal) !important;
}

.clear-all-filters button:hover,
suitepress-clear-all-filters button:hover {
  border-color: var(--color-primary-500) !important;
  color: var(--color-primary-600) !important;
  background: rgba(var(--color-primary-rgb), 0.05) !important;
}

/* ── Checkbox accordion ── */
suitepress-checkbox-accordion.checkbox-accordion {
  display: block !important;
  background: var(--color-bg-card) !important;
  border: 1px solid var(--color-border-default) !important;
  border-radius: var(--radius-xl) !important;
  overflow: hidden !important;
}

.checkbox-accordion__handle {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: var(--space-4) var(--space-4) !important;
  cursor: pointer !important;
  user-select: none !important;
  transition: background var(--duration-fast) !important;
}

.checkbox-accordion__handle:hover {
  background: rgba(var(--color-primary-rgb), 0.04) !important;
}

.checkbox-accordion__handle-text {
  font-family: var(--font-ui) !important;
  font-size: var(--text-sm) !important;
  font-weight: var(--font-semibold) !important;
  color: var(--color-text-primary) !important;
}

.checkbox-accordion__handle-icon {
  display: inline-block !important;
  width: 16px !important;
  height: 16px !important;
  position: relative !important;
  flex-shrink: 0 !important;
  transition: transform var(--duration-normal) !important;
}

.checkbox-accordion__handle-icon::before,
.checkbox-accordion__handle-icon::after {
  content: "" !important;
  position: absolute !important;
  background: var(--color-text-muted) !important;
  border-radius: 2px !important;
  top: 50% !important;
  transition: transform var(--duration-normal) !important;
}

.checkbox-accordion__handle-icon::before {
  width: 10px !important;
  height: 2px !important;
  left: 3px !important;
  transform: translateY(-50%) !important;
}

.checkbox-accordion__handle-icon::after {
  width: 2px !important;
  height: 10px !important;
  left: 7px !important;
  transform: translateY(-50%) !important;
}

/* Collapsed state — remove vertical bar */
.checkbox-accordion--collapsed .checkbox-accordion__handle-icon::after {
  transform: translateY(-50%) scaleY(0) !important;
}

suitepress-checkbox-accordion-content.checkbox-accordion__content {
  display: block !important;
  padding: 0 var(--space-4) var(--space-4) !important;
  border-top: 1px solid var(--color-border-default) !important;
}

/* ── Accordion children ── */
suitepress-checkbox-accordion-child.checkbox-accordion__child {
  display: block !important;
}

.checkbox-accordion__child-handle {
  display: flex !important;
  align-items: center !important;
  gap: var(--space-2) !important;
  padding: var(--space-2) 0 !important;
}

.checkbox-accordion__child-content {
  padding-left: var(--space-5) !important;
  border-left: 2px solid var(--color-border-default) !important;
  margin-left: var(--space-2) !important;
}

/* Level-one expand icon */
.checkbox-accordion__lvl-one-icon,
.checkbox-accordion__child-handle-icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 16px !important;
  height: 16px !important;
  flex-shrink: 0 !important;
  cursor: pointer !important;
  color: var(--color-text-muted) !important;
  transition: transform var(--duration-normal) !important;
}

/* ── Custom checkboxes ── */
.checkbox-accordion .checkbox {
  display: flex !important;
  align-items: center !important;
  gap: var(--space-2) !important;
  cursor: pointer !important;
  flex: 1 !important;
}

.checkbox-accordion .checkbox input[type=checkbox] {
  appearance: none !important;
  -webkit-appearance: none !important;
  width: 16px !important;
  height: 16px !important;
  min-width: 16px !important;
  border: 2px solid var(--color-border-strong) !important;
  border-radius: var(--radius-sm) !important;
  background: var(--color-bg-primary) !important;
  cursor: pointer !important;
  position: relative !important;
  transition: border-color var(--duration-fast), background var(--duration-fast) !important;
  flex-shrink: 0 !important;
}

.checkbox-accordion .checkbox input[type=checkbox]:checked {
  background: var(--color-primary-500) !important;
  border-color: var(--color-primary-500) !important;
}

.checkbox-accordion .checkbox input[type=checkbox]:checked::after {
  content: "" !important;
  position: absolute !important;
  left: 3px !important;
  top: 1px !important;
  width: 5px !important;
  height: 8px !important;
  border: 2px solid #fff !important;
  border-top: none !important;
  border-left: none !important;
  transform: rotate(45deg) !important;
}

.checkbox-accordion .checkbox input[type=checkbox]:hover:not(:checked) {
  border-color: var(--color-primary-400) !important;
}

.checkbox-accordion .checkbox-text {
  font-family: var(--font-ui) !important;
  font-size: var(--text-sm) !important;
  color: var(--color-text-secondary) !important;
  line-height: var(--leading-snug) !important;
  transition: color var(--duration-fast) !important;
}

.checkbox-accordion .checkbox:hover .checkbox-text {
  color: var(--color-text-primary) !important;
}

/* ── Results column ── */
.sp-search-results-col {
  display: flex !important;
  flex-direction: column !important;
  gap: var(--space-6) !important;
  min-width: 0 !important;
}

/* ── Results count ── */
suitepress-results-count.sp-search-count,
.suitepress-results-count.sp-search-count {
  display: block !important;
  font-family: var(--font-ui) !important;
  font-size: var(--text-sm) !important;
  color: var(--color-text-muted) !important;
}

suitepress-results-count.sp-search-count strong,
.suitepress-results-count.sp-search-count strong {
  color: var(--color-text-primary) !important;
  font-weight: var(--font-semibold) !important;
}

/* ── Results grid ── */
suitepress-results.sp-search-results-grid,
.sp-search-results-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)) !important;
  gap: var(--space-5) !important;
}

/* ── Result card ── */
.sp-result-card {
  display: flex !important;
  flex-direction: column !important;
  background: var(--color-bg-card) !important;
  border: 1px solid var(--color-border-default) !important;
  border-radius: var(--radius-2xl) !important;
  overflow: hidden !important;
  transition: border-color var(--duration-normal), box-shadow var(--duration-normal), transform var(--duration-normal) !important;
}

.sp-result-card:hover {
  border-color: rgba(var(--color-primary-rgb), 0.35) !important;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08), 0 2px 8px rgba(var(--color-primary-rgb), 0.08) !important;
  transform: translateY(-3px) !important;
}

/* ── Card image ── */
.sp-result-card-image-link {
  display: block !important;
  text-decoration: none !important;
}

.sp-result-image {
  aspect-ratio: 16/9 !important;
  overflow: hidden !important;
  background: var(--color-bg-secondary) !important;
}

.sp-result-image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  transition: transform var(--duration-slow) !important;
}

.sp-result-card:hover .sp-result-image img {
  transform: scale(1.04) !important;
}

/* Placeholder image */
.sp-result-image--placeholder {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: var(--color-text-disabled) !important;
}

/* ── Card body ── */
.sp-result-card-body {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 !important;
  padding: var(--space-5) !important;
  gap: var(--space-3) !important;
}

.sp-result-card-title-link {
  text-decoration: none !important;
}

.sp-result-card-title {
  font-family: var(--font-heading) !important;
  font-size: var(--text-base) !important;
  font-weight: var(--font-semibold) !important;
  color: var(--color-text-primary) !important;
  line-height: var(--leading-snug) !important;
  margin: 0 !important;
  transition: color var(--duration-fast) !important;
}

.sp-result-card-title-link:hover .sp-result-card-title {
  color: var(--color-primary-600) !important;
}

.sp-result-card-excerpt {
  font-size: var(--text-sm) !important;
  color: var(--color-text-muted) !important;
  line-height: var(--leading-relaxed) !important;
  flex: 1 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 3 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}

.sp-result-card-cta {
  display: inline-flex !important;
  align-items: center !important;
  gap: var(--space-1) !important;
  font-family: var(--font-ui) !important;
  font-size: var(--text-sm) !important;
  font-weight: var(--font-semibold) !important;
  color: var(--color-primary-600) !important;
  text-decoration: none !important;
  margin-top: auto !important;
  transition: gap var(--duration-fast), color var(--duration-fast) !important;
}

.sp-result-card-cta:hover {
  color: var(--color-primary-700) !important;
  gap: var(--space-2) !important;
}

/* ── Loading indicator ── */
suitepress-loading-more.sp-search-loading,
.suitepress-loading-more.sp-search-loading {
  display: block !important;
  text-align: center !important;
  padding: var(--space-4) !important;
  font-family: var(--font-ui) !important;
  font-size: var(--text-sm) !important;
  color: var(--color-text-muted) !important;
}

/* ── Load more ── */
suitepress-load-more.load-more-wrap,
.load-more-wrap {
  display: flex !important;
  justify-content: center !important;
  padding-top: var(--space-4) !important;
}

.load-more-wrap .btn,
.load-more-wrap button {
  display: inline-flex !important;
  align-items: center !important;
  gap: var(--space-2) !important;
  padding: var(--space-3) var(--space-8) !important;
  background: transparent !important;
  border: 2px solid var(--color-primary-500) !important;
  border-radius: var(--radius-full) !important;
  font-family: var(--font-ui) !important;
  font-size: var(--text-sm) !important;
  font-weight: var(--font-semibold) !important;
  color: var(--color-primary-600) !important;
  cursor: pointer !important;
  transition: background var(--duration-normal), color var(--duration-normal), border-color var(--duration-normal), transform var(--duration-fast) !important;
}

.load-more-wrap .btn:hover,
.load-more-wrap button:hover {
  background: var(--color-primary-500) !important;
  color: #fff !important;
  transform: translateY(-2px) !important;
}

/* ── No results ── */
.sp-search-results-col .sp-no-results,
suitepress-results .sp-no-results {
  grid-column: 1/-1 !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
  padding: var(--space-16) var(--space-8) !important;
  background: var(--color-bg-card) !important;
  border: 1px solid var(--color-border-default) !important;
  border-radius: var(--radius-2xl) !important;
}

.sp-search-results-col .sp-no-results .sp-no-results-icon,
suitepress-results .sp-no-results .sp-no-results-icon {
  width: 72px !important;
  height: 72px !important;
  border-radius: var(--radius-2xl) !important;
  background: var(--color-bg-secondary) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-bottom: var(--space-5) !important;
  color: var(--color-text-disabled) !important;
}

.sp-search-results-col .sp-no-results h3,
suitepress-results .sp-no-results h3 {
  font-family: var(--font-heading) !important;
  font-size: var(--text-xl) !important;
  font-weight: var(--font-bold) !important;
  color: var(--color-text-primary) !important;
  margin-bottom: var(--space-2) !important;
}

.sp-search-results-col .sp-no-results p,
suitepress-results .sp-no-results p {
  font-size: var(--text-sm) !important;
  color: var(--color-text-muted) !important;
  margin-bottom: 0 !important;
}

/* ── Responsive ── */
@media (max-width: 900px) {
  .suitepress-search.sp-search-layout {
    grid-template-columns: 1fr !important;
  }
  suitepress-filters.sp-search-filters-col {
    position: static !important;
  }
}
@media (max-width: 600px) {
  suitepress-results.sp-search-results-grid,
  .sp-search-results-grid {
    grid-template-columns: 1fr !important;
  }
}
/* ════════════════════════════════════════════════════════════
   21. CATEGORY ARCHIVE PAGE (category.php)
   ════════════════════════════════════════════════════════════ */
/* ── Page wrapper ── */
.sp-category-page {
  background: var(--color-bg-primary) !important;
  min-height: 80vh !important;
}

/* ── Hero ── */
.sp-category-hero {
  background: linear-gradient(135deg, #1a1f2e 0%, #0f1219 60%, #1c1016 100%) !important;
  position: relative !important;
  overflow: hidden !important;
  padding: clamp(3rem, 8vw, 5rem) 0 clamp(2.5rem, 6vw, 4rem) !important;
}

.sp-category-hero::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: radial-gradient(ellipse 60% 80% at 5% 50%, rgba(var(--color-primary-rgb), 0.14) 0%, transparent 60%), radial-gradient(ellipse 40% 55% at 95% 25%, rgba(var(--color-primary-rgb), 0.08) 0%, transparent 55%) !important;
  pointer-events: none !important;
}

.sp-category-hero .container {
  position: relative !important;
  z-index: 1 !important;
}

.sp-category-eyebrow {
  display: inline-block !important;
  font-family: var(--font-ui) !important;
  font-size: var(--text-xs) !important;
  font-weight: var(--font-semibold) !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: var(--color-primary-400) !important;
  background: rgba(var(--color-primary-rgb), 0.12) !important;
  border: 1px solid rgba(var(--color-primary-rgb), 0.25) !important;
  padding: 2px var(--space-3) !important;
  border-radius: var(--radius-full) !important;
  margin-bottom: var(--space-4) !important;
}

.sp-category-title {
  font-family: var(--font-heading) !important;
  font-size: clamp(2rem, 5vw, 3rem) !important;
  font-weight: var(--font-bold) !important;
  color: #fff !important;
  line-height: var(--leading-tight) !important;
  margin: 0 0 var(--space-3) !important;
}

.sp-category-description {
  font-size: var(--text-base) !important;
  color: rgba(255, 255, 255, 0.65) !important;
  line-height: var(--leading-relaxed) !important;
  margin: 0 0 var(--space-5) !important;
  max-width: 600px !important;
}

.sp-category-count {
  display: inline-flex !important;
  align-items: center !important;
  font-family: var(--font-ui) !important;
  font-size: var(--text-sm) !important;
  font-weight: var(--font-medium) !important;
  color: rgba(255, 255, 255, 0.55) !important;
}

.sp-category-count::before {
  content: "" !important;
  display: inline-block !important;
  width: 6px !important;
  height: 6px !important;
  border-radius: 50% !important;
  background: var(--color-primary-400) !important;
  margin-right: var(--space-2) !important;
}

/* ── Content area ── */
.sp-category-container {
  padding-block: var(--space-10) !important;
}

.sp-category-layout {
  display: grid !important;
  grid-template-columns: 1fr 280px !important;
  gap: var(--space-8) !important;
  align-items: start !important;
}

/* ── Posts column ── */
.sp-category-posts-col {
  min-width: 0 !important;
}

.sp-category-grid {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: var(--space-6) !important;
}

/* Override blog-page-container scoping so cards render correctly here */
.sp-category-grid .sp-blog-card {
  background: var(--color-bg-card) !important;
  border: 1px solid var(--color-border-default) !important;
  border-radius: var(--radius-2xl) !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  transition: border-color var(--duration-normal), box-shadow var(--duration-normal), transform var(--duration-normal) !important;
}

.sp-category-grid .sp-blog-card:hover {
  border-color: rgba(var(--color-primary-rgb), 0.3) !important;
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.07), 0 2px 8px rgba(var(--color-primary-rgb), 0.07) !important;
  transform: translateY(-3px) !important;
}

.sp-category-grid .sp-blog-card-image {
  aspect-ratio: 16/9 !important;
  overflow: hidden !important;
  flex-shrink: 0 !important;
}

.sp-category-grid .sp-blog-card-image .sp-blog-image-link {
  display: block !important;
  height: 100% !important;
}

.sp-category-grid .sp-blog-card-image .sp-blog-thumbnail {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  transition: transform var(--duration-slow) !important;
}

.sp-category-grid .sp-blog-card:hover .sp-blog-thumbnail {
  transform: scale(1.04) !important;
}

.sp-category-grid .sp-blog-card-content {
  padding: var(--space-5) !important;
  display: flex !important;
  flex-direction: column !important;
  flex: 1 !important;
}

.sp-category-grid .sp-blog-card-title {
  font-family: var(--font-heading) !important;
  font-size: var(--text-base) !important;
  font-weight: var(--font-semibold) !important;
  line-height: var(--leading-snug) !important;
  margin: 0 0 var(--space-2) !important;
}

.sp-category-grid .sp-blog-title-link {
  color: var(--color-text-primary) !important;
  text-decoration: none !important;
  transition: color var(--duration-fast) !important;
}

.sp-category-grid .sp-blog-card:hover .sp-blog-title-link {
  color: var(--color-primary-600) !important;
}

.sp-category-grid .sp-blog-card-meta {
  font-size: var(--text-xs) !important;
  color: var(--color-text-muted) !important;
  margin-bottom: var(--space-3) !important;
}

.sp-category-grid .sp-blog-card-excerpt {
  font-size: var(--text-sm) !important;
  color: var(--color-text-muted) !important;
  line-height: var(--leading-relaxed) !important;
  flex: 1 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 3 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}

.sp-category-grid .sp-blog-card-footer {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding-top: var(--space-3) !important;
  border-top: 1px solid var(--color-border-default) !important;
  margin-top: var(--space-4) !important;
}

.sp-category-grid .sp-read-more-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: var(--space-1) !important;
  font-family: var(--font-ui) !important;
  font-size: var(--text-xs) !important;
  font-weight: var(--font-semibold) !important;
  color: var(--color-primary-600) !important;
  text-decoration: none !important;
  transition: gap var(--duration-fast), color var(--duration-fast) !important;
}

.sp-category-grid .sp-blog-card:hover .sp-read-more-btn {
  gap: var(--space-2) !important;
}

.sp-category-grid .sp-reading-time {
  font-family: var(--font-ui) !important;
  font-size: var(--text-xs) !important;
  color: var(--color-text-disabled) !important;
}

/* ── Pagination ── */
.sp-category-pagination {
  display: flex !important;
  justify-content: center !important;
  margin-top: var(--space-8) !important;
}

/* ── Sidebar ── */
.sp-category-sidebar-col {
  position: sticky !important;
  top: calc(var(--header-height, 72px) + var(--space-4)) !important;
}

/* ── Authors card ── */
.sp-cat-authors-card {
  background: var(--color-bg-card) !important;
  border: 1px solid var(--color-border-default) !important;
  border-radius: var(--radius-2xl) !important;
  overflow: hidden !important;
}

.sp-cat-authors-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: var(--space-4) var(--space-5) !important;
  border-bottom: 1px solid var(--color-border-default) !important;
}

.sp-cat-authors-title {
  display: flex !important;
  align-items: center !important;
  gap: var(--space-2) !important;
  font-family: var(--font-ui) !important;
  font-size: var(--text-sm) !important;
  font-weight: var(--font-semibold) !important;
  color: var(--color-text-primary) !important;
  margin: 0 !important;
}

.sp-cat-authors-title svg {
  color: var(--color-primary-500) !important;
  flex-shrink: 0 !important;
}

.sp-cat-authors-count {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 22px !important;
  height: 22px !important;
  padding: 0 var(--space-2) !important;
  background: rgba(var(--color-primary-rgb), 0.1) !important;
  color: var(--color-primary-700) !important;
  border-radius: var(--radius-full) !important;
  font-family: var(--font-ui) !important;
  font-size: 11px !important;
  font-weight: var(--font-semibold) !important;
}

/* ── Author list ── */
.sp-cat-authors-list {
  list-style: none !important;
  margin: 0 !important;
  padding: var(--space-2) 0 !important;
}

.sp-cat-author-item {
  border-bottom: 1px solid var(--color-border-subtle) !important;
}

.sp-cat-author-item:last-child {
  border-bottom: none !important;
}

.sp-cat-author-link {
  display: flex !important;
  align-items: center !important;
  gap: var(--space-3) !important;
  padding: var(--space-3) var(--space-5) !important;
  text-decoration: none !important;
  transition: background var(--duration-fast) !important;
}

.sp-cat-author-link:hover {
  background: rgba(var(--color-primary-rgb), 0.04) !important;
}

/* Avatar */
.sp-cat-author-avatar-wrap {
  flex-shrink: 0 !important;
}

.sp-cat-author-avatar {
  width: 40px !important;
  height: 40px !important;
  border-radius: 50% !important;
  display: block !important;
  object-fit: cover !important;
  border: 2px solid rgba(var(--color-primary-rgb), 0.2) !important;
}

.sp-cat-author-avatar--initials {
  background: linear-gradient(135deg, var(--color-primary-600), var(--color-primary-400)) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.sp-cat-author-avatar--initials span {
  font-family: var(--font-heading) !important;
  font-size: var(--text-sm) !important;
  font-weight: var(--font-bold) !important;
  color: #fff !important;
  line-height: 1 !important;
}

/* Author info */
.sp-cat-author-info {
  flex: 1 !important;
  min-width: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 2px !important;
}

.sp-cat-author-name {
  font-family: var(--font-ui) !important;
  font-size: var(--text-sm) !important;
  font-weight: var(--font-semibold) !important;
  color: var(--color-text-primary) !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  transition: color var(--duration-fast) !important;
}

.sp-cat-author-link:hover .sp-cat-author-name {
  color: var(--color-primary-600) !important;
}

.sp-cat-author-title {
  font-size: 11px !important;
  color: var(--color-text-disabled) !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

/* Post count badge */
.sp-cat-author-posts {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  flex-shrink: 0 !important;
  gap: 1px !important;
  font-family: var(--font-heading) !important;
  font-size: var(--text-base) !important;
  font-weight: var(--font-bold) !important;
  color: var(--color-text-primary) !important;
  min-width: 32px !important;
  text-align: center !important;
}

.sp-cat-author-posts span {
  font-family: var(--font-ui) !important;
  font-size: 10px !important;
  font-weight: var(--font-normal) !important;
  color: var(--color-text-disabled) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
}

/* ── Responsive ── */
@media (max-width: 1024px) {
  .sp-category-layout {
    grid-template-columns: 1fr 240px !important;
  }
}
@media (max-width: 860px) {
  .sp-category-layout {
    grid-template-columns: 1fr !important;
  }
  .sp-category-sidebar-col {
    position: static !important;
  }
  .sp-cat-authors-list {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
  }
  .sp-cat-author-item {
    border-bottom: none !important;
    border: 1px solid var(--color-border-subtle) !important;
    border-radius: var(--radius-xl) !important;
    margin: var(--space-1) !important;
  }
}
@media (max-width: 600px) {
  .sp-category-grid {
    grid-template-columns: 1fr !important;
  }
  .sp-cat-authors-list {
    grid-template-columns: 1fr !important;
  }
}
/* ════════════════════════════════════════════════════════════
   20. AUTHOR ARCHIVE PAGE (author.php)
   ════════════════════════════════════════════════════════════ */
/* ── Page wrapper ── */
.sp-author-page {
  background: var(--color-bg-primary) !important;
  min-height: 80vh !important;
}

/* ── Hero ── */
.sp-author-hero {
  background: linear-gradient(135deg, #1a1f2e 0%, #0f1219 60%, #1c1016 100%) !important;
  position: relative !important;
  overflow: hidden !important;
  padding: clamp(3rem, 8vw, 5rem) 0 clamp(2.5rem, 6vw, 4rem) !important;
}

.sp-author-hero::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: radial-gradient(ellipse 55% 80% at 0% 50%, rgba(var(--color-primary-rgb), 0.13) 0%, transparent 60%), radial-gradient(ellipse 40% 50% at 100% 20%, rgba(var(--color-primary-rgb), 0.08) 0%, transparent 55%) !important;
  pointer-events: none !important;
}

.sp-author-hero .container {
  position: relative !important;
  z-index: 1 !important;
}

.sp-author-hero-inner {
  display: flex !important;
  align-items: center !important;
  gap: var(--space-8) !important;
}

/* ── Avatar ── */
.sp-author-avatar-wrap {
  flex-shrink: 0 !important;
}

.sp-author-avatar {
  width: 96px !important;
  height: 96px !important;
  border-radius: 50% !important;
  border: 3px solid rgba(var(--color-primary-rgb), 0.4) !important;
  display: block !important;
  object-fit: cover !important;
}

.sp-author-avatar--initials {
  background: linear-gradient(135deg, var(--color-primary-600), var(--color-primary-400)) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.sp-author-avatar--initials span {
  font-family: var(--font-heading) !important;
  font-size: var(--text-2xl) !important;
  font-weight: var(--font-bold) !important;
  color: #fff !important;
  line-height: 1 !important;
}

/* ── Hero info ── */
.sp-author-hero-info {
  flex: 1 !important;
  min-width: 0 !important;
}

.sp-author-hero-eyebrow {
  display: inline-block !important;
  font-family: var(--font-ui) !important;
  font-size: var(--text-xs) !important;
  font-weight: var(--font-semibold) !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: var(--color-primary-400) !important;
  background: rgba(var(--color-primary-rgb), 0.12) !important;
  border: 1px solid rgba(var(--color-primary-rgb), 0.25) !important;
  padding: 2px var(--space-3) !important;
  border-radius: var(--radius-full) !important;
  margin-bottom: var(--space-3) !important;
}

.sp-author-hero-name {
  font-family: var(--font-heading) !important;
  font-size: clamp(1.75rem, 4vw, 2.5rem) !important;
  font-weight: var(--font-bold) !important;
  color: #fff !important;
  line-height: var(--leading-tight) !important;
  margin: 0 0 var(--space-2) !important;
}

.sp-author-hero-title {
  font-family: var(--font-ui) !important;
  font-size: var(--text-sm) !important;
  font-weight: var(--font-medium) !important;
  color: var(--color-primary-300) !important;
  margin: 0 0 var(--space-3) !important;
}

.sp-author-hero-bio {
  font-size: var(--text-sm) !important;
  color: rgba(255, 255, 255, 0.65) !important;
  line-height: var(--leading-relaxed) !important;
  margin: 0 0 var(--space-5) !important;
  max-width: 560px !important;
}

/* ── Stats row ── */
.sp-author-hero-stats {
  display: flex !important;
  align-items: center !important;
  gap: var(--space-5) !important;
  flex-wrap: wrap !important;
}

.sp-author-stat {
  display: flex !important;
  flex-direction: column !important;
  gap: 2px !important;
}

.sp-author-stat-value {
  font-family: var(--font-heading) !important;
  font-size: var(--text-xl) !important;
  font-weight: var(--font-bold) !important;
  color: #fff !important;
  line-height: 1 !important;
}

.sp-author-stat-label {
  font-family: var(--font-ui) !important;
  font-size: var(--text-xs) !important;
  color: rgba(255, 255, 255, 0.5) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
}

.sp-author-stat-divider {
  width: 1px !important;
  height: 32px !important;
  background: rgba(255, 255, 255, 0.15) !important;
  flex-shrink: 0 !important;
}

/* ── Content area ── */
.sp-author-container {
  padding-block: var(--space-10) !important;
}

.sp-author-layout {
  display: grid !important;
  grid-template-columns: 1fr 300px !important;
  gap: var(--space-8) !important;
  align-items: start !important;
}

.sp-author-posts-col {
  min-width: 0 !important;
}

.sp-author-sidebar-col {
  position: sticky !important;
  top: calc(var(--header-height, 72px) + var(--space-4)) !important;
}

/* ── No posts state ── */
.sp-author-no-posts {
  padding: var(--space-12) var(--space-8) !important;
  background: var(--color-bg-card) !important;
  border: 1px solid var(--color-border-default) !important;
  border-radius: var(--radius-2xl) !important;
  text-align: center !important;
  font-size: var(--text-sm) !important;
  color: var(--color-text-muted) !important;
}

/* ── Follow card ── */
.sp-author-follow-card {
  background: var(--color-bg-card) !important;
  border: 1px solid var(--color-border-default) !important;
  border-radius: var(--radius-2xl) !important;
  overflow: hidden !important;
  padding: var(--space-5) !important;
  display: flex !important;
  flex-direction: column !important;
  gap: var(--space-5) !important;
}

/* Card profile row */
.sp-author-card-profile {
  display: flex !important;
  align-items: center !important;
  gap: var(--space-3) !important;
}

.sp-author-card-avatar-wrap {
  flex-shrink: 0 !important;
}

.sp-author-card-avatar {
  width: 52px !important;
  height: 52px !important;
  border-radius: 50% !important;
  border: 2px solid rgba(var(--color-primary-rgb), 0.3) !important;
  display: block !important;
  object-fit: cover !important;
}

.sp-author-card-avatar--initials {
  background: linear-gradient(135deg, var(--color-primary-600), var(--color-primary-400)) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.sp-author-card-avatar--initials span {
  font-family: var(--font-heading) !important;
  font-size: var(--text-base) !important;
  font-weight: var(--font-bold) !important;
  color: #fff !important;
  line-height: 1 !important;
}

.sp-author-card-info {
  min-width: 0 !important;
}

.sp-author-card-name {
  display: block !important;
  font-family: var(--font-heading) !important;
  font-size: var(--text-base) !important;
  font-weight: var(--font-semibold) !important;
  color: var(--color-text-primary) !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  transition: color var(--duration-fast) !important;
}

.sp-author-card-name:hover {
  color: var(--color-primary-600) !important;
}

.sp-author-card-title {
  font-size: var(--text-xs) !important;
  color: var(--color-text-muted) !important;
  margin: 2px 0 0 !important;
  font-family: var(--font-ui) !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

/* Card stats */
.sp-author-card-stats {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: var(--space-2) !important;
  padding: var(--space-4) !important;
  background: var(--color-bg-secondary) !important;
  border-radius: var(--radius-xl) !important;
}

.sp-author-card-stat {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 2px !important;
  text-align: center !important;
}

.sp-author-card-stat-value {
  font-family: var(--font-heading) !important;
  font-size: var(--text-lg) !important;
  font-weight: var(--font-bold) !important;
  color: var(--color-text-primary) !important;
  line-height: 1 !important;
}

.sp-author-card-stat-label {
  font-family: var(--font-ui) !important;
  font-size: 10px !important;
  color: var(--color-text-disabled) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
}

/* Follow/unfollow buttons */
.sp-author-card-actions {
  display: flex !important;
  flex-direction: column !important;
  gap: var(--space-2) !important;
}

.sp-author-follow-btn {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: var(--space-2) !important;
  width: 100% !important;
  padding: var(--space-3) var(--space-4) !important;
  background: var(--color-primary-500) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--radius-full) !important;
  font-family: var(--font-ui) !important;
  font-size: var(--text-sm) !important;
  font-weight: var(--font-semibold) !important;
  cursor: pointer !important;
  box-shadow: var(--shadow-primary-glow) !important;
  transition: background var(--duration-normal), transform var(--duration-fast) !important;
  text-decoration: none !important;
}

.sp-author-follow-btn:hover {
  background: var(--color-primary-600) !important;
  transform: translateY(-1px) !important;
}

.sp-author-unfollow-btn {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  padding: var(--space-3) var(--space-4) !important;
  background: transparent !important;
  color: var(--color-text-secondary) !important;
  border: 1px solid var(--color-border-default) !important;
  border-radius: var(--radius-full) !important;
  font-family: var(--font-ui) !important;
  font-size: var(--text-sm) !important;
  font-weight: var(--font-medium) !important;
  cursor: pointer !important;
  transition: border-color var(--duration-normal), color var(--duration-normal) !important;
  text-decoration: none !important;
}

.sp-author-unfollow-btn:hover {
  border-color: var(--color-primary-500) !important;
  color: var(--color-primary-600) !important;
}

/* Joined meta */
.sp-author-card-meta {
  padding-top: var(--space-4) !important;
  border-top: 1px solid var(--color-border-default) !important;
}

.sp-author-card-joined {
  display: inline-flex !important;
  align-items: center !important;
  gap: var(--space-2) !important;
  font-family: var(--font-ui) !important;
  font-size: var(--text-xs) !important;
  color: var(--color-text-disabled) !important;
}

/* ── Responsive ── */
@media (max-width: 900px) {
  .sp-author-layout {
    grid-template-columns: 1fr !important;
  }
  .sp-author-sidebar-col {
    position: static !important;
    order: -1 !important;
  }
  .sp-author-follow-card {
    flex-direction: row !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: var(--space-4) !important;
  }
  .sp-author-card-profile {
    flex: 1;
    min-width: 200px !important;
  }
  .sp-author-card-stats {
    flex: 1;
    min-width: 200px !important;
  }
  .sp-author-card-actions {
    width: 100% !important;
    flex-direction: row !important;
  }
  .sp-author-card-meta {
    width: 100% !important;
    border-top: none !important;
    padding-top: 0 !important;
  }
}
@media (max-width: 600px) {
  .sp-author-hero-inner {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: var(--space-5) !important;
  }
  .sp-author-follow-card {
    flex-direction: column !important;
  }
  .sp-author-card-actions {
    flex-direction: column !important;
  }
}
/* ════════════════════════════════════════════════════════════
   19. WORDPRESS SEARCH RESULTS PAGE (search.php)
   ════════════════════════════════════════════════════════════ */
/* ── Page wrapper ── */
.sp-search-wp-page {
  background: var(--color-bg-primary) !important;
  min-height: 80vh !important;
}

/* ── Hero — override old teal gradient ── */
.search-hero-section.sp-search-wp-hero,
.sp-search-wp-hero {
  background: linear-gradient(135deg, #1a1f2e 0%, #0f1219 60%, #1c1016 100%) !important;
  position: relative !important;
  overflow: hidden !important;
  padding: clamp(3rem, 8vw, 5rem) 0 clamp(2.5rem, 6vw, 4rem) !important;
  margin-bottom: 0 !important;
}

.sp-search-wp-hero::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: radial-gradient(ellipse 60% 70% at 10% 50%, rgba(var(--color-primary-rgb), 0.12) 0%, transparent 60%), radial-gradient(ellipse 40% 50% at 90% 30%, rgba(var(--color-primary-rgb), 0.08) 0%, transparent 55%) !important;
  pointer-events: none !important;
}

.sp-search-wp-hero .container {
  position: relative !important;
  z-index: 1 !important;
}

.sp-search-wp-eyebrow {
  display: inline-block !important;
  font-family: var(--font-ui) !important;
  font-size: var(--text-xs) !important;
  font-weight: var(--font-semibold) !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: var(--color-primary-400) !important;
  background: rgba(var(--color-primary-rgb), 0.12) !important;
  border: 1px solid rgba(var(--color-primary-rgb), 0.25) !important;
  padding: var(--space-1) var(--space-3) !important;
  border-radius: var(--radius-full) !important;
  margin-bottom: var(--space-4) !important;
}

.sp-search-wp-hero .search-hero-title {
  font-family: var(--font-heading) !important;
  font-size: clamp(1.75rem, 4vw, 2.75rem) !important;
  font-weight: var(--font-bold) !important;
  color: #fff !important;
  line-height: var(--leading-tight) !important;
  margin: 0 0 var(--space-3) !important;
}

.sp-search-wp-hero .search-query {
  font-size: var(--text-base) !important;
  color: rgba(255, 255, 255, 0.65) !important;
  opacity: 1 !important;
  margin: 0 !important;
}

/* ── Container & layout ── */
.sp-search-wp-container {
  padding-block: var(--space-10) !important;
}

.search-results-layout.sp-search-wp-layout {
  display: grid !important;
  grid-template-columns: 1fr 300px !important;
  gap: var(--space-8) !important;
  align-items: start !important;
}

/* ── Main results column ── */
.sp-search-wp-main {
  display: flex !important;
  flex-direction: column !important;
  gap: var(--space-6) !important;
  min-width: 0 !important;
}

.sp-search-wp-results {
  display: flex !important;
  flex-direction: column !important;
  gap: var(--space-6) !important;
}

.sp-search-wp-list {
  display: flex !important;
  flex-direction: column !important;
  gap: var(--space-4) !important;
}

/* ── Result card ── */
.search-result-card.sp-search-wp-card {
  display: flex !important;
  align-items: stretch !important;
  background: var(--color-bg-card) !important;
  border: 1px solid var(--color-border-default) !important;
  border-radius: var(--radius-2xl) !important;
  overflow: hidden !important;
  box-shadow: none !important;
  transition: border-color var(--duration-normal), box-shadow var(--duration-normal), transform var(--duration-normal) !important;
}

.search-result-card.sp-search-wp-card:hover {
  border-color: rgba(var(--color-primary-rgb), 0.3) !important;
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.07), 0 2px 8px rgba(var(--color-primary-rgb), 0.07) !important;
  transform: translateY(-2px) !important;
}

/* Card thumbnail */
.sp-search-wp-card-thumb {
  display: block !important;
  width: 200px !important;
  min-width: 200px !important;
  flex-shrink: 0 !important;
  overflow: hidden !important;
  text-decoration: none !important;
}

.sp-search-wp-card-thumb img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  transition: transform var(--duration-slow) !important;
}

.sp-search-wp-card:hover .sp-search-wp-card-thumb img {
  transform: scale(1.04) !important;
}

/* Card body — override old padding/background */
.sp-search-wp-card-body.result-card-content {
  flex: 1 !important;
  padding: var(--space-5) !important;
  background: transparent !important;
  display: flex !important;
  flex-direction: column !important;
  gap: var(--space-3) !important;
  min-width: 0 !important;
}

/* Meta row */
.sp-search-wp-card .result-meta {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: var(--space-3) !important;
  margin-bottom: 0 !important;
}

.sp-search-wp-card .author-link {
  color: var(--color-text-muted) !important;
  font-size: var(--text-xs) !important;
  text-decoration: none !important;
  display: flex !important;
  align-items: center !important;
  gap: var(--space-2) !important;
  transition: color var(--duration-fast) !important;
}

.sp-search-wp-card .author-link:hover {
  color: var(--color-text-secondary) !important;
}

.sp-search-wp-card .author-link img {
  border-radius: 50% !important;
  margin: 0 !important;
  width: 24px !important;
  height: 24px !important;
}

.sp-search-wp-card .post-category a {
  display: inline-block !important;
  background: rgba(var(--color-primary-rgb), 0.1) !important;
  color: var(--color-primary-700) !important;
  padding: 2px var(--space-3) !important;
  border-radius: var(--radius-full) !important;
  font-size: var(--text-xs) !important;
  font-weight: var(--font-semibold) !important;
  font-family: var(--font-ui) !important;
  text-decoration: none !important;
  transition: background var(--duration-fast), color var(--duration-fast) !important;
}

.sp-search-wp-card .post-category a:hover {
  background: var(--color-primary-500) !important;
  color: #fff !important;
}

/* Title */
.sp-search-wp-card .result-title {
  font-family: var(--font-heading) !important;
  font-size: var(--text-lg) !important;
  font-weight: var(--font-semibold) !important;
  line-height: var(--leading-snug) !important;
  margin: 0 !important;
}

.sp-search-wp-card .result-title a {
  color: var(--color-text-primary) !important;
  text-decoration: none !important;
  transition: color var(--duration-fast) !important;
}

.sp-search-wp-card .result-title a:hover {
  color: var(--color-primary-600) !important;
}

/* Excerpt */
.sp-search-wp-card .result-excerpt {
  font-size: var(--text-sm) !important;
  color: var(--color-text-muted) !important;
  line-height: var(--leading-relaxed) !important;
  margin: 0 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  flex: 1 !important;
}

/* Footer row */
.sp-search-wp-card .result-footer {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding-top: var(--space-3) !important;
  border-top: 1px solid var(--color-border-default) !important;
  margin-top: auto !important;
  gap: var(--space-4) !important;
}

.sp-search-wp-card .post-info {
  display: flex !important;
  align-items: center !important;
  gap: var(--space-3) !important;
  font-size: var(--text-xs) !important;
  color: var(--color-text-disabled) !important;
  font-family: var(--font-ui) !important;
}

.sp-search-wp-card .post-info .publish-date,
.sp-search-wp-card .post-info .reading-time {
  white-space: nowrap !important;
}

.sp-search-wp-card .post-info .publish-date::after {
  content: "·" !important;
  margin-left: var(--space-3) !important;
  color: var(--color-border-strong) !important;
}

/* Read more link */
.sp-search-wp-read-more {
  display: inline-flex !important;
  align-items: center !important;
  gap: var(--space-1) !important;
  font-family: var(--font-ui) !important;
  font-size: var(--text-xs) !important;
  font-weight: var(--font-semibold) !important;
  color: var(--color-primary-600) !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  flex-shrink: 0 !important;
  transition: gap var(--duration-fast), color var(--duration-fast) !important;
}

.sp-search-wp-read-more:hover {
  color: var(--color-primary-700) !important;
  gap: var(--space-2) !important;
}

/* ── Pagination ── */
.sp-search-wp-pagination {
  display: flex !important;
  justify-content: center !important;
  margin-top: var(--space-8) !important;
}

/* ── Sidebar ── */
.sp-search-wp-sidebar {
  position: sticky !important;
  top: calc(var(--header-height, 72px) + var(--space-4)) !important;
}

.sidebar-widget.sp-search-wp-widget {
  background: var(--color-bg-card) !important;
  border: 1px solid var(--color-border-default) !important;
  border-radius: var(--radius-2xl) !important;
  padding: var(--space-6) !important;
  margin-bottom: 0 !important;
}

.sp-search-wp-widget .widget-title {
  font-family: var(--font-heading) !important;
  font-size: var(--text-base) !important;
  font-weight: var(--font-semibold) !important;
  color: var(--color-text-primary) !important;
  margin: 0 0 var(--space-4) !important;
  padding-bottom: var(--space-3) !important;
  border-bottom: 1px solid var(--color-border-default) !important;
}

.sp-search-wp-widget .help-cta {
  text-align: center !important;
}

.sp-search-wp-widget .help-cta p {
  font-size: var(--text-sm) !important;
  color: var(--color-text-muted) !important;
  margin-bottom: var(--space-4) !important;
  line-height: var(--leading-relaxed) !important;
}

/* ── CTA button (sidebar + no-results) ── */
.sp-search-wp-cta {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: var(--space-3) var(--space-6) !important;
  background: var(--color-primary-500) !important;
  color: #fff !important;
  border-radius: var(--radius-full) !important;
  font-family: var(--font-ui) !important;
  font-size: var(--text-sm) !important;
  font-weight: var(--font-semibold) !important;
  text-decoration: none !important;
  box-shadow: var(--shadow-primary-glow) !important;
  transition: background var(--duration-normal), transform var(--duration-fast) !important;
}

.sp-search-wp-cta:hover {
  background: var(--color-primary-600) !important;
  color: #fff !important;
  transform: translateY(-2px) !important;
}

/* ── No results ── */
.sp-search-wp-no-results .no-results-content {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
  padding: var(--space-16) var(--space-8) !important;
  background: var(--color-bg-card) !important;
  border: 1px solid var(--color-border-default) !important;
  border-radius: var(--radius-2xl) !important;
}

.sp-search-wp-no-results-icon {
  width: 72px !important;
  height: 72px !important;
  border-radius: var(--radius-2xl) !important;
  background: var(--color-bg-secondary) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-bottom: var(--space-5) !important;
  color: var(--color-text-disabled) !important;
}

.sp-search-wp-no-results h3 {
  font-family: var(--font-heading) !important;
  font-size: var(--text-xl) !important;
  font-weight: var(--font-bold) !important;
  color: var(--color-text-primary) !important;
  margin: 0 0 var(--space-2) !important;
}

.sp-search-wp-no-results p {
  font-size: var(--text-sm) !important;
  color: var(--color-text-muted) !important;
  margin: 0 0 var(--space-6) !important;
  max-width: 400px !important;
  line-height: var(--leading-relaxed) !important;
}

/* ── Responsive ── */
@media (max-width: 900px) {
  .search-results-layout.sp-search-wp-layout {
    grid-template-columns: 1fr !important;
  }
  .sp-search-wp-sidebar {
    position: static !important;
  }
}
@media (max-width: 640px) {
  .search-result-card.sp-search-wp-card {
    flex-direction: column !important;
  }
  .sp-search-wp-card-thumb {
    width: 100% !important;
    min-width: unset !important;
    max-height: 180px !important;
  }
  .sp-search-wp-card .result-footer {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: var(--space-2) !important;
  }
}
/* ════════════════════════════════════════════════════════════
   16. RESPONSIVE CLEANUP
   ════════════════════════════════════════════════════════════ */
@media (max-width: 479px) {
  #suitepress-cover-container {
    padding-inline: var(--space-4);
  }
  .suitepress-search .search-form {
    flex-direction: column;
    border-radius: var(--radius-xl);
    padding: var(--space-3);
  }
  .suitepress-search .search-form input[type=submit] {
    width: 100%;
  }
  .footer-subscription-card .subscription-card {
    margin-inline: var(--space-4);
  }
  .tutorials-cta .cta-actions, .courses-cta .cta-actions {
    flex-direction: column;
    align-items: center;
  }
  .tutorials-cta .cta-actions a, .courses-cta .cta-actions a {
    width: 100%;
    max-width: 280px;
    justify-content: center;
  }
}

/*# sourceMappingURL=components.css.map*/