:root {
	--th-ink: #101417;
	--th-ink-soft: #1a2227;
	--th-muted: #62706b;
	--th-paper: #f8faf7;
	--th-surface: #ffffff;
	--th-raised: #fbfdfb;
	--th-mist: #edf2ef;
	--th-line: #dce4df;
	--th-line-dark: #2b363c;
	--th-teal: #0f8f83;
	--th-teal-dark: #0b6f66;
	--th-blue: #315be8;
	--th-amber: #e4b649;
	--th-rose: #d9566b;
	--th-green-soft: #dff5ed;
	--th-blue-soft: #e8edff;
	--th-amber-soft: #fff5d9;
	--th-shadow-soft: 0 10px 28px rgba(16, 20, 23, 0.08);
	--th-shadow-strong: 0 22px 60px rgba(16, 20, 23, 0.18);
	--th-font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	--th-font-display: "Plus Jakarta Sans", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

html {
	scroll-behavior: smooth;
}

body {
	background: var(--th-paper);
	color: var(--th-ink);
	font-family: var(--th-font-body);
	letter-spacing: 0;
	text-rendering: optimizeLegibility;
}

body,
button,
input,
select,
textarea {
	font-family: var(--th-font-body);
}

::selection {
	background: var(--th-green-soft);
	color: var(--th-ink);
}

a {
	text-decoration-thickness: 1px;
	text-underline-offset: 0.18em;
}

.wp-site-blocks > header,
.site-header {
	position: relative;
	z-index: 40;
	border-bottom: 1px solid var(--th-line-dark);
	background: var(--th-ink);
}

.th-premium-header {
	margin: 0;
	padding: 16px 0;
	background: var(--th-ink);
	color: #ffffff;
}

.th-header-inner {
	display: flex;
	width: min(1160px, calc(100% - 40px));
	margin: 0 auto;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
}

.th-brand-lockup {
	gap: 10px;
}

.th-brand-lockup .wp-block-site-title {
	margin: 0;
}

.wp-site-blocks > header .wp-block-site-title a,
.wp-site-blocks > header .wp-block-navigation-item__content,
.site-header a {
	color: #ffffff;
	text-decoration: none;
}

.wp-site-blocks > header .wp-block-site-title a,
.th-brand-link {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	color: #ffffff;
	font-family: var(--th-font-display);
	font-size: 1.18rem;
	font-weight: 800;
	text-decoration: none;
}

.wp-site-blocks > header .wp-block-site-title a::before,
.th-brand-mark {
	display: inline-flex;
	width: 32px;
	height: 32px;
	align-items: center;
	justify-content: center;
	border-radius: 8px;
	background: #59e3d3;
	color: #07100f;
	content: "T";
	font-family: var(--th-font-display);
	font-size: 0.95rem;
	font-weight: 800;
}

.th-brand-mark {
	content: none;
}

.wp-block-navigation .wp-block-navigation-item__content {
	font-size: 0.94rem;
	font-weight: 700;
}

.wp-block-navigation .wp-block-navigation-item__content:hover,
.wp-block-navigation .wp-block-navigation-item__content:focus-visible {
	color: #59e3d3;
}

.th-header-menu {
	display: flex;
	flex: 1 1 auto;
	flex-wrap: wrap;
	gap: 6px;
	align-items: center;
	justify-content: center;
}

.th-header-menu a {
	display: inline-flex;
	min-height: 38px;
	align-items: center;
	padding: 8px 11px;
	border-radius: 8px;
	color: #d6e0dc;
	font-size: 0.94rem;
	font-weight: 750;
	text-decoration: none;
}

.th-header-menu a:hover,
.th-header-menu a:focus-visible {
	background: rgba(255, 255, 255, 0.08);
	color: #ffffff;
	outline: none;
}

.th-header-actions .wp-block-button__link,
.th-header-cta-link {
	display: inline-flex;
	min-height: 40px;
	align-items: center;
	justify-content: center;
	padding: 9px 14px;
	border: 1px solid #59e3d3;
	border-radius: 8px;
	background: #59e3d3;
	color: #07100f;
	font-size: 0.9rem;
	font-weight: 800;
	text-decoration: none;
}

.th-page-main {
	margin-top: 0;
}

.th-section {
	padding: 72px 0;
	text-align: center;
}

.th-wrap {
	width: min(1160px, calc(100% - 40px));
	margin: 0 auto;
}

.th-center {
	text-align: center;
	margin-right: auto;
	margin-left: auto;
}

.th-kicker {
	display: inline-flex;
	align-items: center;
	width: fit-content;
	min-height: 30px;
	margin: 0 0 14px;
	padding: 6px 10px;
	border: 1px solid rgba(15, 143, 131, 0.24);
	border-radius: 8px;
	background: rgba(223, 245, 237, 0.76);
	color: var(--th-teal-dark);
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0;
	line-height: 1;
	text-transform: uppercase;
}

.th-section-heading .th-kicker,
.th-hero .th-kicker,
.th-tool-heading .th-kicker {
	margin-right: auto;
	margin-left: auto;
}

.th-section-heading {
	max-width: 760px;
	margin: 0 auto 34px;
	text-align: center;
}

.th-section-heading h1,
.th-section-heading h2,
.th-hero-copy h1,
.th-tool-heading h1,
.th-article-header h1 {
	margin-top: 0;
	color: var(--th-ink);
	font-family: var(--th-font-display);
	font-weight: 800;
	letter-spacing: 0;
	line-height: 1.04;
}

.th-section-heading h1,
.th-hero-copy h1 {
	font-size: 3.7rem;
}

.th-section-heading h2 {
	font-size: 2.25rem;
}

.th-section-heading p,
.th-hero-copy p,
.th-tool-heading p,
.th-tool-content p,
.th-split p,
.th-contact-layout p {
	color: var(--th-muted);
	font-size: 1.03rem;
	line-height: 1.75;
}

.th-hero {
	position: relative;
	overflow: hidden;
	min-height: 720px;
	padding: 74px 0 64px;
	border-bottom: 1px solid var(--th-line);
	background: var(--th-ink);
	color: #ffffff;
}

.th-hero-stage {
	position: relative;
	display: grid;
	gap: 38px;
	justify-items: center;
}

.th-hero .th-kicker {
	border-color: rgba(255, 255, 255, 0.18);
	background: rgba(255, 255, 255, 0.08);
	color: #b8fff1;
}

.th-hero-copy {
	max-width: 900px;
	text-align: center;
}

.th-hero-copy h1 {
	max-width: 900px;
	margin-right: auto;
	margin-left: auto;
	margin-bottom: 18px;
	color: #ffffff;
	font-size: 4.2rem;
}

.th-hero-copy > p {
	max-width: 760px;
	margin-right: auto;
	margin-left: auto;
	color: #c9d6d1;
	font-size: 1.14rem;
}

.th-actions,
.th-tool-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	align-items: center;
	justify-content: center;
	margin-top: 22px;
}

.th-button,
.th-button:visited,
button.th-button {
	display: inline-flex;
	min-height: 46px;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 11px 18px;
	border: 1px solid var(--th-line);
	border-radius: 8px;
	background: var(--th-surface);
	color: var(--th-ink);
	font-size: 0.95rem;
	font-weight: 800;
	line-height: 1.1;
	text-decoration: none;
	cursor: pointer;
	transition: background 160ms ease, border-color 160ms ease, color 160ms ease, transform 160ms ease, box-shadow 160ms ease;
}

.th-button:hover,
button.th-button:hover {
	transform: translateY(-1px);
	border-color: var(--th-teal);
	color: var(--th-teal-dark);
	box-shadow: var(--th-shadow-soft);
}

.th-button:focus-visible,
button.th-button:focus-visible,
.th-tool-card:focus-visible,
.th-related-card:focus-visible,
.th-sitemap-list a:focus-visible,
.th-read-more:focus-visible {
	outline: 3px solid rgba(49, 91, 232, 0.22);
	outline-offset: 3px;
}

.th-button-primary,
.th-button-primary:visited,
button.th-button-primary {
	border-color: #59e3d3;
	background: #59e3d3;
	color: #07100f;
	box-shadow: 0 14px 34px rgba(89, 227, 211, 0.24);
}

.th-button-primary:hover,
button.th-button-primary:hover {
	background: #7cf1e4;
	color: #07100f;
}

.th-button-secondary {
	border-color: rgba(16, 20, 23, 0.1);
	background: var(--th-mist);
}

.th-hero .th-button-secondary {
	border-color: rgba(255, 255, 255, 0.22);
	background: rgba(255, 255, 255, 0.08);
	color: #ffffff;
}

.th-hero .th-button-secondary:hover {
	background: rgba(255, 255, 255, 0.14);
	color: #ffffff;
}

.th-workbench {
	width: 100%;
	max-width: 980px;
	overflow: hidden;
	border: 1px solid rgba(255, 255, 255, 0.13);
	border-radius: 8px;
	background: #121a1f;
	box-shadow: var(--th-shadow-strong);
}

.th-workbench-top {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	align-items: center;
	justify-content: space-between;
	padding: 14px 16px;
	border-bottom: 1px solid var(--th-line-dark);
	background: #172229;
}

.th-workbench-top span {
	color: #c9d6d1;
	font-weight: 700;
}

.th-workbench-top strong {
	color: #ffffff;
	font-family: var(--th-font-display);
	font-size: 1rem;
}

.th-workbench-grid {
	display: grid;
	grid-template-columns: minmax(0, 1.35fr) minmax(250px, 0.65fr);
	gap: 1px;
	background: var(--th-line-dark);
}

.th-workbench-main,
.th-workbench-side {
	background: #10171c;
}

.th-workbench-main {
	min-height: 300px;
	padding: 28px;
}

.th-workbench-main > span,
.th-workbench-side span {
	color: #93a29c;
	font-size: 0.88rem;
	font-weight: 700;
}

.th-workbench-main p {
	max-width: 560px;
	margin: 10px 0 24px;
	color: #eef7f3;
	font-family: var(--th-font-display);
	font-size: 1.8rem;
	font-weight: 800;
	line-height: 1.22;
}

.th-workbench-lines {
	display: grid;
	gap: 10px;
	max-width: 620px;
}

.th-workbench-lines i {
	display: block;
	height: 14px;
	border-radius: 8px;
	background: #26333a;
}

.th-workbench-lines i:nth-child(1) {
	width: 92%;
	background: #27443f;
}

.th-workbench-lines i:nth-child(2) {
	width: 78%;
}

.th-workbench-lines i:nth-child(3) {
	width: 54%;
	background: #23305a;
}

.th-workbench-side {
	display: grid;
	gap: 1px;
	background: var(--th-line-dark);
}

.th-workbench-side div {
	padding: 22px;
	background: #121a1f;
}

.th-workbench-side strong {
	display: block;
	margin-bottom: 4px;
	color: #ffffff;
	font-family: var(--th-font-display);
	font-size: 1.25rem;
}

.th-workbench-tools {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	padding: 14px;
	border-top: 1px solid var(--th-line-dark);
	background: #172229;
}

.th-workbench-tools a {
	display: inline-flex;
	min-height: 34px;
	align-items: center;
	padding: 7px 10px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.06);
	color: #e8f2ee;
	font-size: 0.88rem;
	font-weight: 700;
	text-decoration: none;
}

.th-card-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
	max-width: 1060px;
	margin: 0 auto;
}

.th-card-grid-wide {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.th-tool-card,
.th-tool-card:visited {
	position: relative;
	display: grid;
	min-height: 202px;
	align-content: start;
	justify-items: center;
	gap: 13px;
	padding: 20px;
	border: 1px solid var(--th-line);
	border-radius: 8px;
	background: var(--th-surface);
	color: var(--th-ink);
	text-align: center;
	text-decoration: none;
	box-shadow: 0 8px 22px rgba(16, 20, 23, 0.05);
	transition: transform 160ms ease, border-color 160ms ease, box-shadow 160ms ease;
}

.th-tool-card::after {
	position: absolute;
	right: 18px;
	bottom: 16px;
	width: 28px;
	height: 28px;
	border: 1px solid var(--th-line);
	border-radius: 50%;
	background: #ffffff;
	color: var(--th-teal-dark);
	content: ">";
	font-size: 1.2rem;
	font-weight: 800;
	line-height: 24px;
	text-align: center;
}

.th-tool-card:hover {
	transform: translateY(-3px);
	border-color: rgba(15, 143, 131, 0.55);
	box-shadow: var(--th-shadow-soft);
}

.th-tool-card-icon {
	display: inline-flex;
	width: 48px;
	height: 48px;
	align-items: center;
	justify-content: center;
	border-radius: 8px;
	background: var(--th-ink);
	color: #ffffff;
	font-family: var(--th-font-display);
	font-size: 0.84rem;
	font-weight: 800;
	letter-spacing: 0;
}

.th-tool-card:nth-child(3n + 2) .th-tool-card-icon {
	background: var(--th-blue);
}

.th-tool-card:nth-child(3n) .th-tool-card-icon {
	background: var(--th-rose);
}

.th-tool-card strong {
	font-family: var(--th-font-display);
	font-size: 1.12rem;
	line-height: 1.28;
}

.th-tool-card span:last-child {
	color: var(--th-muted);
	line-height: 1.6;
}

.th-band {
	border-top: 1px solid var(--th-line);
	border-bottom: 1px solid var(--th-line);
	background: #ffffff;
}

.th-split {
	display: grid;
	grid-template-columns: minmax(240px, 0.82fr) minmax(0, 1.18fr);
	gap: 42px;
	align-items: start;
	max-width: 980px;
	text-align: center;
}

.th-split h2 {
	margin: 0;
	font-family: var(--th-font-display);
	font-size: 2.25rem;
	line-height: 1.08;
}

.th-breadcrumb {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	justify-content: center;
	margin-bottom: 20px;
	color: var(--th-muted);
	font-size: 0.92rem;
	font-weight: 650;
}

.th-breadcrumb a {
	color: var(--th-teal-dark);
	text-decoration: none;
}

.th-tool-shell {
	max-width: 980px;
	margin: 0 auto;
	padding: 24px;
	border: 1px solid var(--th-line);
	border-radius: 8px;
	background: #ffffff;
	box-shadow: var(--th-shadow-soft);
}

.th-tool-heading {
	display: grid;
	grid-template-columns: 1fr;
	gap: 16px;
	align-items: start;
	justify-items: center;
	margin-bottom: 22px;
	text-align: center;
}

.th-tool-heading h1 {
	margin-bottom: 8px;
	font-size: 2.75rem;
}

.th-tool-heading p:last-child {
	margin-bottom: 0;
}

.th-tool-panel {
	display: grid;
	gap: 16px;
	text-align: left;
}

.th-field {
	display: grid;
	gap: 8px;
	font-weight: 750;
}

.th-field span,
.th-result-list span {
	color: var(--th-ink);
	font-size: 0.94rem;
}

.th-input,
.th-textarea,
.th-result-list input {
	width: 100%;
	box-sizing: border-box;
	border: 1px solid var(--th-line);
	border-radius: 8px;
	background: #ffffff;
	color: var(--th-ink);
	font: inherit;
	letter-spacing: 0;
	text-align: left;
	transition: border-color 150ms ease, box-shadow 150ms ease, background 150ms ease;
}

.th-input,
.th-result-list input {
	min-height: 48px;
	padding: 11px 13px;
}

.th-textarea {
	min-height: 164px;
	padding: 13px;
	resize: vertical;
}

.th-output,
.th-input[readonly],
.th-textarea[readonly] {
	background: #f7faf8;
}

.th-input:focus,
.th-textarea:focus {
	border-color: var(--th-blue);
	outline: none;
	box-shadow: 0 0 0 4px rgba(49, 91, 232, 0.12);
}

.th-stat-grid {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 10px;
}

.th-stat-grid div {
	min-height: 90px;
	padding: 15px;
	border: 1px solid var(--th-line);
	border-radius: 8px;
	background: var(--th-raised);
}

.th-stat-grid strong {
	display: block;
	font-family: var(--th-font-display);
	font-size: 1.5rem;
	line-height: 1.2;
}

.th-stat-grid span {
	display: block;
	margin-top: 5px;
	color: var(--th-muted);
	font-size: 0.9rem;
	font-weight: 650;
}

.th-sticky-actions {
	position: relative;
	z-index: 5;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: center;
	margin-top: 18px;
	padding: 10px;
	border: 1px solid var(--th-line);
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.96);
	box-shadow: var(--th-shadow-soft);
	backdrop-filter: blur(10px);
}

.th-icon-action {
	min-height: 40px;
	padding: 8px 12px;
	border: 1px solid var(--th-line);
	border-radius: 8px;
	background: var(--th-mist);
	color: var(--th-ink);
	font: inherit;
	font-weight: 800;
	cursor: pointer;
}

.th-icon-action:hover,
.th-icon-action:focus-visible {
	border-color: var(--th-blue);
	outline: 3px solid rgba(49, 91, 232, 0.14);
}

.th-action-feedback {
	min-height: 22px;
	margin-left: auto;
	color: var(--th-teal-dark);
	font-weight: 800;
	opacity: 0;
	transform: translateY(4px);
	transition: opacity 180ms ease, transform 180ms ease;
}

.th-action-feedback.is-visible {
	opacity: 1;
	transform: translateY(0);
}

.th-empty-state {
	display: none;
	margin: 12px 0 0;
	padding: 12px 14px;
	border: 1px dashed var(--th-line);
	border-radius: 8px;
	background: var(--th-amber-soft);
	color: #785d13;
	font-weight: 750;
}

.th-empty-state.is-visible {
	display: block;
}

.th-option-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 10px;
}

.th-option-grid label {
	display: flex;
	min-height: 46px;
	align-items: center;
	gap: 8px;
	padding: 10px;
	border: 1px solid var(--th-line);
	border-radius: 8px;
	background: var(--th-raised);
	font-weight: 700;
}

.th-two-col,
.th-result-list {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px;
}

.th-result-list label {
	display: grid;
	gap: 8px;
	font-weight: 750;
}

.th-status {
	min-height: 22px;
	margin: 0;
	color: var(--th-muted);
	font-weight: 750;
}

.th-status.is-error {
	color: #a33222;
}

.th-status.is-success {
	color: var(--th-teal-dark);
}

.th-color-layout {
	display: grid;
	grid-template-columns: 160px minmax(0, 1fr) 120px;
	gap: 14px;
	align-items: end;
}

.th-color-layout input[type="color"] {
	width: 100%;
	min-height: 48px;
	padding: 4px;
	border: 1px solid var(--th-line);
	border-radius: 8px;
	background: #ffffff;
}

.th-color-swatch {
	min-height: 82px;
	border: 1px solid var(--th-line);
	border-radius: 8px;
	background: var(--th-teal);
}

.th-search-preview {
	padding: 18px;
	border: 1px solid var(--th-line);
	border-radius: 8px;
	background: #ffffff;
	font-family: Arial, sans-serif;
}

.th-search-preview div {
	color: #1a0dab;
	font-size: 1.15rem;
	line-height: 1.3;
}

.th-search-preview cite {
	display: block;
	margin-top: 4px;
	color: #006621;
	font-style: normal;
	word-break: break-word;
}

.th-search-preview p {
	margin: 6px 0 0;
	color: #4d5156;
	line-height: 1.45;
}

.th-tool-content {
	display: grid;
	gap: 24px;
	max-width: 900px;
	margin: 38px auto 0;
}

.th-tool-content section {
	padding: 24px;
	border: 1px solid var(--th-line);
	border-radius: 8px;
	background: #ffffff;
	box-shadow: 0 8px 22px rgba(16, 20, 23, 0.04);
	text-align: center;
}

.th-tool-content h2 {
	margin-top: 0;
	font-family: var(--th-font-display);
	font-size: 1.45rem;
}

.th-tool-content ol {
	display: inline-block;
	padding-left: 1.4rem;
	color: var(--th-muted);
	line-height: 1.75;
	text-align: left;
}

.th-prose {
	max-width: 760px;
	margin-right: auto;
	margin-left: auto;
	text-align: left;
}

.th-prose p {
	margin: 0 0 14px;
}

.th-prose p:last-child {
	margin-bottom: 0;
}

.th-check-list,
.th-linked-list {
	display: grid;
	gap: 10px;
	max-width: 680px;
	margin-right: auto;
	margin-left: auto;
	padding-left: 0;
	list-style: none;
	text-align: left;
}

.th-check-list li,
.th-linked-list li {
	position: relative;
	padding-left: 28px;
	color: var(--th-muted);
	line-height: 1.65;
}

.th-check-list li::before,
.th-linked-list li::before {
	position: absolute;
	left: 0;
	top: 0.1em;
	width: 20px;
	height: 20px;
	border-radius: 50%;
	background: var(--th-green-soft);
	content: "";
}

.th-check-list li::after,
.th-linked-list li::after {
	position: absolute;
	left: 6px;
	top: 0.32em;
	width: 7px;
	height: 11px;
	border: solid var(--th-teal-dark);
	border-width: 0 2px 2px 0;
	content: "";
	transform: rotate(45deg);
}

.th-warning-list li::before {
	background: var(--th-amber-soft);
}

.th-warning-list li::after {
	border-color: #8a640e;
}

.th-workflow-list {
	max-width: 720px;
	margin-right: auto;
	margin-left: auto;
}

.th-workflow-list li {
	margin-bottom: 8px;
}

.th-audience-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
	max-width: 760px;
	margin: 0 auto;
}

.th-audience-item {
	padding: 14px;
	border: 1px solid var(--th-line);
	border-radius: 8px;
	background: var(--th-raised);
	color: var(--th-muted);
	font-weight: 650;
	line-height: 1.55;
}

.th-example-list {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
	max-width: 720px;
	margin: 0 auto;
}

.th-example-item {
	display: grid;
	gap: 6px;
	padding: 14px;
	border: 1px solid var(--th-line);
	border-radius: 8px;
	background: var(--th-raised);
}

.th-example-item span {
	color: var(--th-muted);
	line-height: 1.55;
}

.th-seo-copy p {
	max-width: 760px;
	margin-right: auto;
	margin-left: auto;
}

.th-note-box {
	max-width: 720px;
	margin: 18px auto 0;
	padding: 12px 14px;
	border: 1px solid rgba(15, 143, 131, 0.18);
	border-radius: 8px;
	background: var(--th-green-soft);
	color: #24433d;
	font-size: 0.94rem;
	font-weight: 650;
}

.th-related-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 12px;
	max-width: 820px;
	margin: 0 auto;
}

.th-related-card,
.th-related-card:visited {
	display: grid;
	gap: 10px;
	align-content: start;
	justify-items: center;
	min-height: 158px;
	padding: 15px;
	border: 1px solid var(--th-line);
	border-radius: 8px;
	background: var(--th-raised);
	color: var(--th-ink);
	text-align: center;
	text-decoration: none;
	transition: border-color 160ms ease, transform 160ms ease, box-shadow 160ms ease;
}

.th-related-card:hover {
	transform: translateY(-1px);
	border-color: var(--th-teal);
	box-shadow: var(--th-shadow-soft);
}

.th-related-card small {
	color: var(--th-muted);
	font-size: 0.9rem;
	line-height: 1.45;
}

.th-faq-list {
	display: grid;
	gap: 10px;
}

.th-faq-item {
	border: 1px solid var(--th-line);
	border-radius: 8px;
	background: var(--th-raised);
}

.th-faq-item summary {
	padding: 14px 16px;
	font-weight: 800;
	cursor: pointer;
}

.th-faq-item p {
	margin: 0;
	padding: 0 16px 16px;
}

.th-article-tool-links {
	margin-top: 34px;
	padding: 20px;
	border: 1px solid var(--th-line);
	border-radius: 8px;
	background: #ffffff;
	box-shadow: var(--th-shadow-soft);
}

.th-article-tool-links h2 {
	margin-top: 0;
	font-family: var(--th-font-display);
}

.th-contact-layout {
	display: grid;
	grid-template-columns: minmax(240px, 0.8fr) minmax(280px, 1fr);
	gap: 34px;
	align-items: start;
}

.th-contact-form {
	display: grid;
	gap: 14px;
	padding: 22px;
	border: 1px solid var(--th-line);
	border-radius: 8px;
	background: var(--th-surface);
	box-shadow: var(--th-shadow-soft);
	text-align: left;
}

.th-hp {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

.th-alert {
	padding: 12px 14px;
	border-radius: 8px;
	font-weight: 800;
}

.th-alert-success {
	border: 1px solid #9ac8a7;
	background: #eef8f0;
	color: #17633b;
}

.th-alert-error {
	border: 1px solid #e4a69b;
	background: #fff1ee;
	color: #9a2f20;
}

.th-sitemap-list {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px 18px;
	padding-left: 0;
	list-style: none;
}

.th-sitemap-list a {
	display: block;
	padding: 13px 15px;
	border: 1px solid var(--th-line);
	border-radius: 8px;
	background: #ffffff;
	color: var(--th-ink);
	font-weight: 700;
	text-decoration: none;
	box-shadow: 0 6px 18px rgba(16, 20, 23, 0.04);
}

.th-premium-footer {
	position: relative;
	padding: 38px 0 18px;
	border-top: 1px solid var(--th-line-dark);
	background: var(--th-ink);
	color: #d6e0dc;
	text-align: center;
}

.th-premium-footer::before {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 3px;
	background: #59e3d3;
	content: "";
}

.th-premium-footer > * {
	width: min(1160px, calc(100% - 40px));
	margin-right: auto;
	margin-left: auto;
}

.th-premium-footer .wp-block-site-title {
	margin-top: 0;
	margin-bottom: 12px;
}

.th-premium-footer .wp-block-site-title a,
.th-footer-brand-link {
	justify-content: flex-start;
	color: #ffffff;
	font-family: var(--th-font-display);
	font-size: 1.02rem;
	font-weight: 800;
	text-decoration: none;
}

.th-premium-footer .th-brand-mark {
	width: 26px;
	height: 26px;
	font-size: 0.78rem;
}

.th-premium-footer p {
	color: #aebbb5;
	font-size: 0.88rem;
	line-height: 1.58;
}

.th-premium-footer h3 {
	margin: 0 0 10px;
	color: #ffffff;
	font-family: var(--th-font-display);
	font-size: 0.82rem;
	font-weight: 800;
	text-transform: uppercase;
}

.th-footer-grid {
	display: grid;
	grid-template-columns: minmax(260px, 1.35fr) repeat(3, minmax(150px, 0.7fr));
	gap: 26px;
	align-items: start;
	margin-bottom: 22px;
	text-align: left;
}

.th-footer-brand p {
	max-width: 360px;
	margin-top: 10px;
}

.th-footer-nav,
.th-footer-links {
	display: grid;
	gap: 7px;
	margin: 0;
	padding-left: 0;
	list-style: none;
}

.th-footer-nav a,
.th-footer-links a {
	color: #d6e0dc;
	font-size: 0.86rem;
	font-weight: 600;
	text-decoration: none;
}

.th-footer-nav a:hover,
.th-footer-links a:hover {
	color: #59e3d3;
}

.th-footer-bottom {
	margin-bottom: 0;
	padding-top: 14px;
	border-top: 1px solid var(--th-line-dark);
	font-size: 0.8rem;
}

.th-post-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}

.th-post-card {
	overflow: hidden;
	border: 1px solid var(--th-line);
	border-radius: 8px;
	background: #ffffff;
	box-shadow: 0 8px 22px rgba(16, 20, 23, 0.05);
	transition: transform 160ms ease, box-shadow 160ms ease;
}

.th-post-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--th-shadow-soft);
}

.th-post-card-image {
	display: block;
	aspect-ratio: 16 / 9;
	background: var(--th-mist);
}

.th-post-card-image img,
.th-featured-image img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.th-post-card-body {
	display: grid;
	gap: 10px;
	padding: 18px;
}

.th-post-card h2 {
	margin: 0;
	font-family: var(--th-font-display);
	font-size: 1.18rem;
	line-height: 1.3;
}

.th-post-card h2 a,
.th-read-more {
	color: var(--th-ink);
	text-decoration: none;
}

.th-post-card p {
	margin: 0;
	color: var(--th-muted);
	line-height: 1.65;
}

.th-post-meta {
	font-size: 0.82rem;
	font-weight: 800;
	text-transform: uppercase;
}

.th-read-more {
	font-weight: 850;
	color: var(--th-teal-dark);
}

.th-pagination {
	margin-top: 30px;
}

.th-article-header {
	padding: 64px 0 36px;
	border-bottom: 1px solid var(--th-line);
	background: #ffffff;
}

.th-article-header h1 {
	max-width: 900px;
	margin: 0;
	font-size: 3.3rem;
}

.th-article-header p:last-child {
	max-width: 760px;
	color: var(--th-muted);
	font-size: 1.08rem;
	line-height: 1.7;
}

.th-featured-image {
	margin-top: 30px;
}

.th-featured-image img {
	max-height: 480px;
	border-radius: 8px;
}

.th-article-content {
	max-width: 820px;
	padding-top: 36px;
	padding-bottom: 56px;
}

.th-article-content p,
.th-article-content li {
	line-height: 1.78;
}

.th-article-content h2,
.th-article-content h3 {
	margin-top: 1.7em;
	font-family: var(--th-font-display);
}

.th-article-footer {
	margin-top: 34px;
	padding-top: 24px;
	border-top: 1px solid var(--th-line);
}

@media (max-width: 980px) {
	.th-hero-copy h1,
	.th-section-heading h1 {
		font-size: 3.05rem;
	}

	.th-workbench-grid,
	.th-split,
	.th-contact-layout {
		grid-template-columns: 1fr;
	}

	.th-card-grid,
	.th-card-grid-wide,
	.th-post-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.th-stat-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.th-option-grid,
	.th-color-layout,
	.th-example-list,
	.th-audience-grid,
	.th-related-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.th-header-inner {
		gap: 12px;
	}

	.th-header-menu {
		order: 3;
		flex-basis: 100%;
	}

	.th-header-actions {
		display: none;
	}

	.th-header-cta-link {
		display: none;
	}

	.th-footer-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 680px) {
	.th-section {
		padding: 44px 0;
	}

	.th-wrap {
		width: min(100% - 24px, 1160px);
	}

	.th-header-inner,
	.th-premium-footer > * {
		width: min(100% - 24px, 1160px);
	}

	.th-header-inner {
		justify-content: center;
		text-align: center;
	}

	.th-brand-link {
		width: 100%;
		justify-content: center;
	}

	.th-header-menu {
		justify-content: center;
	}

	.th-header-menu a {
		min-height: 34px;
		padding: 7px 9px;
		font-size: 0.88rem;
	}

	.th-footer-grid {
		grid-template-columns: 1fr;
		text-align: center;
	}

	.th-footer-brand p {
		margin-right: auto;
		margin-left: auto;
	}

	.th-hero {
		min-height: 0;
		padding: 50px 0 42px;
	}

	.th-hero-copy h1,
	.th-section-heading h1,
	.th-article-header h1 {
		font-size: 2.35rem;
	}

	.th-section-heading h2,
	.th-split h2 {
		font-size: 1.8rem;
	}

	.th-hero-copy > p {
		font-size: 1rem;
	}

	.th-card-grid,
	.th-card-grid-wide,
	.th-post-grid,
	.th-two-col,
	.th-result-list,
	.th-sitemap-list,
	.th-option-grid,
	.th-color-layout,
	.th-example-list,
	.th-audience-grid,
	.th-related-grid {
		grid-template-columns: 1fr;
	}

	.th-tool-shell,
	.th-contact-form,
	.th-tool-content section {
		padding: 16px;
	}

	.th-tool-heading {
		grid-template-columns: 1fr;
	}

	.th-tool-heading h1 {
		font-size: 2.1rem;
	}

	.th-stat-grid {
		grid-template-columns: 1fr;
	}

	.th-actions,
	.th-tool-actions {
		align-items: stretch;
	}

	.th-button,
	button.th-button {
		width: 100%;
	}

	.th-sticky-actions {
		bottom: 8px;
	}

	.th-icon-action {
		flex: 1 1 30%;
	}

	.th-action-feedback {
		flex-basis: 100%;
		margin-left: 0;
	}

	.th-workbench-main {
		min-height: 220px;
		padding: 20px;
	}

	.th-workbench-main p {
		font-size: 1.35rem;
	}
}
