@media (max-width: 1200px) {
	:root {
		--dg-container: 1080px;
	}
}

@media (max-width: 1024px) {
	:root {
		--dg-section-padding: 80px;
	}

	.dg-container,
	.dg-container-wide {
		width: min(100% - 32px, var(--dg-container));
	}
}

@media (max-width: 767px) {
	:root {
		--dg-section-padding: var(--dg-section-padding-mobile);
	}

	.dg-container,
	.dg-container-wide {
		width: min(100% - 28px, var(--dg-container));
	}

	.dg-btn {
		width: 100%;
		min-height: 50px;
	}
}

@media (max-width: 374px) {
	.dg-container,
	.dg-container-wide {
		width: min(100% - 24px, var(--dg-container));
	}

	.dg-section {
		padding-top: 56px;
		padding-bottom: 56px;
	}
}

/* ================================
   DigitalGrow Footer Responsive
================================ */

@media (max-width: 1024px) {
	.dg-site-footer {
		padding: 70px 18px 30px;
	}

	.dg-footer-main {
		grid-template-columns: 1fr;
		gap: 44px;
		padding: 28px;
	}

	.dg-footer-brand {
		max-width: 520px;
	}

	.dg-footer-columns {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 767px) {
	.dg-site-footer {
		padding: 58px 14px 26px;
	}

	.dg-footer-main {
		padding: 24px;
	}

	.dg-footer-logo img,
	.dg-footer-logo-image,
	.dg-footer-logo .custom-logo {
		max-width: 184px;
		max-height: 56px;
	}

	.dg-footer-description {
		margin-top: 22px;
		font-size: 14.5px;
		line-height: 1.6;
	}

	.dg-footer-socials {
		margin-top: 24px;
	}

	.dg-footer-columns {
		grid-template-columns: 1fr;
		gap: 34px;
	}

	.dg-footer-title {
		margin-bottom: 20px;
	}

	.dg-footer-menu {
		gap: 13px;
	}

	.dg-footer-bottom {
		align-items: flex-start;
		flex-direction: column;
		gap: 16px;
	}

	.dg-footer-legal-menu {
		justify-content: flex-start;
	}
}

@media (max-width: 480px) {
	.dg-footer-main {
		padding: 22px 18px;
	}

	.dg-footer-social {
		width: 40px;
		height: 40px;
	}
}

/* ================================
   DigitalGrow Header Responsive - stable version
================================ */

@media (max-width: 1024px) {
	.dg-site-header {
		width: 100%;
		padding: 14px 12px 0;
		background: transparent !important;
	}

	.dg-header-shell {
		width: 100%;
		max-width: 100%;
	}

	.dg-header-inner {
		width: 100%;
		max-width: 100%;
		min-height: 66px;
		padding: 9px 11px 9px 18px;
		background:
			radial-gradient(circle at 14% 0%, rgba(255, 255, 255, 0.095), transparent 32%),
			radial-gradient(circle at 92% 100%, rgba(17, 228, 79, 0.075), transparent 30%),
			linear-gradient(135deg, rgba(255, 255, 255, 0.10), rgba(255, 255, 255, 0.038)),
			rgba(18, 18, 18, 0.66);
		border-color: rgba(255, 255, 255, 0.15);
		backdrop-filter: blur(16px) saturate(135%);
		-webkit-backdrop-filter: blur(16px) saturate(135%);
		box-shadow:
			inset 0 1px 0 rgba(255, 255, 255, 0.16),
			inset 0 -1px 0 rgba(255, 255, 255, 0.045),
			0 14px 34px rgba(0, 0, 0, 0.30),
			0 0 28px rgba(17, 228, 79, 0.035);
	}

	.dg-header-logo {
		min-width: auto;
	}

	.dg-header-logo img {
		max-height: 38px;
	}

	.dg-header-nav {
		display: none;
	}

	.dg-header-cta {
		display: none;
	}

	.dg-menu-toggle {
		display: inline-flex;
	}

	.dg-mobile-nav {
		position: relative;
		display: block;
		width: 100%;
		max-width: 100%;
		max-height: 0;
		overflow: hidden;
		margin-top: 10px;
		background:
			radial-gradient(circle at 100% 0%, rgba(17, 228, 79, 0.105), transparent 34%),
			linear-gradient(135deg, rgba(255, 255, 255, 0.105), rgba(255, 255, 255, 0.04)),
			rgba(18, 18, 18, 0.74);
		border: 1px solid rgba(255, 255, 255, 0.15);
		border-radius: 24px;
		backdrop-filter: blur(16px) saturate(135%);
		-webkit-backdrop-filter: blur(16px) saturate(135%);
		box-shadow:
			inset 0 1px 0 rgba(255, 255, 255, 0.14),
			0 16px 38px rgba(0, 0, 0, 0.32),
			0 0 28px rgba(17, 228, 79, 0.045);
		opacity: 0;
		transform: translateY(-6px);
		transition:
			max-height 0.28s ease,
			opacity 0.22s ease,
			transform 0.22s ease;
	}

	.dg-mobile-nav::before {
		content: "";
		position: absolute;
		inset: 1px;
		border-radius: inherit;
		background: linear-gradient(120deg, rgba(255, 255, 255, 0.12), transparent 38%);
		opacity: 0.58;
		pointer-events: none;
	}

	.dg-mobile-menu {
		position: relative;
		z-index: 1;
	}

	body.dg-mobile-menu-open {
		overflow: hidden;
	}

	body.dg-mobile-menu-open .dg-mobile-nav {
		max-height: calc(100dvh - 104px);
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
		opacity: 1;
		transform: translateY(0);
	}

	.dg-mobile-menu {
		padding: 12px;
	}

	.dg-mobile-menu > li > a {
		display: flex;
		align-items: center;
		justify-content: flex-start;
		gap: 10px;
		min-height: 46px;
		padding: 0 14px;
		color: rgba(255, 255, 255, 0.86);
		font-size: 15px;
		font-weight: 500;
		letter-spacing: -0.01em;
		border-radius: 14px;
		transition:
			color 0.2s ease,
			background-color 0.2s ease;
	}

	.dg-mobile-menu .dg-menu-title {
		min-width: 0;
	}

	.dg-mobile-menu .dg-menu-badge {
		min-width: 30px;
		height: 28px;
		margin-left: 0;
	}

	.dg-mobile-menu .dg-menu-icon {
		flex: 0 0 30px;
		width: 30px;
		height: 30px;
		border-radius: 10px;
	}

	.dg-mobile-menu > li.current-menu-item > a,
	.dg-mobile-menu > li.current-menu-ancestor > a,
	.dg-mobile-menu > li > a:hover {
		color: #ffffff;
		background: rgba(255, 255, 255, 0.09);
	}

	/* Stable mobile submenu: closed by default */
	.dg-mobile-menu .menu-item-has-children > .sub-menu {
		display: block;
		height: 0;
		overflow: hidden;
		margin: 0;
		padding: 0 10px;
		background:
			linear-gradient(180deg, rgba(255, 255, 255, 0.065), rgba(255, 255, 255, 0.025)),
			rgba(255, 255, 255, 0.025);
		border: 1px solid rgba(255, 255, 255, 0);
		border-radius: 18px;
		opacity: 0;
		transform: translate3d(0, -4px, 0);
		transition:
			height 0.24s ease,
			margin 0.24s ease,
			padding 0.24s ease,
			opacity 0.18s ease,
			transform 0.18s ease,
			border-color 0.18s ease;
	}

	.dg-mobile-menu .menu-item-has-children.dg-submenu-open > .sub-menu {
		opacity: 1;
		transform: translate3d(0, 0, 0);
	}

	.dg-mobile-menu .sub-menu li + li {
		margin-top: 8px;
	}

	.dg-mobile-menu .sub-menu a {
		display: flex;
		align-items: center;
		gap: 13px;
		padding: 12px;
		color: #ffffff;
		border-radius: 14px;
		transition: background-color 0.2s ease;
	}

	.dg-mobile-menu .sub-menu a:hover {
		background: rgba(255, 255, 255, 0.065);
	}

	.dg-mobile-menu .dg-submenu-icon {
		flex: 0 0 40px;
		width: 40px;
		height: 40px;
		border-radius: 12px;
	}

	.dg-mobile-menu .dg-submenu-title {
		font-size: 14.5px;
		font-weight: 600;
	}

	.dg-mobile-menu .dg-submenu-description {
		font-size: 13px;
		line-height: 1.3;
	}

	.dg-mobile-menu .menu-item-has-children > a {
		cursor: pointer;
	}

	.dg-mobile-menu .menu-item-has-children > a .dg-dropdown-arrow {
		margin-left: auto;
		transition: transform 0.2s ease;
	}

	.dg-mobile-menu .menu-item-has-children.dg-submenu-open > a .dg-dropdown-arrow {
		transform: rotate(225deg) translateY(-2px);
	}

	.dg-mobile-cta-wrap {
		position: relative;
		z-index: 1;
		display: block;
		padding: 0 12px 12px;
	}

	.dg-mobile-cta {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: 100%;
		min-height: 48px;
		padding: 0 18px;
		color: #0b0b0b;
		background: var(--dg-accent);
		border: 1px solid var(--dg-accent);
		border-radius: 999px;
		font-family: var(--dg-font-body);
		font-size: 15px;
		font-weight: 600;
		line-height: 1;
		box-shadow: 0 14px 30px rgba(17, 228, 79, 0.16);
	}

	.dg-mobile-cta:hover,
	.dg-mobile-cta:focus-visible {
		color: #0b0b0b;
		background: var(--dg-accent-hover);
		border-color: var(--dg-accent-hover);
	}
}

@media (max-width: 782px) {
	body.admin-bar .dg-site-header {
		top: 46px;
	}
}

@media (max-width: 480px) {
	.dg-site-header {
		padding-left: 10px;
		padding-right: 10px;
	}

	.dg-header-inner {
		border-radius: 22px;
	}

	.dg-logo-text {
		font-size: 18px;
	}

	.dg-header-logo img {
		max-height: 34px;
	}

	.dg-mobile-nav {
		border-radius: 20px;
	}

	.dg-mobile-menu {
		padding: 10px;
	}
}

@media (max-width: 390px) {
	body.dg-mobile-menu-open .dg-mobile-nav {
		max-height: calc(100dvh - 108px);
	}

	.dg-mobile-menu > li > a {
		min-height: 44px;
		font-size: 14.5px;
	}

	.dg-mobile-menu .sub-menu a {
		padding: 10px;
	}

	.dg-mobile-menu .dg-submenu-icon {
		flex: 0 0 38px;
		width: 38px;
		height: 38px;
	}
}
