/* ==========================================================================
   Puja Blog – Single Post Stylesheet
   All custom properties match main.css tokens.
   ========================================================================== */

:root {
  /* Colours */
  --color-primary: #ff6b00;
  --color-primary-dark: #e55d00;
  --color-primary-light: #fff3e6;
  --color-secondary: #1a1a2e;
  --color-accent: #ffcc33;
  --color-text: #1e1e1e;
  --color-text-secondary: #636363;
  --color-text-muted: #999;
  --color-bg: #ffffff;
  --color-bg-alt: #f7f7f7;
  --color-border: #e5e5e5;
  --color-white: #ffffff;

  /* Typography */
  --font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --font-size-xs: 0.75rem;    /* 12px */
  --font-size-sm: 0.875rem;   /* 14px */
  --font-size-base: 1rem;     /* 16px */
  --font-size-md: 1.125rem;   /* 18px */
  --font-size-lg: 1.25rem;    /* 20px */
  --font-size-xl: 1.5rem;     /* 24px */
  --font-size-2xl: 2rem;      /* 32px */
  --font-size-3xl: 2.5rem;    /* 40px */

  /* Spacing */
  --space-xs: 0.25rem;
  --space-sm: 0.5rem;
  --space-md: 1rem;
  --space-lg: 1.5rem;
  --space-xl: 2rem;
  --space-2xl: 3rem;
  --space-3xl: 4rem;

  /* Layout */
  --container-max: 1200px;
  --container-padding: 1rem;
  --header-height: 64px;

  /* Radius */
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 16px;
  --radius-full: 9999px;

  /* Shadows */
  --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.08);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.1);
  --shadow-lg: 0 8px 30px rgba(0, 0, 0, 0.12);

  /* Transitions */
  --transition: 0.2s ease;
}


/* -----------------------------------------------------------------------
   Breadcrumbs row
   --------------------------------------------------------------------- */
.single-post__breadcrumbs {
  padding: var(--sp-md) 0 0;
}

/* -----------------------------------------------------------------------
   Two-column layout
   --------------------------------------------------------------------- */
.single-post__container {
  padding-top: var(--sp-lg);
  padding-bottom: var(--sp-3xl);
}

.single-post__layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
}

@media (min-width: 960px) {
  .single-post__layout {
    grid-template-columns: 1fr 300px;
    align-items: start;
  }
}

/* -----------------------------------------------------------------------
   Post header
   --------------------------------------------------------------------- */
.single-post__header {
  margin-bottom: var(--sp-xl);
}

.single-post__category {
  display: inline-flex;
  align-items: center;
  font-size: var(--fs-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-primary);
  background: var(--color-primary-light);
  padding: 4px 14px;
  border-radius: var(--r-full);
  margin-bottom: var(--sp-md);
  text-decoration: none;
  transition: all var(--trans);
}

.single-post__category:hover {
  background: var(--color-primary);
  color: var(--color-white);
}

.single-post__title {
  font-size: var(--fs-2xl);
  font-weight: 800;
  line-height: 1.22;
  color: var(--color-text);
  margin-bottom: var(--sp-lg);
  letter-spacing: -0.02em;
}

@media (min-width: 768px) {
  .single-post__title { font-size: var(--fs-2xl); }
}

.single-post__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
}

.single-post__author {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 500;
  color: var(--color-text-secondary);
}

.single-post__avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  object-fit: cover;
}

.single-post__dot { color: var(--color-text-muted); }

/* -----------------------------------------------------------------------
   Featured image
   --------------------------------------------------------------------- */
.single-post__featured-image {
  margin: 0 0 var(--sp-xl);
  border-radius: var(--r-lg);
  overflow: hidden;
}

.single-post__img {
  width: 100%;
  height: auto;
  display: block;
}

/* -----------------------------------------------------------------------
   Post body – override entry-content headings with orange accent bar
   --------------------------------------------------------------------- */
.single-post__content.entry-content h2 {
  font-size: var(--fs-lg);
  font-weight: 700;
  color: var(--color-text);
  margin: var(--sp-2xl) 0 var(--sp-sm);
  padding-left: var(--sp-md);
  border-left: 4px solid var(--color-primary);
  line-height: 1.3;
}

.single-post__content.entry-content h3 {
  font-size: var(--fs-md);
  font-weight: 600;
  margin: var(--sp-xl) 0 var(--sp-sm);
  padding-left: var(--sp-md);
  border-left: 3px solid var(--color-primary);
}

/* -----------------------------------------------------------------------
   Tags
   --------------------------------------------------------------------- */
.single-post__tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-sm);
  margin-top: var(--sp-xl);
  padding-top: var(--sp-xl);
  border-top: 1px solid var(--color-border);
}

.single-post__tag {
  display: inline-flex;
  font-size: var(--fs-xs);
  font-weight: 500;
  color: var(--color-text-secondary);
  background: var(--color-bg-alt);
  padding: 4px 12px;
  border-radius: var(--r-full);
  border: 1px solid var(--color-border);
  text-decoration: none;
  transition: all var(--trans);
}

.single-post__tag:hover {
  color: var(--color-primary);
  border-color: var(--color-primary);
}

/* Share strip below post body */
.single-post__share {
  margin-top: var(--sp-xl);
  padding-top: var(--sp-lg);
  border-top: 1px solid var(--color-border);
}

.single-post__share-label {
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: var(--sp-sm);
}

/* -----------------------------------------------------------------------
   Sidebar
   --------------------------------------------------------------------- */
.single-post__sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--sp-lg);
}

@media (min-width: 960px) {
  .single-post__sidebar {
    position: sticky;
    top: calc(var(--header-h) + var(--sp-xl));
    align-self: start;
  }
}

/* Sidebar cards */
.sidebar__card {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--r-md);
  padding: var(--sp-lg);
}

.sidebar__card-body {
  font-size: 16px;
  line-height: 1.65;
  color: var(--color-text-secondary);
  font-family: 500;
}

/* Share buttons */
.sidebar__share-buttons {
  display: flex;
  gap: 8px;
}

.sidebar__share-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 1px solid var(--color-border);
  background: var(--color-white);
  color: var(--color-text-secondary);
  cursor: pointer;
  text-decoration: none;
  transition: all var(--trans);
  flex-shrink: 0;
}

.sidebar__share-btn:hover                { border-color: var(--color-primary); color: var(--color-primary); }
.sidebar__share-btn--facebook:hover      { color: #1877f2; border-color: #1877f2; }
.sidebar__share-btn--twitter:hover       { color: #000;    border-color: #000; }
.sidebar__share-btn--linkedin:hover      { color: #0a66c2; border-color: #0a66c2; }
.sidebar__share-btn--whatsapp:hover      { color: #25d366; border-color: #25d366; }

/* -----------------------------------------------------------------------
   Puja Card (Suggested Puja sidebar component)
   --------------------------------------------------------------------- */
.puja-card {
  width: 100%;
  max-width: 380px;
  background: #ffffff;
  border-radius: 20px;
  border: 1px solid #eaeaea;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.puja-card__title {
  font-size: 28px;
  font-weight: 700;
  color: #111111;
  line-height: 1.2;
  margin: 0;
}

.puja-card__image {
  width: 100%;
  height: 180px;
  border-radius: 12px;
  object-fit: cover;
  display: block;
  flex-shrink: 0;
}

.puja-card__image--placeholder {
  background: linear-gradient(135deg, #e8d5c4, #c4a882);
}

.puja-card__content {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.puja-card__heading {
  font-size: 24px;
  font-weight: 700;
  color: #111111;
  margin: 0;
  line-height: 1.25;
}

.puja-card__description {
  font-size: 16px;
  font-weight: 400;
  color: #666666;
  margin: 0;
  line-height: 1.5;
}

.puja-card__button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 52px;
  border-radius: 8px;
  background: #ff7a00;
  color: #ffffff !important;
  font-size: 16px;
  font-weight: 600;
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition: background 0.2s ease;
  flex-shrink: 0;
}

.puja-card__button:hover {
  background: #e96e00;
  color: #ffffff !important;
}

/* Categories card */
.sidebar__cat-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.sidebar__cat-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 0;
  font-size: 16px;
  font-weight: 500;
  color: var(--color-text-secondary);
  text-decoration: none;
  border-bottom: 1px solid var(--color-border);
  transition: color var(--trans);
}

.sidebar__cat-list li:last-child .sidebar__cat-link {
  border-bottom: none;
}

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

.sidebar__cat-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
  height: 24px;
  font-size: var(--fs-xs);
  font-weight: 600;
  color: var(--color-text-muted);
  background: var(--color-bg-alt);
  border-radius: var(--r-full);
  padding: 0 6px;
}

.sidebar__cat-link:hover .sidebar__cat-count {
  background: var(--color-primary-light);
  color: var(--color-primary);
}

/* -----------------------------------------------------------------------
   Post Footer – Author left + Share right
   --------------------------------------------------------------------- */
.post-footer {
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
  padding: var(--sp-lg) 0;
  margin-bottom: var(--sp-xl);
}

.post-footer__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--sp-lg);
}

/* Author (left) */
.post-footer__author {
  display: flex;
  align-items: center;
  gap: var(--sp-md);
}

.post-footer__avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}

.post-footer__author-info,
.post-footer__date-info {
  display: flex;
  flex-direction: column;
}

.post-footer__author-label,
.post-footer__date-label {
  font-size: var(--fs-xs);
  color: var(--color-text-muted);
  font-weight: 400;
}

.post-footer__author-name {
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--color-text);
}

.post-footer__date {
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--color-text);
}

.post-footer__sep {
  color: var(--color-text-muted);
  font-size: var(--fs-lg);
}

/* Share (right) */
.post-footer__share {
  display: flex;
  align-items: center;
  gap: var(--sp-md);
}

.post-footer__share-label {
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--color-text);
  white-space: nowrap;
}

.post-footer__share-buttons {
  display: flex;
  gap: 8px;
}

@media (max-width: 599px) {
  .post-footer__inner {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* -----------------------------------------------------------------------
   Related Posts
   --------------------------------------------------------------------- */
.related-posts {
  background: var(--color-bg-alt);
  border-top: 1px solid var(--color-border);
  padding: 16px;
}

.related-posts__caption {
  font-size: var(--fs-xs);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 500;
  margin-bottom: 6px;
}

.related-posts__heading {
  font-size: var(--fs-xl);
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: 0;
}

.related-posts__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-xl);
}

@media (min-width: 600px) {
  .related-posts__grid { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 960px) {
  .related-posts__grid { grid-template-columns: repeat(3, 1fr); }
}

/* -----------------------------------------------------------------
   Single Post Layout
   --------------------------------------------------------------- */
.single-post__breadcrumbs {
  padding-top: var(--space-md);
}

.single-post__container {
  padding-top: 16px;
  padding-bottom: var(--space-3xl);
}

.single-post__layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-2xl);
}

@media (min-width: 960px) {
  .single-post__layout {
    grid-template-columns: 1fr 340px;
  }
}

/* -----------------------------------------------------------------
   Post Header
   --------------------------------------------------------------- */
.single-post__header {
  margin-bottom: var(--space-xl);
}

.single-post__category {
  display: inline-block;
  font-size: var(--font-size-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-primary);
  background: var(--color-primary-light);
  padding: 4px 14px;
  border-radius: var(--radius-full);
  margin-bottom: var(--space-md);
  text-decoration: none;
}

.single-post__category:hover {
  background: var(--color-primary);
  color: var(--color-white);
}

.single-post__title {
  font-size: var(--font-size-2xl);
  font-weight: 800;
  line-height: 1.25;
  color: var(--color-secondary);
  margin-bottom: var(--space-lg);
}

@media (min-width: 768px) {
  .single-post__title {
    font-size: var(--font-size-3xl);
  }
}

.single-post__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.single-post__author {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 500;
  color: var(--color-text-secondary);
}

.single-post__avatar {
  border-radius: 50%;
}

.single-post__dot {
  color: var(--color-text-muted);
}

/* -----------------------------------------------------------------
   Featured Image
   --------------------------------------------------------------- */
.single-post__featured-image {
  margin: 0 0 var(--space-xl);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.single-post__img {
  width: 100%;
  height: auto;
  display: block;
}

/* -----------------------------------------------------------------
   Post Content
   --------------------------------------------------------------- */
.single-post__content {
  max-width: 100%;
}

/* Tags */
.single-post__tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  margin-top: var(--space-xl);
  padding-top: var(--space-xl);
  border-top: 1px solid var(--color-border);
}

.single-post__tag {
  display: inline-flex;
  font-size: var(--font-size-xs);
  font-weight: 500;
  color: var(--color-text-secondary);
  background: var(--color-bg-alt);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  border: 1px solid var(--color-border);
  text-decoration: none;
  transition: all var(--transition);
}

.single-post__tag:hover {
  color: var(--color-primary);
  border-color: var(--color-primary);
}

/* -----------------------------------------------------------------
   Sidebar
   --------------------------------------------------------------- */
.sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--space-xl);
}

@media (min-width: 960px) {
  .sidebar {
    position: sticky;
    top: calc(var(--header-height) + var(--space-xl));
    align-self: start;
    max-height: calc(100vh - var(--header-height) - var(--space-2xl));
    overflow-y: auto;
  }
}

.sidebar__card {
  background: var(--color-bg-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
}

.sidebar__card-title {
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-secondary);
  font-size: 20px;
  margin-bottom: 6px;
}

.sidebar__card-body {
  font-size: var(--font-size-sm);
  line-height: 1.6;
  color: var(--color-text-secondary);
}

/* Share Buttons */
.sidebar__share-buttons {
  display: flex;
  gap: 8px;
}

.sidebar__share-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid var(--color-border);
  background: var(--color-white);
  color: var(--color-text-secondary);
  cursor: pointer;
  transition: all var(--transition);
  text-decoration: none;
}

.sidebar__share-btn:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
}

.sidebar__share-btn--facebook:hover  { color: #1877f2; border-color: #1877f2; }
.sidebar__share-btn--twitter:hover   { color: #1da1f2; border-color: #1da1f2; }
.sidebar__share-btn--whatsapp:hover  { color: #25d366; border-color: #25d366; }

/* Suggested Puja */
.sidebar__card--puja {
  background: var(--color-primary-light);
  border-color: var(--color-primary);
}

.sidebar__puja-img {
  width: 100%;
  border-radius: var(--radius-sm);
  margin-bottom: var(--space-md);
}

.sidebar__puja-name {
  font-size: var(--font-size-base);
  font-weight: 600;
  color: var(--color-secondary);
  margin-bottom: var(--space-sm);
}

.sidebar__puja-desc {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-md);
}

.sidebar__puja-btn {
  width: 100%;
}

/* -----------------------------------------------------------------------
   FAQ Section
   --------------------------------------------------------------------- */
.post-faq {
  padding: var(--sp-2xl) 0 var(--sp-3xl);
}

.post-faq__heading {
  font-size: var(--fs-xl);
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: var(--sp-xl);
}

.post-faq__list {
  display: flex;
  flex-direction: column;
  gap: 0;
  border-top: 1px solid var(--color-border);
}

/* FAQ item */
.faq-item {
  border-bottom: 1px solid var(--color-border);
}

.faq-item__question {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-md);
  padding: var(--sp-lg) 0;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  font-family: var(--font);
  font-size: var(--fs-base);
  font-weight: 600;
  color: var(--color-text);
  line-height: 1.4;
  transition: color var(--trans);
}

.faq-item__question:hover { color: var(--color-primary); }

.faq-item__question[aria-expanded="true"] { color: var(--color-primary); }

.faq-item__icon {
  flex-shrink: 0;
  color: var(--color-text-muted);
  transition: transform var(--trans);
}

.faq-item__question[aria-expanded="true"] .faq-item__icon {
  transform: rotate(180deg);
  color: var(--color-primary);
}

.faq-item__answer {
  display: none;
  overflow: hidden;
}

.faq-item__answer.is-open {
  display: block;
}

.faq-item__answer-body {
  padding: 0 0 var(--sp-lg);
  font-size: var(--fs-base);
  color: var(--color-text-secondary);
  line-height: 1.7;
}

@media (max-width: 768px) {
    .single-post__title{
      font-size: 18px;
      margin-bottom: 0px;
    }
    .single-post__layout{
      gap: 16px;
    }
    .related-posts__heading{
      font-size: 18px;
      margin-bottom: 10px;
    }
}