/*
 Theme Name:   Woodmart Child
 Description:  Woodmart Child Theme
 Author:       XTemos
 Author URI:   http://xtemos.com
 Template:     woodmart
 Version:      1.0.0
 Text Domain:  woodmart
*/

:root {
	--ctk-heading-font: "Sora", Arial, sans-serif;
}

body h1,
body h2,
body h3,
body h4,
body h5,
body h6,
body .elementor-heading-title,
body .title,
body .wd-entities-title {
	font-family: var(--ctk-heading-font) !important;
	letter-spacing: 0;
}

body h1,
body h2,
body .elementor-heading-title {
	font-weight: 700 !important;
}

.ctk-services-page {
	--ctk-ink: #172033;
	--ctk-muted: #637083;
	--ctk-line: #e5e9ef;
	--ctk-soft: #f6f8fb;
	--ctk-primary: #00a6c8;
	--ctk-primary-dark: #007e98;
	color: var(--ctk-ink);
}

.ctk-services-page h1,
.ctk-services-page h2,
.ctk-services-page h3,
.ctk-contact-hero h1,
.ctk-contact-section-title h2,
.ctk-contact-map__info h2,
.ctk-shop-mega h3 {
	font-family: var(--ctk-heading-font);
	font-weight: 700;
	letter-spacing: 0;
}

.ctk-services-hero {
	padding: clamp(42px, 7vw, 88px) 0 clamp(28px, 4vw, 52px);
	border-bottom: 1px solid var(--ctk-line);
	background: linear-gradient(180deg, #f7fbfd 0%, #fff 100%);
}

.ctk-services-inner {
	width: min(1180px, calc(100% - 32px));
	margin: 0 auto;
}

.ctk-eyebrow {
	margin-bottom: 12px;
	color: var(--ctk-primary-dark);
	font-size: 13px;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
}

.ctk-services-hero h1,
.ctk-service-detail h1 {
	max-width: 900px;
	margin-bottom: 16px;
	font-size: clamp(34px, 5vw, 58px);
	line-height: 1.08;
}

.ctk-lead {
	max-width: 940px;
	margin-bottom: 0;
	color: var(--ctk-muted);
	font-size: clamp(17px, 2vw, 21px);
	line-height: 1.65;
}

.ctk-service-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 22px;
	padding: clamp(34px, 5vw, 58px) 0;
}

.ctk-service-column {
	padding: 24px;
	border: 1px solid var(--ctk-line);
	border-radius: 8px;
	background: #fff;
}

.ctk-service-column h2 {
	margin-bottom: 18px;
	font-size: 22px;
}

.ctk-service-list {
	display: grid;
	gap: 12px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.ctk-service-list a {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	color: var(--ctk-ink);
	font-weight: 700;
	text-decoration: none;
}

.ctk-service-list a:before {
	content: "";
	flex: 0 0 8px;
	width: 8px;
	height: 8px;
	margin-top: .58em;
	border-radius: 50%;
	background: var(--ctk-primary);
}

.ctk-service-list a:hover {
	color: var(--ctk-primary-dark);
}

.ctk-services-cta,
.ctk-service-cta {
	padding: clamp(28px, 5vw, 46px);
	border-radius: 8px;
	background: #172033;
	color: #fff;
}

.ctk-services-cta h2,
.ctk-service-cta h2 {
	margin-bottom: 12px;
	color: #fff;
	font-size: clamp(26px, 3vw, 38px);
}

.ctk-services-cta p,
.ctk-service-cta p {
	max-width: 820px;
	margin-bottom: 22px;
	color: rgba(255, 255, 255, .78);
	font-size: 17px;
	line-height: 1.65;
}

.ctk-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 46px;
	padding: 0 22px;
	border-radius: 4px;
	background: var(--ctk-primary);
	color: #fff !important;
	font-weight: 800;
	text-decoration: none !important;
}

.ctk-service-detail {
	padding: clamp(38px, 6vw, 72px) 0;
}

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

.ctk-content-main h2 {
	margin-top: 34px;
	margin-bottom: 14px;
	font-size: 27px;
}

.ctk-content-main p {
	color: var(--ctk-muted);
	font-size: 17px;
	line-height: 1.75;
}

.ctk-priority-list {
	display: grid;
	gap: 12px;
	margin: 16px 0 0;
	padding: 0;
	list-style: none;
}

.ctk-priority-list li {
	padding: 16px 18px;
	border-left: 4px solid var(--ctk-primary);
	background: var(--ctk-soft);
	color: var(--ctk-ink);
	font-weight: 650;
	line-height: 1.55;
}

.ctk-sidebox {
	position: sticky;
	top: 110px;
	padding: 22px;
	border: 1px solid var(--ctk-line);
	border-radius: 8px;
	background: #fff;
}

.ctk-sidebox h2 {
	margin-bottom: 14px;
	font-size: 20px;
}

.ctk-sidebox ul {
	margin: 0;
	padding-left: 18px;
	color: var(--ctk-muted);
	line-height: 1.7;
}

@media (max-width: 900px) {
	.ctk-service-grid,
	.ctk-content-grid {
		grid-template-columns: 1fr;
	}

	.ctk-sidebox {
		position: static;
	}
}

.ctk-tech-table-wrap {
	overflow-x: auto;
	margin: 18px 0 26px;
	border: 1px solid #e5e9ef;
	border-radius: 8px;
	background: #fff;
}

.ctk-tech-table {
	margin: 0;
	min-width: 640px;
	border-collapse: collapse;
	font-size: 14px;
	line-height: 1.45;
}

.ctk-tech-table th {
	padding: 13px 14px;
	border-bottom: 1px solid #dfe5ec;
	background: #f6f8fb;
	color: #172033;
	font-weight: 800;
	text-align: left;
	text-transform: none;
}

.ctk-tech-table td {
	padding: 12px 14px;
	border-bottom: 1px solid #edf1f5;
	color: #49566a;
	vertical-align: top;
}

.ctk-tech-table tr:last-child td {
	border-bottom: 0;
}

.ctk-shop-mega {
	display: grid;
	grid-template-columns: minmax(170px, .9fr) minmax(170px, .9fr) minmax(300px, 1.7fr) minmax(220px, 1fr);
	gap: 26px;
	min-width: min(1080px, calc(100vw - 48px));
	padding: 26px;
	color: #172033;
}

.ctk-shop-mega h3 {
	margin: 0 0 12px;
	color: #172033;
	font-size: 15px;
	font-weight: 800;
	line-height: 1.25;
}

.ctk-shop-mega ul {
	display: grid;
	gap: 8px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.ctk-shop-mega a {
	color: #4a5568;
	font-size: 14px;
	font-weight: 650;
	line-height: 1.35;
	text-decoration: none;
}

.ctk-shop-mega a:hover {
	color: #0a4b9f;
}

.ctk-shop-mega__families {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px 22px;
}

.ctk-shop-mega__families strong {
	display: block;
	margin-bottom: 6px;
	color: #172033;
	font-size: 14px;
	font-weight: 800;
}

.ctk-shop-mega__families a {
	display: block;
	margin-top: 5px;
}

.ctk-shop-mega__cta {
	padding: 18px;
	border: 1px solid #e5e9ef;
	border-radius: 8px;
	background: #f6f8fb;
}

.ctk-shop-mega__cta p {
	margin: 0 0 14px;
	color: #637083;
	font-size: 14px;
	line-height: 1.55;
}

.ctk-shop-mega__button {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 40px;
	margin-top: 8px;
	padding: 0 14px;
	border-radius: 4px;
	background: #0a4b9f;
	color: #fff !important;
	font-weight: 800 !important;
}

.ctk-shop-mega__button--ghost {
	border: 1px solid #b8c6d9;
	background: #fff;
	color: #0a4b9f !important;
}

.ctk-contact-hero {
	max-width: 850px;
}

.ctk-contact-hero__eyebrow,
.ctk-contact-section-title p {
	margin: 0 0 8px;
	color: #0a4b9f;
	font-size: 13px;
	font-weight: 800;
	letter-spacing: 0;
	text-transform: uppercase;
}

.ctk-contact-hero h1,
.ctk-contact-section-title h2 {
	margin: 0;
	color: #172033;
	font-size: 42px;
	font-weight: 800;
	line-height: 1.15;
}

.ctk-contact-hero p:not(.ctk-contact-hero__eyebrow),
.ctk-contact-section-title span {
	display: block;
	max-width: 680px;
	margin-top: 16px;
	color: #637083;
	font-size: 17px;
	line-height: 1.65;
}

.ctk-contact-cards {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 16px;
	margin-top: 32px;
}

.ctk-contact-card {
	display: block;
	min-height: 128px;
	padding: 22px;
	border: 1px solid #e5e9ef;
	border-radius: 8px;
	background: #fff;
	text-decoration: none;
	transition: border-color .2s ease, transform .2s ease, box-shadow .2s ease;
}

.ctk-contact-card:hover {
	border-color: #b8c6d9;
	box-shadow: 0 12px 30px rgba(23, 32, 51, .08);
	transform: translateY(-2px);
}

.ctk-contact-card span {
	display: block;
	margin-bottom: 10px;
	color: #7b8796;
	font-size: 13px;
	font-weight: 800;
	text-transform: uppercase;
}

.ctk-contact-card strong {
	color: #172033;
	font-size: 15px;
	font-weight: 750;
	line-height: 1.45;
}

.ctk-contact-section-title {
	margin-bottom: 24px;
}

.ctk-contact-section-title h2 {
	font-size: 30px;
}

.ctk-contact-form {
	padding: 26px;
	border: 1px solid #e5e9ef;
	border-radius: 8px;
	background: #fff;
}

.ctk-contact-form__row {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 16px;
}

.ctk-contact-form label {
	display: block;
	margin-bottom: 16px;
	color: #172033;
	font-size: 14px;
	font-weight: 750;
}

.ctk-contact-form input,
.ctk-contact-form select,
.ctk-contact-form textarea {
	margin-top: 7px;
	border-color: #dfe5ec;
	border-radius: 4px;
}

.ctk-contact-form textarea {
	min-height: 145px;
}

.ctk-contact-form .wpcf7-acceptance label {
	margin-bottom: 18px;
	color: #637083;
	font-weight: 600;
	line-height: 1.5;
}

.ctk-contact-map {
	overflow: hidden;
	height: 100%;
	min-height: 560px;
	border: 1px solid #e5e9ef;
	border-radius: 8px;
	background: #f6f8fb;
}

.ctk-contact-map iframe {
	display: block;
	width: 100%;
	height: 390px;
	border: 0;
}

.ctk-contact-map__info {
	padding: 24px;
}

.ctk-contact-map__info h2 {
	margin: 0 0 10px;
	color: #172033;
	font-size: 24px;
	font-weight: 800;
}

.ctk-contact-map__info p {
	margin: 0 0 18px;
	color: #637083;
	line-height: 1.6;
}

.ctk-contact-map__info a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 40px;
	padding: 0 16px;
	border-radius: 4px;
	background: #0a4b9f;
	color: #fff;
	font-weight: 800;
	text-decoration: none;
}

.page-id-4439 .elementor-element-a7704f0,
.page-id-4439 .elementor-element-9ebc9a2 {
	position: relative;
	left: 50%;
	width: 100vw;
	max-width: 100vw;
	margin-right: -50vw !important;
	margin-left: -50vw !important;
}

.page-id-4439 .elementor-element-a7704f0 {
	padding: 70px 15px !important;
	background: #f6f8fb;
}

.page-id-4439 .elementor-element-a7704f0 > .elementor-element {
	width: min(100%, 920px) !important;
	max-width: 920px !important;
	margin-right: auto !important;
	margin-left: auto !important;
}

.page-id-4439 .elementor-element-a7704f0 .elementor-element-ctkctform {
	width: min(100%, 760px) !important;
	max-width: 760px !important;
	margin-top: 26px !important;
}

.page-id-4439 .elementor-element-a7704f0 > .e-con-inner,
.page-id-4439 .elementor-element-9ebc9a2 > .e-con-inner {
	max-width: none !important;
	width: 100% !important;
}

@media (max-width: 1024px) {
	.ctk-contact-cards {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.elementor-element-ctkctmain {
		flex-direction: column !important;
	}

	.elementor-element-ctkctleft,
	.elementor-element-ctkctright {
		width: 100% !important;
	}
}

@media (max-width: 640px) {
	.ctk-contact-hero h1 {
		font-size: 32px;
	}

	.ctk-contact-cards,
	.ctk-contact-form__row {
		grid-template-columns: 1fr;
	}

	.ctk-contact-form {
		padding: 20px;
	}
}

@media (max-width: 1024px) {
	.ctk-shop-mega {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		min-width: min(720px, calc(100vw - 32px));
	}
}

@media (max-width: 640px) {
	.ctk-shop-mega {
		grid-template-columns: 1fr;
		min-width: 0;
		padding: 18px;
	}

	.ctk-shop-mega__families {
		grid-template-columns: 1fr;
	}
}

.page-id-35828 .elementor-element-e3f110a {
	flex-wrap: wrap !important;
	align-items: stretch;
}

.page-id-35830 .elementor-element-ctkengc {
	flex-wrap: wrap !important;
	align-items: stretch;
	justify-content: center;
}

.page-id-35832 .elementor-element-ctksvcc {
	flex-wrap: wrap !important;
	align-items: stretch;
	justify-content: center;
}

.page-id-35828 .elementor-element-e3f110a > .elementor-element {
	flex: 0 0 calc(25% - 8px) !important;
	width: calc(25% - 8px) !important;
	max-width: calc(25% - 8px) !important;
}

.page-id-35830 .elementor-element-ctkengc > .elementor-element {
	flex: 0 0 calc(33.333% - 7px) !important;
	width: calc(33.333% - 7px) !important;
	max-width: calc(33.333% - 7px) !important;
}

.page-id-35832 .elementor-element-ctksvcc > .elementor-element {
	flex: 0 0 calc(33.333% - 7px) !important;
	width: calc(33.333% - 7px) !important;
	max-width: calc(33.333% - 7px) !important;
}

.page-id-35828 .elementor-element-e3f110a .wd-info-box,
.page-id-35828 .elementor-element-e3f110a .info-box-wrapper,
.page-id-35830 .elementor-element-ctkengc .wd-info-box,
.page-id-35830 .elementor-element-ctkengc .info-box-wrapper,
.page-id-35832 .elementor-element-ctksvcc .wd-info-box,
.page-id-35832 .elementor-element-ctksvcc .info-box-wrapper {
	height: 100%;
}

@media (max-width: 1024px) {
	.page-id-35828 .elementor-element-e3f110a > .elementor-element {
		flex-basis: calc(50% - 6px) !important;
		width: calc(50% - 6px) !important;
		max-width: calc(50% - 6px) !important;
	}

	.page-id-35830 .elementor-element-ctkengc > .elementor-element {
		flex-basis: calc(50% - 6px) !important;
		width: calc(50% - 6px) !important;
		max-width: calc(50% - 6px) !important;
	}

	.page-id-35832 .elementor-element-ctksvcc > .elementor-element {
		flex-basis: calc(50% - 6px) !important;
		width: calc(50% - 6px) !important;
		max-width: calc(50% - 6px) !important;
	}
}

@media (max-width: 640px) {
	.page-id-35828 .elementor-element-e3f110a > .elementor-element {
		flex-basis: 100% !important;
		width: 100% !important;
		max-width: 100% !important;
	}

	.page-id-35830 .elementor-element-ctkengc > .elementor-element {
		flex-basis: 100% !important;
		width: 100% !important;
		max-width: 100% !important;
	}

	.page-id-35832 .elementor-element-ctksvcc > .elementor-element {
		flex-basis: 100% !important;
		width: 100% !important;
		max-width: 100% !important;
	}
}

.ctk-home-brand-slider .wd-gallery-item {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 138px;
	padding: 20px 24px;
	border: 1px solid rgba(23, 32, 51, .07);
	border-radius: 8px;
	background: rgba(255, 255, 255, .94);
	box-shadow: 0 12px 28px rgba(23, 32, 51, .04);
}

.ctk-home-brand-slider .wd-gallery-item img {
	display: block;
	width: auto;
	max-width: 100%;
	max-height: 86px;
	object-fit: contain;
}

@media (max-width: 640px) {
	.ctk-home-brand-slider .wd-gallery-item {
		min-height: 118px;
		padding: 16px;
	}
}
