/* =====================================================================
   AromaNish Digital — Main Stylesheet
   Lightweight, no framework dependency. Mobile-first, BEM-ish naming.
   ===================================================================== */

/* ---------------------------------------------------------------------
   1. DESIGN TOKENS
   ------------------------------------------------------------------- */
:root {
	--color-primary: #FF5A1F;
	--color-primary-dark: #E04A12;
	--color-secondary: #0B1B33;
	--color-secondary-light: #16294A;
	--color-text: #2B2F38;
	--color-text-light: #6B7280;
	--color-border: #E7E9EE;
	--color-bg: #FFFFFF;
	--color-bg-alt: #F6F8FB;
	--color-success: #1F9D55;
	--color-warning: #F59E0B;

	--font-heading: 'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
	--font-body: 'Manrope', system-ui, -apple-system, sans-serif;

	--container-width: 1240px;
	--radius-sm: 6px;
	--radius-md: 12px;
	--radius-lg: 20px;
	--shadow-sm: 0 2px 8px rgba(11,27,51,0.06);
	--shadow-md: 0 8px 24px rgba(11,27,51,0.10);
	--shadow-lg: 0 16px 48px rgba(11,27,51,0.14);

	--transition: 200ms ease;
	--header-height: 76px;
}

/* ---------------------------------------------------------------------
   2. RESET / BASE
   ------------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
	margin: 0;
	font-family: var(--font-body);
	font-size: 16px;
	line-height: 1.7;
	color: var(--color-text);
	background: var(--color-bg);
	overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--color-primary); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--color-primary-dark); }
ul, ol { padding-left: 1.25rem; }
h1,h2,h3,h4,h5,h6 {
	font-family: var(--font-heading);
	color: var(--color-secondary);
	line-height: 1.25;
	margin: 0 0 0.6em;
	font-weight: 800;
}
h1 { font-size: clamp(2rem, 4vw, 3.25rem); }
h2 { font-size: clamp(1.6rem, 3vw, 2.4rem); }
h3 { font-size: 1.25rem; }
p { margin: 0 0 1.1em; }
.container { max-width: var(--container-width); margin: 0 auto; padding: 0 24px; }
.container.narrow { max-width: 760px; }
.screen-reader-text {
	position: absolute !important; clip: rect(1px,1px,1px,1px);
	width: 1px; height: 1px; overflow: hidden;
}
.skip-link:focus {
	position: fixed; top: 0; left: 0; z-index: 9999;
	background: var(--color-secondary); color: #fff; padding: 12px 20px;
	width: auto; height: auto; clip: auto;
}
section.section { padding: 64px 0; }
@media (max-width: 768px) { section.section { padding: 44px 0; } }

/* ---------------------------------------------------------------------
   3. BUTTONS
   ------------------------------------------------------------------- */
.btn {
	display: inline-flex; align-items: center; justify-content: center;
	gap: 8px; font-family: var(--font-heading); font-weight: 700;
	font-size: 0.95rem; padding: 13px 26px; border-radius: var(--radius-sm);
	border: 2px solid transparent; cursor: pointer; transition: all var(--transition);
	line-height: 1.2; white-space: nowrap;
}
.btn--primary { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }
.btn--primary:hover { background: var(--color-primary-dark); border-color: var(--color-primary-dark); color:#fff; transform: translateY(-2px); box-shadow: var(--shadow-md); }
.btn--outline { background: transparent; color: var(--color-secondary); border-color: var(--color-border); }
.btn--outline:hover { border-color: var(--color-primary); color: var(--color-primary); }
.btn--ghost { background: rgba(255,255,255,0.08); color: #fff; border-color: rgba(255,255,255,0.4); }
.btn--ghost:hover { background: rgba(255,255,255,0.18); color:#fff; }
.btn--sm { padding: 9px 18px; font-size: 0.85rem; }
.btn--lg { padding: 16px 34px; font-size: 1.05rem; }
.btn--block { width: 100%; }

/* ---------------------------------------------------------------------
   4. TOPBAR + HEADER
   ------------------------------------------------------------------- */
.topbar { background: var(--color-secondary); color: #cfd8ea; font-size: 0.85rem; }
.topbar__inner { display: flex; justify-content: space-between; align-items: center; height: 38px; }
.topbar__contact { display: flex; gap: 22px; }
.topbar__contact a { color: #cfd8ea; display: inline-flex; align-items: center; gap: 6px; }
.topbar__contact a:hover { color: #fff; }
.social-links { display: flex; gap: 10px; list-style: none; margin: 0; padding: 0; }
.social-links a {
	display: flex; align-items: center; justify-content: center;
	width: 28px; height: 28px; border-radius: 50%;
	background: rgba(255,255,255,0.08); color: #cfd8ea;
}
.social-links a:hover { background: var(--color-primary); color: #fff; }

.site-header {
	position: sticky; top: 0; z-index: 100; background: #fff;
	box-shadow: var(--shadow-sm); height: var(--header-height);
}
.site-header__inner { display: flex; align-items: center; justify-content: space-between; height: 100%; gap: 24px; }
.site-branding img { max-height: 46px; width: auto; }
.site-title-link { font-family: var(--font-heading); font-weight: 800; font-size: 1.4rem; color: var(--color-secondary); }

.main-navigation { flex: 1; display: flex; justify-content: center; }
#primary-menu { display: flex; gap: 28px; list-style: none; margin: 0; padding: 0; align-items: center; }
#primary-menu > li { position: relative; }
#primary-menu > li > a {
	color: var(--color-secondary); font-weight: 600; font-size: 0.97rem;
	padding: 8px 2px; display: inline-block;
}
#primary-menu > li > a:hover { color: var(--color-primary); }
#primary-menu ul {
	list-style: none; margin: 0; padding: 8px; position: absolute; top: 100%; left: 0;
	background: #fff; border-radius: var(--radius-sm); box-shadow: var(--shadow-md);
	min-width: 220px; opacity: 0; visibility: hidden; transform: translateY(8px);
	transition: all var(--transition); z-index: 10;
}
#primary-menu li:hover > ul, #primary-menu li.focus > ul { opacity: 1; visibility: visible; transform: translateY(0); }
#primary-menu ul li a { display: block; padding: 8px 12px; border-radius: var(--radius-sm); color: var(--color-text); font-weight: 500; font-size: 0.92rem; }
#primary-menu ul li a:hover { background: var(--color-bg-alt); color: var(--color-primary); }

.site-header__actions { display: flex; align-items: center; gap: 14px; }
.menu-toggle {
	display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; padding: 8px;
}
.menu-toggle__bar { display: block; width: 24px; height: 2px; background: var(--color-secondary); border-radius: 2px; }

@media (max-width: 980px) {
	.topbar__contact { display: none; }
	.main-navigation {
		position: fixed; inset: var(--header-height) 0 0 0; background: #fff;
		flex-direction: column; padding: 24px; justify-content: flex-start;
		transform: translateX(100%); transition: transform var(--transition);
		overflow-y: auto;
	}
	.main-navigation.is-open { transform: translateX(0); }
	#primary-menu { flex-direction: column; align-items: flex-start; width: 100%; gap: 4px; }
	#primary-menu > li { width: 100%; }
	#primary-menu > li > a { display: block; padding: 12px 0; border-bottom: 1px solid var(--color-border); width: 100%; }
	#primary-menu ul { position: static; opacity: 1; visibility: visible; transform: none; box-shadow: none; display: none; padding-left: 12px; }
	#primary-menu li.is-expanded > ul { display: block; }
	.menu-toggle { display: flex; }
	.site-header__actions .btn--sm { display: none; }
}

.page-header-strip { background: var(--color-bg-alt); padding: 12px 0; border-bottom: 1px solid var(--color-border); }
.breadcrumbs ol { list-style: none; display: flex; flex-wrap: wrap; gap: 6px; margin: 0; padding: 0; font-size: 0.85rem; color: var(--color-text-light); }
.breadcrumbs li:not(:last-child)::after { content: '/'; margin-left: 6px; color: var(--color-border); }
.breadcrumbs a { color: var(--color-text-light); }
.breadcrumbs a:hover { color: var(--color-primary); }
.breadcrumbs li[aria-current] { color: var(--color-secondary); font-weight: 600; }

/* ---------------------------------------------------------------------
   5. HERO (homepage)
   ------------------------------------------------------------------- */
.hero {
	background: linear-gradient(135deg, var(--color-secondary) 0%, var(--color-secondary-light) 100%);
	color: #fff; padding: 64px 0 96px; position: relative; overflow: hidden;
}
.hero::after {
	content: ''; position: absolute; inset: auto -10% -40% auto; width: 600px; height: 600px;
	background: radial-gradient(circle, rgba(255,90,31,0.25), transparent 70%); border-radius: 50%;
}
.hero__inner { display: grid; grid-template-columns: 1.2fr 1fr; gap: 48px; align-items: center; position: relative; z-index: 1; }
.hero__eyebrow {
	display: inline-block; background: rgba(255,90,31,0.15); color: var(--color-primary);
	font-weight: 700; font-size: 0.8rem; letter-spacing: 0.06em; text-transform: uppercase;
	padding: 6px 14px; border-radius: 999px; margin-bottom: 18px;
}
.hero__title { color: #fff; margin-bottom: 0.5em; }
.hero__subtitle { color: #cfd8ea; font-size: 1.05rem; max-width: 560px; }
.hero__actions { display: flex; gap: 16px; margin: 28px 0; flex-wrap: wrap; }
.hero__trust-points { list-style: none; padding: 0; display: flex; flex-wrap: wrap; gap: 18px; margin: 0; font-size: 0.9rem; color: #cfd8ea; }
.hero__trust-points li { display: flex; align-items: center; gap: 8px; }
.hero__form-card { background: #fff; border-radius: var(--radius-lg); padding: 28px; box-shadow: var(--shadow-lg); color: var(--color-text); }

@media (max-width: 980px) {
	.hero__inner { grid-template-columns: 1fr; }
	.hero { padding-top: 40px; padding-bottom: 56px; }
}

/* ---------------------------------------------------------------------
   6. TRUST BAR
   ------------------------------------------------------------------- */
.trust-bar { background: var(--color-bg-alt); padding: 32px 0; border-bottom: 1px solid var(--color-border); }
.trust-bar__inner { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; text-align: center; }
.trust-stat__number { display: block; font-family: var(--font-heading); font-size: clamp(1.5rem, 3vw, 2.2rem); font-weight: 800; color: var(--color-primary); }
.trust-stat__label { font-size: 0.85rem; color: var(--color-text-light); }
@media (max-width: 768px) { .trust-bar__inner { grid-template-columns: repeat(2, 1fr); gap: 28px 16px; } }

/* ---------------------------------------------------------------------
   7. SECTION HEADINGS
   ------------------------------------------------------------------- */
.section-heading { margin-bottom: 40px; }
.section-heading--center { text-align: center; max-width: 720px; margin: 0 auto 40px; }
.section-heading__eyebrow {
	display: inline-block; color: var(--color-primary); font-weight: 700; font-size: 0.8rem;
	letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 8px;
}
.section-heading__sub { color: var(--color-text-light); }

/* ---------------------------------------------------------------------
   8. SERVICES GRID
   ------------------------------------------------------------------- */
.services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.service-card {
	background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-md);
	padding: 28px; transition: all var(--transition);
}
.service-card:hover { box-shadow: var(--shadow-md); transform: translateY(-4px); border-color: transparent; }
.service-card__icon { width: 48px; height: 48px; margin-bottom: 16px; }
.service-card__icon img { width: 100%; height: 100%; object-fit: contain; }
.service-card__title { margin-bottom: 10px; font-size: 1.15rem; }
.service-card__title a { color: var(--color-secondary); }
.service-card__title a:hover { color: var(--color-primary); }
.service-card__desc { color: var(--color-text-light); font-size: 0.95rem; margin-bottom: 14px; }
.service-card__link { font-weight: 700; font-size: 0.9rem; }
@media (max-width: 980px) { .services-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .services-grid { grid-template-columns: 1fr; } }

/* ---------------------------------------------------------------------
   9. MISSION / EEAT GRID
   ------------------------------------------------------------------- */
.mission-section { background: var(--color-bg-alt); }
.mission-grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 48px; align-items: center; }
.mission-pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 28px; }
.mission-pillar h3 { font-size: 1rem; margin-bottom: 6px; }
.mission-pillar p { font-size: 0.88rem; color: var(--color-text-light); margin-bottom: 8px; }
.mission-pillar a { font-weight: 700; font-size: 0.85rem; }
.mission-media img { border-radius: var(--radius-lg); box-shadow: var(--shadow-md); }
@media (max-width: 980px) {
	.mission-grid { grid-template-columns: 1fr; }
	.mission-media { order: -1; }
	.mission-pillars { grid-template-columns: 1fr; }
}

/* ---------------------------------------------------------------------
   10. TESTIMONIALS
   ------------------------------------------------------------------- */
.testimonials-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.testimonial-card { background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: 26px; }
.testimonial-card blockquote { margin: 12px 0; font-style: italic; color: var(--color-text); }
.testimonial-card figcaption { display: flex; align-items: center; gap: 12px; margin-top: 14px; }
.testimonial-card figcaption img { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; }
.testimonial-card figcaption strong { display: block; font-size: 0.92rem; }
.testimonial-card figcaption span { display: block; font-size: 0.8rem; color: var(--color-text-light); }
.star-rating { display: flex; gap: 3px; }
.star { width: 16px; height: 16px; display: inline-block; }
.star--filled { background: var(--color-warning); clip-path: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%); }
.star--empty { background: var(--color-border); clip-path: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%); }
.section-cta { text-align: center; margin-top: 32px; }
.empty-state { color: var(--color-text-light); text-align: center; grid-column: 1/-1; }
@media (max-width: 980px) { .testimonials-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 640px) { .testimonials-grid { grid-template-columns: 1fr; } }

/* ---------------------------------------------------------------------
   11. WHY US
   ------------------------------------------------------------------- */
.why-us-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.why-us-item {
	border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: 24px;
	border-top: 4px solid var(--color-primary);
}
.why-us-item h3 { font-size: 1.05rem; }
.why-us-item p { font-size: 0.9rem; color: var(--color-text-light); margin: 0; }
@media (max-width: 980px) { .why-us-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 640px) { .why-us-grid { grid-template-columns: 1fr; } }

/* ---------------------------------------------------------------------
   12. BLOG GRID / CARDS
   ------------------------------------------------------------------- */
.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.blog-grid--archive { grid-template-columns: repeat(2, 1fr); }
.blog-card { background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-md); overflow: hidden; transition: all var(--transition); }
.blog-card:hover { box-shadow: var(--shadow-md); transform: translateY(-4px); }
.blog-card__media { display: block; aspect-ratio: 3/2; overflow: hidden; }
.blog-card__media img { width: 100%; height: 100%; object-fit: cover; }
.blog-card__body { padding: 20px; }
.blog-card__body time { font-size: 0.8rem; color: var(--color-text-light); }
.blog-card__body h2, .blog-card__body h3 { font-size: 1.1rem; margin: 6px 0 10px; }
.blog-card__body h2 a, .blog-card__body h3 a { color: var(--color-secondary); }
.blog-card__body h2 a:hover, .blog-card__body h3 a:hover { color: var(--color-primary); }
.blog-card__body p { font-size: 0.92rem; color: var(--color-text-light); }
.blog-card__link { font-weight: 700; font-size: 0.88rem; }
@media (max-width: 980px) { .blog-grid, .blog-grid--archive { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 640px) { .blog-grid, .blog-grid--archive { grid-template-columns: 1fr; } }

/* ---------------------------------------------------------------------
   13. CTA BAND
   ------------------------------------------------------------------- */
.cta-band { background: var(--color-primary); color: #fff; padding: 48px 0; }
.cta-band__inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.cta-band__text h2 { color: #fff; margin-bottom: 4px; }
.cta-band__text p { color: rgba(255,255,255,0.9); margin: 0; }
.cta-band .btn--primary { background: #fff; color: var(--color-primary); border-color: #fff; }
.cta-band .btn--primary:hover { background: var(--color-secondary); color: #fff; border-color: var(--color-secondary); }

/* ---------------------------------------------------------------------
   14. FOOTER
   ------------------------------------------------------------------- */
.site-footer { background: var(--color-secondary); color: #cfd8ea; }
.footer__top { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.4fr; gap: 32px; padding: 56px 0 36px; }
.footer__col .widget-title { color: #fff; font-size: 1rem; margin-bottom: 16px; }
.footer__logo-text { font-family: var(--font-heading); font-weight: 800; font-size: 1.4rem; color: #fff; }
.footer__tagline { font-size: 0.9rem; color: #9fb0cc; margin: 12px 0 18px; }
.footer-menu, .legal-menu { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.footer-menu a, .legal-menu a { color: #cfd8ea; font-size: 0.92rem; }
.footer-menu a:hover, .legal-menu a:hover { color: var(--color-primary); }
.social-links--footer a { background: rgba(255,255,255,0.08); }
.footer__col--form .lead-form { background: rgba(255,255,255,0.05); padding: 18px; border-radius: var(--radius-md); }
.footer__col--form input, .footer__col--form select, .footer__col--form textarea {
	background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.15); color: #fff;
}
.footer__col--form input::placeholder, .footer__col--form textarea::placeholder { color: #9fb0cc; }
.footer__col--form .lead-form__privacy { color: #9fb0cc; }
.footer__bottom { border-top: 1px solid rgba(255,255,255,0.08); padding: 18px 0; }
.footer__bottom-inner { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; font-size: 0.85rem; }
.footer__bottom-inner p { margin: 0; }
.legal-menu { flex-direction: row; gap: 18px; }
@media (max-width: 980px) { .footer__top { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 640px) { .footer__top { grid-template-columns: 1fr; } }

/* ---------------------------------------------------------------------
   15. LEAD FORM
   ------------------------------------------------------------------- */
.lead-form__title { margin-bottom: 16px; font-size: 1.2rem; }
.lead-form__row { margin-bottom: 14px; }
.lead-form__row--split { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.lead-form input, .lead-form select, .lead-form textarea {
	width: 100%; padding: 13px 14px; border: 1px solid var(--color-border); border-radius: var(--radius-sm);
	font-family: var(--font-body); font-size: 0.95rem; background: #fff; color: var(--color-text);
	transition: border-color var(--transition);
}
.lead-form input:focus, .lead-form select:focus, .lead-form textarea:focus {
	outline: none; border-color: var(--color-primary);
}
.lead-form__honeypot { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.lead-form__privacy { font-size: 0.78rem; color: var(--color-text-light); text-align: center; margin: 10px 0 0; }
.lead-form__feedback { margin-top: 10px; font-size: 0.9rem; min-height: 1.2em; }
.lead-form__feedback.is-success { color: var(--color-success); }
.lead-form__feedback.is-error { color: #D14343; }
.lead-form input.field-error, .lead-form select.field-error, .lead-form textarea.field-error { border-color: #D14343; }
.lead-form .btn[disabled] { opacity: 0.7; cursor: not-allowed; }
@media (max-width: 480px) { .lead-form__row--split { grid-template-columns: 1fr; } }

/* ---------------------------------------------------------------------
   16. AI/SEO CONTENT BOXES (tldr, key takeaways)
   ------------------------------------------------------------------- */
.ai-box {
	border-left: 4px solid var(--color-primary); background: var(--color-bg-alt);
	border-radius: 0 var(--radius-md) var(--radius-md) 0; padding: 18px 22px; margin: 0 0 28px;
}
.ai-box--takeaways { border-left-color: var(--color-secondary); }
.ai-box__label {
	display: inline-block; font-weight: 800; font-size: 0.78rem; letter-spacing: 0.08em;
	text-transform: uppercase; color: var(--color-primary); margin-bottom: 8px;
}
.ai-box--takeaways .ai-box__label { color: var(--color-secondary); }
.ai-box__body p:last-child, .ai-box__body ul:last-child { margin-bottom: 0; }

/* ---------------------------------------------------------------------
   17. TABLE OF CONTENTS
   ------------------------------------------------------------------- */
.toc { background: var(--color-bg-alt); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: 18px 22px; margin: 0 0 28px; }
.toc__title { font-weight: 800; font-family: var(--font-heading); margin: 0 0 8px; font-size: 0.95rem; }
.toc ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.toc__item--h3 { padding-left: 18px; }
.toc a { font-size: 0.92rem; color: var(--color-text); }
.toc a:hover { color: var(--color-primary); }

/* ---------------------------------------------------------------------
   18. FAQ ACCORDION
   ------------------------------------------------------------------- */
.faq-accordion { max-width: 820px; margin: 0 auto; }
.faq-item { border-bottom: 1px solid var(--color-border); }
.faq-question {
	width: 100%; text-align: left; background: none; border: none; cursor: pointer;
	display: flex; justify-content: space-between; align-items: center; gap: 16px;
	padding: 18px 4px; font-family: var(--font-heading); font-weight: 700; font-size: 1rem; color: var(--color-secondary);
}
.faq-icon { position: relative; width: 18px; height: 18px; flex-shrink: 0; }
.faq-icon::before, .faq-icon::after {
	content: ''; position: absolute; background: var(--color-primary); transition: transform var(--transition);
}
.faq-icon::before { width: 100%; height: 2px; top: 50%; left: 0; transform: translateY(-50%); }
.faq-icon::after { width: 2px; height: 100%; top: 0; left: 50%; transform: translateX(-50%); }
.faq-question[aria-expanded="true"] .faq-icon::after { transform: translateX(-50%) scaleY(0); }
.faq-answer { padding: 0 4px 18px; color: var(--color-text-light); }
.faq-answer[hidden] { display: none; }

/* ---------------------------------------------------------------------
   19. PAGE HERO (interior pages)
   ------------------------------------------------------------------- */
.page-hero { background: var(--color-bg-alt); padding: 56px 0; text-align: center; border-bottom: 1px solid var(--color-border); }
.page-hero__title { margin-bottom: 12px; }
.page-hero__subtitle { color: var(--color-text-light); max-width: 720px; margin: 0 auto; font-size: 1.05rem; }

/* ---------------------------------------------------------------------
   20. SERVICES PAGE BLOCKS
   ------------------------------------------------------------------- */
.service-blocks { display: flex; flex-direction: column; gap: 56px; }
.service-block { display: grid; grid-template-columns: 1fr; }
.service-block__text { max-width: 680px; }
.service-block--reverse .service-block__text { margin-left: auto; }
.checklist { list-style: none; padding: 0; display: grid; gap: 10px; margin: 18px 0; }
.checklist li { padding-left: 28px; position: relative; font-size: 0.95rem; }
.checklist li::before {
	content: ''; position: absolute; left: 0; top: 6px; width: 16px; height: 16px; border-radius: 50%;
	background: var(--color-primary);
}
.checklist li::after {
	content: ''; position: absolute; left: 4px; top: 9px; width: 8px; height: 4px;
	border-left: 2px solid #fff; border-bottom: 2px solid #fff; transform: rotate(-45deg);
}

/* ---------------------------------------------------------------------
   21. PRICING
   ------------------------------------------------------------------- */
.pricing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; align-items: stretch; }
.pricing-card {
	border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: 32px;
	display: flex; flex-direction: column; position: relative; background: #fff;
}
.pricing-card--featured { border-color: var(--color-primary); box-shadow: var(--shadow-md); transform: translateY(-8px); }
.pricing-card__badge {
	position: absolute; top: -12px; left: 50%; transform: translateX(-50%);
	background: var(--color-primary); color: #fff; font-size: 0.75rem; font-weight: 700;
	padding: 4px 14px; border-radius: 999px; text-transform: uppercase; letter-spacing: 0.05em;
}
.pricing-card__title { margin-bottom: 6px; }
.pricing-card__tagline { color: var(--color-text-light); font-size: 0.9rem; margin-bottom: 14px; }
.pricing-card__price { font-family: var(--font-heading); font-size: 1.6rem; font-weight: 800; color: var(--color-primary); margin-bottom: 14px; }
.pricing-card .checklist { flex: 1; }
.pricing-note { text-align: center; color: var(--color-text-light); margin-top: 32px; }
@media (max-width: 980px) { .pricing-grid { grid-template-columns: 1fr; } .pricing-card--featured { transform: none; } }

/* ---------------------------------------------------------------------
   22. CONTACT PAGE
   ------------------------------------------------------------------- */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; }
.contact-details { list-style: none; padding: 0; margin: 24px 0; display: grid; gap: 18px; }
.contact-details li { display: flex; gap: 14px; align-items: flex-start; }
.contact-details strong { display: block; margin-bottom: 2px; }
.contact-form-card, .form-card {
	background: var(--color-bg-alt); border-radius: var(--radius-lg); padding: 32px; border: 1px solid var(--color-border);
}
.map-section iframe { display: block; }
@media (max-width: 980px) { .contact-grid { grid-template-columns: 1fr; } }

/* ---------------------------------------------------------------------
   23. ABOUT PAGE
   ------------------------------------------------------------------- */
.two-col { display: grid; grid-template-columns: 1.2fr 1fr; gap: 48px; align-items: center; }
.stat-cards { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.stat-card { background: var(--color-bg-alt); border-radius: var(--radius-md); padding: 24px; text-align: center; }
.stat-card__num { display: block; font-family: var(--font-heading); font-size: 1.8rem; font-weight: 800; color: var(--color-primary); }
.stat-card__label { font-size: 0.85rem; color: var(--color-text-light); }
.team-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.team-card { text-align: center; }
.team-card img { border-radius: var(--radius-md); margin-bottom: 12px; aspect-ratio: 1; object-fit: cover; }
.team-card h3 { margin-bottom: 2px; font-size: 1.05rem; }
.team-card__role { color: var(--color-primary); font-weight: 700; font-size: 0.85rem; margin-bottom: 6px; }
.team-card__credentials { font-size: 0.82rem; color: var(--color-text-light); }
@media (max-width: 980px) { .two-col { grid-template-columns: 1fr; } .team-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 640px) { .stat-cards { grid-template-columns: 1fr 1fr; } .team-grid { grid-template-columns: 1fr; } }

/* ---------------------------------------------------------------------
   24. LANDING PAGE (Get Started)
   ------------------------------------------------------------------- */
.landing-hero { padding-top: 48px; }
.landing-grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 48px; align-items: start; }
.landing-form-card { background: var(--color-bg-alt); border-radius: var(--radius-lg); padding: 32px; border: 1px solid var(--color-border); position: sticky; top: calc(var(--header-height) + 24px); }
.testimonial-mini { background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: 20px; margin-top: 24px; }
.testimonial-mini p { font-style: italic; margin: 10px 0; }
@media (max-width: 980px) { .landing-grid { grid-template-columns: 1fr; } .landing-form-card { position: static; } }

/* ---------------------------------------------------------------------
   25. BLOG SINGLE
   ------------------------------------------------------------------- */
.layout-with-sidebar { display: grid; grid-template-columns: 1fr 320px; gap: 48px; }
.post-categories { display: flex; gap: 8px; margin-bottom: 12px; }
.post-category { background: var(--color-bg-alt); color: var(--color-primary); font-size: 0.78rem; font-weight: 700; padding: 4px 12px; border-radius: 999px; text-transform: uppercase; letter-spacing: 0.04em; }
.post-meta { display: flex; flex-wrap: wrap; gap: 16px; align-items: center; color: var(--color-text-light); font-size: 0.88rem; margin-bottom: 24px; }
.post-meta__author { display: flex; align-items: center; gap: 8px; }
.post-meta img { border-radius: 50%; }
.post-featured-image { margin-bottom: 28px; border-radius: var(--radius-md); overflow: hidden; }
.post-body :is(h2,h3) { margin-top: 1.6em; }
.post-body img { border-radius: var(--radius-md); }
.post-body blockquote { border-left: 4px solid var(--color-primary); margin: 1.5em 0; padding: 0.5em 1.2em; background: var(--color-bg-alt); border-radius: 0 var(--radius-sm) var(--radius-sm) 0; font-style: italic; }
.post-tags { display: flex; flex-wrap: wrap; gap: 8px; margin: 24px 0; }
.post-tag { background: var(--color-bg-alt); padding: 4px 12px; border-radius: 999px; font-size: 0.8rem; }
.post-share { display: flex; align-items: center; gap: 10px; margin: 16px 0; }
.post-share a { display: flex; align-items: center; justify-content: center; width: 34px; height: 34px; border-radius: 50%; background: var(--color-bg-alt); }
.post-share a:hover { background: var(--color-primary); }

.author-box {
	display: flex; gap: 18px; align-items: center; background: var(--color-bg-alt);
	border-radius: var(--radius-md); padding: 24px; margin: 36px 0;
}
.author-box__avatar img { border-radius: 50%; }
.author-box__label { font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--color-text-light); margin: 0; }
.author-box__name { margin: 4px 0; font-size: 1.1rem; }
.author-box__bio { margin: 0; font-size: 0.9rem; color: var(--color-text-light); }

.in-content-cta { background: var(--color-secondary); color: #fff; border-radius: var(--radius-lg); padding: 28px; margin: 36px 0; }
.in-content-cta .lead-form__title { color: #fff; }
.in-content-cta input, .in-content-cta select, .in-content-cta textarea { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.18); color: #fff; }
.in-content-cta input::placeholder, .in-content-cta textarea::placeholder { color: #cfd8ea; }
.in-content-cta .lead-form__privacy { color: #cfd8ea; }
.related-posts { margin: 40px 0; }

@media (max-width: 980px) { .layout-with-sidebar { grid-template-columns: 1fr; } }

/* ---------------------------------------------------------------------
   26. SIDEBAR / WIDGETS
   ------------------------------------------------------------------- */
.widget-area .widget { background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: 22px; margin-bottom: 24px; }
.widget--cta { background: var(--color-bg-alt); }
.widget-title { font-size: 1rem; margin-bottom: 14px; }
.widget-area ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.widget-area a { color: var(--color-text); font-size: 0.92rem; }
.widget-area a:hover { color: var(--color-primary); }

/* ---------------------------------------------------------------------
   27. PAGINATION
   ------------------------------------------------------------------- */
.pagination { display: flex; gap: 8px; justify-content: center; margin-top: 40px; flex-wrap: wrap; }
.pagination .page-numbers {
	display: inline-flex; align-items: center; justify-content: center; min-width: 40px; height: 40px;
	border: 1px solid var(--color-border); border-radius: var(--radius-sm); color: var(--color-text); font-weight: 600; padding: 0 12px;
}
.pagination .page-numbers.current { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }
.pagination a.page-numbers:hover { border-color: var(--color-primary); color: var(--color-primary); }

/* ---------------------------------------------------------------------
   28. STICKY MOBILE CTA BAR
   ------------------------------------------------------------------- */
.sticky-cta {
	position: fixed; bottom: 0; left: 0; right: 0; z-index: 200; display: none;
	background: #fff; box-shadow: 0 -4px 20px rgba(11,27,51,0.12);
}
.sticky-cta__item {
	flex: 1; display: flex; flex-direction: column; align-items: center; gap: 4px;
	padding: 10px 0; font-size: 0.78rem; font-weight: 700; color: var(--color-secondary);
}
.sticky-cta__item--primary { background: var(--color-primary); color: #fff; }
@media (max-width: 768px) {
	.sticky-cta { display: flex; }
	body { padding-bottom: 64px; }
}

/* ---------------------------------------------------------------------
   29. EXIT-INTENT MODAL
   ------------------------------------------------------------------- */
.exit-modal { position: fixed; inset: 0; z-index: 999; display: flex; align-items: center; justify-content: center; }
.exit-modal[hidden] { display: none; }
.exit-modal__overlay { position: absolute; inset: 0; background: rgba(11,27,51,0.6); }
.exit-modal__panel {
	position: relative; background: #fff; border-radius: var(--radius-lg); padding: 36px;
	max-width: 440px; width: 92%; box-shadow: var(--shadow-lg); max-height: 90vh; overflow-y: auto;
}
.exit-modal__close { position: absolute; top: 12px; right: 16px; background: none; border: none; font-size: 1.6rem; cursor: pointer; color: var(--color-text-light); line-height: 1; }

/* ---------------------------------------------------------------------
   30. ICONS (inline SVG-via-mask, single-color, no icon font request)
   ------------------------------------------------------------------- */
.icon { display: inline-block; width: 18px; height: 18px; background-color: currentColor; -webkit-mask-size: contain; mask-size: contain; -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat; -webkit-mask-position: center; mask-position: center; }
.icon--phone    { -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M6.6 10.8c1.4 2.8 3.8 5.2 6.6 6.6l2.2-2.2c.3-.3.7-.4 1-.2 1.2.5 2.5.8 3.8.8.6 0 1 .4 1 1V21c0 .6-.4 1-1 1C10.5 22 2 13.5 2 3c0-.6.4-1 1-1h3.9c.6 0 1 .4 1 1 0 1.3.3 2.6.8 3.8.1.4 0 .8-.2 1L6.6 10.8z'/%3E%3C/svg%3E"); mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M6.6 10.8c1.4 2.8 3.8 5.2 6.6 6.6l2.2-2.2c.3-.3.7-.4 1-.2 1.2.5 2.5.8 3.8.8.6 0 1 .4 1 1V21c0 .6-.4 1-1 1C10.5 22 2 13.5 2 3c0-.6.4-1 1-1h3.9c.6 0 1 .4 1 1 0 1.3.3 2.6.8 3.8.1.4 0 .8-.2 1L6.6 10.8z'/%3E%3C/svg%3E"); }
.icon--mail     { -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M2 4h20v16H2V4zm2 2v.01L12 13l8-6.99V6H4zm16 12V8.4l-8 7-8-7V18h16z'/%3E%3C/svg%3E"); mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M2 4h20v16H2V4zm2 2v.01L12 13l8-6.99V6H4zm16 12V8.4l-8 7-8-7V18h16z'/%3E%3C/svg%3E"); }
.icon--check    { -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E"); mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E"); color: var(--color-success); }
.icon--whatsapp { -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M20.5 3.5A11 11 0 0 0 3 17.4L2 22l4.7-1.2A11 11 0 1 0 20.5 3.5zM12 20a8 8 0 0 1-4.1-1.1l-.3-.2-3 .8.8-2.9-.2-.3A8 8 0 1 1 12 20zm4.4-5.9c-.2-.1-1.4-.7-1.6-.8-.2-.1-.4-.1-.6.1-.2.2-.6.8-.8 1-.1.2-.3.2-.5.1-1.4-.6-2.3-2-2.6-2.4-.1-.2 0-.4.1-.5.2-.2.4-.5.5-.7.1-.2.1-.4 0-.5-.1-.2-.6-1.5-.8-2-.2-.5-.4-.4-.6-.4h-.5c-.2 0-.5.1-.7.3-.2.2-.9 1-.9 2.3 0 1.4 1 2.7 1.1 2.9.1.2 1.9 3 4.7 4.1 2.4 1 2.9.8 3.4.7.5-.1 1.5-.6 1.7-1.2.2-.6.2-1.1.1-1.2-.1-.1-.2-.2-.4-.3z'/%3E%3C/svg%3E"); mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M20.5 3.5A11 11 0 0 0 3 17.4L2 22l4.7-1.2A11 11 0 1 0 20.5 3.5zM12 20a8 8 0 0 1-4.1-1.1l-.3-.2-3 .8.8-2.9-.2-.3A8 8 0 1 1 12 20zm4.4-5.9c-.2-.1-1.4-.7-1.6-.8-.2-.1-.4-.1-.6.1-.2.2-.6.8-.8 1-.1.2-.3.2-.5.1-1.4-.6-2.3-2-2.6-2.4-.1-.2 0-.4.1-.5.2-.2.4-.5.5-.7.1-.2.1-.4 0-.5-.1-.2-.6-1.5-.8-2-.2-.5-.4-.4-.6-.4h-.5c-.2 0-.5.1-.7.3-.2.2-.9 1-.9 2.3 0 1.4 1 2.7 1.1 2.9.1.2 1.9 3 4.7 4.1 2.4 1 2.9.8 3.4.7.5-.1 1.5-.6 1.7-1.2.2-.6.2-1.1.1-1.2-.1-.1-.2-.2-.4-.3z'/%3E%3C/svg%3E"); color: #25D366; }
.icon--quote    { -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9.6 12H6c0-2.2 1.8-4 4-4V6c-3.3 0-6 2.7-6 6v6h6v-6h-.4zm10 0H16c0-2.2 1.8-4 4-4V6c-3.3 0-6 2.7-6 6v6h6v-6h-.4z'/%3E%3C/svg%3E"); mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9.6 12H6c0-2.2 1.8-4 4-4V6c-3.3 0-6 2.7-6 6v6h6v-6h-.4zm10 0H16c0-2.2 1.8-4 4-4V6c-3.3 0-6 2.7-6 6v6h6v-6h-.4z'/%3E%3C/svg%3E"); }
.icon--pin      { -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2C8.1 2 5 5.1 5 9c0 5.2 7 13 7 13s7-7.8 7-13c0-3.9-3.1-7-7-7zm0 9.5A2.5 2.5 0 1 1 12 6a2.5 2.5 0 0 1 0 5.5z'/%3E%3C/svg%3E"); mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2C8.1 2 5 5.1 5 9c0 5.2 7 13 7 13s7-7.8 7-13c0-3.9-3.1-7-7-7zm0 9.5A2.5 2.5 0 1 1 12 6a2.5 2.5 0 0 1 0 5.5z'/%3E%3C/svg%3E"); }
.icon--clock    { -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2a10 10 0 1 0 0 20 10 10 0 0 0 0-20zm1 10.6V7h-2v6.4l4.5 2.7 1-1.7-3.5-2.1z'/%3E%3C/svg%3E"); mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2a10 10 0 1 0 0 20 10 10 0 0 0 0-20zm1 10.6V7h-2v6.4l4.5 2.7 1-1.7-3.5-2.1z'/%3E%3C/svg%3E"); }
.icon--search   { -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M21 20l-5.6-5.6a7.5 7.5 0 1 0-1.4 1.4L20 21l1-1zM4 10.5A5.5 5.5 0 1 1 9.5 16 5.5 5.5 0 0 1 4 10.5z'/%3E%3C/svg%3E"); mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M21 20l-5.6-5.6a7.5 7.5 0 1 0-1.4 1.4L20 21l1-1zM4 10.5A5.5 5.5 0 1 1 9.5 16 5.5 5.5 0 0 1 4 10.5z'/%3E%3C/svg%3E"); }
.icon--facebook { -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M22 12a10 10 0 1 0-11.6 9.9v-7H7.9V12h2.5V9.8c0-2.5 1.5-3.9 3.8-3.9 1.1 0 2.2.2 2.2.2v2.4h-1.2c-1.2 0-1.6.8-1.6 1.6V12h2.8l-.4 2.9h-2.4v7A10 10 0 0 0 22 12z'/%3E%3C/svg%3E"); mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M22 12a10 10 0 1 0-11.6 9.9v-7H7.9V12h2.5V9.8c0-2.5 1.5-3.9 3.8-3.9 1.1 0 2.2.2 2.2.2v2.4h-1.2c-1.2 0-1.6.8-1.6 1.6V12h2.8l-.4 2.9h-2.4v7A10 10 0 0 0 22 12z'/%3E%3C/svg%3E"); }
.icon--twitter  { -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M3 3l7.5 9.6L3.4 21H6l5.8-6.6L16.5 21H21l-7.8-10L20.6 3H18l-5.3 6.1L8.5 3H3z'/%3E%3C/svg%3E"); mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M3 3l7.5 9.6L3.4 21H6l5.8-6.6L16.5 21H21l-7.8-10L20.6 3H18l-5.3 6.1L8.5 3H3z'/%3E%3C/svg%3E"); }
.icon--youtube  { -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M23 12s0-3.2-.4-4.6c-.2-.9-.9-1.6-1.8-1.8C19.1 5 12 5 12 5s-7.1 0-8.8.6c-.9.2-1.6.9-1.8 1.8C1 8.8 1 12 1 12s0 3.2.4 4.6c.2.9.9 1.6 1.8 1.8C4.9 19 12 19 12 19s7.1 0 8.8-.6c.9-.2 1.6-.9 1.8-1.8.4-1.4.4-4.6.4-4.6zM10 15.5v-7l6 3.5-6 3.5z'/%3E%3C/svg%3E"); mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M23 12s0-3.2-.4-4.6c-.2-.9-.9-1.6-1.8-1.8C19.1 5 12 5 12 5s-7.1 0-8.8.6c-.9.2-1.6.9-1.8 1.8C1 8.8 1 12 1 12s0 3.2.4 4.6c.2.9.9 1.6 1.8 1.8C4.9 19 12 19 12 19s7.1 0 8.8-.6c.9-.2 1.6-.9 1.8-1.8.4-1.4.4-4.6.4-4.6zM10 15.5v-7l6 3.5-6 3.5z'/%3E%3C/svg%3E"); }
.icon--linkedin { -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M4.98 3.5C4.98 4.6 4.1 5.5 3 5.5S1 4.6 1 3.5 1.9 1.5 3 1.5s1.98.9 1.98 2zM1.5 8.5h3V22h-3V8.5zM9 8.5h2.9v1.8h.04c.4-.8 1.4-1.8 3.1-1.8 3.3 0 3.9 2.2 3.9 5V22h-3v-6.1c0-1.5 0-3.4-2.1-3.4s-2.4 1.6-2.4 3.3V22H9V8.5z'/%3E%3C/svg%3E"); mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M4.98 3.5C4.98 4.6 4.1 5.5 3 5.5S1 4.6 1 3.5 1.9 1.5 3 1.5s1.98.9 1.98 2zM1.5 8.5h3V22h-3V8.5zM9 8.5h2.9v1.8h.04c.4-.8 1.4-1.8 3.1-1.8 3.3 0 3.9 2.2 3.9 5V22h-3v-6.1c0-1.5 0-3.4-2.1-3.4s-2.4 1.6-2.4 3.3V22H9V8.5z'/%3E%3C/svg%3E"); }

/* ---------------------------------------------------------------------
   31. ERROR 404
   ------------------------------------------------------------------- */
.error-404 { text-align: center; padding: 80px 0; }
.error-404 h1 { font-size: 6rem; color: var(--color-primary); margin-bottom: 0; }
.error-404__links { display: flex; gap: 12px; justify-content: center; margin-top: 24px; flex-wrap: wrap; }
.error-404 .search-form { max-width: 480px; margin: 24px auto; display: flex; }
.search-form { display: flex; }
.search-field { flex: 1; border-radius: var(--radius-sm) 0 0 var(--radius-sm) !important; }
.search-submit { border: 1px solid var(--color-primary); background: var(--color-primary); color: #fff; border-radius: 0 var(--radius-sm) var(--radius-sm) 0; padding: 0 16px; cursor: pointer; }

/* ---------------------------------------------------------------------
   32. ACCESSIBILITY / PRINT / REDUCED MOTION
   ------------------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after { transition: none !important; animation: none !important; scroll-behavior: auto !important; }
}
:focus-visible { outline: 3px solid var(--color-primary); outline-offset: 2px; }
