.pshc {
  --pshc-navy: #15233c;
  --pshc-text: #273449;
  --pshc-muted: #617084;
  --pshc-border: #dfe5ee;
  --pshc-bg: #f6f9fc;
  --pshc-soft: #eef7fb;
  --pshc-link: #0f7f9f;
  --pshc-link-dark: #09647f;
  --pshc-white: #ffffff;
  --pshc-accent: var(--wp--custom--color--primary, var(--wp--preset--color--primary, var(--pshc-link)));
  --pshc-accent-dark: var(--wp--custom--color--primary-dark, var(--wp--preset--color--primary, var(--pshc-link-dark)));
  --pshc-button-bg: var(--wp--custom--button--color--background, var(--wp--preset--color--primary, var(--pshc-accent)));
  --pshc-button-text: var(--wp--custom--button--color--text, var(--wp--preset--color--base, var(--pshc-white)));
  color: var(--pshc-text);
  font-size: 15px;
  font-family: inherit;
  line-height: 1.55;
  left: 50%;
  margin: 0 0 0 -50vw;
  max-width: none;
  padding: 36px max(18px, calc((100vw - 1180px) / 2)) 52px;
  position: relative;
  width: 100vw;
}

.pshc * {
  box-sizing: border-box;
}

.pshc a {
  color: var(--pshc-accent);
  text-decoration: none;
}

.pshc a:hover {
  color: var(--pshc-accent-dark);
  text-decoration: underline;
}

.pshc-hero {
  background: linear-gradient(135deg, var(--pshc-soft), var(--pshc-white));
  border: 1px solid var(--pshc-border);
  border-radius: 22px;
  box-shadow: 0 18px 44px rgba(21, 35, 60, 0.08);
  margin: 0 auto 24px;
  max-width: 920px;
  padding: 46px 48px;
  text-align: center;
  width: 100%;
}

.pshc-hero--compact {
  padding: 32px 24px;
}

.pshc-eyebrow,
.pshc-kicker {
  color: var(--pshc-accent);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.14em;
  margin: 0 0 10px;
  text-transform: uppercase;
}

.pshc-hero h1 {
  color: var(--pshc-navy);
  font-size: clamp(1.8rem, 3vw, 2.75rem);
  letter-spacing: -0.035em;
  line-height: 1.08;
  margin: 0 auto 12px;
  max-width: 760px;
}

.pshc-hero p:not(.pshc-eyebrow) {
  color: var(--pshc-muted);
  font-size: 0.98rem;
  line-height: 1.6;
  margin: 0 auto 20px;
  max-width: 720px;
}

.pshc-search {
  align-items: stretch;
  background: var(--pshc-white);
  border: 1px solid var(--pshc-border);
  border-radius: 999px;
  box-shadow: 0 12px 28px rgba(21, 35, 60, 0.1);
  display: flex;
  gap: 8px;
  margin: 0 auto;
  max-width: 620px;
  padding: 6px;
}

.pshc-search input {
  border: 0;
  border-radius: 999px;
  color: var(--pshc-text);
  flex: 1;
  font: inherit;
  min-height: 42px;
  min-width: 0;
  outline: none;
  padding: 0 18px;
}

.pshc-search button {
  background: var(--pshc-button-bg);
  border: 0;
  border-radius: 999px;
  color: var(--pshc-button-text);
  cursor: pointer;
  font-weight: 800;
  min-height: 42px;
  padding: 0 22px;
}

.pshc-live-results {
  background: var(--pshc-white);
  border: 1px solid var(--pshc-border);
  border-radius: 20px;
  box-shadow: 0 22px 44px rgba(21, 35, 60, 0.16);
  display: none;
  gap: 6px;
  left: 0;
  margin-top: 10px;
  padding: 10px;
  position: absolute;
  right: 0;
  text-align: left;
  top: 100%;
  z-index: 20;
}

.pshc-live-results:not([hidden]) {
  display: grid;
}

.pshc-search {
  position: relative;
}

.pshc-live-results a {
  border-radius: 14px;
  display: grid;
  gap: 3px;
  padding: 10px 12px;
}

.pshc-live-results a:hover {
  background: var(--pshc-bg);
  text-decoration: none;
}

.pshc-live-results small {
  color: var(--pshc-accent);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.pshc-live-results strong {
  color: var(--pshc-navy);
}

.pshc-live-results span,
.pshc-live-results__empty {
  color: var(--pshc-muted);
  font-size: 0.9rem;
}

.pshc-quick {
  margin: 0 auto 24px;
  max-width: 100%;
}

.pshc-page {
  display: grid;
  gap: 24px;
}

.pshc-module {
  margin: 0 auto;
  max-width: 1180px;
  width: 100%;
}

.pshc-module__header {
  margin-bottom: 16px;
  text-align: center;
}

.pshc-module__header h2 {
  color: var(--pshc-navy);
  font-size: clamp(1.45rem, 2.4vw, 2rem);
  letter-spacing: -0.03em;
  margin: 0 0 8px;
}

.pshc-module__header p {
  color: var(--pshc-muted);
  margin: 0 auto;
  max-width: 680px;
}

.pshc-topic-popular {
  align-items: start;
  display: grid;
  gap: 18px;
  grid-template-columns: minmax(220px, 260px) 1fr;
}

.pshc-category-grid {
  display: grid;
  gap: 16px;
}

.pshc-category-sections--grid .pshc-category-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.pshc-category-sections--tabs .pshc-category-grid,
.pshc-category-sections--drilldown .pshc-category-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.pshc-category-switcher {
  display: grid;
  gap: 18px;
  grid-template-columns: minmax(220px, 270px) 1fr;
}

.pshc-category-switcher__nav {
  background: var(--pshc-white);
  border: 1px solid var(--pshc-border);
  border-radius: 24px;
  box-shadow: 0 18px 34px rgba(21, 35, 60, 0.07);
  display: grid;
  gap: 8px;
  padding: 16px;
}

.pshc-category-switcher__nav button {
  background: transparent;
  border: 0;
  border-radius: 14px;
  color: var(--pshc-text);
  cursor: pointer;
  font: inherit;
  font-weight: 800;
  padding: 11px 12px;
  text-align: left;
}

.pshc-category-switcher__nav button.is-active,
.pshc-category-switcher__nav button:hover {
  background: var(--pshc-bg);
  color: var(--pshc-accent-dark);
}

.pshc-category-switcher__panels .pshc-topic {
  display: none;
}

.pshc-category-switcher__panels .pshc-topic.is-active {
  display: block;
}

.pshc-category-sections--tabs .pshc-category-switcher {
  grid-template-columns: 1fr;
}

.pshc-category-sections--tabs .pshc-category-switcher__nav {
  display: flex;
  flex-wrap: wrap;
}

.pshc-category-sections--drilldown .pshc-category-switcher__nav button::after {
  content: "›";
  float: right;
}

.pshc-quick h2,
.pshc-results h2 {
  color: var(--pshc-navy);
  font-size: 1.15rem;
  margin: 0 0 10px;
}

.pshc-quick__links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.pshc-quick__links a,
.pshc-filters a {
  background: var(--pshc-white);
  border: 1px solid var(--pshc-border);
  border-radius: 999px;
  box-shadow: 0 10px 22px rgba(21, 35, 60, 0.06);
  color: var(--pshc-navy);
  display: inline-flex;
  font-size: 0.88rem;
  font-weight: 700;
  padding: 8px 13px;
}

.pshc-quick__links a:hover,
.pshc-filters a:hover,
.pshc-filters a.is-active {
  background: var(--pshc-button-bg);
  border-color: var(--pshc-button-bg);
  color: var(--pshc-button-text);
  text-decoration: none;
}

.pshc-browser {
  align-items: flex-start;
  display: grid;
  gap: 28px;
  grid-template-columns: minmax(220px, 280px) 1fr;
  margin: 0 auto;
  max-width: 1120px;
}

.pshc-sidebar {
  background: var(--pshc-white);
  border: 1px solid var(--pshc-border);
  border-radius: 18px;
  box-shadow: 0 14px 28px rgba(21, 35, 60, 0.06);
  padding: 18px;
  position: sticky;
  top: 24px;
}

.pshc-sidebar h2 {
  color: var(--pshc-navy);
  font-size: 1rem;
  margin: 0 0 8px;
}

.pshc-sidebar p {
  color: var(--pshc-muted);
  font-size: 0.86rem;
  line-height: 1.5;
  margin: 0 0 12px;
}

.pshc-sidebar nav {
  display: grid;
  gap: 6px;
}

.pshc-sidebar a {
  border-radius: 12px;
  color: var(--pshc-text);
  font-size: 0.9rem;
  font-weight: 700;
  padding: 8px 10px;
}

.pshc-sidebar a:hover,
.pshc-sidebar a[aria-current="true"] {
  background: var(--pshc-bg);
  color: var(--pshc-accent-dark);
  text-decoration: none;
}

.pshc-topic-list {
  display: grid;
  gap: 20px;
}

.pshc-topic,
.pshc-results,
.pshc-faq-group,
.pshc-empty {
  background: var(--pshc-white);
  border: 1px solid var(--pshc-border);
  border-radius: 18px;
  box-shadow: 0 14px 28px rgba(21, 35, 60, 0.06);
  padding: 20px;
  scroll-margin-top: 96px;
}

.pshc-topic__header {
  align-items: flex-start;
  display: flex;
  gap: 14px;
  justify-content: space-between;
  margin-bottom: 14px;
}

.pshc-topic__header h3 {
  color: var(--pshc-navy);
  font-size: 1.18rem;
  letter-spacing: -0.02em;
  margin: 0 0 6px;
}

.pshc-topic__header p:not(.pshc-kicker) {
  color: var(--pshc-muted);
  font-size: 0.92rem;
  line-height: 1.55;
  margin: 0;
}

.pshc-topic__view,
.pshc-read-more {
  font-size: 0.88rem;
  font-weight: 800;
  white-space: nowrap;
}

.pshc-link-list,
.pshc-result-list {
  display: grid;
  gap: 8px;
}

.pshc-link-list + .pshc-link-list {
  margin-top: 20px;
}

.pshc-link-list h4 {
  color: var(--pshc-navy);
  font-size: 0.95rem;
  margin: 0 0 4px;
}

.pshc-link-list a,
.pshc-result-list a {
  border: 1px solid var(--pshc-border);
  border-radius: 13px;
  display: grid;
  gap: 3px;
  padding: 11px 13px;
}

.pshc-link-list a:hover,
.pshc-result-list a:hover {
  background: var(--pshc-bg);
  text-decoration: none;
}

.pshc-link-list span,
.pshc-result-list strong {
  color: var(--pshc-navy);
  font-size: 0.94rem;
  font-weight: 800;
}

.pshc-link-list small,
.pshc-result-list small {
  color: var(--pshc-muted);
  font-size: 0.82rem;
  line-height: 1.5;
}

.pshc-result-list__type {
  color: var(--pshc-accent);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.pshc-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 auto 20px;
  max-width: 1180px;
}

.pshc-faq-list {
  display: grid;
  gap: 16px;
  margin: 0 auto;
  max-width: 980px;
}

.pshc-faq-preview .pshc-faq-list {
  max-width: 980px;
}

.pshc-faq-groups .pshc-faq-list {
  max-width: 1180px;
}

.pshc-faq-group {
  padding: 20px;
}

.pshc-faq-group h2 {
  color: var(--pshc-navy);
  font-size: 1.15rem;
  margin: 0 0 12px;
}

.pshc-faq-group h3 {
  color: var(--pshc-navy);
  font-size: 1.12rem;
  letter-spacing: -0.015em;
  margin: 0 0 12px;
}

.pshc-faq-item {
  border: 1px solid var(--pshc-border);
  border-radius: 13px;
  margin: 8px 0;
  overflow: hidden;
}

.pshc-faq-item summary {
  color: var(--pshc-navy);
  cursor: pointer;
  font-size: 0.94rem;
  font-weight: 800;
  line-height: 1.45;
  list-style: none;
  padding: 12px 15px;
}

.pshc-faq-item summary::-webkit-details-marker {
  display: none;
}

.pshc-faq-item summary::after {
  color: var(--pshc-accent);
  content: "+";
  float: right;
  font-size: 1.05rem;
  line-height: 1;
}

.pshc-faq-item[open] summary::after {
  content: "-";
}

.pshc-faq-item__answer {
  border-top: 1px solid var(--pshc-border);
  color: #334155;
  font-size: 0.92rem;
  line-height: 1.75;
  padding: 14px 16px 16px;
}

.pshc-faq-item__answer p:last-child {
  margin-bottom: 0;
}

.pshc-article-page {
  padding-top: 48px;
  padding-bottom: 64px;
}

.pshc-article-hero {
  background: linear-gradient(135deg, var(--pshc-soft), var(--pshc-white));
  border: 1px solid var(--pshc-border);
  border-radius: 22px;
  box-shadow: 0 18px 44px rgba(21, 35, 60, 0.08);
  margin: 0 auto 22px;
  max-width: 1180px;
  padding: 34px 38px;
}

.pshc-back-link {
  color: var(--pshc-accent-dark);
  display: inline-flex;
  font-size: 0.88rem;
  font-weight: 800;
  margin-bottom: 16px;
}

.pshc-article-hero h1 {
  color: var(--pshc-navy);
  font-size: clamp(1.8rem, 3vw, 2.55rem);
  letter-spacing: -0.035em;
  line-height: 1.12;
  margin: 0 0 12px;
  max-width: 820px;
}

.pshc-article-hero p:not(.pshc-eyebrow) {
  color: #475569;
  font-size: 0.98rem;
  line-height: 1.7;
  margin: 0;
  max-width: 760px;
}

.pshc-article-layout {
  align-items: start;
  display: grid;
  gap: 22px;
  grid-template-columns: minmax(0, 1fr) 340px;
  margin: 0 auto;
  max-width: 1180px;
}

.pshc-article-card,
.pshc-article-nav-card {
  background: var(--pshc-white);
  border: 1px solid var(--pshc-border);
  border-radius: 20px;
  box-shadow: 0 14px 30px rgba(21, 35, 60, 0.06);
}

.pshc-article-card {
  padding: 34px 38px;
}

.pshc-article-content {
  color: #334155;
  font-size: 1rem;
  line-height: 1.8;
}

.pshc-article-content > *:first-child {
  margin-top: 0;
}

.pshc-article-content h2,
.pshc-article-content h3 {
  color: var(--pshc-navy);
  letter-spacing: -0.02em;
  line-height: 1.25;
  margin: 28px 0 10px;
}

.pshc-article-content h2 {
  font-size: 1.45rem;
}

.pshc-article-content h3 {
  font-size: 1.18rem;
}

.pshc-article-content p,
.pshc-article-content li {
  color: #334155;
}

.pshc-article-content a {
  font-weight: 800;
}

.pshc-article-aside {
  display: grid;
  gap: 14px;
  position: sticky;
  top: 24px;
}

.pshc-article-mini-search {
  background: var(--pshc-white);
  border: 1px solid var(--pshc-border);
  border-radius: 18px;
  box-shadow: 0 12px 26px rgba(21, 35, 60, 0.05);
  display: grid;
  gap: 10px;
  padding: 14px;
}

.pshc-article-mini-search input {
  background: var(--pshc-bg);
  border: 1px solid var(--pshc-border);
  border-radius: 999px;
  color: var(--pshc-text);
  font-size: 0.9rem;
  min-height: 42px;
  min-width: 0;
  outline: none;
  padding: 0 15px;
  width: 100%;
}

.pshc-article-mini-search button {
  background: var(--pshc-button-bg);
  border: 0;
  border-radius: 999px;
  color: var(--pshc-button-text);
  cursor: pointer;
  font-size: 0.88rem;
  font-weight: 800;
  min-height: 40px;
  padding: 0 16px;
  width: 100%;
}

.pshc-article-nav-card {
  padding: 18px;
}

.pshc-article-nav-card h2 {
  color: var(--pshc-navy);
  font-size: 1rem;
  margin: 0 0 12px;
}

.pshc-article-nav-card nav {
  display: grid;
  gap: 6px;
}

.pshc-article-overview-card {
  padding-bottom: 14px;
}

.pshc-article-nav-card a {
  border-radius: 12px;
  color: #475569;
  font-size: 0.88rem;
  font-weight: 700;
  line-height: 1.4;
  padding: 8px 10px;
}

.pshc-article-nav-card a:hover,
.pshc-article-nav-card a.is-active {
  background: var(--pshc-bg);
  color: var(--pshc-accent-dark);
  text-decoration: none;
}

.pshc-article-overview-card > a {
  background: #eaf7fb;
  color: var(--pshc-accent-dark);
  display: block;
}

.pshc-article-extras {
  margin-top: 32px;
}

.pshc-article-extras .pshc-topic,
.pshc-article-extras .pshc-empty {
  margin: 0 auto 20px;
  max-width: 920px;
}

.pshc-cta {
  align-items: center;
  display: flex;
  gap: 18px;
  justify-content: space-between;
}

.pshc-cta p {
  color: var(--pshc-navy);
  font-size: 0.98rem;
  font-weight: 800;
  margin: 0;
}

.pshc-cta__button {
  background: var(--pshc-button-bg);
  border-radius: 999px;
  color: var(--pshc-button-text) !important;
  display: inline-flex;
  font-size: 0.88rem;
  font-weight: 800;
  padding: 10px 16px;
}

.pshc-cta__button:hover {
  background: var(--pshc-accent-dark);
  text-decoration: none !important;
}

.pshc-feedback {
  background: var(--pshc-white);
  border: 1px solid var(--pshc-border);
  border-radius: 22px;
  margin: 22px auto 0;
  max-width: 1180px;
  padding: 24px;
}

.pshc-feedback h3 {
  color: var(--pshc-navy);
  margin: 0 0 14px;
}

.pshc-feedback__buttons {
  display: flex;
  gap: 10px;
}

.pshc-feedback button {
  background: var(--pshc-button-bg);
  border: 0;
  border-radius: 999px;
  color: var(--pshc-button-text);
  cursor: pointer;
  font-weight: 800;
  padding: 10px 18px;
}

.pshc-feedback__message {
  color: var(--pshc-muted);
  margin: 12px 0 0;
}

@media (max-width: 860px) {
  .pshc-hero {
    border-radius: 22px;
    padding: 38px 20px;
  }

  .pshc-search {
    border-radius: 22px;
    flex-direction: column;
  }

  .pshc-search input,
  .pshc-search button {
    width: 100%;
  }

  .pshc-browser {
    grid-template-columns: 1fr;
  }

  .pshc-topic-popular,
  .pshc-article-layout,
  .pshc-category-sections--grid .pshc-category-grid,
  .pshc-category-sections--tabs .pshc-category-grid,
  .pshc-category-sections--drilldown .pshc-category-grid,
  .pshc-category-switcher {
    grid-template-columns: 1fr;
  }

  .pshc-sidebar {
    position: static;
  }

  .pshc-sidebar nav {
    display: flex;
    flex-wrap: wrap;
  }

  .pshc-topic__header {
    display: block;
  }

  .pshc-topic__view {
    display: inline-flex;
    margin-top: 12px;
  }

  .pshc-cta {
    align-items: flex-start;
    flex-direction: column;
  }

  .pshc-article-page {
    padding-top: 28px;
  }

  .pshc-article-hero,
  .pshc-article-card {
    padding: 26px 20px;
  }

  .pshc-article-aside {
    order: -1;
    position: static;
  }

  .pshc-article-mini-search {
    gap: 8px;
  }
}
