.container,
.site-header__top-inner,
.site-header__inner,
.site-footer__inner {
	margin-inline: auto;
	max-width: var(--container-max);
	padding-inline: var(--container-padding);
	width: 100%;
}

.site-header {
	background: var(--color-surface);
	border-bottom: 1px solid var(--color-border);
	position: sticky;
	top: 0;
	transition: box-shadow 0.2s ease;
	z-index: 1000;
}

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

.site-header__top {
	background: var(--color-primary);
	color: var(--color-surface);
	display: none;
	font-size: 0.875rem;
}

.site-header__top-inner {
	align-items: center;
	display: flex;
	gap: 1rem;
	justify-content: space-between;
	min-height: 40px;
}

.site-header__benefits {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin: 0;
}

.site-header__contact {
	align-items: center;
	display: flex;
	gap: 1rem;
	white-space: nowrap;
}

.site-header__contact a {
	color: var(--color-surface);
	font-weight: 700;
	text-decoration: none;
	transition: color 0.2s ease;
}

.site-header__contact a:hover,
.site-header__contact a:focus {
	color: var(--color-accent);
}

.site-header__main {
	background: color-mix(in srgb, var(--color-surface) 94%, transparent);
	backdrop-filter: blur(14px);
}

.site-header__inner {
	align-items: center;
	display: flex;
	gap: 1rem;
	justify-content: space-between;
	min-height: 60px;
	padding-block: 0.75rem;
	transition: min-height 0.2s ease, padding-block 0.2s ease;
}

.site-header.is-scrolled .site-header__inner {
	min-height: 60px;
	padding-block: 0.5rem;
}

.site-branding {
	flex: 0 0 auto;
}

.site-logo {
	display: inline-flex;
	line-height: 0;
	text-decoration: none;
}

.site-logo img {
	max-width: min(180px, 48vw);
	width: 180px;
}

.site-navigation {
	display: none;
}

.primary-menu,
.footer-navigation ul {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 1rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.primary-menu {
	align-items: center;
	gap: 0.25rem;
}

.primary-menu > li {
	position: relative;
}

.site-navigation a,
.footer-navigation a {
	font-weight: 600;
	text-decoration: none;
}

.site-navigation a {
	color: var(--color-text);
	display: inline-flex;
	padding: 0.7rem 0.55rem;
	position: relative;
	transition: color 0.2s ease;
}

.site-navigation a::after {
	background: var(--color-accent);
	border-radius: var(--radius-full);
	bottom: 0.45rem;
	content: "";
	height: 2px;
	left: 0.55rem;
	position: absolute;
	right: 0.55rem;
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 0.2s ease;
}

.site-navigation a:hover,
.site-navigation a:focus,
.site-navigation a.is-active,
.site-navigation a[aria-current="page"] {
	color: var(--color-primary);
}

.site-navigation a:hover::after,
.site-navigation a:focus::after,
.site-navigation a.is-active::after,
.site-navigation a[aria-current="page"]::after {
	transform: scaleX(1);
}

.site-navigation .has-dropdown::before {
	content: "";
}

.site-navigation .has-dropdown {
	align-items: center;
	gap: 0.35rem;
}

.site-navigation .has-dropdown::before {
	border-color: currentcolor transparent transparent;
	border-style: solid;
	border-width: 5px 4px 0;
	content: "";
	order: 2;
	transform: translateY(1px);
	transition: transform 0.2s ease;
}

.site-navigation .menu-item-has-children.is-open > .has-dropdown::before,
.site-navigation .menu-item-has-children:hover > .has-dropdown::before,
.site-navigation .menu-item-has-children:focus-within > .has-dropdown::before {
	transform: rotate(180deg) translateY(-1px);
}

.sub-menu {
	background: color-mix(in srgb, var(--color-surface) 94%, transparent);
	backdrop-filter: blur(18px);
	border: 1px solid color-mix(in srgb, var(--color-border) 70%, transparent);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-lg);
	display: grid;
	gap: 0.15rem;
	left: 50%;
	list-style: none;
	margin: 0;
	min-width: 300px;
	opacity: 0;
	padding: 0.65rem;
	pointer-events: none;
	position: absolute;
	top: calc(100% + 0.75rem);
	transform: translate(-50%, 8px);
	transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s ease;
	visibility: hidden;
}

.menu-item-has-children.is-open > .sub-menu,
.menu-item-has-children:hover > .sub-menu,
.menu-item-has-children:focus-within > .sub-menu {
	opacity: 1;
	pointer-events: auto;
	transform: translate(-50%, 0);
	visibility: visible;
}

.sub-menu a {
	border-radius: var(--radius-sm);
	display: block;
	padding: 0.65rem 0.75rem;
}

.sub-menu a::after {
	display: none;
}

.sub-menu a:hover,
.sub-menu a:focus {
	background: var(--color-accent-light);
	color: var(--color-primary);
}

.sub-menu__all {
	color: var(--color-primary) !important;
	font-weight: 800 !important;
}

.site-header__actions {
	align-items: center;
	display: flex;
	gap: 0.75rem;
}

.site-header__cta {
	display: none;
}

.menu-toggle {
	align-items: center;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	cursor: pointer;
	display: inline-flex;
	flex-direction: column;
	gap: 5px;
	height: 44px;
	justify-content: center;
	padding: 0;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	width: 44px;
}

.menu-toggle:hover,
.menu-toggle:focus {
	border-color: var(--color-primary);
	box-shadow: var(--shadow-sm);
}

.menu-toggle span {
	background: var(--color-primary);
	border-radius: var(--radius-full);
	display: block;
	height: 2px;
	transition: opacity 0.2s ease, transform 0.2s ease;
	width: 22px;
}

.menu-toggle.is-active span:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}

.menu-toggle.is-active span:nth-child(2) {
	opacity: 0;
}

.menu-toggle.is-active span:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

.mobile-menu {
	background: var(--color-surface);
	border-top: 1px solid var(--color-border);
	box-shadow: var(--shadow-lg);
	left: 0;
	max-height: calc(100vh - 60px);
	overflow: auto;
	padding: 1rem var(--container-padding) 1.5rem;
	position: absolute;
	right: 0;
	top: 100%;
	transform-origin: top;
	transition: opacity 0.2s ease, transform 0.2s ease;
}

.mobile-menu[hidden] {
	display: none;
}

.mobile-menu ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.mobile-menu a,
.mobile-submenu-toggle {
	align-items: center;
	background: transparent;
	border: 0;
	border-bottom: 1px solid var(--color-border);
	color: var(--color-text);
	display: flex;
	font-weight: 700;
	justify-content: space-between;
	padding: 1rem 0;
	text-align: left;
	text-decoration: none;
	transition: color 0.2s ease;
	width: 100%;
}

.mobile-menu a:hover,
.mobile-menu a:focus,
.mobile-menu a.is-active,
.mobile-submenu-toggle:hover,
.mobile-submenu-toggle:focus {
	color: var(--color-primary);
}

.mobile-submenu-toggle::after {
	content: "+";
	font-size: 1.25rem;
}

.mobile-submenu-toggle[aria-expanded="true"]::after {
	content: "−";
}

.mobile-sub-menu {
	background: var(--color-bg);
	border-radius: var(--radius-sm);
	margin-block: 0.5rem 0.75rem !important;
	padding-inline: 1rem !important;
}

.mobile-sub-menu[hidden] {
	display: none;
}

.mobile-sub-menu a {
	font-weight: 600;
	padding: 0.75rem 0;
}

.mobile-menu__contact {
	display: grid;
	gap: 1rem;
	padding-block-start: 1rem;
}

.mobile-menu__contact > a:first-child {
	border: 0;
	color: var(--color-primary);
	display: inline-flex;
	font-size: 1.1rem;
	justify-content: center;
	padding: 0.25rem 0;
}

.site-main {
	padding-block: clamp(2rem, 6vw, 5rem);
}

.archive-header {
	margin-block-end: 1.5rem;
}

.footer-cta {
	background:
		linear-gradient(135deg, rgba(27, 58, 107, 0.96), rgba(17, 34, 64, 0.98)),
		var(--color-primary);
	color: var(--color-surface);
	margin-block-start: clamp(2rem, 6vw, 5rem);
}

.footer-cta__inner {
	align-items: center;
	display: grid;
	gap: 1.5rem;
	margin-inline: auto;
	max-width: var(--container-max);
	padding: clamp(2rem, 6vw, 4rem) var(--container-padding);
	width: 100%;
}

.footer-cta h2 {
	color: var(--color-surface);
	font-size: clamp(1.75rem, 4vw, 2.75rem);
	margin-block-end: 0.5rem;
}

.footer-cta p {
	color: rgba(255, 255, 255, 0.86);
	font-size: 1.075rem;
	margin: 0;
	max-width: 58ch;
}

.footer-cta__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.85rem;
}

.button--outline-light {
	background: transparent;
	border: 1px solid rgba(255, 255, 255, 0.74);
	color: var(--color-surface);
}

.button--outline-light:hover,
.button--outline-light:focus {
	background: var(--color-surface);
	color: var(--color-primary);
}

.site-footer {
	background: #10284d;
	color: rgba(255, 255, 255, 0.82);
}

.site-footer__inner {
	margin-inline: auto;
	max-width: var(--container-max);
	padding: clamp(2.5rem, 6vw, 4.5rem) var(--container-padding) 1.25rem;
	width: 100%;
}

.site-footer__grid {
	display: grid;
	gap: 2rem;
	grid-template-columns: 1fr;
}

.footer-column h2 {
	color: var(--color-surface);
	font-size: 1rem;
	margin-block-end: 1rem;
}

.footer-company__text {
	max-width: 28ch;
}

.footer-logo {
	display: inline-flex;
	line-height: 0;
	margin-block-end: 1rem;
}

.footer-logo img {
	max-width: 180px;
	width: 180px;
}

.footer-address {
	color: rgba(255, 255, 255, 0.82);
	font-style: normal;
	line-height: 1.75;
	margin-block: 1rem;
}

.footer-badges {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.footer-badges span {
	border: 1px solid rgba(255, 255, 255, 0.28);
	border-radius: var(--radius-full);
	color: var(--color-surface);
	font-size: 0.8rem;
	font-weight: 700;
	padding: 0.35rem 0.7rem;
}

.footer-navigation ul {
	display: grid;
	gap: 0.55rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.site-footer p {
	margin-block-end: 0.9rem;
}

.site-footer a {
	color: rgba(255, 255, 255, 0.86);
	text-decoration: none;
	transition: color 0.2s ease;
}

.site-footer a:hover,
.site-footer a:focus {
	color: var(--color-accent);
}

.footer-phone {
	color: var(--color-surface) !important;
	display: inline-flex;
	font-family: var(--font-heading);
	font-size: 1.35rem;
	font-weight: 800;
	margin-block-end: 0.9rem;
}

.footer-whatsapp {
	align-items: center;
	background: rgba(255, 255, 255, 0.09);
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: var(--radius-full);
	color: var(--color-surface) !important;
	display: inline-flex;
	font-weight: 800;
	margin-block-end: 0.5rem;
	padding: 0.65rem 0.9rem;
}

.footer-whatsapp:hover,
.footer-whatsapp:focus {
	background: var(--color-accent);
	color: var(--color-text) !important;
}

.footer-privacy-note {
	color: rgba(255, 255, 255, 0.62);
	font-size: 0.85rem;
}

.site-footer__bottom {
	align-items: center;
	border-top: 1px solid rgba(255, 255, 255, 0.14);
	display: grid;
	gap: 0.75rem;
	margin-block-start: clamp(2rem, 5vw, 3.5rem);
	padding-block-start: 1.25rem;
}

.site-footer__bottom p {
	margin: 0;
}

.site-footer__bottom nav {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem 1rem;
}

.site-footer__credit {
	color: rgba(255, 255, 255, 0.58);
	font-size: 0.9rem;
}

.legal-page {
	background: var(--color-bg);
	padding-block: 0;
}

.legal-hero {
	background: var(--color-surface);
	border-bottom: 1px solid var(--color-border);
}

.legal-hero__inner,
.legal-layout {
	margin-inline: auto;
	max-width: var(--container-max);
	padding-inline: var(--container-padding);
	width: 100%;
}

.legal-hero__inner {
	padding-block: clamp(2.5rem, 6vw, 4.5rem);
}

.legal-eyebrow {
	color: var(--color-primary);
	font-size: 0.85rem;
	font-weight: 800;
	letter-spacing: 0.08em;
	margin-block: 0 0.75rem;
	text-transform: uppercase;
}

.legal-hero h1 {
	font-size: clamp(2rem, 5vw, 3.5rem);
	margin: 0;
	max-width: 850px;
}

.legal-content-section {
	padding-block: clamp(2rem, 6vw, 4rem);
}

.legal-layout {
	display: grid;
	gap: clamp(1.5rem, 4vw, 3rem);
}

.legal-content {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-sm);
	padding: clamp(1.25rem, 4vw, 2.5rem);
}

.legal-content > *:first-child {
	margin-block-start: 0;
}

.legal-content h2 {
	border-top: 1px solid var(--color-border);
	font-size: clamp(1.35rem, 3vw, 1.85rem);
	margin-block-start: 2rem;
	padding-block-start: 1.5rem;
}

.legal-content h2:first-child {
	border-top: 0;
	margin-block-start: 0;
	padding-block-start: 0;
}

.legal-content p,
.legal-content li {
	color: var(--color-text-secondary);
}

.legal-content ul,
.legal-content ol {
	padding-inline-start: 1.25rem;
}

.legal-sidebar {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-sm);
	padding: 1.25rem;
}

.legal-sidebar h2 {
	font-size: 1rem;
	margin-block-end: 1rem;
}

.legal-sidebar dl {
	display: grid;
	gap: 1rem;
	margin: 0 0 1rem;
}

.legal-sidebar dt {
	color: var(--color-text-secondary);
	font-size: 0.85rem;
	font-weight: 700;
}

.legal-sidebar dd {
	color: var(--color-text);
	font-weight: 800;
	margin: 0.2rem 0 0;
}

.legal-sidebar p {
	color: var(--color-text-secondary);
	font-size: 0.9rem;
	margin: 0;
}

.contact-page {
	padding-block: 0;
}

.contact-hero {
	background:
		linear-gradient(135deg, rgba(27, 58, 107, 0.94), rgba(17, 34, 64, 0.94)),
		var(--color-primary);
	color: var(--color-surface);
	overflow: hidden;
	padding-block: clamp(3rem, 7vw, 6rem);
}

.contact-hero__inner {
	display: grid;
	gap: 1.5rem;
}

.contact-eyebrow {
	color: var(--color-accent);
	font-size: 0.85rem;
	font-weight: 800;
	letter-spacing: 0.08em;
	margin-block: 0 0.75rem;
	text-transform: uppercase;
}

.contact-hero h1 {
	color: var(--color-surface);
	font-size: clamp(2.2rem, 6vw, 4.2rem);
	max-width: 850px;
}

.contact-hero p {
	color: rgba(255, 255, 255, 0.82);
	max-width: 62ch;
}

.contact-card,
.callback-form {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-lg);
	color: var(--color-text);
	padding: clamp(1.25rem, 4vw, 2rem);
}

.contact-card {
	display: grid;
	gap: 0.6rem;
}

.contact-card a {
	color: var(--color-primary);
	font-weight: 800;
	text-decoration: none;
}

.contact-card__phone {
	font-family: var(--font-heading);
	font-size: clamp(1.45rem, 4vw, 2.2rem);
}

.callback-section {
	padding-block: clamp(2.5rem, 6vw, 5rem);
}

.callback-layout {
	display: grid;
	gap: 1.5rem;
}

.callback-copy h2 {
	font-size: clamp(1.9rem, 4vw, 3rem);
}

.callback-copy p {
	color: var(--color-text-secondary);
	max-width: 58ch;
}

.callback-form {
	display: grid;
	gap: 1rem;
}

.callback-form label {
	display: grid;
	gap: 0.45rem;
	font-weight: 700;
}

.callback-form input,
.callback-form select,
.callback-form textarea {
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	font: inherit;
	min-height: 44px;
	padding: 0.75rem 0.85rem;
}

.callback-form input:focus,
.callback-form select:focus,
.callback-form textarea:focus {
	border-color: var(--color-border-focus);
	box-shadow: 0 0 0 3px rgba(27, 58, 107, 0.14);
	outline: none;
}

.callback-status {
	border-radius: var(--radius-sm);
	font-weight: 700;
	padding: 0;
}

.callback-status.is-info,
.callback-status.is-success,
.callback-status.is-error {
	padding: 0.8rem 1rem;
}

.callback-status.is-info {
	background: var(--color-accent-light);
	color: var(--color-text);
}

.callback-status.is-success {
	background: #dcfce7;
	color: #166534;
}

.callback-status.is-error {
	background: #fee2e2;
	color: #991b1b;
}

.callback-teaser {
	background: var(--color-bg-warm);
	padding-block: clamp(2.5rem, 6vw, 4.5rem);
}

.callback-teaser__inner {
	align-items: center;
	display: grid;
	gap: clamp(1.5rem, 4vw, 3rem);
}

.callback-teaser__copy {
	max-width: 660px;
}

.callback-teaser__eyebrow {
	color: var(--color-primary);
	font-size: 0.85rem;
	font-weight: 900;
	letter-spacing: 0.08em;
	margin-block-end: 0.7rem;
	text-transform: uppercase;
}

.callback-teaser h2 {
	font-size: clamp(1.8rem, 4vw, 3rem);
}

.callback-teaser p {
	color: var(--color-text-secondary);
}

.callback-form--compact {
	box-shadow: var(--shadow-md);
}

.contact-rail {
	display: none;
}

.mobile-contact-dock {
	background: rgba(255, 255, 255, 0.94);
	backdrop-filter: blur(16px);
	border: 1px solid var(--color-border);
	border-radius: 18px;
	box-shadow: 0 10px 34px rgba(27, 58, 107, 0.14);
	display: grid;
	gap: 0.38rem;
	grid-template-columns: 1fr;
	padding: 0.4rem;
	position: fixed;
	right: max(0.45rem, env(safe-area-inset-right));
	top: 50%;
	transform: translateY(-50%);
	z-index: 1200;
}

.mobile-contact-dock a {
	align-items: center;
	background: transparent;
	border-radius: 14px;
	color: var(--color-primary);
	display: inline-grid;
	font-size: 0.68rem;
	font-weight: 900;
	gap: 0.16rem;
	justify-content: center;
	line-height: 1.1;
	min-height: 54px;
	padding: 0.42rem 0.35rem;
	text-align: center;
	text-decoration: none;
	transition: transform 0.2s ease, background 0.2s ease, color 0.2s ease;
	width: 64px;
}

.contact-action__icon {
	align-items: center;
	display: inline-flex;
	justify-content: center;
	line-height: 0;
}

.contact-action__icon svg {
	display: block;
	fill: none;
	height: 1.35em;
	stroke: currentColor;
	stroke-linecap: round;
	stroke-linejoin: round;
	stroke-width: 1.9;
	width: 1.35em;
}

.mobile-contact-dock a:nth-child(2) {
	background: linear-gradient(135deg, var(--color-accent), #ffc25a);
	box-shadow: 0 5px 14px rgba(245, 166, 35, 0.24);
	color: var(--color-text);
}

.mobile-contact-dock a:nth-child(4) {
	background: rgba(22, 101, 52, 0.09);
	color: #166534;
}

.mobile-contact-dock a:hover,
.mobile-contact-dock a:focus-visible {
	background: rgba(27, 58, 107, 0.08);
	transform: translateX(-2px);
}

body {
	padding-bottom: 0;
}

@media (min-width: 640px) {
	.site-footer__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.mobile-contact-dock {
		right: max(0.75rem, env(safe-area-inset-right));
	}

	.mobile-contact-dock a {
		font-size: 0.72rem;
		min-height: 58px;
		width: 76px;
	}
}

@media (min-width: 980px) {
	.site-header__top {
		display: block;
	}

	.footer-cta__inner {
		grid-template-columns: minmax(0, 1fr) auto;
	}

	.footer-cta__actions {
		justify-content: flex-end;
	}

	.site-footer__grid {
		grid-template-columns: 1.35fr 1fr 0.85fr 1fr;
	}

	.site-footer__bottom {
		grid-template-columns: 1fr auto auto;
	}

	.legal-layout {
		align-items: start;
		grid-template-columns: minmax(0, 1fr) minmax(240px, 300px);
	}

	.contact-hero__inner,
	.callback-layout,
	.callback-teaser__inner {
		align-items: center;
		grid-template-columns: minmax(0, 1fr) minmax(320px, 440px);
	}

	.legal-sidebar {
		position: sticky;
		top: 110px;
	}

	.site-header__inner {
		min-height: 80px;
	}

	.site-header.is-scrolled .site-header__inner {
		min-height: 68px;
	}

	.site-navigation {
		display: block;
	}

	.site-header__cta {
		display: inline-flex;
		white-space: nowrap;
	}

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

@media (min-width: 1780px) {
	body {
		padding-bottom: 0;
	}

	.mobile-contact-dock {
		display: none;
	}

	.contact-rail {
		display: block;
		max-height: calc(100vh - 190px);
		overflow: auto;
		position: fixed;
		right: clamp(1rem, 2.2vw, 2.5rem);
		scrollbar-width: thin;
		top: 172px;
		width: min(320px, calc((100vw - var(--container-max)) / 2 - 2rem));
		z-index: 900;
	}

	.admin-bar .contact-rail {
		top: 204px;
	}

	.contact-rail__form {
		gap: 0.8rem;
		padding: 1.1rem;
	}

	.contact-rail__eyebrow {
		color: var(--color-primary);
		font-size: 0.72rem;
		font-weight: 900;
		letter-spacing: 0.08em;
		margin: 0;
		text-transform: uppercase;
	}

	.contact-rail h2 {
		font-size: 1.35rem;
		margin: -0.35rem 0 0;
	}

	.contact-rail__intro {
		color: var(--color-text-secondary);
		font-size: 0.9rem;
		margin: -0.25rem 0 0.1rem;
	}

	.contact-rail .callback-form label {
		font-size: 0.88rem;
	}

	.contact-rail .callback-form input,
	.contact-rail .callback-form select {
		min-height: 42px;
		padding: 0.65rem 0.75rem;
	}

	.contact-rail__submit {
		min-height: 44px;
		width: 100%;
	}

	.contact-rail__actions {
		display: grid;
		gap: 0.55rem;
		margin-top: 0.75rem;
	}

	.contact-rail__button {
		align-items: center;
		border: 1px solid transparent;
		border-radius: var(--radius-full);
		box-shadow: 0 5px 16px rgba(27, 58, 107, 0.08);
		display: inline-flex;
		gap: 0.5rem;
		font-weight: 900;
		justify-content: center;
		min-height: 44px;
		padding: 0.68rem 1rem;
		text-align: center;
		text-decoration: none;
		transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
	}

	.contact-rail__button:hover,
	.contact-rail__button:focus-visible {
		box-shadow: 0 10px 22px rgba(27, 58, 107, 0.14);
		transform: translateY(-2px);
	}

	.contact-rail__button--accent {
		background: linear-gradient(135deg, var(--color-accent), #ffc25a);
		color: var(--color-text);
	}

	.contact-rail__button--outline {
		background: var(--color-surface);
		border-color: rgba(27, 58, 107, 0.22);
		color: var(--color-primary);
	}

	.contact-rail__button--whatsapp {
		background: rgba(22, 101, 52, 0.09);
		border-color: rgba(22, 101, 52, 0.16);
		color: #166534;
	}
}
