/* =============================================================
   TopTier — Sections
   Styles for full-width reusable page sections.
   ============================================================= */

/* ===== Hero (generic) ===== */
.tt-hero {
	position: relative;
	padding: clamp(80px, 10vw, 160px) 0 clamp(60px, 8vw, 120px);
	overflow: hidden;
}
.tt-hero__grid {
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	gap: var(--tt-space-7);
	align-items: center;
}
.tt-hero__title {
	font-size: clamp(2rem, 5vw + 0.5rem, 5rem);
	line-height: 1.05;
	margin-bottom: var(--tt-space-5);
	word-wrap: break-word;
	overflow-wrap: break-word;
	hyphens: auto;
}
.tt-hero__title em {
	font-style: italic;
	font-weight: 400;
	color: var(--tt-blue-600);
}
.tt-hero__sub {
	font-size: var(--tt-fs-md);
	color: var(--tt-ink-500);
	max-width: 50ch;
	margin-bottom: var(--tt-space-6);
}
.tt-hero__actions { display: flex; gap: 12px; flex-wrap: wrap; }
.tt-hero__visual {
	position: relative;
	aspect-ratio: 4/5;
	border-radius: var(--tt-r-xl);
	overflow: hidden;
	background: linear-gradient(135deg, var(--tt-blue-50) 0%, var(--tt-ink-50) 100%);
	box-shadow: var(--tt-shadow-xl);
}
.tt-hero__visual img { width: 100%; height: 100%; object-fit: cover; }

/* Decorative grid background used on hero */
.tt-hero--grid-bg::before {
	content: '';
	position: absolute; inset: 0;
	background-image:
		linear-gradient(to right, rgba(10, 22, 40, 0.04) 1px, transparent 1px),
		linear-gradient(to bottom, rgba(10, 22, 40, 0.04) 1px, transparent 1px);
	background-size: 48px 48px;
	mask-image: radial-gradient(ellipse at 50% 20%, black 40%, transparent 80%);
	-webkit-mask-image: radial-gradient(ellipse at 50% 20%, black 40%, transparent 80%);
	pointer-events: none;
	z-index: -1;
}

/* Hero — dark variant used by Blog */
.tt-hero--dark {
	background: radial-gradient(ellipse at top, #1a2a4a 0%, var(--tt-ink-900) 65%);
	color: #fff;
}
.tt-hero--dark .tt-hero__title { color: #fff; }
.tt-hero--dark .tt-hero__sub   { color: var(--tt-ink-200); }
.tt-hero--dark .tt-eyebrow     { color: var(--tt-blue-300); }
.tt-hero--dark::before {
	content: '';
	position: absolute; inset: 0;
	background-image:
		linear-gradient(to right, rgba(255,255,255,0.03) 1px, transparent 1px),
		linear-gradient(to bottom, rgba(255,255,255,0.03) 1px, transparent 1px);
	background-size: 48px 48px;
	pointer-events: none;
}

/* Centered hero variant */
.tt-hero--center { text-align: center; }
.tt-hero--center .tt-hero__sub { margin-left: auto; margin-right: auto; }
.tt-hero--center .tt-hero__actions { justify-content: center; }

@media (min-width: 1025px) {
	body.home .tt-hero--home {
		padding-top: clamp(40px, 5vw, 80px);
	}
}

@media (max-width: 900px) {
	.tt-hero__grid { grid-template-columns: 1fr; }
	.tt-hero__visual {
		max-width: 100%;
		margin: 0 auto;
		aspect-ratio: 1/1;
	}
}
@media (max-width: 560px) {
	.tt-hero {
		padding: 48px 0 40px;
	}
	.tt-hero__visual {
		aspect-ratio: 4/3;
	}
}

/* ===== Trust logo strip ===== */
.tt-logos {
	padding: var(--tt-space-7) 0;
	border-top: var(--tt-border);
	border-bottom: var(--tt-border);
}
.tt-logos__label {
	text-align: center;
	font-size: var(--tt-fs-xs);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--tt-ink-500);
	margin-bottom: var(--tt-space-5);
}
.tt-logos__grid {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: var(--tt-space-6);
	align-items: center;
}
.tt-logos__item {
	display: flex; align-items: center; justify-content: center;
	min-height: 40px;
	opacity: 0.6;
	transition: opacity var(--tt-t-fast) var(--tt-ease);
	font-family: var(--tt-font-display);
	font-weight: 500;
	font-size: var(--tt-fs-md);
	color: var(--tt-ink-500);
	letter-spacing: -0.01em;
}
.tt-logos__item:hover { opacity: 1; color: var(--tt-ink-900); }
.tt-section--dark .tt-logos__item { color: var(--tt-ink-300); }

@media (max-width: 900px) {
	.tt-logos__grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 480px) {
	.tt-logos__grid { grid-template-columns: repeat(2, 1fr); gap: var(--tt-space-4); }
}

/* ===== Feature grid ===== */
.tt-features__head {
	max-width: 720px;
	margin: 0 auto var(--tt-space-7);
	text-align: center;
}
.tt-features__head--left { margin-left: 0; text-align: left; }
.tt-features__head h2 { margin-bottom: var(--tt-space-4); }
.tt-features__head p  { font-size: var(--tt-fs-md); color: var(--tt-ink-500); }

/* ===== Process timeline ===== */
.tt-process {
	position: relative;
}
.tt-process__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--tt-space-5);
	position: relative;
}
.tt-process__grid::before {
	content: '';
	position: absolute;
	top: 28px;
	left: 6%;
	right: 6%;
	height: 1px;
	background: linear-gradient(to right, transparent, var(--tt-ink-200) 10%, var(--tt-ink-200) 90%, transparent);
	z-index: 0;
}
.tt-process__step { position: relative; z-index: 1; }
.tt-process__num {
	width: 56px; height: 56px;
	border-radius: 50%;
	display: grid; place-items: center;
	background: #fff;
	border: 1.5px solid var(--tt-ink-100);
	font-family: var(--tt-font-display);
	font-weight: 500;
	font-size: var(--tt-fs-lg);
	color: var(--tt-ink-900);
	margin-bottom: var(--tt-space-4);
	position: relative;
	transition: all var(--tt-t-med) var(--tt-ease);
}
.tt-process__step:hover .tt-process__num {
	background: var(--tt-blue-500);
	border-color: var(--tt-blue-500);
	color: #fff;
	box-shadow: 0 8px 20px rgba(30,94,255,0.25);
}
.tt-process__title {
	font-family: var(--tt-font-display);
	font-weight: 500;
	font-size: var(--tt-fs-lg);
	color: var(--tt-ink-900);
	margin-bottom: 8px;
	line-height: 1.3;
}
.tt-process__desc { font-size: var(--tt-fs-sm); color: var(--tt-ink-500); line-height: 1.6; }
.tt-section--dark .tt-process__num { background: var(--tt-ink-800); border-color: var(--tt-ink-700); color: #fff; }
.tt-section--dark .tt-process__title { color: #fff; }
.tt-section--dark .tt-process__grid::before { background: linear-gradient(to right, transparent, rgba(255,255,255,0.15) 10%, rgba(255,255,255,0.15) 90%, transparent); }

@media (max-width: 900px) {
	.tt-process__grid { grid-template-columns: 1fr 1fr; }
	.tt-process__grid::before { display: none; }
}
@media (max-width: 560px) {
	.tt-process__grid { grid-template-columns: 1fr; }
}

/* ===== Stats block ===== */
.tt-stats {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0;
	border: var(--tt-border);
	border-radius: var(--tt-r-lg);
	overflow: hidden;
	background: #fff;
}
.tt-stats__item {
	padding: var(--tt-space-6) var(--tt-space-5);
	border-right: var(--tt-border);
	text-align: left;
}
.tt-stats__item:last-child { border-right: 0; }
.tt-stats__num {
	font-family: var(--tt-font-display);
	font-weight: 500;
	font-size: clamp(2.25rem, 4vw, 3.5rem);
	line-height: 1;
	letter-spacing: -0.02em;
	color: var(--tt-ink-900);
	margin-bottom: 12px;
}
.tt-stats__num sup { font-size: 0.4em; color: var(--tt-blue-500); vertical-align: super; margin-left: 4px; }
.tt-stats__label { font-size: var(--tt-fs-sm); color: var(--tt-ink-500); line-height: 1.5; }
.tt-section--dark .tt-stats {
	background: transparent;
	border-color: rgba(255,255,255,0.1);
}
.tt-section--dark .tt-stats__item { border-color: rgba(255,255,255,0.08); }
.tt-section--dark .tt-stats__num { color: #fff; }

@media (max-width: 900px) {
	.tt-stats { grid-template-columns: 1fr 1fr; }
	.tt-stats__item:nth-child(2n) { border-right: 0; }
	.tt-stats__item:nth-child(1), .tt-stats__item:nth-child(2) { border-bottom: var(--tt-border); }
}
@media (max-width: 560px) {
	.tt-stats { grid-template-columns: 1fr; }
	.tt-stats__item { border-right: 0; border-bottom: var(--tt-border); }
	.tt-stats__item:last-child { border-bottom: 0; }
}

/* ===== Content+Image section ===== */
.tt-content-image {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--tt-space-8);
	align-items: center;
}
.tt-content-image--reversed { direction: rtl; }
.tt-content-image--reversed > * { direction: ltr; }
.tt-content-image__media {
	border-radius: var(--tt-r-xl);
	overflow: hidden;
	aspect-ratio: 5/4;
	background: var(--tt-ink-50);
	box-shadow: var(--tt-shadow-lg);
}
.tt-content-image__media img { width: 100%; height: 100%; object-fit: cover; }
.tt-content-image__body h2 { margin-bottom: var(--tt-space-4); }
.tt-content-image__body p  { color: var(--tt-ink-500); font-size: var(--tt-fs-md); margin-bottom: var(--tt-space-4); }
.tt-content-image__list {
	margin-top: var(--tt-space-5);
}
.tt-content-image__list li {
	padding: 14px 0 14px 32px;
	border-top: var(--tt-border);
	position: relative;
	color: var(--tt-ink-700);
}
.tt-content-image__list li::before {
	content: '✓';
	position: absolute;
	left: 0; top: 14px;
	width: 22px; height: 22px;
	background: var(--tt-blue-500);
	color: #fff;
	border-radius: 50%;
	display: grid; place-items: center;
	font-size: 12px;
	font-weight: 700;
}
@media (max-width: 900px) {
	.tt-content-image { grid-template-columns: 1fr; }
	.tt-content-image__media { max-width: 560px; }
}

/* ===== Comparison table ===== */
.tt-compare {
	border: var(--tt-border);
	border-radius: var(--tt-r-lg);
	overflow: hidden;
	background: #fff;
}
.tt-compare__row {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr;
	border-bottom: var(--tt-border);
}
.tt-compare__row:last-child { border-bottom: 0; }
.tt-compare__cell {
	padding: 20px 24px;
	border-right: var(--tt-border);
	font-size: var(--tt-fs-sm);
}
.tt-compare__cell:last-child { border-right: 0; }
.tt-compare__row--head .tt-compare__cell {
	font-family: var(--tt-font-display);
	font-size: var(--tt-fs-md);
	background: var(--tt-ink-50);
	font-weight: 500;
	color: var(--tt-ink-900);
}
.tt-compare__row--head .tt-compare__cell:last-child {
	background: var(--tt-ink-900);
	color: #fff;
}
.tt-compare__cell--yes { color: var(--tt-blue-600); font-weight: 600; }
.tt-compare__cell--no  { color: var(--tt-ink-400); }
@media (max-width: 720px) {
	.tt-compare__row { grid-template-columns: 1fr; }
	.tt-compare__cell { border-right: 0; border-bottom: var(--tt-border); }
	.tt-compare__row:last-child .tt-compare__cell:last-child { border-bottom: 0; }
}

/* ===== CTA band ===== */
.tt-cta-band {
	padding: var(--tt-space-8) 0;
}
.tt-cta-band__inner {
	background: var(--tt-ink-900);
	color: #fff;
	padding: clamp(40px, 6vw, 72px);
	border-radius: var(--tt-r-xl);
	display: grid;
	grid-template-columns: 1.5fr 1fr;
	gap: var(--tt-space-6);
	align-items: center;
	position: relative;
	overflow: hidden;
}
.tt-cta-band__inner::after {
	content: '';
	position: absolute;
	right: -10%; bottom: -30%;
	width: 60%; aspect-ratio: 1;
	background: radial-gradient(circle, rgba(30, 94, 255, 0.5), transparent 70%);
	pointer-events: none;
}
.tt-cta-band__inner.is-accent { background: var(--tt-blue-500); }
.tt-cta-band__inner.is-light {
	background: var(--tt-ink-50); color: var(--tt-ink-900);
	border: var(--tt-border);
}
.tt-cta-band__title {
	font-size: clamp(1.75rem, 3vw + 0.5rem, 2.75rem);
	line-height: 1.15;
	color: inherit;
	margin-bottom: var(--tt-space-3);
	position: relative; z-index: 1;
}
.tt-cta-band__sub { color: rgba(255,255,255,0.75); max-width: 50ch; position: relative; z-index: 1; }
.tt-cta-band__inner.is-light .tt-cta-band__sub { color: var(--tt-ink-500); }
.tt-cta-band__actions { display: flex; gap: 12px; justify-content: flex-end; flex-wrap: wrap; position: relative; z-index: 1; }
@media (max-width: 900px) {
	.tt-cta-band__inner { grid-template-columns: 1fr; }
	.tt-cta-band__actions { justify-content: flex-start; }
}

/* ===== Blog hero / search ===== */
.tt-blog-hero {
	padding: clamp(80px, 10vw, 140px) 0 var(--tt-space-7);
}
.tt-blog-hero__intro { max-width: 720px; margin: 0 auto var(--tt-space-6); text-align: center; }
.tt-blog-hero__intro h1 { font-size: clamp(2.5rem, 5vw, 4rem); color: #fff; margin-bottom: var(--tt-space-4); }
.tt-blog-hero__intro p  { color: var(--tt-ink-200); }
.tt-blog-hero .tt-search { margin: 0 auto; }
.tt-blog-hero .tt-input {
	background: rgba(255,255,255,0.08);
	border-color: rgba(255,255,255,0.15);
	color: #fff;
	padding: 18px 20px 18px 54px;
	font-size: var(--tt-fs-md);
}
.tt-blog-hero .tt-input::placeholder { color: var(--tt-ink-300); }
.tt-blog-hero .tt-search__icon { color: var(--tt-ink-300); }

/* ===== Newsletter section ===== */
.tt-newsletter {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--tt-space-7);
	align-items: center;
	background: linear-gradient(135deg, var(--tt-blue-50), #fff);
	padding: clamp(40px, 6vw, 72px);
	border-radius: var(--tt-r-xl);
	border: var(--tt-border);
}
.tt-newsletter h2 { margin-bottom: var(--tt-space-3); }
.tt-newsletter p  { color: var(--tt-ink-500); margin-bottom: var(--tt-space-4); }
.tt-newsletter__form { display: flex; gap: 10px; flex-wrap: wrap; }
.tt-newsletter__form .tt-input { flex: 1; min-width: 220px; background: #fff; }
@media (max-width: 900px) { .tt-newsletter { grid-template-columns: 1fr; } }

/* ===== Blog card grid ===== */
.tt-article-card { display: flex; flex-direction: column; height: 100%; }
.tt-article-card .tt-card__media { aspect-ratio: 16/10; }
.tt-article-card__meta {
	font-size: var(--tt-fs-xs);
	color: var(--tt-ink-500);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-weight: 600;
	margin-bottom: 10px;
}
.tt-article-card__title {
	font-family: var(--tt-font-display);
	font-size: var(--tt-fs-lg);
	font-weight: 500;
	line-height: 1.3;
	color: var(--tt-ink-900);
	margin-bottom: 10px;
}
.tt-article-card__excerpt { color: var(--tt-ink-500); font-size: var(--tt-fs-sm); margin-bottom: var(--tt-space-4); }
.tt-article-card__author {
	margin-top: auto;
	display: flex; align-items: center; gap: 10px;
	font-size: var(--tt-fs-xs);
	color: var(--tt-ink-500);
}
.tt-article-card__avatar {
	width: 28px; height: 28px; border-radius: 50%;
	background: var(--tt-ink-100);
	display: grid; place-items: center;
	font-weight: 600; color: var(--tt-ink-700);
	font-size: 11px;
}

/* ===== Jobs grid ===== */
.tt-job-card {
	display: flex;
	gap: var(--tt-space-4);
	justify-content: space-between;
	padding: var(--tt-space-5);
	background: #fff;
	border: var(--tt-border);
	border-radius: var(--tt-r-lg);
	transition: all var(--tt-t-med) var(--tt-ease);
	align-items: center;
}
.tt-job-card:hover {
	border-color: var(--tt-blue-300);
	box-shadow: var(--tt-shadow-md);
	transform: translateY(-2px);
}
.tt-job-card__body { flex: 1; }
.tt-job-card__cat {
	display: inline-block;
	font-size: var(--tt-fs-xs);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--tt-blue-600);
	margin-bottom: 8px;
}
.tt-job-card__title {
	font-family: var(--tt-font-display);
	font-weight: 500;
	font-size: var(--tt-fs-lg);
	color: var(--tt-ink-900);
	line-height: 1.3;
	margin-bottom: 8px;
}
.tt-job-card__meta {
	display: flex; gap: 18px; flex-wrap: wrap;
	font-size: var(--tt-fs-sm);
	color: var(--tt-ink-500);
}
.tt-job-card__meta span { display: inline-flex; align-items: center; gap: 6px; }
.tt-job-card__arrow {
	width: 44px; height: 44px;
	border-radius: 50%;
	border: var(--tt-border);
	display: grid; place-items: center;
	color: var(--tt-ink-500);
	transition: all var(--tt-t-fast) var(--tt-ease);
	flex-shrink: 0;
}
.tt-job-card:hover .tt-job-card__arrow {
	background: var(--tt-blue-500);
	border-color: var(--tt-blue-500);
	color: #fff;
}

/* ===== Category cards ===== */
.tt-category-card {
	display: flex;
	flex-direction: column;
	gap: 12px;
	padding: var(--tt-space-5);
	background: #fff;
	border: var(--tt-border);
	border-radius: var(--tt-r-lg);
	transition: all var(--tt-t-med) var(--tt-ease);
	position: relative;
	overflow: hidden;
}
.tt-category-card::before {
	content: '';
	position: absolute;
	inset: 0 0 auto 0; height: 4px;
	background: var(--tt-blue-500);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform var(--tt-t-med) var(--tt-ease);
}
.tt-category-card:hover { border-color: var(--tt-ink-200); box-shadow: var(--tt-shadow-md); transform: translateY(-3px); }
.tt-category-card:hover::before { transform: scaleX(1); }
.tt-category-card__name {
	font-family: var(--tt-font-display);
	font-size: var(--tt-fs-lg);
	font-weight: 500;
	color: var(--tt-ink-900);
}
.tt-category-card__count { font-size: var(--tt-fs-sm); color: var(--tt-ink-500); }
