﻿/* Softlance Professional Theme — Light & Dark */

:root,
[data-theme="dark"] {
	--sl-primary: #2563EB;
	--sl-primary-dark: #1D4ED8;
	--sl-primary-glow: rgba(37, 99, 235, 0.45);
	--sl-dark: #0A1128;
	--sl-dark-alt: #0D1526;
	--sl-muted: #94a3b8;
	--sl-container: 1200px;
	--sl-radius: 12px;
	--sl-radius-lg: 16px;
	--sl-body-bg: #ffffff;
	--sl-body-text: #111827;
	--sl-header-bg: rgba(10, 14, 23, 0.97);
	--sl-header-border: rgba(255, 255, 255, 0.06);
	--sl-header-text: #e2e8f0;
	--sl-header-muted: #94a3b8;
	--sl-nav-hover: #60a5fa;
	--sl-section-bg: #ffffff;
	--sl-card-bg: #ffffff;
	--sl-card-border: #e2e8f0;
	--sl-desc-color: #64748b;
}

[data-theme="light"] {
	--sl-body-bg: #f8fafc;
	--sl-body-text: #0f172a;
	--sl-header-bg: rgba(255, 255, 255, 0.97);
	--sl-header-border: rgba(15, 23, 42, 0.08);
	--sl-header-text: #0f172a;
	--sl-header-muted: #64748b;
	--sl-nav-hover: #0052ff;
	--sl-section-bg: #ffffff;
	--sl-card-bg: #ffffff;
	--sl-card-border: #e2e8f0;
	--sl-desc-color: #64748b;
	--sl-dark: #0f172a;
	--sl-dark-alt: #1e293b;
}

*, *::before, *::after { box-sizing: border-box; }

html {
	margin: 0;
	padding: 0;
	scroll-behavior: smooth;
	background: var(--sl-body-bg);
	overflow-x: hidden; /* fallback: older Safari/Android that don't support clip */
	overflow-x: clip;   /* preferred: clips without affecting position:sticky */
}

body {
	overflow-x: clip; /* belt-and-suspenders: prevent body from scrolling wider than viewport */
}

body {
	margin: 0;
	padding: 0;
	font-family: 'Plus Jakarta Sans', Inter, system-ui, sans-serif;
	-webkit-font-smoothing: antialiased;
	color: var(--sl-body-text);
	background: var(--sl-body-bg);
}

/* Block theme — flush header to top (no gap above menu) */
.wp-site-blocks,
.has-global-padding,
.is-root-container {
	padding-top: 0 !important;
	padding-bottom: 0 !important;
	margin-top: 0 !important;
	--wp--style--root--padding-top: 0 !important;
	--wp--style--root--padding-bottom: 0 !important;
	--wp--style--root--padding-left: 0 !important;
	--wp--style--root--padding-right: 0 !important;
}

html {
	margin: 0 !important;
	padding: 0 !important;
	scroll-padding-top: 0;
}

/* WP admin bar — sticky header offset */
body.admin-bar {
	--sl-admin-bar-height: 32px;
}

@media screen and (max-width: 782px) {
	body.admin-bar {
		--sl-admin-bar-height: 46px;
	}
}

body.admin-bar {
	--sl-site-header-offset: calc(var(--sl-header-height) + var(--sl-admin-bar-height, 0px));
}

body.admin-bar .wp-site-blocks > header.wp-block-template-part,
body.admin-bar .wp-block-template-part:has(.softlance-site-header) {
	top: var(--sl-admin-bar-height, 32px);
}

@media screen and (max-width: 782px) {
	body.admin-bar .wp-site-blocks > header.wp-block-template-part,
	body.admin-bar .wp-block-template-part:has(.softlance-site-header) {
		top: 46px;
	}
}

/* Sticky navigation — stick the template part (full-page scroll parent) */
.wp-site-blocks > header.wp-block-template-part,
.wp-block-template-part:has(.softlance-site-header) {
	position: sticky;
	top: 0;
	z-index: 1000;
	width: 100%;
	background: var(--sl-header-bg, #fff);
}

.wp-block-template-part:has(.softlance-site-header) {
	--sl-site-header-offset: var(--sl-header-height);
}

.wp-block-template-part:has(.softlance-site-header.is-scrolled) {
	box-shadow: 0 4px 20px rgba(15, 23, 42, 0.08);
}

@media (min-width: 901px) {
	.wp-block-template-part:has(.softlance-site-header:not(.softlance-site-header--transparent)) {
		--sl-site-header-offset: calc(var(--sl-header-height) + var(--sl-topbar-height));
	}
}

/* Hide invisible BOM text nodes if any plugin/template still emits them */
.wp-site-blocks {
	font-size: inherit;
}

.wp-site-blocks > *,
.wp-site-blocks > *:first-child,
.wp-site-blocks > .wp-block-template-part,
.wp-site-blocks > .wp-block-template-part:first-child {
	margin-block-start: 0 !important;
	margin-top: 0 !important;
	padding-top: 0 !important;
}

.wp-block-template-part,
.wp-block-template-part-header,
.wp-block-softlance-header,
.wp-block-softlance-footer {
	margin: 0 !important;
	padding: 0 !important;
	max-width: none !important;
}

:root :where(.is-layout-flow) > .wp-block-template-part,
:root :where(.is-layout-flow) > .wp-block-softlance-header,
:root :where(.is-layout-flow) > .softlance-header {
	margin-block-start: 0 !important;
}

.wp-block-post-content,
.wp-block-post-content > *,
main.wp-block-group {
	margin-top: 0 !important;
	padding-top: 0 !important;
}

.wp-block-softlance-header.alignfull,
.wp-block-softlance-footer.alignfull {
	max-width: none !important;
	width: 100% !important;
	margin-left: 0 !important;
	margin-right: 0 !important;
}

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

.softlance-container {
	width: min(100% - 2rem, var(--sl-container));
	margin-inline: auto;
}

/* Skip link (SEO / a11y) */
.softlance-skip-link {
	position: absolute;
	left: -9999px;
	top: 0;
	z-index: 100000;
	padding: .75rem 1rem;
	background: var(--sl-primary);
	color: #fff;
	font-weight: 600;
	text-decoration: none;
	border-radius: 0 0 8px 0;
}
.softlance-skip-link:focus {
	left: 0;
	outline: 2px solid #fff;
	outline-offset: 2px;
}

/* (admin-bar header offset defined above with body.admin-bar) */

/* Sections */
.softlance-section { padding: clamp(3rem, 6vw, 5rem) 0; background: var(--sl-section-bg); }
.softlance-section--dark { background: var(--sl-dark); color: #e2e8f0; }
.softlance-section--dark-alt { background: var(--sl-dark-alt); color: #cbd5e1; }
.softlance-section--accent {
	background: linear-gradient(135deg, var(--sl-primary), var(--sl-primary-dark));
	color: #fff;
}

.softlance-section-label {
	display: block;
	color: var(--sl-primary);
	font-size: .8125rem;
	font-weight: 700;
	letter-spacing: .12em;
	text-transform: uppercase;
	margin-bottom: .75rem;
}

.softlance-section--dark .softlance-section-label,
.softlance-section--dark-alt .softlance-section-label { color: #60a5fa; }

.softlance-section-title {
	font-family: Poppins, sans-serif;
	font-size: clamp(1.75rem, 4vw, 2.5rem);
	line-height: 1.15;
	margin: 0 0 1rem;
}

.softlance-section-description {
	color: var(--sl-desc-color);
	line-height: 1.7;
	margin: 0 0 1.5rem;
	max-width: 640px;
}

.softlance-section--dark .softlance-section-description,
.softlance-section--dark-alt .softlance-section-description { color: var(--sl-muted); }

.softlance-section-header { margin-bottom: 2.5rem; text-align: center; }
.softlance-section-header--row {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	justify-content: space-between;
	gap: 1rem;
	text-align: left;
}

.softlance-section-header--row .softlance-section-header__content { flex: 1; min-width: 220px; }

/* Buttons */
.softlance-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: .875rem 1.75rem;
	border-radius: 999px;
	font-weight: 600;
	font-size: .9375rem;
	text-decoration: none;
	border: 2px solid transparent;
	transition: .2s;
	cursor: pointer;
}

.softlance-btn--primary {
	background: var(--sl-primary);
	color: #fff;
	box-shadow: 0 4px 14px var(--sl-primary-glow);
}
.softlance-btn--primary:hover {
	background: var(--sl-primary-dark);
	color: #fff;
	box-shadow: 0 6px 20px var(--sl-primary-glow);
	transform: translateY(-1px);
}
.softlance-btn--cta {
	font-size: 1rem;
	padding: .8125rem 1.5rem;
	font-weight: 700;
	letter-spacing: .01em;
	animation: softlance-cta-pulse 2.5s ease-in-out infinite;
}
@keyframes softlance-cta-pulse {
	0%, 100% { box-shadow: 0 4px 14px var(--sl-primary-glow); }
	50% { box-shadow: 0 4px 22px var(--sl-primary-glow), 0 0 0 4px rgba(0, 82, 255, 0.12); }
}
.softlance-btn--secondary { background: transparent; border-color: rgba(255,255,255,.35); color: #fff; }
.softlance-btn--secondary:hover { border-color: #fff; background: rgba(255,255,255,.08); }
.softlance-btn--lg { padding: 1.0625rem 2.125rem; font-size: 1.0625rem; }

.softlance-link { color: var(--sl-primary); font-weight: 600; text-decoration: none; font-size: .875rem; }
.softlance-link:hover { text-decoration: underline; }
.softlance-link--arrow::after { content: ' →'; }

/* Header — flush to viewport top */
.softlance-header {
	position: relative;
	top: auto;
	z-index: 1;
	margin: 0;
	padding: 0;
	width: 100%;
	overflow: visible;
	background: var(--sl-header-bg);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	border-bottom: 1px solid var(--sl-header-border);
	transition: background 0.25s, border-color 0.25s, box-shadow 0.25s;
}

.softlance-site-header.is-scrolled .softlance-header,
.softlance-header.is-scrolled {
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08);
}

.softlance-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: .75rem;
	padding: .5rem 0;
	min-height: 64px;
	overflow: visible;
}

.softlance-header__brand { display: flex; align-items: center; gap: .625rem; min-width: 0; flex-shrink: 0; }
.softlance-header__logo-link { display: flex; align-items: center; text-decoration: none; line-height: 0; }

.softlance-logo-wrap {
	display: inline-flex;
	align-items: center;
	line-height: 0;
}

.softlance-logo {
	max-height: 44px;
	width: auto;
	height: auto;
}

/* Dark logo = colored mark for light header backgrounds */
.softlance-logo--dark { display: none; }
.softlance-logo--light { display: block; }

[data-theme="light"] .softlance-logo--dark { display: block; }
[data-theme="light"] .softlance-logo--light { display: none; }

.softlance-site-header--transparent:not(.is-scrolled) .softlance-logo--dark,
.softlance-header.is-transparent:not(.is-scrolled) .softlance-logo--dark {
	display: none;
}

.softlance-site-header--transparent:not(.is-scrolled) .softlance-logo--light,
.softlance-header.is-transparent:not(.is-scrolled) .softlance-logo--light {
	display: block;
}

.softlance-site-header--transparent.is-scrolled .softlance-logo--dark,
.softlance-header.is-transparent.is-scrolled .softlance-logo--dark {
	display: block;
}

.softlance-site-header--transparent.is-scrolled .softlance-logo--light,
.softlance-header.is-transparent.is-scrolled .softlance-logo--light {
	display: none;
}

body.softlance-front-page .softlance-logo--dark { display: none !important; }
body.softlance-front-page .softlance-logo--light { display: block !important; }

/* Scope logo-swap to header brand only — drawer has its own logo with always-light rules */
body.softlance-nav-open .softlance-header__brand .softlance-logo--dark { display: block !important; }
body.softlance-nav-open .softlance-header__brand .softlance-logo--light { display: none !important; }

[data-theme="dark"] body.softlance-nav-open .softlance-header__brand .softlance-logo--dark { display: none !important; }
[data-theme="dark"] body.softlance-nav-open .softlance-header__brand .softlance-logo--light { display: block !important; }

.softlance-logo--custom { display: block !important; }

.softlance-header__tagline {
	color: var(--sl-header-muted);
	font-size: .625rem;
	font-weight: 600;
	letter-spacing: .14em;
	text-transform: uppercase;
	white-space: nowrap;
}

.softlance-header__nav { display: flex; align-items: center; flex: 1; justify-content: center; overflow: visible; }

.softlance-menu {
	display: flex;
	align-items: center;
	gap: .25rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.softlance-menu > .menu-item {
	position: relative;
	display: flex;
	align-items: center;
}

.softlance-menu a,
.softlance-menu .softlance-menu__link {
	color: var(--sl-header-text);
	text-decoration: none;
	font-weight: 500;
	font-size: .9375rem;
	white-space: nowrap;
	transition: color .15s;
	display: inline-flex;
	align-items: center;
	padding: .5rem .625rem;
	border-radius: 8px;
}
.softlance-menu a:hover,
.softlance-menu .softlance-menu__link:hover { color: var(--sl-nav-hover); }

.softlance-menu > .menu-item-has-children > .softlance-menu__link--has-children::after,
.softlance-menu > .menu-item-has-children > a::after {
	content: '';
	width: .4rem;
	height: .4rem;
	margin-left: .35rem;
	border-right: 1.5px solid currentColor;
	border-bottom: 1.5px solid currentColor;
	transform: rotate(45deg) translateY(-1px);
	opacity: .7;
}

/* Dropdown submenus — desktop */
.softlance-menu .sub-menu {
	position: absolute;
	top: 100%;
	left: 0;
	min-width: 240px;
	list-style: none;
	margin: 0;
	padding: .85rem .5rem .5rem;
	background: var(--sl-header-bg);
	border: 1px solid var(--sl-header-border);
	border-radius: var(--sl-radius);
	box-shadow: 0 16px 40px rgba(0, 0, 0, 0.18);
	opacity: 0;
	visibility: hidden;
	transform: translateY(6px);
	transition: opacity .2s, transform .2s, visibility .2s;
	z-index: 1100;
	pointer-events: none;
}

.softlance-menu .sub-menu .menu-item {
	display: block;
	width: 100%;
}

.softlance-menu .sub-menu a,
.softlance-menu .sub-menu .softlance-menu__link {
	display: block;
	width: 100%;
	padding: .625rem .875rem;
	white-space: normal;
	border-radius: 6px;
	font-size: .875rem;
}

.softlance-menu .sub-menu a:hover,
.softlance-menu .sub-menu .softlance-menu__link:hover {
	background: rgba(0, 82, 255, 0.08);
	color: var(--sl-nav-hover);
}

.softlance-menu > .menu-item-has-children:hover,
.softlance-menu > .menu-item-has-children:focus-within,
.softlance-menu > .menu-item-has-children.is-submenu-open {
	z-index: 1101;
}

.softlance-menu > .menu-item-has-children:hover > .sub-menu,
.softlance-menu > .menu-item-has-children:focus-within > .sub-menu,
.softlance-menu > .menu-item-has-children.is-submenu-open > .sub-menu,
.softlance-menu .sub-menu .menu-item-has-children:hover > .sub-menu,
.softlance-menu .sub-menu .menu-item-has-children:focus-within > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
	pointer-events: auto;
}

.softlance-menu .sub-menu .sub-menu {
	top: 0;
	left: calc(100% + .35rem);
}

.softlance-submenu-toggle {
	display: none;
	align-items: center;
	justify-content: center;
	width: 2rem;
	height: 2rem;
	margin-left: -.25rem;
	border: 0;
	border-radius: 6px;
	background: transparent;
	color: var(--sl-header-text);
	cursor: pointer;
	flex-shrink: 0;
}

.softlance-submenu-toggle__icon {
	width: .5rem;
	height: .5rem;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: rotate(45deg);
	transition: transform .2s;
}

.menu-item-has-children.is-submenu-open > .softlance-submenu-toggle .softlance-submenu-toggle__icon {
	transform: rotate(-135deg);
}

.softlance-header__actions {
	display: flex;
	align-items: center;
	gap: .625rem;
	flex-shrink: 0;
}

.softlance-header__phone {
	color: var(--sl-header-text);
	text-decoration: none;
	font-weight: 600;
	font-size: .8125rem;
	white-space: nowrap;
	padding: .5rem .75rem;
	border-radius: 999px;
	border: 1px solid var(--sl-header-border);
	transition: .15s;
}
.softlance-header__phone:hover {
	color: var(--sl-primary);
	border-color: var(--sl-primary);
}

.softlance-header__theme-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border: 1px solid var(--sl-header-border);
	border-radius: 10px;
	background: transparent;
	cursor: pointer;
	color: var(--sl-header-text);
	font-size: 1rem;
	line-height: 1;
	transition: .15s;
}
.softlance-header__theme-toggle:hover {
	border-color: var(--sl-primary);
	color: var(--sl-primary);
}

[data-theme="dark"] .softlance-header__theme-icon--sun { display: inline; }
[data-theme="dark"] .softlance-header__theme-icon--moon { display: none; }
[data-theme="light"] .softlance-header__theme-icon--sun { display: none; }
[data-theme="light"] .softlance-header__theme-icon--moon { display: inline; }

.softlance-header__cta { padding: .6875rem 1.125rem; white-space: nowrap; }

.softlance-header__toggle {
	display: none;
	width: 44px;
	height: 44px;
	border: 1px solid var(--sl-header-border);
	border-radius: 10px;
	background: transparent;
	cursor: pointer;
	padding: 0;
	flex-shrink: 0;
}

.softlance-header__toggle-bar {
	display: block;
	width: 18px;
	height: 2px;
	margin: 4px auto;
	background: var(--sl-header-text);
}

/* Floating high-visibility CTA */
.softlance-floating-cta {
	position: fixed;
	right: 1rem;
	bottom: 1rem;
	z-index: 999;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: .5rem;
	opacity: 0;
	transform: translateY(12px);
	pointer-events: none;
	transition: .25s ease;
}
.softlance-floating-cta.is-visible {
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
}
.softlance-floating-cta__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: .375rem;
	padding: .875rem 1.25rem;
	border-radius: 999px;
	font-weight: 700;
	font-size: .9375rem;
	text-decoration: none;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.18);
	transition: .15s;
}
.softlance-floating-cta__btn--phone {
	background: var(--sl-header-bg);
	color: var(--sl-header-text);
	border: 1px solid var(--sl-header-border);
}
.softlance-floating-cta__btn--primary {
	background: var(--sl-primary);
	color: #fff;
	box-shadow: 0 8px 28px var(--sl-primary-glow);
}
.softlance-floating-cta__btn:hover { transform: translateY(-2px); }

/* Hero */
.softlance-hero { background: var(--sl-dark); color: #fff; position: relative; overflow: hidden; }
.softlance-hero::before {
	content: ''; position: absolute; inset: 0; pointer-events: none;
	background: radial-gradient(circle at 20% 80%, rgba(0,82,255,.15), transparent 50%);
}

.softlance-hero__inner {
	position: relative; z-index: 1;
	display: grid; grid-template-columns: 1.1fr .9fr;
	gap: clamp(1.5rem, 4vw, 3rem); align-items: center;
}

.softlance-hero__title {
	font-family: Poppins, sans-serif;
	font-size: clamp(2rem, 5vw, 3.5rem);
	line-height: 1.08; margin: 0 0 1rem;
}

.softlance-hero__highlight { display: block; color: var(--sl-primary); }

.softlance-hero__description { color: #cbd5e1; font-size: 1.05rem; line-height: 1.7; margin: 0 0 1.5rem; }

.softlance-hero__checklist { list-style: none; padding: 0; margin: 0 0 2rem; }
.softlance-hero__checklist-item {
	display: flex; align-items: center; gap: .625rem;
	margin-bottom: .625rem; color: #cbd5e1; font-size: .9375rem;
}

.softlance-hero__checklist-item::before {
	content: '✓'; display: inline-flex; align-items: center; justify-content: center;
	width: 1.25rem; height: 1.25rem; border-radius: 50%;
	background: rgba(0,82,255,.2); color: var(--sl-primary);
	font-size: .6875rem; font-weight: 700; flex-shrink: 0;
}

.softlance-hero__actions { display: flex; flex-wrap: wrap; gap: 1rem; }
.softlance-hero__media { display: flex; justify-content: center; }
.softlance-hero__image { max-width: 520px; animation: sl-float 6s ease-in-out infinite; }

@keyframes sl-float {
	0%, 100% { transform: translateY(0); }
	50% { transform: translateY(-14px); }
}

/* Trusted logos */
.softlance-trusted-logos__heading {
	text-align: center; color: #64748b; font-size: .75rem; font-weight: 600;
	letter-spacing: .1em; text-transform: uppercase; margin: 0 0 1.25rem;
}

.softlance-trusted-logos__grid {
	display: grid; grid-template-columns: repeat(6, 1fr); gap: 1rem;
	align-items: center; text-align: center; opacity: .55; filter: grayscale(1);
}

.softlance-trusted-logos__name { font-weight: 700; font-size: clamp(.85rem, 2vw, 1.1rem); }

.softlance-trusted-logos__logo {
	display: block;
	max-width: 100%;
	max-height: 2.5rem;
	width: auto;
	height: auto;
	margin: 0 auto;
	object-fit: contain;
}

.softlance-trusted-logos__item {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 2.5rem;
}

/* Services */
.softlance-services__grid {
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem;
}

.softlance-services__card {
	background: var(--sl-card-bg); border: 1px solid var(--sl-card-border); border-radius: var(--sl-radius-lg);
	padding: 1.75rem; height: 100%; transition: .25s;
}

.softlance-services__card:hover { transform: translateY(-4px); box-shadow: 0 12px 40px rgba(0,0,0,.12); }

.softlance-services__icon {
	width: 3rem; height: 3rem; border-radius: 10px;
	display: flex; align-items: center; justify-content: center;
	font-size: 1.25rem; margin-bottom: 1rem;
}

.softlance-services__icon[data-icon]::before { content: attr(data-icon); }

.softlance-services__icon-img {
	width: 1.5rem;
	height: 1.5rem;
	object-fit: contain;
	display: block;
}

.softlance-icon-blue { background: rgba(0,82,255,.12); }
.softlance-icon-purple { background: rgba(139,92,246,.12); }
.softlance-icon-pink { background: rgba(236,72,153,.12); }
.softlance-icon-green { background: rgba(16,185,129,.12); }

.softlance-services__title { margin: 0 0 .625rem; font-size: 1.125rem; font-family: Poppins, sans-serif; }
.softlance-services__text { color: #64748b; margin: 0 0 1rem; line-height: 1.6; font-size: .9375rem; }
.softlance-services__link { color: var(--sl-primary); font-weight: 600; text-decoration: none; font-size: .875rem; }

/* Why choose us */
.softlance-why-choose-us .softlance-container {
	display: grid; grid-template-columns: .9fr 1.1fr;
	gap: clamp(1.5rem, 4vw, 3rem); align-items: start;
}

.softlance-why-choose-us__highlight { color: var(--sl-primary); }

.softlance-why-choose-us__grid {
	display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem;
}

.softlance-why-choose-us__card {
	padding: 1.25rem; border-radius: var(--sl-radius);
	border: 1px solid rgba(255,255,255,.08); background: rgba(255,255,255,.03);
}

.softlance-why-choose-us__icon {
	width: 2.5rem; height: 2.5rem; border-radius: 8px;
	border: 1px solid rgba(0,82,255,.4);
	display: flex; align-items: center; justify-content: center; margin-bottom: .875rem;
}

.softlance-why-choose-us__icon[data-icon]::before { content: attr(data-icon); font-size: 1rem; }

.softlance-why-choose-us__icon-img {
	width: 1.25rem;
	height: 1.25rem;
	object-fit: contain;
	display: block;
}

.softlance-why-choose-us__title { margin: 0 0 .5rem; font-size: 1rem; font-family: Poppins, sans-serif; }
.softlance-why-choose-us__text { margin: 0; color: var(--sl-muted); font-size: .875rem; line-height: 1.6; }

/* Stats */
.softlance-stats__grid {
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; text-align: center;
}

.softlance-stats__number {
	font-family: Poppins, sans-serif;
	font-size: clamp(2rem, 4vw, 2.75rem); font-weight: 800; line-height: 1;
}

.softlance-stats__label { font-size: .875rem; opacity: .9; margin-top: .375rem; }

/* Portfolio */
.softlance-portfolio__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }

.softlance-portfolio__card {
	border-radius: var(--sl-radius-lg); overflow: hidden;
	border: 1px solid var(--sl-card-border); background: var(--sl-card-bg); height: 100%;
}

.softlance-portfolio__image { width: 100%; aspect-ratio: 4/3; object-fit: cover; }
.softlance-portfolio__content { padding: 1.25rem; }
.softlance-portfolio__link { text-decoration: none; color: inherit; display: block; height: 100%; }
.softlance-portfolio__placeholder { width: 100%; aspect-ratio: 4/3; background: linear-gradient(135deg, #1e293b, #334155); }
.softlance-portfolio__title { margin: 0 0 .375rem; font-size: 1.125rem; font-family: Poppins, sans-serif; color: var(--sl-gray-900, #0F172A); }
.softlance-portfolio__category { color: var(--sl-primary); font-size: .8125rem; font-weight: 600; margin: 0 0 .75rem; }

/* Process */
.softlance-process__steps { display: grid; grid-template-columns: repeat(5, 1fr); gap: 1rem; }

.softlance-process__step { text-align: center; }

.softlance-process__step-number {
	display: inline-flex; align-items: center; justify-content: center;
	width: 3.5rem; height: 3.5rem; border-radius: 50%;
	border: 2px solid rgba(0,82,255,.5); background: rgba(0,82,255,.1);
	color: #60a5fa; font-weight: 700; margin-bottom: 1rem;
}

.softlance-process__step-title { margin: 0 0 .5rem; font-size: 1rem; font-family: Poppins, sans-serif; }
.softlance-process__step-text { margin: 0; color: var(--sl-muted); font-size: .875rem; line-height: 1.6; }

/* Testimonials */
.softlance-testimonials__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }

.softlance-testimonials__card {
	background: var(--sl-card-bg); border: 1px solid var(--sl-card-border); border-radius: var(--sl-radius-lg);
	padding: 1.75rem; margin: 0; height: 100%;
}

.softlance-testimonials__avatar {
	margin-bottom: 1rem;
}

.softlance-testimonials__avatar-img {
	width: 3.5rem;
	height: 3.5rem;
	border-radius: 50%;
	object-fit: cover;
	display: block;
}

.softlance-testimonials__quote { margin: 0 0 1.25rem; color: #475569; font-style: italic; line-height: 1.7; }
.softlance-testimonials__name { font-style: normal; font-weight: 700; display: block; color: #111827; }
.softlance-testimonials__role { color: #64748b; font-size: .875rem; }

/* Blog */
.softlance-blog-posts__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }

.softlance-blog-posts__card {
	border: 1px solid var(--sl-card-border); border-radius: var(--sl-radius-lg);
	overflow: hidden; background: var(--sl-card-bg); height: 100%;
}

.softlance-blog-posts__link { text-decoration: none; color: inherit; display: block; height: 100%; }

.softlance-blog-posts__image { width: 100%; aspect-ratio: 16/10; object-fit: cover; }

.softlance-blog-posts__placeholder {
	width: 100%; aspect-ratio: 16/10; background: linear-gradient(135deg, #1e293b, #334155);
}

.softlance-blog-posts__content { padding: 1.25rem; }
.softlance-blog-posts__date { color: #64748b; font-size: .8125rem; display: block; margin-bottom: .5rem; }
.softlance-blog-posts__post-title { margin: 0 0 .5rem; font-size: 1.125rem; font-family: Poppins, sans-serif; }
.softlance-blog-posts__excerpt { margin: 0; color: #64748b; font-size: .9375rem; line-height: 1.6; }

/* CTA — see assets/css/cta.css for global styles */

/* Footer */
.softlance-footer {
	background: #0A1628;
	color: #94A3B8;
	padding: 0;
	border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.softlance-footer__inner {
	display: grid;
	grid-template-columns: minmax(240px, 1.35fr) repeat(3, minmax(0, 1fr));
	gap: 2.5rem 2rem;
	padding: 4rem 0 3rem;
}

.softlance-footer__col-title {
	color: #F8FAFC;
	font-size: 0.8125rem;
	font-weight: 700;
	margin: 0 0 1.125rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.softlance-footer__logo-link {
	display: inline-flex;
	line-height: 0;
}

.softlance-footer__tagline {
	color: #60A5FA;
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	margin: 0.875rem 0 0;
}

.softlance-footer__about {
	margin: 0.875rem 0 0;
	line-height: 1.75;
	font-size: 0.9375rem;
	color: #94A3B8;
	max-width: 22rem;
}

.softlance-footer__social {
	display: flex;
	flex-wrap: wrap;
	gap: 0.625rem;
	margin-top: 1.25rem;
}

.softlance-footer__social-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.5rem;
	height: 2.5rem;
	border-radius: 10px;
	background: rgba(255, 255, 255, 0.05);
	border: 1px solid rgba(255, 255, 255, 0.08);
	color: #E2E8F0;
	text-decoration: none;
	transition: background 0.2s, border-color 0.2s, color 0.2s, transform 0.2s;
}

.softlance-footer__social-link:hover {
	background: rgba(37, 99, 235, 0.18);
	border-color: rgba(96, 165, 250, 0.35);
	color: #fff;
	transform: translateY(-2px);
}

.softlance-footer__newsletter {
	margin-top: 1.5rem;
	max-width: 22rem;
}

.softlance-footer__newsletter-label {
	display: block;
	color: #F1F5F9;
	font-size: 0.875rem;
	font-weight: 600;
	margin-bottom: 0.625rem;
}

.softlance-footer__newsletter-row {
	display: flex;
	gap: 0.5rem;
}

.softlance-footer__newsletter-input {
	flex: 1;
	min-width: 0;
	padding: 0.6875rem 0.875rem;
	border-radius: 10px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(255, 255, 255, 0.05);
	color: #F8FAFC;
	font: inherit;
	font-size: 0.875rem;
	transition: border-color 0.2s, background 0.2s;
}

.softlance-footer__newsletter-input::placeholder {
	color: #64748B;
}

.softlance-footer__newsletter-input:focus {
	outline: none;
	border-color: rgba(96, 165, 250, 0.55);
	background: rgba(255, 255, 255, 0.08);
}

.softlance-footer__newsletter-btn {
	flex-shrink: 0;
	padding: 0.6875rem 1rem;
	border: 0;
	border-radius: 10px;
	background: var(--sl-primary);
	color: #fff;
	font: inherit;
	font-size: 0.875rem;
	font-weight: 600;
	cursor: pointer;
	transition: background 0.2s, transform 0.2s;
}

.softlance-footer__newsletter-btn:hover {
	background: var(--sl-primary-dark);
	transform: translateY(-1px);
}

.softlance-footer__links {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0.625rem;
}

.softlance-footer__cities .softlance-footer__links {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 0.5rem 1rem;
}

.softlance-footer__cities .softlance-footer__links > li:last-child {
	grid-column: 1 / -1;
}

.softlance-footer__link {
	color: #94A3B8;
	text-decoration: none;
	font-size: 0.9375rem;
	line-height: 1.4;
	transition: color 0.15s ease, transform 0.15s ease;
	display: inline-flex;
}

.softlance-footer__link:hover {
	color: #F8FAFC;
	transform: translateX(3px);
}

.softlance-footer__link--cta {
	color: #60A5FA;
	font-weight: 600;
	margin-top: 0.375rem;
}

.softlance-footer__link--cta::after {
	content: ' →';
}

.softlance-footer__link--cta:hover {
	color: #93C5FD;
}

.softlance-footer__contact {
	margin-top: 1.5rem;
	padding-top: 1.25rem;
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	display: flex;
	flex-direction: column;
	gap: 0.625rem;
}

.softlance-footer__contact-item {
	display: inline-flex;
	align-items: center;
	gap: 0.625rem;
	color: #CBD5E1;
	text-decoration: none;
	font-size: 0.875rem;
	transition: color 0.15s;
}

.softlance-footer__contact-item:hover {
	color: #fff;
}

.softlance-footer__contact-icon {
	flex-shrink: 0;
	width: 1.25rem;
	text-align: center;
	opacity: 0.85;
}

.softlance-footer__bottom {
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	padding: 1.25rem 0 1.5rem;
	background: rgba(0, 0, 0, 0.15);
}

.softlance-footer__bottom-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 0.75rem 1.5rem;
}

.softlance-footer__copyright {
	margin: 0;
	font-size: 0.8125rem;
	color: #64748B;
}

.softlance-footer__copyright a {
	color: #E2E8F0;
	text-decoration: none;
}

.softlance-footer__copyright a:hover {
	color: #fff;
}

.softlance-footer__legal {
	display: inline-flex;
	align-items: center;
	gap: 0.625rem;
}

.softlance-footer__legal a {
	color: #94A3B8;
	text-decoration: none;
	font-size: 0.8125rem;
	transition: color 0.15s;
}

.softlance-footer__legal a:hover {
	color: #fff;
}

.softlance-footer__legal-sep {
	color: #475569;
}

.softlance-footer__made-in {
	margin: 0;
	font-size: 0.8125rem;
	color: #64748B;
}

/* Legacy footer menu class (fallback) */
.softlance-footer__menu { list-style: none; padding: 0; margin: 0; }
.softlance-footer__menu a { color: var(--sl-muted); text-decoration: none; }
.softlance-footer__menu a:hover { color: var(--sl-primary); }

main.wp-block-group { margin: 0; }

/* Responsive */
@media (max-width: 1024px) {
	.softlance-hero__inner,
	.softlance-why-choose-us .softlance-container { grid-template-columns: 1fr; }

	.softlance-hero__media { order: -1; }

	.softlance-services__grid,
	.softlance-portfolio__grid,
	.softlance-stats__grid,
	.softlance-trusted-logos__grid { grid-template-columns: repeat(2, 1fr); }

	.softlance-process__steps { grid-template-columns: repeat(3, 1fr); }
	.softlance-testimonials__grid,
	.softlance-blog-posts__grid { grid-template-columns: repeat(2, 1fr); }
	.softlance-footer__inner { grid-template-columns: 1fr 1fr; }
	.softlance-footer__brand { grid-column: 1 / -1; }
}

@media (max-width: 900px) {
	.softlance-services__grid,
	.softlance-portfolio__grid,
	.softlance-stats__grid,
	.softlance-process__steps,
	.softlance-testimonials__grid,
	.softlance-blog-posts__grid,
	.softlance-trusted-logos__grid,
	.softlance-why-choose-us__grid,
	.softlance-footer__inner { grid-template-columns: 1fr; gap: 2rem; }
	.softlance-footer__brand { grid-column: auto; }
	.softlance-footer__newsletter-row { flex-direction: column; }
	.softlance-footer__newsletter-btn { width: 100%; }
	.softlance-footer__bottom-inner { flex-direction: column; align-items: flex-start; }
	.softlance-footer__cities .softlance-footer__links { grid-template-columns: 1fr; }

	/* Mobile header + drawer: see assets/css/mobile-nav.css */
	.softlance-hero__actions { flex-direction: column; }
	.softlance-hero__actions .softlance-btn { width: 100%; }
	.softlance-floating-cta {
		left: 1rem;
		right: 1rem;
		flex-direction: row;
	}
	.softlance-floating-cta__btn { flex: 1; }
}

body.softlance-nav-open { overflow: hidden; }

.editor-styles-wrapper .softlance-section { margin: 0; }

/* Inner pages (Gutenberg core blocks) */
.softlance-page-hero { text-align: center; }
.softlance-page-hero__title {
	font-family: Poppins, sans-serif;
	font-size: clamp(2rem, 5vw, 3rem);
	line-height: 1.1;
	margin: 0 0 1rem;
}
.softlance-page-hero__lead {
	font-size: 1.125rem;
	line-height: 1.7;
	color: var(--sl-muted);
	max-width: 720px;
	margin: 0 auto 1.5rem;
}
.softlance-page-hero__actions {
	justify-content: center;
	gap: .75rem;
	flex-wrap: wrap;
}
.softlance-page-content {
	padding-top: clamp(2.5rem, 5vw, 4rem);
	padding-bottom: clamp(2.5rem, 5vw, 4rem);
}
.softlance-page-content .softlance-section-title { margin-bottom: 1.25rem; }
.softlance-page-features { gap: 1.5rem; margin-top: 1.5rem; }
.softlance-page-list {
	padding-left: 1.25rem;
	line-height: 1.8;
	max-width: 720px;
}
.softlance-page-list li { margin-bottom: .35rem; }
.softlance-faq h3 {
	font-family: Poppins, sans-serif;
	font-size: 1.125rem;
	margin: 1.5rem 0 .5rem;
}
.softlance-contact-note {
	padding: 1rem 1.25rem;
	border-left: 3px solid var(--sl-primary);
	background: rgba(0, 82, 255, 0.06);
	border-radius: 0 8px 8px 0;
}
body.page .entry-content,
body.page .wp-block-post-content { margin: 0; }
body.page .wp-block-post-content > .alignfull { width: 100%; max-width: none; }

