/* ============================================================
   Single Article — PFC (Hair Transplant)
   Editorial article template: hero + reading progress + summary +
   content + clinical trust + author + related + trust strip.
   No right sidebar, no consultation snapshot box.
   Palette / container / gutters identical to the other PFC pages.
   ============================================================ */
.dgs2-pfc-single-ht{
	--pfsa-ink:#142646;
	--pfsa-ink-2:#1a2f52;
	--pfsa-blue:#455e8a;
	--pfsa-blue-soft:#698bc5;
	--pfsa-accent:#ff9472;
	--pfsa-accent-2:#ff8a2b;
	--pfsa-text:#33414f;
	--pfsa-muted:#6a727f;
	--pfsa-line:rgba(20,38,70,.10);
	--pfsa-soft:#eef1f6;
	--pfsa-container:1500px;
	--pfsa-content:1180px;
	box-sizing:border-box; width:100%;
	background:#fff; color:var(--pfsa-text); font-family:inherit;
}
.dgs2-pfc-single-ht *,
.dgs2-pfc-single-ht *::before,
.dgs2-pfc-single-ht *::after{ box-sizing:border-box; }
.dgs2-pfc-single-ht :where(h1,h2,h3,h4){ color:var(--pfsa-ink); }
.dgs2-pfc-single-ht :where(p){ margin:0; }
.dgs2-pfc-single-ht :where(a){ text-decoration:none; }
.dgs2-pfc-single-ht :where(figure){ margin:0; }

.pfsa__wrap{ max-width:var(--pfsa-container); margin:0 auto; padding:0 20px; }

/* ---------- READING PROGRESS ---------- */
.pfsa__progress{ position:fixed; top:0; left:0; right:0; height:3px; background:transparent; z-index:99999; pointer-events:none; }
.pfsa__progress > i{ display:block; height:100%; width:0; background:linear-gradient(90deg,var(--pfsa-accent),var(--pfsa-blue)); }

/* ---------- HERO (navy, centred — matches the other pages) ---------- */
.pfsa__hero{
	padding:74px 0 62px; margin-bottom:48px;
	color:#fff; text-align:center;
	background:
		radial-gradient(90% 120% at 50% -30%, rgba(105,139,197,.34), rgba(105,139,197,0) 60%),
		linear-gradient(135deg,#1a2f52 0%,#142646 58%,#0f1f3a 100%);
}
.pfsa__hero-inner{ display:flex; flex-direction:column; align-items:center; }
.pfsa__hero-copy{ max-width:920px; }
.pfsa__kicker{ display:inline-block; font-size:13px; font-weight:800; letter-spacing:.18em; text-transform:uppercase; color:var(--pfsa-accent-2); }
.dgs2-pfc-single-ht .pfsa__title{ font-size:clamp(32px,4.4vw,56px); font-weight:800; letter-spacing:-.02em; line-height:1.12; margin:14px 0 0; color:#fff; }
.pfsa__proof{ display:flex; flex-wrap:wrap; justify-content:center; gap:10px 14px; margin-top:22px; }
.pfsa__proof span{ position:relative; font-size:12.5px; font-weight:700; color:rgba(255,255,255,.82); padding-left:18px; }
.pfsa__proof span::before{ content:""; position:absolute; left:0; top:50%; transform:translateY(-50%); width:10px; height:10px; border-radius:50%; background:rgba(255,255,255,.12); border:2px solid var(--pfsa-blue-soft); }
.pfsa__meta{ display:flex; align-items:center; justify-content:center; flex-wrap:wrap; gap:8px; margin-top:18px; font-size:13.5px; font-weight:600; color:rgba(255,255,255,.7); }
.pfsa__meta-author{ color:#fff; font-weight:800; }
.pfsa__meta .pfsa__dot{ color:rgba(255,255,255,.4); }
.pfsa__hero-media{ display:none; }

/* ---------- BODY ---------- */
.pfsa__body{ padding-bottom:80px; }
/* Body blocks span the full container width, aligned with the hero (no
   narrow centred column). */

/* summary */
.pfsa__summary{ background:#fff; border:1px solid var(--pfsa-line); border-left:4px solid var(--pfsa-accent); border-radius:12px; padding:16px 20px; margin-bottom:30px; }
.pfsa__summary-k{ display:block; font-size:11px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--pfsa-blue); margin-bottom:6px; }
.pfsa__summary p{ font-size:16px; line-height:1.7; color:var(--pfsa-text); }

/* ---------- ARTICLE CONTENT (prose) ---------- */
.pfsa__content{ font-size:17.5px; line-height:1.8; color:var(--pfsa-text); }
.pfsa__content > *{ margin:0 0 22px; }
.pfsa__content > *:last-child{ margin-bottom:0; }
.pfsa__content h2{ font-size:clamp(24px,2.4vw,32px); font-weight:800; letter-spacing:-.02em; line-height:1.2; margin:42px 0 16px; scroll-margin-top:90px; }
.pfsa__content h2::after{ content:""; display:block; width:54px; height:4px; border-radius:99px; margin-top:14px; background:linear-gradient(90deg,var(--pfsa-blue),var(--pfsa-accent)); }
.pfsa__content h3{ font-size:clamp(19px,1.8vw,23px); font-weight:800; line-height:1.3; margin:30px 0 12px; color:var(--pfsa-ink-2); }
.pfsa__content h4{ font-size:18px; font-weight:800; margin:24px 0 10px; }
.pfsa__content p{ margin:0 0 22px; }
.pfsa__content a{ color:var(--pfsa-blue); font-weight:700; border-bottom:1px solid transparent; transition:border-color .2s ease; }
.pfsa__content a:hover{ border-color:var(--pfsa-accent); }
.pfsa__content strong{ color:var(--pfsa-ink); }
.pfsa__content em{ color:var(--pfsa-ink-2); }
/* In-content images are not shown on single posts (text-only article pages). */
.pfsa__content p:has(> img){ display:none; }
.pfsa__content img{ display:none; }
.pfsa__content ul,
.pfsa__content ol{ margin:0 0 22px; padding-left:0; list-style:none; }
.pfsa__content ul li,
.pfsa__content ol li{ position:relative; padding-left:32px; margin:0 0 12px; line-height:1.7; }
.pfsa__content ul li::before{ content:""; position:absolute; left:6px; top:11px; width:8px; height:8px; border-radius:50%; background:var(--pfsa-accent); }
.pfsa__content ol{ counter-reset:pfsa-ol; }
.pfsa__content ol li{ counter-increment:pfsa-ol; }
.pfsa__content ol li::before{ content:counter(pfsa-ol); position:absolute; left:0; top:2px; width:22px; height:22px; border-radius:50%; display:grid; place-items:center; font-size:12px; font-weight:800; color:#fff; background:var(--pfsa-blue); }
.pfsa__content blockquote{ margin:0 0 24px; padding:18px 22px; border-left:4px solid var(--pfsa-blue); background:var(--pfsa-soft); border-radius:0 14px 14px 0; font-style:italic; color:var(--pfsa-ink-2); }
.pfsa__content blockquote p:last-child{ margin-bottom:0; }

/* tables */
.pfsa__content .table-responsive{ overflow-x:auto; margin:0 0 26px; border-radius:14px; box-shadow:0 14px 36px rgba(20,38,70,.08); }
.pfsa__content table{ width:100%; border-collapse:collapse; background:#fff; font-size:15px; }
.pfsa__content table th,
.pfsa__content table td{ padding:13px 16px; text-align:left; border:1px solid var(--pfsa-line); vertical-align:top; }
.pfsa__content table th{ background:var(--pfsa-ink); color:#fff; font-weight:700; }
.pfsa__content table tr:first-child th,
.pfsa__content table tr:first-child td{ background:var(--pfsa-ink); color:#fff; font-weight:700; }
.pfsa__content table tr:nth-child(even) td{ background:var(--pfsa-soft); }

/* ---------- CLINICAL TRUST LAYER ---------- */
.pfsa__trust{ display:grid; grid-template-columns:1.6fr 1fr; gap:24px; align-items:stretch; margin-top:46px; background:var(--pfsa-soft); border:1px solid var(--pfsa-line); border-radius:18px; padding:26px; }
.pfsa__trust-eyebrow{ display:inline-block; font-size:11px; font-weight:800; letter-spacing:.14em; text-transform:uppercase; color:var(--pfsa-blue); margin-bottom:8px; }
.dgs2-pfc-single-ht .pfsa__trust-h{ font-size:clamp(20px,2vw,26px); margin:0 0 10px; }
.pfsa__trust-p{ color:var(--pfsa-text); line-height:1.65; font-size:15px; margin:0 0 16px; }
.pfsa__trust-badges{ display:flex; flex-wrap:wrap; gap:8px; }
.pfsa__badge{ display:inline-flex; align-items:center; padding:6px 13px; border-radius:999px; background:#fff; border:1px solid var(--pfsa-line); color:var(--pfsa-blue); font-weight:800; font-size:11.5px; }
.pfsa__trust-status{ background:#fff; border:1px solid var(--pfsa-line); border-radius:14px; padding:18px; }
.pfsa__trust-k{ display:block; font-size:10.5px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--pfsa-muted); margin-bottom:8px; }
.pfsa__trust-v{ display:inline-flex; align-items:center; gap:8px; font-size:15.5px; font-weight:800; color:var(--pfsa-ink); margin-bottom:12px; }
.pfsa__trust-list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:9px; }
.pfsa__trust-list li{ display:flex; align-items:center; gap:8px; color:var(--pfsa-text); font-weight:600; font-size:13.5px; }
.pfsa__check{ flex:0 0 auto; }

/* ---------- AUTHOR ---------- */
.pfsa__author{ display:flex; gap:16px; align-items:flex-start; margin-top:30px; background:var(--pfsa-soft); border:1px solid var(--pfsa-line); border-radius:16px; padding:20px 22px; }
.pfsa__author-img{ width:66px; height:66px; border-radius:50%; object-fit:cover; flex:0 0 auto; }
.pfsa__author-k{ display:block; font-size:10.5px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--pfsa-blue); }
.pfsa__author-name{ display:block; font-size:17px; color:var(--pfsa-ink); margin:3px 0 8px; }
.pfsa__author-body p{ color:var(--pfsa-text); line-height:1.6; font-size:14.5px; }

/* ---------- RELATED ARTICLES (same design as contact / appointment) ---------- */
.pfsa__rel{ margin-top:46px; padding:30px 0 6px; }
.pfsa__rel-eyebrow{ display:inline-block; font-size:13px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--pfsa-blue); }
.dgs2-pfc-single-ht .pfsa__rel-h{ font-size:clamp(24px,2.6vw,32px); font-weight:800; letter-spacing:-.01em; margin:6px 0 14px; }
.pfsa__rel-list{ list-style:none; margin:0; padding:0; }
.pfsa__rel-list li{ border-top:1px solid var(--pfsa-line); }
.pfsa__rel-list li:last-child{ border-bottom:1px solid var(--pfsa-line); }
.pfsa__rel-link{ display:flex; align-items:baseline; justify-content:space-between; gap:18px; padding:15px 4px; }
.pfsa__rel-t{ font-size:16.5px; font-weight:700; color:var(--pfsa-blue); text-decoration:underline; text-underline-offset:3px; line-height:1.4; }
.pfsa__rel-link:hover .pfsa__rel-t{ color:var(--pfsa-ink); }
.pfsa__rel-more{ flex:0 0 auto; font-size:14px; font-weight:700; color:var(--pfsa-ink-2); white-space:nowrap; }
.pfsa__rel-more span{ display:inline-block; transition:transform .2s ease; }
.pfsa__rel-link:hover .pfsa__rel-more span{ transform:translateX(4px); }

/* ---------- TRUST STRIP ---------- */
.pfsa__trust3{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:50px; padding-top:34px; border-top:1px solid var(--pfsa-line); }
.pfsa__trust3 div{ display:flex; flex-direction:column; gap:5px; }
.pfsa__trust3 strong{ font-size:15.5px; color:var(--pfsa-ink); font-weight:800; }
.pfsa__trust3 span{ font-size:13.5px; color:var(--pfsa-muted); line-height:1.55; }

/* ---------- RESPONSIVE ---------- */
@media (max-width:900px){
	.pfsa__hero-inner{ grid-template-columns:1fr; gap:28px; }
	.pfsa__hero{ padding:42px 0 36px; margin-bottom:34px; }
	.pfsa__trust{ grid-template-columns:1fr; }
	.pfsa__rel-grid{ grid-template-columns:repeat(2,1fr); gap:20px; }
	.pfsa__trust3{ grid-template-columns:1fr; gap:18px; }
}
@media (max-width:680px){
	.dgs2-pfc-single-ht .pfsa__summary p,
	.dgs2-pfc-single-ht .pfsa__content p,
	.dgs2-pfc-single-ht .pfsa__content li,
	.dgs2-pfc-single-ht .pfsa__content blockquote,
	.dgs2-pfc-single-ht .pfsa__trust-p,
	.dgs2-pfc-single-ht .pfsa__author-body p,
	.dgs2-pfc-single-ht .pfsa__trust3 span{
		max-width:none;
		width:100%;
		text-align:justify;
		text-align-last:left;
		-webkit-hyphens:auto;
		hyphens:auto;
	}
}
@media (max-width:560px){
	.pfsa__content{ font-size:16.5px; }
	.pfsa__rel-grid{ grid-template-columns:1fr; }
	.pfsa__author{ flex-direction:column; }
}

/* ============================================================
   SEARCH RESULTS — PFC (Hair Transplant)
   ============================================================ */
.dgs2-pfc-search{
	--pfsr-ink:#142646; --pfsr-ink-2:#1a2f52; --pfsr-blue:#455e8a; --pfsr-blue-soft:#698bc5; --pfsr-accent:#ff9472;
	--pfsr-accent-2:#ff8a2b; --pfsr-text:#33414f; --pfsr-muted:#6a727f;
	--pfsr-line:rgba(20,38,70,.10); --pfsr-soft:#eef1f6; --pfsr-container:1500px;
	box-sizing:border-box; width:100%; background:#fff; color:var(--pfsr-text); font-family:inherit; padding:0 0 80px;
}
.dgs2-pfc-search *,
.dgs2-pfc-search *::before,
.dgs2-pfc-search *::after{ box-sizing:border-box; }
.dgs2-pfc-search :where(h1,h2){ margin:0; color:var(--pfsr-ink); }
.dgs2-pfc-search :where(p){ margin:0; }
.dgs2-pfc-search :where(a){ text-decoration:none; color:inherit; }
.pfsr__wrap{ max-width:var(--pfsr-container); margin:0 auto; padding:0 20px; }

.pfsr__hero{
	position:relative; overflow:hidden; text-align:center; padding:70px 0 62px; margin-bottom:48px; color:#fff;
	background:
		radial-gradient(90% 120% at 50% -30%, rgba(105,139,197,.34), rgba(105,139,197,0) 60%),
		linear-gradient(135deg,#1a2f52 0%,#142646 58%,#0f1f3a 100%);
}
.pfsr__eyebrow{ display:inline-block; font-size:13px; font-weight:800; letter-spacing:.18em; text-transform:uppercase; color:var(--pfsr-accent-2); }
.dgs2-pfc-search .pfsr__h1{ font-size:clamp(30px,4vw,50px); font-weight:800; letter-spacing:-.02em; color:#fff; margin:14px 0 0; line-height:1.1; }
.pfsr__h1 b{ color:#fff; }
.pfsr__form{ display:flex; max-width:560px; margin:26px auto 0; background:#fff; border-radius:999px; overflow:hidden; box-shadow:0 18px 44px rgba(0,0,0,.22); }
.pfsr__form input{ flex:1; min-width:0; border:0; outline:0; padding:0 22px; font-size:16px; color:var(--pfsr-ink); background:transparent; }
.pfsr__form button{ flex:0 0 auto; border:0; cursor:pointer; padding:16px 28px; font-size:15px; font-weight:800; color:#fff; background:var(--pfsr-accent); transition:filter .2s ease; }
.pfsr__form button:hover{ filter:brightness(1.05); }
.pfsr__count{ margin-top:18px; font-size:14px; font-weight:600; color:rgba(255,255,255,.8); }

.pfsr__group{ margin-bottom:34px; }
.pfsr__group-title{ font-size:18px; font-weight:800; color:var(--pfsr-ink); margin:0 0 14px; }
.pfsr__group-title b{ color:var(--pfsr-blue); }
.pfsr__grid{ display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:18px; }
.pfsr__card{
	position:relative; display:block; height:300px; overflow:hidden;
	border-radius:16px; border:1px solid var(--pfsr-line);
	background:var(--pfsr-soft) center/cover no-repeat;
	box-shadow:0 12px 30px rgba(20,38,70,.10);
	transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.pfsr__card:hover{ transform:translateY(-4px); box-shadow:0 26px 50px rgba(20,38,70,.18); border-color:var(--pfsr-blue-soft); }
.pfsr__card::after{ content:""; position:absolute; inset:0; background:linear-gradient(0deg, var(--pfsr-ink) 0%, rgba(20,38,70,.82) 32%, rgba(20,38,70,0) 100%); pointer-events:none; }
.pfsr__body{ position:absolute; left:16px; right:16px; bottom:14px; z-index:2; }
.pfsr__tag{ display:inline-block; font-size:11px; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:var(--pfsr-accent-2); margin-bottom:7px; text-shadow:0 1px 4px rgba(0,0,0,.5); }
.pfsr__title{ display:block; font-size:16.5px; font-weight:700; line-height:1.32; color:#fff; text-shadow:0 2px 10px rgba(0,0,0,.45); }

.pfsr__empty{ text-align:center; padding:20px 0 30px; }
.pfsr__empty-ic{ width:64px; height:64px; margin:0 auto 18px; border-radius:50%; display:grid; place-items:center; background:var(--pfsr-soft); }
.pfsr__empty-ic svg{ width:30px; height:30px; fill:none; stroke:var(--pfsr-blue); stroke-width:2; stroke-linecap:round; }
.pfsr__empty h2{ font-size:clamp(20px,2.2vw,26px); color:var(--pfsr-ink); }
.pfsr__empty p{ font-size:16px; color:var(--pfsr-muted); margin:10px auto 22px; max-width:460px; }
.pfsr__empty-btn{ display:inline-flex; align-items:center; gap:9px; padding:14px 30px; border-radius:999px; font-size:15px; font-weight:800; color:#fff; background:var(--pfsr-ink); transition:all .25s ease; }
.pfsr__empty-btn:hover{ background:var(--pfsr-accent); transform:translateY(-2px); }

.pfsr__pagination{ margin-top:48px; display:flex; justify-content:center; }
.pfsr__pagination .nav-links{ display:flex; flex-wrap:wrap; gap:8px; align-items:center; }
.pfsr__pagination .page-numbers{ display:inline-grid; place-items:center; min-width:44px; height:44px; padding:0 12px; border-radius:12px; border:1px solid var(--pfsr-line); font-weight:800; font-size:14px; color:var(--pfsr-ink); background:#fff; }
.pfsr__pagination .page-numbers.current{ background:var(--pfsr-ink); border-color:var(--pfsr-ink); color:#fff; }
.pfsr__pagination a.page-numbers:hover{ border-color:var(--pfsr-blue); color:var(--pfsr-blue); }

@media (max-width:1200px){ .pfsr__grid{ grid-template-columns:repeat(3,minmax(0,1fr)); } }
@media (max-width:992px){ .pfsr__grid{ grid-template-columns:repeat(2,minmax(0,1fr)); } }
@media (max-width:640px){ .pfsr__grid{ grid-template-columns:1fr; } .pfsr__hero{ padding:54px 0 52px; } .pfsr__card{ height:240px; } }
