/* ----------------------------------------------------------------
	Keefe Werx Custom CSS
	Clean Version
----------------------------------------------------------------- */

:root {
	--cnvs-body-font: "Inter", sans-serif;
	--cnvs-primary-font: "Inter", sans-serif;
	--cnvs-secondary-font: "Inter", sans-serif;

	--kw-accent: #FF00FF;
	--kw-footer-accent: #FFFF00;
	--kw-hover: #00FFFF;
	--kw-text: #4a4a4a;
	--kw-body: #5d5d5d;
	--kw-bg: #f3f2ef;
	--kw-line: #dedbd6;
}


/* Global */

body,
p,
span,
li,
label,
input,
textarea {
	font-family: "Inter", sans-serif;
	color: var(--kw-body);
}

#wrapper,
#content,
.content-wrap,
.page-section {
	background-color: var(--kw-bg);
}

#header,
#header-wrap {
	background-color: #fff !important;
}


/* Header */

#header {
	border-bottom: 0 !important;
}

#header-wrap {
	background-color: #fff !important;
	padding-top: 24px !important;
	padding-bottom: 24px !important;
}

.header-row {
	display: flex;
	align-items: center !important;
	flex-wrap: wrap;
	min-height: auto !important;
}

#logo {
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	margin-right: 34px;
}

.logo-sticky.valign-center {
	display: flex !important;
	align-items: flex-end !important;
	flex: 0 0 auto;
	margin-right: 28px !important;
	margin-bottom: 0 !important;
	line-height: 1 !important;
}


/* Header Type Logo */

.header-logo-type {
	display: inline-flex;
	align-items: flex-end;
	font-family: "Inter", sans-serif;
	font-size: 2.95rem;
	font-weight: 500;
	line-height: 0.96;
	letter-spacing: -0.05em;
	text-transform: lowercase;
	color: #111;
	text-decoration: none !important;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.header-logo-type:hover {
	color: #111;
}

/* Perfect alignment with main content */
#page-title .container {
    max-width: 930px;
    margin: 0 auto;
    padding-left: 20px;
    padding-right: 20px;
}

/* Perfect alignment with main content */
#page-title .container {
    max-width: 930px;
    margin: 0 auto;
    padding-left: 20px;
    padding-right: 20px;
}

/* Top Navigation */

.primary-menu {
	display: flex;
	flex: 0 0 auto;
	flex-grow: 0;
	align-items: flex-end;
	margin-top: 6px !important;
	padding-top: 0 !important;
}

.primary-menu + .primary-menu {
	border-top: 0 !important;
}

.menu-container:not(.mobile-primary-menu) {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	width: auto;
}

.menu-container > .menu-item:not(:first-child) {
	margin-left: 8px;
}

.primary-menu .menu-container {
    gap: 20px;
}

.menu-item:not(:first-child) {
	border-top: 0 !important;
}

.menu-link {
	display: flex !important;
	align-items: flex-end !important;
	padding: 8px 8px 0 8px !important;
	line-height: 1 !important;
}

.menu-link div {
	display: block;
	font-family: "Inter", sans-serif;
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: #7a7a7a;
	line-height: 1;
	padding-bottom: 0;
}

/* Square Pink Periods */

.kw-dot {
	display: inline-block;
	width: 10px;
	height: 10px;
	background-color: #FF00FF;
	margin-left: 3px;
	border-radius: 0 !important;
	vertical-align: -0.15em;
	box-shadow: none !important;
	background-image: none !important;
}

.page-section h2 .kw-dot,
.hero-headline h1 .kw-dot,
.hero-headline h2 .kw-dot {
	vertical-align: -0.15em;
}


/* Hero */

.hero-headline {
	margin-top: 40px;
}

.hero-headline h1,
.hero-headline h2 {
	font-family: "Inter", sans-serif;
	font-size: 3.4rem;
	line-height: 1.08;
	letter-spacing: 0em;
	font-weight: 700;
	color: var(--kw-text);
	margin-bottom: 0;
}

.hero-headline > span {
	display: block;
	max-width: 780px;
	font-size: 1.5rem;
	line-height: 1.65;
	font-weight: 500;
	color: var(--kw-body);
	margin-top: 1.5rem;
}

.hero-subline {
	max-width: 780px;
	font-size: 1.45rem;
	line-height: 1.7;
	font-weight: 600;
	color: var(--kw-text);
	margin: 2rem 0 1.5rem;
}

.kw-local-note {
	font-size: 1.05rem;
	line-height: 1.7;
	color: #666;
	margin-top: 1.5rem;
}


/* Section Headings */

.page-section h2 {
	font-family: "Inter", sans-serif;
	font-size: 2.6rem;
	line-height: 1.1;
	letter-spacing: 0em;
	font-weight: 700;
	color: var(--kw-text);
	margin-bottom: 2rem !important;
}


/* Services */

.kw-group-title {
	font-size: 1.4rem;
	line-height: 1.3;
	font-weight: 700;
	color: var(--kw-text);
	margin: 3.5rem 0 0.5rem;
}

.kw-group-intro {
	max-width: 860px;
	font-size: 1.15rem;
	line-height: 1.7;
	color: #666;
	margin-bottom: 2.5rem;
}

#section-services .row {
	margin-bottom: 2rem;
}


/* Service Boxes */

.feature-box.fbox-plain {
	padding: 22px 0;
}

.feature-box.fbox-plain .fbox-icon {
	width: 58px;
	padding-top: 4px;
}

.feature-box.fbox-plain .fbox-icon i {
	font-size: 2rem;
	color: var(--kw-text);
}

.feature-box.fbox-plain .fbox-content {
	padding-left: 14px;
}

.feature-box.fbox-plain .fbox-content h3 {
	font-size: 1.15rem;
	font-weight: 700;
	text-transform: uppercase;
	color: var(--kw-text);
	margin-bottom: 6px;
}

.feature-box.fbox-plain .fbox-content p {
	font-size: 1.08rem;
	line-height: 1.7;
	color: var(--kw-body);
	max-width: 32rem;
}


/* About */

.about-copy p {
	max-width: 900px;
	font-size: 1.35rem;
	line-height: 1.8;
	color: var(--kw-body);
	margin-bottom: 1.75rem;
}


/* Buttons */

.button-pill {
	display: inline-block;
	padding: 16px 30px;
	font-size: 1rem;
	font-weight: 700;
	border-radius: 999px;
	background-color: #111;
	color: #fff !important;
	border: 2px solid #111;
	text-decoration: none !important;
	transition: all 0.2s ease;
}

.button-pill:hover {
	background-color: var(--kw-hover);
	border-color: var(--kw-hover);
	color: #000 !important;
}

.button-pill-lg {
	padding: 18px 34px;
	font-size: 1.1rem;
}

.button-pill-light {
	background-color: transparent;
	color: #111 !important;
	border: 2px solid #111;
}

.button-pill-light:hover {
	background-color: var(--kw-hover);
	border-color: var(--kw-hover);
	color: #000 !important;
}


/* Divider */

.line.my-6,
.line.topmargin-xl.bottommargin-xl {
	margin-top: 5rem !important;
	margin-bottom: 5rem !important;
	border-top-color: var(--kw-line) !important;
}


/* Footer */

#copyrights {
	background-color: #111 !important;
}

.footer-logo-type {
	display: inline-flex;
	align-items: flex-end;
	font-family: 'fractul-variable', helvetica, sans-serif;
	font-size: 2.15rem;
	font-weight: 500;
	line-height: 0.96;
	letter-spacing: 0.02em;
	text-transform: lowercase;
	text-decoration: none !important;
    padding-bottom: 20px;
}

.footer-logo-type:hover {
	color: #fff !important;
}

.footer-logo-type .kw-dot {
	display: inline-block;
	width: 9px;
	height: 9px;
	background-color: var(--kw-footer-accent);
	margin-left: 7px;
	margin-bottom: 5px;
	border-radius: 0 !important;
}

#copyrights,
#copyrights p,
#copyrights a,
#copyrights span,
#copyrights div {
	color: #fff !important;
}

#copyrights a:hover {
	color: #fff !important;
}


/* Responsive */

@media (min-width: 992px) {
	.menu-container > .menu-item > .menu-link {
		padding-top: 8px !important;
		padding-bottom: 0 !important;
	}
}

	.header-logo-type {
		font-size: 2.2rem;
	}

	.footer-logo-type {
		font-size: 1.85rem;
	}

    .header-logo-svg img {
        height: clamp(32px, 5vw, 48px);
        width: auto;
        max-width: 100%;
        display: block;
    }

    @media (max-width: 575px) {
        .header-logo-svg img {
            height: 28px;
        }
    }
@media (max-width: 394px) {
	.header-logo-svg img {
		height: 19px;
	}
}

	.kw-dot,
	.page-section h2 .kw-dot,
	.hero-headline h1 .kw-dot,
	.hero-headline h2 .kw-dot,
	.header-logo-type .kw-dot,
	.footer-logo-type .kw-dot {
		width: 8px;
		height: 8px;
		margin-left: 6px;
		margin-bottom: 4px;
	}

	.primary-menu {
		margin-top: 8px !important;
	}

	.hero-headline h1,
	.hero-headline h2 {
		font-size: 2.4rem;
	}

	.hero-headline > span {
		font-size: 1.2rem;
	}

	.hero-subline,
	.about-copy p {
		font-size: 1.05rem;
	}

	.page-section h2 {
		font-size: 2rem;
	}

	.feature-box.fbox-plain {
		padding: 16px 0;
	}

	.feature-box.fbox-plain .fbox-icon {
		width: 48px;
	}

	.feature-box.fbox-plain .fbox-content {
		padding-left: 10px;
	}
}
