/* ==========================================================================
   Category Archive — Page-specific styles
   All tokens reference the global design system in style.css.
   ========================================================================== */

/*  Category Hero  */
.ts-ca-header {
  background: linear-gradient(180deg, #FFFFFF 0%, #F5F3FF 100%);
  border-bottom: 1px solid var(--fp-border-1);
  padding: 36px var(--fp-gutter) 52px;
  position: relative;
  overflow: hidden;
}
.ts-ca-header::before {
  content: "";
  position: absolute;
  right: -80px;
  top: -80px;
  width: 340px;
  height: 340px;
  background: radial-gradient(circle, rgba(196,181,253,.28), transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}
.ts-ca-header-inner {
  max-width: var(--fp-container);
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

/* Breadcrumb */
.ts-crumbs {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--fp-fg-3);
  margin-bottom: 26px;
  flex-wrap: wrap;
  list-style: none;
  padding: 0;
}
.ts-crumbs a {
  color: var(--fp-fg-3);
  text-decoration: none;
  transition: color var(--fp-d-fast);
}
.ts-crumbs a:hover { color: var(--ts-purple-600); }
.ts-crumbs-sep {
  color: var(--ts-ink-300);
  display: inline-flex;
  align-items: center;
}
.ts-crumbs-sep svg { width: 14px; height: 14px; }
.ts-crumbs-current { color: var(--ts-purple-700); font-weight: 600; }

/* Hero 2-col grid */
.ts-ca-head-grid {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 48px;
  align-items: end;
}

/* Parent tag pill */
.ts-ca-parent-tag {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .04em;
  color: var(--ts-purple-600);
  background: #fff;
  border: 1px solid var(--fp-border-2);
  padding: 6px 13px 6px 11px;
  border-radius: var(--fp-r-pill);
  margin-bottom: 18px;
  text-decoration: none;
  transition: border-color var(--fp-d-fast), background var(--fp-d-fast);
}
.ts-ca-parent-tag:hover { background: var(--ts-purple-50); border-color: var(--ts-purple-300); }
.ts-ca-parent-tag svg { width: 14px; height: 14px; flex-shrink: 0; }
.ts-ca-parent-within { color: var(--fp-fg-3); font-weight: 500; letter-spacing: 0; }

/* Title row: emblem + h1 */
.ts-ca-title-row {
  display: flex;
  align-items: center;
  gap: 18px;
  margin-bottom: 18px;
}
.ts-ca-emblem {
  width: 64px;
  height: 64px;
  border-radius: 16px;
  background: var(--fp-grad-brand);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  box-shadow: 0 10px 28px rgba(109,40,217,.22);
  flex-shrink: 0;
}
.ts-ca-emblem svg { width: 30px; height: 30px; }
.ts-ca-title {
  
  font-size: var(--fp-fs-hero);
  font-weight: 800;
  letter-spacing: -.025em;
  line-height: 1.05;
  color: var(--fp-fg-1);
  margin: 0;
}
.ts-ca-desc {
  font-size: 17px;
  line-height: 1.65;
  color: var(--fp-fg-2);
  margin: 0 0 24px;
  max-width: 640px;
}

/* Meta row */
.ts-ca-meta {
  display: flex;
  align-items: center;
  gap: 10px 22px;
  flex-wrap: wrap;
}
.ts-ca-meta-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--fp-fg-3);
}
.ts-ca-meta-item svg { width: 15px; height: 15px; color: var(--ts-purple-500); }
.ts-ca-meta-item strong { color: var(--fp-fg-1); font-weight: 600; }
.ts-ca-slug-chip {
  
  font-size: 12px;
  font-weight: 600;
  color: var(--ts-purple-700);
  background: #fff;
  border: 1px solid var(--fp-border-2);
  border-radius: var(--fp-r-sm);
  padding: 4px 9px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  letter-spacing: .02em;
}
.ts-ca-slug-label { color: var(--fp-fg-3); font-weight: 400; }

/* Follow card (right side of hero) */
.ts-ca-follow {
  background: #fff;
  border: 1px solid var(--fp-border-2);
  border-radius: var(--fp-r-card);
  padding: 22px;
  width: 288px;
  box-shadow: var(--fp-shadow-sm);
}
.ts-ca-follow h4 {
  
  font-size: 15px;
  font-weight: 700;
  color: var(--fp-fg-1);
  margin: 0 0 4px;
}
.ts-ca-follow p {
  font-size: 13px;
  color: var(--fp-fg-3);
  line-height: 1.5;
  margin: 0 0 14px;
}
.ts-ca-follow .forminator-ui.forminator-custom-form {
  margin: 0 !important;
}
.ts-ca-follow .forminator-ui.forminator-custom-form label{
  display: none !important;
}
.ts-ca-follow .forminator-ui .forminator-row {
  margin-bottom: 10px !important;
}
.ts-ca-follow .forminator-ui .forminator-row-last {
  margin-bottom: 0 !important;
}
.ts-ca-follow .forminator-ui .forminator-input {
  font-size: 13px !important;
  padding: 10px 12px !important;
  border-radius: var(--fp-r-md) !important;
  border: 1px solid var(--fp-border-1) !important;
  background: var(--ts-white) !important;
  color: var(--fp-fg-1) !important;
  width: 100% !important;
  box-sizing: border-box !important;
  transition: border-color var(--fp-d-base), box-shadow var(--fp-d-base) !important;
}
.ts-ca-follow .forminator-ui .forminator-input:focus {
  outline: none !important;
  border-color: var(--ts-purple-400) !important;
  box-shadow: 0 0 0 3px rgba(167,139,250,.25) !important;
}
.ts-ca-follow .forminator-ui .forminator-input::placeholder { color: var(--ts-ink-400) !important; }
.ts-ca-follow .forminator-ui .forminator-button-submit {
  width: 100% !important;
  justify-content: center !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  padding: 10px 18px !important;
  border-radius: var(--fp-r-md) !important;
  border: none !important;
  cursor: pointer !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  background: var(--ts-coral-400) !important;
  color: #fff !important;
  box-shadow: var(--fp-shadow-cta) !important;
  transition: background var(--fp-d-base), transform var(--fp-d-base) !important;
}
.ts-ca-follow .forminator-ui .forminator-button-submit:hover { background: var(--ts-coral-500) !important; transform: translateY(-1px) !important; }
.ts-ca-follow .forminator-ui .forminator-has_error .forminator-input {
  border-color: var(--ts-coral-400) !important;
}
.ts-ca-follow .forminator-ui .forminator-has_error .forminator-input:focus {
  box-shadow: 0 0 0 3px rgba(251,113,133,.25) !important;
}
.ts-ca-follow .forminator-ui .forminator-error-message {
  color: var(--ts-coral-500) !important;
  font-size: 12px !important;
  margin-top: 6px !important;
  display: block !important;
}
.ts-ca-follow .forminator-ui .forminator-response-message {
  display: none !important;
}
.ts-ca-follow .forminator-ui .forminator-button-submit.ts-ca-subscribed {
  background: var(--ts-success) !important;
  pointer-events: none;
}

/*  Sub-category toolbar  */
.ts-ca-toolbar-wrap {
  max-width: var(--fp-container);
  margin: 0 auto;
  padding: 32px var(--fp-gutter) 0;
}
.ts-ca-toolbar {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  padding-bottom: 22px;
  border-bottom: 1px solid var(--fp-border-1);
}
.ts-ca-sub-chips {
  display: flex;
  gap: 9px;
  flex-wrap: wrap;
  flex: 1;
}
.ts-ca-chip {
  
  font-size: 13px;
  font-weight: 600;
  color: var(--fp-fg-2);
  background: #fff;
  border: 1px solid var(--fp-border-1);
  border-radius: var(--fp-r-pill);
  padding: 7px 15px;
  cursor: pointer;
  transition: all var(--fp-d-base) var(--fp-ease-out);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  text-decoration: none;
  line-height: 1;
}
.ts-ca-chip:hover {
  border-color: var(--ts-purple-300);
  color: var(--ts-purple-700);
  background: var(--ts-purple-50);
}
.ts-ca-chip.active {
  background: var(--ts-purple-600);
  border-color: var(--ts-purple-600);
  color: #fff;
}
.ts-ca-chip-cnt { font-size: 11px; opacity: .75; font-weight: 500; }

.ts-ca-sort { display: flex; align-items: center; gap: 9px; flex-shrink: 0; }
.ts-ca-sort label { font-size: 13px; color: var(--fp-fg-3); }
.ts-ca-sort select {
  
  font-size: 13px;
  font-weight: 600;
  color: var(--fp-fg-1);
  background: #fff;
  border: 1px solid var(--fp-border-1);
  border-radius: var(--fp-r-md);
  padding: 8px 32px 8px 13px;
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
}
.ts-ca-sort select:focus {
  outline: none;
  border-color: var(--ts-purple-400);
  box-shadow: 0 0 0 3px rgba(167,139,250,.25);
}

/*  Archive body  */
.ts-ca-archive-body {
  max-width: var(--fp-container);
  margin: 0 auto;
  padding: 32px var(--fp-gutter) 80px;
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 48px;
  align-items: start;
}

/* Post grid — 2-up, matches Home blog section */
.ts-ca-posts-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 22px;
}
.ts-ca-card {
  padding: 0;
  overflow: hidden;
  cursor: pointer;
  display: flex;
  flex-direction: column;
}
.ts-ca-thumb {
  height: 170px;
  position: relative;
  overflow: hidden;
}
/* Gradient art variants (no featured image) */
.ts-ca-thumb-a { background: linear-gradient(135deg, #6D28D9 0%, #A78BFA 100%); }
.ts-ca-thumb-a::before {
  content: "";
  position: absolute;
  inset: 24px;
  border: 2px dashed rgba(255,255,255,.4);
  border-radius: 8px;
}
.ts-ca-thumb-b { background: linear-gradient(135deg, #FBBF24 0%, #FB7185 100%); }
.ts-ca-thumb-b::before {
  content: "";
  position: absolute;
  inset: 18px;
  background: repeating-linear-gradient(45deg, rgba(255,255,255,.18) 0 6px, transparent 6px 18px);
  border-radius: 6px;
}
.ts-ca-thumb-c { background: linear-gradient(135deg, #0F766E 0%, #14B8A6 100%); }
.ts-ca-thumb-c::before {
  content: "";
  position: absolute;
  left: 16%; top: 24%;
  width: 34px; height: 34px;
  background: #FBBF24;
  border-radius: 50%;
  box-shadow: 64px 16px 0 -2px #FCD34D, 116px 6px 0 0 #F87171, 32px 64px 0 -4px #C4B5FD, 96px 72px 0 -2px #60A5FA;
}
.ts-ca-thumb-d { background: linear-gradient(135deg, #4F46E5 0%, #818CF8 100%); }
.ts-ca-thumb-d::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.22), transparent 45%),
              radial-gradient(circle at 75% 70%, rgba(255,255,255,.16), transparent 45%);
}
.ts-ca-thumb-e { background: linear-gradient(135deg, #DB2777 0%, #FB7185 100%); }
.ts-ca-thumb-e::before {
  content: "";
  position: absolute;
  inset: 22px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,.5);
}
.ts-ca-thumb-e::after {
  content: "";
  position: absolute;
  inset: 40px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,.35);
}
.ts-ca-thumb-f { background: linear-gradient(135deg, #0EA5E9 0%, #6366F1 100%); }
.ts-ca-thumb-f::before {
  content: "";
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  width: 62%; height: 62%;
  background:
    linear-gradient(90deg, transparent 48%, rgba(255,255,255,.4) 48% 52%, transparent 52%),
    linear-gradient(0deg,  transparent 48%, rgba(255,255,255,.4) 48% 52%, transparent 52%);
}
/* Featured image (when set) */
.ts-ca-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform var(--fp-d-base) var(--fp-ease-out);
}
.ts-ca-card:hover .ts-ca-thumb img { transform: scale(1.04); }

/* Category pill on image */
.ts-ca-pill {
  position: absolute;
  top: 14px;
  left: 14px;
  background: rgba(255,255,255,.95);
  color: var(--ts-purple-700);
  
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 5px 11px;
  border-radius: var(--fp-r-pill);
  backdrop-filter: blur(4px);
  text-decoration: none;
}

/* Card body */
.ts-ca-card-body {
  padding: 18px 22px 20px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.ts-ca-card-body h3 {
  
  font-size: 17px;
  font-weight: 700;
  color: var(--fp-fg-1);
  line-height: 1.32;
  letter-spacing: -.01em;
  margin: 0 0 8px;
  text-decoration: none;
}
.ts-ca-card-body a.ts-ca-card-link:hover h3 { color: var(--ts-purple-700); }
.ts-ca-card-link { text-decoration: none; display: block; }
.ts-ca-card-body p {
  font-size: 13px;
  line-height: 1.55;
  color: var(--fp-fg-2);
  margin: 0 0 16px;
}
.ts-ca-card-meta {
  display: flex;
  gap: 14px;
  font-size: 12px;
  color: var(--fp-fg-3);
  padding-top: 12px;
  border-top: 1px solid var(--ts-ink-100);
  align-items: center;
  margin-top: auto;
}
.ts-ca-card-meta span { display: inline-flex; align-items: center; gap: 5px; }
.ts-ca-card-meta svg { width: 13px; height: 13px; }
.ts-ca-card-arr { margin-left: auto; color: var(--ts-purple-600); }

/* No posts message */
.ts-ca-empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: 60px 24px;
  color: var(--fp-fg-3);
}
.ts-ca-empty p { font-size: 15px; margin: 8px 0 0; }

/*  Pagination  */
.ts-ca-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 40px;
  list-style: none;
  padding: 0;
  flex-wrap: wrap;
}
.ts-ca-pagination .page-numbers {
  min-width: 40px;
  height: 40px;
  padding: 0 12px;
  border-radius: var(--fp-r-md);
  border: 1px solid var(--fp-border-1);
  background: #fff;
  color: var(--fp-fg-2);
  
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  transition: all var(--fp-d-base) var(--fp-ease-out);
  text-decoration: none;
}
.ts-ca-pagination .page-numbers:hover {
  border-color: var(--ts-purple-300);
  color: var(--ts-purple-700);
  background: var(--ts-purple-50);
}
.ts-ca-pagination .page-numbers.current {
  background: var(--ts-purple-600);
  border-color: var(--ts-purple-600);
  color: #fff;
}
.ts-ca-pagination .page-numbers.dots {
  border: none;
  background: none;
  color: var(--ts-ink-400);
  cursor: default;
}
.ts-ca-pagination svg { width: 16px; height: 16px; }

/*  Sidebar  */
.ts-ca-sidebar {
  display: flex;
  flex-direction: column;
  gap: 22px;
  position: sticky;
  top: 88px;
}
.ts-ca-side-card {
  background: #fff;
  border: 1px solid var(--fp-border-1);
  border-radius: var(--fp-r-card);
  padding: 22px;
}
.ts-ca-side-card h4 {
  
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--fp-fg-1);
  margin: 0 0 16px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.ts-ca-side-card h4 svg { width: 15px; height: 15px; color: var(--ts-purple-600); }

/* Most read card */
.ts-ca-popular {
  background: var(--ts-purple-50);
  border-color: var(--fp-border-2);
}
.ts-ca-pop-list {
  list-style: none;
  margin: 0;
  padding: 0;
  counter-reset: pop;
}
.ts-ca-pop-list li a {
  display: flex;
  gap: 13px;
  align-items: flex-start;
  padding: 13px 0;
  border-bottom: 1px dashed var(--fp-border-2);
  text-decoration: none;
}
.ts-ca-pop-list li:first-child a { padding-top: 0; }
.ts-ca-pop-list li:last-child a { border-bottom: 0; padding-bottom: 0; }
.ts-ca-pop-rank {
  counter-increment: pop;
  
  font-size: 18px;
  font-weight: 800;
  line-height: 1;
  color: var(--ts-purple-300);
  flex-shrink: 0;
  width: 22px;
  transition: color var(--fp-d-fast);
}
.ts-ca-pop-rank::before { content: counter(pop); }
.ts-ca-pop-list li a:hover .ts-ca-pop-rank { color: var(--ts-purple-600); }
.ts-ca-pop-text h5 {
  
  font-size: 13px;
  font-weight: 600;
  line-height: 1.4;
  color: var(--fp-fg-1);
  margin: 0 0 4px;
  transition: color var(--fp-d-fast);
}
.ts-ca-pop-list li a:hover .ts-ca-pop-text h5 { color: var(--ts-purple-700); }
.ts-ca-pop-meta {
  font-size: 11px;
  color: var(--fp-fg-3);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.ts-ca-pop-meta svg { width: 12px; height: 12px; }

/* Sibling categories list */
.ts-ca-cat-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.ts-ca-cat-list li a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 0;
  font-size: 14px;
  color: var(--fp-fg-2);
  text-decoration: none;
  border-bottom: 1px solid var(--ts-ink-100);
  transition: color var(--fp-d-fast);
}
.ts-ca-cat-list li:last-child a { border-bottom: 0; }
.ts-ca-cat-list li a:hover { color: var(--ts-purple-700); }
.ts-ca-cat-name { display: inline-flex; align-items: center; gap: 9px; }
.ts-ca-cat-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.ts-ca-cat-count {
  font-size: 12px;
  font-weight: 600;
  color: var(--ts-ink-400);
  background: var(--ts-ink-100);
  border-radius: var(--fp-r-pill);
  padding: 2px 9px;
  white-space: nowrap;
}
.ts-ca-cat-list li a.ts-ca-is-current .ts-ca-cat-name { color: var(--ts-purple-700); font-weight: 700; }
.ts-ca-cat-list li a.ts-ca-is-current .ts-ca-cat-count {
  background: var(--ts-purple-100);
  color: var(--ts-purple-700);
}

/* Tag cloud */
.ts-ca-tag-cloud { display: flex; flex-wrap: wrap; gap: 8px; }
.ts-ca-tag-cloud a {
  font-size: 12px;
  font-weight: 500;
  color: var(--fp-fg-2);
  background: var(--ts-ink-50);
  border: 1px solid var(--fp-border-1);
  border-radius: var(--fp-r-sm);
  padding: 5px 10px;
  text-decoration: none;
  transition: all var(--fp-d-base);
}
.ts-ca-tag-cloud a:hover {
  border-color: var(--ts-purple-300);
  color: var(--ts-purple-700);
  background: var(--ts-purple-50);
}
.ts-ca-tag-hash { color: var(--ts-purple-400); }

/*  CTA band  */
.ts-ca-cta {
  padding: 56px var(--fp-gutter);
  background: var(--ts-purple-600);
  position: relative;
  overflow: hidden;
}
.ts-ca-cta::before {
  content: "";
  position: absolute;
  right: -60px;
  bottom: -60px;
  width: 300px;
  height: 300px;
  background: radial-gradient(circle, rgba(255,255,255,.08), transparent 70%);
  border-radius: 50%;
}
.ts-ca-cta-dots {
  position: absolute;
  right: 8%;
  top: 50%;
  transform: translateY(-50%);
  display: grid;
  grid-template-columns: repeat(8, 4px);
  gap: 10px;
  opacity: .18;
}
.ts-ca-cta-dots span { width: 4px; height: 4px; background: #fff; border-radius: 50%; }
.ts-ca-cta-grid {
  max-width: var(--fp-container);
  margin: 0 auto;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 32px;
  align-items: center;
  position: relative;
  z-index: 1;
}
.ts-ca-cta-icon {
  width: 64px;
  height: 64px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  flex-shrink: 0;
}
.ts-ca-cta-icon svg { width: 28px; height: 28px; }
.ts-ca-cta-text h2 {
  
  font-size: 28px;
  font-weight: 700;
  color: #fff;
  letter-spacing: -.015em;
  margin: 0 0 6px;
}
.ts-ca-cta-text p { font-size: 14px; color: var(--ts-purple-200); margin: 0; line-height: 1.5; }
.ts-ca-cta-action { text-align: right; }
.ts-ca-cta-note { font-size: 11px; color: var(--ts-purple-200); margin-top: 8px; display: block; }
.ts-ca-cta-btn {
  
  font-size: 15px;
  font-weight: 600;
  padding: 14px 24px;
  border-radius: var(--fp-r-md);
  border: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--ts-coral-400);
  color: #fff;
  box-shadow: 0 10px 28px rgba(0,0,0,.18);
  text-decoration: none;
  transition: background var(--fp-d-base), transform var(--fp-d-base);
}
.ts-ca-cta-btn:hover { background: var(--ts-coral-500); transform: translateY(-1px); color: #fff; }

/* ══ What Is Explainer section ══════════════════════════════════════════════ */

.ts-ca-explainer-section {
  background: var(--ts-ink-50);
  border-top: 1px solid var(--fp-border-1);
  border-bottom: 1px solid var(--fp-border-1);
  padding: 64px var(--fp-gutter);
}
.ts-ca-explainer-inner {
  max-width: 920px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 32px;
  align-items: start;
}
.ts-ca-explainer-mark {
  width: 60px;
  height: 60px;
  border-radius: 16px;
  background: var(--fp-grad-brand);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  box-shadow: 0 10px 28px rgba(109, 40, 217, .20);
  flex-shrink: 0;
}
.ts-ca-explainer-mark svg {
  width: 28px;
  height: 28px;
  stroke-width: 1.9;
}
.ts-ca-explainer-eyebrow {
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ts-purple-600);
  margin: 0 0 8px;
  display: block;
}
.ts-ca-explainer-inner h2 {
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  font-size: 32px;
  font-weight: 800;
  letter-spacing: -.02em;
  color: var(--fp-fg-1);
  margin: 0 0 18px;
  line-height: 1.1;
}

/* Rich-text explainer body from WYSIWYG */
.ts-cat-explainer p {
  font-size: 17px;
  line-height: 1.72;
  color: var(--fp-fg-2);
  margin: 0 0 16px;
  max-width: 660px;
}
.ts-cat-explainer p:last-child { margin-bottom: 0; }
/* First paragraph is the lede — slightly larger, ink-900 */
.ts-cat-explainer > p:first-child,
.ts-cat-explainer > p:first-of-type {
  font-size: 18px;
  color: var(--fp-fg-1);
}

/* ══ FAQ section ═════════════════════════════════════════════════════════════ */

.ts-ca-faq {
  padding: 64px var(--fp-gutter);
  background: #fff;
}
.ts-ca-faq-inner {
  max-width: 820px;
  margin: 0 auto;
}
.ts-ca-faq-head {
  text-align: center;
  margin-bottom: 36px;
}
.ts-ca-faq-eyebrow {
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ts-purple-600);
  margin: 0 0 8px;
  display: block;
}
.ts-ca-faq-head h2 {
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  font-size: 32px;
  font-weight: 800;
  letter-spacing: -.02em;
  color: var(--fp-fg-1);
  margin: 0;
  line-height: 1.1;
}
.ts-ca-faq-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* Native <details> accordion item */
.ts-ca-faq-item {
  background: #fff;
  border: 1px solid var(--fp-border-1);
  border-radius: var(--fp-r-card);
  overflow: hidden;
  transition: border-color var(--fp-d-base), box-shadow var(--fp-d-base);
}
.ts-ca-faq-item[open] {
  border-color: var(--ts-purple-300);
  box-shadow: var(--fp-shadow-sm);
}
.ts-ca-faq-item summary {
  list-style: none;
  cursor: pointer;
  padding: 20px 22px;
  display: flex;
  align-items: center;
  gap: 16px;
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  font-size: 16px;
  font-weight: 600;
  color: var(--fp-fg-1);
  user-select: none;
}
.ts-ca-faq-item summary::-webkit-details-marker { display: none; }
.ts-ca-faq-item summary:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(167, 139, 250, .35);
}

/* The +/× toggle icon */
.ts-ca-faq-q-icon {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: var(--ts-purple-50);
  color: var(--ts-purple-600);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background var(--fp-d-base) var(--fp-ease-out),
              color var(--fp-d-base) var(--fp-ease-out);
}
.ts-ca-faq-q-icon svg {
  width: 17px;
  height: 17px;
  transition: transform var(--fp-d-base) var(--fp-ease-out);
}
.ts-ca-faq-item[open] .ts-ca-faq-q-icon {
  background: var(--ts-purple-600);
  color: #fff;
}
/* Rotate +45° so plus becomes × when open */
.ts-ca-faq-item[open] .ts-ca-faq-q-icon svg { transform: rotate(45deg); }

.ts-ca-faq-q-text { flex: 1; }

.ts-ca-faq-answer {
  padding: 0 22px 22px 68px; /* 68px = 22px left + 30px icon + 16px gap */
  font-size: 15px;
  line-height: 1.7;
  color: var(--fp-fg-2);
}
.ts-ca-faq-answer p { margin: 0 0 8px; }
.ts-ca-faq-answer p:last-child { margin-bottom: 0; }
.ts-ca-faq-answer a { color: var(--ts-purple-600); }
.ts-ca-faq-answer a:hover { text-decoration: underline; }

.ts-ca-faq-foot {
  text-align: center;
  margin-top: 32px;
  font-size: 15px;
  color: var(--fp-fg-3);
}
.ts-ca-faq-foot a {
  color: var(--ts-purple-600);
  font-weight: 600;
  text-decoration: none;
}
.ts-ca-faq-foot a:hover {
  color: var(--ts-purple-700);
  text-decoration: underline;
}

/*  Responsive  */
@media (max-width: 980px) {
  .ts-ca-archive-body { grid-template-columns: 1fr; }
  .ts-ca-sidebar { position: static; }
  .ts-ca-head-grid { grid-template-columns: 1fr; gap: 28px; }
  .ts-ca-follow { width: 100%; }
}
@media (max-width: 760px) {
  .ts-ca-posts-grid { grid-template-columns: 1fr; }
  .ts-ca-cta-grid { grid-template-columns: 1fr; gap: 20px; }
  .ts-ca-cta-action { text-align: left; }
  .ts-ca-toolbar { flex-direction: column; align-items: stretch; }
  .ts-ca-sort { justify-content: space-between; }
  .ts-ca-title { font-size: clamp(28px, 8vw, 48px); }
  /* Explainer: collapse 2-col to 1-col */
  .ts-ca-explainer-inner { grid-template-columns: 1fr; gap: 20px; }
  /* FAQ answer: remove icon-width offset on narrow screens */
  .ts-ca-faq-answer { padding-left: 22px; }
}
