.ao-works-canvas-gallery-links {
	--ao-works-bg: #080808;
	--ao-works-panel: rgba(24, 28, 32, 0.88);
	--ao-works-text: #ffffff;
	--ao-works-muted: rgba(255, 255, 255, 0.74);
	--ao-works-accent: #e45d5d;
	--ao-works-shadow: rgba(0, 0, 0, 0.44);
	--ao-works-card-overlay: rgba(0, 0, 0, 0.62);
	--ao-works-viewer-overlay: rgba(0, 0, 0, 0.42);
	--ao-works-button-bg: rgba(0, 0, 0, 0.50);
	--ao-works-button-color: #ffffff;
	--ao-works-grid-min-height: 640px;
	--ao-works-viewer-height: 780px;
	--ao-works-thumbs-below-height: 120px;
	--ao-works-thumbs-below-bg: #000000;

	position: relative;
	width: 100%;
	min-height: var(--ao-works-grid-min-height);
	background: var(--ao-works-bg);
	color: var(--ao-works-text);
	overflow: hidden;
}

.ao-works-canvas-gallery-links.is-viewing {
	height: var(--ao-works-viewer-height);
	min-height: var(--ao-works-viewer-height);
}


.ao-works-canvas-gallery-links.ao-works-canvas-gallery-links--direct {
	height: var(--ao-works-viewer-height);
	min-height: var(--ao-works-viewer-height);
}

.ao-works-canvas-gallery-links.ao-works-canvas-gallery-links--direct .ao-works-canvas-gallery-links__grid {
	display: none;
}

.ao-works-canvas-gallery-links.ao-works-canvas-gallery-links--direct .ao-works-canvas-gallery-links__back {
	display: none;
}

.ao-works-canvas-gallery-links *,
.ao-works-canvas-gallery-links *::before,
.ao-works-canvas-gallery-links *::after {
	box-sizing: border-box;
}

.ao-works-canvas-gallery-links__empty {
	margin: 0;
	padding: 28px;
	color: #fff;
}

.ao-works-canvas-gallery-links__grid {
	display: grid;
	grid-template-columns: repeat(6, minmax(0, 1fr));
	grid-auto-rows: var(--ao-works-card-height, 220px);
	align-items: stretch;
	gap: 6px;
	width: 100%;
	transition: opacity 260ms ease, visibility 260ms ease;
}

.ao-works-canvas-gallery-links.is-viewing .ao-works-canvas-gallery-links__grid {
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
}

.ao-works-canvas-gallery-links__card {
	position: relative;
	display: block;
	width: 100%;
	height: 100%;
	min-height: var(--ao-works-card-height, 220px);
	padding: 0;
	border: 0;
	border-radius: 0;
	background: #111;
	overflow: hidden;
	cursor: pointer;
}

.ao-works-canvas-gallery-links__card-image {
	position: absolute;
	inset: 0;
	display: block;
	width: 100%;
	height: 100%;
	min-width: 100%;
	min-height: 100%;
	max-width: none;
	border: 0;
	margin: 0;
	padding: 0;
	object-fit: cover;
	object-position: center;
	transition: transform 520ms ease, filter 520ms ease;
}

.ao-works-canvas-gallery-links__card::after {
	content: "";
	position: absolute;
	inset: 0;
	background: var(--ao-works-card-overlay);
	opacity: 0;
	transition: opacity 260ms ease;
}

.ao-works-canvas-gallery-links__card-title {
	position: absolute;
	left: 50%;
	top: 50%;
	z-index: 2;
	width: calc(100% - 44px);
	max-width: 420px;
	color: #fff;
	font-size: 15px;
	line-height: 1.15;
	font-weight: 800;
	text-align: center;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	opacity: 0;
	transform: translate(-50%, -42%);
	transition: opacity 260ms ease, transform 260ms ease;
}

.ao-works-canvas-gallery-links__card:hover .ao-works-canvas-gallery-links__card-image,
.ao-works-canvas-gallery-links__card:focus-visible .ao-works-canvas-gallery-links__card-image {
	transform: scale(1.04);
	filter: brightness(0.82);
}

.ao-works-canvas-gallery-links__card:hover::after,
.ao-works-canvas-gallery-links__card:focus-visible::after {
	opacity: 1;
}

.ao-works-canvas-gallery-links__card:hover .ao-works-canvas-gallery-links__card-title,
.ao-works-canvas-gallery-links__card:focus-visible .ao-works-canvas-gallery-links__card-title {
	opacity: 1;
	transform: translate(-50%, -50%);
}

.ao-works-canvas-gallery-links__viewer {
	position: absolute;
	inset: 0;
	z-index: 5;
	width: 100%;
	height: 100%;
	min-height: var(--ao-works-viewer-height);
	background: #050505;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: opacity 280ms ease, visibility 280ms ease;
}

.ao-works-canvas-gallery-links.is-viewing .ao-works-canvas-gallery-links__viewer {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
}

.ao-works-canvas-gallery-links__stage {
	position: absolute;
	inset: 0;
	z-index: 1;
	overflow: hidden;
	background: #050505;
}

.ao-works-canvas-gallery-links__slide {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	opacity: 0;
	transform: scale(1.02);
	transition: opacity 430ms ease, transform 430ms ease;
}

.ao-works-canvas-gallery-links__slide.is-active {
	opacity: 1;
	transform: scale(1);
	z-index: 2;
}

.ao-works-canvas-gallery-links__slide-image {
	position: absolute;
	inset: 0;
	display: block;
	width: 100%;
	height: 100%;
	min-width: 100%;
	min-height: 100%;
	max-width: none !important;
	max-height: none !important;
	border: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	object-fit: var(--ao-works-project-image-fit, cover) !important;
	object-position: center center;
	background: #050505;
}

/* Modo contain responsivo: a imagem ocupa a área do slide, mas sem cortar.
   Antes usávamos width/height auto, o que em algumas telas mantinha a imagem no tamanho
   natural/desktop e deixava grandes áreas pretas no mobile. */
.ao-works-canvas-gallery-links.ao-works-canvas-gallery-links--fit-contain .ao-works-canvas-gallery-links__slide-image,
.ao-works-canvas-gallery-links[data-project-image-fit="contain"] .ao-works-canvas-gallery-links__slide-image,
.ao-works-canvas-gallery-links .ao-works-canvas-gallery-links__slide-image.ao-works-canvas-gallery-links__slide-image--contain {
	inset: 0 !important;
	top: 0 !important;
	left: 0 !important;
	right: 0 !important;
	bottom: 0 !important;
	width: 100% !important;
	height: 100% !important;
	min-width: 100% !important;
	min-height: 100% !important;
	max-width: none !important;
	max-height: none !important;
	transform: none !important;
	object-fit: contain !important;
	object-position: center center !important;
}

.ao-works-canvas-gallery-links.ao-works-canvas-gallery-links--fit-scale-down .ao-works-canvas-gallery-links__slide-image,
.ao-works-canvas-gallery-links[data-project-image-fit="scale-down"] .ao-works-canvas-gallery-links__slide-image,
.ao-works-canvas-gallery-links .ao-works-canvas-gallery-links__slide-image.ao-works-canvas-gallery-links__slide-image--scale-down {
	inset: 0 !important;
	top: 0 !important;
	left: 0 !important;
	right: 0 !important;
	bottom: 0 !important;
	width: 100% !important;
	height: 100% !important;
	min-width: 100% !important;
	min-height: 100% !important;
	max-width: none !important;
	max-height: none !important;
	transform: none !important;
	object-fit: scale-down !important;
	object-position: center center !important;
}


.ao-works-canvas-gallery-links.ao-works-canvas-gallery-links--fit-cover .ao-works-canvas-gallery-links__slide-image {
	object-fit: cover !important;
}

.ao-works-canvas-gallery-links.ao-works-canvas-gallery-links--fit-contain .ao-works-canvas-gallery-links__slide-image {
	object-fit: contain !important;
}

.ao-works-canvas-gallery-links.ao-works-canvas-gallery-links--fit-fill .ao-works-canvas-gallery-links__slide-image {
	object-fit: fill !important;
}

.ao-works-canvas-gallery-links.ao-works-canvas-gallery-links--fit-scale-down .ao-works-canvas-gallery-links__slide-image {
	object-fit: scale-down !important;
}

.ao-works-canvas-gallery-links__viewer::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 3;
	background: linear-gradient(180deg, rgba(0, 0, 0, 0.02) 0%, var(--ao-works-viewer-overlay) 100%);
	pointer-events: none;
}

.ao-works-canvas-gallery-links__back,
.ao-works-canvas-gallery-links__info-toggle,
.ao-works-canvas-gallery-links__info-close,
.ao-works-canvas-gallery-links__arrow,
.ao-works-canvas-gallery-links__share,
.ao-works-canvas-gallery-links__contact {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid rgba(255, 255, 255, 0.24);
	background: var(--ao-works-button-bg);
	backdrop-filter: blur(10px);
	color: var(--ao-works-button-color);
	cursor: pointer;
	text-decoration: none;
	transition: background 180ms ease, border-color 180ms ease, transform 180ms ease, opacity 180ms ease;
}


/* Protege botões contra estilos globais do tema/Elementor, inclusive :active no mobile. */
.ao-works-canvas-gallery-links button,
.ao-works-canvas-gallery-links a {
	-webkit-tap-highlight-color: transparent;
}

.ao-works-canvas-gallery-links button.ao-works-canvas-gallery-links__back,
.ao-works-canvas-gallery-links button.ao-works-canvas-gallery-links__info-toggle,
.ao-works-canvas-gallery-links button.ao-works-canvas-gallery-links__info-close,
.ao-works-canvas-gallery-links button.ao-works-canvas-gallery-links__arrow,
.ao-works-canvas-gallery-links button.ao-works-canvas-gallery-links__share,
.ao-works-canvas-gallery-links a.ao-works-canvas-gallery-links__contact {
	background: var(--ao-works-button-bg) !important;
	color: var(--ao-works-button-color) !important;
	box-shadow: none;
	outline: none;
}

.ao-works-canvas-gallery-links button.ao-works-canvas-gallery-links__back:hover,
.ao-works-canvas-gallery-links button.ao-works-canvas-gallery-links__back:focus,
.ao-works-canvas-gallery-links button.ao-works-canvas-gallery-links__back:focus-visible,
.ao-works-canvas-gallery-links button.ao-works-canvas-gallery-links__back:active,
.ao-works-canvas-gallery-links button.ao-works-canvas-gallery-links__info-toggle:hover,
.ao-works-canvas-gallery-links button.ao-works-canvas-gallery-links__info-toggle:focus,
.ao-works-canvas-gallery-links button.ao-works-canvas-gallery-links__info-toggle:focus-visible,
.ao-works-canvas-gallery-links button.ao-works-canvas-gallery-links__info-toggle:active,
.ao-works-canvas-gallery-links button.ao-works-canvas-gallery-links__info-close:hover,
.ao-works-canvas-gallery-links button.ao-works-canvas-gallery-links__info-close:focus,
.ao-works-canvas-gallery-links button.ao-works-canvas-gallery-links__info-close:focus-visible,
.ao-works-canvas-gallery-links button.ao-works-canvas-gallery-links__info-close:active,
.ao-works-canvas-gallery-links button.ao-works-canvas-gallery-links__arrow:hover,
.ao-works-canvas-gallery-links button.ao-works-canvas-gallery-links__arrow:focus,
.ao-works-canvas-gallery-links button.ao-works-canvas-gallery-links__arrow:focus-visible,
.ao-works-canvas-gallery-links button.ao-works-canvas-gallery-links__arrow:active,
.ao-works-canvas-gallery-links button.ao-works-canvas-gallery-links__share:hover,
.ao-works-canvas-gallery-links button.ao-works-canvas-gallery-links__share:focus,
.ao-works-canvas-gallery-links button.ao-works-canvas-gallery-links__share:focus-visible,
.ao-works-canvas-gallery-links button.ao-works-canvas-gallery-links__share:active,
.ao-works-canvas-gallery-links a.ao-works-canvas-gallery-links__contact:hover,
.ao-works-canvas-gallery-links a.ao-works-canvas-gallery-links__contact:focus,
.ao-works-canvas-gallery-links a.ao-works-canvas-gallery-links__contact:focus-visible,
.ao-works-canvas-gallery-links a.ao-works-canvas-gallery-links__contact:active,
.ao-works-canvas-gallery-links a.ao-works-canvas-gallery-links__contact:visited {
	background: rgba(0, 0, 0, 0.80) !important;
	border-color: rgba(255, 255, 255, 0.72) !important;
	color: var(--ao-works-button-color) !important;
	box-shadow: none !important;
	outline: none !important;
}

.ao-works-canvas-gallery-links__back,
.ao-works-canvas-gallery-links__info-toggle {
	position: absolute;
	top: 24px;
	z-index: 14;
	min-width: 44px;
	height: 44px;
	padding: 0 16px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.ao-works-canvas-gallery-links__info-toggle {
	left: 24px;
}

.ao-works-canvas-gallery-links__back {
	right: 24px;
}

.ao-works-canvas-gallery-links.is-info-open .ao-works-canvas-gallery-links__info-toggle {
	opacity: 0;
	visibility: hidden;
	transform: translateX(-12px);
	pointer-events: none;
}

.ao-works-canvas-gallery-links__back:hover,
.ao-works-canvas-gallery-links__info-toggle:hover,
.ao-works-canvas-gallery-links__info-close:hover,
.ao-works-canvas-gallery-links__arrow:hover,
.ao-works-canvas-gallery-links__share:hover,
.ao-works-canvas-gallery-links__contact:hover {
	background: rgba(0, 0, 0, 0.80);
	border-color: rgba(255, 255, 255, 0.72);
	transform: translateY(-1px);
	color: var(--ao-works-button-color);
}

.ao-works-canvas-gallery-links__info {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 30;
	width: min(380px, 88vw);
	height: 100%;
	padding: 44px 34px 34px;
	background: var(--ao-works-panel);
	backdrop-filter: blur(12px);
	color: #fff;
	transform: translateX(-100%);
	transition: transform 320ms ease;
	overflow-y: auto;
	box-shadow: 26px 0 48px var(--ao-works-shadow);
}

.ao-works-canvas-gallery-links.is-info-open .ao-works-canvas-gallery-links__info {
	transform: translateX(0);
}


.ao-works-canvas-gallery-links__info-close {
	position: absolute;
	top: 18px;
	right: 18px;
	z-index: 35;
	width: 38px;
	height: 38px;
	padding: 0;
	border-radius: 999px;
	font-size: 0;
	line-height: 1;
}

.ao-works-canvas-gallery-links__info-close svg {
	width: 16px;
	height: 16px;
	fill: currentColor;
}

.ao-works-canvas-gallery-links__info-line {
	width: 34px;
	height: 2px;
	margin-bottom: 20px;
	background: var(--ao-works-accent);
}

.ao-works-canvas-gallery-links__info-title {
	margin: 0 0 5px;
	font-size: 30px;
	line-height: 0.96;
	font-weight: 900;
	letter-spacing: -0.04em;
}

.ao-works-canvas-gallery-links__info-subtitle {
	margin: 0 0 22px;
	font-size: 16px;
	line-height: 1.15;
	font-weight: 700;
	color: #fff;
}

.ao-works-canvas-gallery-links__info-location {
	margin: 0 0 28px;
	color: var(--ao-works-accent);
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.08em;
}

.ao-works-canvas-gallery-links__info-block {
	margin: 0 0 20px;
}

.ao-works-canvas-gallery-links__info-label {
	display: block;
	margin: 0 0 6px;
	color: #fff;
	font-size: 13px;
	font-weight: 800;
}

.ao-works-canvas-gallery-links__info-text {
	margin: 0;
	color: var(--ao-works-muted);
	font-size: 14px;
	line-height: 1.45;
	white-space: pre-line;
}

.ao-works-canvas-gallery-links__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 28px;
}

.ao-works-canvas-gallery-links__contact,
.ao-works-canvas-gallery-links__share {
	min-height: 38px;
	padding: 0 13px;
	border-radius: 999px;
	font-size: 11px;
	line-height: 1;
	font-weight: 900;
	letter-spacing: 0.10em;
	text-transform: uppercase;
}

.ao-works-canvas-gallery-links__contact {
	border-color: var(--ao-works-accent);
	color: var(--ao-works-button-color);
}

.ao-works-canvas-gallery-links__nav {
	position: absolute;
	left: 50%;
	bottom: var(--ao-works-thumbs-bottom, 24px);
	z-index: 12;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: calc(100% - 80px);
	transform: translateX(-50%);
	pointer-events: auto;
}

.ao-works-canvas-gallery-links__thumbs {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	max-width: calc(100% - 100px);
	overflow-x: auto;
	scrollbar-width: none;
}

.ao-works-canvas-gallery-links__nav:not(.ao-works-canvas-gallery-links__nav--has-arrows) .ao-works-canvas-gallery-links__thumbs {
	max-width: 100%;
}

.ao-works-canvas-gallery-links__arrow--side {
	position: absolute;
	top: 50%;
	z-index: 14;
	width: 48px;
	height: 48px;
	padding: 0;
	border-radius: 999px;
	transform: translateY(-50%);
}

.ao-works-canvas-gallery-links__arrow--side:hover,
.ao-works-canvas-gallery-links__arrow--side:focus-visible {
	transform: translateY(-50%) scale(1.04) !important;
}

.ao-works-canvas-gallery-links__arrow--side-prev {
	left: clamp(16px, 2.5vw, 42px);
}

.ao-works-canvas-gallery-links__arrow--side-next {
	right: clamp(16px, 2.5vw, 42px);
}

.ao-works-canvas-gallery-links__arrow--thumb {
	position: relative;
}

@media (min-width: 768px) {
	.ao-works-canvas-gallery-links.ao-works-canvas-gallery-links--arrows-mobile .ao-works-canvas-gallery-links__arrow {
		display: none !important;
	}
}


.ao-works-canvas-gallery-links__thumbs::-webkit-scrollbar {
	display: none;
}


/* =========================================================
   Thumbnails abaixo do slide
   Divide a altura total da visualização em: stage + faixa inferior.
   ========================================================= */
.ao-works-canvas-gallery-links.ao-works-canvas-gallery-links--thumbs-below .ao-works-canvas-gallery-links__viewer {
	display: flex !important;
	flex-direction: column !important;
}

.ao-works-canvas-gallery-links.ao-works-canvas-gallery-links--thumbs-below .ao-works-canvas-gallery-links__stage {
	position: relative !important;
	inset: auto !important;
	width: 100% !important;
	height: calc(100% - var(--ao-works-thumbs-below-height, 120px)) !important;
	min-height: 0 !important;
	flex: 0 0 calc(100% - var(--ao-works-thumbs-below-height, 120px)) !important;
	z-index: 1 !important;
}

.ao-works-canvas-gallery-links.ao-works-canvas-gallery-links--thumbs-below .ao-works-canvas-gallery-links__viewer::after {
	top: 0 !important;
	left: 0 !important;
	right: 0 !important;
	bottom: var(--ao-works-thumbs-below-height, 120px) !important;
	inset: 0 0 var(--ao-works-thumbs-below-height, 120px) 0 !important;
	z-index: 3 !important;
}

.ao-works-canvas-gallery-links.ao-works-canvas-gallery-links--thumbs-below .ao-works-canvas-gallery-links__nav {
	position: relative !important;
	left: auto !important;
	right: auto !important;
	bottom: auto !important;
	transform: none !important;
	z-index: 16 !important;
	width: 100% !important;
	max-width: none !important;
	height: var(--ao-works-thumbs-below-height, 120px) !important;
	flex: 0 0 var(--ao-works-thumbs-below-height, 120px) !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 10px !important;
	padding: 0 28px !important;
	margin: 0 !important;
	background: var(--ao-works-thumbs-below-bg, #000000) !important;
	overflow: hidden !important;
	pointer-events: auto !important;
}

.ao-works-canvas-gallery-links.ao-works-canvas-gallery-links--thumbs-below .ao-works-canvas-gallery-links__thumbs {
	position: relative !important;
	z-index: 17 !important;
	max-width: calc(100% - 104px) !important;
	justify-content: center !important;
}

.ao-works-canvas-gallery-links.ao-works-canvas-gallery-links--thumbs-below .ao-works-canvas-gallery-links__nav:not(.ao-works-canvas-gallery-links__nav--has-arrows) .ao-works-canvas-gallery-links__thumbs {
	max-width: 100% !important;
}

.ao-works-canvas-gallery-links.ao-works-canvas-gallery-links--thumbs-below .ao-works-canvas-gallery-links__arrow--thumb {
	z-index: 18 !important;
}

.ao-works-canvas-gallery-links.ao-works-canvas-gallery-links--thumbs-below .ao-works-canvas-gallery-links__arrow--side {
	top: calc((100% - var(--ao-works-thumbs-below-height, 120px)) / 2) !important;
}

.ao-works-canvas-gallery-links.ao-works-canvas-gallery-links--thumbs-overlay .ao-works-canvas-gallery-links__nav {
	background: transparent;
}

.ao-works-canvas-gallery-links__thumb {
	position: relative;
	flex: 0 0 auto;
	width: 72px;
	height: 52px;
	padding: 0;
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.08);
	overflow: hidden;
	cursor: pointer;
	opacity: 0.86;
}

.ao-works-canvas-gallery-links__thumb.is-active {
	border-color: rgba(255, 255, 255, 0.95);
	box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.82);
	opacity: 1;
}

.ao-works-canvas-gallery-links__thumb img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	max-width: none;
	object-fit: cover;
}

.ao-works-canvas-gallery-links__arrow {
	position: relative;
	flex: 0 0 auto;
	width: 40px;
	height: 40px;
	padding: 0;
	border-radius: 999px;
}

.ao-works-canvas-gallery-links__arrow svg {
	width: 17px;
	height: 17px;
	fill: currentColor;
}

.ao-works-canvas-gallery-links__arrow--side {
	position: absolute;
	top: 50%;
	z-index: 14;
	width: 48px;
	height: 48px;
	padding: 0;
	border-radius: 999px;
	transform: translateY(-50%);
}

.ao-works-canvas-gallery-links__arrow--side:hover,
.ao-works-canvas-gallery-links__arrow--side:focus-visible {
	transform: translateY(-50%) scale(1.04) !important;
}

.ao-works-canvas-gallery-links__arrow--side-prev {
	left: clamp(16px, 2.5vw, 42px);
}

.ao-works-canvas-gallery-links__arrow--side-next {
	right: clamp(16px, 2.5vw, 42px);
}

.ao-works-canvas-gallery-links__arrow--thumb {
	position: relative;
}

@media (max-width: 1024px) {
	.ao-works-canvas-gallery-links {
		--ao-works-grid-min-height: 560px;
		--ao-works-viewer-height: 680px;
	}

	.ao-works-canvas-gallery-links__grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.ao-works-canvas-gallery-links__grid {
		grid-auto-rows: var(--ao-works-card-height, 180px);
	}

	.ao-works-canvas-gallery-links__card {
		min-height: var(--ao-works-card-height, 180px);
	}
}

@media (max-width: 767px) {
	.ao-works-canvas-gallery-links {
		--ao-works-grid-min-height: 520px;
		--ao-works-viewer-height: 640px;
	}

	.ao-works-canvas-gallery-links__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 4px;
	}

	.ao-works-canvas-gallery-links__grid {
		grid-auto-rows: var(--ao-works-card-height, 150px);
	}

	.ao-works-canvas-gallery-links__card {
		min-height: var(--ao-works-card-height, 150px);
	}

	.ao-works-canvas-gallery-links__card-title {
		width: calc(100% - 28px);
		font-size: 12px;
		opacity: 1;
		transform: translate(-50%, -50%);
	}

	.ao-works-canvas-gallery-links__card::after {
		opacity: 0.42;
	}

	.ao-works-canvas-gallery-links__info {
		width: min(360px, 92vw);
		padding: 72px 26px 28px;
		z-index: 30;
	}

	.ao-works-canvas-gallery-links__info-title {
		font-size: 24px;
	}

	.ao-works-canvas-gallery-links__back,
	.ao-works-canvas-gallery-links__info-toggle {
		top: 16px;
		height: 40px;
		padding: 0 13px;
		font-size: 11px;
	}

	.ao-works-canvas-gallery-links__info-toggle {
		left: 16px;
	}

	.ao-works-canvas-gallery-links__back {
		right: 16px;
	}

	.ao-works-canvas-gallery-links__info-close {
		top: 18px;
		right: 18px;
		width: 38px;
		height: 38px;
		z-index: 35;
	}

	.ao-works-canvas-gallery-links__nav {
		width: calc(100% - 28px);
		bottom: var(--ao-works-thumbs-bottom, 18px);
	}

	.ao-works-canvas-gallery-links.ao-works-canvas-gallery-links--thumbs-below .ao-works-canvas-gallery-links__nav {
		width: 100% !important;
		height: var(--ao-works-thumbs-below-height, 108px) !important;
		flex-basis: var(--ao-works-thumbs-below-height, 108px) !important;
		padding: 0 14px !important;
		gap: 8px !important;
	}

	.ao-works-canvas-gallery-links.ao-works-canvas-gallery-links--thumbs-below .ao-works-canvas-gallery-links__stage {
		height: calc(100% - var(--ao-works-thumbs-below-height, 108px)) !important;
		flex-basis: calc(100% - var(--ao-works-thumbs-below-height, 108px)) !important;
	}

	.ao-works-canvas-gallery-links.ao-works-canvas-gallery-links--thumbs-below .ao-works-canvas-gallery-links__thumbs {
		justify-content: flex-start !important;
		max-width: calc(100% - 92px) !important;
	}

	.ao-works-canvas-gallery-links__thumbs {
		justify-content: flex-start;
		max-width: calc(100% - 94px);
	}

	.ao-works-canvas-gallery-links__thumb {
		width: 76px;
		height: 54px;
	}

	.ao-works-canvas-gallery-links.ao-works-canvas-gallery-links--arrows-desktop .ao-works-canvas-gallery-links__arrow {
		display: none !important;
	}

	.ao-works-canvas-gallery-links__arrow--side {
		width: 40px;
		height: 40px;
	}

	.ao-works-canvas-gallery-links__arrow--side-prev {
		left: 14px;
	}

	.ao-works-canvas-gallery-links__arrow--side-next {
		right: 14px;
	}
}

/* =========================================================
   Modo opcional: slide galeria com URL individual por imagem
   ========================================================= */
.elementor-widget-ao-works-canvas-gallery-links .ao-works-canvas-gallery-links__linked-gallery {
	position: relative;
	width: 100%;
	height: var(--ao-linked-gallery-height, 720px);
	min-height: 320px;
	overflow: hidden;
	background: #111;
}

.ao-works-canvas-gallery-links__linked-stage,
.ao-works-canvas-gallery-links__linked-slide,
.ao-works-canvas-gallery-links__linked-anchor {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
}

.ao-works-canvas-gallery-links__linked-slide {
	opacity: 0;
	visibility: hidden;
	transition: opacity .65s ease, visibility .65s ease;
	pointer-events: none;
}

.ao-works-canvas-gallery-links__linked-slide.is-active {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
}

.ao-works-canvas-gallery-links__linked-anchor {
	display: block;
	color: inherit;
	text-decoration: none;
}

.ao-works-canvas-gallery-links__linked-anchor img {
	display: block;
	width: 100% !important;
	height: 100% !important;
	max-width: none !important;
	object-fit: cover !important;
	object-position: center center !important;
}

.ao-works-canvas-gallery-links__linked-title {
	position: absolute;
	left: clamp(20px, 5vw, 72px);
	bottom: clamp(110px, 16vh, 170px);
	z-index: 3;
	max-width: min(760px, 80%);
	color: #fff;
	font-size: clamp(28px, 4vw, 68px);
	font-weight: 700;
	line-height: 1.05;
	text-shadow: 0 4px 24px rgba(0,0,0,.45);
}

.ao-works-canvas-gallery-links__linked-arrow {
	position: absolute !important;
	top: 50% !important;
	z-index: 10 !important;
	width: 52px !important;
	height: 52px !important;
	padding: 0 !important;
	border: 1px solid rgba(255,255,255,.35) !important;
	border-radius: 50% !important;
	background: rgba(0,0,0,.48) !important;
	color: #fff !important;
	font-size: 25px !important;
	line-height: 1 !important;
	transform: translateY(-50%) !important;
	cursor: pointer !important;
}

.ao-works-canvas-gallery-links__linked-arrow.is-prev { left: 24px !important; }
.ao-works-canvas-gallery-links__linked-arrow.is-next { right: 24px !important; }

.ao-works-canvas-gallery-links__linked-thumbs {
	position: absolute !important;
	left: 0 !important;
	right: 0 !important;
	bottom: 0 !important;
	z-index: 12 !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 10px !important;
	width: 100% !important;
	padding: 18px 24px !important;
	background: rgba(0,0,0,.78) !important;
	overflow-x: auto !important;
	scrollbar-width: none !important;
}

.ao-works-canvas-gallery-links__linked-thumbs::-webkit-scrollbar { display: none !important; }

.ao-works-canvas-gallery-links__linked-thumb {
	position: relative !important;
	flex: 0 0 82px !important;
	width: 82px !important;
	height: 58px !important;
	padding: 0 !important;
	border: 2px solid transparent !important;
	border-radius: 8px !important;
	background: transparent !important;
	overflow: hidden !important;
	opacity: .72 !important;
	cursor: pointer !important;
}

.ao-works-canvas-gallery-links__linked-thumb.is-active {
	border-color: #fff !important;
	opacity: 1 !important;
}

.ao-works-canvas-gallery-links__linked-thumb img {
	display: block !important;
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
}

@media (max-width: 767px) {
	.ao-works-canvas-gallery-links__linked-title {
		left: 20px;
		bottom: 100px;
		max-width: calc(100% - 40px);
	}
	.ao-works-canvas-gallery-links__linked-arrow {
		width: 42px !important;
		height: 42px !important;
	}
	.ao-works-canvas-gallery-links__linked-arrow.is-prev { left: 12px !important; }
	.ao-works-canvas-gallery-links__linked-arrow.is-next { right: 12px !important; }
	.ao-works-canvas-gallery-links__linked-thumbs {
		justify-content: flex-start !important;
		padding: 14px 12px !important;
	}
	.ao-works-canvas-gallery-links__linked-thumb {
		flex-basis: 72px !important;
		width: 72px !important;
		height: 50px !important;
	}
}


/* v2: garante que a altura responsiva da galeria seja aplicada no editor e no frontend */
.elementor-widget-ao-works-canvas-gallery-links .ao-works-canvas-gallery-links__linked-gallery {
	height: var(--ao-linked-gallery-height, 720px) !important;
}

.elementor-widget-ao-works-canvas-gallery-links .ao-works-canvas-gallery-links__linked-stage {
	height: 100% !important;
	min-height: 0 !important;
}
