/**
 * Verdox child — global responsive foundation (theme + Elementor chrome).
 * NJCMS shortcode layouts: plugin assets/css/njcms-responsive.css
 */

/* --- A. Global foundation --- */
html {
	box-sizing: border-box;
	scroll-padding-top: var(--nj-header-scroll-padding, 5.5rem);
}

*,
*::before,
*::after {
	box-sizing: inherit;
}

body {
	overflow-x: clip;
}

#main,
.site-main,
#content,
.site-content,
.elementor-section-wrap {
	max-width: 100%;
}

img,
video,
iframe,
embed,
object,
svg {
	max-width: 100%;
	height: auto;
}

.elementor-widget-text-editor,
.elementor-widget-html,
.elementor-widget-shortcode,
.elementor-widget-image,
.elementor-widget-video {
	max-width: 100%;
}

.elementor-widget-text-editor img,
.elementor-widget-text-editor video,
.elementor-widget-html img,
.elementor-widget-html video {
	max-width: 100%;
	height: auto;
}

.elementor-widget-html iframe,
.elementor-widget-google_maps iframe,
.njcms-contact-page__map iframe {
	max-width: 100%;
}

/* Long legal text, emails, URLs */
#main p,
#main li,
#main td,
#main th,
.elementor-widget-text-editor p,
.elementor-widget-text-editor li,
.njcms-court-prose,
.njcms-court-list__body,
.njcms-design-section {
	overflow-wrap: break-word;
	word-break: break-word;
}

#main a[href^="mailto:"],
#main a[href^="tel:"],
.njcms-contact-page__card-detail,
.njcms-staff__list-email,
.njcms-staff__list-phone {
	overflow-wrap: anywhere;
}

/* Elementor full-width sections must not force page scroll */
.elementor-section.elementor-section-boxed > .elementor-container {
	max-width: min(var(--container-max-width, 1140px), 100%);
}

.elementor-section .elementor-column-gap-default > .elementor-row,
.elementor-section .elementor-column-gap-extended > .elementor-row {
	max-width: 100%;
}

/* --- G. Typography (mobile) --- */
@media (max-width: 767px) {
	#main h1,
	.site-main h1,
	.elementor-widget-heading h1.elementor-heading-title {
		font-size: clamp(1.65rem, 6.5vw, 2.35rem);
		line-height: 1.2;
	}

	#main h2,
	.site-main h2,
	.elementor-widget-heading h2.elementor-heading-title {
		font-size: clamp(1.35rem, 5vw, 1.85rem);
		line-height: 1.25;
	}

	#main h3,
	.site-main h3,
	.elementor-widget-heading h3.elementor-heading-title {
		font-size: clamp(1.15rem, 4.2vw, 1.45rem);
		line-height: 1.3;
	}

	#main .entry-content,
	.elementor-widget-text-editor {
		font-size: clamp(0.95rem, 2.8vw, 1.05rem);
	}
}

@media (min-width: 1280px) {
	#main .entry-content > p,
	.elementor-widget-text-editor > .elementor-widget-container > p {
		max-width: 72ch;
	}
}

/* --- B. Header & navigation --- */
.wgl-logotype-container img,
.wgl-logotype-container svg,
.wgl-theme-header .logo-name {
	max-width: min(200px, 46vw);
	height: auto;
}

.wgl-theme-header.sticky_active .wgl-logotype-container img,
.wgl-theme-header.sticky_active .wgl-logotype-container svg,
.wgl-sticky-header .wgl-logotype-container img,
.wgl-sticky-header .wgl-logotype-container svg {
	max-width: min(168px, 40vw);
}

/*
 * Desktop/tablet nav: keep primary menu on one line between mobile breakpoint and ~1350px.
 * Replaces earlier flex-wrap rule that caused a second menu row on narrower desktops.
 */
@media (min-width: 1200px) and (max-width: 1350px) {
	.wgl-theme-header .header_row,
	.wgl-theme-header .header__container,
	.elementor-location-header .elementor-container {
		flex-wrap: nowrap;
		align-items: center;
	}

	.wgl-theme-header .primary-nav > ul,
	.elementor-widget-wgl-menu .primary-nav > ul {
		flex-wrap: nowrap;
		justify-content: flex-end;
		gap: 0;
	}

	.wgl-theme-header .primary-nav > ul > li > a,
	.elementor-widget-wgl-menu .primary-nav > ul > li > a {
		padding-inline: 0.42rem;
		font-size: 0.8125rem;
		letter-spacing: 0;
		white-space: nowrap;
	}

	.wgl-theme-header .wgl-logotype-container img,
	.wgl-theme-header .wgl-logotype-container svg {
		max-width: min(150px, 28vw);
	}

	.wgl-theme-header .header_side-area,
	.wgl-theme-header .header__side-area,
	.elementor-location-header .elementor-widget-social-icons {
		flex-shrink: 0;
	}

	.elementor-location-header .elementor-widget-social-icons .elementor-grid {
		gap: 0.35rem;
	}

	.elementor-location-header .elementor-widget-social-icons .elementor-icon {
		font-size: 0.95rem;
	}
}

@media (min-width: 1200px) and (max-width: 1279px) {
	.wgl-theme-header .primary-nav > ul > li > a,
	.elementor-widget-wgl-menu .primary-nav > ul > li > a {
		padding-inline: 0.35rem;
		font-size: 0.78rem;
	}

	.elementor-location-header .elementor-widget-social-icons .elementor-grid {
		gap: 0.25rem;
	}
}

/* Mobile drawer / overlay menu */
@media (max-width: 1199px) {
	.mobile_nav_wrapper .primary-nav > ul > li > a,
	.wgl-menu-outer_content .primary-nav > ul > li > a {
		display: flex;
		align-items: center;
		min-height: 2.75rem;
		padding-block: 0.65rem;
	}

	.mobile_nav_wrapper .primary-nav .sub-menu a,
	.wgl-menu-outer_content .primary-nav .sub-menu a {
		min-height: 2.75rem;
		padding-block: 0.55rem;
	}

	.mobile_nav_wrapper button.button_switcher,
	.mobile_nav_wrapper button.button_switcher_vertical,
	.wgl-menu-outer_content button.button_switcher,
	.wgl-menu-outer_content button.button_switcher_vertical {
		min-width: 2.75rem;
		min-height: 2.75rem;
	}

	.hamburger-box,
	.mobile-hamburger-toggle,
	.wgl-mobile-header .hamburger {
		min-width: 2.75rem;
		min-height: 2.75rem;
	}
}

/* Search overlay / field */
.header_search.search_alt .header_search-field,
.header_search .header_search-wrap,
.header_search .header_search-form,
.header_search input[type="search"],
.header_search input[type="text"] {
	max-width: 100%;
	box-sizing: border-box;
}

@media (max-width: 767px) {
	.header_search.search_alt .header_search-field,
	.header_search .header_search-wrap {
		width: min(100vw - 2rem, 28rem);
		margin-inline: auto;
		padding-inline: 1rem;
	}

	.header_search input[type="search"],
	.header_search input[type="text"] {
		width: 100%;
		min-height: 2.75rem;
		font-size: 1rem;
	}
}

/* Sticky header: avoid covering focused skip link / in-page targets */
.wgl-theme-header.sticky_active,
.wgl-sticky-header {
	z-index: 999;
}

body:has(.njcms-skip-link:focus) .wgl-theme-header.sticky_active,
body:has(.njcms-skip-link:focus) .wgl-sticky-header {
	z-index: 998;
}

/* Homepage hero: center on small screens (Elementor) */
@media (max-width: 767px) {
	body.home #main .elementor-section:first-of-type .elementor-heading-title,
	body.home #primary .elementor-section:first-of-type .elementor-heading-title,
	body.home .site-main .elementor-section:first-of-type .elementor-heading-title,
	body.home #main .elementor-section:first-of-type .elementor-widget-text-editor,
	body.home #primary .elementor-section:first-of-type .elementor-widget-text-editor,
	body.home .site-main .elementor-section:first-of-type .elementor-widget-text-editor {
		text-align: center;
	}

	body.home #main .elementor-section:first-of-type .elementor-widget-button .elementor-widget-container,
	body.home #primary .elementor-section:first-of-type .elementor-widget-button .elementor-widget-container,
	body.home .site-main .elementor-section:first-of-type .elementor-widget-button .elementor-widget-container {
		display: flex;
		justify-content: center;
	}
}

/* Homepage WGL infobox CTAs: allow wrap on narrow screens */
@media (max-width: 480px) {
	.elementor-175 .elementor-widget-wgl-infobox .wgl-widget__button,
	.elementor-175 .elementor-widget-wgl-infobox .wgl-infobox_button,
	.elementor-175 .elementor-widget-wgl-infobox .wgl-button {
		min-width: 0 !important;
		max-width: 100%;
		white-space: normal !important;
	}

	.elementor-175 .elementor-widget-wgl-infobox .wgl-widget__button .button__content,
	.elementor-175 .elementor-widget-wgl-infobox .wgl-button .button__content {
		white-space: normal !important;
	}
}

/*
 * Verdox grid: .row uses margin-left/right -15px (main.css) while columns add 15px padding.
 * On very narrow viewports the row margin box can exceed 100% of the viewport (~350px at 320px).
 */
@media (max-width: 480px) {
	#main {
		overflow-x: clip;
	}

	#main > .wgl-container,
	#main .wgl-container {
		width: 100%;
		max-width: 100%;
		box-sizing: border-box;
		overflow-x: clip;
	}

	/* Verdox .row { margin: 0 -15px } — !important beats equal-specificity theme rules after deploy */
	#main .row,
	#main .row.sidebar_none {
		margin-left: 0 !important;
		margin-right: 0 !important;
		width: 100%;
		max-width: 100%;
		box-sizing: border-box;
	}

	#main .row [class*="wgl_col-"],
	#main #main-content {
		width: 100%;
		max-width: 100%;
		box-sizing: border-box;
	}

	#main #main-content {
		overflow-x: clip;
		float: none;
	}
}

/* --- H. Footer --- */
@media (max-width: 767px) {
	.site-footer .elementor-inner-section > .elementor-container,
	.footer.elementor-location-footer .elementor-inner-section > .elementor-container {
		flex-wrap: wrap;
	}

	.site-footer .elementor-column,
	.footer.elementor-location-footer .elementor-column,
	.elementor-638 .elementor-column {
		flex: 0 0 100% !important;
		max-width: 100% !important;
		width: 100% !important;
	}

	.site-footer .elementor-widget-text-editor,
	.site-footer .elementor-icon-list-item,
	.footer .quick-links {
		overflow-wrap: anywhere;
	}
}

/* Page title band under header */
@media (max-width: 767px) {
	.wgl-page-title,
	.page-header,
	.page_title {
		padding-inline: clamp(0.75rem, 3vw, 1.25rem);
	}
}
