/*!
 * blog-optimized.css - Blog page styles
 * Merged: blog.css + blog-content.css
 * Generated: 2026-01-23
 */

/* ===== blog.css content removed to fix footer layout interference ===== */
/* This section contained legacy styles (Bxx classes) that were conflicting with the modern footer */

/* ===== blog-content.css content ===== */
/* ==========================================================================
   Blog Content Styles
   Matches global optimized.css variables while maintaining blog layout
   ========================================================================== */

.blog-page {
  /* --- Variable Mapping --- */
  /* Colors */
  --color-primary: var(--primary-color);
  --color-primary-light: #d44d71; 
  --color-primary-dark: var(--primary-color-hover);
  
  --color-text-primary: var(--text-main);
  --color-text-secondary: var(--text-gray);
  --color-text-inverse: var(--text-white);
  --color-text-tertiary: #999;
  
  --color-bg-primary: var(--bg-body);
  --color-bg-secondary: var(--bg-light);
  --color-bg-tertiary: #f5f5f5;
  --color-bg-dark: var(--bg-dark);
  
  --color-border-light: #e0e0e0;
  
  --font-size-xs: var(--text-xs);
  --font-size-sm: var(--text-sm);
  --font-size-md: var(--text-md);
  --font-size-h1: var(--text-4xl);
  --font-size-h2: var(--text-3xl);
  --font-size-h3: var(--text-2xl);
  --font-size-h4: var(--text-xl);
  
  /* Effects */
  --shadow-md: var(--shadow-card);
  --shadow-lg: var(--shadow-soft);
  
  --radius-card: var(--radius-lg);
  
  --line-height-tight: 1.2;
  --line-height-normal: 1.8; /* Improved for reading */
  --duration-fast: 0.3s;
  --easing-ease: ease;

  --blog-container-width: 1200px;
  --blog-card-radius: 16px;
  --blog-card-shadow: 0 6px 30px rgba(0, 0, 0, 0.08);
  --blog-card-hover-shadow: 0 15px 50px rgba(0, 0, 0, 0.15);
  --blog-card-featured-shadow: 0 8px 40px rgba(178, 50, 86, 0.15);
  --blog-card-image-height: 200px;
  --blog-card-featured-image-height: 300px;
  --blog-sidebar-width: 320px;
}

body.blog-page .site-footer, .blog-page .site-footer {
  display: flex;
  width: 100%;
  visibility: visible;
  opacity: 1;
}

body.blog-page .footer__brand, .blog-page .footer__brand, body.blog-page .footer__column, .blog-page .footer__column, body.blog-page .footer__heading, .blog-page .footer__heading, body.blog-page .footer__link, .blog-page .footer__link {
  display: block;
  visibility: visible;
  opacity: 1;
}

body.blog-page .footer__brand, .blog-page .footer__brand {
  display: flex;
}

body.blog-page .footer__column, .blog-page .footer__column {
  display: flex;
  flex-direction: column;
}

body.blog-page .site-footer .footer-container, .blog-page .site-footer .footer-container {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: var(--spacing-2xl);
  visibility: visible;
  opacity: 1;
}

body.blog-page .site-header, .blog-page .site-header, body.blog-page .site-header.site-header--dark, .blog-page .site-header.site-header--dark {
  position: relative;
  background-color: var(--bg-dark, #333);
  display: flex;
  visibility: visible;
  opacity: 1;
}

body.blog-page .site-nav__list, .blog-page .site-nav__list {
  display: flex;
  visibility: visible;
  opacity: 1;
}

body.blog-page .site-nav__item, .blog-page .site-nav__item {
  display: list-item;
  visibility: visible;
  opacity: 1;
}

body.blog-page .site-nav__link, .blog-page .site-nav__link {
  display: block;
  visibility: visible;
  opacity: 1;
}

body.blog-page .site-header__container, .blog-page .site-header__container {
  display: flex;
  visibility: visible;
  opacity: 1;
}

body.blog-page .site-header__logo, .blog-page .site-header__logo {
  display: block;
  visibility: visible;
  opacity: 1;
}

/* Accessibility */
.skip-link {
  position: absolute;
  top: -9999px;
  left: 0;
  background: var(--color-primary);
  color: #fff;
  padding: 10px 20px;
  z-index: 9999;
  text-decoration: none;
  border-radius: 0 0 4px 0;
}

.skip-link:focus {
  top: 0;
}

/* ==========================================================================
   Header Styling
   ========================================================================== */

/* ==========================================================================
   Layout
   ========================================================================== */

/* Blog page container */
.blog-page .blog-main {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

/* Blog content container - wraps article and sidebar */
.blog-content-container {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
  width: 100%;
}

/* Main article area */
.blog-article-container {
  flex: 1;
  min-width: 300px;
  max-width: 800px;
  width: 100%;
}

/* Sidebar area */
.blog-sidebar-container {
  flex: 0 0 300px;
  min-width: 300px;
}

/* Responsive layout */
@media (max-width: 1024px) {
  .blog-content-container {
    flex-direction: column;
    gap: 30px;
    padding: 0 15px;
  }
  
  .blog-article-container, .blog-sidebar-container {
    flex: 1;
    max-width: 100%;
    width: 100%;
  }
}

@media (max-width: 768px) {
  .blog-content-container {
    padding: 0 15px;
    gap: 20px;
  }
}

/* .blog-main style removed to fix layout issues (overriding core.css incorrectly) */
.blog-main {
  flex: 1;
  width: auto;
  min-width: 0; /* Important for flex items to shrink properly */
}

/* Blog Breadcrumb (Maintain backward compatibility) */

.blog-breadcrumb {

  margin: 10px 0 20px;

  padding: 0 20px;

  position: relative;

  z-index: 5;

}

.blog-breadcrumb__list {

  display: flex;

  align-items: center;

  list-style: none;

  padding: 0;

  margin: 0;

  flex-wrap: wrap;

  gap: 8px;

}

.blog-breadcrumb__item {

  display: flex;

  align-items: center;

  font-size: 0.9rem;

  color: var(--text-light);

}

.blog-breadcrumb__item:not(:last-child)::after {

  content: ">";

  margin-left: 8px;

  color: var(--text-light);

  opacity: 0.6;

}

.blog-breadcrumb__link {

  color: var(--text-light);

  text-decoration: none;

  transition: color 0.2s ease;

}

.blog-breadcrumb__link:hover {

  color: var(--primary-color);

  text-decoration: underline;

}

.blog-breadcrumb__current {

  color: var(--text-main);

  font-weight: 500;

}

/* Blog Title & Header */

.blog-title {

  font-family: var(--font-heading);

  font-size: 2.5rem;

  font-weight: 700;

  color: var(--text-main);

  position: relative;

  display: block;

  text-align: center;

  max-width: var(--blog-container-width);

  margin: 30px auto 50px;

  padding: 0 20px;

  line-height: 1.3;

}

.blog-title::after {

  content: '';

  display: block;

  width: 60px;

  height: 3px;

  background-color: var(--primary-color);

  margin: 25px auto 0;

}

/* Blog Introduction */

.blog-intro {

  max-width: var(--blog-container-width);

  margin: 0 auto 50px;

  padding: 0 20px;

  text-align: center;

}

.blog-intro p {

  font-size: 1.1rem;

  line-height: 1.8;

  color: var(--text-gray);

  margin-bottom: 20px;

}

.blog-intro p:last-child {

  margin-bottom: 0;

}

/* Blog Container & Grid */

.blog-container {

  max-width: var(--blog-container-width);

  margin: 0 auto;

  padding: 0 20px 60px;

  display: flex;

  gap: 40px;

}

.blog-main {

  flex: 1;

}

.blog-sidebar {

  width: var(--blog-sidebar-width);

  flex-shrink: 0;

}

.blog-grid {

  display: grid;

  grid-template-columns: repeat(2, 1fr);

  gap: 30px;

}

/* Blog Card (Modern) */

.blog-card {

  background: linear-gradient(135deg, #ffffff 0%, #fafafa 100%);

  border-radius: 16px;

  overflow: hidden;

  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08), 0 1px 3px rgba(0, 0, 0, 0.05);

  transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);

  border: 1px solid rgba(212, 74, 122, 0.15);

  display: flex;

  flex-direction: column;

  height: 100%;

  width: 100%;
  /* Override optimized.css fixed width */

  max-width: 100%;
  /* Ensure it doesn't get restricted */

  position: relative;

}

.blog-card::before {

  content: '';

  position: absolute;

  top: 0;

  left: 0;

  right: 0;

  height: 5px;

  background: var(--primary-color);
  
  opacity: 0.8;

  transition: opacity 0.3s ease, height 0.3s ease;

}

.blog-card:hover {

  transform: translateY(-8px) scale(1.02);

  box-shadow: 0 20px 50px rgba(212, 74, 122, 0.15), 0 8px 25px rgba(0, 0, 0, 0.1);

  border-color: rgba(212, 74, 122, 0.3);

}

.blog-card:hover::before {

  opacity: 1;

  height: 6px;

}

/* Ensure featured card label is not affected by the hover height change */
.blog-card--featured:hover::before {
  height: auto;
  opacity: 1;
}

.blog-card:active {

  transform: translateY(-4px) scale(1.01);

  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12);

  transition-duration: 0.1s;

}

.blog-card__image-wrapper {

  position: relative;

  height: var(--blog-card-image-height);

  overflow: hidden;

  background-color: #f8f9fa;

  border-radius: var(--blog-card-radius) var(--blog-card-radius) 0 0;

}

.blog-card__image {

  width: 100%;

  height: 100%;

  object-fit: cover;

  transition: transform 0.4s ease;

  opacity: 1;

}

.blog-card:hover .blog-card__image {

  transform: scale(1.08);

  filter: brightness(1.05) contrast(1.05);

}

.blog-card__image-wrapper::before {

  content: '';

  position: absolute;

  top: 0;

  left: 0;

  right: 0;

  bottom: 0;

  background: rgba(178, 50, 86, 0.1);

  opacity: 0;

  transition: opacity 0.4s ease;

  z-index: 1;

}

.blog-card:hover .blog-card__image-wrapper::before {

  opacity: 1;

}

.blog-card__content {

  padding: 28px;

  display: flex;

  flex-direction: column;

  flex: 1;

}

.blog-card__title {

  margin-bottom: 16px;

  line-height: 1.35;

  font-size: 1.35rem;

  font-weight: 700;

  color: #333;

}

.blog-card__title a {

  font-family: var(--font-heading);

  font-size: 1.3rem;

  font-weight: 600;

  color: var(--text-main);

  text-decoration: none;

  transition: color 0.2s;

  line-height: 1.35;

  display: block;

}

.blog-card__title a:hover {

  color: var(--primary-color);

}

.blog-card__excerpt {

  font-size: 0.95rem;

  color: var(--text-gray);

  line-height: 1.75;

  margin-bottom: 24px;

  flex: 1;

  display: -webkit-box;

  -webkit-line-clamp: 3;

  -webkit-box-orient: vertical;

  overflow: hidden;

  line-clamp: 3;

  box-orient: vertical;

}

/* Blog Card Tags */

.blog-card__tags {

  display: flex;

  gap: 6px;

  flex-wrap: wrap;

}

/* Default Tag Style (Base) */

.blog-card__tag {

  display: inline-block;

  padding: 4px 12px;

  border-radius: 50px;

  font-size: 0.75rem;

  font-weight: 600;

  text-transform: capitalize;

  letter-spacing: 0.3px;

  transition: all 0.3s ease;

  border: none;

  cursor: pointer;

  text-decoration: none;

}

/* Hover Effect */

.blog-card__tag:hover {

  background-color: var(--primary-color);

  color: white;

  transform: translateY(-2px);

  box-shadow: 0 4px 8px rgba(178, 50, 86, 0.2);

}

/* Grid Cards Tags (Positioned on Image) */

.blog-card:not(.blog-card--featured) .blog-card__tags {

  position: absolute;

  top: 155px;
  /* Image height 200px - tag height approx 30px - spacing */

  left: 15px;

  z-index: 5;

  margin-top: 0;

}

/* Featured Card Tags (Positioned on Image) */

.blog-card--featured .blog-card__tags {

  position: absolute;

  bottom: 20px;

  left: 20px;

  z-index: 5;

  margin-top: 0;

}

/* Unified Tag Style for All Cards */

.blog-card .blog-card__tag {

  background-color: rgba(255, 255, 255, 0.9);

  color: var(--text-main);

  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);

  backdrop-filter: blur(4px);

}

.blog-card__tag:active {

  transform: translateY(0);

}

/* Blog Card Tag Modifiers */

.blog-card__tag--category {

  background-color: rgba(178, 50, 86, 0.1);

  color: var(--primary-color);

}

.blog-card__tag--tips {

  background-color: rgba(76, 175, 80, 0.1);

  color: #4CAF50;

}

.blog-card__tag--stories {

  background-color: rgba(156, 39, 176, 0.1);

  color: #9C27B0;

}

.blog-card__tag--location {

  background-color: rgba(33, 150, 243, 0.1);

  color: #2196F3;

}

/* Blog Card Read More Button */

.blog-card__read-more {

  display: inline-flex;

  align-items: center;

  justify-content: center;

  padding: 12px 28px;

  background-color: var(--primary-color);

  border: 2px solid var(--primary-color);

  color: #fff;

  border-radius: 50px;

  text-decoration: none;

  font-size: 0.85rem;

  font-weight: 800;

  letter-spacing: 1px;

  text-transform: uppercase;

  transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);

  position: relative;

  padding-right: 55px;

  align-self: flex-start;

  box-shadow: 0 4px 15px rgba(178, 50, 86, 0.25);

  margin-top: 20px;

}

.blog-card__read-more::after {

  content: '→';

  position: absolute;

  right: 28px;

  top: 50%;

  transform: translateY(-50%);

  opacity: 0.8;

  transition: all 0.3s ease;

  font-weight: 900;

}

.blog-card__read-more:hover {

  background-color: #9a2b4a;

  border-color: #9a2b4a;

  color: #fff;

  box-shadow: 0 8px 25px rgba(178, 50, 86, 0.4);

  transform: translateY(-4px);

  padding-right: 60px;

}

.blog-card__read-more:hover::after {

  opacity: 1;

  right: 24px;

  transform: translateY(-50%) translateX(3px);

}

.blog-card__read-more:active {

  transform: translateY(-2px);

  box-shadow: 0 4px 15px rgba(178, 50, 86, 0.3);

  transition-duration: 0.1s;

}

.blog-card__feedback {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 15px;
  padding-top: 15px;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}

.blog-card__helpful-text {
  font-size: 0.85rem;
  color: var(--text-light);
  margin-right: 5px;
}

.blog-card__feedback-btn {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 6px 12px;
  border: 1px solid rgba(0, 0, 0, 0.1);
  background-color: white;
  border-radius: 20px;
  cursor: pointer;
  font-size: 0.85rem;
  color: var(--text-gray);
  transition: all 0.2s ease;
}

.blog-card__feedback-btn:hover {
  background-color: var(--bg-light);
  transform: translateY(-2px);
}

.blog-card__feedback-btn--yes:hover {
  border-color: var(--color-love);
  color: var(--color-love);
}

.blog-card__feedback-btn--no:hover {
  border-color: var(--color-appreciation);
  color: var(--color-appreciation);
}

.blog-card__feedback-btn.voted {
  background-color: var(--bg-light);
  font-weight: 600;
}

.blog-card__feedback-btn--yes.voted {
  border-color: var(--color-love);
  color: var(--color-love);
  background-color: var(--color-love-light);
}

.blog-card__feedback-btn--no.voted {
  border-color: var(--color-appreciation);
  color: var(--color-appreciation);
  background-color: var(--color-appreciation-light);
}

.blog-card__feedback-icon {
  font-size: 1rem;
}

.blog-card__feedback-count {
  font-weight: 600;
}

@media (max-width: 768px) {
  .blog-card__feedback {
    flex-wrap: wrap;
    gap: 8px;
  }

  .blog-card__helpful-text {
    width: 100%;
    margin-bottom: 5px;
  }

  .blog-card__feedback-btn {
    padding: 8px 16px;
    min-height: 36px;
  }
}

/* Featured Article Card */

.blog-card--featured {

  grid-column: 1 / -1;

  display: grid;

  grid-template-columns: 1fr 1fr;

  gap: 30px;

  background: linear-gradient(135deg, #ffffff 0%, #f8f9fa 100%);

  border: 2px solid var(--primary-color);

  box-shadow: var(--blog-card-featured-shadow);

  position: relative;

  overflow: visible;

}

.blog-card--featured::before {

  content: 'FEATURED';

  position: absolute;

  top: 20px;

  left: 20px;

  background: var(--primary-color);

  color: white;

  font-size: 0.7rem;

  font-weight: 800;

  padding: 6px 20px;

  border-radius: 100px;

  letter-spacing: 1px;

  z-index: 3;

  box-shadow: 0 4px 12px rgba(178, 50, 86, 0.3);

  height: auto;

  width: auto;

  right: auto;

  opacity: 1;

}

.blog-card--featured .blog-card__image-wrapper {

  height: 100%;

  min-height: var(--blog-card-featured-image-height);

  border-radius: 14px 0 0 14px;

  overflow: hidden;

}

.blog-card--featured .blog-card__image {

  border-radius: 14px 0 0 14px;

  width: 100%;

  height: 100%;

  object-fit: cover;

}

.blog-card--featured .blog-card__content {

  display: flex;

  flex-direction: column;

  justify-content: center;

  padding: 40px;

}

.blog-card--featured .blog-card__title {

  font-size: 2rem;

  font-weight: 700;

  margin-bottom: 20px;

  line-height: 1.3;

}

.blog-card--featured .blog-card__excerpt {

  font-size: 1.1rem;

  line-height: 1.8;

  -webkit-line-clamp: 4;

  line-clamp: 4;

  margin-bottom: 28px;

}

/* Latest Article Card */

.blog-card--latest {

  border-top: 4px solid #ff6b6b;

  box-shadow: 0 6px 30px rgba(0, 0, 0, 0.1);

  position: relative;

}

.blog-card--latest::after {

  content: 'NEW';

  position: absolute;

  top: 15px;

  right: 15px;

  background: #ff6b6b;

  color: white;

  font-size: 0.65rem;

  font-weight: 800;

  padding: 4px 12px;

  border-radius: 100px;

  letter-spacing: 1px;

  z-index: 3;

}

/* Remove the red top bar for latest cards */

.blog-card.blog-card--latest::before {

  display: none;

  opacity: 0;

  height: 0;

}

/* Enhanced Sidebar Styles */

/* Sidebar Widget Base */

.sidebar-widget {

  background: #fff;

  border-radius: 16px;

  padding: 28px;

  margin-bottom: 30px;

  box-shadow: 0 6px 30px rgba(0, 0, 0, 0.08);

  border: 1px solid rgba(0, 0, 0, 0.08);

  transition: all 0.3s ease;

}

.sidebar-widget:hover {

  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.12);

  transform: translateY(-3px);

}

.sidebar-widget__title {

  font-family: var(--font-heading);

  font-size: 1.3rem;

  font-weight: 700;

  color: var(--text-main);

  margin-bottom: 24px;

  padding-bottom: 16px;

  border-bottom: 3px solid var(--primary-color);

  position: relative;

}

.sidebar-widget__title::after {

  content: '';

  position: absolute;

  bottom: -3px;

  left: 0;

  width: 60px;

  height: 3px;

  background: linear-gradient(90deg, var(--primary-color), #d44a7a);

}

/* Search Widget */

.blog-search {

  margin-bottom: 10px;

}

.blog-search__container {

  position: relative;

  display: flex;

  margin-bottom: 8px;

}

.blog-search__input {

  flex: 1;

  padding: 12px 16px;

  padding-right: 50px;

  border: 2px solid #e0e0e0;

  border-radius: 50px;

  font-size: 0.95rem;

  font-family: var(--font-body);

  color: var(--text-main);

  background-color: white;

  transition: all 0.3s ease;

}

.blog-search__input:focus {

  outline: none;

  border-color: var(--primary-color);

  box-shadow: 0 0 0 3px rgba(178, 50, 86, 0.1);

}

.blog-search__input::placeholder {

  color: #999;

}

.blog-search__button {

  position: absolute;

  right: 6px;

  top: 50%;

  transform: translateY(-50%);

  width: 40px;

  height: 40px;

  background-color: var(--primary-color);

  color: white;

  border: none;

  border-radius: 50%;

  cursor: pointer;

  display: flex;

  align-items: center;

  justify-content: center;

  transition: all 0.3s ease;

}

.blog-search__button:hover {

  background-color: #9a2b4a;

  transform: translateY(-50%) scale(1.05);

}

.blog-search__button:active {

  transform: translateY(-50%) scale(0.95);

}

.blog-search__icon {

  width: 18px;

  height: 18px;

}

.blog-search__suggestions {

  padding: 0 16px;

}

.blog-search__hint {

  font-size: 0.8rem;

  color: var(--text-gray);

  font-style: italic;

}

/* About Widget */

.sidebar-image {

  max-width: 100%;

  height: auto;

  border-radius: 12px;

  display: block;

  margin-bottom: 15px;

}













/* Sidebar Posts */

.sidebar-posts {

  display: flex;

  flex-direction: column;

  gap: 16px;

}

.sidebar-post {

  padding-bottom: 16px;

  border-bottom: 1px solid #f0f0f0;

}

.sidebar-post:last-child {

  padding-bottom: 0;

  border-bottom: none;

}

.sidebar-post__link {

  display: block;

  text-decoration: none;

  color: inherit;

  transition: all 0.2s ease;

}

.sidebar-post__link:hover {

  transform: translateX(5px);

}

.sidebar-post__title {

  display: block;

  font-family: var(--font-heading);

  font-size: 0.95rem;

  font-weight: 600;

  color: var(--text-main);

  margin-bottom: 4px;

  line-height: 1.4;

  transition: color 0.2s ease;

}

.sidebar-post__link:hover .sidebar-post__title {

  color: var(--primary-color);

}

.sidebar-post__date {

  display: block;

  font-size: 0.8rem;

  color: var(--text-gray);

  font-weight: 500;

}

/* Sidebar Categories */

.sidebar-categories {

  display: flex;

  flex-direction: column;

  gap: 12px;

}

.sidebar-category {

  display: flex;

  justify-content: space-between;

  align-items: center;

  padding: 10px 16px;

  background-color: #f8f9fa;

  border-radius: 8px;

  text-decoration: none;

  color: var(--text-main);

  transition: all 0.3s ease;

  border: 1px solid transparent;

}

.sidebar-category:hover {

  background-color: white;

  border-color: var(--primary-color);

  transform: translateX(5px);

  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08);

}

.sidebar-category__name {

  font-size: 0.9rem;

  font-weight: 600;

  color: var(--text-main);

}

.sidebar-category__count {

  font-size: 0.8rem;

  font-weight: 700;

  color: var(--primary-color);

  background-color: rgba(178, 50, 86, 0.1);

  padding: 4px 10px;

  border-radius: 50px;

  min-width: 30px;

  text-align: center;

}

/* Sidebar Tags */

.sidebar-tags {

  display: flex;

  flex-wrap: wrap;

  gap: 8px;

}

.sidebar-tag {

  display: inline-block;

  padding: 6px 14px;

  background-color: #f0f0f0;

  color: var(--text-gray);

  border-radius: 50px;

  text-decoration: none;

  font-size: 0.8rem;

  font-weight: 500;

  transition: all 0.3s ease;

}

.sidebar-tag:hover {

  background-color: var(--primary-color);

  color: white;

  transform: translateY(-2px);

  box-shadow: 0 4px 12px rgba(178, 50, 86, 0.2);

}

/* Blog Pagination Styles */

.blog-pagination {

  display: flex;

  flex-direction: column;

  align-items: center;

  margin: 30px 0 20px;

  padding: 0 20px;

  width: 100%;

}

.blog-pagination__info {

  font-size: 0.95rem;

  color: var(--text-gray);

  margin-bottom: 25px;

  font-weight: 500;

}

.blog-pagination__current-range {

  font-weight: 700;

  color: var(--primary-color);

}

.blog-pagination__total {

  font-weight: 700;

  color: var(--text-main);

}

.blog-pagination__nav {

  width: 100%;

  max-width: 600px;

}

.blog-pagination__list {

  display: flex;

  justify-content: center;

  align-items: center;

  gap: 8px;

  list-style: none;

  margin: 0;

  padding: 0;

}

.blog-pagination__item {

  margin: 0;

}

.blog-pagination__link {

  display: flex;

  align-items: center;

  justify-content: center;

  min-width: 44px;

  height: 44px;

  padding: 0 16px;

  background-color: #fff;

  border: 2px solid #e0e0e0;

  border-radius: 10px;

  color: var(--text-main);

  text-decoration: none;

  font-size: 0.95rem;

  font-weight: 600;

  transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);

  position: relative;

  overflow: hidden;

}

.blog-pagination__link:hover {

  background-color: #f8f9fa;

  border-color: var(--primary-color);

  color: var(--primary-color);

  transform: translateY(-2px);

  box-shadow: 0 6px 20px rgba(178, 50, 86, 0.15);

}

.blog-pagination__link:active {

  transform: translateY(0);

  box-shadow: 0 3px 10px rgba(178, 50, 86, 0.1);

  transition-duration: 0.1s;

}

/* Active page */

.blog-pagination__item--active .blog-pagination__link {

  background-color: var(--primary-color);

  border-color: var(--primary-color);

  color: white;

  font-weight: 700;

  box-shadow: 0 4px 15px rgba(178, 50, 86, 0.25);

  text-shadow: 0 1px 1px rgba(0, 0, 0, 0.2);

}

.blog-pagination__item--active .blog-pagination__link:hover {

  background-color: #9a2b4a;

  border-color: #9a2b4a;

  color: white;

  font-weight: 700;

  box-shadow: 0 6px 20px rgba(178, 50, 86, 0.35);

}

/* Previous/Next buttons */

.blog-pagination__item--prev, .blog-pagination__item--next {

  flex: 1;

  max-width: 140px;

}

.blog-pagination__link--prev, .blog-pagination__link--next {

  gap: 8px;

  padding: 0 20px;

}

.blog-pagination__icon {

  width: 16px;

  height: 16px;

  flex-shrink: 0;

}

.blog-pagination__text {

  font-size: 0.9rem;

  font-weight: 700;

  letter-spacing: 0.3px;

}

/* Ellipsis */





/* Disabled state */

.blog-pagination__item--disabled .blog-pagination__link {

  opacity: 0.5;

  cursor: not-allowed;

  pointer-events: none;

}

.blog-pagination__item--disabled .blog-pagination__link:hover {

  background-color: #fff;

  border-color: #e0e0e0;

  color: var(--text-main);

  transform: none;

  box-shadow: none;

}

/* =========================================

   Blog Responsive Design

   ========================================= */

/* Tablet (992px and below) */

@media (max-width: 992px) {

  .blog-container {

    flex-direction: column;

  }

  .blog-sidebar {

    width: 100%;

    order: 2;

  }

  .blog-breadcrumb {

    margin: 10px 0 15px;

  }

  .breadcrumb {

    margin: 140px 0 15px;

  }

}

/* Mobile (768px and below) */

@media (max-width: 768px) {

  .blog-grid {

    grid-template-columns: 1fr;

    gap: 25px;

  }

  .blog-card--featured .blog-card__title {

    font-size: 1.8rem;

  }

  .blog-card--featured .blog-card__excerpt {

    font-size: 1rem;

    -webkit-line-clamp: 3;

    line-clamp: 3;

  }

  .sidebar-widget {

    margin-bottom: 20px;

    padding: 24px;

  }

  .sidebar-widget__title {

    font-size: 1.2rem;

  }

  /* Mobile breadcrumb */

  .blog-breadcrumb {

    margin: 10px 0 15px;

    padding: 0 15px;

  }

  .blog-breadcrumb__item {

    font-size: 0.85rem;

  }

  .breadcrumb {

    margin: 90px 0 15px;

    padding: 0 15px;

  }

  

}

@media (max-width: 768px) {

  

  .blog-title {

    font-size: 2.2rem;

    margin: 30px auto 40px;

  }

  /* Responsive adjustments for featured and latest cards */

  .blog-card--featured {

    grid-template-columns: 1fr;

    gap: 0;

  }

  .blog-card--featured .blog-card__image-wrapper {

    min-height: 200px;

    height: 200px;

    border-radius: 12px 12px 0 0;

  }

  .blog-card--featured .blog-card__image {

    border-radius: 12px 12px 0 0;

  }

  .blog-card--featured .blog-card__tags {

    bottom: auto;

    top: 155px;

    left: 15px;

  }

  .blog-card--featured .blog-card__content {

    padding: 24px;

  }

  .blog-card--featured .blog-card__title {

    font-size: 1.8rem;

  }

  .blog-card--featured::before {

    left: 20px;

    top: -10px;

    font-size: 0.65rem;

    padding: 5px 15px;

  }

  .blog-container {

    padding: 0 15px 40px;

  }

  .sidebar-widget {

    padding: 20px;

    margin-bottom: 25px;

  }

  .sidebar-widget__title {

    font-size: 1.1rem;

    margin-bottom: 20px;

    padding-bottom: 12px;

  }

  

  .sidebar-post__title {

    font-size: 0.9rem;

  }

  .sidebar-category {

    padding: 8px 14px;

  }

  .sidebar-tag {

    padding: 5px 12px;

    font-size: 0.75rem;

  }

  /* Mobile pagination */

  .blog-pagination {

    margin: 40px 0 30px;

    padding: 0 15px;

  }

  .blog-pagination__info {

    font-size: 0.9rem;

    margin-bottom: 20px;

  }

  .blog-pagination__list {

    gap: 6px;

  }

  .blog-pagination__link {

    min-width: 40px;

    height: 40px;

    padding: 0 12px;

    font-size: 0.9rem;

  }

  .blog-pagination__link--prev, .blog-pagination__link--next {

    padding: 0 16px;

  }

  .blog-pagination__text {

    font-size: 0.9rem;

  }

  .blog-pagination__text {

    font-size: 0.85rem;

  }

}

/* Mobile (480px and below) */

@media (max-width: 480px) {

  .blog-title {

    font-size: 2rem;

    margin: 80px auto 30px;

  }

  .blog-card__content {

    padding: 20px;

  }

  .blog-card__title a {

    font-size: 1.2rem;

    line-height: 1.3;

  }

  .blog-card__excerpt {

    font-size: 0.9rem;

    line-height: 1.7;

  }

  .blog-card__read-more {

    padding: 10px 22px;

    font-size: 0.8rem;

    padding-right: 50px;

  }

  .blog-card__read-more::after {

    right: 22px;

  }

  .blog-card__read-more:hover {

    padding-right: 55px;

  }

  .blog-card__read-more:hover::after {

    right: 18px;

  }

  .blog-card--featured .blog-card__title {

    font-size: 1.6rem;

  }

  .blog-card--featured .blog-card__excerpt {

    font-size: 0.95rem;

    line-height: 1.7;

  }

  .blog-card--featured::before {

    left: 15px;

    top: 15px;

    font-size: 0.6rem;

    padding: 4px 12px;

  }

  .blog-card--latest::after {

    top: 12px;

    right: 12px;

    font-size: 0.6rem;

    padding: 3px 10px;

  }

  /* Pagination Responsive */

  .blog-pagination {

    margin: 30px 0 20px;

  }

  .blog-pagination__list {

    gap: 6px;

  }

  .blog-card__read-more:hover::after {

    right: 18px;

  }

  .blog-pagination__link {

    min-width: 36px;

    height: 36px;

    padding: 0 12px;

    font-size: 0.85rem;

    border-radius: 8px;

  }

  .blog-pagination__item--prev, .blog-pagination__item--next {

    max-width: 100px;

  }

  .blog-pagination__link--prev, .blog-pagination__link--next {

    padding: 0 12px;

    gap: 6px;

  }

  .blog-pagination__text {

    font-size: 0.8rem;

  }

  .blog-pagination__icon {

    width: 14px;

    height: 14px;

  }

}
/* Readability improvements */

.blog-page-content p {

  line-height: 1.8;

  margin-bottom: 1.5em;

}

.blog-page-content h1, .blog-page-content h2, .blog-page-content h3, .blog-page-content h4 {

  margin-top: 1.5em;

  margin-bottom: 0.75em;

  line-height: 1.3;

}

.blog-page-content h1+p, .blog-page-content h2+p, .blog-page-content h3+p, .blog-page-content h4+p {

  margin-top: 0;

}

.blog-page-content ul:not(.blog-article__related-list), .blog-page-content ol:not(.blog-article__related-list) {

  margin-bottom: 1.5em;

  padding-left: 1.5em;

}

.blog-page-content li:not(.blog-article__related-item) {

  margin-bottom: 0.5em;

  line-height: 1.7;

}

/* Page fade-in animation */

@keyframes fadeIn {

  from {

    opacity: 0;

    transform: translateY(20px);

  }

  to {

    opacity: 1;

    transform: translateY(0);

  }

}

.blog-page-content {

  animation: fadeIn 0.6s ease-out;

}

/* Staggered animation for blog cards */

.blog-card {

  animation: fadeIn 0.6s ease-out;

  animation-fill-mode: both;

}

/* Delay each card slightly for staggered effect */

.blog-card:nth-child(1) {
  animation-delay: 0.1s;
}

.blog-card:nth-child(2) {
  animation-delay: 0.2s;
}

.blog-card:nth-child(3) {
  animation-delay: 0.3s;
}

.blog-card:nth-child(4) {
  animation-delay: 0.4s;
}

.blog-card:nth-child(5) {
  animation-delay: 0.5s;
}

.blog-card:nth-child(6) {
  animation-delay: 0.6s;
}

.blog-card:nth-child(7) {
  animation-delay: 0.7s;
}

.blog-card:nth-child(8) {
  animation-delay: 0.8s;
}

.blog-card:nth-child(9) {
  animation-delay: 0.9s;
}

/* Reduce motion preference */

@media (prefers-reduced-motion: reduce) {

  .blog-page-content, .blog-card {

    animation: none;

  }

}

.blog-page-content blockquote {

  border-left: 4px solid var(--primary-color);

  padding-left: 1.5em;

  margin: 2em 0;

  font-style: italic;

  color: var(--text-gray);

  font-size: 1.1em;

  line-height: 1.7;

}

.blog-page-content blockquote p {

  margin-bottom: 0.5em;

}

.blog-page-content blockquote p:last-child {

  margin-bottom: 0;

}





@media (max-width: 768px) {

  .blog-page-content p {

    line-height: 1.7;

    margin-bottom: 1.2em;

  }

  .blog-page-content h1, .blog-page-content h2, .blog-page-content h3, .blog-page-content h4 {

    margin-top: 1.2em;

    margin-bottom: 0.6em;

  }

  .blog-page-content blockquote {

    padding-left: 1em;

    margin: 1.5em 0;

    font-size: 1em;

  }

}
/* ==========================================================================
   Article Styling
   ========================================================================== */

.blog-article {
  background-color: transparent; /* Revert to transparent/page background */
  border-radius: 0; /* Remove radius */
  box-shadow: none; /* Remove shadow */
  overflow: visible; /* Allow overflow if needed */
  margin-top: 60px; /* Add margin to separate from header */
}

.blog-article:hover {
  box-shadow: none; /* Remove hover effect */
}



.blog-article__title {
  font-family: var(--font-heading);
  font-size: var(--font-size-h1);
  font-weight: 700;
  line-height: 1.3;
  color: var(--color-text-primary);
  margin-bottom: 32px; /* Increased spacing */
}

/* Meta Data */
.blog-article__metadata {
  display: flex !important; /* Force display */
  justify-content: center;
  flex-wrap: wrap;
  gap: 24px; /* Explicit px value */
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  margin-bottom: 32px; /* Increased spacing */
  width: 100%;
  position: relative;
  z-index: 2;
}

.blog-article__meta-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
}

.blog-article__meta-icon {
  width: 18px;
  height: 18px;
  min-width: 18px;
  color: var(--color-primary);
  fill: currentColor;
  opacity: 0.9;
}

/* Breadcrumb */
.breadcrumb {
  margin-top: 16px; /* Spacing handled by meta's margin-bottom + this margin-top */
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  padding-top: 16px;
  border-top: 1px dashed #eee; /* Optional separator */
  width: 100%;
  display: flex;
  justify-content: flex-start; /* Left align */
  margin-bottom: 8px; /* Extra space before bottom border */
}



/* Fix double slash issue by resetting ::after from other css files */










/* Content */
.blog-article__content {
  padding: 32px 0; /* Vertical padding */
  font-size: 16px; /* Larger font for readability */
  color: #444;
  line-height: 1.8;
}

/* Ensure content has proper horizontal spacing */
.blog-article__content > * {
  max-width: 100%;
}

.blog-article__content p, .blog-article__content h2, .blog-article__content h3, .blog-article__content h4, .blog-article__content ul, .blog-article__content ol, .blog-article__content blockquote {
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

.blog-article__content img {
  max-width: 100%;
  height: auto;
}

.blog-article__content h2 {
  font-family: var(--font-heading);
  font-size: var(--font-size-h2);
  font-weight: 600;
  line-height: 1.3;
  color: var(--color-text-primary);
  margin: 48px 0 24px;
  padding-bottom: 12px;
  border-bottom: 2px solid #f0f0f0;
  position: relative;
}

.blog-article__content h2::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 60px;
  height: 2px;
  background-color: var(--color-primary);
}

.blog-article__content h3 {
  font-family: var(--font-body);
  font-size: var(--font-size-h3);
  font-weight: 600;
  color: var(--color-text-primary);
  margin: 32px 0 16px;
}

.blog-article__content p {
  margin-bottom: 16px;
  line-height: 1.8;
}

.blog-article__content a {
  color: var(--color-primary);
  text-decoration: none;
  border-bottom: 1px solid rgba(178, 50, 86, 0.3);
  transition: all 0.2s;
}

.blog-article__content a:hover {
  color: var(--color-primary-dark);
  border-bottom-color: var(--color-primary);
  background-color: rgba(178, 50, 86, 0.05);
}

.blog-article__content img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-md);
  margin: 32px 0;
  box-shadow: 0 4px 12px rgba(0,0,0,0.05);
}

.blog-image--float-left {
  float: left;
  margin-right: 24px !important;
  margin-bottom: 16px !important;
  margin-top: 8px !important;
  max-width: 50% !important;
}

@media (max-width: 600px) {
  .blog-article__content img {
    margin: 20px 0;
  }

  .blog-article__content .blog-image--float-left {
    float: none;
    display: block;
    width: 100% !important;
    max-width: 100% !important;
    margin: 16px auto 24px !important;
  }
}

.blog-article__content ul, .blog-article__content ol {
  margin: 24px 0 24px 24px;
  padding-left: 16px;
}

.blog-article__content li {
  margin-bottom: 12px;
  position: relative;
}

.blog-article__content ul {
  list-style: none;
}

.blog-article__content ul li::before {
  content: "•";
  color: var(--color-primary);
  font-weight: bold;
  display: inline-block;
  width: 1em;
  margin-left: -1em;
}

.blog-article__content blockquote {
  border-left: 4px solid var(--color-primary);
  background-color: #fff9fb; /* Very subtle pink tint */
  padding: 24px 32px;
  margin: 32px 0;
  font-style: italic;
  font-size: 1.1em;
  color: var(--color-text-primary);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
}

/* Footer & Tags */
.blog-article__footer {
  padding: var(--spacing-xl, 32px) 0 var(--spacing-md, 16px);
  border-top: 1px solid var(--color-border-light);
  background-color: transparent;
}

.blog-article__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: var(--spacing-md, 16px);
}

.blog-article__tag {
  display: inline-block;
  padding: 6px 16px;
  background-color: #fff;
  color: var(--color-text-secondary);
  border: 1px solid #e0e0e0;
  border-radius: 20px;
  font-size: var(--font-size-xs);
  text-decoration: none;
  transition: all 0.2s;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.blog-article__tag:hover {
  background-color: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary);
  transform: translateY(-1px);
}

/* Related Articles */
.blog-article__related {
  margin-top: 0;
  margin-bottom: var(--spacing-xl, 32px);
  clear: both;
}

.blog-article__related-title {
  font-size: var(--font-size-h4);
  font-weight: 600;
  margin-bottom: 16px;
  padding-left: 12px;
  border-left: 4px solid var(--color-primary);
  color: var(--color-text-primary);
}

.blog-article__related-list {
  list-style: none;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: 16px;
  margin: 0;
}

.blog-article__related-item {
  background: #fff;
  border: 1px solid #eee;
  border-radius: 8px;
  padding: 16px;
  transition: all 0.2s ease;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

.blog-article__related-item:hover {
  transform: translateY(-2px);
  border-color: var(--color-primary-light);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}

.blog-article__related-link {
  color: var(--color-text-primary);
  text-decoration: none;
  font-weight: 600;
  display: block;
  line-height: 1.4;
}

.blog-article__related-link:hover {
  color: var(--color-primary);
}

/* Responsive design for related articles */
@media (max-width: 768px) {
  .blog-article__related-list {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  
  .blog-article__related-item {
    padding: 12px;
  }
}

@media (max-width: 480px) {
  .blog-article__related {
    margin-top: 0;
    margin-bottom: var(--spacing-lg, 24px);
  }
  
  .blog-article__related-title {
    font-size: var(--font-size-h5);
    margin-bottom: 12px;
  }
}
/* ==========================================================================
   Sidebar
   ========================================================================== */

.blog-sidebar {
  display: flex;
  flex-direction: column;
  gap: 32px;
  position: sticky;
  top: 100px; /* Sticky sidebar */
}

.blog-sidebar__widget {
  background-color: #fff;
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-card);
  overflow: hidden;
  border: 1px solid #eee;
  padding: 28px;
}



.blog-sidebar__widget-title {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: 600;
  margin: 0 0 var(--spacing-md) 0;
  line-height: 1.3;
  color: var(--color-text-primary);
  border-bottom: 3px solid var(--primary-color);
}

.blog-sidebar__about {
  text-align: center;
}

.blog-sidebar__about-image {
  border-radius: 8px;
  margin-bottom: 16px;
  width: 100%;
  height: auto;
  object-fit: cover;
}

.blog-sidebar__about-text {
  font-size: 14px;
  color: var(--color-text-secondary);
  line-height: 1.6;
  margin-bottom: 0;
}

.blog-sidebar__posts-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.blog-sidebar__posts-item {
  margin-bottom: var(--spacing-md);
  padding-bottom: var(--spacing-md);
  border-bottom: 1px solid #f0f0f0;
}

.blog-sidebar__posts-item:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: none;
}

.blog-sidebar__posts-link {
  color: var(--color-text-primary);
  text-decoration: none;
  font-size: var(--text-sm);
  font-weight: 500;
  line-height: 1.6;
  margin-bottom: var(--spacing-xs);
  transition: color 0.2s;
  display: block;
}

.blog-sidebar__posts-link:hover {
  color: var(--color-primary);
}

/* ==========================================================================
   Interactive Elements
   ========================================================================== */

/* Back to Top */
.back-to-top {
  position: fixed;
  bottom: 32px;
  right: 32px;
  width: 48px;
  height: 48px;
  background-color: var(--color-primary);
  color: #fff;
  border: none;
  border-radius: 50%;
  box-shadow: 0 4px 12px rgba(0,0,0,0.2);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transform: translateY(20px);
  transition: all 0.3s ease;
  z-index: 999;
}

.back-to-top.visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.back-to-top:hover {
  background-color: var(--color-primary-dark);
  transform: translateY(-4px);
  box-shadow: 0 8px 16px rgba(178, 50, 86, 0.3);
}

.back-to-top__icon {
  width: 24px;
  height: 24px;
  fill: currentColor;
}

.hub-page .sidebar-widget {
  background: var(--bg-body);
  border: 1px solid var(--bg-light);
  box-shadow: var(--shadow-card);
  padding: 22px;
  margin-bottom: var(--spacing-lg);
}

.hub-page .sidebar-widget:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-1px);
}

.hub-page .sidebar-widget__title {
  font-size: 1.15rem;
  margin-bottom: 18px;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--primary-color);
}

.hub-page .sidebar-widget__title::after {
  background: var(--primary-gradient);
  height: 2px;
  width: 48px;
}

.hub-page .sidebar-tag {
  background-color: var(--bg-light);
  color: var(--text-gray);
  padding: 10px 16px;
  font-size: 0.85rem;
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.hub-page .sidebar-tag:hover {
  background-color: var(--primary-color);
  color: var(--text-white);
}

.hub-page .hub-toc {
  margin-bottom: var(--spacing-xl);
  position: relative;
  z-index: 2;
}

.hub-page .hub-reads-grid {
  gap: var(--spacing-lg);
  justify-items: stretch;
  align-items: stretch;
}

.hub-page .blog-card--compact {
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.hub-page .blog-card--compact::before {
  content: none;
}

.hub-page .blog-card--compact .blog-card__content {
  padding: 18px;
}

.hub-page .blog-card--compact .blog-card__title {
  font-size: 1.15rem;
  margin: 0 0 var(--spacing-md);
}

.hub-page .blog-card--compact .blog-card__title a {
  text-decoration: none;
  color: var(--text-main);
}

.hub-page .blog-card--compact .blog-card__title a:hover {
  color: var(--primary-color);
}

.hub-page .blog-card--compact .blog-card__read-more {
  margin-top: var(--spacing-md);
}

.hub-page .blog-page-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-lg);
  background: var(--primary-gradient);
  border-radius: var(--radius-lg);
  padding: var(--spacing-lg);
  padding-bottom: max(var(--spacing-lg), env(safe-area-inset-bottom));
  box-shadow: var(--shadow-soft);
  margin-top: var(--spacing-xl);
  margin-bottom: var(--spacing-2xl);
}

.hub-page .blog-page-actions .btn {
  margin-bottom: 0;
}

.hub-page .blog-page-actions .btn--primary {
  background: rgba(255, 255, 255, 0.18);
  border: 2px solid rgba(255, 255, 255, 0.92);
  color: var(--text-white);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.18);
  transform: translateY(-1px);
}

.hub-page .blog-page-actions .btn--primary:hover {
  background: rgba(255, 255, 255, 0.26);
  border-color: var(--text-white);
  color: var(--text-white);
  transform: translateY(-2px);
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.22);
}

.hub-page .blog-page-actions .btn--outline {
  border-color: rgba(255, 255, 255, 0.9);
  color: var(--text-white);
}

.hub-page .blog-page-actions .btn--outline:hover {
  background-color: var(--text-white);
  color: var(--primary-color);
  border-color: var(--text-white);
}

.hub-page .hub-cta__content {
  min-width: 260px;
  flex: 1 1 360px;
}

.hub-page .hub-cta__title {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  line-height: 1.25;
  color: var(--text-white);
  margin: 0 0 var(--spacing-sm);
}

.hub-page .hub-cta__text {
  margin: 0;
  color: rgba(255, 255, 255, 0.92);
  line-height: 1.7;
}

.hub-page .hub-cta__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-md);
  justify-content: center;
  flex: 0 0 auto;
}

@media (max-width: 768px) {
  .hub-page .blog-page-actions {
    justify-content: center;
    text-align: center;
    flex-direction: column;
    align-items: stretch;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
  }

  .hub-page .hub-cta__content {
    min-width: 0;
    flex: 0 1 auto;
  }

  .hub-page .hub-cta__actions {
    width: 100%;
    justify-content: stretch;
    flex-direction: column;
  }

  .hub-page .hub-cta__actions .btn {
    width: 100%;
    min-width: 0;
  }

  .hub-page .hub-reads-grid {
    gap: var(--spacing-md);
  }
}

.hub-page .hub-subtitle {
  font-size: var(--text-md);
  font-weight: 700;
  color: var(--text-main);
  margin: var(--spacing-lg) 0 var(--spacing-sm);
}



.hub-page .hub-section {
  margin-bottom: 0;
  scroll-margin-top: 110px;
}

.hub-page .hub-section:target {
  outline: 2px solid rgba(178, 50, 86, 0.25);
  outline-offset: 6px;
}









.hub-page .hub-faq__items details {
  border: 1px solid var(--bg-light);
  border-radius: var(--radius-md);
  padding: var(--spacing-md);
  background: var(--bg-body);
}

.hub-page .hub-faq__items details + details {
  margin-top: var(--spacing-sm);
}

.hub-page .hub-faq__items summary {
  cursor: pointer;
  font-weight: 700;
  color: var(--text-main);
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-md);
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--radius-sm);
}

.hub-page .hub-faq__items summary::-webkit-details-marker {
  display: none;
}

.hub-page .hub-faq__items summary::after {
  content: "+";
  color: var(--primary-color);
  font-weight: 800;
}

.hub-page .hub-faq__items details[open] > summary::after {
  content: "–";
}

.hub-page .hub-faq__items details > p {
  margin: var(--spacing-sm) 0 0;
  color: var(--text-gray);
}

.hub-page .hub-faq__items details[open] {
  box-shadow: var(--shadow-soft);
}

.hub-page .hub-faq__items summary:focus-visible {
  outline: 2px solid var(--primary-color);
  outline-offset: 4px;
  border-radius: var(--radius-sm);
}

@media (min-width: 900px) {
  .hub-page .hub-toc {
    position: sticky;
    top: 96px;
  }

  

  .hub-page #overview {
    grid-column: 1 / span 6;
  }

  .hub-page #tips {
    grid-column: 7 / span 6;
  }

  .hub-page #reads, .hub-page #faq, .hub-page #related {
    grid-column: 1 / -1;
  }

  
}

/* ==========================================================================
   Responsive Design
   ========================================================================== */




