/**
 * Craft Breeze Secure Login — modal stylesheet (v1.0.4+)
 *
 * Design system: Cormorant Garamond + Italiana + Inter, paleta dourada sobre
 * preto. Adaptação do mockup oficial Craft Breeze. Todas as classes são
 * prefixadas com `cbsl-` para evitar colisões com outros temas/plugins.
 *
 * Notas de implementação:
 * - O CSS usa !important nos pontos críticos (cor, fonte, layout) porque o
 *   plugin tem que sobreviver a temas premium agressivos. NÃO usa !important
 *   em transições/animações para que possam ser sobrepostas se necessário.
 * - Variável --cbsl-primary é injectada via wp_add_inline_style() a partir
 *   das settings (sanitize_hex_color). Aqui só serve de fallback dourado.
 * - A z-index do modal é 99999 para sobrepor menus sticky/fixed dos temas.
 */

:root {
	--cbsl-primary: #c9a449;
	--cbsl-primary-warm: #e8a800;
	--cbsl-cream: #e8dec5;
	--cbsl-bg: #070605;
	--cbsl-card-top: #0e0c0a;
	--cbsl-card-bottom: #13100c;
}

/* =============================================================================
   TRIGGER — botão "Entrar" injectado em /entrar/ que abre o modal
   ========================================================================== */

.cbsl-trigger-wrap {
	min-height: calc(100vh - 200px);
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	padding: 60px 20px;
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}

.cbsl-trigger-inner {
	text-align: center;
	max-width: 440px;
}

.cbsl-trigger-eyebrow {
	font-family: 'Italiana', serif !important;
	font-size: 11px !important;
	letter-spacing: .5em !important;
	color: var(--cbsl-primary) !important;
	margin-bottom: 18px !important;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 14px;
	text-transform: uppercase;
}
.cbsl-trigger-eyebrow::before,
.cbsl-trigger-eyebrow::after {
	content: '';
	width: 24px;
	height: 1px;
	background: var(--cbsl-primary);
	opacity: .6;
}

.cbsl-trigger-title {
	font-family: 'Cormorant Garamond', serif !important;
	font-size: 48px !important;
	font-weight: 300 !important;
	color: var(--cbsl-cream) !important;
	margin: 0 0 12px !important;
	letter-spacing: -.02em !important;
	line-height: 1.1;
}
.cbsl-trigger-title em {
	color: var(--cbsl-primary) !important;
	font-style: italic !important;
}

.cbsl-trigger-sub {
	color: rgba(232, 222, 197, .6) !important;
	font-size: 15px !important;
	margin: 0 0 36px !important;
	font-weight: 300 !important;
	line-height: 1.6;
}

.cbsl-trigger {
	background: transparent !important;
	border: 1px solid var(--cbsl-primary) !important;
	color: var(--cbsl-cream) !important;
	display: inline-flex !important;
	align-items: center !important;
	gap: 12px !important;
	padding: 16px 32px !important;
	font-family: 'Inter', sans-serif !important;
	font-size: 11px !important;
	letter-spacing: .36em !important;
	text-transform: uppercase !important;
	font-weight: 500 !important;
	cursor: pointer;
	transition: all .4s cubic-bezier(.7, 0, .3, 1);
	position: relative;
	overflow: hidden;
}
.cbsl-trigger::before {
	content: '';
	position: absolute;
	inset: 0;
	background: var(--cbsl-primary);
	transform: translateY(101%);
	transition: transform .5s cubic-bezier(.7, 0, .3, 1);
}
.cbsl-trigger:hover {
	color: var(--cbsl-bg) !important;
}
.cbsl-trigger:hover::before {
	transform: translateY(0);
}
.cbsl-trigger > * {
	position: relative;
	z-index: 1;
}
.cbsl-trigger svg {
	width: 18px;
	height: 18px;
	transition: transform .4s cubic-bezier(.7, 0, .3, 1);
}
.cbsl-trigger:hover svg {
	transform: scale(1.1);
}

body.cbsl-page {
	background: var(--cbsl-bg) !important;
}

/* =============================================================================
   MODAL-AS-PAGE — quando o modal É a página inteira (v1.0.5+)
   ========================================================================== */

/* Trava overflow para o utilizador não conseguir fazer scroll por trás do modal. */
html.cbsl-login-html,
body.cbsl-login-active {
	overflow: hidden !important;
	height: 100% !important;
}

/* Esconde elementos típicos do tema: header, footer, breadcrumbs, título da
   página, conteúdo "empty page". O modal posiciona-se com position:fixed e
   cobre tudo, mas tirar o resto do fluxo evita "fantasmas" em browsers com
   JS desactivado e melhora a percepção de carregamento. */
body.cbsl-login-active .site-header,
body.cbsl-login-active .site-footer,
body.cbsl-login-active header.site-header,
body.cbsl-login-active footer.site-footer,
body.cbsl-login-active .entry-header,
body.cbsl-login-active .entry-title,
body.cbsl-login-active .entry-meta,
body.cbsl-login-active .breadcrumbs,
body.cbsl-login-active .breadcrumb-trail,
body.cbsl-login-active #wpadminbar {
	display: none !important;
}

/* Page content (Astra, GeneratePress, Twenty*, Hello, Kadence) — torna invisível
   mas mantém no DOM para preservar a estrutura semântica da página. O modal
   sobrepõe-se mesmo assim por causa do z-index 99999. */
body.cbsl-login-active .site-content,
body.cbsl-login-active main#main,
body.cbsl-login-active main#primary,
body.cbsl-login-active #content,
body.cbsl-login-active .entry-content {
	background: var(--cbsl-bg) !important;
	min-height: 100vh;
}

/* Classe injectada no modal pelo PHP quando o modal é a página inteira.
   Tem o mesmo aspecto visual do .cbsl-open mas sem transição de visibilidade —
   a página já abre com o card visível, sem flash de overlay. */
.cbsl-modal.cbsl-as-page {
	transition: none;
}
.cbsl-modal.cbsl-as-page .cbsl-card {
	transition: none;
}

/* =============================================================================
   POPUP MODE (1.0.7) — modal injectado globalmente, fechado por defeito
   ========================================================================== */

/* Em modo popup, o modal já tem as transições padrão do .cbsl-modal — fica
   invisível até receber a classe .cbsl-open via JS. Quando o body tiver
   .cbsl-modal-open (adicionado pelo JS), o scroll fica travado. */
body.cbsl-modal-open {
	overflow: hidden !important;
}

/* O popup NÃO esconde o tema do site — apenas se sobrepõe.  */

/* =============================================================================
   MENU TRIGGER (1.0.7) — botão "Login" no header
   ========================================================================== */

.cbsl-menu-trigger {
	display: inline-flex !important;
	align-items: center !important;
	gap: 8px !important;
	padding: 8px 14px !important;
	font-family: 'Inter', sans-serif !important;
	font-size: 11px !important;
	letter-spacing: .32em !important;
	text-transform: uppercase !important;
	font-weight: 400 !important;
	color: inherit;
	text-decoration: none !important;
	border: none;
	background: transparent;
	cursor: pointer;
	transition: color .3s ease;
	position: relative;
}
.cbsl-menu-trigger:hover {
	color: var(--cbsl-primary) !important;
}
.cbsl-menu-trigger-icon {
	width: 16px;
	height: 16px;
	transition: transform .3s ease;
}
.cbsl-menu-trigger:hover .cbsl-menu-trigger-icon {
	transform: scale(1.1);
}

/* =============================================================================
   MODAL — overlay + card sobreposto
   ========================================================================== */

.cbsl-modal {
	position: fixed !important;
	inset: 0 !important;
	z-index: 99999 !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	background: rgba(7, 6, 5, .85) !important;
	-webkit-backdrop-filter: blur(12px) saturate(120%);
	backdrop-filter: blur(12px) saturate(120%);
	opacity: 0;
	visibility: hidden;
	transition: opacity .5s cubic-bezier(.7, 0, .3, 1), visibility 0s .5s;
	padding: 20px;
	box-sizing: border-box;
	font-family: 'Inter', sans-serif;
}
.cbsl-modal *,
.cbsl-modal *::before,
.cbsl-modal *::after {
	box-sizing: border-box;
}
.cbsl-modal.cbsl-open {
	opacity: 1;
	visibility: visible;
	transition: opacity .5s cubic-bezier(.7, 0, .3, 1), visibility 0s 0s;
}

.cbsl-modal-bg {
	position: absolute !important;
	inset: 0 !important;
	background:
		radial-gradient(ellipse 60% 40% at 50% 30%, rgba(201, 164, 73, .15), transparent 60%),
		radial-gradient(ellipse 80% 50% at 50% 90%, rgba(138, 104, 24, .12), transparent 60%);
	pointer-events: none;
}

.cbsl-card {
	position: relative;
	width: 100%;
	max-width: 480px;
	background: linear-gradient(180deg, var(--cbsl-card-top), var(--cbsl-card-bottom)) !important;
	border: 1px solid rgba(201, 164, 73, .2) !important;
	padding: 56px 48px 48px !important;
	transform: scale(.92) translateY(20px);
	transition: transform .6s cubic-bezier(.7, 0, .3, 1);
	color: var(--cbsl-cream);
	max-height: 100vh;
	/* (1.0.6) Scroll funciona quando preciso (mobile pequenos) mas a barra
	   nunca aparece. overflow:hidden cortaria conteúdo; auto+hidden via
	   pseudo-classes esconde a barra preservando a funcionalidade. */
	overflow-y: auto;
	scrollbar-width: none;          /* Firefox */
	-ms-overflow-style: none;       /* IE/Edge legacy */
}
.cbsl-card::-webkit-scrollbar {
	display: none;                  /* Chrome, Safari, Edge moderno */
	width: 0;
	height: 0;
}
.cbsl-modal.cbsl-open .cbsl-card {
	transform: scale(1) translateY(0);
}
.cbsl-card::before,
.cbsl-card::after {
	content: '';
	position: absolute;
	width: 32px;
	height: 32px;
	border: 1px solid var(--cbsl-primary);
}
.cbsl-card::before {
	top: -1px;
	left: -1px;
	border-right: none;
	border-bottom: none;
}
.cbsl-card::after {
	bottom: -1px;
	right: -1px;
	border-left: none;
	border-top: none;
}

.cbsl-close {
	position: absolute !important;
	top: 20px !important;
	right: 20px !important;
	width: 36px !important;
	height: 36px !important;
	background: transparent !important;
	border: none !important;
	color: rgba(232, 222, 197, .5) !important;
	cursor: pointer;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	transition: all .3s;
	z-index: 5;
	padding: 0 !important;
}
.cbsl-close:hover {
	color: var(--cbsl-primary) !important;
	transform: rotate(90deg);
}
.cbsl-close svg {
	width: 18px;
	height: 18px;
}

.cbsl-emblem-wrap {
	display: flex;
	justify-content: center;
	margin-bottom: 24px;
}
.cbsl-emblem {
	width: 64px !important;
	height: 64px !important;
	object-fit: contain;
	filter: drop-shadow(0 0 16px rgba(201, 164, 73, .5));
	animation: cbslEmblemFloat 4s ease-in-out infinite;
}
@keyframes cbslEmblemFloat {
	0%, 100% { transform: translateY(0) rotateZ(0); }
	50%      { transform: translateY(-6px) rotateZ(2deg); }
}

.cbsl-eyebrow {
	text-align: center;
	font-family: 'Italiana', serif !important;
	font-size: 11px !important;
	letter-spacing: .5em !important;
	color: var(--cbsl-primary) !important;
	margin-bottom: 16px !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 14px !important;
	text-transform: uppercase;
}
.cbsl-eyebrow::before,
.cbsl-eyebrow::after {
	content: '';
	width: 24px;
	height: 1px;
	background: var(--cbsl-primary);
	opacity: .6;
}

.cbsl-title {
	font-family: 'Cormorant Garamond', serif !important;
	font-size: 42px !important;
	font-weight: 300 !important;
	color: var(--cbsl-cream) !important;
	text-align: center;
	margin: 0 0 8px 0 !important;
	letter-spacing: -.02em !important;
	line-height: 1;
}
.cbsl-title em {
	color: var(--cbsl-primary) !important;
	font-style: italic !important;
}

.cbsl-subtitle {
	text-align: center;
	color: rgba(232, 222, 197, .6) !important;
	font-size: 14px !important;
	margin: 0 0 40px 0 !important;
	font-weight: 300 !important;
}

.cbsl-alert {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 12px 14px;
	margin: 0 0 24px 0;
	background: rgba(220, 38, 38, .08);
	border: 1px solid rgba(220, 38, 38, .35);
	color: #fca5a5 !important;
	font-size: 13px;
	line-height: 1.4;
	font-weight: 400;
}
.cbsl-alert svg {
	flex-shrink: 0;
	width: 18px;
	height: 18px;
}

.cbsl-form {
	display: flex !important;
	flex-direction: column !important;
	gap: 24px !important;
	margin: 0 !important;
}
.cbsl-field {
	position: relative;
}
.cbsl-field label {
	position: absolute !important;
	top: 14px !important;
	left: 0 !important;
	font-size: 13px !important;
	color: rgba(232, 222, 197, .5) !important;
	letter-spacing: .06em !important;
	pointer-events: none;
	transition: all .4s cubic-bezier(.7, 0, .3, 1) !important;
	font-weight: 300 !important;
	margin: 0 !important;
}
.cbsl-field input {
	width: 100% !important;
	background: transparent !important;
	border: none !important;
	border-bottom: 1px solid rgba(201, 164, 73, .25) !important;
	color: var(--cbsl-cream) !important;
	font-family: 'Inter', sans-serif !important;
	font-size: 15px !important;
	padding: 14px 0 !important;
	transition: border-color .4s;
	font-weight: 300 !important;
	outline: none !important;
	border-radius: 0 !important;
	box-shadow: none !important;
}
.cbsl-field input:focus {
	border-color: var(--cbsl-primary) !important;
}
.cbsl-field input:focus + label,
.cbsl-field input:not(:placeholder-shown) + label {
	top: -12px !important;
	font-size: 9px !important;
	letter-spacing: .32em !important;
	text-transform: uppercase !important;
	color: var(--cbsl-primary) !important;
}
.cbsl-field-password {
	position: relative;
}
.cbsl-toggle-pass {
	position: absolute !important;
	right: 0 !important;
	top: 12px !important;
	background: transparent !important;
	border: none !important;
	color: rgba(232, 222, 197, .5) !important;
	cursor: pointer;
	padding: 4px !important;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: color .3s;
}
.cbsl-toggle-pass:hover {
	color: var(--cbsl-primary) !important;
}
.cbsl-toggle-pass svg {
	width: 18px;
	height: 18px;
}
.cbsl-field-password input {
	padding-right: 36px !important;
}

.cbsl-row {
	display: flex !important;
	justify-content: space-between !important;
	align-items: center !important;
	margin-top: 4px !important;
	flex-wrap: wrap;
	gap: 12px;
}
.cbsl-remember {
	display: flex !important;
	align-items: center !important;
	gap: 10px !important;
	color: rgba(232, 222, 197, .65) !important;
	font-size: 11px !important;
	letter-spacing: .18em !important;
	text-transform: uppercase !important;
	cursor: pointer;
	user-select: none;
	margin: 0 !important;
}
.cbsl-remember input {
	appearance: none;
	-webkit-appearance: none;
	width: 14px !important;
	height: 14px !important;
	border: 1px solid rgba(201, 164, 73, .4) !important;
	background: transparent !important;
	cursor: pointer;
	position: relative;
	transition: all .3s;
	margin: 0 !important;
	padding: 0 !important;
}
.cbsl-remember input:checked {
	background: var(--cbsl-primary) !important;
	border-color: var(--cbsl-primary) !important;
}
.cbsl-remember input:checked::after {
	content: '';
	position: absolute;
	top: 1px;
	left: 4px;
	width: 4px;
	height: 8px;
	border-right: 1.5px solid var(--cbsl-bg);
	border-bottom: 1.5px solid var(--cbsl-bg);
	transform: rotate(45deg);
}
.cbsl-forgot {
	background: none !important;
	border: none !important;
	color: var(--cbsl-primary) !important;
	cursor: pointer;
	font-family: 'Inter', sans-serif !important;
	font-size: 11px !important;
	letter-spacing: .18em !important;
	text-transform: uppercase !important;
	font-weight: 400 !important;
	padding: 0 !important;
	border-bottom: 1px solid transparent !important;
	transition: border-color .3s;
	text-decoration: none !important;
}
.cbsl-forgot:hover {
	border-bottom-color: var(--cbsl-primary) !important;
}

.cbsl-submit {
	width: 100% !important;
	background: var(--cbsl-primary) !important;
	color: var(--cbsl-bg) !important;
	border: none !important;
	padding: 18px 32px !important;
	font-size: 11px !important;
	letter-spacing: .36em !important;
	text-transform: uppercase !important;
	font-family: 'Inter', sans-serif !important;
	font-weight: 500 !important;
	margin-top: 24px !important;
	cursor: pointer;
	position: relative;
	overflow: hidden;
	transition: transform .4s;
	border-radius: 0 !important;
}
.cbsl-submit::before {
	content: '';
	position: absolute;
	inset: 0;
	background: var(--cbsl-cream);
	transform: translateY(101%);
	transition: transform .5s cubic-bezier(.7, 0, .3, 1);
}
.cbsl-submit span {
	position: relative;
	z-index: 1;
}
.cbsl-submit:hover::before {
	transform: translateY(0);
}
.cbsl-submit:disabled {
	opacity: .6;
	cursor: not-allowed;
}

.cbsl-divider {
	display: flex !important;
	align-items: center !important;
	gap: 18px !important;
	margin: 32px 0 24px !important;
	color: rgba(232, 222, 197, .4) !important;
	font-size: 10px !important;
	letter-spacing: .4em !important;
	text-transform: uppercase !important;
}
.cbsl-divider::before,
.cbsl-divider::after {
	content: '';
	flex: 1;
	height: 1px;
	background: rgba(201, 164, 73, .15);
}

.cbsl-social {
	display: grid !important;
	grid-template-columns: 1fr 1fr !important;
	gap: 12px !important;
}
.cbsl-social-btn {
	background: transparent !important;
	border: 1px solid rgba(201, 164, 73, .2) !important;
	color: var(--cbsl-cream) !important;
	padding: 14px 16px !important;
	font-family: 'Inter', sans-serif !important;
	font-size: 11px !important;
	letter-spacing: .18em !important;
	text-transform: uppercase !important;
	font-weight: 400 !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 10px !important;
	cursor: pointer;
	transition: all .4s;
	border-radius: 0 !important;
	text-decoration: none !important;
}
.cbsl-social-btn:hover {
	border-color: var(--cbsl-primary) !important;
	color: var(--cbsl-primary) !important;
	background: rgba(201, 164, 73, .05) !important;
}
.cbsl-social-btn svg {
	width: 16px;
	height: 16px;
}

.cbsl-footer {
	text-align: center;
	margin-top: 32px !important;
	padding-top: 24px !important;
	border-top: 1px solid rgba(201, 164, 73, .1) !important;
	color: rgba(232, 222, 197, .55) !important;
	font-size: 13px !important;
	font-weight: 300 !important;
}
.cbsl-footer a {
	color: var(--cbsl-primary) !important;
	border-bottom: 1px solid transparent;
	padding-bottom: 1px;
	transition: border-color .3s;
	font-style: italic;
	font-family: 'Cormorant Garamond', serif !important;
	font-size: 16px !important;
	text-decoration: none !important;
}
.cbsl-footer a:hover {
	border-bottom-color: var(--cbsl-primary) !important;
}

/* Card "já logado" — versão modal */
.cbsl-loggedin {
	text-align: center;
}
.cbsl-loggedin-avatar {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	background: var(--cbsl-primary);
	color: var(--cbsl-bg);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-family: 'Cormorant Garamond', serif;
	font-size: 28px;
	font-weight: 600;
	margin: 0 auto 18px;
}
.cbsl-loggedin-actions {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin-top: 24px;
}
.cbsl-loggedin-actions a {
	display: block;
	padding: 14px 24px;
	border: 1px solid rgba(201, 164, 73, .25);
	color: var(--cbsl-cream);
	text-decoration: none;
	font-size: 11px;
	letter-spacing: .32em;
	text-transform: uppercase;
	transition: all .3s;
}
.cbsl-loggedin-actions a:hover {
	border-color: var(--cbsl-primary);
	color: var(--cbsl-primary);
}
.cbsl-loggedin-actions a.cbsl-primary {
	background: var(--cbsl-primary);
	color: var(--cbsl-bg);
	border-color: var(--cbsl-primary);
}
.cbsl-loggedin-actions a.cbsl-primary:hover {
	background: var(--cbsl-cream);
	border-color: var(--cbsl-cream);
}

/* MOBILE */
@media (max-width: 540px) {
	.cbsl-card {
		padding: 48px 28px 36px !important;
	}
	.cbsl-title {
		font-size: 34px !important;
	}
	.cbsl-trigger-title {
		font-size: 36px !important;
	}
	.cbsl-emblem {
		width: 54px !important;
		height: 54px !important;
	}
	.cbsl-social {
		grid-template-columns: 1fr !important;
	}
	.cbsl-row {
		flex-direction: column;
		align-items: flex-start !important;
	}
}
