/* =============================================
   CGT RGD Hero Slider
   ============================================= */

.cgt-hero-slider {
	position: relative;
	width: 100%;
	overflow: hidden;
	background: #0d1b2a;
	--slider-height: 90vh;
	--features-height: 0px;
}

/* Track */
.cgt-slider-track {
	display: flex;
	transition: transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
	will-change: transform;
}

/* Slide */
.cgt-slide {
	position: relative;
	min-width: 100%;
	height: var(--slider-height);
	min-height: 560px;
	display: flex;
	flex-direction: column;
}

/* Background */
.cgt-slide-bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center top;
	background-repeat: no-repeat;
	transition: transform 8s ease;
	will-change: transform;
}
.cgt-slide.is-active .cgt-slide-bg {
	transform: scale(1.04);
}

/* Overlay — cor sólida definida pelo meta box (inline style) */
.cgt-slide-overlay {
	position: absolute;
	inset: 0;
	z-index: 1;
	pointer-events: none;
}

/* Gradiente de legibilidade — padrão: lateral da esquerda */
.cgt-slide::after {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 2;
	pointer-events: none;
	background: linear-gradient(
		to right,
		rgba(0, 0, 0, 0.55) 0%,
		rgba(0, 0, 0, 0.20) 55%,
		transparent 100%
	);
}

/* Gradiente radial — para texto centralizado */
.cgt-slide--overlay-radial::after {
	background: radial-gradient(
		ellipse at 35% 50%,
		rgba(0, 0, 0, 0.60) 0%,
		rgba(0, 0, 0, 0.25) 50%,
		transparent 78%
	);
}

/* Sobreposição sólida — sem gradiente */
.cgt-slide--overlay-solid::after {
	content: none;
}

/* Sem sobreposição alguma — nem gradiente nem cor sólida */
.cgt-slide--overlay-none::after {
	content: none;
}
.cgt-slide--overlay-none .cgt-slide-overlay {
	opacity: 0;
}

/* Inner — área do conteúdo acima dos diferenciais */
.cgt-slide-inner {
	position: relative;
	z-index: 3;
	flex: 1;
	display: flex;
	align-items: center;
	padding: 6rem 0 2rem;
	max-width: 1280px;
	margin: 0 auto;
	width: 100%;
	padding-inline: 2rem;
}

/* Content alignment */
.cgt-slide-content {
	max-width: 680px;
	color: #fff;
}
.cgt-align-center { margin-inline: auto; text-align: center; }
.cgt-align-right  { margin-left: auto; text-align: right; }
.cgt-align-left   { margin-right: auto; text-align: left; }

/* Subtitle */
.cgt-slide-subtitle {
	display: inline-block;
	font-size: 0.85rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--color-secondary, #c9a96e);
	margin-bottom: 1rem;
	opacity: 0;
	transform: translateY(16px);
	transition: opacity 0.6s ease 0.1s, transform 0.6s ease 0.1s;
}

/* Title */
.cgt-slide-title {
	font-size: clamp(2.8rem, 6vw, 5.5rem);
	font-family: var(--font-heading, 'Cormorant Garamond', serif);
	font-weight: 300;
	line-height: 1.1;
	color: rgba(253, 250, 245, 0.97);
	margin-bottom: 1.2rem;
	letter-spacing: -0.01em;
	text-shadow: 0 2px 16px rgba(0, 0, 0, 0.45), 0 1px 4px rgba(0, 0, 0, 0.35);
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 0.6s ease 0.25s, transform 0.6s ease 0.25s;
}
.cgt-title-main {
	display: block;
}
.cgt-title-highlight {
	display: block;
	font-style: italic;
	color: var(--color-secondary, #C4A46B);
}

/* Description */
.cgt-slide-desc {
	font-size: 1.05rem;
	line-height: 1.7;
	color: rgba(255,255,255,0.8);
	max-width: 520px;
	margin-bottom: 2rem;
	text-shadow: 0 1px 8px rgba(0, 0, 0, 0.40);
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 0.6s ease 0.4s, transform 0.6s ease 0.4s;
}
.cgt-align-center .cgt-slide-desc { margin-inline: auto; }

/* CTA Button — padrão */
.cgt-slide-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.6rem;
	background: var(--color-secondary, #C4A46B);
	color: var(--color-primary, #1A1814);
	font-family: var(--font-body, sans-serif);
	font-weight: 500;
	font-size: 0.8rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	padding: 0.85rem 1.75rem;
	border-radius: 0;
	text-decoration: none;
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 0.6s ease 0.55s, transform 0.6s ease 0.55s,
	            background 0.25s ease, color 0.25s ease;
}
.cgt-slide-btn:hover {
	background: rgba(196,164,107,0.85);
	color: var(--color-primary, #1A1814);
	text-decoration: none;
}
.cgt-slide-btn .ph { font-size: 1rem; }


/* Animate when active */
.cgt-slide.is-active .cgt-slide-hero-tag,
.cgt-slide.is-active .cgt-slide-subtitle,
.cgt-slide.is-active .cgt-slide-title,
.cgt-slide.is-active .cgt-slide-desc,
.cgt-slide.is-active .cgt-slide-btn {
	opacity: 1;
	transform: translateY(0);
}

/* ── DIFERENCIAIS ─────────────────────────────── */
.cgt-slide-features {
	position: relative;
	z-index: 4;
	background: rgba(13, 27, 42, 0.92);
	backdrop-filter: blur(4px);
	border-top: 1px solid rgba(255,255,255,0.08);
}

.cgt-features-inner {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	max-width: 1280px;
	margin: 0 auto;
	padding-inline: 2rem;
}

.cgt-feature {
	display: flex;
	align-items: flex-start;
	gap: 1rem;
	padding: 1.75rem 2rem;
	border-right: 1px solid rgba(255,255,255,0.08);
	transition: background 0.3s;
}
.cgt-feature:last-child { border-right: none; }
.cgt-feature:hover { background: rgba(255,255,255,0.04); }

.cgt-feature-icon {
	flex-shrink: 0;
	font-size: 1.75rem;
	color: var(--color-secondary, #c9a96e);
	margin-top: 2px;
}
.cgt-feature-icon img {
	width: 32px;
	height: 32px;
	object-fit: contain;
}

.cgt-feature-title {
	font-size: 1rem;
	font-weight: 700;
	color: #fff;
	margin: 0 0 0.35rem;
	font-family: var(--font-heading, 'Playfair Display', serif);
}

.cgt-feature-desc {
	font-size: 0.85rem;
	line-height: 1.6;
	color: rgba(255,255,255,0.6);
	margin: 0;
}

/* ── CONTROLES ───────────────────────────────── */
.cgt-slider-controls {
	position: absolute;
	bottom: 1.5rem;
	left: 50%;
	transform: translateX(-50%);
	z-index: 10;
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

/* Quando há barra de diferenciais, sobe os controles */
.cgt-hero-slider--has-features .cgt-slider-controls {
	bottom: calc(var(--features-height, 0px) + 1.5rem);
}

.cgt-slider-prev,
.cgt-slider-next {
	width: 42px;
	height: 42px;
	border-radius: 50%;
	border: 2px solid rgba(255,255,255,0.4);
	background: transparent;
	color: #fff;
	font-size: 1.2rem;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: background 0.25s, border-color 0.25s;
}
.cgt-slider-prev:hover,
.cgt-slider-next:hover {
	background: var(--color-secondary, #c9a96e);
	border-color: var(--color-secondary, #c9a96e);
}

.cgt-slider-dots {
	display: flex;
	gap: 0.4rem;
}
.cgt-dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	border: 2px solid rgba(255,255,255,0.5);
	background: transparent;
	cursor: pointer;
	transition: background 0.25s, border-color 0.25s, width 0.25s;
	padding: 0;
}
.cgt-dot.is-active {
	background: var(--color-secondary, #c9a96e);
	border-color: var(--color-secondary, #c9a96e);
	width: 22px;
	border-radius: 4px;
}

/* ── ALINHAMENTO VERTICAL ────────────────────────────────────────────────── */
.cgt-slide--valign-top    .cgt-slide-inner { align-items: flex-start; }
.cgt-slide--valign-center .cgt-slide-inner { align-items: center; }
.cgt-slide--valign-bottom .cgt-slide-inner { align-items: flex-end; }

/* ── OVERRIDES MOBILE ────────────────────────────────────────────────────── */
@media (max-width: 899px) {
	.cgt-slide--mob-halign-left   .cgt-slide-content { margin-right: auto; margin-left: 0; text-align: left; }
	.cgt-slide--mob-halign-center .cgt-slide-content { margin-inline: auto; text-align: center; }
	.cgt-slide--mob-halign-right  .cgt-slide-content { margin-left: auto; margin-right: 0; text-align: right; }
	.cgt-slide--mob-valign-top    .cgt-slide-inner { align-items: flex-start; }
	.cgt-slide--mob-valign-center .cgt-slide-inner { align-items: center; }
	.cgt-slide--mob-valign-bottom .cgt-slide-inner { align-items: flex-end; }
	/* Hero-tag usa display:flex — não herda text-align, precisa de justify-content explícito */
	.cgt-slide--mob-halign-center .cgt-slide-hero-tag { justify-content: center; }
	.cgt-slide--mob-halign-right  .cgt-slide-hero-tag { justify-content: flex-end; }
	.cgt-slide--mob-halign-left   .cgt-slide-hero-tag { justify-content: flex-start; }
}

/* ── RESPONSIVE ──────────────────────────────── */
@media (max-width: 768px) {
	.cgt-slide { min-height: 480px; }
	.cgt-slide-inner { padding-top: 5rem; padding-bottom: 5rem; }
	.cgt-slide-content { max-width: 100%; }
	.cgt-slide-title { font-size: 1.8rem; line-height: 1.2; }
	.cgt-slide-desc  { font-size: 0.95rem; }
	/* Features ocultas no mobile */
	.cgt-slide-features { display: none !important; }
	/* Controles mobile: reseta desktop e aplica posição configurável por grupo */
	.cgt-slider-controls {
		bottom: 1.5rem;
		top: auto;
		left: auto;
		right: auto;
		transform: none;
		flex-direction: row;
	}
	.cgt-slider--controls-mob-left   .cgt-slider-controls { left: 2rem; }
	.cgt-slider--controls-mob-center .cgt-slider-controls { left: 50%; transform: translateX(-50%); }
	.cgt-slider--controls-mob-right  .cgt-slider-controls { right: 2rem; }
	.cgt-slider--hide-controls-mobile .cgt-slider-controls { display: none; }
	.cgt-slider-prev,
	.cgt-slider-next {
		width: 34px;
		height: 34px;
		font-size: 1rem;
	}
	.cgt-dot { width: 6px; height: 6px; }
	.cgt-dot.is-active { width: 16px; }
	/* Gradiente vertical no mobile — cobre toda a largura */
	.cgt-slide::after {
		background: linear-gradient(
			to bottom,
			transparent 0%,
			rgba(0, 0, 0, 0.25) 40%,
			rgba(0, 0, 0, 0.72) 100%
		);
	}
}

@media (max-width: 480px) {
	.cgt-slide-title { font-size: 1.6rem; }
	.cgt-slide-desc  { font-size: 0.9rem; }
}

/* ── CARD DE CONTEÚDO ────────────────────────────────────────────────────── */
/* Fundo translúcido atrás do texto para melhorar leitura em fotos claras    */

.cgt-slide--card-both .cgt-slide-content,
.cgt-slide--card-desktop .cgt-slide-content {
	background: rgba(13, 27, 42, 0.76);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	padding: 2.5rem 3rem;
	border-left: 3px solid var(--color-secondary, #C4A46B);
}
.cgt-slide--center.cgt-slide--card-both .cgt-slide-content,
.cgt-slide--center.cgt-slide--card-desktop .cgt-slide-content {
	border-left: none;
	border-top: 3px solid var(--color-secondary, #C4A46B);
}

@media (max-width: 768px) {
	.cgt-slide--card-both .cgt-slide-content,
	.cgt-slide--card-mobile .cgt-slide-content {
		background: rgba(13, 27, 42, 0.80);
		backdrop-filter: blur(6px);
		-webkit-backdrop-filter: blur(6px);
		padding: 1.5rem 1.75rem;
		border-left: 3px solid var(--color-secondary, #C4A46B);
	}
	.cgt-slide--center.cgt-slide--card-both .cgt-slide-content,
	.cgt-slide--center.cgt-slide--card-mobile .cgt-slide-content {
		border-left: none;
		border-top: 3px solid var(--color-secondary, #C4A46B);
	}
	/* Desktop-only card: desativar no mobile */
	.cgt-slide--card-desktop .cgt-slide-content {
		background: none;
		backdrop-filter: none;
		-webkit-backdrop-filter: none;
		padding: 0;
		border: none;
	}
}

/* ─────────────────────────────────────────────
   PROGRESS BAR
   ───────────────────────────────────────────── */
.cgt-progress-bar {
    position: absolute;
    left: 0;
    right: 0;
    height: 3px;
    background: rgba(255, 255, 255, 0.15);
    z-index: 10;
    overflow: hidden;
}
.cgt-progress-bar--top    { top: 0; }
.cgt-progress-bar--bottom { bottom: 0; }

.cgt-progress-fill {
    height: 100%;
    width: 0%;
    background: var(--color-secondary, #c9a96e);
    transform-origin: left;
    transition: width linear;
    /* duração definida via JS usando data-speed */
}
.cgt-progress-fill.is-running {
    width: 100%;
}
.cgt-progress-fill.is-reset {
    transition: none;
    width: 0%;
}

/* ─────────────────────────────────────────────
   COUNTER (números)
   ───────────────────────────────────────────── */
.cgt-slider-counter {
    display: flex;
    align-items: baseline;
    gap: 4px;
    font-family: var(--font-heading, 'Playfair Display', serif);
}
.cgt-counter-current {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-secondary, #c9a96e);
    line-height: 1;
    transition: opacity 0.25s ease;
}
.cgt-counter-sep {
    font-size: 0.9rem;
    color: rgba(255, 255, 255, 0.4);
}
.cgt-counter-total {
    font-size: 0.9rem;
    color: rgba(255, 255, 255, 0.5);
}

/* ─────────────────────────────────────────────
   HERO TAG
   ───────────────────────────────────────────── */
.cgt-slide-hero-tag {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    color: var(--color-secondary, #C4A46B);
    font-family: var(--font-body, sans-serif);
    font-size: 0.68rem;
    font-weight: 400;
    text-transform: uppercase;
    letter-spacing: 0.22em;
    margin-bottom: 1rem;
    background: none;
    padding: 0;
    opacity: 0;
    transform: translateY(14px);
    transition: opacity 0.6s ease 0s, transform 0.6s ease 0s;
}
.cgt-slide-hero-tag::before {
    content: '';
    display: block;
    width: 28px;
    height: 0.5px;
    background: currentColor;
    flex-shrink: 0;
}

/* Hero-tag alinhamento por posição do slide */
.cgt-align-center .cgt-slide-hero-tag { justify-content: center; }
.cgt-align-right  .cgt-slide-hero-tag { justify-content: flex-end; }

/* ─────────────────────────────────────────────
   BOTÃO ESTILO SETA
   ───────────────────────────────────────────── */
.cgt-slide-btn--arrow {
    display: inline-flex;
    align-items: center;
    gap: 1.25rem;
    background: none;
    border: none;
    padding: 0;
    color: #ffffff;
    font-family: var(--font-body, sans-serif);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.2em;
    font-weight: 500;
    text-decoration: none;
    transition: gap 0.35s cubic-bezier(0.25, 1, 0.5, 1);
}
.cgt-slide-btn--arrow:hover {
    gap: 1.75rem;
    color: #ffffff;
    text-decoration: none;
}
.cgt-slide-btn__circle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border: 1px solid rgba(255, 255, 255, 0.45);
    border-radius: 50%;
    flex-shrink: 0;
    transition: background 0.3s ease, border-color 0.3s ease;
}
.cgt-slide-btn--arrow:hover .cgt-slide-btn__circle {
    background: rgba(255, 255, 255, 0.15);
    border-color: rgba(255, 255, 255, 0.75);
}
.cgt-slide-btn__circle svg {
    display: block;
}