:root {
	--ss-ink: #111827;
	--ss-graphite: #24313f;
	--ss-muted: #657080;
	--ss-line: #dfe5eb;
	--ss-paper: #f7f8fa;
	--ss-white: #ffffff;
	--ss-solar: #f5a524;
	--ss-energy: #19a974;
	--ss-sky: #1c6dd0;
	--ss-danger: #d74a36;
	--ss-shadow: 0 18px 55px rgba(17, 24, 39, 0.12);
	--ss-radius: 8px;
	--ss-container: 1180px;
	--ss-header-height: 84px;
}

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

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	background: var(--ss-white);
	color: var(--ss-ink);
	font-family: Inter, "Noto Sans Bengali", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	font-size: 16px;
	line-height: 1.65;
	letter-spacing: 0;
	text-rendering: optimizeLegibility;
	-webkit-font-smoothing: antialiased;
}

body.ss-nav-open,
body.ss-search-open {
	overflow: hidden;
}

img,
svg,
video,
iframe {
	max-width: 100%;
}

img {
	height: auto;
	display: block;
}

svg {
	width: 1.15em;
	height: 1.15em;
	fill: currentColor;
	flex: 0 0 auto;
}

a {
	color: var(--ss-sky);
	text-decoration: none;
	text-underline-offset: 0.18em;
}

a:hover {
	color: var(--ss-energy);
}

p {
	margin: 0 0 1rem;
	color: var(--ss-muted);
}

h1,
h2,
h3,
h4,
h5,
h6 {
	margin: 0 0 0.75rem;
	color: var(--ss-ink);
	font-weight: 800;
	line-height: 1.08;
	letter-spacing: 0;
}

h1 {
	font-size: 56px;
}

h2 {
	font-size: 38px;
}

h3 {
	font-size: 22px;
}

button,
input,
textarea,
select {
	font: inherit;
	letter-spacing: 0;
}

input,
textarea,
select {
	width: 100%;
	border: 1px solid var(--ss-line);
	border-radius: var(--ss-radius);
	background: var(--ss-white);
	color: var(--ss-ink);
	padding: 13px 14px;
	min-height: 48px;
}

textarea {
	resize: vertical;
}

input:focus,
textarea:focus,
select:focus,
button:focus-visible,
a:focus-visible {
	outline: 3px solid rgba(28, 109, 208, 0.22);
	outline-offset: 3px;
}

.screen-reader-text,
.skip-link {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.screen-reader-text:focus,
.skip-link:focus {
	width: auto;
	height: auto;
	clip: auto;
	white-space: normal;
	z-index: 100000;
	top: 12px;
	left: 12px;
	padding: 10px 14px;
	background: var(--ss-ink);
	color: var(--ss-white);
	border-radius: var(--ss-radius);
}

.ss-container {
	width: min(100% - 32px, var(--ss-container));
	margin-inline: auto;
}

.elementor-section .ss-hero,
.elementor-section .ss-logo-ticker,
.elementor-widget-container > .ss-section,
.elementor-widget-container > .ss-band {
	width: 100%;
}

.ss-main {
	min-height: 52vh;
}

.ss-section {
	padding: 92px 0;
}

.ss-band {
	background: var(--ss-paper);
}

.ss-reveal {
	opacity: 0;
	transform: translateY(18px);
	transition: opacity 520ms ease, transform 520ms ease;
}

.ss-reveal.is-visible,
.no-js .ss-reveal {
	opacity: 1;
	transform: none;
}

.ss-eyebrow,
.ss-badge {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: var(--ss-energy);
	background: rgba(25, 169, 116, 0.1);
	border: 1px solid rgba(25, 169, 116, 0.2);
	border-radius: 999px;
	padding: 6px 11px;
	font-size: 13px;
	font-weight: 800;
	line-height: 1.2;
	margin-bottom: 16px;
}

.ss-badge {
	color: var(--ss-graphite);
	background: var(--ss-paper);
	border-color: var(--ss-line);
}

.ss-section-heading {
	max-width: 920px;
	margin-bottom: 34px;
}

.ss-section-heading h2 {
	margin-bottom: 12px;
}

.ss-section-heading p {
	font-size: 18px;
	margin-bottom: 0;
}

.ss-actions {
	display: flex;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
}

.ss-btn,
.wp-element-button,
.button,
button[type="submit"] {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	min-height: 48px;
	border: 0;
	border-radius: var(--ss-radius);
	padding: 13px 18px;
	background: var(--ss-energy);
	color: var(--ss-white);
	font-weight: 800;
	line-height: 1.1;
	cursor: pointer;
	box-shadow: none;
	text-decoration: none;
	transition: transform 180ms ease, background-color 180ms ease, color 180ms ease, border-color 180ms ease;
}

.ss-btn:hover,
.wp-element-button:hover,
.button:hover,
button[type="submit"]:hover {
	transform: translateY(-2px);
	background: #12855c;
	color: var(--ss-white);
}

.ss-btn--ghost {
	background: rgba(255, 255, 255, 0.1);
	color: var(--ss-white);
	border: 1px solid rgba(255, 255, 255, 0.28);
}

.ss-btn--ghost:hover {
	background: var(--ss-white);
	color: var(--ss-ink);
}

.ss-btn--ghost-dark {
	color: var(--ss-ink);
	border: 1px solid var(--ss-line);
	background: var(--ss-white);
}

.ss-btn--dark {
	background: var(--ss-ink);
	color: var(--ss-white);
}

.ss-btn--small {
	min-height: 40px;
	padding: 10px 13px;
	font-size: 14px;
}

.ss-link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-weight: 800;
	color: var(--ss-energy);
}

.ss-icon-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	border: 1px solid var(--ss-line);
	border-radius: var(--ss-radius);
	background: var(--ss-white);
	color: var(--ss-ink);
	cursor: pointer;
}

.ss-header {
	position: sticky;
	top: 0;
	z-index: 1000;
	background: rgba(255, 255, 255, 0.96);
	border-bottom: 1px solid rgba(223, 229, 235, 0.9);
	backdrop-filter: blur(12px);
}

.admin-bar .ss-header {
	top: 32px;
}

.ss-topbar {
	background: var(--ss-ink);
	color: var(--ss-white);
	font-size: 13px;
}

.ss-topbar__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	min-height: 38px;
}

.ss-topbar nav {
	display: flex;
	align-items: center;
	gap: 18px;
	flex-wrap: wrap;
}

.ss-topbar a,
.ss-topbar span {
	color: rgba(255, 255, 255, 0.86);
}

.ss-header__inner {
	min-height: var(--ss-header-height);
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: 24px;
}

.ss-brand img,
.custom-logo {
	width: 238px;
	max-height: 68px;
	object-fit: contain;
}

.ss-nav ul {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 4px;
	padding: 0;
	margin: 0;
	list-style: none;
}

.ss-nav li {
	position: relative;
}

.ss-nav a {
	display: flex;
	align-items: center;
	min-height: 44px;
	padding: 10px 12px;
	color: var(--ss-graphite);
	font-size: 15px;
	font-weight: 800;
	border-radius: var(--ss-radius);
}

.ss-nav a:hover,
.ss-nav .current-menu-item > a,
.ss-nav .current-menu-ancestor > a {
	background: var(--ss-paper);
	color: var(--ss-energy);
}

.ss-nav .sub-menu {
	position: absolute;
	top: calc(100% + 8px);
	left: 0;
	min-width: 240px;
	display: grid;
	gap: 3px;
	padding: 10px;
	background: var(--ss-white);
	border: 1px solid var(--ss-line);
	border-radius: var(--ss-radius);
	box-shadow: var(--ss-shadow);
	opacity: 0;
	visibility: hidden;
	transform: translateY(8px);
	transition: opacity 180ms ease, transform 180ms ease, visibility 180ms ease;
}

.ss-nav li:hover > .sub-menu,
.ss-nav li:focus-within > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: none;
}

.ss-nav .sub-menu a {
	justify-content: flex-start;
	min-height: 40px;
	white-space: nowrap;
}

.ss-nav-toggle {
	display: none;
}

.ss-header__actions {
	display: flex;
	align-items: center;
	gap: 10px;
}

.ss-cart-link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-height: 42px;
	padding: 8px 10px;
	border: 1px solid var(--ss-line);
	border-radius: var(--ss-radius);
	color: var(--ss-ink);
	font-weight: 800;
}

.ss-cart-link strong {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 22px;
	height: 22px;
	border-radius: 999px;
	background: var(--ss-solar);
	color: var(--ss-ink);
	font-size: 12px;
}

.ss-search-drawer {
	position: fixed;
	inset: 0;
	z-index: 1100;
	display: none;
	align-items: flex-start;
	justify-content: center;
	padding: 90px 20px;
	background: rgba(17, 24, 39, 0.58);
}

.ss-search-open .ss-search-drawer {
	display: flex;
}

.ss-search-drawer__panel {
	width: min(100%, 680px);
	padding: 24px;
	background: var(--ss-white);
	border-radius: var(--ss-radius);
	box-shadow: var(--ss-shadow);
}

.ss-search-drawer__panel > .ss-icon-button {
	margin-left: auto;
	margin-bottom: 14px;
}

.ss-search-form {
	display: flex;
	gap: 10px;
	align-items: stretch;
}

.ss-search-form label {
	flex: 1;
}

.ss-search-form button {
	white-space: nowrap;
}

.ss-hero {
	position: relative;
	isolation: isolate;
	min-height: 680px;
	display: flex;
	align-items: center;
	color: var(--ss-white);
	background: var(--ss-ink);
	overflow: hidden;
}

.ss-hero__media {
	position: absolute;
	inset: 0;
	background-image: linear-gradient(90deg, rgba(17, 24, 39, var(--ss-hero-overlay, 0.72)), rgba(17, 24, 39, var(--ss-hero-overlay-mid, 0.56)), rgba(17, 24, 39, 0.18)), var(--ss-hero-image);
	background-size: cover;
	background-position: center;
	z-index: -1;
}

.ss-hero__inner {
	display: grid;
	grid-template-columns: minmax(0, 760px) 300px;
	align-items: end;
	gap: 46px;
	padding: 106px 0 88px;
}

.ss-hero h1 {
	color: var(--ss-white);
	font-size: 64px;
	max-width: 840px;
	margin-bottom: 20px;
}

.ss-hero p {
	color: rgba(255, 255, 255, 0.84);
	font-size: 19px;
	max-width: 700px;
	margin-bottom: 30px;
}

.ss-hero .ss-eyebrow {
	color: var(--ss-ink);
	background: var(--ss-solar);
	border-color: var(--ss-solar);
}

.ss-hero__panel {
	display: grid;
	gap: 12px;
	background: rgba(255, 255, 255, 0.13);
	border: 1px solid rgba(255, 255, 255, 0.22);
	border-radius: var(--ss-radius);
	padding: 16px;
	backdrop-filter: blur(10px);
}

.ss-hero__panel div {
	display: grid;
	gap: 2px;
	padding: 14px;
	border-radius: var(--ss-radius);
	background: rgba(255, 255, 255, 0.1);
}

.ss-hero__panel strong {
	color: var(--ss-white);
	font-size: 30px;
	line-height: 1;
}

.ss-hero__panel span {
	color: rgba(255, 255, 255, 0.78);
	font-weight: 700;
	font-size: 13px;
}

.ss-logo-ticker {
	padding: 28px 0;
	overflow: hidden;
	width: 100%;
}

.ss-logo-ticker__title {
	margin: 0 0 18px;
	color: var(--ss-graphite);
	font-weight: 800;
	text-align: center;
}

.ss-logo-ticker__track {
	overflow: hidden;
	width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
}

.ss-logo-ticker__row {
	display: flex;
	gap: 14px;
	width: max-content;
	animation: ss-marquee 28s linear infinite;
}

.ss-logo-pill {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 180px;
	height: 58px;
	padding: 0 24px;
	border-radius: var(--ss-radius);
	background: var(--ss-white);
	border: 1px solid var(--ss-line);
	color: var(--ss-graphite);
	font-weight: 900;
	box-shadow: 0 10px 25px rgba(17, 24, 39, 0.05);
}

.ss-logo-pill img {
	width: auto;
	max-width: 150px;
	max-height: 34px;
	object-fit: contain;
}

@keyframes ss-marquee {
	from {
		transform: translateX(0);
	}
	to {
		transform: translateX(-50%);
	}
}

.ss-stats {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 14px;
	padding: 28px 0;
}

.ss-stat {
	padding: 24px;
	border: 1px solid var(--ss-line);
	border-radius: var(--ss-radius);
	background: var(--ss-white);
}

.ss-stat strong {
	display: block;
	font-size: 34px;
	line-height: 1;
	color: var(--ss-energy);
	margin-bottom: 8px;
}

.ss-stat span {
	color: var(--ss-graphite);
	font-weight: 800;
}

.ss-about__grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(320px, 0.8fr);
	gap: 34px;
	align-items: start;
}

.ss-about__cards {
	display: grid;
	gap: 16px;
}

.ss-info-card {
	border: 1px solid var(--ss-line);
	border-radius: var(--ss-radius);
	background: var(--ss-white);
	padding: 24px;
	box-shadow: 0 14px 34px rgba(17, 24, 39, 0.06);
}

.ss-info-card h3 {
	font-size: 20px;
	margin-bottom: 10px;
}

.ss-card-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 22px;
}

.ss-card {
	display: flex;
	flex-direction: column;
	min-width: 0;
	border: 1px solid var(--ss-line);
	border-radius: var(--ss-radius);
	background: var(--ss-white);
	overflow: hidden;
	box-shadow: 0 14px 34px rgba(17, 24, 39, 0.06);
	transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.ss-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--ss-shadow);
	border-color: rgba(25, 169, 116, 0.32);
}

.ss-card__media {
	display: block;
	aspect-ratio: 16 / 10;
	background: var(--ss-paper);
	overflow: hidden;
}

.ss-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 400ms ease;
}

.ss-card:hover .ss-card__media img {
	transform: scale(1.04);
}

.ss-card__body {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	flex: 1;
	padding: 24px;
}

.ss-card__body h2,
.ss-card__body h3 {
	font-size: 22px;
	margin-bottom: 10px;
}

.ss-card__body h2 a,
.ss-card__body h3 a {
	color: var(--ss-ink);
}

.ss-card__body p {
	margin-bottom: 20px;
}

.ss-card__body .ss-link {
	margin-top: auto;
}

.ss-icon-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	border-radius: var(--ss-radius);
	background: var(--ss-solar);
	color: var(--ss-ink);
	margin-bottom: 16px;
}

.ss-highlight__grid {
	display: grid;
	grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
	gap: 44px;
	align-items: center;
}

.ss-highlight__image {
	border-radius: var(--ss-radius);
	overflow: hidden;
	box-shadow: var(--ss-shadow);
	aspect-ratio: 4 / 3;
}

.ss-highlight__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.ss-check-list {
	display: grid;
	gap: 10px;
	padding: 0;
	margin: 22px 0;
	list-style: none;
}

.ss-check-list li {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	color: var(--ss-graphite);
	font-weight: 700;
}

.ss-check-list svg {
	color: var(--ss-energy);
	margin-top: 4px;
}

.ss-slider {
	position: relative;
}

.ss-slider__track {
	display: grid;
	grid-auto-flow: column;
	grid-auto-columns: 280px;
	gap: 18px;
	overflow-x: auto;
	padding: 4px 2px 18px;
	scroll-snap-type: x mandatory;
	scrollbar-width: thin;
}

.ss-product-card {
	scroll-snap-align: start;
	border: 1px solid var(--ss-line);
	border-radius: var(--ss-radius);
	background: var(--ss-white);
	overflow: hidden;
	box-shadow: 0 14px 34px rgba(17, 24, 39, 0.06);
}

.ss-product-card a {
	display: grid;
	color: var(--ss-ink);
}

.ss-product-card img {
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	background: var(--ss-paper);
}

.ss-product-card h3 {
	font-size: 18px;
	padding: 18px 18px 4px;
	margin: 0;
}

.ss-product-card span {
	display: block;
	padding: 0 18px 18px;
	color: var(--ss-energy);
	font-weight: 900;
}

.ss-slider__controls {
	display: flex;
	gap: 10px;
	justify-content: flex-end;
	margin-top: 12px;
}

.ss-projects__toolbar .ss-slider__controls {
	margin-top: 0;
}

.ss-slider__prev,
.ss-slider__next {
	width: 44px;
	height: 44px;
	border: 1px solid var(--ss-line);
	border-radius: var(--ss-radius);
	background: var(--ss-white);
	color: var(--ss-ink);
	cursor: pointer;
}

.ss-slider__prev svg {
	transform: rotate(180deg);
}

.ss-process__grid {
	display: grid;
	grid-template-columns: repeat(6, minmax(0, 1fr));
	gap: 14px;
}

.ss-process-step {
	position: relative;
	min-height: 150px;
	padding: 22px 18px;
	border-radius: var(--ss-radius);
	background: var(--ss-white);
	border: 1px solid var(--ss-line);
}

.ss-process-step span {
	display: inline-flex;
	color: var(--ss-solar);
	font-weight: 900;
	margin-bottom: 24px;
}

.ss-process-step h3 {
	font-size: 18px;
	margin: 0;
}

.ss-card-grid--experts .ss-card__media {
	aspect-ratio: 1 / 1;
}

.ss-filterbar {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
	margin: -10px 0 28px;
}

.ss-filterbar button {
	border: 1px solid var(--ss-line);
	border-radius: var(--ss-radius);
	background: var(--ss-white);
	color: var(--ss-graphite);
	padding: 10px 14px;
	font-weight: 800;
	cursor: pointer;
}

.ss-filterbar button.is-active {
	background: var(--ss-ink);
	color: var(--ss-white);
	border-color: var(--ss-ink);
}

.ss-project-card.is-hidden {
	display: none;
}

.ss-projects__toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	margin: -8px 0 24px;
}

.ss-project-slider__track {
	grid-auto-columns: calc((100% - 66px) / 4);
	padding-bottom: 22px;
}

.ss-project-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 22px;
}

.ss-pagination {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	justify-content: center;
	margin-top: 34px;
}

.ss-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 42px;
	height: 42px;
	border: 1px solid var(--ss-line);
	border-radius: var(--ss-radius);
	background: var(--ss-white);
	color: var(--ss-ink);
	font-weight: 800;
}

.ss-pagination .current {
	background: var(--ss-ink);
	color: var(--ss-white);
	border-color: var(--ss-ink);
}

.ss-progress {
	width: 100%;
	height: 10px;
	border-radius: 999px;
	background: #e8edf2;
	overflow: hidden;
	margin-top: 16px;
}

.ss-progress span {
	display: block;
	height: 100%;
	border-radius: inherit;
	background: var(--ss-energy);
}

.ss-testimonial-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 22px;
}

.ss-testimonial {
	margin: 0;
	padding: 26px;
	background: var(--ss-white);
	border: 1px solid var(--ss-line);
	border-radius: var(--ss-radius);
}

.ss-testimonial blockquote {
	margin: 0 0 18px;
	color: var(--ss-graphite);
	font-size: 18px;
	font-weight: 700;
}

.ss-testimonial figcaption {
	color: var(--ss-energy);
	font-weight: 900;
}

.ss-cta {
	padding: 54px 0;
	background: var(--ss-ink);
	color: var(--ss-white);
}

.ss-cta__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 28px;
}

.ss-cta h2 {
	color: var(--ss-white);
	margin-bottom: 8px;
}

.ss-cta p {
	color: rgba(255, 255, 255, 0.76);
	margin: 0;
}

.ss-contact__grid {
	display: grid;
	grid-template-columns: minmax(0, 0.85fr) minmax(320px, 0.65fr);
	gap: 28px;
	align-items: start;
}

.ss-contact__form,
.ss-sidebar-box {
	border: 1px solid var(--ss-line);
	border-radius: var(--ss-radius);
	background: var(--ss-white);
	box-shadow: 0 14px 34px rgba(17, 24, 39, 0.06);
	padding: 24px;
}

.ss-contact__form form {
	display: grid;
	gap: 14px;
}

.ss-contact__form label {
	display: grid;
	gap: 6px;
	color: var(--ss-graphite);
	font-weight: 800;
}

.ss-contact-list {
	display: grid;
	gap: 10px;
	margin: 0 0 24px;
}

.ss-contact-list a,
.ss-contact-list span {
	color: var(--ss-graphite);
	font-weight: 800;
}

.ss-contact__map {
	grid-column: 1 / -1;
	border-radius: var(--ss-radius);
	overflow: hidden;
	border: 1px solid var(--ss-line);
	background: var(--ss-paper);
	min-height: 320px;
}

.ss-contact__map iframe {
	display: block;
	width: 100%;
	height: 360px;
	border: 0;
}

.ss-newsletter {
	padding: 42px 0;
}

.ss-newsletter__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
}

.ss-newsletter h2 {
	font-size: 28px;
	margin: 0;
}

.ss-newsletter form {
	display: flex;
	gap: 10px;
	width: min(100%, 520px);
}

.ss-newsletter input {
	background: var(--ss-white);
}

.ss-page-hero,
.ss-single-hero {
	position: relative;
	padding: 78px 0 58px;
	background: var(--ss-paper);
	overflow: hidden;
}

.ss-page-hero h1 {
	max-width: 1100px;
	margin-bottom: 0;
}

.ss-breadcrumbs {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
	margin-bottom: 16px;
	font-size: 14px;
	font-weight: 800;
	color: var(--ss-muted);
}

.ss-breadcrumbs a {
	color: var(--ss-graphite);
}

.ss-breadcrumbs__sep {
	color: var(--ss-muted);
}

.ss-single-hero {
	position: relative;
	min-height: 480px;
	display: flex;
	align-items: center;
	color: var(--ss-white);
	background: var(--ss-ink);
	overflow: hidden;
}

.ss-single-hero__media {
	position: absolute;
	inset: 0;
	background-image: linear-gradient(90deg, rgba(17, 24, 39, 0.9), rgba(17, 24, 39, 0.58)), var(--ss-hero-image);
	background-size: cover;
	background-position: center;
	z-index: 0;
}

.ss-single-hero__inner {
	position: relative;
	z-index: 1;
}

.ss-single-hero h1,
.ss-single-hero .ss-breadcrumbs,
.ss-single-hero .ss-breadcrumbs a {
	color: var(--ss-white);
}

.ss-single-hero p {
	max-width: 760px;
	color: rgba(255, 255, 255, 0.82);
	font-size: 18px;
}

.ss-content {
	padding-top: 58px;
	padding-bottom: 72px;
}

.ss-content > * {
	max-width: 100%;
}

.ss-content > .alignwide {
	max-width: var(--ss-container);
}

.ss-content > .alignfull {
	max-width: none;
	margin-inline: calc(50% - 50vw);
}

.ss-content ul,
.ss-content ol {
	color: var(--ss-muted);
	margin-bottom: 1.2rem;
}

.ss-content li + li {
	margin-top: 0.35rem;
}

.ss-featured-image {
	margin: 0 0 32px;
	border-radius: var(--ss-radius);
	overflow: hidden;
}

.ss-detail-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 360px;
	gap: 42px;
	align-items: start;
}

.ss-detail-layout .ss-content {
	padding: 0;
}

.ss-detail-sidebar {
	position: sticky;
	top: calc(var(--ss-header-height) + 28px);
	display: grid;
	gap: 18px;
}

.ss-sidebar-box h2 {
	font-size: 22px;
}

.ss-meta-list {
	display: grid;
	grid-template-columns: 110px 1fr;
	gap: 9px 16px;
	margin: 0;
}

.ss-meta-list dt {
	color: var(--ss-muted);
	font-weight: 800;
}

.ss-meta-list dd {
	margin: 0;
	color: var(--ss-graphite);
	font-weight: 800;
}

.ss-expert-profile__grid {
	display: grid;
	grid-template-columns: 420px minmax(0, 1fr);
	gap: 48px;
	align-items: center;
}

.ss-expert-profile__photo {
	border-radius: var(--ss-radius);
	overflow: hidden;
	box-shadow: var(--ss-shadow);
	aspect-ratio: 1 / 1;
}

.ss-expert-profile__photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.ss-archive-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 22px;
	padding-top: 64px;
	padding-bottom: 84px;
}

.ss-archive-grid .navigation,
.ss-archive-grid .pagination {
	grid-column: 1 / -1;
}

.ss-full-width-content,
.ss-front-content,
.ss-elementor-page {
	width: 100%;
}

.ss-footer {
	background: #101820;
	color: var(--ss-white);
	padding: 70px 0 26px;
}

.ss-footer__grid {
	display: grid;
	grid-template-columns: 1.3fr 0.8fr 0.8fr 1fr;
	gap: 34px;
}

.ss-footer h2 {
	color: var(--ss-white);
	font-size: 18px;
	margin-bottom: 16px;
}

.ss-footer p,
.ss-footer li,
.ss-footer a {
	color: rgba(255, 255, 255, 0.72);
}

.ss-footer__brand img {
	background: var(--ss-white);
	border-radius: var(--ss-radius);
	padding: 8px;
	margin-bottom: 18px;
}

.ss-footer-menu {
	display: grid;
	gap: 10px;
	padding: 0;
	margin: 0;
	list-style: none;
}

.ss-socials {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	align-items: center;
}

.ss-socials a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: var(--ss-radius);
	padding: 0;
	font-weight: 800;
	color: rgba(255, 255, 255, 0.82);
	transition: background-color 180ms ease, color 180ms ease, transform 180ms ease, border-color 180ms ease;
}

.ss-socials a:hover {
	transform: translateY(-2px);
	background: var(--ss-energy);
	border-color: var(--ss-energy);
	color: var(--ss-white);
}

.ss-socials svg {
	width: 18px;
	height: 18px;
}

.ss-socials--topbar {
	gap: 6px;
	margin-left: 4px;
}

.ss-socials--topbar a {
	width: 30px;
	height: 30px;
	border-color: rgba(255, 255, 255, 0.14);
	color: rgba(255, 255, 255, 0.78);
}

.ss-socials--topbar svg {
	width: 15px;
	height: 15px;
}

.ss-footer__bottom {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	border-top: 1px solid rgba(255, 255, 255, 0.12);
	margin-top: 42px;
	padding-top: 22px;
	font-size: 14px;
}

.ss-footer__bottom p {
	margin: 0;
}

.ss-floating-whatsapp {
	position: fixed;
	right: 22px;
	bottom: 22px;
	z-index: 999;
	width: 58px;
	height: 58px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 999px;
	background: #25d366;
	color: var(--ss-white);
	box-shadow: 0 14px 30px rgba(37, 211, 102, 0.28);
}

.ss-floating-whatsapp:hover {
	color: var(--ss-white);
	background: #1fb45a;
}

@media (prefers-reduced-motion: reduce) {
	html {
		scroll-behavior: auto;
	}

	*,
	*::before,
	*::after {
		animation-duration: 0.001ms !important;
		animation-iteration-count: 1 !important;
		scroll-behavior: auto !important;
		transition-duration: 0.001ms !important;
	}
}

@media (max-width: 1180px) {
	.ss-process__grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 1024px) {
	h1,
	.ss-hero h1 {
		font-size: 44px;
	}

	h2 {
		font-size: 32px;
	}

	.ss-topbar {
		display: none;
	}

	.admin-bar .ss-header {
		top: 32px;
	}

	.ss-header__inner {
		grid-template-columns: auto auto 1fr;
	}

	.ss-nav-toggle {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: 42px;
		height: 42px;
		border: 1px solid var(--ss-line);
		border-radius: var(--ss-radius);
		background: var(--ss-white);
		color: var(--ss-ink);
		cursor: pointer;
	}

	.ss-nav {
		position: fixed;
		inset: var(--ss-header-height) 0 0;
		z-index: 1001;
		display: none;
		overflow: auto;
		padding: 18px;
		background: var(--ss-white);
		border-top: 1px solid var(--ss-line);
	}

	.ss-nav-open .ss-nav {
		display: block;
	}

	.ss-nav ul {
		display: grid;
		gap: 4px;
		justify-content: stretch;
	}

	.ss-nav a {
		justify-content: space-between;
		min-height: 48px;
	}

	.ss-nav .sub-menu {
		position: static;
		min-width: 0;
		box-shadow: none;
		border: 0;
		background: var(--ss-paper);
		opacity: 1;
		visibility: visible;
		transform: none;
		margin: 4px 0 8px;
		padding: 8px;
	}

	.ss-header__actions {
		justify-content: flex-end;
	}

	.ss-header__quote,
	.ss-cart-link span {
		display: none;
	}

	.ss-hero {
		min-height: 620px;
	}

	.ss-hero__inner {
		grid-template-columns: 1fr;
		gap: 28px;
	}

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

	.ss-card-grid,
	.ss-testimonial-grid,
	.ss-archive-grid,
	.ss-project-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.ss-project-slider__track {
		grid-auto-columns: calc((100% - 22px) / 2);
	}

	.ss-highlight__grid,
	.ss-about__grid,
	.ss-contact__grid,
	.ss-detail-layout,
	.ss-expert-profile__grid {
		grid-template-columns: 1fr;
	}

	.ss-detail-sidebar {
		position: static;
	}

	.ss-footer__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 782px) {
	.admin-bar .ss-header {
		top: 46px;
	}
}

@media (max-width: 700px) {
	body {
		font-size: 15px;
	}

	h1,
	.ss-hero h1 {
		font-size: 36px;
	}

	h2 {
		font-size: 28px;
	}

	.ss-container {
		width: min(100% - 24px, var(--ss-container));
	}

	.ss-section {
		padding: 64px 0;
	}

	.ss-header__inner {
		min-height: 72px;
		gap: 10px;
	}

	.ss-brand img,
	.custom-logo {
		width: 190px;
	}

	.ss-nav {
		inset: 72px 0 0;
	}

	.ss-hero {
		min-height: 620px;
	}

	.ss-hero__inner {
		padding: 84px 0 56px;
	}

	.ss-hero p {
		font-size: 16px;
	}

	.ss-hero__panel {
		grid-template-columns: 1fr;
	}

	.ss-actions,
	.ss-cta__inner,
	.ss-newsletter__inner,
	.ss-newsletter form,
	.ss-search-form,
	.ss-footer__bottom {
		flex-direction: column;
		align-items: stretch;
	}

	.ss-btn,
	.ss-search-form button,
	.ss-newsletter button {
		width: 100%;
	}

	.ss-stats,
	.ss-card-grid,
	.ss-project-grid,
	.ss-testimonial-grid,
	.ss-archive-grid,
	.ss-process__grid,
	.ss-footer__grid {
		grid-template-columns: 1fr;
	}

	.ss-stat,
	.ss-card__body,
	.ss-contact__form,
	.ss-sidebar-box {
		padding: 20px;
	}

	.ss-slider__track {
		grid-auto-columns: 82%;
	}

	.ss-projects__toolbar {
		align-items: stretch;
		flex-direction: column;
	}

	.ss-project-slider__track {
		grid-auto-columns: 86%;
	}

	.ss-page-hero,
	.ss-single-hero {
		padding: 58px 0 44px;
	}

	.ss-single-hero {
		min-height: 420px;
	}

	.ss-meta-list {
		grid-template-columns: 1fr;
	}

	.ss-contact__map iframe {
		height: 300px;
	}
}
