/* ==========================================================================
   Agency Theme — Corporate & Business
   ========================================================================== */

:root {
	--agency-primary: #1a2744;
	--agency-accent: #c41e3a;
	--agency-highlight: #f5b800;
	--agency-dark: #0d1526;
	--agency-text: #333333;
	--agency-text-light: #666666;
	--agency-white: #ffffff;
	--agency-gray-100: #f5f6f8;
	--agency-gray-200: #e8eaed;
	--agency-font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	--agency-font-heading: 'Roboto Condensed', var(--agency-font);
	--agency-content-box: 1300px;
	--agency-container: 1300px;
	--agency-elementor-box: 100%;
	--agency-radius: 4px;
	--agency-shadow: 0 4px 24px rgba(0, 0, 0, 0.08);
	--agency-transition: 0.3s ease;
}

*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
	margin: 0;
	font-family: var(--agency-font);
	font-size: 16px;
	line-height: 1.7;
	color: var(--agency-text);
	background: var(--agency-white);
	-webkit-font-smoothing: antialiased;
}

img { max-width: 100%; height: auto; display: block; }

a { color: var(--agency-accent); text-decoration: none; transition: color var(--agency-transition); }
a:hover { color: var(--agency-primary); }

h1, h2, h3, h4, h5, h6 {
	font-family: var(--agency-font-heading);
	font-weight: 700;
	line-height: 1.2;
	color: var(--agency-primary);
	margin: 0 0 0.5em;
	text-transform: uppercase;
	letter-spacing: 0.02em;
}

.screen-reader-text {
	clip: rect(1px, 1px, 1px, 1px);
	position: absolute !important;
	height: 1px; width: 1px;
	overflow: hidden;
}

/* Container — header, footer, pages (shell bg stays full width) */
.agency-container {
	width: 100%;
	max-width: var(--agency-content-box, 1300px);
	margin: 0 auto;
	padding: 0 24px;
	box-sizing: border-box;
}

.site-header,
.site-footer,
.agency-top-bar {
	width: 100%;
}

.agency-container--narrow { max-width: 800px; }

/* Full width pages & Elementor */
.site-main--fullwidth,
.site-main--front {
	padding: 0;
	width: 100%;
}

.site-main--fullwidth .entry-content--elementor,
.site-main--front .entry-content--elementor,
.site-main--front .elementor {
	max-width: 100%;
	width: 100%;
}

.site-main--fullwidth .elementor-section.elementor-section-boxed > .elementor-container {
	max-width: var(--agency-elementor-box, var(--agency-content-box, 1300px));
}

body.agency-layout-full .site-main--fullwidth .elementor-section.elementor-section-boxed > .elementor-container,
body.agency-layout-full .elementor-section.elementor-section-boxed > .elementor-container {
	max-width: var(--agency-elementor-box, 100%);
	padding-left: 24px;
	padding-right: 24px;
}

/* Buttons */
.agency-btn {
	display: inline-block;
	padding: 14px 32px;
	font-family: var(--agency-font-heading);
	font-size: 14px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	border: 2px solid transparent;
	border-radius: var(--agency-radius);
	cursor: pointer;
	transition: all var(--agency-transition);
}

.agency-btn--primary {
	background: var(--agency-accent);
	color: var(--agency-white);
	border-color: var(--agency-accent);
}

.agency-btn--primary:hover {
	background: transparent;
	color: var(--agency-accent);
}

.agency-btn--outline {
	background: transparent;
	color: var(--agency-white);
	border-color: var(--agency-white);
}

.agency-btn--outline:hover {
	background: var(--agency-white);
	color: var(--agency-accent);
}

.agency-link {
	font-weight: 600;
	text-transform: uppercase;
	font-size: 13px;
	letter-spacing: 0.05em;
}

/* Top Bar */
.agency-top-bar {
	background: var(--agency-topbar-bg, var(--agency-dark));
	color: var(--agency-topbar-text, rgba(255, 255, 255, 0.92));
	font-size: var(--agency-topbar-font-size, 13px);
	line-height: var(--agency-topbar-line-height, 1.35);
	padding: var(--agency-topbar-padding-y, 10px) 0;
}

.agency-top-bar__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px 20px;
	flex-wrap: wrap;
	width: 100%;
	max-width: var(--agency-content-box, 1300px);
	margin: 0 auto;
	padding-left: var(--agency-topbar-padding-x, 24px);
	padding-right: var(--agency-topbar-padding-x, 24px);
	box-sizing: border-box;
}

.agency-top-bar__left,
.agency-top-bar__right {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	min-width: 0;
}

.agency-top-bar__left {
	flex: 1 1 280px;
}

.agency-top-bar__right {
	flex: 0 1 auto;
	justify-content: flex-end;
	align-self: center;
}

.agency-top-bar__contact {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--agency-topbar-row-gap, 6px) var(--agency-topbar-items-gap, 18px);
	min-width: 0;
}

.agency-top-bar__item {
	display: inline-flex;
	align-items: center;
	gap: var(--agency-topbar-icon-gap, 8px);
	color: var(--agency-topbar-text, rgba(255, 255, 255, 0.92));
	text-decoration: none;
	line-height: inherit;
	max-width: 100%;
	margin: 0;
	padding: 0;
	vertical-align: middle;
}

.agency-top-bar__item:hover .agency-top-bar__text,
.agency-top-bar__item:focus .agency-top-bar__text {
	color: var(--agency-topbar-link-hover, #fff);
}

.agency-top-bar__icon {
	flex-shrink: 0;
	width: 1em;
	line-height: 1;
	font-size: 1.05em;
	color: var(--agency-contact-icon, var(--agency-topbar-icon, var(--agency-highlight)));
	margin: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.agency-top-bar__text {
	white-space: normal;
	word-break: break-word;
	line-height: inherit;
	display: inline-block;
	margin: 0;
	padding: 0;
}

/* Social */
.agency-social-links {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.agency-social-links a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	color: var(--agency-highlight);
	font-size: 16px;
	border-radius: 50%;
	transition: color var(--agency-transition), background var(--agency-transition), transform var(--agency-transition);
}

.agency-social-links a:hover {
	color: #fff;
	background: rgba(245, 184, 0, 0.2);
	transform: translateY(-1px);
}

.agency-top-bar .agency-social-links a {
	color: var(--agency-social-color, var(--agency-topbar-social, var(--agency-highlight)));
}

.agency-top-bar .agency-social-links a:hover {
	color: var(--agency-topbar-social-hover, #fff);
	background: rgba(255, 255, 255, 0.12);
	transform: none;
}

.site-footer__contact-icon {
	color: var(--agency-contact-icon, var(--agency-topbar-icon, var(--agency-highlight)));
}

.site-footer__contact a:hover,
.site-footer__contact a:focus {
	color: var(--agency-topbar-link-hover, #fff);
}

.site-footer .agency-social-links a {
	color: var(--agency-social-color, var(--agency-topbar-social, var(--agency-highlight)));
}

.site-footer .agency-social-links a:hover {
	color: var(--agency-social-hover, var(--agency-topbar-social-hover, #fff));
	background: rgba(255, 255, 255, 0.12);
	transform: none;
}

/* Header */
.site-header {
	background: var(--agency-white);
	box-shadow: 0 1px 0 var(--agency-gray-200);
	position: sticky;
	top: 0;
	z-index: 1000;
	transition: box-shadow var(--agency-transition);
}

.site-header.is-scrolled {
	box-shadow: var(--agency-shadow);
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: nowrap;
	padding: 16px 0;
	gap: 16px;
}

/* Desktop: logo | menu (center) | one CTA — no wrap beside logo */
@media (min-width: 993px) {
	.site-header__inner {
		display: grid;
		grid-template-columns: auto minmax(0, 1fr) auto;
		align-items: center;
		column-gap: 24px;
	}

	.site-branding {
		grid-column: 1;
		min-width: 0;
	}

	.menu-toggle {
		display: none !important;
	}

	.main-navigation {
		grid-column: 2;
		min-width: 0;
		justify-content: center;
	}

	.site-header__cta {
		grid-column: 3;
		justify-self: end;
	}

	.main-navigation__cta {
		display: none !important;
	}

	.main-navigation .menu {
		flex-wrap: wrap;
		justify-content: center;
		row-gap: 4px;
	}

	.main-navigation .menu a {
		padding: 8px 12px;
		font-size: clamp(11px, 1.1vw, 14px);
	}
}

.main-navigation {
	flex: 1;
	display: flex;
	justify-content: center;
}

.site-branding .custom-logo { max-height: 60px; width: auto; }

.site-title {
	font-family: var(--agency-font-heading);
	font-size: 28px;
	font-weight: 800;
	color: var(--agency-primary);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

/* Navigation */
.main-navigation .menu {
	display: flex;
	list-style: none;
	margin: 0;
	padding: 0;
	gap: 4px;
}

.main-navigation .menu a {
	display: block;
	padding: 10px 16px;
	font-family: var(--agency-font-heading);
	font-size: 14px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--agency-primary);
}

.main-navigation .menu a:hover,
.main-navigation .current-menu-item > a {
	color: var(--agency-accent);
}

.main-navigation .sub-menu {
	position: absolute;
	background: var(--agency-dark);
	min-width: 220px;
	list-style: none;
	margin: 0;
	padding: 8px 0;
	opacity: 0;
	visibility: hidden;
	transform: translateY(8px);
	transition: all var(--agency-transition);
	box-shadow: var(--agency-shadow);
}

.main-navigation .menu-item-has-children { position: relative; }
.main-navigation .menu-item-has-children:hover > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.main-navigation .sub-menu a { color: var(--agency-white); font-size: 13px; }
.main-navigation .sub-menu a:hover { color: var(--agency-highlight); background: rgba(255,255,255,0.05); }

.menu-toggle {
	display: none;
	flex-direction: column;
	justify-content: center;
	gap: 5px;
	background: none;
	border: none;
	cursor: pointer;
	padding: 10px;
	z-index: 1003;
}

.menu-toggle__bar {
	display: block;
	width: 24px;
	height: 2px;
	background: var(--agency-primary);
	transition: var(--agency-transition);
}

/* Main content */
.site-main { padding: 60px 0; }
.site-main--front { padding: 0; }

.page-header { margin-bottom: 40px; }
.page-title { font-size: 2.5rem; }

/* Posts grid */
.posts-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	gap: 32px;
}

.post-card {
	background: var(--agency-white);
	border: 1px solid var(--agency-gray-200);
	border-radius: var(--agency-radius);
	overflow: hidden;
	transition: box-shadow var(--agency-transition);
}

.post-card:hover { box-shadow: var(--agency-shadow); }

.post-card__thumb img { width: 100%; aspect-ratio: 3/2; object-fit: cover; }
.post-card__body { padding: 24px; }
.post-card__title { font-size: 1.25rem; margin-bottom: 8px; }
.post-card__title a { color: var(--agency-primary); }
.post-card__meta { font-size: 13px; color: var(--agency-text-light); margin-bottom: 12px; }

/* Entry */
.entry-header { margin-bottom: 32px; }
.entry-title { font-size: 2.5rem; }
.entry-meta { font-size: 14px; color: var(--agency-text-light); }
.entry-thumbnail { margin-bottom: 32px; border-radius: var(--agency-radius); overflow: hidden; }
.entry-content { font-size: 17px; line-height: 1.8; }
.entry-content p { margin-bottom: 1.5em; }

/* 404 */
.error-404 { text-align: center; padding: 80px 0; }
.error-404__code { font-size: 8rem; color: var(--agency-accent); line-height: 1; margin-bottom: 0; }
.error-404__title { font-size: 2rem; margin-bottom: 16px; }

/* Footer */
.site-footer { background: var(--agency-primary); color: rgba(255, 255, 255, 0.85); }
.site-footer__main { padding: 60px 0 40px; }
.site-footer__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 40px;
}

.site-footer__title {
	font-size: 1.5rem;
	color: var(--agency-white);
	text-transform: uppercase;
}

.site-footer .widget-title {
	color: var(--agency-contact-icon, var(--agency-topbar-icon, var(--agency-highlight)));
	font-size: 14px;
	margin-bottom: 20px;
	border-bottom: none;
	padding-bottom: 0;
	display: block;
}

.site-footer a { color: rgba(255, 255, 255, 0.85); }
.site-footer a:hover { color: var(--agency-highlight); }

.site-footer__bottom {
	background: var(--agency-dark);
	padding: 16px 0;
	font-size: 13px;
}

.site-footer__bottom-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	flex-wrap: wrap;
}

.site-footer__copyright { margin: 0; }

/* Sidebar */
#secondary { padding: 60px 0; }
.widget { margin-bottom: 32px; }
.widget-title {
	font-size: 14px;
	color: var(--agency-primary);
	border-bottom: 3px solid var(--agency-highlight);
	padding-bottom: 8px;
	display: inline-block;
}

/* Pagination */
.navigation.pagination { margin-top: 48px; text-align: center; }
.navigation.pagination .nav-links { display: flex; justify-content: center; gap: 8px; }
.navigation.pagination a,
.navigation.pagination span {
	display: inline-block;
	padding: 8px 16px;
	border: 1px solid var(--agency-gray-200);
	color: var(--agency-primary);
}

.navigation.pagination .current {
	background: var(--agency-accent);
	color: var(--agency-white);
	border-color: var(--agency-accent);
}

/* Mobile overlay menu — below .site-header (1000) so the drawer stays visible */
.mobile-nav-overlay {
	position: fixed;
	inset: 0;
	background: rgba(13, 21, 38, 0.55);
	z-index: 999;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: opacity var(--agency-transition), visibility var(--agency-transition);
}

.mobile-nav-overlay.is-visible {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
}

body.agency-menu-open {
	overflow: hidden;
}

body.agency-menu-open .site-header {
	z-index: 1002;
}

/* Hide hamburger when drawer is open (× button inside panel closes menu) */
body.agency-menu-open .menu-toggle {
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
}

.menu-close {
	display: none;
	position: absolute;
	top: 16px;
	right: 16px;
	width: 44px;
	height: 44px;
	border: none;
	background: var(--agency-gray-100);
	border-radius: 50%;
	font-size: 28px;
	line-height: 1;
	cursor: pointer;
	color: var(--agency-primary);
	z-index: 2;
}

.main-navigation__panel {
	width: 100%;
}

.main-navigation__cta {
	display: none;
}

/* Responsive */
@media (max-width: 992px) {
	.site-footer__grid { grid-template-columns: 1fr 1fr; }
	.site-header__inner {
		display: flex;
		flex-wrap: nowrap;
	}

	.site-header__cta { display: none; }
	.main-navigation { flex: 0; }

	.site-header {
		overflow: visible;
	}

	.menu-toggle {
		display: flex;
		position: relative;
		z-index: 1003;
		flex-shrink: 0;
		margin-left: auto;
	}

	.main-navigation {
		position: fixed;
		top: 0;
		right: 0;
		width: min(320px, 88vw);
		max-width: 100%;
		height: 100vh;
		height: 100dvh;
		background: #ffffff;
		z-index: 1005;
		transform: translateX(100%);
		transition: transform 0.35s cubic-bezier(0.25, 0.46, 0.45, 0.94);
		box-shadow: -8px 0 32px rgba(0, 0, 0, 0.18);
		overflow-x: hidden;
		overflow-y: auto;
		padding: 0;
		-webkit-overflow-scrolling: touch;
		visibility: visible;
		isolation: isolate;
	}

	.main-navigation.toggled {
		transform: translateX(0);
	}

	.menu-close {
		display: flex;
		align-items: center;
		justify-content: center;
		z-index: 10;
	}

	.main-navigation__panel {
		padding: 72px 24px 32px;
		background: #ffffff;
		min-height: 100%;
		box-sizing: border-box;
	}

	.site-branding {
		position: relative;
		z-index: 1003;
		flex: 1;
		min-width: 0;
	}

	.main-navigation .menu {
		flex-direction: column;
		gap: 0;
		width: 100%;
	}

	.main-navigation .menu > li {
		border-bottom: 1px solid var(--agency-gray-200);
	}

	.main-navigation .menu a {
		padding: 16px 0;
		font-size: var(--agency-font-size-menu, 15px);
		display: block;
	}

	.main-navigation .sub-menu {
		position: static;
		opacity: 1;
		visibility: visible;
		transform: none;
		box-shadow: none;
		background: transparent;
		padding: 0 0 8px 12px;
		display: none;
	}

	.main-navigation .menu-item-has-children.submenu-open > .sub-menu {
		display: block;
	}

	.main-navigation .menu-item-has-children > a::after {
		content: '+';
		float: right;
		font-weight: 400;
	}

	.main-navigation .menu-item-has-children.submenu-open > a::after {
		content: '−';
	}

	.main-navigation__cta {
		display: block;
		margin-top: 24px;
		width: 100%;
		text-align: center;
		box-sizing: border-box;
	}

	.agency-top-bar__inner {
		flex-direction: column;
		align-items: flex-start;
	}

	.agency-top-bar__left,
	.agency-top-bar__right {
		flex: 1 1 100%;
		justify-content: flex-start;
		width: 100%;
	}

	.agency-top-bar__contact {
		width: 100%;
	}

	/* Mobile top bar: address + primary phone only */
	.agency-top-bar__item--fax,
	.agency-top-bar__item--email,
	.agency-top-bar__item--clock {
		display: none !important;
	}

	.agency-top-bar {
		font-size: 11px;
	}

	.agency-top-bar__icon {
		font-size: 1em;
	}

	.agency-top-bar .agency-social-links a {
		font-size: 14px;
		width: 28px;
		height: 28px;
	}
}

@media (max-width: 768px) {
	.site-footer__grid { grid-template-columns: 1fr; }
	.site-header__inner { padding: 12px 0; }
	.agency-top-bar { font-size: 10px; }
	.agency-top-bar__inner { padding: 0 16px; }
}
