:root {
	--te-ink: #17202a;
	--te-muted: #667085;
	--te-line: #e6e9ef;
	--te-soft: #f5f7fb;
	--te-primary: #2367ff;
	--te-primary-dark: #174fd0;
	--te-accent: #16a085;
	--te-warm: #f4b740;
}

body {
	background: #fff;
	color: var(--te-ink);
	font-family: Inter, Manrope, system-ui, -apple-system, "Segoe UI", sans-serif;
	font-size: 16px;
	line-height: 1.65;
	overflow-x: hidden;
}

a {
	color: inherit;
	text-decoration: none;
}

a:hover {
	color: var(--te-primary);
}

.btn {
	border-radius: 999px;
	font-weight: 700;
	padding-inline: 1.15rem;
}

.btn-primary {
	background: var(--te-primary);
	border-color: var(--te-primary);
}

.btn-primary:hover {
	background: var(--te-primary-dark);
	border-color: var(--te-primary-dark);
}

.site-header {
	backdrop-filter: blur(16px);
	box-shadow: 0 10px 30px rgba(23, 32, 42, .04);
}

.brand-mark {
	color: var(--te-ink);
	font-family: Manrope, Inter, sans-serif;
	font-weight: 800;
}

.brand-mark__icon {
	align-items: center;
	background: var(--te-ink);
	border-radius: 12px;
	color: #fff;
	display: inline-flex;
	height: 42px;
	justify-content: center;
	width: 42px;
}

.brand-mark__text {
	font-size: 1.2rem;
}

.navbar .nav-link {
	border-radius: 999px;
	color: var(--te-muted);
	font-weight: 700;
	padding: .45rem .75rem;
}

.navbar .nav-link:hover,
.navbar .current-menu-item .nav-link {
	background: var(--te-soft);
	color: var(--te-ink);
}

.search-pill {
	background: var(--te-soft);
	border: 1px solid var(--te-line);
	border-radius: 999px;
	gap: .35rem;
	padding: .25rem;
}

.search-pill .form-control {
	background: transparent;
	border: 0;
	box-shadow: none;
	min-width: 210px;
}

.section-space {
	padding: 5.5rem 0;
}

.bg-soft {
	background: var(--te-soft);
}

.hero-section {
	background:
		linear-gradient(135deg, rgba(35, 103, 255, .08), rgba(22, 160, 133, .08)),
		#fff;
	padding: 5rem 0 4rem;
}

.hero-section > .container > .row,
.page-hero > .container > .row,
.trust-section > .container > .row {
	margin-left: 0;
	margin-right: 0;
}

.page-hero {
	background: var(--te-soft);
	padding: 4rem 0;
}

.page-hero h1 {
	font-family: Manrope, Inter, sans-serif;
	font-weight: 800;
}

.page-hero__note,
.filter-panel,
.filter-panel__group,
.info-panel,
.author-profile,
.author-card,
.author-box,
.editorial-block {
	background: #fff;
	border: 1px solid var(--te-line);
	border-radius: 8px;
}

.page-hero__note {
	box-shadow: 0 20px 60px rgba(23, 32, 42, .08);
	color: var(--te-muted);
	font-weight: 700;
	padding: 1.5rem;
}

.eyebrow {
	color: var(--te-accent);
	font-size: .78rem;
	font-weight: 800;
	letter-spacing: 0;
	text-transform: uppercase;
}

.hero-panel,
.content-card,
.review-card,
.trust-step,
.empty-state {
	background: #fff;
	border: 1px solid var(--te-line);
	border-radius: 8px;
	box-shadow: 0 24px 70px rgba(23, 32, 42, .08);
}

.hero-panel {
	padding: 1.5rem;
}

.hero-photo-card {
	border: 1px solid rgba(23, 32, 42, .08);
	border-radius: 8px;
	box-shadow: 0 24px 70px rgba(23, 32, 42, .12);
	overflow: hidden;
}

.hero-photo-card__image {
	aspect-ratio: 16 / 10;
	display: block;
	height: 100%;
	object-fit: cover;
	object-position: 58% center;
	width: 100%;
}

.hero-panel__top,
.content-card__meta,
.section-heading {
	align-items: center;
	display: flex;
	justify-content: space-between;
}

.hero-panel__top span,
.hero-panel__grid span,
.content-card__excerpt,
.content-card__meta,
.trust-step p {
	color: var(--te-muted);
}

.hero-panel__top strong {
	font-size: 3rem;
	line-height: 1;
}

.hero-panel__bars {
	display: grid;
	gap: .75rem;
	margin: 2rem 0;
}

.hero-panel__bar {
	background: var(--te-soft);
	border-radius: 999px;
	height: 12px;
	overflow: hidden;
}

.hero-panel__bar::before {
	background: linear-gradient(90deg, var(--te-primary), var(--te-accent));
	border-radius: inherit;
	content: "";
	display: block;
	height: 100%;
	width: 70%;
}

.hero-panel__bar--xl::before {
	width: 94%;
}

.hero-panel__bar--lg::before {
	width: 86%;
}

.hero-panel__bar--md::before {
	width: 78%;
}

.hero-panel__grid {
	display: grid;
	gap: .8rem;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.hero-panel__grid div {
	background: var(--te-soft);
	border-radius: 8px;
	padding: 1rem;
}

.hero-panel__grid strong {
	display: block;
	font-size: 1.35rem;
}

.section-heading {
	gap: 1rem;
	margin-bottom: 2rem;
}

.section-heading h1,
.section-heading h2,
.content-page h1 {
	font-family: Manrope, Inter, sans-serif;
	font-weight: 800;
	margin: .2rem 0 0;
}

.content-card {
	display: flex;
	flex-direction: column;
	overflow: hidden;
	transition: transform .2s ease, box-shadow .2s ease;
}

.content-card:hover {
	box-shadow: 0 28px 80px rgba(23, 32, 42, .12);
	transform: translateY(-4px);
}

.content-card__media {
	aspect-ratio: 16 / 10;
	background: linear-gradient(135deg, #e9f0ff, #e7fbf5);
	display: block;
	overflow: hidden;
}

.content-card__image {
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.content-card__placeholder {
	align-items: center;
	color: var(--te-primary);
	display: flex;
	font-family: Manrope, Inter, sans-serif;
	font-size: 4rem;
	font-weight: 800;
	height: 100%;
	justify-content: center;
}

.content-card__body {
	display: flex;
	flex: 1;
	flex-direction: column;
	padding: 1.25rem;
}

.tag-list {
	display: flex;
	flex-wrap: wrap;
	gap: .45rem;
	margin-bottom: .8rem;
}

.tag-list__item {
	background: #eef5ff;
	border: 0;
	border-radius: 999px;
	color: var(--te-primary-dark);
	cursor: pointer;
	font-size: .78rem;
	font-weight: 800;
	padding: .25rem .6rem;
}

.tag-list__item.is-active {
	background: var(--te-primary);
	color: #fff;
}

.filter-panel {
	box-shadow: none;
	padding: 1.25rem;
}

.filter-panel__title {
	font-size: 1.25rem;
	font-weight: 800;
	margin: .2rem 0 0;
}

.filter-panel__group {
	box-shadow: none;
	padding: 1rem;
}

.filter-panel__group h3 {
	font-size: .95rem;
	font-weight: 800;
	margin-bottom: .8rem;
}

.content-card__title {
	font-size: 1.15rem;
	font-weight: 800;
	line-height: 1.35;
	margin-bottom: .75rem;
}

.content-card__byline,
.meta-line {
	color: var(--te-muted);
	display: flex;
	flex-wrap: wrap;
	font-size: .85rem;
	font-weight: 700;
	gap: .55rem;
	margin-bottom: .8rem;
}

.content-card__more {
	color: var(--te-primary);
	font-weight: 800;
}

.content-card__excerpt {
	margin-bottom: 1rem;
}

.content-card__meta {
	border-top: 1px solid var(--te-line);
	font-size: .88rem;
	font-weight: 700;
	margin-top: auto;
	padding-top: .9rem;
}

.review-slider {
	padding-bottom: 2.5rem;
}

.review-card {
	box-shadow: none;
	margin: 0;
	padding: 1.5rem;
}

.review-card blockquote {
	font-size: 1.05rem;
	font-weight: 600;
	margin-bottom: 1.5rem;
}

.review-card figcaption span {
	color: var(--te-muted);
	display: block;
	font-size: .92rem;
}

.trust-section {
	background: #101820;
	color: #fff;
}

.trust-section .text-secondary,
.trust-step p {
	color: rgba(255, 255, 255, .72) !important;
}

.trust-step {
	background: rgba(255, 255, 255, .08);
	border-color: rgba(255, 255, 255, .14);
	box-shadow: none;
	padding: 1.25rem;
}

.trust-step span {
	color: var(--te-warm);
	font-weight: 800;
}

.trust-step h3 {
	font-size: 1.05rem;
	font-weight: 800;
	margin: .8rem 0 .5rem;
}

.content-page {
	max-width: 850px;
}

.content-body {
	font-size: 1.08rem;
}

.content-body img {
	height: auto;
	max-width: 100%;
}

.author-box {
	align-items: center;
	display: grid;
	gap: 1.25rem;
	grid-template-columns: auto 1fr;
	max-width: 850px;
	padding: 1.25rem;
}

.author-box h2 {
	font-size: 1.35rem;
	font-weight: 800;
}

.author-box p {
	color: var(--te-muted);
	margin-bottom: 0;
}

.author-profile,
.author-card,
.info-panel,
.editorial-block {
	box-shadow: none;
	padding: 1.5rem;
}

.author-card {
	text-align: center;
}

.author-card h2 {
	font-size: 1.2rem;
	font-weight: 800;
	margin-top: 1rem;
}

.author-card p {
	color: var(--te-muted);
}

.author-hero__avatar {
	border: 6px solid #fff;
	box-shadow: 0 20px 60px rgba(23, 32, 42, .12);
}

.catalog-actions {
	margin-top: 2rem;
	text-align: center;
}

.editorial-block__image {
	aspect-ratio: 16 / 10;
	background: linear-gradient(135deg, #eef5ff, #e8fbf5);
	border-radius: 8px;
}

.contact-list dt {
	color: var(--te-muted);
	font-size: .9rem;
	margin-top: 1rem;
}

.contact-list dd {
	font-weight: 800;
	margin-bottom: 0;
}

.editor-form .form-label {
	font-weight: 700;
	width: 100%;
}

.check-list {
	color: var(--te-muted);
	padding-left: 1.2rem;
}

.page-numbers {
	border: 1px solid var(--te-line);
	border-radius: 999px;
	display: inline-flex;
	font-weight: 800;
	margin: .2rem;
	min-width: 2.4rem;
	padding: .45rem .75rem;
	justify-content: center;
}

.page-numbers.current {
	background: var(--te-primary);
	border-color: var(--te-primary);
	color: #fff;
}

.article-cover img {
	width: 100%;
}

.empty-state {
	box-shadow: none;
	padding: 2rem;
}

.site-footer {
	background: #fff;
}

.footer-menu a {
	color: var(--te-muted);
	font-weight: 700;
}

@media (max-width: 991.98px) {
	.section-space {
		padding: 4rem 0;
	}

	.search-pill {
		border-radius: 8px;
	}
}

@media (max-width: 575.98px) {
	.hero-section {
		padding-top: 3.5rem;
	}

	.section-heading {
		align-items: flex-start;
		flex-direction: column;
	}

	.hero-panel__grid {
		grid-template-columns: 1fr;
	}

	.author-box {
		grid-template-columns: 1fr;
	}
}
