/* =========================================================
   BSvH | Employment Law — main stylesheet
   White + muted dark slate-blue. Restrained, sans-serif.
   ========================================================= */

/* ---------- Reset / base ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body { margin: 0; }
img, svg { max-width: 100%; height: auto; display: block; }
button { font: inherit; cursor: pointer; }

/* ---------- Design tokens ---------- */
:root {
	--c-primary:        #1F2A44;   /* muted deep slate-blue */
	--c-primary-dark:   #14192A;
	--c-primary-soft:   #324A6B;
	--c-primary-tint:   rgba(31, 42, 68, 0.06);

	--c-text:           #1F2A37;
	--c-text-muted:     #5C6B85;
	--c-text-soft:      #8392AB;

	--c-bg:             #FFFFFF;
	--c-bg-soft:        #F5F7FA;   /* cool, pale blue-gray */
	--c-bg-soft-deep:   #EBEFF5;

	--c-border:         #E1E5EC;
	--c-border-soft:    #EEF1F5;

	--c-success:        #1E7A55;
	--c-error:          #B0413E;
	--c-warning:        #C97E1B;
	--c-whatsapp:       #25D366;

	--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

	--shadow-sm: 0 1px 2px rgba(31, 42, 68, 0.05);
	--shadow-md: 0 4px 14px rgba(31, 42, 68, 0.08);
	--shadow-lg: 0 10px 28px rgba(31, 42, 68, 0.12);

	--radius-sm: 3px;
	--radius-md: 6px;
	--radius-lg: 10px;

	--container: 1180px;
	--container-narrow: 780px;

	--space-1: 0.25rem;
	--space-2: 0.5rem;
	--space-3: 0.75rem;
	--space-4: 1rem;
	--space-5: 1.5rem;
	--space-6: 2rem;
	--space-7: 3rem;
	--space-8: 4rem;
	--space-9: 6rem;
}

/* ---------- Typography ---------- */
html { font-size: 17px; }
@media (max-width: 600px) { html { font-size: 16px; } }

body {
	font-family: var(--font-sans);
	font-weight: 400;
	color: var(--c-text);
	background: var(--c-bg);
	line-height: 1.7;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-sans);
	color: var(--c-primary);
	font-weight: 600;
	margin: 0 0 var(--space-4);
	line-height: 1.2;
	letter-spacing: -0.005em;
}
h1 { font-size: 2.6rem; line-height: 1.15; letter-spacing: -0.012em; }
h2 { font-size: 1.95rem; }
h3 { font-size: 1.45rem; }
h4 { font-size: 1.18rem; font-weight: 500; }
@media (max-width: 600px) {
	h1 { font-size: 2.0rem; }
	h2 { font-size: 1.55rem; }
	h3 { font-size: 1.25rem; }
}

p { margin: 0 0 var(--space-4); }

a {
	color: var(--c-primary);
	text-decoration: underline;
	text-decoration-color: var(--c-border);
	text-underline-offset: 3px;
	transition: text-decoration-color 0.15s ease, color 0.15s ease;
}
a:hover, a:focus {
	text-decoration-color: var(--c-primary);
	color: var(--c-primary-soft);
}

strong { font-weight: 600; }

.dg-eyebrow {
	text-transform: uppercase;
	letter-spacing: 0.18em;
	font-size: 0.78rem;
	font-weight: 500;
	color: var(--c-text-muted);
	margin: 0 0 var(--space-3);
}

/* ---------- Layout helpers ---------- */
.dg-container {
	max-width: var(--container);
	margin: 0 auto;
	padding: 0 var(--space-5);
}
@media (min-width: 900px) {
	.dg-container { padding: 0 var(--space-6); }
}

.dg-content { padding: var(--space-8) 0; }
.dg-content--narrow { max-width: var(--container-narrow); margin: 0 auto; }
@media (max-width: 700px) {
	.dg-content { padding: var(--space-6) 0; }
}

.dg-section { padding: var(--space-9) 0; }
.dg-section--alt { background: var(--c-bg-soft); }
.dg-section--cta { background: var(--c-primary); color: #FFFFFF; text-align: center; padding: var(--space-8) 0; }
.dg-section--cta h2 { color: #FFFFFF; margin-bottom: var(--space-4); }
.dg-section--cta p { color: rgba(255, 255, 255, 0.82); max-width: 600px; margin: 0 auto var(--space-5); }
@media (max-width: 700px) {
	.dg-section { padding: var(--space-7) 0; }
}

.dg-section__header { max-width: 760px; margin: 0 auto var(--space-7); text-align: center; }
.dg-section__header h2 { margin-bottom: var(--space-3); }
.dg-section__lede { color: var(--c-text-muted); font-size: 1.08rem; }
.dg-section__more { text-align: center; margin-top: var(--space-6); font-size: 1.02rem; }

.dg-grid { display: grid; gap: var(--space-5); }
.dg-grid--2 { grid-template-columns: repeat(2, 1fr); }
.dg-grid--3 { grid-template-columns: repeat(3, 1fr); }
.dg-grid--4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 900px) {
	.dg-grid--2, .dg-grid--3, .dg-grid--4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 580px) {
	.dg-grid--2, .dg-grid--3, .dg-grid--4 { grid-template-columns: 1fr; }
}

/* ---------- Skip link ---------- */
.dg-skiplink {
	position: absolute;
	top: -100px;
	left: 0;
	background: var(--c-primary);
	color: #FFFFFF;
	padding: var(--space-3) var(--space-4);
	z-index: 9999;
	text-decoration: none;
}
.dg-skiplink:focus { top: 0; }

/* ---------- Top utility bar (phone + WhatsApp) ---------- */
.dg-topbar {
	background: var(--c-primary);
	color: rgba(255, 255, 255, 0.92);
	font-size: 0.88rem;
}
.dg-topbar__inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0.55rem var(--space-5);
	gap: var(--space-4);
	flex-wrap: wrap;
}
.dg-topbar__left { font-size: 0.86rem; color: rgba(255, 255, 255, 0.7); }
.dg-topbar__contacts { display: flex; align-items: center; gap: var(--space-4); flex-wrap: wrap; }
.dg-topbar__contact {
	color: #FFFFFF;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	font-weight: 500;
	transition: opacity 0.15s;
}
.dg-topbar__contact:hover { color: #FFFFFF; opacity: 0.8; text-decoration: none; }
.dg-topbar__contact svg { width: 16px; height: 16px; flex-shrink: 0; }
.dg-topbar__contact--whatsapp svg { color: var(--c-whatsapp); }
@media (max-width: 700px) {
	.dg-topbar__inner { justify-content: center; padding: 0.5rem var(--space-4); }
	.dg-topbar__left { display: none; }
}

/* ---------- Header ---------- */
.dg-site-header {
	background: var(--c-bg);
	border-bottom: 1px solid var(--c-border);
	position: sticky;
	top: 0;
	z-index: 50;
}
.dg-site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-5);
	padding-top: var(--space-4);
	padding-bottom: var(--space-4);
}
.dg-logo img, .dg-logo svg { height: 52px; width: auto; }
.dg-site-header .custom-logo { height: 52px; width: auto; }

.dg-primary-nav { display: flex; align-items: center; gap: var(--space-5); }
.dg-primary-nav__list {
	list-style: none;
	display: flex;
	gap: var(--space-5);
	margin: 0;
	padding: 0;
	align-items: center;
}
.dg-primary-nav__list a {
	color: var(--c-primary);
	text-decoration: none;
	font-weight: 500;
	font-size: 0.95rem;
	padding: var(--space-2) 0;
	border-bottom: 2px solid transparent;
	transition: border-color 0.15s;
}
.dg-primary-nav__list a:hover,
.dg-primary-nav__list .current-menu-item > a,
.dg-primary-nav__list .current_page_item > a { border-color: var(--c-primary); }

.dg-primary-nav__list .menu-item-has-children { position: relative; }
.dg-primary-nav__list .sub-menu {
	display: none;
	position: absolute;
	top: 100%;
	left: -1rem;
	background: var(--c-bg);
	min-width: 240px;
	list-style: none;
	margin: 0;
	padding: var(--space-3) 0;
	box-shadow: var(--shadow-md);
	border: 1px solid var(--c-border);
	border-radius: var(--radius-md);
}
.dg-primary-nav__list .menu-item-has-children:hover .sub-menu,
.dg-primary-nav__list .menu-item-has-children:focus-within .sub-menu { display: block; }
.dg-primary-nav__list .sub-menu li { display: block; }
.dg-primary-nav__list .sub-menu a {
	padding: var(--space-2) var(--space-4);
	border-bottom: none;
	display: block;
}
.dg-primary-nav__list .sub-menu a:hover { background: var(--c-bg-soft); }

.dg-primary-nav__cta { white-space: nowrap; }

.dg-menu-toggle {
	display: none;
	background: transparent;
	border: 1px solid var(--c-border);
	border-radius: var(--radius-sm);
	padding: var(--space-2) var(--space-3);
	color: var(--c-primary);
	font-weight: 500;
	align-items: center;
	gap: var(--space-2);
}
.dg-menu-toggle__bars { display: inline-flex; flex-direction: column; gap: 3px; }
.dg-menu-toggle__bars span { display: block; width: 18px; height: 2px; background: var(--c-primary); }

@media (max-width: 900px) {
	.dg-menu-toggle { display: inline-flex; }
	.dg-primary-nav {
		display: none;
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		background: var(--c-bg);
		border-bottom: 1px solid var(--c-border);
		padding: var(--space-5);
		flex-direction: column;
		align-items: stretch;
	}
	.dg-primary-nav.is-open { display: flex; }
	.dg-primary-nav__list { flex-direction: column; align-items: stretch; gap: 0; }
	.dg-primary-nav__list li { border-bottom: 1px solid var(--c-border-soft); }
	.dg-primary-nav__list a { padding: var(--space-3) 0; display: block; }
	.dg-primary-nav__list .sub-menu { display: block; position: static; box-shadow: none; border: none; padding-left: var(--space-4); }
	.dg-primary-nav__cta { margin-top: var(--space-3); align-self: stretch; text-align: center; }
}

/* ---------- Buttons ---------- */
.dg-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.85rem 1.6rem;
	border-radius: var(--radius-sm);
	font-weight: 500;
	text-decoration: none;
	font-size: 0.97rem;
	border: 1px solid transparent;
	background: var(--c-primary);
	color: #FFFFFF;
	transition: background 0.15s, color 0.15s;
}
.dg-button:hover, .dg-button:focus { background: var(--c-primary-dark); color: #FFFFFF; text-decoration: none; }
.dg-button--primary { background: var(--c-primary); color: #FFFFFF; }
.dg-button--ghost { background: transparent; color: var(--c-primary); border-color: var(--c-primary); }
.dg-button--ghost:hover, .dg-button--ghost:focus { background: var(--c-primary); color: #FFFFFF; }
.dg-button--whatsapp { background: var(--c-whatsapp); color: #FFFFFF; }
.dg-button--whatsapp:hover { background: #1FB155; color: #FFFFFF; }

/* Legacy gold class kept as alias to primary for backward compatibility */
.dg-button--gold { background: var(--c-primary); color: #FFFFFF; }
.dg-button--gold:hover { background: var(--c-primary-dark); color: #FFFFFF; }

/* ---------- Icons ---------- */
.dg-icon {
	display: inline-block;
	width: 1em;
	height: 1em;
	vertical-align: middle;
	fill: currentColor;
}
.dg-icon-circle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	border-radius: 50%;
	background: var(--c-primary-tint);
	color: var(--c-primary);
	margin-bottom: var(--space-4);
	flex-shrink: 0;
}
.dg-icon-circle svg { width: 28px; height: 28px; }
.dg-icon-circle--inverse { background: var(--c-primary); color: #FFFFFF; }
.dg-icon-circle--sm { width: 40px; height: 40px; }
.dg-icon-circle--sm svg { width: 20px; height: 20px; }

/* ---------- Hero ---------- */
.dg-hero {
	background: var(--c-bg-soft);
	padding: var(--space-9) 0 var(--space-8);
	border-bottom: 1px solid var(--c-bg-soft-deep);
}
.dg-hero__inner {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: var(--space-8);
	align-items: start;
}
@media (max-width: 900px) { .dg-hero__inner { grid-template-columns: 1fr; gap: var(--space-6); } }

.dg-hero__title { font-size: 3.1rem; line-height: 1.1; margin: 0 0 var(--space-5); }
.dg-hero__title-accent { display: block; color: var(--c-primary-soft); font-weight: 400; margin-top: var(--space-2); font-size: 0.88em; }
@media (max-width: 700px) { .dg-hero__title { font-size: 2.2rem; } }

.dg-hero__lede { font-size: 1.15rem; color: var(--c-text); max-width: 580px; margin-bottom: var(--space-6); }
.dg-hero__actions { display: flex; gap: var(--space-3); flex-wrap: wrap; margin-bottom: var(--space-6); }
.dg-hero__trust { font-size: 0.92rem; color: var(--c-text-muted); }

.dg-hero__panel {
	background: var(--c-bg);
	border: 1px solid var(--c-border);
	border-radius: var(--radius-md);
	padding: var(--space-6);
	border-top: 3px solid var(--c-primary);
	box-shadow: var(--shadow-sm);
}
.dg-hero__panel-title { font-size: 1.15rem; margin-bottom: var(--space-4); }
.dg-hero__panel-list { list-style: none; padding: 0; margin: 0 0 var(--space-5); counter-reset: step; }
.dg-hero__panel-list li {
	counter-increment: step;
	padding-left: 2.4rem;
	position: relative;
	margin-bottom: var(--space-4);
	color: var(--c-text);
	font-size: 0.97rem;
}
.dg-hero__panel-list li::before {
	content: counter(step);
	position: absolute;
	left: 0;
	top: 0;
	width: 26px;
	height: 26px;
	border-radius: 50%;
	background: var(--c-primary);
	color: #FFFFFF;
	font-size: 0.78rem;
	font-weight: 600;
	display: flex;
	align-items: center;
	justify-content: center;
}
.dg-hero__panel-link { font-weight: 500; font-size: 0.97rem; text-decoration: none; color: var(--c-primary); }
.dg-hero__panel-link:hover { color: var(--c-primary-soft); }

/* ---------- Cards (services) ---------- */
.dg-card {
	background: var(--c-bg);
	border: 1px solid var(--c-border);
	border-radius: var(--radius-md);
	padding: var(--space-5);
	transition: border-color 0.15s, transform 0.15s, box-shadow 0.15s;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
}
.dg-card:hover { border-color: var(--c-primary); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.dg-card__title { font-size: 1.12rem; margin: 0 0 var(--space-3); }
.dg-card__title a { text-decoration: none; color: var(--c-primary); }
.dg-card p { color: var(--c-text-muted); font-size: 0.95rem; margin: 0; }

.dg-mini-card {
	display: block;
	background: var(--c-bg);
	border: 1px solid var(--c-border);
	border-radius: var(--radius-md);
	padding: var(--space-5);
	text-decoration: none;
	color: var(--c-primary);
	transition: border-color 0.15s, transform 0.15s;
}
.dg-mini-card:hover { border-color: var(--c-primary); transform: translateY(-2px); text-decoration: none; }
.dg-mini-card__eyebrow {
	display: block;
	text-transform: uppercase;
	letter-spacing: 0.16em;
	font-size: 0.72rem;
	color: var(--c-text-muted);
	font-weight: 500;
	margin-bottom: var(--space-3);
}
.dg-mini-card__title { display: block; font-size: 1.04rem; line-height: 1.4; font-weight: 500; }

/* ---------- Deadline banner ---------- */
.dg-deadline-banner {
	background: var(--c-primary);
	color: #FFFFFF;
	border-radius: var(--radius-md);
	padding: var(--space-7);
	display: flex;
	gap: var(--space-5);
	align-items: flex-start;
}
.dg-deadline-banner__icon { flex-shrink: 0; color: #FFFFFF; opacity: 0.9; }
.dg-deadline-banner__icon svg { width: 48px; height: 48px; }
.dg-deadline-banner__title { color: #FFFFFF; font-size: 1.6rem; margin-bottom: var(--space-3); }
.dg-deadline-banner__text { color: rgba(255, 255, 255, 0.88); max-width: 720px; margin-bottom: var(--space-5); font-size: 1.04rem; }
@media (max-width: 700px) { .dg-deadline-banner { flex-direction: column; padding: var(--space-5); } }

.dg-deadline {
	background: var(--c-bg-soft);
	border-left: 3px solid var(--c-primary);
	padding: var(--space-4) var(--space-5);
	border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
	margin: var(--space-5) 0;
}

.dg-cta {
	background: var(--c-bg-soft);
	border: 1px solid var(--c-bg-soft-deep);
	border-radius: var(--radius-md);
	padding: var(--space-6);
	margin: var(--space-7) 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-5);
	flex-wrap: wrap;
}
.dg-cta__heading { font-size: 1.18rem; margin-bottom: var(--space-2); }
.dg-cta__text { margin: 0; color: var(--c-text-muted); }

/* ---------- Lawyer cards ---------- */
.dg-lawyer { text-align: center; }
.dg-lawyer__photo {
	width: 200px;
	height: 200px;
	border-radius: 50%;
	object-fit: cover;
	margin: 0 auto var(--space-4);
	border: 1px solid var(--c-border);
}
.dg-lawyer__name { font-size: 1.25rem; margin-bottom: var(--space-1); }
.dg-lawyer__role { color: var(--c-primary-soft); font-size: 0.92rem; margin-bottom: var(--space-3); font-weight: 500; }
.dg-lawyer__bio { color: var(--c-text-muted); font-size: 0.97rem; max-width: 320px; margin: 0 auto; }

/* ---------- Articles / page body ---------- */
.dg-article { max-width: var(--container-narrow); margin: 0 auto; }
.dg-article__header { margin-bottom: var(--space-7); }
.dg-article__title { font-size: 2.5rem; margin-bottom: var(--space-3); }
.dg-article__lede { font-size: 1.18rem; color: var(--c-text-muted); margin-bottom: var(--space-3); line-height: 1.55; }
.dg-article__meta { color: var(--c-text-muted); font-size: 0.92rem; }
@media (max-width: 700px) { .dg-article__title { font-size: 1.85rem; } }

.dg-article__body { font-size: 1.04rem; }
.dg-article__body h2 { margin-top: var(--space-7); font-size: 1.6rem; }
.dg-article__body h3 { margin-top: var(--space-6); font-size: 1.25rem; }
.dg-article__body ul, .dg-article__body ol { padding-left: 1.4rem; margin-bottom: var(--space-5); }
.dg-article__body li { margin-bottom: var(--space-2); }
.dg-article__body li::marker { color: var(--c-primary); }
.dg-article__body blockquote {
	border-left: 3px solid var(--c-primary);
	margin: var(--space-6) 0;
	padding: 0 0 0 var(--space-5);
	font-size: 1.1rem;
	color: var(--c-text-muted);
	font-style: normal;
}
.dg-article__body code {
	background: var(--c-bg-soft);
	padding: 0.1em 0.4em;
	border-radius: 3px;
	font-size: 0.92em;
	font-family: "SFMono-Regular", Consolas, monospace;
}
.dg-article__body table {
	width: 100%;
	border-collapse: collapse;
	margin: var(--space-5) 0;
	font-size: 0.95rem;
}
.dg-article__body th, .dg-article__body td {
	padding: 0.6rem 0.8rem;
	border-bottom: 1px solid var(--c-border);
	text-align: left;
	vertical-align: top;
}
.dg-article__body th {
	font-weight: 600;
	color: var(--c-primary);
	background: var(--c-bg-soft);
}

/* ---------- Page header (archives, reference list) ---------- */
.dg-page-header { text-align: center; max-width: 800px; margin: 0 auto var(--space-7); }
.dg-page-header__lede { font-size: 1.12rem; color: var(--c-text-muted); }

/* ---------- Topic index (above glossary archive) ---------- */
.dg-topic-index {
	background: var(--c-bg-soft);
	border: 1px solid var(--c-bg-soft-deep);
	border-radius: var(--radius-md);
	padding: var(--space-5) var(--space-6);
	margin-bottom: var(--space-8);
}
.dg-topic-index__heading {
	font-size: 0.78rem;
	text-transform: uppercase;
	letter-spacing: 0.16em;
	color: var(--c-text-muted);
	font-weight: 500;
	margin-bottom: var(--space-3);
}
.dg-topic-index__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3) var(--space-5);
}
.dg-topic-index__list li { margin: 0; }
.dg-topic-index__list a {
	color: var(--c-primary);
	text-decoration: none;
	font-weight: 500;
	font-size: 0.97rem;
	border-bottom: 1px solid transparent;
	padding-bottom: 2px;
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
}
.dg-topic-index__list a:hover { border-bottom-color: var(--c-primary); }
.dg-topic-index__list a .dg-topic-index__count {
	font-size: 0.78rem;
	color: var(--c-text-muted);
	background: var(--c-bg);
	padding: 0.05rem 0.45rem;
	border-radius: 99px;
	border: 1px solid var(--c-border);
	font-weight: 500;
}

/* ---------- Topic groups (reference index) ---------- */
.dg-topic-group {
	margin-bottom: var(--space-8);
	scroll-margin-top: 100px;
}
.dg-topic-group__heading {
	font-size: 1.45rem;
	margin-bottom: var(--space-2);
	display: flex;
	align-items: center;
	gap: var(--space-3);
}
.dg-topic-group__heading-icon {
	display: inline-flex;
	width: 36px;
	height: 36px;
	border-radius: 8px;
	background: var(--c-primary-tint);
	color: var(--c-primary);
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.dg-topic-group__heading-icon svg { width: 20px; height: 20px; }
.dg-topic-group__desc { color: var(--c-text-muted); margin-bottom: var(--space-5); margin-left: 48px; }
.dg-topic-group__list { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(2, 1fr); gap: 0; border-top: 1px solid var(--c-border-soft); }
.dg-topic-group__list li { border-bottom: 1px solid var(--c-border-soft); }
.dg-topic-group__list li:nth-child(odd) { border-right: 1px solid var(--c-border-soft); }
.dg-topic-group__list a {
	display: block;
	padding: var(--space-4) var(--space-5);
	text-decoration: none;
	transition: background 0.12s;
}
.dg-topic-group__list a:hover { background: var(--c-bg-soft); }
.dg-topic-group__title { display: block; font-weight: 500; color: var(--c-primary); font-size: 1.02rem; line-height: 1.35; }
.dg-topic-group__excerpt { display: block; color: var(--c-text-muted); font-size: 0.9rem; margin-top: var(--space-1); }
@media (max-width: 700px) {
	.dg-topic-group__list { grid-template-columns: 1fr; }
	.dg-topic-group__list li:nth-child(odd) { border-right: 0; }
}

/* ---------- Breadcrumbs ---------- */
.dg-breadcrumbs {
	font-size: 0.9rem;
	color: var(--c-text-muted);
	margin-bottom: var(--space-5);
}
.dg-breadcrumbs a { color: var(--c-text-muted); text-decoration: none; }
.dg-breadcrumbs a:hover { color: var(--c-primary); }
.dg-breadcrumbs span[aria-hidden] { margin: 0 var(--space-2); color: var(--c-border); }

/* ---------- Related articles ---------- */
.dg-related {
	margin-top: var(--space-8);
	padding-top: var(--space-6);
	border-top: 1px solid var(--c-border);
}
.dg-related__heading { font-size: 1.2rem; margin-bottom: var(--space-4); }
.dg-related__list { list-style: none; padding: 0; margin: 0; }
.dg-related__list li { padding: var(--space-3) 0; border-bottom: 1px solid var(--c-border-soft); }
.dg-related__list a { text-decoration: none; color: var(--c-primary); font-weight: 500; }
.dg-related__list a:hover { color: var(--c-primary-soft); }

/* ---------- Forms ---------- */
.dg-form {
	background: var(--c-bg);
	border: 1px solid var(--c-border);
	border-radius: var(--radius-md);
	padding: var(--space-6);
}
.dg-form__row { margin-bottom: var(--space-4); }
.dg-form label {
	display: block;
	font-size: 0.95rem;
	font-weight: 500;
	color: var(--c-primary);
	margin-bottom: var(--space-2);
}
.dg-form input[type="text"],
.dg-form input[type="email"],
.dg-form input[type="tel"],
.dg-form select,
.dg-form textarea {
	width: 100%;
	padding: 0.7rem 0.85rem;
	border: 1px solid var(--c-border);
	border-radius: var(--radius-sm);
	font-family: var(--font-sans);
	font-size: 1rem;
	color: var(--c-text);
	background: var(--c-bg);
	transition: border-color 0.15s;
}
.dg-form input:focus, .dg-form textarea:focus, .dg-form select:focus { outline: none; border-color: var(--c-primary); }
.dg-form textarea { min-height: 160px; resize: vertical; }
.dg-form__hint { font-size: 0.85rem; color: var(--c-text-muted); margin-top: var(--space-2); }

/* Contact Form 7 specific overrides */
.wpcf7-form p { margin-bottom: var(--space-4); }
.wpcf7-form label { display: block; font-weight: 500; color: var(--c-primary); margin-bottom: var(--space-2); }
.wpcf7-form input[type="text"], .wpcf7-form input[type="email"], .wpcf7-form input[type="tel"],
.wpcf7-form select, .wpcf7-form textarea {
	width: 100%; padding: 0.7rem 0.85rem;
	border: 1px solid var(--c-border); border-radius: var(--radius-sm);
	font-family: var(--font-sans); font-size: 1rem; color: var(--c-text); background: var(--c-bg);
}
.wpcf7-form input:focus, .wpcf7-form textarea:focus, .wpcf7-form select:focus { outline: none; border-color: var(--c-primary); }
.wpcf7-form textarea { min-height: 160px; resize: vertical; }
.wpcf7-form input[type="submit"] {
	background: var(--c-primary); color: #FFFFFF; padding: 0.85rem 1.8rem;
	border: 0; border-radius: var(--radius-sm); font-weight: 500; font-size: 0.97rem; cursor: pointer;
}
.wpcf7-form input[type="submit"]:hover { background: var(--c-primary-dark); }
.wpcf7-response-output { border: 1px solid var(--c-border); padding: var(--space-3); margin-top: var(--space-4); border-radius: var(--radius-sm); }

.dg-searchform { display: flex; gap: var(--space-2); margin-bottom: var(--space-6); }
.dg-searchform input { flex: 1; padding: 0.65rem 0.85rem; border: 1px solid var(--c-border); border-radius: var(--radius-sm); font-family: inherit; }
.dg-searchform button { padding: 0.65rem 1.2rem; background: var(--c-primary); color: white; border: 0; border-radius: var(--radius-sm); }
.dg-searchform__label { position: absolute; left: -9999px; }

/* ---------- Footer ---------- */
.dg-site-footer { background: var(--c-primary); color: rgba(255, 255, 255, 0.85); padding: var(--space-8) 0 0; margin-top: var(--space-8); }
.dg-site-footer__inner {
	display: grid;
	grid-template-columns: 1.6fr 1fr 1fr 1fr;
	gap: var(--space-7);
	padding-bottom: var(--space-7);
}
@media (max-width: 900px) {
	.dg-site-footer__inner { grid-template-columns: 1fr 1fr; gap: var(--space-6); }
}
@media (max-width: 580px) {
	.dg-site-footer__inner { grid-template-columns: 1fr; }
}
.dg-site-footer__brand img { height: 52px; width: auto; margin-bottom: var(--space-4); }
.dg-site-footer__tagline { font-size: 0.95rem; color: rgba(255, 255, 255, 0.7); max-width: 320px; }
.dg-site-footer h4 { color: #FFFFFF; font-size: 0.92rem; text-transform: uppercase; letter-spacing: 0.12em; font-weight: 500; margin-bottom: var(--space-4); }
.dg-site-footer a { color: rgba(255, 255, 255, 0.85); text-decoration: none; }
.dg-site-footer a:hover { color: #FFFFFF; }
.dg-site-footer address { font-style: normal; line-height: 1.7; font-size: 0.95rem; }
.dg-footer-nav { list-style: none; padding: 0; margin: 0; }
.dg-footer-nav li { margin-bottom: var(--space-2); font-size: 0.95rem; }

.dg-site-footer__bottom { border-top: 1px solid rgba(255, 255, 255, 0.1); padding: var(--space-4) 0; }
.dg-site-footer__bottom-inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--space-3);
	font-size: 0.88rem;
	color: rgba(255, 255, 255, 0.6);
}
.dg-site-footer__bottom-inner p { margin: 0; }
.dg-legal-nav { list-style: none; padding: 0; margin: 0; display: flex; gap: var(--space-4); }
.dg-legal-nav a { font-size: 0.88rem; color: rgba(255, 255, 255, 0.6); }

/* ---------- Floating WhatsApp button ---------- */
.dg-whatsapp-fab {
	position: fixed;
	bottom: 24px;
	right: 24px;
	width: 60px;
	height: 60px;
	border-radius: 50%;
	background: var(--c-whatsapp);
	color: #FFFFFF;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 6px 20px rgba(37, 211, 102, 0.35), 0 2px 6px rgba(0, 0, 0, 0.1);
	z-index: 100;
	text-decoration: none;
	transition: transform 0.15s, box-shadow 0.15s;
}
.dg-whatsapp-fab:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(37, 211, 102, 0.45), 0 3px 8px rgba(0, 0, 0, 0.12);
	color: #FFFFFF;
}
.dg-whatsapp-fab svg { width: 32px; height: 32px; }
.dg-whatsapp-fab__label {
	position: absolute;
	right: 70px;
	background: var(--c-primary);
	color: #FFFFFF;
	padding: 0.5rem 0.85rem;
	border-radius: var(--radius-sm);
	font-size: 0.85rem;
	white-space: nowrap;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.15s;
}
.dg-whatsapp-fab:hover .dg-whatsapp-fab__label { opacity: 1; }
@media (max-width: 600px) {
	.dg-whatsapp-fab { bottom: 16px; right: 16px; width: 52px; height: 52px; }
	.dg-whatsapp-fab svg { width: 28px; height: 28px; }
	.dg-whatsapp-fab__label { display: none; }
}

/* ---------- Cost table specific ---------- */
.dg-cost-table th { background: var(--c-primary); color: #FFFFFF; }

/* ---------- 2-column layout (content + sticky contact widget) ---------- */
.dg-content--with-sidebar { max-width: var(--container); padding-left: var(--space-5); padding-right: var(--space-5); }
.dg-with-sidebar {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 320px;
	gap: var(--space-7);
	align-items: start;
}
.dg-article--in-layout { max-width: none; margin: 0; }
.dg-sidebar { position: sticky; top: 130px; }
.dg-sidebar__inner { position: relative; }
@media (max-width: 1000px) {
	.dg-with-sidebar { grid-template-columns: 1fr; gap: var(--space-6); }
	.dg-sidebar { position: static; }
}

/* ---------- Contact widget ---------- */
.dg-contact-widget {
	background: var(--c-bg);
	border: 1px solid var(--c-border);
	border-top: 3px solid var(--c-primary);
	border-radius: var(--radius-md);
	padding: var(--space-5);
	box-shadow: var(--shadow-sm);
}
.dg-contact-widget__eyebrow {
	font-size: 0.72rem;
	font-weight: 500;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--c-text-muted);
	margin: 0 0 var(--space-2);
}
.dg-contact-widget__title { font-size: 1.18rem; margin: 0 0 var(--space-3); }
.dg-contact-widget__lede { font-size: 0.92rem; color: var(--c-text-muted); margin: 0 0 var(--space-4); }
.dg-contact-widget__list { list-style: none; padding: 0; margin: 0 0 var(--space-4); }
.dg-contact-widget__list li { border-top: 1px solid var(--c-border-soft); }
.dg-contact-widget__list li:first-child { border-top: none; }
.dg-contact-widget__row {
	display: flex;
	align-items: center;
	gap: 0.7rem;
	padding: 0.65rem 0;
	color: var(--c-primary);
	text-decoration: none;
	transition: color 0.15s;
}
.dg-contact-widget__row:hover { color: var(--c-primary-soft); text-decoration: none; }
.dg-contact-widget__icon {
	width: 34px;
	height: 34px;
	flex-shrink: 0;
	border-radius: 8px;
	background: var(--c-primary-tint);
	color: var(--c-primary);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.dg-contact-widget__icon svg { width: 18px; height: 18px; }
.dg-contact-widget__icon--whatsapp { background: rgba(37, 211, 102, 0.15); color: var(--c-whatsapp); }
.dg-contact-widget__row-label {
	display: block;
	font-size: 0.7rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--c-text-muted);
	font-weight: 500;
}
.dg-contact-widget__row-value { display: block; font-size: 0.97rem; font-weight: 500; }
.dg-contact-widget__cta { display: block; width: 100%; text-align: center; }
.dg-contact-widget__small {
	font-size: 0.78rem;
	color: var(--c-text-muted);
	margin: var(--space-3) 0 0;
	text-align: center;
}

/* ---------- Table of contents ---------- */
.dg-toc {
	background: var(--c-bg-soft);
	border: 1px solid var(--c-bg-soft-deep);
	border-left: 3px solid var(--c-primary);
	border-radius: var(--radius-sm);
	padding: var(--space-5);
	margin: 0 0 var(--space-7);
}
.dg-toc__heading {
	margin: 0 0 var(--space-3);
	font-size: 0.78rem;
	font-weight: 500;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--c-text-muted);
}
.dg-toc__list {
	list-style: none;
	padding: 0;
	margin: 0;
	counter-reset: toc;
	columns: 2;
	column-gap: var(--space-6);
}
@media (max-width: 700px) { .dg-toc__list { columns: 1; } }
.dg-toc__list li {
	counter-increment: toc;
	padding: 0.25rem 0 0.25rem 1.8rem;
	position: relative;
	break-inside: avoid;
}
.dg-toc__list li::before {
	content: counter(toc, decimal-leading-zero);
	position: absolute;
	left: 0;
	top: 0.4rem;
	font-size: 0.72rem;
	font-weight: 600;
	color: var(--c-primary-soft);
	letter-spacing: 0.05em;
}
.dg-toc__list a {
	color: var(--c-primary);
	text-decoration: none;
	font-size: 0.95rem;
	line-height: 1.4;
	border-bottom: 1px solid transparent;
}
.dg-toc__list a:hover { border-bottom-color: var(--c-primary); }

/* ---------- Callout boxes ---------- */
.dg-callout {
	display: flex;
	gap: var(--space-4);
	padding: var(--space-5);
	border-radius: var(--radius-md);
	margin: var(--space-6) 0;
	border-left: 3px solid var(--c-primary);
	background: var(--c-bg-soft);
}
.dg-callout--tip     { border-left-color: var(--c-success); background: rgba(30, 122, 85, 0.05); }
.dg-callout--warning { border-left-color: var(--c-warning); background: rgba(201, 126, 27, 0.06); }
.dg-callout--success { border-left-color: var(--c-success); background: rgba(30, 122, 85, 0.05); }
.dg-callout__icon {
	flex-shrink: 0;
	width: 40px;
	height: 40px;
	border-radius: 8px;
	background: var(--c-bg);
	color: var(--c-primary);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--c-border);
}
.dg-callout__icon svg { width: 22px; height: 22px; }
.dg-callout--tip .dg-callout__icon     { color: var(--c-success); }
.dg-callout--warning .dg-callout__icon { color: var(--c-warning); }
.dg-callout__body { flex: 1; }
.dg-callout__body p:last-child { margin-bottom: 0; }
.dg-callout__title { margin: 0 0 var(--space-2); font-size: 1.05rem; color: var(--c-primary); }
.dg-callout--tip .dg-callout__title     { color: var(--c-success); }
.dg-callout--warning .dg-callout__title { color: var(--c-warning); }

/* ---------- Step lists ---------- */
.dg-steps {
	list-style: none;
	padding: 0;
	margin: var(--space-6) 0;
	counter-reset: dgstep;
}
.dg-step {
	display: flex;
	gap: var(--space-4);
	padding: var(--space-4) 0;
	counter-increment: dgstep;
	border-bottom: 1px solid var(--c-border-soft);
}
.dg-step:last-child { border-bottom: 0; }
.dg-step__icon {
	flex-shrink: 0;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background: var(--c-primary-tint);
	color: var(--c-primary);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	position: relative;
}
.dg-step__icon svg { width: 22px; height: 22px; }
.dg-step__icon::after {
	content: counter(dgstep);
	position: absolute;
	right: -4px;
	bottom: -4px;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	background: var(--c-primary);
	color: #FFFFFF;
	font-size: 0.72rem;
	font-weight: 600;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 2px solid var(--c-bg);
}
.dg-step__body { flex: 1; padding-top: 0.25rem; }
.dg-step__title { margin: 0 0 var(--space-2); font-size: 1.08rem; }
.dg-step__body p:last-child { margin-bottom: 0; }

/* ---------- Facts grid (key numbers) ---------- */
.dg-facts {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-4);
	margin: var(--space-6) 0;
	padding: var(--space-5);
	background: var(--c-bg-soft);
	border-radius: var(--radius-md);
}
@media (max-width: 700px) { .dg-facts { grid-template-columns: 1fr; gap: var(--space-3); } }
.dg-fact { text-align: center; }
.dg-fact__number {
	font-size: 2.4rem;
	font-weight: 700;
	color: var(--c-primary);
	line-height: 1.05;
	letter-spacing: -0.02em;
	margin-bottom: 0.25rem;
}
.dg-fact__label { font-size: 0.88rem; color: var(--c-text-muted); }

/* ---------- Lawyer page (vita) ---------- */
.dg-vita {
	display: grid;
	grid-template-columns: 220px 1fr;
	gap: var(--space-6);
	align-items: start;
	margin-bottom: var(--space-7);
}
@media (max-width: 700px) { .dg-vita { grid-template-columns: 1fr; text-align: center; } }
.dg-vita__photo {
	width: 220px;
	height: 220px;
	border-radius: 50%;
	object-fit: cover;
	border: 1px solid var(--c-border);
}
@media (max-width: 700px) { .dg-vita__photo { margin: 0 auto; } }
.dg-vita__role {
	color: var(--c-primary-soft);
	font-weight: 500;
	margin-bottom: var(--space-3);
	font-size: 1.05rem;
}
.dg-vita__chips { display: flex; flex-wrap: wrap; gap: 0.4rem; margin-bottom: var(--space-4); }
.dg-vita__chip {
	display: inline-block;
	background: var(--c-primary-tint);
	color: var(--c-primary);
	padding: 0.2rem 0.7rem;
	border-radius: 99px;
	font-size: 0.82rem;
	font-weight: 500;
}

.dg-cv {
	margin: var(--space-6) 0;
}
.dg-cv__item {
	display: grid;
	grid-template-columns: 110px 1fr;
	gap: var(--space-4);
	padding: var(--space-3) 0;
	border-bottom: 1px solid var(--c-border-soft);
}
.dg-cv__when { color: var(--c-text-muted); font-size: 0.92rem; font-weight: 500; }
.dg-cv__what { font-size: 0.97rem; }
@media (max-width: 600px) { .dg-cv__item { grid-template-columns: 1fr; gap: 0.25rem; } }

/* ---------- Lawyer cards (preview on About) ---------- */
.dg-lawyer-cards {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-5);
	margin: var(--space-6) 0 var(--space-7);
}
@media (max-width: 900px) { .dg-lawyer-cards { grid-template-columns: 1fr; gap: var(--space-5); } }

.dg-lawyer-card {
	display: flex;
	flex-direction: column;
	background: var(--c-bg);
	border: 1px solid var(--c-border);
	border-radius: var(--radius-md);
	overflow: hidden;
	text-decoration: none;
	color: var(--c-primary);
	transition: border-color 0.15s, transform 0.15s, box-shadow 0.15s;
	box-shadow: var(--shadow-sm);
}
.dg-lawyer-card:hover {
	border-color: var(--c-primary);
	transform: translateY(-3px);
	box-shadow: var(--shadow-md);
	text-decoration: none;
}
.dg-lawyer-card__photo-wrap {
	width: 100%;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: var(--c-bg-soft);
}
.dg-lawyer-card__photo {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.4s;
}
.dg-lawyer-card:hover .dg-lawyer-card__photo { transform: scale(1.03); }

.dg-lawyer-card__body {
	padding: var(--space-5);
	display: flex;
	flex-direction: column;
	flex: 1;
}
.dg-lawyer-card__name {
	display: block;
	font-size: 1.45rem;
	font-weight: 600;
	letter-spacing: -0.01em;
	margin-bottom: 0.35rem;
	color: var(--c-primary);
}
.dg-lawyer-card__role {
	display: block;
	color: var(--c-primary-soft);
	font-size: 0.92rem;
	font-weight: 500;
	margin-bottom: var(--space-3);
}
.dg-lawyer-card__bio {
	display: block;
	color: var(--c-text-muted);
	font-size: 0.95rem;
	line-height: 1.55;
	margin-bottom: var(--space-4);
	flex: 1;
}
.dg-lawyer-card__more {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	font-weight: 500;
	font-size: 0.95rem;
	color: var(--c-primary);
	border-top: 1px solid var(--c-border-soft);
	padding-top: var(--space-3);
	margin-top: auto;
}
.dg-lawyer-card__more::after { content: "→"; transition: transform 0.15s; }
.dg-lawyer-card:hover .dg-lawyer-card__more::after { transform: translateX(3px); }

/* ---------- WP-specific bits ---------- */
.alignleft { float: left; margin: 0 var(--space-5) var(--space-3) 0; }
.alignright { float: right; margin: 0 0 var(--space-3) var(--space-5); }
.aligncenter { display: block; margin-left: auto; margin-right: auto; }
.wp-caption { max-width: 100%; }
.wp-caption-text, .gallery-caption { font-size: 0.88rem; color: var(--c-text-muted); text-align: center; }
.screen-reader-text { position: absolute; left: -9999px; }

/* Pagination */
.dg-pagination, .pagination { margin: var(--space-6) 0; text-align: center; }
.dg-pagination .page-numbers, .pagination .page-numbers {
	display: inline-block;
	padding: var(--space-2) var(--space-3);
	margin: 0 2px;
	color: var(--c-primary);
	text-decoration: none;
	border: 1px solid var(--c-border);
	border-radius: var(--radius-sm);
}
.dg-pagination .current, .pagination .current { background: var(--c-primary); color: white; border-color: var(--c-primary); }
