/* ==========================================================================
   Basira Business — Main Stylesheet
   ========================================================================== */

/* ---------- Design Tokens ---------- */
:root {
	/* Colors */
	--color-primary: #1B2A4A;
	--color-primary-dark: #111D35;
	--color-primary-light: #2A4070;
	--color-secondary: #8C7B6B;
	--color-secondary-light: #B8A99A;
	--color-accent: #C4963C;
	--color-accent-hover: #D4A64C;
	--color-bg: #FFFFFF;
	--color-bg-alt: #F7F6F3;
	--color-bg-warm: #FAF8F5;
	--color-text: #2D2D2D;
	--color-text-light: #6B6B6B;
	--color-border: #E5E2DC;

	/* Typography */
	--font-en: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
	--font-ar: 'IBM Plex Sans Arabic', 'Inter', sans-serif;
	--font-body: var(--font-en);
	--fs-xs: 0.8125rem;
	--fs-sm: 0.875rem;
	--fs-base: 1.0625rem;
	--fs-md: 1.25rem;
	--fs-lg: 1.5rem;
	--fs-xl: 2rem;
	--fs-2xl: 2.25rem;
	--fs-3xl: 3rem;
	--lh-tight: 1.15;
	--lh-snug: 1.3;
	--lh-normal: 1.7;

	/* Spacing */
	--sp-xs: 0.5rem;
	--sp-sm: 1rem;
	--sp-md: 1.5rem;
	--sp-lg: 2rem;
	--sp-xl: 3rem;
	--sp-2xl: 4rem;
	--sp-3xl: 5rem;
	--sp-section: 5.5rem;

	/* Layout */
	--max-width: 1200px;
	--max-content: 720px;
	--radius: 0.375rem;
	--radius-lg: 0.75rem;

	/* Transitions */
	--transition: 0.2s ease;
	--transition-slow: 0.35s ease;

	/* Shadows */
	--shadow-sm: 0 1px 3px rgba(27, 42, 74, 0.06);
	--shadow-md: 0 4px 12px rgba(27, 42, 74, 0.08);
	--shadow-lg: 0 8px 30px rgba(27, 42, 74, 0.1);
}

/* Arabic locale: swap body font */
html[lang^="ar"] {
	--font-body: var(--font-ar);
}

/* ---------- Reset & Base ---------- */
*,
*::before,
*::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	font-size: 100%;
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
}

body {
	font-family: var(--font-body);
	font-size: var(--fs-base);
	line-height: var(--lh-normal);
	color: var(--color-text);
	background-color: var(--color-bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	overflow-x: hidden;
}

img {
	max-width: 100%;
	height: auto;
	display: block;
}

a {
	color: var(--color-primary-light);
	text-decoration: none;
	transition: color var(--transition);
}
a:hover {
	color: var(--color-accent);
}

ul, ol {
	list-style: none;
}

/* ---------- Typography ---------- */
h1, h2, h3, h4, h5, h6 {
	font-weight: 700;
	color: var(--color-primary);
	line-height: var(--lh-tight);
}

h1 { font-size: var(--fs-3xl); margin-bottom: var(--sp-md); }
h2 { font-size: var(--fs-2xl); margin-bottom: var(--sp-md); line-height: 1.2; }
h3 { font-size: var(--fs-lg); margin-bottom: var(--sp-sm); font-weight: 600; line-height: var(--lh-snug); }
h4 { font-size: var(--fs-md); margin-bottom: var(--sp-sm); font-weight: 600; }

p {
	margin-bottom: var(--sp-md);
}

p:last-child {
	margin-bottom: 0;
}

strong {
	font-weight: 600;
}

/* ---------- Layout ---------- */
.container {
	max-width: var(--max-width);
	margin-inline: auto;
	padding-inline: var(--sp-md);
}

.container--narrow {
	max-width: var(--max-content);
}

.section {
	padding-block: var(--sp-section);
}

.section--alt {
	background-color: var(--color-bg-alt);
}

.section--warm {
	background-color: var(--color-bg-warm);
}

.section--dark {
	background-color: var(--color-primary-dark);
	color: #FFFFFF;
}
.section--dark h2,
.section--dark h3,
.section--dark h4 {
	color: #FFFFFF;
}
.section--dark p {
	color: rgba(255, 255, 255, 0.8);
}

.section__header {
	text-align: center;
	max-width: 640px;
	margin-inline: auto;
	margin-bottom: var(--sp-2xl);
}

.section__header p {
	color: var(--color-text-light);
	font-size: var(--fs-md);
}

.section--dark .section__header p {
	color: rgba(255, 255, 255, 0.7);
}

/* Grid helpers */
.grid {
	display: grid;
	gap: var(--sp-lg);
}

.grid--2 { grid-template-columns: repeat(2, 1fr); }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
.grid--4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 1024px) {
	.grid--4 { grid-template-columns: repeat(2, 1fr); }
	.grid--3 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 640px) {
	.grid--4,
	.grid--3,
	.grid--2 {
		grid-template-columns: 1fr;
	}
}

/* ---------- Buttons ---------- */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	padding: 0.75rem 1.75rem;
	font-family: var(--font-body);
	font-size: var(--fs-sm);
	font-weight: 500;
	line-height: 1;
	border: 2px solid transparent;
	border-radius: var(--radius);
	cursor: pointer;
	transition: all var(--transition);
	text-decoration: none;
	white-space: nowrap;
}

.btn--primary {
	background-color: var(--color-primary);
	color: #FFFFFF;
	border-color: var(--color-primary);
}
.btn--primary:hover {
	background-color: var(--color-primary-light);
	border-color: var(--color-primary-light);
	color: #FFFFFF;
}

.btn--accent {
	background-color: var(--color-accent);
	color: #FFFFFF;
	border-color: var(--color-accent);
}
.btn--accent:hover {
	background-color: var(--color-accent-hover);
	border-color: var(--color-accent-hover);
	color: #FFFFFF;
}

.btn--outline {
	background-color: transparent;
	color: var(--color-primary);
	border-color: var(--color-primary);
}
.btn--outline:hover {
	background-color: var(--color-primary);
	color: #FFFFFF;
}

.btn--outline-white {
	background-color: transparent;
	color: #FFFFFF;
	border-color: rgba(255, 255, 255, 0.5);
}
.btn--outline-white:hover {
	background-color: #FFFFFF;
	color: var(--color-primary);
	border-color: #FFFFFF;
}

.btn--lg {
	padding: 0.9rem 2.25rem;
	font-size: var(--fs-base);
}

.btn--sm {
	padding: 0.5rem 1.25rem;
	font-size: var(--fs-xs);
}

/* ---------- Language Switcher ---------- */
.lang-switcher {
	display: flex;
	align-items: center;
}

.lang-switcher ul {
	display: flex;
	align-items: center;
	gap: 0;
}

.lang-switcher li {
	list-style: none;
}

.lang-switcher a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.3rem 0.7rem;
	font-size: var(--fs-xs);
	font-weight: 600;
	color: var(--color-text-light);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	transition: all var(--transition);
}

.lang-switcher a:hover {
	color: var(--color-primary);
	border-color: var(--color-primary);
	background-color: var(--color-bg-alt);
}

.lang-switcher--mobile {
	margin-bottom: var(--sp-sm);
}

.lang-switcher--mobile ul {
	display: flex;
	gap: 0;
	width: 100%;
}

.lang-switcher--mobile li {
	flex: 1;
}

.lang-switcher--mobile a {
	display: flex;
	width: 100%;
	justify-content: center;
	padding: 0.6rem;
	font-size: var(--fs-sm);
	border-radius: 0;
}

.lang-switcher--mobile li:first-child a {
	border-radius: var(--radius) 0 0 var(--radius);
}

html[dir="rtl"] .lang-switcher--mobile li:first-child a {
	border-radius: 0 var(--radius) var(--radius) 0;
}

.lang-switcher--mobile li:last-child a {
	border-radius: 0 var(--radius) var(--radius) 0;
}

html[dir="rtl"] .lang-switcher--mobile li:last-child a {
	border-radius: var(--radius) 0 0 var(--radius);
}

.lang-switcher--mobile .current-lang a {
	background-color: var(--color-primary);
	color: #FFFFFF;
	border-color: var(--color-primary);
}

/* ---------- Header ---------- */
.site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background-color: #FFFFFF;
	border-bottom: 1px solid var(--color-border);
	transition: box-shadow var(--transition), padding var(--transition);
}

.site-header.is-scrolled {
	box-shadow: var(--shadow-md);
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-block: var(--sp-sm);
	max-width: var(--max-width);
	margin-inline: auto;
	padding-inline: var(--sp-md);
}

.site-header.is-scrolled .site-header__inner {
	padding-block: 0.6rem;
}

.site-logo img {
	height: 48px;
	width: auto;
	max-width: 240px;
}

.site-header.is-scrolled .site-logo img {
	height: 38px;
}

.site-logo--text {
	font-size: var(--fs-lg);
	font-weight: 700;
	color: var(--color-primary);
	text-decoration: none;
}
.site-logo--text span {
	color: var(--color-accent);
}

/* Navigation */
.primary-nav__list {
	display: flex;
	align-items: center;
	gap: var(--sp-lg);
}

.primary-nav__list a {
	color: var(--color-text);
	font-size: var(--fs-sm);
	font-weight: 500;
	padding: 0.25rem 0;
	position: relative;
	transition: color var(--transition);
}

.primary-nav__list a:hover,
.primary-nav__list .current-menu-item > a,
.primary-nav__list .current_page_item > a {
	color: var(--color-primary);
}

.primary-nav__list a::after {
	content: '';
	position: absolute;
	bottom: -2px;
	inset-inline-start: 0;
	width: 0;
	height: 2px;
	background-color: var(--color-accent);
	transition: width var(--transition);
}

.primary-nav__list a:hover::after,
.primary-nav__list .current-menu-item > a::after,
.primary-nav__list .current_page_item > a::after {
	width: 100%;
}

/* Dropdown */
.primary-nav__list .sub-menu {
	display: none;
	position: absolute;
	top: 100%;
	inset-inline-start: 0;
	background: #FFFFFF;
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	box-shadow: var(--shadow-md);
	min-width: 220px;
	padding: var(--sp-xs) 0;
	z-index: 50;
}

.primary-nav__list li {
	position: relative;
}

.primary-nav__list li:hover > .sub-menu {
	display: block;
}

.primary-nav__list .sub-menu a {
	display: block;
	padding: 0.5rem var(--sp-md);
	font-size: var(--fs-sm);
}

.primary-nav__list .sub-menu a::after {
	display: none;
}

.primary-nav__list .sub-menu a:hover {
	background-color: var(--color-bg-alt);
}

/* Header actions */
.header-actions {
	display: flex;
	align-items: center;
	gap: var(--sp-sm);
}

.header-search-toggle {
	background: none;
	border: none;
	cursor: pointer;
	color: var(--color-text);
	padding: 0.35rem;
	display: flex;
	align-items: center;
}

.header-search-toggle svg {
	width: 20px;
	height: 20px;
}

/* Mobile menu toggle */
.mobile-menu-toggle {
	display: none;
	background: none;
	border: none;
	cursor: pointer;
	padding: 0.35rem;
	flex-direction: column;
	gap: 5px;
}

.mobile-menu-toggle span {
	display: block;
	width: 24px;
	height: 2px;
	background-color: var(--color-primary);
	transition: all var(--transition);
}

.mobile-menu-toggle[aria-expanded="true"] span:nth-child(1) {
	transform: rotate(45deg) translate(5px, 5px);
}
.mobile-menu-toggle[aria-expanded="true"] span:nth-child(2) {
	opacity: 0;
}
.mobile-menu-toggle[aria-expanded="true"] span:nth-child(3) {
	transform: rotate(-45deg) translate(5px, -5px);
}

/* Search overlay */
.search-overlay {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(17, 29, 53, 0.92);
	z-index: 200;
	align-items: center;
	justify-content: center;
}

.search-overlay.is-active {
	display: flex;
}

.search-overlay__inner {
	width: 90%;
	max-width: 600px;
}

.search-overlay__form {
	display: flex;
	border-bottom: 2px solid #FFFFFF;
}

.search-overlay__input {
	flex: 1;
	background: transparent;
	border: none;
	color: #FFFFFF;
	font-family: var(--font-body);
	font-size: var(--fs-xl);
	padding: var(--sp-sm) 0;
	outline: none;
}

.search-overlay__input::placeholder {
	color: rgba(255, 255, 255, 0.5);
}

.search-overlay__close {
	position: absolute;
	top: var(--sp-lg);
	inset-inline-end: var(--sp-lg);
	background: none;
	border: none;
	color: #FFFFFF;
	font-size: var(--fs-xl);
	cursor: pointer;
	padding: var(--sp-xs);
}

@media (max-width: 1024px) {
	.primary-nav,
	.header-actions .btn {
		display: none;
	}

	.mobile-menu-toggle {
		display: flex;
	}
}

/* Mobile navigation panel */
.mobile-nav {
	display: none;
	position: fixed;
	top: 0;
	inset-inline-end: 0;
	width: 100%;
	max-width: 360px;
	height: 100vh;
	background: #FFFFFF;
	z-index: 150;
	padding: var(--sp-3xl) var(--sp-lg) var(--sp-lg);
	overflow-y: auto;
	box-shadow: var(--shadow-lg);
	transform: translateX(100%);
	transition: transform var(--transition-slow);
}

html[dir="rtl"] .mobile-nav {
	transform: translateX(-100%);
}

.mobile-nav.is-active {
	display: block;
	transform: translateX(0);
}

html[dir="rtl"] .mobile-nav.is-active {
	transform: translateX(0);
}

.mobile-nav__list {
	display: flex;
	flex-direction: column;
	gap: 0;
}

.mobile-nav__list a {
	display: block;
	padding: 0.85rem 0;
	color: var(--color-text);
	font-size: var(--fs-base);
	font-weight: 500;
	border-bottom: 1px solid var(--color-border);
}

.mobile-nav__list .sub-menu {
	padding-inline-start: var(--sp-md);
}

.mobile-nav__list .sub-menu a {
	font-size: var(--fs-sm);
	font-weight: 400;
	color: var(--color-text-light);
}

.mobile-nav__cta {
	margin-top: var(--sp-lg);
}

.mobile-backdrop {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(0, 0, 0, 0.4);
	z-index: 140;
}

.mobile-backdrop.is-active {
	display: block;
}

/* ---------- Hero ---------- */
.hero {
	background-color: var(--color-primary-dark);
	color: #FFFFFF;
	padding: var(--sp-3xl) 0 var(--sp-section);
	position: relative;
	overflow: hidden;
}

.hero::before {
	content: '';
	position: absolute;
	top: -40%;
	inset-inline-end: -10%;
	width: 500px;
	height: 500px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(196, 150, 60, 0.08) 0%, transparent 70%);
	pointer-events: none;
}

.hero__inner {
	max-width: var(--max-width);
	margin-inline: auto;
	padding-inline: var(--sp-md);
	text-align: center;
}

.hero__content {
	max-width: 700px;
	margin-inline: auto;
}

.hero__title {
	font-size: clamp(2rem, 4vw, 3.25rem);
	font-weight: 700;
	color: #FFFFFF;
	line-height: var(--lh-tight);
	margin-bottom: var(--sp-md);
}

.hero__subtitle {
	font-size: var(--fs-md);
	color: rgba(255, 255, 255, 0.75);
	line-height: var(--lh-normal);
	margin-bottom: var(--sp-xl);
}

.hero__actions {
	display: flex;
	gap: var(--sp-sm);
	flex-wrap: wrap;
	justify-content: center;
}

@media (max-width: 1024px) {
	.hero__content {
		max-width: 100%;
	}
	.hero {
		padding: var(--sp-2xl) 0 var(--sp-3xl);
	}
}

/* ---------- Page Hero (internal) ---------- */
.page-hero {
	background-color: var(--color-primary-dark);
	color: #FFFFFF;
	padding: var(--sp-2xl) 0 var(--sp-xl);
}

.page-hero__title {
	font-size: clamp(1.75rem, 3vw, 2.5rem);
	color: #FFFFFF;
	margin-bottom: var(--sp-xs);
}

.page-hero__subtitle {
	font-size: var(--fs-base);
	color: rgba(255, 255, 255, 0.65);
}

.page-hero .breadcrumb {
	margin-bottom: var(--sp-sm);
}

/* ---------- Breadcrumb ---------- */
.breadcrumb {
	font-size: var(--fs-sm);
}

.breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.35rem;
}

.breadcrumb__item {
	display: flex;
	align-items: center;
	gap: 0.35rem;
}

.breadcrumb a {
	color: rgba(255, 255, 255, 0.55);
}
.breadcrumb a:hover {
	color: #FFFFFF;
}

.breadcrumb__sep {
	color: rgba(255, 255, 255, 0.3);
	margin-inline: 0.2rem;
}

.breadcrumb [aria-current] {
	color: rgba(255, 255, 255, 0.85);
}

/* Breadcrumbs in non-hero contexts */
.breadcrumb--light a {
	color: var(--color-text-light);
}
.breadcrumb--light a:hover {
	color: var(--color-primary);
}
.breadcrumb--light .breadcrumb__sep {
	color: var(--color-secondary-light);
}
.breadcrumb--light [aria-current] {
	color: var(--color-text);
}

/* ---------- Cards ---------- */
.card {
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	overflow: hidden;
	transition: transform var(--transition), box-shadow var(--transition);
}

.card:hover {
	transform: translateY(-3px);
	box-shadow: var(--shadow-md);
}

.card__image {
	aspect-ratio: 3 / 2;
	overflow: hidden;
}

.card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--transition-slow);
}

.card:hover .card__image img {
	transform: scale(1.03);
}

.card__body {
	padding: var(--sp-md);
}

.card__category {
	display: inline-block;
	font-size: var(--fs-xs);
	font-weight: 600;
	color: var(--color-accent);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	margin-bottom: var(--sp-xs);
}

.card__title {
	font-size: var(--fs-md);
	font-weight: 600;
	color: var(--color-primary);
	margin-bottom: var(--sp-xs);
	line-height: var(--lh-snug);
}

.card__title a {
	color: inherit;
}
.card__title a:hover {
	color: var(--color-primary-light);
}

.card__excerpt {
	font-size: var(--fs-sm);
	color: var(--color-text-light);
	line-height: var(--lh-normal);
	margin-bottom: var(--sp-sm);
}

.card__meta {
	font-size: var(--fs-xs);
	color: var(--color-secondary);
	display: flex;
	align-items: center;
	gap: var(--sp-sm);
}

.card__meta span {
	display: flex;
	align-items: center;
	gap: 0.3rem;
}

/* Service card variant */
.card--service {
	text-align: center;
	padding: var(--sp-xl) var(--sp-md);
}

.card--service .card__icon {
	width: 52px;
	height: 52px;
	background-color: var(--color-bg-alt);
	border-radius: var(--radius);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-inline: auto;
	margin-bottom: var(--sp-md);
	color: var(--color-primary);
	font-size: 1.5rem;
}

.card--service .card__title {
	font-size: var(--fs-lg);
}

.card--service .card__link {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	font-size: var(--fs-sm);
	font-weight: 500;
	color: var(--color-accent);
	margin-top: var(--sp-sm);
}

.card--service .card__link:hover {
	gap: 0.6rem;
}

/* Resource card variant */
.card--resource {
	display: flex;
	align-items: center;
	padding: var(--sp-md);
}

.card--resource .card__icon {
	flex-shrink: 0;
	width: 48px;
	height: 48px;
	background-color: var(--color-accent);
	color: #FFFFFF;
	border-radius: var(--radius);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: var(--fs-sm);
	font-weight: 700;
	text-transform: uppercase;
	margin-inline-end: var(--sp-md);
}

.card--resource .card__body {
	padding: 0;
	flex: 1;
}

.card--resource .card__title {
	font-size: var(--fs-base);
	margin-bottom: 0.25rem;
}

/* ---------- Service Page Components ---------- */
.service-hero {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--sp-2xl);
	align-items: center;
}

@media (max-width: 768px) {
	.service-hero {
		grid-template-columns: 1fr;
	}
}

.service-summary {
	font-size: var(--fs-md);
	color: var(--color-text-light);
	line-height: var(--lh-normal);
}

.service-detail {
	padding-block: var(--sp-xl);
}

.service-detail h3 {
	font-size: var(--fs-lg);
	margin-bottom: var(--sp-sm);
}

.service-includes {
	list-style: none;
}

.service-includes li {
	padding: var(--sp-xs) 0;
	border-bottom: 1px solid var(--color-border);
	padding-inline-start: var(--sp-lg);
	position: relative;
	font-size: var(--fs-base);
}

.service-includes li::before {
	content: '✓';
	position: absolute;
	inset-inline-start: 0;
	color: var(--color-accent);
	font-weight: 700;
}

/* Process steps */
.process-steps {
	counter-reset: step;
}

.process-step {
	display: flex;
	gap: var(--sp-md);
	padding: var(--sp-md) 0;
	border-bottom: 1px solid var(--color-border);
}

.process-step:last-child {
	border-bottom: none;
}

.process-step__number {
	counter-increment: step;
	flex-shrink: 0;
	width: 40px;
	height: 40px;
	background-color: var(--color-primary);
	color: #FFFFFF;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	font-size: var(--fs-sm);
}

.process-step__number::before {
	content: counter(step);
}

.process-step__content h4 {
	margin-bottom: 0.25rem;
}

.process-step__content p {
	color: var(--color-text-light);
	font-size: var(--fs-sm);
}

/* ---------- How It Works ---------- */
.how-it-works {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--sp-xl);
	text-align: center;
}

.how-it-works__step {
	position: relative;
}

.how-it-works__number {
	width: 56px;
	height: 56px;
	border: 2px solid var(--color-accent);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-inline: auto;
	margin-bottom: var(--sp-md);
	font-size: var(--fs-lg);
	font-weight: 700;
	color: var(--color-accent);
}

.how-it-works__step h3 {
	margin-bottom: var(--sp-xs);
}

.how-it-works__step p {
	font-size: var(--fs-sm);
	color: var(--color-text-light);
	max-width: 280px;
	margin-inline: auto;
}

@media (max-width: 640px) {
	.how-it-works {
		grid-template-columns: 1fr;
		gap: var(--sp-xl);
	}
}

/* ---------- FAQ Accordion ---------- */
.faq-item {
	border-bottom: 1px solid var(--color-border);
}

.faq-item__question {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--sp-md) 0;
	background: none;
	border: none;
	cursor: pointer;
	font-family: var(--font-body);
	font-size: var(--fs-base);
	font-weight: 600;
	color: var(--color-primary);
	text-align: start;
	gap: var(--sp-sm);
}

.faq-item__icon {
	flex-shrink: 0;
	width: 24px;
	height: 24px;
	position: relative;
	transition: transform var(--transition);
}

.faq-item__icon::before,
.faq-item__icon::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	background-color: var(--color-primary);
	transform: translate(-50%, -50%);
}

.faq-item__icon::before {
	width: 14px;
	height: 2px;
}

.faq-item__icon::after {
	width: 2px;
	height: 14px;
	transition: transform var(--transition);
}

.faq-item.is-open .faq-item__icon::after {
	transform: translate(-50%, -50%) rotate(90deg);
}

.faq-item__answer {
	max-height: 0;
	overflow: hidden;
	transition: max-height var(--transition-slow);
}

.faq-item__answer-inner {
	padding-bottom: var(--sp-md);
	color: var(--color-text-light);
	font-size: var(--fs-sm);
	line-height: var(--lh-normal);
}

/* ---------- Testimonials ---------- */
.testimonial-card {
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: var(--sp-xl);
	position: relative;
}

.testimonial-card::before {
	content: '\201C';
	position: absolute;
	top: var(--sp-sm);
	inset-inline-start: var(--sp-md);
	font-size: 4rem;
	color: var(--color-accent);
	opacity: 0.25;
	line-height: 1;
	font-family: Georgia, serif;
}

.testimonial-card__text {
	font-size: var(--fs-base);
	font-style: italic;
	color: var(--color-text);
	margin-bottom: var(--sp-md);
	line-height: var(--lh-normal);
}

.testimonial-card__author {
	font-weight: 600;
	color: var(--color-primary);
	font-size: var(--fs-sm);
}

.testimonial-card__role {
	font-size: var(--fs-xs);
	color: var(--color-text-light);
}

/* ---------- CTA Section ---------- */
.cta-section {
	background-color: var(--color-primary);
	color: #FFFFFF;
	padding: var(--sp-2xl) 0;
	text-align: center;
}

.cta-section h2 {
	color: #FFFFFF;
	margin-bottom: var(--sp-sm);
}

.cta-section p {
	color: rgba(255, 255, 255, 0.75);
	max-width: 540px;
	margin-inline: auto;
	margin-bottom: var(--sp-lg);
}

.cta-section .btn {
	margin-inline: 0.5rem;
}

/* Inline CTA (within articles) */
.cta-inline {
	background-color: var(--color-bg-alt);
	border: 1px solid var(--color-border);
	border-inline-start: 4px solid var(--color-accent);
	border-radius: var(--radius);
	padding: var(--sp-lg);
	margin: var(--sp-xl) 0;
}

.cta-inline h4 {
	margin-bottom: var(--sp-xs);
}

.cta-inline p {
	font-size: var(--fs-sm);
	color: var(--color-text-light);
	margin-bottom: var(--sp-sm);
}

/* ---------- Newsletter ---------- */
.newsletter {
	background-color: var(--color-bg-warm);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: var(--sp-xl);
	text-align: center;
	max-width: 540px;
	margin-inline: auto;
}

.newsletter h3 {
	margin-bottom: var(--sp-xs);
}

.newsletter p {
	font-size: var(--fs-sm);
	color: var(--color-text-light);
	margin-bottom: var(--sp-md);
}

.newsletter__form {
	display: flex;
	gap: var(--sp-xs);
}

.newsletter__input {
	flex: 1;
	padding: 0.65rem var(--sp-sm);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	font-family: var(--font-body);
	font-size: var(--fs-sm);
	background: #FFFFFF;
}

.newsletter__input:focus {
	outline: 2px solid var(--color-accent);
	outline-offset: 1px;
	border-color: transparent;
}

@media (max-width: 480px) {
	.newsletter__form {
		flex-direction: column;
	}
}

/* ---------- Topics Grid ---------- */
.topic-card {
	display: flex;
	align-items: center;
	gap: var(--sp-md);
	padding: var(--sp-md);
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	transition: border-color var(--transition), box-shadow var(--transition);
}

.topic-card:hover {
	border-color: var(--color-secondary-light);
	box-shadow: var(--shadow-sm);
}

.topic-card__icon {
	flex-shrink: 0;
	width: 44px;
	height: 44px;
	background-color: var(--color-bg-alt);
	border-radius: var(--radius);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-primary);
}

.topic-card__label {
	font-weight: 600;
	font-size: var(--fs-sm);
	color: var(--color-primary);
}

.topic-card__count {
	font-size: var(--fs-xs);
	color: var(--color-text-light);
}

/* ---------- Trust / Features ---------- */
.trust-card {
	text-align: center;
	padding: var(--sp-lg);
}

.trust-card__icon {
	width: 48px;
	height: 48px;
	background-color: var(--color-bg-alt);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-inline: auto;
	margin-bottom: var(--sp-sm);
	color: var(--color-accent);
}

.trust-card h4 {
	font-size: var(--fs-base);
	margin-bottom: var(--sp-xs);
}

.trust-card p {
	font-size: var(--fs-sm);
	color: var(--color-text-light);
}

/* ---------- Community Teaser ---------- */
.community-teaser {
	max-width: var(--max-content);
	margin-inline: auto;
	text-align: center;
}

@media (max-width: 768px) {
	.community-teaser {
		text-align: center;
	}
}

/* ---------- Content (single articles, pages) ---------- */
.content-area {
	max-width: var(--max-content);
	margin-inline: auto;
	padding: var(--sp-2xl) var(--sp-md);
}

.content-area h2 { margin-top: var(--sp-xl); }
.content-area h3 { margin-top: var(--sp-lg); }

.content-area ul,
.content-area ol {
	margin-bottom: var(--sp-md);
	padding-inline-start: var(--sp-lg);
}

.content-area ul {
	list-style: disc;
}

.content-area ol {
	list-style: decimal;
}

.content-area li {
	margin-bottom: var(--sp-xs);
}

.content-area blockquote {
	border-inline-start: 4px solid var(--color-accent);
	padding: var(--sp-md) var(--sp-lg);
	margin: var(--sp-lg) 0;
	background-color: var(--color-bg-warm);
	border-radius: 0 var(--radius) var(--radius) 0;
	font-style: italic;
	color: var(--color-text);
}

.content-area blockquote p:last-child {
	margin-bottom: 0;
}

.content-area pre {
	background-color: var(--color-primary-dark);
	color: #e0e0e0;
	padding: var(--sp-md);
	border-radius: var(--radius);
	overflow-x: auto;
	font-size: var(--fs-sm);
	margin-bottom: var(--sp-md);
}

.content-area code {
	font-size: 0.9em;
	background-color: var(--color-bg-alt);
	padding: 0.15em 0.4em;
	border-radius: 3px;
}

.content-area pre code {
	background: none;
	padding: 0;
}

.content-area table {
	width: 100%;
	border-collapse: collapse;
	margin-bottom: var(--sp-lg);
}

.content-area th,
.content-area td {
	padding: var(--sp-xs) var(--sp-sm);
	border: 1px solid var(--color-border);
	font-size: var(--fs-sm);
	text-align: start;
}

.content-area th {
	background-color: var(--color-bg-alt);
	font-weight: 600;
	color: var(--color-primary);
}

/* Highlighted note callout */
.note-callout {
	background-color: var(--color-bg-alt);
	border: 1px solid var(--color-border);
	border-inline-start: 4px solid var(--color-primary);
	padding: var(--sp-md);
	border-radius: 0 var(--radius) var(--radius) 0;
	margin: var(--sp-lg) 0;
	font-size: var(--fs-sm);
}

/* ---------- Article Meta ---------- */
.article-meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--sp-sm);
	font-size: var(--fs-sm);
	color: var(--color-text-light);
	margin-bottom: var(--sp-lg);
	padding-bottom: var(--sp-md);
	border-bottom: 1px solid var(--color-border);
}

.article-meta__cat {
	font-weight: 600;
	color: var(--color-accent);
	text-transform: uppercase;
	font-size: var(--fs-xs);
	letter-spacing: 0.04em;
}

.article-meta__sep {
	color: var(--color-border);
}

.article-featured-image {
	border-radius: var(--radius-lg);
	overflow: hidden;
	margin-bottom: var(--sp-lg);
}

/* ---------- Sidebar ---------- */
.sidebar {
	padding-inline-start: var(--sp-xl);
}

.sidebar .widget {
	margin-bottom: var(--sp-xl);
}

.sidebar .widget-title {
	font-size: var(--fs-base);
	font-weight: 600;
	margin-bottom: var(--sp-sm);
	padding-bottom: var(--sp-xs);
	border-bottom: 2px solid var(--color-accent);
}

/* ---------- Footer ---------- */
.site-footer {
	background-color: var(--color-primary-dark);
	color: rgba(255, 255, 255, 0.7);
	padding-top: var(--sp-3xl);
}

.footer-main {
	display: grid;
	grid-template-columns: 2fr 1fr 1fr 1fr;
	gap: var(--sp-2xl);
	padding-bottom: var(--sp-2xl);
	border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.footer-brand {
	max-width: 300px;
}

.footer-brand__logo {
	margin-bottom: var(--sp-md);
}

.footer-brand__logo img {
	height: 42px;
	width: auto;
	max-width: 200px;
}

.footer-brand p {
	font-size: var(--fs-sm);
	line-height: var(--lh-normal);
	color: rgba(255, 255, 255, 0.55);
}

.footer-col h4 {
	color: #FFFFFF;
	font-size: var(--fs-sm);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	margin-bottom: var(--sp-md);
}

.footer-col ul li {
	margin-bottom: 0.6rem;
}

.footer-col a {
	color: rgba(255, 255, 255, 0.6);
	font-size: var(--fs-sm);
	transition: color var(--transition);
}

.footer-col a:hover {
	color: #FFFFFF;
}

.footer-social {
	display: flex;
	gap: var(--sp-sm);
	margin-top: var(--sp-md);
}

.footer-social a {
	width: 36px;
	height: 36px;
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: rgba(255, 255, 255, 0.6);
	font-size: var(--fs-xs);
	transition: all var(--transition);
}

.footer-social a:hover {
	background-color: var(--color-accent);
	border-color: var(--color-accent);
	color: #FFFFFF;
}

.footer-bottom {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--sp-md) 0;
	font-size: var(--fs-xs);
	color: rgba(255, 255, 255, 0.4);
}

.footer-bottom a {
	color: rgba(255, 255, 255, 0.4);
}

.footer-bottom a:hover {
	color: #FFFFFF;
}

.footer-legal {
	display: flex;
	gap: var(--sp-md);
}

@media (max-width: 1024px) {
	.footer-main {
		grid-template-columns: 1fr 1fr;
	}
}

@media (max-width: 640px) {
	.footer-main {
		grid-template-columns: 1fr;
	}
	.footer-bottom {
		flex-direction: column;
		gap: var(--sp-sm);
		text-align: center;
	}
}

/* ---------- Pagination ---------- */
.pagination {
	padding: var(--sp-xl) 0;
}

.pagination__inner {
	display: flex;
	justify-content: center;
}

.pagination .nav-links {
	display: flex;
	align-items: center;
	gap: var(--sp-xs);
}

.pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 var(--sp-sm);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	font-size: var(--fs-sm);
	font-weight: 500;
	color: var(--color-text);
	transition: all var(--transition);
}

.pagination .page-numbers:hover {
	border-color: var(--color-primary);
	color: var(--color-primary);
}

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

/* ---------- Search Results ---------- */
.search-result {
	padding: var(--sp-lg) 0;
	border-bottom: 1px solid var(--color-border);
}

.search-result__type {
	font-size: var(--fs-xs);
	font-weight: 600;
	color: var(--color-accent);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	margin-bottom: var(--sp-xs);
}

.search-result__title {
	font-size: var(--fs-md);
	margin-bottom: var(--sp-xs);
}

.search-result__title a {
	color: var(--color-primary);
}

.search-result__excerpt {
	font-size: var(--fs-sm);
	color: var(--color-text-light);
}

/* ---------- 404 ---------- */
.error-404 {
	text-align: center;
	padding: var(--sp-3xl) var(--sp-md);
}

.error-404__code {
	font-size: clamp(5rem, 12vw, 10rem);
	font-weight: 700;
	color: var(--color-border);
	line-height: 1;
	margin-bottom: var(--sp-sm);
}

.error-404 h1 {
	font-size: var(--fs-2xl);
	margin-bottom: var(--sp-sm);
}

.error-404 p {
	color: var(--color-text-light);
	max-width: 480px;
	margin-inline: auto;
	margin-bottom: var(--sp-lg);
}

/* ---------- Contact Form Styling ---------- */
.form-row {
	margin-bottom: var(--sp-md);
}

.form-row label {
	display: block;
	font-size: var(--fs-sm);
	font-weight: 600;
	color: var(--color-primary);
	margin-bottom: 0.35rem;
	text-align: start;
}

.form-row .required {
	color: #c0392b;
}

.wpcf7-form label,
.wpforms-field-label {
	display: block;
	font-size: var(--fs-sm);
	font-weight: 600;
	color: var(--color-primary);
	margin-bottom: 0.35rem;
	text-align: start;
}

.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form input[type="url"],
.wpcf7-form textarea,
.wpcf7-form select,
.wpforms-field input,
.wpforms-field textarea,
.wpforms-field select {
	width: 100%;
	padding: 0.65rem var(--sp-sm);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	font-family: var(--font-body);
	font-size: var(--fs-sm);
	background-color: #FFFFFF;
	transition: border-color var(--transition);
}

.wpcf7-form input:focus,
.wpcf7-form textarea:focus,
.wpcf7-form select:focus {
	outline: 2px solid var(--color-accent);
	outline-offset: 1px;
	border-color: transparent;
}

.wpcf7-form p {
	margin-bottom: var(--sp-md);
}

.wpcf7-submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.75rem 1.75rem;
	background-color: var(--color-accent);
	color: #FFFFFF;
	border: 2px solid var(--color-accent);
	border-radius: var(--radius);
	font-family: var(--font-body);
	font-size: var(--fs-sm);
	font-weight: 500;
	cursor: pointer;
	transition: all var(--transition);
}

.wpcf7-submit:hover {
	background-color: var(--color-accent-hover);
	border-color: var(--color-accent-hover);
}

/* RTL form adjustments */
html[dir="rtl"] .wpcf7-form input,
html[dir="rtl"] .wpcf7-form textarea,
html[dir="rtl"] .wpcf7-form select {
	text-align: right;
}

html[dir="rtl"] .wpcf7-form input::placeholder,
html[dir="rtl"] .wpcf7-form textarea::placeholder {
	text-align: right;
}

.wpcf7-form .wpcf7-submit {
	width: 100%;
	margin-top: var(--sp-sm);
}

/* ---------- Forum Landing ---------- */
.forum-topics {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--sp-md);
}

.forum-topic-card {
	display: flex;
	align-items: flex-start;
	gap: var(--sp-md);
	padding: var(--sp-md);
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	transition: border-color var(--transition);
}

.forum-topic-card:hover {
	border-color: var(--color-secondary-light);
}

.forum-topic-card__icon {
	flex-shrink: 0;
	width: 44px;
	height: 44px;
	background-color: var(--color-bg-alt);
	border-radius: var(--radius);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-primary);
}

.forum-topic-card h4 {
	font-size: var(--fs-base);
	margin-bottom: 0.2rem;
}

.forum-topic-card p {
	font-size: var(--fs-sm);
	color: var(--color-text-light);
}

.forum-rules {
	background-color: var(--color-bg-alt);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: var(--sp-xl);
}

.forum-rules h3 {
	margin-bottom: var(--sp-md);
}

.forum-rules ol {
	list-style: decimal;
	padding-inline-start: var(--sp-lg);
}

.forum-rules li {
	margin-bottom: var(--sp-xs);
	font-size: var(--fs-sm);
	color: var(--color-text-light);
}

@media (max-width: 640px) {
	.forum-topics {
		grid-template-columns: 1fr;
	}
}

/* ---------- Accessibility ---------- */
.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
	word-wrap: normal !important;
}

.screen-reader-text:focus {
	background-color: #FFFFFF;
	border-radius: var(--radius);
	box-shadow: var(--shadow-md);
	clip: auto !important;
	clip-path: none;
	color: var(--color-primary);
	display: block;
	font-size: var(--fs-sm);
	font-weight: 600;
	height: auto;
	padding: var(--sp-sm) var(--sp-md);
	position: fixed;
	top: 5px;
	inset-inline-start: 5px;
	width: auto;
	z-index: 100000;
}

:focus-visible {
	outline: 2px solid var(--color-accent);
	outline-offset: 2px;
}

/* ---------- Utility ---------- */
.text-center { text-align: center; }
.text-start { text-align: start; }
.mt-0 { margin-top: 0; }
.mb-0 { margin-bottom: 0; }
.mb-sm { margin-bottom: var(--sp-sm); }
.mb-md { margin-bottom: var(--sp-md); }
.mb-lg { margin-bottom: var(--sp-lg); }
.mb-xl { margin-bottom: var(--sp-xl); }
