/* CES Mail — brand colors from logo */
:root {
	--ces-purple: #663399;
	--ces-blue: #333699;
	--ces-teal: #2ec4c6;
	--ces-gradient: linear-gradient(135deg, var(--ces-purple) 0%, var(--ces-blue) 100%);
	--ces-text-muted: #5c5f7a;
}

/* Logo plate — white rounded background for dark UI */
.ces-brand-logo {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: #fff;
	border-radius: 14px;
	padding: 10px 16px;
	box-shadow: 0 2px 12px rgba(51, 54, 150, 0.15);
}

.ces-brand-logo img {
	height: 44px;
	width: auto;
	max-width: min(300px, 88vw);
	display: block;
}

/* Login / signup — full wordmark, larger */
.ces-brand-logo--login {
	padding: 14px 22px;
	border-radius: 16px;
}

.ces-brand-logo--login img {
	height: 72px;
	max-width: min(380px, 92vw);
}

@media (min-width: 640px) {
	.ces-brand-logo--login img {
		height: 80px;
		max-width: 400px;
	}
}

.ces-brand-logo--icon {
	padding: 10px;
	border-radius: 50%;
}

.ces-brand-logo--icon img {
	height: 40px;
	width: 40px;
	max-width: 40px;
}

/* Sidebar header — favicon on white plate (dark mode) */
.ces-sidebar-logo {
	min-width: 100%;
	min-height: 100%;
	background: #fff !important;
}

/* Frappe /login page */
body[data-path="login"] {
	background: linear-gradient(160deg, #f4f0fa 0%, #eef3fc 45%, #f8fafc 100%) !important;
}

.page-card-head img.app-logo {
	background: #fff !important;
	border-radius: 16px !important;
	padding: 14px 22px !important;
	box-shadow: 0 2px 12px rgba(51, 54, 150, 0.15) !important;
	height: 80px !important;
	width: auto !important;
	max-width: min(400px, 92vw) !important;
	object-fit: contain !important;
	box-sizing: content-box !important;
}

body[data-path="login"] .page-card-head h4 {
	color: var(--ces-blue);
	font-weight: 600;
}

body[data-path="login"] .btn-primary,
body[data-path="login"] .btn-login {
	background: var(--ces-gradient) !important;
	border: none !important;
	box-shadow: 0 2px 8px rgba(102, 51, 153, 0.35);
}

body[data-path="login"] .btn-primary:hover,
body[data-path="login"] .btn-login:hover {
	filter: brightness(1.06);
}

body[data-path="login"] a,
body[data-path="login"] .forgot-password-message a {
	color: var(--ces-purple) !important;
}

body[data-path="login"] a:hover {
	color: var(--ces-blue) !important;
}

/* Single-line footer — no duplicate company name */
body[data-path="login"] .web-footer .footer-info .footer-col-right {
	display: none !important;
}

body[data-path="login"] .web-footer .footer-info .footer-col-left {
	width: 100%;
	text-align: center;
	color: var(--ces-text-muted);
	font-size: 12px;
	line-height: 1.5;
}

body[data-path="login"] .web-footer {
	border-top: 1px solid rgba(51, 54, 150, 0.12);
	padding-top: 1rem;
	margin-top: 2rem;
}

/* Mail app login / billing screens (/mail/login, /mail/billing) */
.ces-login-page {
	min-height: 100vh;
	background: linear-gradient(160deg, #f4f0fa 0%, #eef3fc 45%, #f8fafc 100%);
}

html[data-theme='dark'] .ces-login-page {
	background: linear-gradient(
		165deg,
		#1a1528 0%,
		#151a2e 40%,
		#12141c 100%
	);
}

.ces-login-page .ces-login-title {
	color: var(--ces-blue);
}

html[data-theme='dark'] .ces-login-page .ces-login-title {
	color: #b8b4e8;
}

.ces-login-footer {
	color: var(--ces-text-muted);
	font-size: 12px;
	text-align: center;
}

html[data-theme='dark'] .ces-login-footer {
	color: #9ca3b8;
}

.ces-login-page a {
	color: var(--ces-purple) !important;
	text-decoration-color: rgba(102, 51, 153, 0.4);
}

.ces-login-page a:hover {
	color: var(--ces-blue) !important;
}

.ces-login-page .ces-login-submit,
.ces-login-page button.ces-login-submit,
.ces-login-page button[type='submit'].ces-login-submit {
	background: var(--ces-gradient) !important;
	border: none !important;
	color: #fff !important;
	box-shadow: 0 2px 10px rgba(102, 51, 153, 0.4);
}

.ces-login-page .ces-login-submit:hover:not(:disabled),
.ces-login-page button[type='submit'].ces-login-submit:hover:not(:disabled) {
	filter: brightness(1.08);
}

.ces-login-page .ces-billing-cta {
	border-top: 1px solid rgba(51, 54, 150, 0.12);
	padding-top: 1.5rem;
	margin-top: 0.5rem;
}

html[data-theme='dark'] .ces-login-page .ces-billing-cta {
	border-top-color: rgba(184, 180, 232, 0.15);
}

.ces-login-page .ces-billing-cta .ces-get-started {
	display: inline-block;
	margin-top: 0.5rem;
	font-weight: 600;
	font-size: 1rem;
}

.ces-login-page:not(.ces-login-page--billing) .ces-login-card {
	max-width: 26rem;
	width: 100%;
}

/* --------------------------------------------------------------------------
   Auth split shell (/mail/login, forgot password, signup invite)
   -------------------------------------------------------------------------- */

.ces-login-page--auth {
	background: #f8fafc;
}

html[data-theme='dark'] .ces-login-page--auth {
	background: #12141c;
}

.ces-login-split {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
	min-height: 100dvh;
}

@media (min-width: 1024px) {
	.ces-login-split {
		display: grid;
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	}
}

/* Hero panel */
.ces-login-hero {
	position: relative;
	overflow: hidden;
	padding: 2rem 1.5rem 2.5rem;
	background: var(--ces-gradient);
	color: #fff;
}

@media (min-width: 1024px) {
	.ces-login-hero {
		display: flex;
		align-items: center;
		padding: 3rem 3.5rem;
		min-height: 100vh;
		min-height: 100dvh;
	}
}

.ces-login-hero__mesh {
	pointer-events: none;
	position: absolute;
	inset: 0;
	opacity: 0.35;
	background:
		radial-gradient(ellipse 80% 60% at 20% 10%, rgba(46, 196, 198, 0.45) 0%, transparent 55%),
		radial-gradient(ellipse 70% 50% at 90% 80%, rgba(255, 255, 255, 0.12) 0%, transparent 50%);
}

.ces-login-hero__content {
	position: relative;
	z-index: 1;
	max-width: 28rem;
}

.ces-login-hero__logo.ces-brand-logo {
	background: rgba(255, 255, 255, 0.98);
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.18);
}

.ces-login-hero__headline {
	margin: 1.75rem 0 0;
	font-size: clamp(1.5rem, 3vw, 2rem);
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: -0.02em;
}

.ces-login-hero__tagline {
	margin: 0.75rem 0 0;
	font-size: 1rem;
	line-height: 1.55;
	color: rgba(255, 255, 255, 0.88);
	max-width: 26rem;
}

.ces-login-hero__features {
	list-style: none;
	margin: 2rem 0 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.ces-login-hero__features li {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	font-size: 0.9375rem;
	line-height: 1.45;
	color: rgba(255, 255, 255, 0.95);
}

.ces-login-hero__feature-icon {
	display: flex;
	flex-shrink: 0;
	align-items: center;
	justify-content: center;
	width: 2.25rem;
	height: 2.25rem;
	border-radius: 0.5rem;
	background: rgba(255, 255, 255, 0.15);
	backdrop-filter: blur(4px);
}

@media (max-width: 1023px) {
	/* Background styling with premium glowing blobs */
	.ces-login-page--auth {
		background: linear-gradient(160deg, #f4f0fa 0%, #eef3fc 45%, #f8fafc 100%) !important;
		position: relative;
		overflow-x: hidden;
	}
	html[data-theme='dark'] .ces-login-page--auth {
		background: linear-gradient(165deg, #1a1528 0%, #151a2e 40%, #12141c 100%) !important;
	}

	.ces-login-page--auth::before {
		content: "";
		position: absolute;
		width: 250px;
		height: 250px;
		border-radius: 50%;
		background: radial-gradient(circle, rgba(102, 51, 153, 0.15) 0%, transparent 70%);
		top: -50px;
		left: -50px;
		z-index: 0;
		pointer-events: none;
		animation: pulse-blob-1 12s infinite alternate ease-in-out;
	}
	.ces-login-page--auth::after {
		content: "";
		position: absolute;
		width: 300px;
		height: 300px;
		border-radius: 50%;
		background: radial-gradient(circle, rgba(46, 196, 198, 0.12) 0%, transparent 70%);
		bottom: 50px;
		right: -100px;
		z-index: 0;
		pointer-events: none;
		animation: pulse-blob-2 15s infinite alternate ease-in-out;
	}

	@keyframes pulse-blob-1 {
		0% {
			transform: translate(0, 0) scale(1);
		}
		100% {
			transform: translate(30px, 40px) scale(1.15);
		}
	}
	@keyframes pulse-blob-2 {
		0% {
			transform: translate(0, 0) scale(1);
		}
		100% {
			transform: translate(-40px, -20px) scale(1.2);
		}
	}

	/* Mobile Staggered Entry Keyframes */
	@keyframes ces-mobile-fade-up {
		from {
			opacity: 0;
			transform: translateY(16px);
		}
		to {
			opacity: 1;
			transform: translateY(0);
		}
	}

	/* Split view and flow */
	.ces-login-split {
		position: relative;
		z-index: 1;
		display: flex;
		flex-direction: column;
		min-height: 100vh;
		min-height: 100dvh;
	}

	.ces-login-hero {
		padding: 2.25rem 1.25rem 1rem;
		background: transparent !important;
		box-shadow: none !important;
	}

	.ces-login-hero__content {
		display: flex;
		flex-direction: column;
		align-items: center;
		width: 100%;
		max-width: none;
	}

	.ces-login-hero__logo.ces-brand-logo {
		background: #ffffff !important;
		border: 1px solid rgba(102, 51, 153, 0.12) !important;
		box-shadow: 0 8px 32px rgba(51, 54, 150, 0.12) !important;
		transform: scale(0.92);
		opacity: 0;
		animation: ces-mobile-fade-up 0.55s cubic-bezier(0.16, 1, 0.3, 1) forwards;
	}
	html[data-theme='dark'] .ces-login-hero__logo.ces-brand-logo {
		background: #ffffff !important;
		border: 1px solid rgba(102, 51, 153, 0.15) !important;
		box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3) !important;
	}

	.ces-login-hero__headline,
	.ces-login-hero__tagline,
	.ces-login-hero__features {
		display: none;
	}

	/* Auth container & spacing */
	.ces-login-auth {
		padding: 0.5rem 1.25rem 2rem;
		z-index: 1;
	}

	.ces-login-auth__inner {
		gap: 1.25rem;
		opacity: 0;
		animation: ces-mobile-fade-up 0.65s cubic-bezier(0.16, 1, 0.3, 1) 0.08s forwards;
	}

	.ces-login-auth__header {
		margin-bottom: 1rem;
		text-align: center;
	}

	.ces-login-auth__title {
		font-size: 1.625rem !important;
		font-weight: 700 !important;
		letter-spacing: -0.025em !important;
		background: linear-gradient(135deg, var(--ces-purple) 0%, var(--ces-blue) 100%);
		-webkit-background-clip: text;
		background-clip: text;
		-webkit-text-fill-color: transparent;
	}
	html[data-theme='dark'] .ces-login-auth__title {
		background: linear-gradient(135deg, #b8b4e8 0%, #2ec4c6 100%);
		-webkit-background-clip: text;
		background-clip: text;
		-webkit-text-fill-color: transparent;
	}

	.ces-login-auth__subtitle {
		display: block !important;
		font-size: 0.875rem !important;
		margin-top: 0.375rem !important;
		opacity: 0.85;
	}

	/* Premium Frosted Glass Card */
	.ces-login-card--auth {
		padding: 1.5rem 1.5rem 1.75rem !important;
		background: rgba(255, 255, 255, 0.72) !important;
		backdrop-filter: blur(20px) !important;
		-webkit-backdrop-filter: blur(20px) !important;
		border: 1px solid rgba(255, 255, 255, 0.45) !important;
		border-radius: 20px !important;
		box-shadow: 
			0 12px 32px -8px rgba(51, 54, 150, 0.06), 
			0 24px 64px -16px rgba(102, 51, 153, 0.1),
			inset 0 1px 1px rgba(255, 255, 255, 0.7) !important;
	}
	html[data-theme='dark'] .ces-login-card--auth {
		background: rgba(24, 27, 38, 0.65) !important;
		border: 1px solid rgba(255, 255, 255, 0.07) !important;
		box-shadow: 
			0 16px 40px -12px rgba(0, 0, 0, 0.25), 
			0 32px 80px -20px rgba(0, 0, 0, 0.4),
			inset 0 1px 1px rgba(255, 255, 255, 0.04) !important;
	}

	/* Native-like Mobile Inputs styling */
	.ces-login-card--auth .frappe-control input,
	.ces-login-card--auth .ces-password-field input {
		font-size: 15px !important;
		min-height: 2.875rem !important;
		border-radius: 12px !important;
		border: 1px solid rgba(51, 54, 150, 0.15) !important;
		background-color: rgba(255, 255, 255, 0.8) !important;
		transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease !important;
		padding-left: 0.875rem !important;
		padding-right: 2.5rem !important; /* Ensure password toggle icon space */
	}
	html[data-theme='dark'] .ces-login-card--auth .frappe-control input,
	html[data-theme='dark'] .ces-login-card--auth .ces-password-field input {
		border-color: rgba(255, 255, 255, 0.08) !important;
		background-color: rgba(18, 20, 28, 0.6) !important;
		color: #f1f5f9 !important;
	}
	.ces-login-card--auth .frappe-control input:focus,
	.ces-login-card--auth .ces-password-field input:focus {
		border-color: var(--ces-purple) !important;
		background-color: #fff !important;
		box-shadow: 0 0 0 4px rgba(102, 51, 153, 0.12) !important;
	}
	html[data-theme='dark'] .ces-login-card--auth .frappe-control input:focus,
	html[data-theme='dark'] .ces-login-card--auth .ces-password-field input:focus {
		background-color: rgba(18, 20, 28, 0.85) !important;
		box-shadow: 0 0 0 4px rgba(102, 51, 153, 0.22) !important;
	}

	.ces-login-card--auth label {
		font-size: 0.8125rem !important;
		font-weight: 600 !important;
		color: var(--ces-blue) !important;
		letter-spacing: 0.01em !important;
		margin-bottom: 0.35rem !important;
	}
	html[data-theme='dark'] .ces-login-card--auth label {
		color: #c4c0f0 !important;
	}

	.ces-password-field button {
		color: var(--ces-text-muted) !important;
		right: 0.625rem !important;
		padding: 0.25rem !important;
	}

	/* Pill submit button */
	.ces-login-card--auth .ces-login-submit {
		border-radius: 12px !important;
		min-height: 2.875rem !important;
		font-size: 0.975rem !important;
		font-weight: 600 !important;
		letter-spacing: 0.01em !important;
		transition: transform 0.2s ease, filter 0.2s ease, box-shadow 0.2s ease !important;
	}
	.ces-login-card--auth .ces-login-submit:active {
		transform: scale(0.98) !important;
	}

	/* Staggered Form Components Delay */
	.ces-login-form > * {
		opacity: 0;
		animation: ces-mobile-fade-up 0.55s cubic-bezier(0.16, 1, 0.3, 1) forwards;
	}
	.ces-login-form > *:nth-child(1) { animation-delay: 0.12s; }
	.ces-login-form > *:nth-child(2) { animation-delay: 0.18s; }
	.ces-login-form > *:nth-child(3) { animation-delay: 0.24s; }
	.ces-login-form > *:nth-child(4) { animation-delay: 0.30s; }
	.ces-login-form > *:nth-child(5) { animation-delay: 0.36s; }

	/* Account signup elements hidden on mobile as requested */
	.ces-login-signup-card,
	.ces-login-signup-tertiary {
		display: none !important;
	}
}

/* Auth column */
.ces-login-auth {
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: 1.5rem 1.25rem 2rem;
}

@media (min-width: 1024px) {
	.ces-login-auth {
		padding: 2.5rem 3rem;
	}
}

.ces-login-auth__inner {
	width: 100%;
	max-width: 28rem;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.ces-login-card--auth {
	width: 100%;
	padding: 1.75rem 1.5rem 2rem;
	border-radius: 1rem;
	border: 1px solid rgba(102, 51, 153, 0.12);
	box-shadow:
		0 4px 6px -1px rgba(51, 54, 150, 0.06),
		0 20px 40px -12px rgba(102, 51, 153, 0.18);
}

html[data-theme='dark'] .ces-login-card--auth {
	background: rgba(24, 27, 38, 0.96) !important;
	border-color: rgba(184, 180, 232, 0.15);
	box-shadow: 0 24px 48px -12px rgba(0, 0, 0, 0.45);
}

@media (prefers-reduced-motion: no-preference) {
	.ces-login-card--auth {
		animation: ces-login-card-in 0.35s ease-out;
	}
}

@keyframes ces-login-card-in {
	from {
		opacity: 0;
		transform: translateY(8px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.ces-login-auth__header {
	margin-bottom: 1.5rem;
	text-align: left;
}

.ces-login-auth__title {
	margin: 0;
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 1.25;
	letter-spacing: -0.02em;
	color: var(--ces-blue);
}

html[data-theme='dark'] .ces-login-auth__title {
	color: #e8e6ff;
}

.ces-login-auth__subtitle {
	margin: 0.5rem 0 0;
	font-size: 0.9375rem;
	line-height: 1.45;
	color: var(--ces-text-muted);
}

html[data-theme='dark'] .ces-login-auth__subtitle {
	color: #9ca3b8;
}

/* Login form */
.ces-login-form {
	gap: 1.25rem;
}

.ces-login-form__forgot {
	margin-top: -0.5rem;
	text-align: right;
}

.ces-login-page--auth .ces-login-submit {
	min-height: 2.75rem;
	width: 100%;
	font-size: 1rem;
	font-weight: 600;
}

/* Signup CTA card */
.ces-login-signup-card {
	margin-top: 0.25rem;
	padding: 1rem 1.125rem;
	border-radius: 0.75rem;
	border: 1px solid rgba(102, 51, 153, 0.18);
	background: linear-gradient(135deg, rgba(102, 51, 153, 0.06), rgba(51, 54, 150, 0.04));
	text-align: center;
}

html[data-theme='dark'] .ces-login-signup-card {
	background: rgba(102, 51, 153, 0.12);
	border-color: rgba(184, 180, 232, 0.2);
}

.ces-login-signup-card__title {
	margin: 0 0 0.5rem;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--ces-text-muted);
}

html[data-theme='dark'] .ces-login-signup-card__title {
	color: #a8b0c4;
}

.ces-login-signup-card__primary {
	display: inline-block;
	font-size: 1rem;
	font-weight: 600;
	color: var(--ces-purple) !important;
	text-decoration: none !important;
}

.ces-login-signup-card__primary:hover {
	color: var(--ces-blue) !important;
	text-decoration: underline !important;
}

.ces-login-signup-card__secondary {
	display: inline-block;
	margin-top: 0.5rem;
	font-size: 0.8125rem;
	color: var(--ces-text-muted) !important;
	text-decoration: none !important;
}

.ces-login-signup-card__secondary:hover {
	text-decoration: underline !important;
}

.ces-login-signup-tertiary {
	text-align: center;
}

@media (min-width: 1024px) {
	.ces-login-signup-card {
		margin-top: 1.5rem;
	}

	.ces-login-signup-tertiary {
		margin-top: 1rem;
	}
}

.ces-login-footer--auth {
	position: static;
	text-align: center;
	padding: 0;
}

.ces-login-footer__short {
	display: inline;
}

.ces-login-footer__full {
	display: none;
}

@media (min-width: 640px) {
	.ces-login-footer__short {
		display: none;
	}

	.ces-login-footer__full {
		display: inline;
	}
}

.ces-login-page--auth a:focus-visible,
.ces-login-page--auth button:focus-visible {
	outline: 2px solid var(--ces-purple);
	outline-offset: 2px;
}

/* Billing page: wider card + plan grid */
.ces-login-page--billing .ces-login-card {
	max-width: min(56rem, calc(100vw - 2rem));
	width: 100%;
	padding: 1.75rem 1.25rem 2rem;
}

@media (min-width: 640px) {
	.ces-login-page--billing .ces-login-card {
		padding: 2rem 2rem 2.25rem;
	}
}

.ces-billing-page {
	width: 100%;
}

/* Domains dashboard — first-domain empty state */
.ces-domains-empty__icon {
	background: var(--ces-gradient);
	box-shadow: 0 8px 24px rgba(102, 51, 153, 0.35);
}

.ces-domains-empty__title {
	color: var(--ces-blue);
}

html[data-theme='dark'] .ces-domains-empty__title {
	color: #e8e6ff;
}

.ces-domains-empty__text {
	color: var(--ces-text-muted);
}

html[data-theme='dark'] .ces-domains-empty__text {
	color: #9ca3b8;
}

.ces-domains-empty__cta {
	background: var(--ces-gradient) !important;
	border: none !important;
	color: #fff !important;
	font-weight: 600 !important;
	box-shadow: 0 4px 14px rgba(102, 51, 153, 0.35);
}

.ces-domains-empty__cta:hover,
.ces-domains-empty__cta:focus-visible,
.ces-domains-empty__cta:active {
	color: #fff !important;
	filter: brightness(1.08);
}

.ces-billing-success {
	padding: 1rem 0.5rem 2rem;
}

.ces-billing-success__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 3rem;
	height: 3rem;
	margin-bottom: 1rem;
	border-radius: 999px;
	background: #16a34a;
	color: #fff;
	font-size: 1.5rem;
	font-weight: 700;
}

.ces-billing-success__title {
	margin: 0 0 0.75rem;
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--ces-blue);
}

html[data-theme='dark'] .ces-billing-success__title {
	color: #e8e6ff;
}

.ces-billing-success__text {
	margin: 0 0 1.25rem;
	font-size: 0.9375rem;
	line-height: 1.5;
	color: var(--ces-text-muted);
}

.ces-billing-success__actions {
	margin-top: 1rem;
}

.ces-billing-success__icon--muted {
	background: #94a3b8;
}

.ces-billing-success__text--warn {
	color: #b45309;
}

html[data-theme='dark'] .ces-billing-success__text--warn {
	color: #fbbf24;
}

.ces-billing-nav {
	margin-bottom: 1rem;
	font-size: 0.875rem;
}

.ces-billing-account {
	margin-bottom: 1.5rem;
	padding: 1.25rem;
	border-radius: 0.75rem;
	border: 1px solid rgba(102, 51, 153, 0.25);
	background: linear-gradient(135deg, rgba(102, 51, 153, 0.08), rgba(51, 54, 150, 0.05));
}

.ces-billing-account__title {
	margin: 0 0 1rem;
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--ces-blue);
}

.ces-billing-account__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(10rem, 1fr));
	gap: 0.75rem 1.25rem;
	margin-bottom: 1rem;
}

.ces-billing-account__grid dt {
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--ces-text-muted);
}

.ces-billing-account__grid dd {
	margin: 0.15rem 0 0;
	font-weight: 600;
	color: var(--ces-text);
}

.ces-billing-account__warn {
	color: #b45309;
}

.ces-billing-account__seats {
	margin-bottom: 1rem;
}

.ces-billing-account__actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.5rem;
	margin-bottom: 0.75rem;
}

.ces-billing-account__hint {
	margin: 0;
	font-size: 0.8125rem;
	color: var(--ces-text-muted);
}

.ces-billing-guest-banner {
	margin-bottom: 1.25rem;
	padding: 0.875rem 1rem;
	border-radius: 0.75rem;
	text-align: center;
	font-size: 0.875rem;
	line-height: 1.5;
	background: linear-gradient(135deg, rgba(102, 51, 153, 0.12), rgba(51, 54, 150, 0.08));
	border: 1px solid rgba(102, 51, 153, 0.25);
}

.ces-billing-guest-banner p {
	margin: 0 0 0.65rem;
	color: var(--ces-text);
}

.ces-billing-guest-banner .ces-get-started {
	display: inline-block;
	font-weight: 600;
	margin-right: 0.5rem;
}

.ces-billing-guest-or {
	margin: 0 0.35rem;
	color: var(--ces-text-muted);
	font-size: 0.8125rem;
}

html[data-theme='dark'] .ces-billing-guest-banner {
	background: rgba(102, 51, 153, 0.15);
	border-color: rgba(184, 180, 232, 0.2);
}

.ces-billing-lead {
	margin: 0 0 1.25rem;
	text-align: center;
	font-size: 0.9375rem;
	line-height: 1.55;
	color: var(--ces-text-muted);
	max-width: 36rem;
	margin-left: auto;
	margin-right: auto;
}

html[data-theme='dark'] .ces-billing-lead {
	color: #a8b0c4;
}

.ces-billing-steps {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.5rem 1rem;
	list-style: none;
	margin: 0 0 1.75rem;
	padding: 0;
}

.ces-billing-step {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.8125rem;
	font-weight: 500;
	color: var(--ces-blue);
}

html[data-theme='dark'] .ces-billing-step {
	color: #c4c0f0;
}

.ces-billing-step__num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.35rem;
	height: 1.35rem;
	border-radius: 999px;
	font-size: 0.7rem;
	font-weight: 700;
	background: var(--ces-gradient);
	color: #fff;
	flex-shrink: 0;
}

.ces-billing-active {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin-bottom: 1.5rem;
	padding: 0.875rem 1rem;
	border-radius: 0.75rem;
	background: linear-gradient(135deg, rgba(34, 197, 94, 0.12), rgba(51, 54, 150, 0.08));
	border: 1px solid rgba(34, 197, 94, 0.35);
}

.ces-billing-active__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 2rem;
	height: 2rem;
	border-radius: 999px;
	background: #16a34a;
	color: #fff;
	font-size: 0.875rem;
	font-weight: 700;
}

.ces-billing-active__title {
	margin: 0;
	font-size: 0.8125rem;
	font-weight: 600;
	color: #15803d;
}

.ces-billing-active__plan {
	margin: 0.15rem 0 0;
	font-size: 1rem;
	font-weight: 600;
	color: var(--ces-text);
}

html[data-theme='dark'] .ces-billing-active__title {
	color: #86efac;
}

html[data-theme='dark'] .ces-billing-active__plan {
	color: #f1f5f9;
}

.ces-billing-notice {
	margin-bottom: 1.25rem;
	padding: 0.75rem 1rem;
	border-radius: 0.5rem;
	font-size: 0.875rem;
	border: 1px solid rgba(245, 158, 11, 0.4);
	background: rgba(254, 243, 199, 0.5);
	color: #92400e;
}

html[data-theme='dark'] .ces-billing-notice {
	background: rgba(120, 53, 15, 0.25);
	color: #fcd34d;
	border-color: rgba(251, 191, 36, 0.35);
}

.ces-billing-loading {
	text-align: center;
	padding: 2rem;
	color: var(--ces-text-muted);
}

.ces-billing-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
}

@media (min-width: 768px) {
	.ces-billing-grid {
		grid-template-columns: repeat(3, 1fr);
		gap: 1rem;
		align-items: stretch;
	}
}

.ces-plan-card {
	position: relative;
	display: flex;
	flex-direction: column;
	padding: 1.75rem 1.5rem 2rem;
	border-radius: 20px;
	border: 1px solid rgba(102, 51, 153, 0.12);
	background: rgba(255, 255, 255, 0.72);
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	box-shadow: 
		0 4px 24px -6px rgba(51, 54, 150, 0.04), 
		0 12px 48px -12px rgba(102, 51, 153, 0.06),
		inset 0 1px 1px rgba(255, 255, 255, 0.8);
	transition:
		transform 0.3s cubic-bezier(0.16, 1, 0.3, 1),
		box-shadow 0.3s cubic-bezier(0.16, 1, 0.3, 1),
		border-color 0.3s ease,
		background-color 0.3s ease;
}

html[data-theme='dark'] .ces-plan-card {
	background: rgba(24, 27, 38, 0.65);
	border-color: rgba(255, 255, 255, 0.06);
	box-shadow: 
		0 8px 32px -8px rgba(0, 0, 0, 0.2), 
		0 24px 64px -16px rgba(0, 0, 0, 0.45),
		inset 0 1px 1px rgba(255, 255, 255, 0.04);
}

.ces-plan-card:hover {
	transform: translateY(-6px) scale(1.015);
	background-color: rgba(255, 255, 255, 0.85);
	box-shadow: 
		0 12px 36px -8px rgba(51, 54, 150, 0.08), 
		0 28px 72px -16px rgba(102, 51, 153, 0.18),
		inset 0 1px 1px rgba(255, 255, 255, 0.9);
	border-color: rgba(102, 51, 153, 0.35);
}

html[data-theme='dark'] .ces-plan-card:hover {
	background-color: rgba(24, 27, 38, 0.8);
	box-shadow: 
		0 16px 48px -8px rgba(0, 0, 0, 0.3), 
		0 36px 96px -16px rgba(0, 0, 0, 0.6),
		inset 0 1px 1px rgba(255, 255, 255, 0.08);
	border-color: rgba(184, 180, 232, 0.3);
}

.ces-plan-card--featured {
	border-color: rgba(102, 51, 153, 0.5) !important;
	background: rgba(255, 255, 255, 0.82);
	box-shadow:
		0 0 0 1px rgba(102, 51, 153, 0.2),
		0 20px 64px -16px rgba(102, 51, 153, 0.25),
		inset 0 1px 1px rgba(255, 255, 255, 0.9) !important;
}

html[data-theme='dark'] .ces-plan-card--featured {
	background: rgba(30, 26, 48, 0.72) !important;
	border-color: rgba(184, 180, 232, 0.3) !important;
	box-shadow:
		0 0 0 1px rgba(184, 180, 232, 0.1),
		0 24px 80px -16px rgba(102, 51, 153, 0.45),
		inset 0 1px 1px rgba(255, 255, 255, 0.06) !important;
}

@media (min-width: 768px) {
	.ces-plan-card--featured {
		transform: scale(1.05);
		z-index: 2;
	}

	.ces-plan-card--featured:hover {
		transform: scale(1.05) translateY(-6px);
	}
}

.ces-plan-badge {
	position: absolute;
	top: -0.65rem;
	left: 50%;
	transform: translateX(-50%);
	padding: 0.25rem 0.875rem;
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: #fff;
	background: var(--ces-gradient);
	border-radius: 999px;
	white-space: nowrap;
	box-shadow: 0 4px 12px rgba(102, 51, 153, 0.45);
	animation: ces-pulse-badge 2s infinite alternate ease-in-out;
}

@keyframes ces-pulse-badge {
	0% {
		box-shadow: 0 4px 12px rgba(102, 51, 153, 0.3);
		transform: translateX(-50%) scale(1);
	}
	100% {
		box-shadow: 0 4px 20px rgba(102, 51, 153, 0.5);
		transform: translateX(-50%) scale(1.05);
	}
}

.ces-plan-card__header {
	margin-bottom: 0.75rem;
}

.ces-plan-card__name {
	margin: 0;
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--ces-blue);
	letter-spacing: -0.02em;
}

html[data-theme='dark'] .ces-plan-card__name {
	color: #e8e6ff;
}

.ces-plan-card__tagline {
	margin: 0.35rem 0 0;
	font-size: 0.75rem;
	line-height: 1.4;
	color: var(--ces-text-muted);
	min-height: 2.1em;
}

html[data-theme='dark'] .ces-plan-card__tagline {
	color: #9ca3b8;
}

.ces-plan-card__price {
	display: flex;
	align-items: baseline;
	flex-wrap: wrap;
	gap: 0.1rem 0.25rem;
	margin-bottom: 1rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid rgba(51, 54, 150, 0.1);
}

html[data-theme='dark'] .ces-plan-card__price {
	border-bottom-color: rgba(184, 180, 232, 0.12);
}

.ces-plan-card__currency {
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--ces-purple);
}

.ces-plan-card__amount {
	font-size: 2.25rem;
	font-weight: 800;
	line-height: 1;
	letter-spacing: -0.03em;
	background: var(--ces-gradient);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}

.ces-plan-card__period {
	font-size: 0.8125rem;
	color: var(--ces-text-muted);
}

.ces-plan-card__features {
	list-style: none;
	margin: 0 0 1.15rem;
	padding: 0;
	flex: 1;
}

.ces-plan-card__features li {
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
	font-size: 0.8125rem;
	line-height: 1.45;
	color: var(--ces-text);
	margin-bottom: 0.5rem;
}

html[data-theme='dark'] .ces-plan-card__features li {
	color: #d1d5e0;
}

.ces-plan-check {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.1rem;
	height: 1.1rem;
	margin-top: 0.1rem;
	font-size: 0.65rem;
	font-weight: 700;
	color: #fff;
	background: linear-gradient(135deg, var(--ces-purple), var(--ces-blue));
	border-radius: 999px;
}

.ces-plan-card__actions {
	margin-top: auto;
}

.ces-login-page .ces-pay-continue,
.ces-login-page a.ces-pay-continue,
.ces-login-page button.ces-pay-continue {
	width: 100%;
	background: var(--ces-gradient) !important;
	border: none !important;
	color: #fff !important;
	font-weight: 700 !important;
	text-decoration: none !important;
	border-radius: 12px !important;
	min-height: 2.875rem !important;
	font-size: 0.95rem !important;
	box-shadow: 0 4px 14px rgba(102, 51, 153, 0.3);
	transition: transform 0.2s ease, filter 0.2s ease, box-shadow 0.2s ease !important;
}

.ces-login-page .ces-pay-continue:hover:not(:disabled),
.ces-login-page button.ces-pay-continue:hover:not(:disabled) {
	filter: brightness(1.08) !important;
	box-shadow: 0 6px 20px rgba(102, 51, 153, 0.45) !important;
}

.ces-login-page .ces-pay-continue:active,
.ces-login-page button.ces-pay-continue:active {
	transform: scale(0.98) !important;
}

.ces-plan-stripe {
	width: 100%;
	margin-top: 0.625rem;
	border-radius: 12px !important;
	min-height: 2.875rem !important;
	font-size: 0.95rem !important;
	font-weight: 600 !important;
	transition: transform 0.2s ease, background 0.2s ease !important;
}

.ces-plan-stripe:active {
	transform: scale(0.98) !important;
}

.ces-billing-signin {
	margin: 1.5rem 0 0;
	text-align: center;
	font-size: 0.875rem;
}

.ces-billing-trust {
	margin: 0.75rem 0 0;
	text-align: center;
	font-size: 0.7rem;
	line-height: 1.45;
	color: var(--ces-text-muted);
	opacity: 0.85;
}

html[data-theme='dark'] .ces-billing-trust {
	color: #6b7280;
}

.ces-billing-interval {
	display: flex;
	justify-content: center;
	gap: 0.25rem;
	margin: 0 auto 2rem;
	padding: 0.35rem;
	border-radius: 999px;
	background: rgba(51, 54, 150, 0.06);
	border: 1px solid rgba(51, 54, 150, 0.1);
	max-width: 21rem;
	box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.03);
}

html[data-theme='dark'] .ces-billing-interval {
	background: rgba(255, 255, 255, 0.04);
	border-color: rgba(255, 255, 255, 0.06);
	box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.2);
}

.ces-interval-btn {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.15rem;
	padding: 0.625rem 1rem;
	border: none;
	border-radius: 999px;
	background: transparent;
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--ces-text-muted);
	cursor: pointer;
	transition: background 0.3s cubic-bezier(0.16, 1, 0.3, 1), color 0.2s ease, box-shadow 0.3s ease, transform 0.2s ease;
}

.ces-interval-btn:active {
	transform: scale(0.97);
}

.ces-interval-btn--active {
	background: var(--ces-gradient);
	color: #fff !important;
	box-shadow: 
		0 4px 14px rgba(102, 51, 153, 0.3), 
		inset 0 1px 0 rgba(255, 255, 255, 0.2);
}

.ces-interval-save {
	font-size: 0.675rem;
	font-weight: 500;
	background: rgba(255, 255, 255, 0.2);
	padding: 0.05rem 0.35rem;
	border-radius: 4px;
	margin-top: 0.1rem;
}

.ces-billing-seats {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin-bottom: 2rem;
	padding: 1rem 1.5rem;
	border-radius: 16px;
	border: 1px solid rgba(102, 51, 153, 0.12);
	background: rgba(255, 255, 255, 0.5);
	backdrop-filter: blur(8px);
	box-shadow: 0 4px 20px rgba(51, 54, 150, 0.03);
}

html[data-theme='dark'] .ces-billing-seats {
	background: rgba(30, 34, 48, 0.6);
	border-color: rgba(184, 180, 232, 0.08);
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
}

.ces-billing-seats__label {
	font-size: 0.95rem;
	font-weight: 700;
	color: var(--ces-blue);
}

html[data-theme='dark'] .ces-billing-seats__label {
	color: #e8e6ff;
}

.ces-billing-seats__hint {
	font-weight: 400;
	color: var(--ces-text-muted);
	font-size: 0.8rem;
}

.ces-billing-seats__control {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.ces-seat-btn {
	width: 2.25rem;
	height: 2.25rem;
	border-radius: 10px;
	border: 1px solid rgba(102, 51, 153, 0.25);
	background: #fff;
	font-size: 1.25rem;
	font-weight: 600;
	color: var(--ces-purple);
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease;
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.03);
}

html[data-theme='dark'] .ces-seat-btn {
	background: rgba(24, 27, 38, 0.6);
	border-color: rgba(255, 255, 255, 0.1);
	color: #c4c0f0;
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
}

.ces-seat-btn:hover:not(:disabled) {
	background: rgba(102, 51, 153, 0.05);
	border-color: var(--ces-purple);
	transform: scale(1.05);
}

html[data-theme='dark'] .ces-seat-btn:hover:not(:disabled) {
	background: rgba(255, 255, 255, 0.08);
	border-color: rgba(184, 180, 232, 0.4);
}

.ces-seat-btn:active:not(:disabled) {
	transform: scale(0.95);
}

.ces-seat-btn:disabled {
	opacity: 0.3;
	cursor: not-allowed;
}

.ces-seat-input {
	width: 3.5rem;
	min-width: 3.5rem;
	text-align: center;
	font-size: 1.05rem;
	font-weight: 700;
	border: 1px solid rgba(102, 51, 153, 0.25);
	border-radius: 10px;
	padding: 0.45rem 0.25rem;
	background: #fff;
	color: var(--ces-blue);
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

html[data-theme='dark'] .ces-seat-input {
	background: rgba(24, 27, 38, 0.6);
	color: #f1f5f9;
	border-color: rgba(255, 255, 255, 0.1);
}

.ces-seat-input:focus {
	outline: none;
	border-color: var(--ces-purple);
	box-shadow: 0 0 0 3px rgba(102, 51, 153, 0.15);
}

html[data-theme='dark'] .ces-seat-input:focus {
	border-color: rgba(184, 180, 232, 0.5);
	box-shadow: 0 0 0 3px rgba(184, 180, 232, 0.2);
}

.ces-plan-storage {
	display: flex;
	align-items: baseline;
	justify-content: center;
	gap: 0.15rem;
	margin-bottom: 0.5rem;
}

.ces-plan-storage__value {
	font-size: 2.5rem;
	font-weight: 800;
	line-height: 1;
	background: var(--ces-gradient);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}

.ces-plan-storage__unit {
	font-size: 1rem;
	font-weight: 700;
	color: var(--ces-purple);
}

.ces-plan-billed {
	margin: -0.5rem 0 0.75rem;
	text-align: center;
	font-size: 0.75rem;
	color: var(--ces-text-muted);
}

.ces-plan-billed__seats {
	display: block;
	margin-top: 0.15rem;
}

.ces-billing-addon-hint {
	margin-top: 1rem;
	text-align: center;
	font-size: 0.75rem;
	color: var(--ces-text-muted);
}

.ces-plan-card--selected {
	border-color: var(--ces-purple);
}

#app a.text-blue-600,
#app .text-blue-600 {
	color: var(--ces-purple) !important;
}

/* Domain DNS detail page */
.ces-domain-overview__cta {
	background: var(--ces-gradient) !important;
	border: none !important;
	color: #fff !important;
}

.ces-domain-dns-header {
	background: linear-gradient(135deg, rgba(102, 51, 153, 0.06) 0%, rgba(51, 54, 153, 0.06) 100%);
}

/* Stays at top while scrolling DNS tables until domain + mandatory records verify */
.ces-domain-dns-header--pinned {
	position: sticky;
	top: 0;
	z-index: 30;
	margin-bottom: 1rem;
	border-bottom-width: 1px;
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
	backdrop-filter: blur(10px);
	background: linear-gradient(
		135deg,
		rgba(102, 51, 153, 0.1) 0%,
		rgba(51, 54, 153, 0.1) 100%
	);
}

html.dark .ces-domain-dns-header--pinned,
[data-theme="dark"] .ces-domain-dns-header--pinned {
	background: linear-gradient(
		135deg,
		rgba(31, 41, 55, 0.97) 0%,
		rgba(17, 24, 39, 0.97) 100%
	);
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.35);
}

.ces-domain-dns-header__ring {
	background: var(--surface-gray-2, #f3f4f6);
	box-shadow: inset 0 0 0 4px var(--surface-white, #fff);
}

.ces-domain-dns-header__ring-inner {
	display: flex;
	height: 2.75rem;
	width: 2.75rem;
	align-items: center;
	justify-content: center;
	border-radius: 9999px;
	background: var(--surface-gray-1, #1f2937);
}

.ces-dns-chip {
	border-color: var(--surface-gray-4, #6b7280);
	background: transparent;
}

.ces-dns-chip--ok {
	border-color: #16a34a;
	color: #4ade80;
}

.ces-dns-chip--fail {
	border-color: #dc2626;
	color: #f87171;
}

.ces-dns-chip--pending {
	color: var(--ces-text-muted, #9ca3af);
}

.ces-dns-row--failed {
	border-left: 3px solid #dc2626;
}

.ces-dns-section--highlight {
	animation: ces-dns-highlight 1.5s ease-out;
}

@keyframes ces-dns-highlight {
	0%,
	100% {
		background: transparent;
	}
	30% {
		background: rgba(220, 38, 38, 0.08);
	}
}

.ces-domain-sticky-bar {
	backdrop-filter: blur(8px);
}

.ces-domain-dns-header__ring span {
	position: relative;
	z-index: 1;
}

.ces-domain-dns-header__verify {
	background: var(--ces-gradient) !important;
	border: none !important;
	color: #fff !important;
}

.ces-domain-dns-header__verify:hover {
	color: #fff !important;
}

.ces-dns-table th {
	font-size: 0.7rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--ces-text-muted);
}

.ces-dns-section-verify {
	font-size: 0.75rem;
}

.ces-password-strength__track {
	background: var(--surface-gray-3, #4b5563);
}

.ces-password-strength--weak {
	background: #dc2626;
}

.ces-password-strength--fair {
	background: #f59e0b;
}

.ces-password-strength--good {
	background: #2ec4c6;
}

.ces-password-strength--strong {
	background: #16a34a;
}

.ces-add-member-advanced {
	background: var(--surface-gray-1, rgba(255, 255, 255, 0.03));
}

.ces-profile-cropper__stage {
	max-height: min(50vh, 360px);
}

.ces-profile-cropper .cropper-view-box,
.ces-profile-cropper .cropper-face {
	border-radius: 0;
}

.ces-domain-skeleton__bar {
	background: linear-gradient(
		90deg,
		var(--surface-gray-2, #eee) 25%,
		var(--surface-gray-3, #e5e7eb) 50%,
		var(--surface-gray-2, #eee) 75%
	);
	background-size: 200% 100%;
	animation: ces-skeleton-shimmer 1.2s ease-in-out infinite;
}

@keyframes ces-skeleton-shimmer {
	0% {
		background-position: 200% 0;
	}
	100% {
		background-position: -200% 0;
	}
}

@media print {
	.ces-sidebar,
	.ces-domain-overview button,
	.ces-domain-dns-header button,
	.ces-registrar-guide,
	header .ml-auto {
		display: none !important;
	}

	.ces-dns-records-print {
		border: none !important;
	}

	.ces-dns-section {
		break-inside: avoid;
	}

	.ces-dns-table {
		font-size: 10px;
	}
}

/* Frappe UI dialogs must sit above mail panes (sidebar, reading pane).
   Overlay wraps content; reka sets pointerdown.prevent on the overlay node.
   Disable hit-testing on the overlay shell, re-enable only on the panel. */
[data-reka-dialog-overlay],
.dialog-overlay {
	z-index: 1000 !important;
	pointer-events: none !important;
}

[data-reka-dialog-overlay] > *,
.dialog-overlay > * {
	pointer-events: none !important;
}

[data-reka-dialog-content],
.dialog-content,
.dialog-overlay [role='dialog'] {
	position: relative;
	z-index: 1001 !important;
	pointer-events: auto !important;
}

/* Inputs inside modals must stay interactive (overlay blocks focus via bubbled pointerdown) */
.dialog-content input,
.dialog-content textarea,
.dialog-content select,
.dialog-content button,
.dialog-content [data-slot='control'],
.dialog-content [role='combobox'] {
	pointer-events: auto !important;
}

/* Portaled Select / MultiSelect / Combobox / Dropdown menus (frappe-ui uses z-[100]; dialog is ~1001) */
.dropdown-content,
[data-slot='content'][data-selection],
[data-reka-combobox-content],
[data-reka-popover-content],
[data-reka-select-content],
[data-reka-dropdown-menu-content],
[data-reka-menu-content] {
	z-index: 1200 !important;
	pointer-events: auto !important;
	background: rgba(255, 255, 255, 0.72) !important;
	backdrop-filter: blur(25px) !important;
	-webkit-backdrop-filter: blur(25px) !important;
	border: 1px solid rgba(0, 0, 0, 0.05) !important;
	box-shadow: 0 10px 30px rgba(51, 54, 150, 0.08) !important;
	transition: background 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease !important;
}

html[data-theme='dark'] .dropdown-content,
html[data-theme='dark'] [data-slot='content'][data-selection],
html[data-theme='dark'] [data-reka-combobox-content],
html[data-theme='dark'] [data-reka-popover-content],
html[data-theme='dark'] [data-reka-select-content],
html[data-theme='dark'] [data-reka-dropdown-menu-content],
html[data-theme='dark'] [data-reka-menu-content] {
	background: rgba(24, 27, 38, 0.65) !important;
	border: 1px solid rgba(255, 255, 255, 0.08) !important;
	box-shadow: 0 12px 36px rgba(0, 0, 0, 0.35) !important;
}

/* When a dialog is open, ensure any portaled menu stacks above the modal panel */
body:has(.dialog-overlay[data-state='open']) [data-slot='content'][data-selection],
body:has(.dialog-overlay[data-state='open']) .dropdown-content,
body:has(.dialog-overlay[data-state='open']) [data-reka-dropdown-menu-content],
body:has(.dialog-overlay[data-state='open']) [data-reka-menu-content] {
	z-index: 1200 !important;
}

/* ==========================================================================
   Premium Glassmorphism & Animated Mesh Background Overhaul
   ========================================================================== */

/* 1. Immersive Animated Mesh Background */
.ces-mesh-bg {
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	overflow: hidden;
	background: #f8fafc;
	transition: background 0.5s ease;
}

html[data-theme='dark'] .ces-mesh-bg {
	background: #0f1016;
}

.ces-mesh-blob-1,
.ces-mesh-blob-2 {
	position: absolute;
	border-radius: 50%;
	filter: blur(80px);
	opacity: 0.12;
	mix-blend-mode: multiply;
	pointer-events: none;
	transition: all 0.5s ease;
}

html[data-theme='dark'] .ces-mesh-blob-1,
html[data-theme='dark'] .ces-mesh-blob-2 {
	opacity: 0.18;
	mix-blend-mode: screen;
}

/* Blob 1: Violet/Indigo drift */
.ces-mesh-blob-1 {
	top: -10%;
	left: -10%;
	width: 50vw;
	height: 50vw;
	background: radial-gradient(circle, rgba(102, 51, 153, 0.7) 0%, rgba(51, 54, 150, 0.3) 100%);
}

/* Blob 2: Cobalt/Teal drift */
.ces-mesh-blob-2 {
	bottom: -10%;
	right: -10%;
	width: 60vw;
	height: 60vw;
	background: radial-gradient(circle, rgba(46, 196, 198, 0.7) 0%, rgba(51, 54, 150, 0.3) 100%);
}

/* 2. Glassmorphism App Sidebar */
#sidebar,
.mail-sidebar,
.sidebar-container {
	background: rgba(255, 255, 255, 0.45) !important;
	backdrop-filter: blur(25px) !important;
	-webkit-backdrop-filter: blur(25px) !important;
	border-right: 1px solid rgba(0, 0, 0, 0.05) !important;
	transition: background 0.3s ease, border-color 0.3s ease !important;
}

html[data-theme='dark'] #sidebar,
html[data-theme='dark'] .mail-sidebar,
html[data-theme='dark'] .sidebar-container {
	background: rgba(15, 16, 22, 0.55) !important;
	border-right: 1px solid rgba(255, 255, 255, 0.07) !important;
}

/* Sidebar inner areas */
#sidebar .sidebar-items,
#sidebar .sidebar-sections {
	background: transparent !important;
}

/* Sidebar Logo Card Brand Lock - keep solid white card as contrast lock */
#sidebar .brand-logo,
#sidebar .ces-brand-logo,
#sidebar [data-slot="header-logo"] {
	background: #ffffff !important;
	border-radius: 12px !important;
	box-shadow: 0 4px 16px rgba(51, 54, 150, 0.08) !important;
	padding: 8px 12px !important;
	transition: all 0.3s ease;
}

html[data-theme='dark'] #sidebar .brand-logo,
html[data-theme='dark'] #sidebar .ces-brand-logo,
html[data-theme='dark'] #sidebar [data-slot="header-logo"] {
	background: #ffffff !important;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.25) !important;
}

/* Sidebar favicon white plate styling */
.ces-sidebar-logo {
	background: #ffffff !important;
	border-radius: 6px !important;
	padding: 2px !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 100% !important;
	height: 100% !important;
}

.ces-sidebar-logo img {
	width: 100% !important;
	height: 100% !important;
	object-fit: contain !important;
}

/* Tactile Active & Hover items as glowing frosted capsules */
#sidebar .sidebar-item,
#sidebar [role="button"].sidebar-item,
#sidebar a.sidebar-item {
	border-radius: 10px !important;
	margin: 2px 8px !important;
	transition: all 0.2s cubic-bezier(0.16, 1, 0.3, 1) !important;
	border: 1px solid transparent !important;
}

#sidebar .sidebar-item:hover {
	background: rgba(102, 51, 153, 0.06) !important;
	transform: translateY(-0.5px) scale(1.01);
	border-color: rgba(102, 51, 153, 0.08) !important;
}

html[data-theme='dark'] #sidebar .sidebar-item:hover {
	background: rgba(184, 180, 232, 0.08) !important;
	border-color: rgba(255, 255, 255, 0.05) !important;
}

/* Active sidebar item */
#sidebar .sidebar-item.is-active,
#sidebar .sidebar-item[aria-current="page"] {
	background: linear-gradient(135deg, rgba(102, 51, 153, 0.12) 0%, rgba(51, 54, 150, 0.08) 100%) !important;
	border-color: rgba(102, 51, 153, 0.15) !important;
	box-shadow: 
		0 4px 12px -2px rgba(102, 51, 153, 0.05),
		inset 0 1px rgba(255, 255, 255, 0.4) !important;
}

html[data-theme='dark'] #sidebar .sidebar-item.is-active,
html[data-theme='dark'] #sidebar .sidebar-item[aria-current="page"] {
	background: linear-gradient(135deg, rgba(184, 180, 232, 0.16) 0%, rgba(46, 196, 198, 0.08) 100%) !important;
	border-color: rgba(255, 255, 255, 0.12) !important;
	box-shadow: 
		0 4px 12px -2px rgba(0, 0, 0, 0.2),
		inset 0 1px rgba(255, 255, 255, 0.05) !important;
}

/* 3. Unified Translucent Topbar, Mail List Pane & Headers */
header.flex.items-center,
header.border-b,
.mail-header {
	background: rgba(255, 255, 255, 0.4) !important;
	backdrop-filter: blur(15px) !important;
	-webkit-backdrop-filter: blur(15px) !important;
	border-bottom: 1px solid rgba(0, 0, 0, 0.05) !important;
	transition: background 0.3s ease, border-color 0.3s ease !important;
}

html[data-theme='dark'] header.flex.items-center,
html[data-theme='dark'] header.border-b,
html[data-theme='dark'] .mail-header {
	background: rgba(15, 16, 22, 0.5) !important;
	border-bottom: 1px solid rgba(255, 255, 255, 0.07) !important;
}

/* Mail List Sidebar Pane (Left part of reading view) */
[ref="mailSidebar"],
.mail-list-pane,
div.sticky.top-16 {
	background: rgba(255, 255, 255, 0.3) !important;
	backdrop-filter: blur(20px) !important;
	-webkit-backdrop-filter: blur(20px) !important;
	border-right: 1px solid rgba(0, 0, 0, 0.05) !important;
	transition: background 0.3s ease, border-color 0.3s ease !important;
}

html[data-theme='dark'] [ref="mailSidebar"],
html[data-theme='dark'] .mail-list-pane,
html[data-theme='dark'] div.sticky.top-16 {
	background: rgba(15, 16, 22, 0.4) !important;
	border-right: 1px solid rgba(255, 255, 255, 0.07) !important;
}

/* Mail list toolbar container */
[ref="mailSidebar"] > div.flex.items-center.border-b {
	background: transparent !important;
	border-bottom: 1px solid rgba(0, 0, 0, 0.05) !important;
}

html[data-theme='dark'] [ref="mailSidebar"] > div.flex.items-center.border-b {
	border-bottom-color: rgba(255, 255, 255, 0.07) !important;
}

/* 4. Frosted Mail List Items & Micro-Animations */
.mail-list-item,
[ref="mailItems"],
div.border-b.cursor-pointer {
	background: transparent !important;
	transition: all 0.2s cubic-bezier(0.16, 1, 0.3, 1) !important;
	border-left: 3px solid transparent !important;
}

/* Hover state on list cards as glowing translucent capsules */
.mail-list-item:hover,
div.border-b.cursor-pointer:hover {
	background: rgba(102, 51, 153, 0.04) !important;
	transform: scale(0.995);
	box-shadow: 
		0 4px 12px rgba(51, 54, 150, 0.03),
		inset 0 1px rgba(255, 255, 255, 0.3) !important;
}

html[data-theme='dark'] .mail-list-item:hover,
html[data-theme='dark'] div.border-b.cursor-pointer:hover {
	background: rgba(255, 255, 255, 0.03) !important;
	box-shadow: 
		0 4px 12px rgba(0, 0, 0, 0.15),
		inset 0 1px rgba(255, 255, 255, 0.03) !important;
}

/* Active / Focused Mail List Card Highlight */
.mail-list-item.is-selected,
.mail-list-item[class*="bg-surface-blue-1"] {
	background: linear-gradient(135deg, rgba(102, 51, 153, 0.08) 0%, rgba(51, 54, 150, 0.05) 100%) !important;
	border-left-color: var(--ces-purple) !important;
	box-shadow: 
		0 6px 16px rgba(102, 51, 153, 0.05),
		inset 0 1px rgba(255, 255, 255, 0.5) !important;
}

html[data-theme='dark'] .mail-list-item.is-selected,
html[data-theme='dark'] .mail-list-item[class*="bg-surface-blue-1"] {
	background: linear-gradient(135deg, rgba(184, 180, 232, 0.1) 0%, rgba(46, 196, 198, 0.05) 100%) !important;
	border-left-color: var(--ces-teal) !important;
	box-shadow: 
		0 6px 16px rgba(0, 0, 0, 0.2),
		inset 0 1px rgba(255, 255, 255, 0.05) !important;
}

/* 5. Gorgeous Floating Mail Thread Viewer Card */
.bg-surface-white.overflow-y-auto:has(.mail-thread-container),
.mail-thread-pane {
	background: rgba(255, 255, 255, 0.45) !important;
	backdrop-filter: blur(25px) !important;
	-webkit-backdrop-filter: blur(25px) !important;
	box-shadow: 
		inset 1px 0 rgba(255, 255, 255, 0.4),
		-4px 0 24px rgba(51, 54, 150, 0.02) !important;
	transition: background 0.3s ease, box-shadow 0.3s ease !important;
}

html[data-theme='dark'] .bg-surface-white.overflow-y-auto:has(.mail-thread-container),
html[data-theme='dark'] .mail-thread-pane {
	background: rgba(15, 16, 22, 0.55) !important;
	box-shadow: 
		inset 1px 0 rgba(255, 255, 255, 0.05),
		-4px 0 24px rgba(0, 0, 0, 0.2) !important;
}

/* Maintain high legibility for actual email content cards (preserves readability) */
.mail-thread-body,
.email-content-card,
.email-content-wrapper {
	background: #ffffff !important;
	border-radius: 12px !important;
	border: 1px solid rgba(0, 0, 0, 0.04) !important;
	box-shadow: 0 4px 20px rgba(51, 54, 150, 0.04) !important;
	padding: 1.5rem !important;
	margin: 1rem 0 !important;
}

html[data-theme='dark'] .mail-thread-body,
html[data-theme='dark'] .email-content-card,
html[data-theme='dark'] .email-content-wrapper {
	background: #181a25 !important;
	border: 1px solid rgba(255, 255, 255, 0.05) !important;
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.3) !important;
}

/* ==========================================================================
   Premium Glassmorphism Overhaul for Dialog Modals
   ========================================================================== */

/* 1. Translucent Backdrop Overlay with soft blur */
[data-reka-dialog-overlay],
.dialog-overlay {
	background: rgba(255, 255, 255, 0.25) !important;
	backdrop-filter: blur(8px) !important;
	-webkit-backdrop-filter: blur(8px) !important;
	transition: background 0.3s ease, backdrop-filter 0.3s ease !important;
}

html[data-theme='dark'] [data-reka-dialog-overlay],
html[data-theme='dark'] .dialog-overlay {
	background: rgba(0, 0, 0, 0.4) !important;
	backdrop-filter: blur(8px) !important;
	-webkit-backdrop-filter: blur(8px) !important;
}

/* 2. Frosted Glassmorphism Modal Cards */
[data-reka-dialog-content],
.dialog-content,
.dialog-overlay [role='dialog'] {
	background: rgba(255, 255, 255, 0.72) !important;
	backdrop-filter: blur(30px) !important;
	-webkit-backdrop-filter: blur(30px) !important;
	border: 1px solid rgba(255, 255, 255, 0.5) !important;
	border-radius: 20px !important;
	box-shadow: 
		0 24px 64px rgba(51, 54, 150, 0.08), 
		inset 0 1px 1px rgba(255, 255, 255, 0.8) !important;
	transition: background 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease !important;
}

html[data-theme='dark'] [data-reka-dialog-content],
html[data-theme='dark'] .dialog-content,
html[data-theme='dark'] .dialog-overlay [role='dialog'] {
	background: rgba(24, 27, 38, 0.6) !important;
	border: 1px solid rgba(255, 255, 255, 0.08) !important;
	box-shadow: 
		0 32px 80px rgba(0, 0, 0, 0.35), 
		inset 0 1px 1px rgba(255, 255, 255, 0.04) !important;
}

/* Modal Title */
[data-reka-dialog-content] h1,
[data-reka-dialog-content] h2,
[data-reka-dialog-content] h3,
.dialog-content h1,
.dialog-content h2,
.dialog-content h3 {
	font-weight: 700 !important;
	color: var(--ces-blue) !important;
	letter-spacing: -0.02em !important;
}

html[data-theme='dark'] [data-reka-dialog-content] h1,
html[data-theme='dark'] [data-reka-dialog-content] h2,
html[data-theme='dark'] [data-reka-dialog-content] h3,
html[data-theme='dark'] .dialog-content h1,
html[data-theme='dark'] .dialog-content h2,
html[data-theme='dark'] .dialog-content h3 {
	color: #e8e6ff !important;
}

/* 3. Tactile Form Fields & Input elements inside modals */
.dialog-content .frappe-control input,
.dialog-content .frappe-control textarea,
.dialog-content input,
.dialog-content textarea,
.dialog-content select,
.dialog-content [role='combobox'] {
	border-radius: 12px !important;
	border: 1px solid rgba(51, 54, 150, 0.15) !important;
	background-color: rgba(255, 255, 255, 0.85) !important;
	font-size: 14px !important;
	min-height: 2.625rem !important;
	padding-left: 0.875rem !important;
	transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease !important;
}

html[data-theme='dark'] .dialog-content .frappe-control input,
html[data-theme='dark'] .dialog-content .frappe-control textarea,
html[data-theme='dark'] .dialog-content input,
html[data-theme='dark'] .dialog-content textarea,
html[data-theme='dark'] .dialog-content select,
html[data-theme='dark'] .dialog-content [role='combobox'] {
	border-color: rgba(255, 255, 255, 0.08) !important;
	background-color: rgba(18, 20, 28, 0.45) !important;
	color: #f1f5f9 !important;
}

/* Form field label text */
.dialog-content label {
	font-size: 0.8125rem !important;
	font-weight: 600 !important;
	color: var(--ces-blue) !important;
	letter-spacing: 0.01em !important;
	margin-bottom: 0.35rem !important;
}

html[data-theme='dark'] .dialog-content label {
	color: #c4c0f0 !important;
}

/* Focus Ring animation state */
.dialog-content input:focus,
.dialog-content textarea:focus,
.dialog-content [role='combobox']:focus {
	border-color: var(--ces-purple) !important;
	background-color: #fff !important;
	box-shadow: 0 0 0 4px rgba(102, 51, 153, 0.12) !important;
}

html[data-theme='dark'] .dialog-content input:focus,
html[data-theme='dark'] .dialog-content textarea:focus,
html[data-theme='dark'] .dialog-content [role='combobox']:focus {
	background-color: rgba(18, 20, 28, 0.75) !important;
	box-shadow: 0 0 0 4px rgba(102, 51, 153, 0.22) !important;
}

/* 4. Action Buttons Inside Modals */
.dialog-content button.btn-primary,
.dialog-content button[variant='solid'] {
	background: var(--ces-gradient) !important;
	border: none !important;
	color: #fff !important;
	border-radius: 10px !important;
	min-height: 2.5rem !important;
	font-weight: 600 !important;
	box-shadow: 0 4px 12px rgba(102, 51, 153, 0.3) !important;
	transition: transform 0.2s ease, filter 0.2s ease, box-shadow 0.2s ease !important;
}

.dialog-content button.btn-primary:hover,
.dialog-content button[variant='solid']:hover {
	filter: brightness(1.08) !important;
	transform: translateY(-0.5px) !important;
	box-shadow: 0 6px 16px rgba(102, 51, 153, 0.4) !important;
}

.dialog-content button.btn-primary:active,
.dialog-content button[variant='solid']:active {
	transform: scale(0.98) !important;
}

/* Close action icon button inside modals */
[data-reka-dialog-content] [aria-label="Close"],
.dialog-content [aria-label="Close"] {
	border-radius: 50% !important;
	transition: all 0.2s ease !important;
}

[data-reka-dialog-content] [aria-label="Close"]:hover,
.dialog-content [aria-label="Close"]:hover {
	background: rgba(102, 51, 153, 0.08) !important;
	transform: scale(1.08) !important;
}

html[data-theme='dark'] [data-reka-dialog-content] [aria-label="Close"]:hover,
html[data-theme='dark'] .dialog-content [aria-label="Close"]:hover {
	background: rgba(255, 255, 255, 0.08) !important;
}

/* Unlock modal glassmorphism by making inner solid containers transparent */
.dialog-content .bg-surface-modal,
.dialog-content > div {
	background-color: transparent !important;
}

/* High-contrast, premium styling for modal warning alerts */
.dialog-content .ces-modal-warning,
.dialog-content .bg-amber-50 {
	background-color: rgba(245, 158, 11, 0.1) !important;
	border: 1px solid rgba(245, 158, 11, 0.3) !important;
	color: #78350f !important;
}

.dialog-content .ces-modal-warning p,
.dialog-content .ces-modal-warning span,
.dialog-content .bg-amber-50 p,
.dialog-content .bg-amber-50 span {
	color: #78350f !important;
}

html[data-theme='dark'] .dialog-content .ces-modal-warning,
html[data-theme='dark'] .dialog-content .bg-amber-50 {
	background-color: rgba(245, 158, 11, 0.15) !important;
	border: 1px solid rgba(245, 158, 11, 0.4) !important;
	color: #fde047 !important; /* Bright high-contrast amber yellow */
}

html[data-theme='dark'] .dialog-content .ces-modal-warning p,
html[data-theme='dark'] .dialog-content .ces-modal-warning span,
html[data-theme='dark'] .dialog-content .bg-amber-50 p,
html[data-theme='dark'] .dialog-content .bg-amber-50 span {
	color: #fde047 !important;
}

/* 5. Styling of individual dropdown / combobox / select option items */
.dropdown-content [role="menuitem"],
[data-slot="content"] [role="option"],
[data-slot="content"] [data-slot="item"],
[data-reka-combobox-item],
[data-reka-select-item] {
	border-radius: 6px !important;
	margin: 2px 4px !important;
	transition: all 0.15s ease !important;
}

/* Hover / Highlight state on option items */
.dropdown-content [role="menuitem"]:hover,
.dropdown-content [role="menuitem"][data-highlighted],
[data-slot="content"] [role="option"]:hover,
[data-slot="content"] [role="option"][data-highlighted],
[data-reka-combobox-item][data-highlighted],
[data-reka-select-item][data-highlighted] {
	background-color: rgba(102, 51, 153, 0.08) !important;
	color: var(--ces-purple) !important;
}

html[data-theme='dark'] .dropdown-content [role="menuitem"]:hover,
html[data-theme='dark'] .dropdown-content [role="menuitem"][data-highlighted],
html[data-theme='dark'] [data-slot="content"] [role="option"]:hover,
html[data-theme='dark'] [data-slot="content"] [role="option"][data-highlighted],
html[data-theme='dark'] [data-reka-combobox-item][data-highlighted],
html[data-theme='dark'] [data-reka-select-item][data-highlighted] {
	background-color: rgba(184, 180, 232, 0.12) !important;
	color: #fde047 !important;
}

/* ==========================================================================
   Premium Tactile Recipient Inputs Overhaul (To/Cc/Bcc)
   ========================================================================== */

/* Style the recipient input wrapper to look premium and consistent */
.dialog-content [data-recipient-input],
[data-recipient-input] {
	border: 1px solid rgba(51, 54, 150, 0.15) !important;
	border-radius: 12px !important;
	background-color: rgba(255, 255, 255, 0.8) !important;
	padding: 4px 8px !important;
	min-height: 2.625rem !important;
	transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease !important;
	cursor: text !important;
}

html[data-theme='dark'] .dialog-content [data-recipient-input],
html[data-theme='dark'] [data-recipient-input] {
	border-color: rgba(255, 255, 255, 0.08) !important;
	background-color: rgba(18, 20, 28, 0.45) !important;
}

/* Focused recipient input container state */
.dialog-content [data-recipient-input]:focus-within,
[data-recipient-input]:focus-within {
	border-color: var(--ces-purple) !important;
	background-color: #fff !important;
	box-shadow: 0 0 0 4px rgba(102, 51, 153, 0.12) !important;
}

html[data-theme='dark'] .dialog-content [data-recipient-input]:focus-within,
html[data-theme='dark'] [data-recipient-input]:focus-within {
	background-color: rgba(18, 20, 28, 0.75) !important;
	box-shadow: 0 0 0 4px rgba(102, 51, 153, 0.22) !important;
}

/* Reset recipient inner input elements to prevent them from taking on global modal input styles */
.dialog-content [data-recipient-input] input,
.dialog-content [data-recipient-input] [role="combobox"],
[data-recipient-input] input,
[data-recipient-input] [role="combobox"] {
	border: none !important;
	background-color: transparent !important;
	background: transparent !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	min-height: unset !important;
	height: auto !important;
	padding: 4px 4px !important;
	width: auto !important;
	flex: 1 1 120px !important; /* Grow and stretch to occupy available horizontal space beautifully */
}

/* Style recipient capsule tags beautifully */
[data-recipient-input] button,
[data-recipient-input] [role="button"] {
	background-color: rgba(102, 51, 153, 0.06) !important;
	border: 1px solid rgba(102, 51, 153, 0.1) !important;
	color: var(--ces-purple) !important;
	border-radius: 8px !important;
	padding: 2px 8px !important;
	font-weight: 500 !important;
	font-size: 13px !important;
	transition: all 0.2s ease !important;
}

html[data-theme='dark'] [data-recipient-input] button,
html[data-theme='dark'] [data-recipient-input] [role="button"] {
	background-color: rgba(184, 180, 232, 0.12) !important;
	border-color: rgba(255, 255, 255, 0.05) !important;
	color: #e8e6ff !important;
}

[data-recipient-input] button:hover,
[data-recipient-input] [role="button"]:hover {
	background-color: rgba(102, 51, 153, 0.1) !important;
	transform: scale(1.02) !important;
}

html[data-theme='dark'] [data-recipient-input] button:hover,
html[data-theme='dark'] [data-recipient-input] [role="button"]:hover {
	background-color: rgba(18, 20, 28, 0.18) !important;
}

/* Bulletproof reset to eliminate double borders, shadows, or outlines on the inner combobox, input, and focus states */
body #modals .dialog-content [data-recipient-input] [data-slot="trigger"],
body #modals .dialog-content [data-recipient-input] [data-slot="trigger"] *,
body #modals .dialog-content [data-recipient-input] [data-slot="trigger"]:focus,
body #modals .dialog-content [data-recipient-input] [data-slot="trigger"]:focus-within,
body #modals .dialog-content [data-recipient-input] [data-slot="trigger"]:active,
body #modals .dialog-content [data-recipient-input] [data-slot="input"],
body #modals .dialog-content [data-recipient-input] [data-slot="input"]:focus,
body #modals .dialog-content [data-recipient-input] [data-slot="input"]:active,
body #modals .dialog-content [data-recipient-input] [role="combobox"],
body #modals .dialog-content [data-recipient-input] [role="combobox"]:focus,
body #modals .dialog-content [data-recipient-input] [role="combobox"]:active,
body #app .dialog-content [data-recipient-input] [data-slot="trigger"],
body #app .dialog-content [data-recipient-input] [data-slot="trigger"] *,
body #app .dialog-content [data-recipient-input] [data-slot="trigger"]:focus,
body #app .dialog-content [data-recipient-input] [data-slot="trigger"]:focus-within,
body #app .dialog-content [data-recipient-input] [data-slot="trigger"]:active,
body #app .dialog-content [data-recipient-input] [data-slot="input"],
body #app .dialog-content [data-recipient-input] [data-slot="input"]:focus,
body #app .dialog-content [data-recipient-input] [data-slot="input"]:active,
body #app .dialog-content [data-recipient-input] [role="combobox"],
body #app .dialog-content [data-recipient-input] [role="combobox"]:focus,
body #app .dialog-content [data-recipient-input] [role="combobox"]:active,
body [data-recipient-input] [data-slot="trigger"],
body [data-recipient-input] [data-slot="trigger"] *,
body [data-recipient-input] [data-slot="trigger"]:focus,
body [data-recipient-input] [data-slot="trigger"]:focus-within,
body [data-recipient-input] [data-slot="trigger"]:active,
body [data-recipient-input] [data-slot="input"],
body [data-recipient-input] [data-slot="input"]:focus,
body [data-recipient-input] [data-slot="input"]:active,
body [data-recipient-input] [role="combobox"],
body [data-recipient-input] [role="combobox"]:focus,
body [data-recipient-input] [role="combobox"]:active,
.dialog-content [data-recipient-input] [data-slot="trigger"],
.dialog-content [data-recipient-input] [data-slot="trigger"] *,
.dialog-content [data-recipient-input] [data-slot="input"],
.dialog-content [data-recipient-input] [data-slot="input"]:focus,
.dialog-content [data-recipient-input] [role="combobox"],
.dialog-content [data-recipient-input] [role="combobox"]:focus,
[data-recipient-input] [data-slot="trigger"],
[data-recipient-input] [data-slot="trigger"] *,
[data-recipient-input] [data-slot="trigger"]:focus,
[data-recipient-input] [data-slot="trigger"]:focus-within,
[data-recipient-input] [data-slot="trigger"]:active,
[data-recipient-input] [data-slot="input"],
[data-recipient-input] [data-slot="input"]:focus,
[data-recipient-input] [data-slot="input"]:active,
[data-recipient-input] [role="combobox"],
[data-recipient-input] [role="combobox"]:focus,
[data-recipient-input] [role="combobox"]:active {
	border: none !important;
	border-width: 0px !important;
	border-color: transparent !important;
	outline: none !important;
	box-shadow: none !important;
	--tw-ring-color: transparent !important;
	--tw-ring-shadow: none !important;
	--tw-ring-width: 0px !important;
	background-color: transparent !important;
	background: transparent !important;
	min-height: unset !important;
}

/* ==========================================================================
   Premium Lined Compose Editor Headers (From, To, Cc, Bcc, Subject)
   ========================================================================== */

/* Remove standard dialog box borders/backgrounds on compose headers */
.ces-from-combobox,
.ces-from-combobox [data-slot="trigger"],
.ces-from-combobox [data-slot="input"],
.ces-from-combobox input,
.ces-from-combobox button,
.ces-recipient-input,
.ces-recipient-input [data-slot="trigger"],
.ces-recipient-input [data-slot="input"],
.ces-recipient-input input,
.ces-recipient-input .recipient-combobox,
.ces-subject-input,
body .dialog-content .ces-from-combobox,
body .dialog-content .ces-from-combobox [data-slot="trigger"],
body .dialog-content .ces-from-combobox [data-slot="input"],
body .dialog-content .ces-from-combobox input,
body .dialog-content .ces-recipient-input,
body .dialog-content .ces-recipient-input [data-slot="trigger"],
body .dialog-content .ces-recipient-input [data-slot="input"],
body .dialog-content .ces-recipient-input input,
body .dialog-content .ces-recipient-input .recipient-combobox,
body .dialog-content .ces-subject-input {
	border: none !important;
	border-width: 0px !important;
	border-color: transparent !important;
	background-color: transparent !important;
	background: transparent !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	outline: none !important;
	--tw-ring-color: transparent !important;
	--tw-ring-shadow: none !important;
	--tw-ring-width: 0px !important;
}

/* Override hover, focus, focus-within, focus-visible, and active/open states */
.ces-from-combobox:focus,
.ces-from-combobox:focus-within,
.ces-from-combobox [data-slot="trigger"]:focus,
.ces-from-combobox [data-slot="trigger"]:focus-within,
.ces-from-combobox [data-slot="trigger"]:focus-visible,
.ces-from-combobox [data-slot="trigger"][data-state="open"],
.ces-from-combobox [data-slot="input"]:focus,
.ces-from-combobox [data-slot="input"]:focus-visible,
.ces-from-combobox input:focus,
.ces-from-combobox input:focus-visible,
.ces-recipient-input:focus,
.ces-recipient-input:focus-within,
.ces-recipient-input [data-slot="trigger"]:focus,
.ces-recipient-input [data-slot="trigger"]:focus-within,
.ces-recipient-input [data-slot="trigger"]:focus-visible,
.ces-recipient-input [data-slot="trigger"][data-state="open"],
.ces-recipient-input [data-slot="input"]:focus,
.ces-recipient-input [data-slot="input"]:focus-visible,
.ces-recipient-input input:focus,
.ces-recipient-input input:focus-visible,
.ces-subject-input:focus,
.ces-subject-input:focus-visible,
body .dialog-content .ces-from-combobox:focus-within,
body .dialog-content .ces-from-combobox [data-slot="trigger"]:focus-within,
body .dialog-content .ces-recipient-input:focus-within,
body .dialog-content .ces-recipient-input [data-slot="trigger"]:focus-within {
	border: none !important;
	border-width: 0px !important;
	border-color: transparent !important;
	background-color: transparent !important;
	background: transparent !important;
	box-shadow: none !important;
	outline: none !important;
	--tw-ring-color: transparent !important;
	--tw-ring-shadow: none !important;
	--tw-ring-width: 0px !important;
}

/* Prevent height collapse and set standard sizes for fields */
.ces-subject-input {
	height: 2.25rem !important;
	line-height: 2.25rem !important;
	min-height: 2.25rem !important;
	padding: 0 0.25rem !important;
}

.ces-from-combobox [data-slot="trigger"],
body .dialog-content .ces-from-combobox [data-slot="trigger"] {
	min-height: 2.25rem !important;
	height: 2.25rem !important;
	padding: 0 0.5rem !important;
	cursor: pointer !important;
}

.ces-recipient-input [data-slot="trigger"],
body .dialog-content .ces-recipient-input [data-slot="trigger"] {
	min-height: 2.25rem !important;
	height: auto !important;
	padding: 0.25rem 0.5rem !important;
}

.ces-recipient-input input[data-slot="input"],
.ces-recipient-input input,
body .dialog-content .ces-recipient-input input[data-slot="input"],
body .dialog-content .ces-recipient-input input {
	height: 1.75rem !important;
	min-height: 1.75rem !important;
	padding: 0 0.25rem !important;
}

/* Style the rows */
.ces-composer-row {
	display: flex;
	align-items: center;
	border-bottom: 1px solid rgba(0, 0, 0, 0.08) !important;
	padding-top: 0.5rem !important;
	padding-bottom: 0.5rem !important;
	min-height: 2.75rem !important;
	transition: border-color 0.2s ease !important;
}

html[data-theme='dark'] .ces-composer-row {
	border-bottom-color: rgba(255, 255, 255, 0.08) !important;
}

.ces-composer-row:focus-within {
	border-bottom-color: var(--ces-purple) !important;
}

/* Align labels */
.ces-composer-label {
	width: 4.5rem !important; /* 72px width */
	flex-shrink: 0 !important;
	font-size: 0.875rem !important;
	font-weight: 500 !important;
	color: var(--ces-text-muted, #6b7280) !important;
	user-select: none !important;
}

/* Style the recipient input wrapper to look completely borderless inside compose rows */
.dialog-content .ces-recipient-input,
.ces-recipient-input {
	border: none !important;
	border-radius: 0 !important;
	background-color: transparent !important;
	box-shadow: none !important;
	padding: 0 !important;
	min-height: unset !important;
}

.dialog-content .ces-recipient-input:focus-within,
.ces-recipient-input:focus-within {
	border: none !important;
	background-color: transparent !important;
	box-shadow: none !important;
}

/* Premium solid update seats button */
.ces-update-seats-btn,
body .ces-update-seats-btn {
	background: var(--ces-gradient) !important;
	color: #ffffff !important;
	font-weight: 600 !important;
	border: none !important;
	box-shadow: 0 2px 8px rgba(102, 51, 153, 0.3) !important;
	transition: filter 0.2s ease, box-shadow 0.2s ease, transform 0.1s ease !important;
}

.ces-update-seats-btn:hover:not(:disabled),
body .ces-update-seats-btn:hover:not(:disabled) {
	filter: brightness(1.08) !important;
	box-shadow: 0 4px 12px rgba(102, 51, 153, 0.45) !important;
	cursor: pointer !important;
}

.ces-update-seats-btn:active:not(:disabled),
body .ces-update-seats-btn:active:not(:disabled) {
	transform: scale(0.97) !important;
}

.ces-update-seats-btn:disabled,
body .ces-update-seats-btn:disabled {
	opacity: 0.6 !important;
	cursor: not-allowed !important;
}
