:root {
	--codepulse-primary: #0866d8;
	--codepulse-primary-dark: #04459b;
	--codepulse-secondary: #f0a35e;
	--codepulse-ink: #0f172f;
	--codepulse-text: #596175;
	--codepulse-muted: #95a1b8;
	--codepulse-surface: #ffffff;
	--codepulse-surface-soft: #f6f8fc;
	--codepulse-border: rgba(15, 23, 47, 0.08);
	--codepulse-shadow: 0 22px 60px rgba(15, 23, 47, 0.08);
	--codepulse-shadow-strong: 0 25px 90px rgba(5, 28, 73, 0.18);
	--codepulse-radius: 22px;
	--codepulse-container: min(1180px, calc(100vw - 40px));
	--codepulse-font-display: "Poppins", "Segoe UI", sans-serif;
	--codepulse-font-body: "DM Sans", "Segoe UI", sans-serif;
}

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	font-family: var(--codepulse-font-body);
	color: var(--codepulse-text);
	background:
		radial-gradient(circle at top left, rgba(8, 102, 216, 0.08), transparent 28%),
		radial-gradient(circle at bottom right, rgba(240, 163, 94, 0.12), transparent 18%),
		#ffffff;
	line-height: 1.7;
	text-rendering: optimizeLegibility;
}

a {
	color: inherit;
	text-decoration: none;
}

img {
	max-width: 100%;
	height: auto;
	display: block;
}

.codepulse-container {
	width: var(--codepulse-container);
	margin: 0 auto;
}

.codepulse-topbar {
	background: linear-gradient(180deg, #f7fbff, #eef5ff);
	font-size: 12px;
	color: #6a7895;
	border-bottom: 1px solid rgba(8, 102, 216, 0.08);
}

.codepulse-topbar__inner,
.codepulse-navbar__inner,
.codepulse-footer-bottom__inner,
.codepulse-cta-banner,
.codepulse-contact-grid,
.codepulse-footer-grid,
.codepulse-about-layout,
.codepulse-hero,
.codepulse-team-layout {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
}

.codepulse-topbar__meta,
.codepulse-footer-socials,
.codepulse-button-group,
.codepulse-inline-meta {
	display: flex;
	align-items: center;
	gap: 18px;
	flex-wrap: wrap;
}

.codepulse-navbar {
	position: sticky;
	top: 0;
	z-index: 50;
	background: rgba(255, 255, 255, 0.9);
	backdrop-filter: blur(18px);
	border-bottom: 1px solid rgba(15, 23, 47, 0.06);
	box-shadow: 0 10px 28px rgba(15, 23, 47, 0.04);
}

.codepulse-navbar__inner {
	padding: 14px 0;
	gap: 18px;
}

.site-title,
.site-title a {
	font-family: var(--codepulse-font-display);
	font-size: 28px;
	font-weight: 700;
	color: var(--codepulse-ink);
	letter-spacing: -0.03em;
}

.site-branding__link {
	display: inline-flex;
	align-items: center;
	gap: 12px;
}

.codepulse-logo {
	display: block;
	width: 224px;
	height: auto;
	max-width: 100%;
}

.codepulse-logo--footer {
	width: 200px;
	margin-bottom: 12px;
}

.codepulse-branding-logos {
	display: inline-block;
	position: relative;
	line-height: 0;
}

.codepulse-navbar .codepulse-branding-logos .codepulse-logo--on-dark-bg,
.site-footer .codepulse-branding-logos .codepulse-logo--on-light-bg {
	display: none;
}

.codepulse-navbar .codepulse-branding-logos .codepulse-logo--on-light-bg,
.site-footer .codepulse-branding-logos .codepulse-logo--on-dark-bg {
	display: block;
}

html.codepulse-dark .codepulse-navbar .codepulse-branding-logos .codepulse-logo--on-light-bg,
html.codepulse-dark .site-footer .codepulse-branding-logos .codepulse-logo--on-dark-bg {
	display: none;
}

html.codepulse-dark .codepulse-navbar .codepulse-branding-logos .codepulse-logo--on-dark-bg,
html.codepulse-dark .site-footer .codepulse-branding-logos .codepulse-logo--on-light-bg {
	display: block;
}

.codepulse-theme-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	padding: 0;
	border-radius: 14px;
	border: 1px solid rgba(15, 23, 47, 0.1);
	background: rgba(8, 102, 216, 0.06);
	color: var(--codepulse-ink);
	cursor: pointer;
	transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.15s ease;
	flex-shrink: 0;
}

.codepulse-theme-toggle:hover {
	background: rgba(8, 102, 216, 0.12);
	border-color: rgba(8, 102, 216, 0.2);
}

.codepulse-theme-toggle:active {
	transform: scale(0.96);
}

.codepulse-theme-toggle__icon {
	display: inline-flex;
	line-height: 0;
}

.codepulse-theme-toggle__icon--sun {
	display: none;
}

html.codepulse-dark .codepulse-theme-toggle__icon--sun {
	display: inline-flex;
}

html.codepulse-dark .codepulse-theme-toggle__icon--moon {
	display: none;
}

.codepulse-scroll-top {
	position: fixed;
	right: 22px;
	bottom: 28px;
	z-index: 60;
	width: 50px;
	height: 50px;
	padding: 0;
	border: 1px solid rgba(8, 102, 216, 0.22);
	border-radius: 50%;
	background: linear-gradient(135deg, #0a62d0, #2a8bff);
	color: #fff;
	cursor: pointer;
	box-shadow: 0 14px 36px rgba(8, 102, 216, 0.35);
	display: flex;
	align-items: center;
	justify-content: center;
	transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.25s ease;
}

.codepulse-scroll-top:hover {
	transform: translateY(-3px);
	box-shadow: 0 18px 40px rgba(8, 102, 216, 0.38);
}

.codepulse-scroll-top[hidden] {
	display: none !important;
}

.codepulse-scroll-top svg {
	display: block;
}

.site-title--footer {
	display: inline-block;
	margin-bottom: 12px;
}

.site-tagline {
	margin: 0;
	font-size: 13px;
	color: var(--codepulse-muted);
}

.main-navigation ul {
	display: flex;
	align-items: center;
	gap: 12px;
	list-style: none;
	margin: 0;
	padding: 0;
	font-weight: 600;
	color: var(--codepulse-ink);
}

.main-navigation li {
	display: flex;
	position: relative;
}

.main-navigation a {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 10px 14px;
	border-radius: 14px;
	font-size: 14px;
	font-weight: 700;
	letter-spacing: -0.01em;
	transition: color 0.2s ease, background-color 0.2s ease, box-shadow 0.2s ease;
}

.main-navigation a:hover,
.main-navigation li:hover > a,
.main-navigation li:focus-within > a,
.main-navigation .current-menu-item > a,
.main-navigation .current_page_item > a {
	background: rgba(8, 102, 216, 0.08);
	color: var(--codepulse-primary);
	box-shadow: inset 0 0 0 1px rgba(8, 102, 216, 0.08);
}

.main-navigation .menu-item-has-children > a {
	padding-right: 30px;
}

.main-navigation .menu-item-has-children > a::after {
	content: "";
	position: absolute;
	right: 14px;
	top: 50%;
	width: 7px;
	height: 7px;
	border-right: 1.5px solid currentColor;
	border-bottom: 1.5px solid currentColor;
	transform: translateY(-65%) rotate(45deg);
	transition: transform 0.2s ease;
}

.main-navigation .menu-item-has-children:hover > a::after,
.main-navigation .menu-item-has-children:focus-within > a::after,
.main-navigation .menu-item-has-children.is-expanded > a::after {
	transform: translateY(-20%) rotate(225deg);
}

.main-navigation .sub-menu {
	position: absolute;
	/* Flush with the bottom of the parent <li> so there is no hover “dead zone”
	   between the trigger and the panel (padding below provides visual air). */
	top: 100%;
	left: 0;
	min-width: 260px;
	padding: 12px 12px 12px;
	margin: 0;
	display: grid;
	gap: 4px;
	background: rgba(255, 255, 255, 0.98);
	border: 1px solid rgba(15, 23, 47, 0.08);
	border-radius: 18px;
	box-shadow: 0 24px 50px rgba(15, 23, 47, 0.12);
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: opacity 0.16s ease, visibility 0.16s ease;
	z-index: 60;
}

.main-navigation .sub-menu li {
	width: 100%;
}

.main-navigation .sub-menu a {
	width: 100%;
	justify-content: flex-start;
	padding: 11px 14px;
	border-radius: 12px;
	font-size: 13px;
	font-weight: 600;
	line-height: 1.35;
}

.main-navigation .sub-menu .menu-item-has-children > a::after {
	right: 12px;
}

.main-navigation li:hover > .sub-menu,
.main-navigation li:focus-within > .sub-menu,
.main-navigation li.is-expanded > .sub-menu {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
}

.codepulse-submenu-toggle {
	display: none;
}

.codepulse-menu-toggle {
	display: none;
	padding: 0;
	border: 0;
	background: transparent;
	flex-direction: column;
	gap: 5px;
	cursor: pointer;
}

.codepulse-menu-toggle span {
	width: 26px;
	height: 2px;
	border-radius: 999px;
	background: var(--codepulse-ink);
}

.codepulse-header-cta,
.codepulse-button,
.codepulse-footer-button,
.codepulse-form button,
.wp-element-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 12px 20px;
	border-radius: 999px;
	background: linear-gradient(135deg, #0a62d0, #2a8bff);
	color: #fff;
	font-weight: 700;
	font-size: 14px;
	letter-spacing: -0.01em;
	box-shadow: 0 10px 24px rgba(8, 102, 216, 0.2);
	border: 1px solid transparent;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.codepulse-header-cta {
	padding-inline: 18px;
}

.codepulse-button--ghost {
	background: linear-gradient(135deg, #0a62d0, #2a8bff);
	color: #ffffff;
	border-color: transparent;
	box-shadow: 0 10px 24px rgba(8, 102, 216, 0.2);
}

.codepulse-header-cta:hover,
.codepulse-button:hover,
.codepulse-footer-button:hover,
.codepulse-form button:hover,
.wp-element-button:hover {
	background: linear-gradient(135deg, #083f8f, #0d63d4);
	color: #ffffff;
	box-shadow: 0 12px 26px rgba(8, 102, 216, 0.18);
}

.codepulse-section {
	padding: 96px 0;
	position: relative;
}

.codepulse-elementor-main {
	padding-bottom: 0;
}

.codepulse-elementor-main .elementor {
	width: 100%;
}

.codepulse-elementor-main .elementor-section,
.codepulse-elementor-main .elementor-container,
.codepulse-elementor-main .elementor-widget-wrap {
	max-width: 100%;
}

.codepulse-elementor-main .elementor-widget-html .elementor-widget-container,
.codepulse-elementor-main .elementor-widget-codepulse_query_grid .elementor-widget-container,
.codepulse-elementor-main .elementor-widget-codepulse_services .elementor-widget-container,
.codepulse-elementor-main .elementor-widget-codepulse_contact .elementor-widget-container,
.codepulse-elementor-main .elementor-widget-codepulse_team .elementor-widget-container,
.codepulse-elementor-main .elementor-widget-codepulse_testimonials .elementor-widget-container,
.codepulse-elementor-main .elementor-widget-codepulse_cta .elementor-widget-container,
.codepulse-elementor-main .elementor-widget-codepulse_hero .elementor-widget-container {
	padding-block: 0;
}

.codepulse-section-heading {
	max-width: 720px;
	margin: 0 auto 42px;
	text-align: center;
}

.codepulse-eyebrow {
	display: inline-block;
	margin-bottom: 14px;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	color: var(--codepulse-muted);
}

h1,
h2,
h3,
h4 {
	margin: 0 0 16px;
	font-family: var(--codepulse-font-display);
	color: var(--codepulse-ink);
	line-height: 1.12;
	letter-spacing: -0.03em;
}

h1 {
	font-size: clamp(34px, 4.8vw, 56px);
}

h2 {
	font-size: clamp(28px, 3.8vw, 44px);
}

h3 {
	font-size: clamp(22px, 2.2vw, 30px);
}

.codepulse-accent {
	color: var(--codepulse-primary);
}

.codepulse-hero-wrap {
	padding: 28px 0 52px;
	background:
		linear-gradient(90deg, rgba(7, 21, 53, 0.84), rgba(7, 21, 53, 0.28)),
		var(--codepulse-hero-bg-image, none),
		radial-gradient(circle at top right, rgba(8, 102, 216, 0.3), transparent 35%),
		linear-gradient(135deg, #f3f7ff 0%, #faf6f1 100%);
	background-size: cover, cover, auto, auto;
	background-position: center center, center center, center center, center center;
	background-repeat: no-repeat;
	overflow: hidden;
}

.codepulse-page-hero-wrap {
	padding: 72px 0 68px;
	background:
		radial-gradient(circle at top left, rgba(8, 102, 216, 0.12), transparent 30%),
		radial-gradient(circle at bottom right, rgba(240, 163, 94, 0.14), transparent 22%),
		linear-gradient(135deg, #f5f9ff, #fff8f2);
	border-bottom: 1px solid rgba(15, 23, 47, 0.06);
}

.codepulse-hero {
	align-items: stretch;
	gap: 34px;
	min-height: 520px;
}

.codepulse-hero__content,
.codepulse-hero__card,
.codepulse-about-copy,
.codepulse-about-tabs,
.codepulse-contact-copy,
.codepulse-contact-card,
.codepulse-team-copy {
	flex: 1;
}

.codepulse-page-hero {
	display: grid;
	grid-template-columns: 1.3fr 0.7fr;
	gap: 32px;
	align-items: stretch;
}

.codepulse-page-hero__content {
	padding: 18px 0;
}

.codepulse-page-hero__content h1 {
	font-size: clamp(30px, 3.8vw, 44px);
	line-height: 1.16;
}

.codepulse-page-hero__content p {
	max-width: 760px;
	font-size: 16px;
	margin-bottom: 26px;
}

.codepulse-page-hero__card {
	padding: 28px;
	align-self: stretch;
}

.codepulse-page-hero__actions {
	margin-top: 28px;
	gap: 14px;
}

.codepulse-page-hero__card-text {
	margin: 18px 0 0;
	font-size: 15px;
	color: var(--codepulse-text);
}

.codepulse-page-hero-wrap--service {
	background:
		radial-gradient(circle at top right, rgba(8, 102, 216, 0.18), transparent 25%),
		radial-gradient(circle at bottom left, rgba(240, 163, 94, 0.14), transparent 22%),
		linear-gradient(135deg, #edf5ff, #fff8ef);
}

.codepulse-page-hero-wrap--service .codepulse-page-hero__content h1 {
	max-width: 760px;
	font-size: clamp(32px, 4vw, 46px);
}

.codepulse-page-hero-wrap--service .codepulse-page-hero__card {
	box-shadow: 0 30px 80px rgba(15, 23, 47, 0.08);
}

.codepulse-hero__content {
	padding: 54px 0 40px;
	color: rgba(255, 255, 255, 0.84);
}

.codepulse-hero__content .codepulse-eyebrow {
	color: rgba(255, 255, 255, 0.72);
}

.codepulse-hero__content h1 {
	max-width: 620px;
	color: #ffffff;
	font-size: clamp(32px, 4.2vw, 48px);
}

.codepulse-hero__play {
	display: inline-flex;
	align-items: center;
	gap: 14px;
	margin-top: 22px;
	font-weight: 700;
	color: #ffffff;
}

.codepulse-play-icon {
	display: inline-grid;
	place-items: center;
	width: 52px;
	height: 52px;
	border-radius: 50%;
	background: #ffffff;
	color: var(--codepulse-primary);
	box-shadow: var(--codepulse-shadow-strong);
}

.codepulse-hero__card,
.codepulse-contact-card,
.codepulse-card,
.codepulse-project-card,
.codepulse-testimonial-card,
.codepulse-team-card,
.codepulse-about-panel {
	background: rgba(255, 255, 255, 0.96);
	backdrop-filter: blur(10px);
	border-radius: var(--codepulse-radius);
	box-shadow: var(--codepulse-shadow);
	border: 1px solid rgba(255, 255, 255, 0.8);
}

.codepulse-hero__card {
	max-width: 356px;
	padding: 20px 20px 18px;
	align-self: center;
	position: relative;
	overflow: hidden;
}

.codepulse-hero__card h3,
.codepulse-contact-card h3 {
	font-size: 28px;
}

.codepulse-hero__card .codepulse-eyebrow {
	margin-bottom: 8px;
}

.codepulse-hero__card h3 {
	margin-bottom: 10px;
	font-size: clamp(30px, 2vw, 34px);
	line-height: 1.06;
}

.codepulse-hero__card p {
	margin: 0 0 14px;
	font-size: 14px;
	line-height: 1.58;
}

.codepulse-hero__card::before,
.codepulse-contact-card::before {
	content: "";
	position: absolute;
	inset: auto auto -60px -60px;
	width: 180px;
	height: 180px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(8, 102, 216, 0.16), transparent 70%);
	pointer-events: none;
}

.codepulse-form,
.codepulse-form__grid {
	display: grid;
	gap: 12px;
}

.codepulse-form__row {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
}

.codepulse-form input,
.codepulse-form select,
.codepulse-form textarea {
	width: 100%;
	padding: 13px 15px;
	border-radius: 12px;
	border: 1px solid rgba(15, 23, 47, 0.12);
	background: #f8fbff;
	font: inherit;
	font-size: 14px;
	color: var(--codepulse-ink);
	box-sizing: border-box;
}

.codepulse-form textarea {
	min-height: 118px;
	resize: vertical;
}

.codepulse-form button {
	width: fit-content;
	min-width: 132px;
}

.codepulse-form--wpforms .wpforms-container {
	margin: 0;
}

.codepulse-form--wpforms .wpforms-field-container {
	display: grid;
	gap: 12px;
}

.codepulse-form--wpforms .wpforms-field {
	padding: 0;
}

.codepulse-form--wpforms .wpforms-field-label,
.codepulse-form--wpforms .wpforms-title,
.codepulse-form--wpforms .wpforms-description {
	display: none !important;
}

.codepulse-form--wpforms .wpforms-field-row {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
}

.codepulse-form--wpforms .wpforms-field input,
.codepulse-form--wpforms .wpforms-field select,
.codepulse-form--wpforms .wpforms-field textarea {
	width: 100%;
	padding: 13px 15px;
	border-radius: 12px;
	border: 1px solid rgba(15, 23, 47, 0.12);
	background: #f8fbff;
	font: inherit;
	font-size: 14px;
	color: var(--codepulse-ink);
	box-sizing: border-box;
}

.codepulse-form--wpforms .wpforms-field textarea {
	min-height: 118px;
	resize: vertical;
}

.codepulse-form--wpforms .wpforms-submit-container {
	padding: 0;
	margin: 0;
}

.codepulse-form--wpforms .wpforms-submit {
	width: fit-content;
	min-width: 132px;
}

.codepulse-form--wpforms .wpforms-confirmation-container-full {
	margin: 0;
	padding: 12px 14px;
	border-radius: 14px;
	border: 0;
	background: rgba(13, 148, 91, 0.12);
	color: #0c7a4b;
	font-weight: 600;
}

.codepulse-form--wpforms .wpforms-error-container,
.codepulse-form--wpforms em.wpforms-error {
	padding: 12px 14px;
	border-radius: 14px;
	background: rgba(220, 38, 38, 0.1);
	color: #b91c1c;
	font-weight: 600;
	font-style: normal;
}

.codepulse-hero__card .codepulse-form--wpforms .wpforms-field-container {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
	align-items: start;
	margin: 0;
}

.codepulse-hero__card .codepulse-form--wpforms .wpforms-field-container .wpforms-field {
	grid-column: span 2;
}

.codepulse-hero__card .codepulse-form--wpforms .wpforms-field-name,
.codepulse-hero__card .codepulse-form--wpforms .wpforms-field-email {
	grid-column: span 1;
}

.codepulse-hero__card .codepulse-form--wpforms .wpforms-field-select,
.codepulse-hero__card .codepulse-form--wpforms .wpforms-field-textarea {
	grid-column: 1 / -1;
}

.codepulse-hero__card .codepulse-form--wpforms .wpforms-field select {
	background-image:
		linear-gradient(45deg, transparent 50%, #5c6c80 50%),
		linear-gradient(135deg, #5c6c80 50%, transparent 50%);
	background-position:
		calc(100% - 18px) calc(50% - 1px),
		calc(100% - 12px) calc(50% - 1px);
	background-size: 6px 6px, 6px 6px;
	background-repeat: no-repeat;
	padding-right: 34px;
	appearance: none;
}

.codepulse-hero__card .codepulse-form--wpforms .wpforms-field input,
.codepulse-hero__card .codepulse-form--wpforms .wpforms-field select,
.codepulse-hero__card .codepulse-form--wpforms .wpforms-field textarea {
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(247, 251, 255, 0.96));
	border-color: rgba(15, 23, 47, 0.1);
}

.codepulse-hero__card .codepulse-form--wpforms .wpforms-field input:focus,
.codepulse-hero__card .codepulse-form--wpforms .wpforms-field select:focus,
.codepulse-hero__card .codepulse-form--wpforms .wpforms-field textarea:focus {
	border-color: rgba(8, 102, 216, 0.42);
	box-shadow: 0 0 0 4px rgba(8, 102, 216, 0.12);
	outline: none;
	background: #ffffff;
}

.codepulse-hero__card .codepulse-form--wpforms .wpforms-submit {
	background: linear-gradient(135deg, var(--codepulse-primary), #0c7aea);
	box-shadow: 0 14px 28px rgba(8, 102, 216, 0.25);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.codepulse-hero__card .codepulse-form--wpforms .wpforms-submit-container {
	margin-top: 2px;
}

.codepulse-hero__card .codepulse-form--wpforms .wpforms-submit:hover {
	transform: translateY(-1px);
	box-shadow: 0 18px 34px rgba(8, 102, 216, 0.34);
}

.codepulse-hero__card .codepulse-form--wpforms .wpforms-submit:active {
	transform: translateY(0);
	box-shadow: 0 10px 20px rgba(8, 102, 216, 0.24);
}

.codepulse-contact-card .codepulse-form input,
.codepulse-contact-card .codepulse-form select,
.codepulse-contact-card .codepulse-form textarea,
.codepulse-contact-card .codepulse-form--wpforms .wpforms-field input,
.codepulse-contact-card .codepulse-form--wpforms .wpforms-field select,
.codepulse-contact-card .codepulse-form--wpforms .wpforms-field textarea {
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(247, 251, 255, 0.96));
	border-color: rgba(15, 23, 47, 0.1);
}

.codepulse-contact-card .codepulse-form input:focus,
.codepulse-contact-card .codepulse-form select:focus,
.codepulse-contact-card .codepulse-form textarea:focus,
.codepulse-contact-card .codepulse-form--wpforms .wpforms-field input:focus,
.codepulse-contact-card .codepulse-form--wpforms .wpforms-field select:focus,
.codepulse-contact-card .codepulse-form--wpforms .wpforms-field textarea:focus {
	border-color: rgba(8, 102, 216, 0.42);
	box-shadow: 0 0 0 4px rgba(8, 102, 216, 0.12);
	outline: none;
	background: #ffffff;
}

.codepulse-contact-card .codepulse-form select,
.codepulse-contact-card .codepulse-form--wpforms .wpforms-field select {
	background-image:
		linear-gradient(45deg, transparent 50%, #5c6c80 50%),
		linear-gradient(135deg, #5c6c80 50%, transparent 50%);
	background-position:
		calc(100% - 18px) calc(50% - 1px),
		calc(100% - 12px) calc(50% - 1px);
	background-size: 6px 6px, 6px 6px;
	background-repeat: no-repeat;
	padding-right: 34px;
	appearance: none;
}

.codepulse-contact-card .codepulse-form--wpforms .wpforms-field-container {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
	align-items: start;
	margin: 0;
}

.codepulse-contact-card .codepulse-form--wpforms .wpforms-field-container .wpforms-field {
	grid-column: span 2;
}

.codepulse-contact-card .codepulse-form--wpforms .wpforms-field-name,
.codepulse-contact-card .codepulse-form--wpforms .wpforms-field-email {
	grid-column: span 1;
}

.codepulse-contact-card .codepulse-form--wpforms .wpforms-field-select,
.codepulse-contact-card .codepulse-form--wpforms .wpforms-field-textarea {
	grid-column: 1 / -1;
}

.codepulse-contact-card .codepulse-form button,
.codepulse-contact-card .codepulse-form--wpforms .wpforms-submit {
	background: linear-gradient(135deg, var(--codepulse-primary), #0c7aea);
	box-shadow: 0 14px 28px rgba(8, 102, 216, 0.25);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.codepulse-contact-card .codepulse-form button:hover,
.codepulse-contact-card .codepulse-form--wpforms .wpforms-submit:hover {
	transform: translateY(-1px);
	box-shadow: 0 18px 34px rgba(8, 102, 216, 0.34);
}

.codepulse-contact-card .codepulse-form button:active,
.codepulse-contact-card .codepulse-form--wpforms .wpforms-submit:active {
	transform: translateY(0);
	box-shadow: 0 10px 20px rgba(8, 102, 216, 0.24);
}

/* WPForms modern theme can inject conflicting layout rules; normalize inside contact cards. */
.codepulse-contact-card .codepulse-form--wpforms .wpforms-container {
	--wpforms-field-border-radius: 12px;
	--wpforms-field-border-size: 1px;
	--wpforms-field-border-color: rgba(15, 23, 47, 0.12);
	--wpforms-field-background-color: #f8fbff;
	--wpforms-field-size-input-height: 48px;
	--wpforms-field-size-input-spacing: 12px;
	--wpforms-field-size-font-size: 14px;
	--wpforms-button-border-radius: 999px;
	--wpforms-button-size-font-size: 14px;
	--wpforms-button-size-height: 46px;
	--wpforms-button-size-padding-h: 22px;
}

.codepulse-contact-card .codepulse-form--wpforms .wpforms-field,
.codepulse-contact-card .codepulse-form--wpforms .wpforms-field.wpforms-one-half,
.codepulse-contact-card .codepulse-form--wpforms .wpforms-field.wpforms-first {
	float: none !important;
	clear: none !important;
	width: auto !important;
	margin: 0 !important;
	max-width: none !important;
}

.codepulse-contact-card .codepulse-form--wpforms .wpforms-field-container {
	margin-bottom: 0 !important;
}

.codepulse-contact-card .codepulse-form--wpforms .choices {
	margin-bottom: 0 !important;
}

.codepulse-contact-card .codepulse-form--wpforms .wpforms-submit-container {
	margin-top: 4px !important;
}

.codepulse-contact-card .codepulse-form--wpforms .wpforms-submit {
	min-width: 156px;
	border: 0 !important;
}

.codepulse-form__notice {
	padding: 12px 14px;
	border-radius: 14px;
	font-weight: 600;
}

.codepulse-form__notice--success {
	background: rgba(13, 148, 91, 0.12);
	color: #0c7a4b;
}

.codepulse-form__notice--error {
	background: rgba(220, 38, 38, 0.1);
	color: #b91c1c;
}

.codepulse-services-grid,
.codepulse-projects-grid,
.codepulse-testimonials-grid,
.codepulse-team-grid,
.codepulse-stats-grid {
	display: grid;
	gap: 24px;
}

.codepulse-services-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.codepulse-card,
.codepulse-project-card,
.codepulse-testimonial-card,
.codepulse-team-card {
	padding: 30px;
	height: 100%;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.codepulse-card:hover,
.codepulse-project-card:hover,
.codepulse-testimonial-card:hover,
.codepulse-team-card:hover,
.codepulse-blog-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 28px 70px rgba(15, 23, 47, 0.1);
}

.codepulse-card__icon {
	display: inline-grid;
	place-items: center;
	width: 56px;
	height: 56px;
	margin-bottom: 18px;
	border-radius: 16px;
	background: linear-gradient(135deg, rgba(8, 102, 216, 0.12), rgba(240, 163, 94, 0.16));
	color: var(--codepulse-primary);
	font-size: 24px;
	font-weight: 700;
}

.codepulse-card__icon i,
.codepulse-card__icon svg {
	width: 24px;
	height: 24px;
}

.codepulse-card__icon svg {
	fill: currentColor;
}

.codepulse-card__icon--stroke svg,
.codepulse-card__icon--stroke svg * {
	fill: none;
	stroke: currentColor;
}

.codepulse-card p,
.codepulse-project-card p,
.codepulse-testimonial-card p,
.codepulse-team-copy p,
.codepulse-about-copy p,
.codepulse-contact-copy p,
.codepulse-hero__content p,
.codepulse-page-hero__content p {
	margin: 0 0 18px;
	font-size: 15px;
}

.codepulse-grid-2 {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 28px;
	align-items: start;
}

.codepulse-pill-list {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

.codepulse-pill-list span {
	display: inline-flex;
	align-items: center;
	padding: 11px 16px;
	border-radius: 999px;
	background: rgba(8, 102, 216, 0.08);
	border: 1px solid rgba(8, 102, 216, 0.1);
	color: var(--codepulse-ink);
	font-weight: 600;
}

.codepulse-mini-stats,
.codepulse-stat-grid-stack,
.codepulse-process-grid,
.codepulse-faq-list {
	display: grid;
	gap: 18px;
}

.codepulse-mini-stat {
	padding: 18px 0;
	border-bottom: 1px solid rgba(15, 23, 47, 0.08);
}

.codepulse-mini-stat:last-child {
	border-bottom: 0;
	padding-bottom: 0;
}

.codepulse-mini-stat strong {
	display: block;
	font-family: var(--codepulse-font-display);
	font-size: 36px;
	color: var(--codepulse-primary);
	line-height: 1;
	margin-bottom: 8px;
}

.codepulse-process-grid {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.codepulse-card--numbered p {
	margin-bottom: 0;
}

.codepulse-projects-grid--wide {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.codepulse-faq-item {
	padding: 18px 0;
	border-bottom: 1px solid rgba(15, 23, 47, 0.08);
}

.codepulse-faq-item:last-child {
	border-bottom: 0;
	padding-bottom: 0;
}

.codepulse-faq-item h3 {
	font-size: 20px;
	margin-bottom: 8px;
}

.codepulse-about-wrap,
.codepulse-testimonials-wrap,
.codepulse-contact-wrap,
.codepulse-footer-main {
	background: var(--codepulse-surface-soft);
}

.codepulse-about-panel {
	padding: 28px;
}

.codepulse-tabs {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
	margin-bottom: 24px;
}

.codepulse-tab {
	padding: 12px 18px;
	border-radius: 999px;
	border: 1px solid rgba(8, 102, 216, 0.12);
	background: #ffffff;
	color: var(--codepulse-ink);
	font-weight: 700;
	cursor: pointer;
}

.codepulse-tab.is-active {
	background: var(--codepulse-primary);
	color: #ffffff;
	border-color: var(--codepulse-primary);
}

.codepulse-tab-panel {
	display: none;
	gap: 18px;
}

.codepulse-tab-panel.is-active {
	display: grid;
}

.codepulse-checklist {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 12px;
}

.codepulse-checklist li::before {
	content: "✓";
	margin-right: 10px;
	color: var(--codepulse-primary);
	font-weight: 700;
}

.codepulse-team-layout {
	align-items: stretch;
}

.codepulse-team-copy {
	max-width: 360px;
	position: sticky;
	top: 120px;
	height: fit-content;
}

.codepulse-team-grid,
.codepulse-projects-grid,
.codepulse-testimonials-grid,
.codepulse-stats-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.codepulse-team-card img,
.codepulse-project-card img,
.codepulse-portfolio-card img {
	width: 100%;
	aspect-ratio: 1.18 / 1;
	object-fit: cover;
	border-radius: 18px;
	margin-bottom: 20px;
	background: linear-gradient(135deg, #dfe9f8, #fff1e4);
}

.codepulse-cta-wrap {
	padding: 42px 0;
	background: linear-gradient(135deg, #fdf8f0, #f4f8ff);
	border-top: 1px solid rgba(15, 23, 47, 0.05);
	border-bottom: 1px solid rgba(15, 23, 47, 0.05);
}

.codepulse-cta-banner {
	padding: 18px 0;
}

.codepulse-project-card__meta,
.codepulse-testimonial-meta {
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--codepulse-muted);
	margin-bottom: 12px;
}

.codepulse-slider-dots {
	display: flex;
	justify-content: center;
	gap: 10px;
	margin-top: 26px;
}

.codepulse-slider-dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: rgba(8, 102, 216, 0.16);
	border: 0;
	padding: 0;
	cursor: pointer;
}

.codepulse-slider-dot.is-active {
	background: var(--codepulse-primary);
}

.codepulse-rating {
	color: var(--codepulse-secondary);
	font-size: 18px;
	letter-spacing: 0.18em;
	margin-bottom: 14px;
}

.codepulse-stats-grid {
	margin-top: 36px;
}

.codepulse-stat {
	padding: 28px;
	text-align: center;
	background: #ffffff;
	border-radius: 20px;
	border: 1px solid var(--codepulse-border);
	box-shadow: var(--codepulse-shadow);
}

.codepulse-stat strong {
	display: block;
	font-family: var(--codepulse-font-display);
	font-size: 44px;
	color: var(--codepulse-primary);
	line-height: 1;
	margin-bottom: 12px;
}

.codepulse-contact-grid {
	align-items: stretch;
}

.codepulse-contact-copy {
	padding-right: 20px;
}

.codepulse-contact-card {
	padding: 34px;
	position: relative;
	overflow: hidden;
}

.codepulse-footer-main {
	padding: 84px 0 40px;
	background:
		radial-gradient(circle at top right, rgba(53, 116, 255, 0.16), transparent 22%),
		linear-gradient(180deg, #0f1b34 0%, #111d39 100%);
	color: rgba(255, 255, 255, 0.74);
}

.codepulse-footer-grid {
	align-items: flex-start;
	display: grid;
	grid-template-columns: 1.2fr 0.8fr 0.8fr 1fr;
	gap: 28px;
}

.site-footer h3 {
	font-size: 18px;
	margin-bottom: 14px;
	color: #ffffff;
}

.site-footer .site-title,
.site-footer .site-title a,
.site-footer a {
	color: #ffffff;
}

.site-footer p,
.site-footer li {
	color: rgba(255, 255, 255, 0.68);
}

.site-footer ul a:hover,
.site-footer p a:hover {
	color: #8cc0ff;
}

.site-footer ul {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: 10px;
}

.codepulse-footer-bottom {
	padding: 18px 0;
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	background: #091327;
	color: rgba(255, 255, 255, 0.6);
}

.codepulse-footer-socials a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.08);
	color: #ffffff;
	transition: background-color 0.2s ease, transform 0.2s ease;
}

.codepulse-footer-socials a svg {
	width: 16px;
	height: 16px;
	fill: currentColor;
}

.codepulse-footer-socials a:hover {
	background: rgba(140, 192, 255, 0.18);
	transform: translateY(-1px);
}

.codepulse-rich-section {
	padding: 20px 0;
}

.codepulse-grid-2--reverse > :first-child {
	order: 2;
}

.codepulse-grid-2--reverse > :last-child {
	order: 1;
}

.codepulse-rich-copy,
.codepulse-page-hero__content,
.codepulse-page-hero__card {
	height: 100%;
}

.codepulse-illustration {
	width: 100%;
	min-height: 340px;
	object-fit: cover;
	border-radius: 18px;
	background: linear-gradient(135deg, #eef4ff, #fff3e8);
}

.codepulse-link-grid,
.codepulse-proof-grid,
.codepulse-blog-grid {
	display: grid;
	gap: 24px;
}

.codepulse-link-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
	margin-top: 16px;
}

.codepulse-link-card {
	display: grid;
	gap: 12px;
	padding: 28px;
	background: #fff;
	border: 1px solid rgba(15, 23, 47, 0.08);
	border-radius: 22px;
	box-shadow: var(--codepulse-shadow);
	transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.codepulse-link-card:hover {
	transform: translateY(-4px);
	border-color: rgba(8, 102, 216, 0.22);
	box-shadow: 0 26px 70px rgba(15, 23, 47, 0.12);
}

.codepulse-link-card strong {
	font-family: var(--codepulse-font-display);
	font-size: 24px;
	color: var(--codepulse-ink);
	line-height: 1.2;
}

.codepulse-link-card em {
	font-style: normal;
	color: var(--codepulse-text);
}

.codepulse-link-card__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	border-radius: 16px;
	background: linear-gradient(135deg, rgba(8, 102, 216, 0.12), rgba(240, 163, 94, 0.18));
	color: var(--codepulse-primary);
	font-weight: 800;
}

.codepulse-proof-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
	margin-top: 18px;
}

.codepulse-proof-section {
	padding-top: 28px;
}

.codepulse-proof-card,
.codepulse-blog-card {
	padding: 30px;
	background: #fff;
	border: 1px solid rgba(15, 23, 47, 0.08);
	border-radius: 22px;
	box-shadow: var(--codepulse-shadow);
}

.codepulse-proof-card {
	position: relative;
	overflow: hidden;
	background: linear-gradient(180deg, #ffffff, #f8fbff);
	box-shadow: 0 20px 54px rgba(15, 23, 47, 0.06);
}

.codepulse-proof-card::before {
	content: "";
	position: absolute;
	inset: 0 auto auto 0;
	width: 100%;
	height: 4px;
	background: linear-gradient(90deg, var(--codepulse-primary), var(--codepulse-secondary));
}

.codepulse-proof-card:hover {
	border-color: rgba(8, 102, 216, 0.16);
	box-shadow: 0 28px 68px rgba(15, 23, 47, 0.1);
}

.codepulse-proof-card strong {
	display: block;
	font-family: var(--codepulse-font-display);
	font-size: 22px;
	color: var(--codepulse-ink);
	margin-bottom: 12px;
}

.codepulse-proof-card p,
.codepulse-blog-card p {
	margin: 0;
}

.codepulse-portfolio-grid {
	display: grid;
	gap: 24px;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.codepulse-portfolio-card {
	padding: 24px;
	background: rgba(255, 255, 255, 0.96);
	backdrop-filter: blur(10px);
	border-radius: var(--codepulse-radius);
	box-shadow: var(--codepulse-shadow);
	border: 1px solid rgba(255, 255, 255, 0.8);
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.codepulse-portfolio-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 28px 70px rgba(15, 23, 47, 0.1);
}

.codepulse-portfolio-card h3 {
	font-size: 20px;
	margin-bottom: 0;
}

.codepulse-blog-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.codepulse-blog-card h3 {
	font-size: 26px;
}

.codepulse-blog-card .entry-title {
	font-size: 24px;
	margin-bottom: 12px;
}

.codepulse-pagination {
	margin-top: 34px;
}

.codepulse-pagination .page-numbers {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	justify-content: center;
}

.codepulse-pagination .page-numbers a,
.codepulse-pagination .page-numbers span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 42px;
	height: 42px;
	padding: 0 14px;
	border-radius: 999px;
	border: 1px solid var(--codepulse-border);
	background: #ffffff;
	color: var(--codepulse-ink);
	font-weight: 700;
}

.codepulse-pagination .page-numbers .current {
	background: var(--codepulse-primary);
	border-color: var(--codepulse-primary);
	color: #ffffff;
}

.codepulse-card-image,
.codepulse-card-image--fallback {
	width: 100%;
	height: 240px;
	border-radius: 18px;
	margin-bottom: 22px;
	object-fit: cover;
	background: linear-gradient(135deg, #e6eefc, #fff1e4);
}

.codepulse-card-image--fallback {
	display: grid;
	place-items: center;
	font-family: var(--codepulse-font-display);
	font-size: 44px;
	font-weight: 800;
	color: var(--codepulse-primary);
}

.single-post .site-main,
.single-codepulse_portfolio .site-main {
	background: linear-gradient(180deg, #f8fbff 0%, #ffffff 38%);
}

.single-post .entry-content,
.single-codepulse_portfolio .entry-content {
	font-size: 18px;
	line-height: 1.8;
}

.codepulse-content-block {
	padding: 72px 0 96px;
}

.codepulse-page-shell {
	padding-bottom: 36px;
}

.entry-title {
	margin-bottom: 24px;
}

.entry-content > * {
	max-width: 780px;
	margin-inline: auto;
	margin-bottom: 24px;
}

.entry-content h2,
.entry-content h3 {
	margin-top: 42px;
}

.entry-content p,
.entry-content li {
	font-size: 18px;
}


.codepulse-rich-section .codepulse-grid-2,
.codepulse-page-hero-wrap--elementor .codepulse-page-hero,
.codepulse-elementor-main .codepulse-section > .codepulse-container,
.codepulse-elementor-main .codepulse-rich-section > .codepulse-grid-2,
.codepulse-elementor-main .codepulse-rich-section > .codepulse-section-heading,
.codepulse-elementor-main .codepulse-rich-section > .codepulse-link-grid,
.codepulse-elementor-main .codepulse-rich-section > .codepulse-proof-grid,
.codepulse-elementor-main .codepulse-page-hero-wrap > .codepulse-page-hero {
	width: var(--codepulse-container);
	margin-inline: auto;
}

.codepulse-elementor-main .codepulse-section,
.codepulse-elementor-main .codepulse-rich-section,
.codepulse-elementor-main .codepulse-page-hero-wrap {
	width: 100%;
	max-width: none;
}

.codepulse-page-hero-wrap--elementor,
.codepulse-elementor-main .codepulse-page-hero-wrap {
	padding-top: 92px;
	padding-bottom: 86px;
}

.codepulse-elementor-main .codepulse-rich-section {
	padding-top: 32px;
	padding-bottom: 32px;
}

.codepulse-elementor-main .codepulse-link-grid,
.codepulse-elementor-main .codepulse-proof-grid,
.codepulse-elementor-main .codepulse-blog-grid,
.codepulse-elementor-main .codepulse-services-grid,
.codepulse-elementor-main .codepulse-projects-grid {
	margin-top: 10px;
}

.elementor-widget-codepulse_hero .elementor-widget-container,
.elementor-widget-codepulse_services .elementor-widget-container,
.elementor-widget-codepulse_about_tabs .elementor-widget-container,
.elementor-widget-codepulse_team .elementor-widget-container,
.elementor-widget-codepulse_cta .elementor-widget-container,
.elementor-widget-codepulse_projects .elementor-widget-container,
.elementor-widget-codepulse_testimonials .elementor-widget-container,
.elementor-widget-codepulse_contact .elementor-widget-container,
.elementor-widget-codepulse_section_heading .elementor-widget-container,
.elementor-widget-codepulse_portfolio_minimal .elementor-widget-container,
.elementor-widget-codepulse_counter_stats .elementor-widget-container {
	width: 100%;
}

@media (max-width: 1100px) {
	.codepulse-hero,
	.codepulse-page-hero,
	.codepulse-about-layout,
	.codepulse-team-layout,
	.codepulse-contact-grid,
	.codepulse-footer-grid {
		grid-template-columns: 1fr;
		display: grid;
	}

	.codepulse-services-grid,
	.codepulse-projects-grid,
	.codepulse-portfolio-grid,
	.codepulse-testimonials-grid,
	.codepulse-team-grid,
	.codepulse-stats-grid,
	.codepulse-footer-grid,
	.codepulse-process-grid,
	.codepulse-grid-2,
	.codepulse-projects-grid--wide,
	.codepulse-link-grid,
	.codepulse-proof-grid,
	.codepulse-blog-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.codepulse-team-copy {
		position: static;
		max-width: none;
	}
}

@media (max-width: 860px) {
	.codepulse-navbar__inner {
		flex-wrap: wrap;
		padding: 16px 0;
	}

	.codepulse-menu-toggle {
		display: inline-flex;
	}

	.main-navigation {
		width: 100%;
		display: none;
	}

	.main-navigation.is-open {
		display: block;
	}

	.main-navigation ul {
		flex-direction: column;
		align-items: flex-start;
		gap: 4px;
	}

	.main-navigation li {
		width: 100%;
		flex-wrap: wrap;
	}

	.main-navigation a {
		width: 100%;
		justify-content: flex-start;
	}

	.main-navigation .menu-item-has-children > a {
		width: calc(100% - 40px);
		padding-right: 14px;
	}

	.main-navigation .menu-item-has-children > a::after {
		display: none;
	}

	.main-navigation .sub-menu {
		position: static;
		min-width: 0;
		width: 100%;
		padding: 4px 0 0 14px;
		background: transparent;
		border: 0;
		border-radius: 0;
		box-shadow: none;
		opacity: 1;
		visibility: visible;
		pointer-events: auto;
		transform: none;
		display: none;
	}

	.main-navigation .menu-item-has-children.is-expanded > .sub-menu {
		display: grid;
	}

	.main-navigation .sub-menu a {
		padding: 10px 0;
		font-size: 14px;
		border-radius: 0;
	}

	.main-navigation .sub-menu a:hover,
		.main-navigation .sub-menu .current-menu-item > a,
		.main-navigation .sub-menu .current_page_item > a {
		background: transparent;
		box-shadow: none;
	}

	.codepulse-submenu-toggle {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: 36px;
		height: 36px;
		margin-left: auto;
		border: 0;
		border-radius: 10px;
		background: rgba(8, 102, 216, 0.08);
		color: var(--codepulse-primary);
		cursor: pointer;
	}

	.codepulse-submenu-toggle::before {
		content: "+";
		font-size: 20px;
		line-height: 1;
	}

	.main-navigation .menu-item-has-children.is-expanded > .codepulse-submenu-toggle::before {
		content: "−";
	}

	.codepulse-header-cta {
		display: none;
	}

	.codepulse-logo {
		width: 178px;
	}

	.codepulse-topbar__inner,
	.codepulse-cta-banner {
		flex-direction: column;
		align-items: flex-start;
	}

	.codepulse-services-grid,
	.codepulse-projects-grid,
	.codepulse-portfolio-grid,
	.codepulse-testimonials-grid,
	.codepulse-team-grid,
	.codepulse-stats-grid,
	.codepulse-footer-grid,
	.codepulse-process-grid,
	.codepulse-grid-2,
	.codepulse-projects-grid--wide,
	.codepulse-link-grid,
	.codepulse-proof-grid,
	.codepulse-blog-grid {
		grid-template-columns: 1fr;
	}

	.codepulse-illustration,
	.codepulse-card-image,
	.codepulse-card-image--fallback {
		height: auto;
		min-height: 220px;
	}


	h1 {
		font-size: 36px;
	}

	h2 {
		font-size: 28px;
	}

	.codepulse-section {
		padding: 74px 0;
	}

	.codepulse-hero__content {
		padding: 36px 0 12px;
	}

	.codepulse-hero__card,
	.codepulse-contact-card {
		max-width: none;
	}

	.codepulse-form__row {
		grid-template-columns: 1fr;
	}

	.codepulse-hero__card .codepulse-form--wpforms .wpforms-field-container {
		grid-template-columns: 1fr;
	}

	.codepulse-contact-card .codepulse-form--wpforms .wpforms-field-container {
		grid-template-columns: 1fr;
	}

	.codepulse-hero__card .codepulse-form--wpforms .wpforms-field-name,
	.codepulse-hero__card .codepulse-form--wpforms .wpforms-field-email,
	.codepulse-hero__card .codepulse-form--wpforms .wpforms-field-select,
	.codepulse-hero__card .codepulse-form--wpforms .wpforms-field-textarea {
		grid-column: span 2;
	}

	.codepulse-contact-card .codepulse-form--wpforms .wpforms-field-name,
	.codepulse-contact-card .codepulse-form--wpforms .wpforms-field-email,
	.codepulse-contact-card .codepulse-form--wpforms .wpforms-field-select,
	.codepulse-contact-card .codepulse-form--wpforms .wpforms-field-textarea {
		grid-column: span 2;
	}
}

/* Site dark mode (visitor toggle) */
html.codepulse-dark {
	color-scheme: dark;
	--codepulse-ink: #e8edf7;
	--codepulse-text: #b4bfd6;
	--codepulse-muted: #8b96ad;
	--codepulse-surface: #141c2f;
	--codepulse-surface-soft: #182236;
	--codepulse-border: rgba(232, 237, 247, 0.1);
	--codepulse-shadow: 0 22px 60px rgba(0, 0, 0, 0.35);
	--codepulse-shadow-strong: 0 25px 90px rgba(0, 0, 0, 0.45);
}

html.codepulse-dark body {
	background:
		radial-gradient(circle at top left, rgba(8, 102, 216, 0.12), transparent 30%),
		radial-gradient(circle at bottom right, rgba(240, 163, 94, 0.08), transparent 22%),
		#0b1020;
	color: var(--codepulse-text);
}

html.codepulse-dark .codepulse-topbar {
	background: linear-gradient(180deg, #141d33, #10182c);
	color: #9aa6bf;
	border-bottom-color: rgba(255, 255, 255, 0.06);
}

html.codepulse-dark .codepulse-navbar {
	background: rgba(12, 18, 32, 0.94);
	border-bottom-color: rgba(255, 255, 255, 0.08);
	box-shadow: 0 10px 28px rgba(0, 0, 0, 0.35);
}

html.codepulse-dark .main-navigation a {
	color: var(--codepulse-ink);
}

html.codepulse-dark .codepulse-menu-toggle span {
	background: var(--codepulse-ink);
}

html.codepulse-dark .codepulse-theme-toggle {
	border-color: rgba(255, 255, 255, 0.12);
	background: rgba(8, 102, 216, 0.15);
	color: #e8edf7;
}

html.codepulse-dark .codepulse-theme-toggle:hover {
	background: rgba(8, 102, 216, 0.28);
	border-color: rgba(126, 183, 255, 0.35);
}

html.codepulse-dark .codepulse-about-wrap,
html.codepulse-dark .codepulse-testimonials-wrap,
html.codepulse-dark .codepulse-contact-wrap,
html.codepulse-dark .codepulse-footer-main {
	background: var(--codepulse-surface-soft);
}

html.codepulse-dark .codepulse-card,
html.codepulse-dark .codepulse-stat,
html.codepulse-dark .codepulse-team-card,
html.codepulse-dark .codepulse-project-card,
html.codepulse-dark .codepulse-testimonial-card,
html.codepulse-dark .codepulse-contact-card,
html.codepulse-dark .codepulse-about-panel,
html.codepulse-dark .codepulse-hero__card {
	background: var(--codepulse-surface);
	border-color: var(--codepulse-border);
	color: var(--codepulse-text);
	box-shadow: var(--codepulse-shadow);
}

html.codepulse-dark .codepulse-tab {
	background: var(--codepulse-surface);
	border-color: rgba(126, 183, 255, 0.2);
	color: var(--codepulse-ink);
}

html.codepulse-dark .codepulse-cta-wrap {
	background: linear-gradient(135deg, #1a1528, #152238);
	border-color: rgba(255, 255, 255, 0.06);
}

html.codepulse-dark .codepulse-scroll-top {
	border-color: rgba(126, 183, 255, 0.35);
	background: linear-gradient(135deg, #1e4a9e, #2a7fd4);
	box-shadow: 0 14px 36px rgba(0, 0, 0, 0.45);
}

/* —— Portfolio minimal (Jevelin-inspired grid + technology filters) —— */
.codepulse-section-heading-block {
	padding-top: clamp(40px, 5vw, 72px);
	padding-bottom: clamp(8px, 2vw, 20px);
}

.codepulse-section-heading-block .codepulse-section-heading--standalone {
	max-width: 720px;
	margin: 0 auto;
	text-align: center;
}

.codepulse-section-heading-block .codepulse-section-heading--standalone p {
	margin-top: 14px;
	font-size: 17px;
	line-height: 1.65;
	color: var(--codepulse-text);
}

.codepulse-portfolio-minimal {
	padding-top: clamp(48px, 6vw, 88px);
	padding-bottom: clamp(48px, 6vw, 96px);
}

.codepulse-portfolio-minimal--tight-top {
	padding-top: clamp(16px, 2.5vw, 28px);
}

.codepulse-section-heading-block + .codepulse-portfolio-minimal--tight-top {
	padding-top: clamp(8px, 1.5vw, 18px);
}

.elementor-widget-codepulse_section_heading + .elementor-widget-codepulse_portfolio_minimal .codepulse-portfolio-minimal--tight-top {
	padding-top: clamp(8px, 1.5vw, 22px);
}

.codepulse-portfolio-minimal__intro {
	max-width: 640px;
	margin: 0 auto 40px;
	text-align: center;
}

.codepulse-portfolio-minimal__title {
	font-family: var(--codepulse-font-display);
	font-size: clamp(28px, 3.4vw, 42px);
	font-weight: 700;
	letter-spacing: -0.03em;
	line-height: 1.15;
	color: var(--codepulse-ink);
	margin: 12px 0 0;
}

.codepulse-portfolio-minimal__lead {
	margin: 16px 0 0;
	font-size: 17px;
	line-height: 1.65;
	color: var(--codepulse-text);
}

.codepulse-portfolio-filters {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 8px 20px;
	margin: 0 0 36px;
}

.codepulse-portfolio-filter {
	font-family: var(--codepulse-font-body);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: rgba(15, 23, 47, 0.45);
	background: transparent;
	border: none;
	border-bottom: 2px solid transparent;
	padding: 6px 2px 10px;
	cursor: pointer;
	transition: color 0.2s ease, border-color 0.2s ease, opacity 0.2s ease;
}

.codepulse-portfolio-filter:hover {
	color: var(--codepulse-ink);
}

.codepulse-portfolio-filter.is-active {
	color: var(--codepulse-primary);
	border-bottom-color: var(--codepulse-primary);
}

.codepulse-portfolio-mosaic {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 20px;
}

.codepulse-portfolio-tile {
	margin: 0;
}

.codepulse-portfolio-tile__link {
	display: block;
	text-decoration: none;
	color: inherit;
	border-radius: 16px;
}

.codepulse-portfolio-tile__media {
	position: relative;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	border-radius: 14px;
	background: linear-gradient(145deg, #eef2fb, #f7f5ff);
	box-shadow: 0 1px 0 rgba(15, 23, 47, 0.06);
}

.codepulse-portfolio-tile__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transform: scale(1.01);
	transition: transform 0.65s cubic-bezier(0.22, 1, 0.36, 1), filter 0.45s ease;
}

.codepulse-portfolio-tile__placeholder {
	position: absolute;
	inset: 0;
	background: radial-gradient(circle at 30% 20%, rgba(8, 102, 216, 0.12), transparent 55%),
		radial-gradient(circle at 80% 80%, rgba(240, 163, 94, 0.18), transparent 50%);
}

.codepulse-portfolio-tile__shine {
	pointer-events: none;
	position: absolute;
	inset: 0;
	opacity: 0;
	background: linear-gradient(115deg, transparent 42%, rgba(255, 255, 255, 0.35) 50%, transparent 58%);
	transition: opacity 0.5s ease;
}

.codepulse-portfolio-tile__link:hover .codepulse-portfolio-tile__img {
	transform: scale(1.06);
	filter: saturate(1.05);
}

.codepulse-portfolio-tile__link:hover .codepulse-portfolio-tile__shine {
	opacity: 1;
}

.codepulse-portfolio-tile__caption {
	padding: 14px 4px 0;
}

.codepulse-portfolio-tile__meta {
	display: block;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: rgba(15, 23, 47, 0.42);
	margin-bottom: 4px;
}

.codepulse-portfolio-tile__name {
	font-family: var(--codepulse-font-display);
	font-size: 17px;
	font-weight: 600;
	letter-spacing: -0.02em;
	margin: 0;
	color: var(--codepulse-ink);
	line-height: 1.25;
	transition: color 0.2s ease;
}

.codepulse-portfolio-tile__link:hover .codepulse-portfolio-tile__name {
	color: var(--codepulse-primary);
}

.codepulse-portfolio-minimal__empty {
	text-align: center;
	grid-column: 1 / -1;
	color: var(--codepulse-text);
}

.codepulse-portfolio-minimal__footer {
	margin-top: 44px;
	text-align: center;
}

.codepulse-portfolio-view-all {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	text-decoration: none;
	color: var(--codepulse-ink);
	border-bottom: 2px solid rgba(8, 102, 216, 0.35);
	padding-bottom: 4px;
	transition: color 0.2s ease, border-color 0.2s ease;
}

.codepulse-portfolio-view-all:hover {
	color: var(--codepulse-primary);
	border-bottom-color: var(--codepulse-primary);
}

.codepulse-portfolio-tile[hidden] {
	display: none !important;
}

@media (max-width: 1100px) {
	.codepulse-portfolio-mosaic {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 780px) {
	.codepulse-portfolio-mosaic {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 14px;
	}

	.codepulse-portfolio-filters {
		justify-content: flex-start;
		overflow-x: auto;
		flex-wrap: nowrap;
		padding-bottom: 6px;
		margin-bottom: 28px;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: thin;
	}

	.codepulse-portfolio-filter {
		flex: 0 0 auto;
	}
}

@media (max-width: 480px) {
	.codepulse-portfolio-mosaic {
		grid-template-columns: 1fr;
	}
}

html.codepulse-dark .codepulse-portfolio-filter {
	color: rgba(230, 237, 255, 0.45);
}

html.codepulse-dark .codepulse-portfolio-filter:hover,
html.codepulse-dark .codepulse-portfolio-filter.is-active {
	color: #b8d4ff;
}

html.codepulse-dark .codepulse-portfolio-filter.is-active {
	border-bottom-color: #7eb7ff;
}

html.codepulse-dark .codepulse-portfolio-tile__media {
	background: linear-gradient(145deg, #1c2436, #232031);
	box-shadow: none;
}

html.codepulse-dark .codepulse-portfolio-tile__meta {
	color: rgba(230, 237, 255, 0.45);
}

html.codepulse-dark .codepulse-portfolio-tile__name {
	color: var(--codepulse-ink);
}

html.codepulse-dark .codepulse-portfolio-view-all {
	color: #e8f0ff;
	border-bottom-color: rgba(126, 183, 255, 0.45);
}

html.codepulse-dark .codepulse-section-heading-block .codepulse-section-heading--standalone p {
	color: var(--codepulse-text);
}

/* —— Counter stats (standalone four-box section) —— */
.codepulse-counter-stats {
	padding-top: clamp(40px, 5vw, 72px);
	padding-bottom: clamp(40px, 5vw, 72px);
	background: linear-gradient(180deg, #f6f8fd 0%, #fafbfe 100%);
	border-top: 1px solid rgba(15, 23, 47, 0.05);
	border-bottom: 1px solid rgba(15, 23, 47, 0.05);
}

.codepulse-counter-stats__heading {
	text-align: center;
	max-width: 640px;
	margin: 0 auto 36px;
}

.codepulse-counter-stats__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 22px;
}

.codepulse-counter-box {
	padding: 32px 20px 34px;
	text-align: center;
	background: #ffffff;
	border-radius: 22px;
	border: 1px solid rgba(15, 23, 47, 0.06);
	box-shadow: 0 14px 40px rgba(15, 23, 47, 0.08);
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.codepulse-counter-box:hover {
	transform: translateY(-3px);
	box-shadow: 0 22px 50px rgba(15, 23, 47, 0.11);
}

.codepulse-counter-box__value {
	display: block;
	font-family: var(--codepulse-font-display);
	font-size: clamp(38px, 4.5vw, 52px);
	font-weight: 700;
	line-height: 1;
	letter-spacing: -0.02em;
	color: var(--codepulse-primary);
	margin-bottom: 14px;
}

.codepulse-counter-box__label {
	display: block;
	font-size: 15px;
	font-weight: 500;
	line-height: 1.45;
	color: rgba(15, 23, 47, 0.58);
}

@media (max-width: 900px) {
	.codepulse-counter-stats__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 18px;
	}
}

@media (max-width: 480px) {
	.codepulse-counter-stats__grid {
		grid-template-columns: 1fr;
	}
}

html.codepulse-dark .codepulse-counter-stats {
	background: linear-gradient(180deg, rgba(22, 28, 42, 0.92), rgba(18, 22, 34, 0.98));
	border-top-color: rgba(255, 255, 255, 0.05);
	border-bottom-color: rgba(255, 255, 255, 0.05);
}

html.codepulse-dark .codepulse-counter-box {
	background: var(--codepulse-surface);
	border-color: var(--codepulse-border);
	box-shadow: var(--codepulse-shadow);
}

html.codepulse-dark .codepulse-counter-box__label {
	color: rgba(230, 237, 255, 0.62);
}

/* —— Technology stacks: homepage services + services link grid —— */
.codepulse-tech-services {
	position: relative;
	overflow: hidden;
	background: radial-gradient(900px 420px at 12% 0%, rgba(8, 102, 216, 0.1), transparent 55%),
		radial-gradient(700px 380px at 92% 20%, rgba(240, 163, 94, 0.12), transparent 50%),
		linear-gradient(180deg, #f5f8ff 0%, #ffffff 42%, #f9fafc 100%);
}

.codepulse-tech-services::after {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	background: linear-gradient(120deg, rgba(255, 255, 255, 0) 40%, rgba(255, 255, 255, 0.35) 50%, rgba(255, 255, 255, 0) 60%);
	opacity: 0.45;
}

.codepulse-tech-services .codepulse-container {
	position: relative;
	z-index: 1;
}

.codepulse-tech-services .codepulse-card {
	background: rgba(255, 255, 255, 0.94);
	backdrop-filter: blur(12px);
	border: 1px solid rgba(255, 255, 255, 0.85);
	box-shadow: 0 22px 60px rgba(15, 23, 47, 0.08);
}

.codepulse-tech-services .codepulse-card__icon {
	width: 64px;
	height: 64px;
	border-radius: 20px;
	font-size: 26px;
	background: linear-gradient(145deg, rgba(8, 102, 216, 0.2), rgba(240, 163, 94, 0.22));
	box-shadow: 0 12px 32px rgba(8, 102, 216, 0.18);
	border: 1px solid rgba(255, 255, 255, 0.65);
}

.codepulse-tech-services .codepulse-card__icon svg {
	width: 28px;
	height: 28px;
}

.codepulse-tech-link-stack {
	position: relative;
	padding: clamp(28px, 4vw, 44px);
	border-radius: 28px;
	border: 1px solid rgba(15, 23, 47, 0.06);
	background: linear-gradient(165deg, rgba(255, 255, 255, 0.96), rgba(245, 249, 255, 0.98));
	box-shadow: 0 30px 90px rgba(15, 23, 47, 0.07);
	overflow: hidden;
}

.codepulse-tech-link-stack::before {
	content: "";
	position: absolute;
	inset: -40% -20% auto;
	height: 70%;
	background: radial-gradient(closest-side, rgba(8, 102, 216, 0.12), transparent 70%);
	pointer-events: none;
}

.codepulse-tech-link-stack .codepulse-section-heading {
	position: relative;
	z-index: 1;
}

.codepulse-link-grid--tech {
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 20px;
	margin-top: 22px;
	position: relative;
	z-index: 1;
}

.codepulse-link-card--tech {
	display: flex;
	flex-direction: column;
	padding: 0;
	overflow: hidden;
	border-radius: 24px;
	border: 1px solid rgba(15, 23, 47, 0.07);
	background: #ffffff;
	box-shadow: 0 18px 50px rgba(15, 23, 47, 0.07);
}

.codepulse-link-card--tech:hover {
	transform: translateY(-5px);
	border-color: rgba(8, 102, 216, 0.22);
	box-shadow: 0 28px 70px rgba(8, 102, 216, 0.14);
}

.codepulse-link-card__media {
	position: relative;
	height: 152px;
	overflow: hidden;
}

.codepulse-link-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transform: scale(1.02);
	transition: transform 0.55s cubic-bezier(0.22, 1, 0.36, 1);
}

.codepulse-link-card--tech:hover .codepulse-link-card__media img {
	transform: scale(1.07);
}

.codepulse-link-card__media-shade {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 10%, rgba(10, 16, 35, 0.55) 100%);
}

.codepulse-link-card__body {
	padding: 20px 22px 24px;
	display: grid;
	gap: 10px;
}

.codepulse-link-card--tech:not(.codepulse-link-card--tech-no-media) .codepulse-link-card__iconrow {
	margin-top: -38px;
	margin-bottom: 4px;
	position: relative;
	z-index: 2;
}

.codepulse-link-card--tech-no-media .codepulse-link-card__body {
	padding-top: 24px;
}

.codepulse-link-card__icon-ring {
	width: 56px;
	height: 56px;
	border-radius: 18px;
	display: inline-grid;
	place-items: center;
	background: linear-gradient(145deg, #ffffff, #eef4ff);
	border: 1px solid rgba(8, 102, 216, 0.2);
	box-shadow: 0 14px 36px rgba(8, 102, 216, 0.2);
	color: var(--codepulse-primary);
	font-size: 22px;
}

.codepulse-link-card__icon-ring svg {
	width: 26px;
	height: 26px;
}

.codepulse-link-card--tech .codepulse-link-card__badge {
	width: 56px;
	height: 56px;
	border-radius: 18px;
	font-size: 16px;
}

.codepulse-link-card--tech strong {
	font-size: 22px;
}

.codepulse-link-card--tech em {
	font-size: 14px;
	line-height: 1.55;
}

html.codepulse-dark .codepulse-tech-services {
	background: radial-gradient(900px 420px at 12% 0%, rgba(8, 102, 216, 0.18), transparent 55%),
		linear-gradient(180deg, #121826, #151b2a 100%);
}

html.codepulse-dark .codepulse-tech-services .codepulse-card {
	background: rgba(22, 28, 42, 0.92);
	border-color: rgba(255, 255, 255, 0.08);
}

html.codepulse-dark .codepulse-tech-link-stack {
	background: linear-gradient(165deg, rgba(22, 28, 42, 0.95), rgba(18, 22, 34, 0.98));
	border-color: rgba(255, 255, 255, 0.08);
}

html.codepulse-dark .codepulse-link-card--tech {
	background: var(--codepulse-surface);
	border-color: var(--codepulse-border);
}

html.codepulse-dark .codepulse-link-card__icon-ring {
	background: linear-gradient(145deg, #1a2234, #243047);
	border-color: rgba(126, 183, 255, 0.25);
	color: #b8d4ff;
}

.codepulse-tech-services .codepulse-services-grid {
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 22px;
}

.codepulse-tech-services .codepulse-card {
	border-radius: 22px;
	border: 1px solid rgba(15, 23, 47, 0.06);
	background: rgba(255, 255, 255, 0.88);
}

.codepulse-tech-services .codepulse-section-heading {
	max-width: 920px;
}

.codepulse-tech-services .codepulse-section-heading h2 {
	letter-spacing: -0.02em;
	line-height: 1.18;
}

.codepulse-tech-link-stack .codepulse-section-heading p {
	color: rgba(15, 23, 47, 0.62);
	font-size: 16px;
	line-height: 1.65;
	max-width: 720px;
}

html.codepulse-dark .codepulse-tech-link-stack .codepulse-section-heading p {
	color: rgba(230, 237, 255, 0.65);
}

html.codepulse-dark .codepulse-tech-services .codepulse-card {
	border-color: rgba(255, 255, 255, 0.08);
}
