@import url("https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Outfit:wght@600;700;800&display=swap");

:root {
	--font-brand-body: "Manrope", "Segoe UI", sans-serif;
	--font-brand-display: "Outfit", "Segoe UI", sans-serif;
	--ui-fs-xs: 0.84rem;
	--ui-fs-sm: 0.92rem;
	--ui-fs-md: 0.98rem;
	--ui-fs-lg: 1.06rem;
	--ui-fs-xl: 1.24rem;
	--navy: #1c2738;
	--navy-soft: #2f3d55;
	--accent: #fab41b;
	--accent-strong: #cb860a;
	--ink: #1b2433;
	--muted: #566176;
	--surface: #ffffff;
	--surface-alt: #edf2f9;
	--page-bg: #f4f7fc;
	--surface-hover: #e8edf5;
	--line: #d5ddeb;
	--line-mid: #c8d5e8;
	--topbar-from: #1f2b3f;
	--topbar-to: #172236;
	--footer-bg: #0f1726;
	--footer-text: #edf3ff;
	--footer-muted: #9fb4ce;
	--footer-link: #b4c3db;
	--success: #247a45;
	--danger: #b42318;
}

body.avalon-client {
	background: var(--page-bg);
	color: var(--ink);
	font-family: var(--font-brand-body);
	font-size: var(--ui-fs-md);
}

body.avalon-client .sidebar .panel-title,
body.avalon-client .sidebar .card-header h3,
body.avalon-client .sidebar .card-sidebar .panel-title {
	font-size: var(--ui-fs-lg) !important;
	font-weight: 700;
	line-height: 1.3;
}

body.avalon-client .sidebar .list-group-item,
body.avalon-client .sidebar .list-group-item-action {
	font-size: var(--ui-fs-md) !important;
	line-height: 1.45;
	padding: 0.66rem 0.85rem;
}

body.avalon-client h1,
body.avalon-client h2,
body.avalon-client h3,
body.avalon-client h4,
body.avalon-client h5,
body.avalon-client h6 {
	font-family: var(--font-brand-display);
	color: var(--navy);
}

/* Force branded typography across WHMCS UI components */
body.avalon-client,
body.avalon-client p,
body.avalon-client span,
body.avalon-client small,
body.avalon-client li,
body.avalon-client label,
body.avalon-client a,
body.avalon-client button,
body.avalon-client input,
body.avalon-client select,
body.avalon-client textarea,
body.avalon-client option,
body.avalon-client .btn,
body.avalon-client .dropdown-item,
body.avalon-client .form-control,
body.avalon-client .custom-select,
body.avalon-client .input-group-text,
body.avalon-client .card,
body.avalon-client .panel,
body.avalon-client .modal,
body.avalon-client .table,
body.avalon-client .nav,
body.avalon-client .navbar,
body.avalon-client .list-group,
body.avalon-client .alert,
body.avalon-client .badge,
body.avalon-client .breadcrumb {
	font-family: var(--font-brand-body) !important;
}

/* Keep icon fonts from being overridden by global brand typography rule */
body.avalon-client .fa,
body.avalon-client .fas,
body.avalon-client .far,
body.avalon-client .fal,
body.avalon-client .fad {
	font-family:
		"Font Awesome 5 Pro", "Font Awesome 5 Free", "Font Awesome 6 Free" !important;
	font-style: normal;
}

body.avalon-client .fab,
body.avalon-client .fa-brands {
	font-family: "Font Awesome 5 Brands", "Font Awesome 6 Brands" !important;
	font-style: normal;
	font-weight: 400;
}

body.avalon-client h1,
body.avalon-client h2,
body.avalon-client h3,
body.avalon-client h4,
body.avalon-client h5,
body.avalon-client h6,
body.avalon-client .h1,
body.avalon-client .h2,
body.avalon-client .h3,
body.avalon-client .h4,
body.avalon-client .h5,
body.avalon-client .h6,
body.avalon-client .panel-title,
body.avalon-client .card-title,
body.avalon-client .modal-title,
body.avalon-client .page-header,
body.avalon-client .header-lined h1 {
	font-family: var(--font-brand-display) !important;
}

.avalon-header-shell .topbar {
	background: linear-gradient(120deg, var(--topbar-from), var(--topbar-to));
	border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.avalon-header-shell .topbar .btn,
.avalon-header-shell .topbar .topbar-link {
	color: #e8efff;
	font-size: 0.86rem;
	font-weight: 600;
	letter-spacing: 0.01em;
}

.avalon-header-shell .topbar .topbar-link {
	text-decoration: none;
	opacity: 0.92;
	padding: 0.65rem 0;
}

.avalon-header-shell .topbar .topbar-link + .topbar-link {
	margin-left: 1rem;
}

.avalon-header-shell .topbar .topbar-link:hover,
.avalon-header-shell .topbar .btn:hover {
	color: #ffffff;
	opacity: 1;
}

.avalon-header-shell .navbar.navbar-light {
	background: var(--surface);
	box-shadow: 0 10px 24px rgba(18, 36, 69, 0.08);
}

.avalon-header-shell .navbar-brand {
	margin-right: 1.4rem;
}

.avalon-header-shell .logo-img {
	max-height: 52px;
}

.avalon-header-shell .search .form-control,
.avalon-header-shell .search .btn {
	border-color: var(--line-mid);
	background: var(--surface-alt);
}

.avalon-header-shell .search .form-control {
	color: var(--ink);
	font-weight: 500;
}

.avalon-header-shell .search .btn {
	color: var(--navy-soft);
}

#header.avalon-header-shell .toolbar .cart-btn {
	align-items: center;
	background: var(--surface-alt);
	border: 1px solid var(--line);
	border-radius: 0.7rem;
	color: var(--navy);
	display: inline-flex;
	justify-content: center;
	min-width: 3.25rem;
	overflow: visible;
	padding: 0.5rem 0.85rem;
	position: relative;
}

#header.avalon-header-shell .toolbar .cart-btn,
#header.avalon-header-shell .toolbar .cart-btn:visited,
#header.avalon-header-shell .toolbar .cart-btn:hover,
#header.avalon-header-shell .toolbar .cart-btn:focus {
	border-color: var(--line);
	color: var(--navy);
	text-decoration: none;
}

#header.avalon-header-shell .toolbar .cart-btn i {
	color: currentColor;
	font-size: 1rem;
	line-height: 1;
}

#header.avalon-header-shell .toolbar .badge-info {
	background: var(--accent);
	border: 1px solid rgba(28, 39, 56, 0.2);
	color: var(--navy);
	font-size: 0.75rem;
	font-weight: 800;
	line-height: 1;
	opacity: 1;
	position: absolute;
	right: -0.35rem;
	top: -0.42rem;
	z-index: 3;
}

#header.avalon-header-shell .toolbar .cart-btn #cartItemCount {
	align-items: center;
	border-radius: 999px;
	box-shadow: 0 2px 8px rgba(20, 31, 49, 0.22);
	display: inline-flex;
	justify-content: center;
	min-height: 1.32rem;
	min-width: 1.32rem;
	padding: 0.18rem 0.38rem;
}

.avalon-header-shell .main-navbar-wrapper {
	background: var(--surface);
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
}

.avalon-header-shell #nav > li > a,
.avalon-header-shell .main-navbar-wrapper .navbar-nav > li > a {
	color: var(--navy-soft);
	font-size: 0.95rem;
	font-weight: 700;
	padding: 0.9rem 0.7rem;
	transition: color 0.18s ease;
}

.avalon-header-shell #nav > li:hover > a,
.avalon-header-shell .main-navbar-wrapper .navbar-nav > li:hover > a,
.avalon-header-shell #nav > li > a:focus,
.avalon-header-shell .main-navbar-wrapper .navbar-nav > li > a:focus {
	color: var(--navy);
}

.avalon-header-shell .dropdown-menu {
	border: 1px solid var(--line-mid);
	border-radius: 0.9rem;
	box-shadow: 0 16px 30px rgba(23, 37, 63, 0.14);
	padding: 0.55rem;
}

.avalon-header-shell .dropdown-item {
	border-radius: 0.56rem;
	color: var(--navy-soft);
	font-weight: 600;
	padding: 0.52rem 0.7rem;
}

.avalon-header-shell .dropdown-item:hover,
.avalon-header-shell .dropdown-item:focus {
	color: var(--navy);
	background: var(--surface-hover);
}

.avalon-header-shell .dropdown-item.active,
.avalon-header-shell .dropdown-item:active {
	background: rgba(250, 180, 27, 0.18);
	color: var(--navy);
}

#footer.avalon-footer {
	background:
		radial-gradient(circle at 20% 0%, rgba(63, 90, 139, 0.18), transparent 46%),
		var(--footer-bg);
	color: var(--footer-text);
	font-size: 0.95rem;
	margin: 3rem 0 0;
	overflow: hidden;
	padding: 1.6rem 0 1.4rem;
	position: relative;
}

#footer.avalon-footer::before {
	background: linear-gradient(90deg, rgba(250, 180, 27, 0.2), transparent 62%);
	content: "";
	height: 2px;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

#footer.avalon-footer p,
#footer.avalon-footer li,
#footer.avalon-footer span {
	color: var(--footer-muted);
}

#footer.avalon-footer .container {
	position: relative;
	z-index: 1;
}

.avalon-footer-newsletter {
	background: linear-gradient(
		160deg,
		rgba(26, 38, 61, 0.95),
		rgba(20, 31, 49, 0.9)
	);
	border: 1px solid rgba(180, 195, 219, 0.24);
	border-top: 3px solid var(--accent);
	border-radius: 1rem;
	box-shadow: 0 20px 40px rgba(8, 15, 30, 0.3);
	margin-bottom: 2rem;
	padding: 1.3rem 1.4rem;
}

.avalon-footer-kicker {
	color: var(--accent);
	font-size: 0.77rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	margin-bottom: 0.25rem;
	text-transform: uppercase;
}

#footer.avalon-footer .avalon-footer-newsletter h3 {
	color: #f5f8ff;
	font-family: "Outfit", "Segoe UI", sans-serif;
	font-size: clamp(1.25rem, 1.1rem + 0.55vw, 1.62rem);
	font-weight: 700;
	line-height: 1.24;
	margin-bottom: 0.5rem;
}

.avalon-footer-newsletter p {
	color: var(--footer-muted);
	margin-bottom: 0;
}

#footer.avalon-footer .btn-accent {
	background: var(--accent);
	border: 0;
	border-radius: 0.66rem;
	color: var(--navy);
	font-weight: 800;
	padding: 0.72rem 1rem;
}

#footer.avalon-footer .btn-accent:hover,
#footer.avalon-footer .btn-accent:focus {
	background: var(--accent-strong);
	color: #ffffff;
}

.avalon-footer-grid {
	display: grid;
	gap: 1.8rem 2rem;
	grid-template-columns: minmax(280px, 1.05fr) minmax(0, 1.95fr);
}

.avalon-footer .footer-brand {
	display: flex;
	flex-direction: column;
	max-width: 31rem;
}

.avalon-footer .footer-brand-logo-link {
	display: inline-flex;
	margin-bottom: 0.72rem;
	text-decoration: none;
}

.avalon-footer .footer-brand-logo {
	filter: brightness(0) invert(1);
	height: auto;
	max-height: 2.8rem;
	max-width: min(16rem, 100%);
	opacity: 0.96;
	width: auto;
}

.avalon-footer .footer-nav-cluster {
	display: grid;
	gap: 1.55rem;
}

.avalon-footer .footer-nav-row {
	display: grid;
	gap: 1.25rem 1.45rem;
}

.avalon-footer .footer-nav-row-primary {
	grid-template-columns: repeat(3, minmax(180px, 1fr));
}

.avalon-footer .footer-nav-row-secondary {
	grid-template-columns: repeat(2, minmax(180px, 1fr));
}

.avalon-footer .footer-heading {
	color: #f4f8ff;
	font-size: 0.94rem;
	font-weight: 700;
	margin-bottom: 0.8rem;
}

#footer.avalon-footer .footer-menu .footer-heading {
	align-items: center;
	color: #f4f8ff !important;
	display: inline-flex;
	font-family: var(--font-brand-display);
	font-size: 0.82rem;
	font-weight: 800;
	letter-spacing: 0.08em;
	margin-bottom: 0.72rem;
	position: relative;
	text-transform: uppercase;
}

#footer.avalon-footer .footer-menu .footer-heading::after {
	background: linear-gradient(
		90deg,
		rgba(250, 180, 27, 0.85),
		rgba(250, 180, 27, 0)
	);
	border-radius: 999px;
	content: "";
	height: 2px;
	left: 0;
	position: absolute;
	top: calc(100% + 0.18rem);
	width: 2.2rem;
}

.avalon-footer .footer-brand .footer-heading {
	font-size: 1.03rem;
	margin-bottom: 0.64rem;
}

.avalon-footer .footer-brand p,
.avalon-footer .footer-meta {
	color: var(--footer-muted);
	font-size: 0.92rem;
}

.avalon-footer .playstore-link {
	display: inline-block;
	margin: 0.12rem 0 0.76rem;
	text-decoration: none;
}

.avalon-footer .playstore-image {
	display: block;
	height: auto;
	max-width: 100%;
	object-fit: contain;
	transition: transform 0.2s cubic-bezier(0.16, 1, 0.3, 1);
	width: min(180px, 100%);
}

.avalon-footer .playstore-link:hover .playstore-image,
.avalon-footer .playstore-link:focus .playstore-image {
	transform: scale(1.02);
}

.avalon-footer .footer-payment {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 0.25rem;
	justify-content: flex-end;
	margin: 0.55rem 0 0.6rem;
	min-width: 0;
	width: 100%;
}

.avalon-footer .payment-method {
	align-items: center;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(180, 195, 219, 0.2);
	border-radius: 0.48rem;
	display: inline-flex;
	height: 1.92rem;
	justify-content: center;
	padding: 0.2rem;
	width: 1.92rem;
}

.avalon-footer .payment-icon {
	height: 1.34rem;
	width: 1.34rem;
}

.avalon-footer .payment-icon-bank-transfer {
	height: 1.16rem;
	width: 1.16rem;
}

.avalon-footer .footer-links {
	list-style: none;
	margin: 0;
	padding: 0;
}

.avalon-footer .footer-links li + li {
	margin-top: 0.46rem;
}

.avalon-footer .footer-links a {
	color: var(--footer-link);
	display: inline-block;
	font-size: 0.9rem;
	font-weight: 600;
	line-height: 1.35;
	text-decoration: none;
	transition: color 0.16s ease;
}

.avalon-footer .footer-links a:hover,
.avalon-footer .footer-links a:focus {
	color: #f5f9ff;
	text-decoration: none;
}

.avalon-footer .footer-status {
	color: #9ee8b9;
	font-weight: 600;
}

.avalon-footer-bottom {
	border-top: 1px solid rgba(180, 195, 219, 0.2);
	color: var(--footer-muted);
	font-size: 0.84rem;
	margin-top: 1.8rem;
	padding: 1rem 0 1.2rem;
}

.avalon-footer .social-list-inline {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.avalon-footer .social-list-inline .list-inline-item {
	margin-right: 0 !important;
}

#footer.avalon-footer .social-list-inline .btn.btn-icon {
	align-items: center;
	display: inline-flex;
	gap: 0;
	border: 1px solid rgba(180, 195, 219, 0.25);
	border-radius: 0.62rem;
	color: var(--footer-link);
	font-size: 0.9rem;
	line-height: 1.2;
	overflow: visible;
	padding: 0;
	height: 2rem;
	justify-content: center;
	min-width: 2rem;
	width: 2rem;
}

#footer.avalon-footer .social-list-inline .btn.btn-icon i {
	font-size: 0.92rem;
	line-height: 1;
}

#footer.avalon-footer .social-list-inline .btn.btn-icon:hover {
	border-color: rgba(250, 180, 27, 0.5);
	color: #ffffff;
}

/* Footer social: show X mark for Twitter link */
#footer.avalon-footer .social-list-inline .btn.btn-icon i.fab.fa-twitter {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 0;
	line-height: 1;
	min-width: 0.9rem;
}

#footer.avalon-footer
	.social-list-inline
	.btn.btn-icon
	i.fab.fa-twitter::before {
	content: "X";
	font-family: var(--font-brand-display);
	font-size: 0.82rem;
	font-style: normal;
	font-weight: 800;
	line-height: 1;
}

#footer.avalon-footer .localization-btn {
	background: rgba(159, 180, 206, 0.08);
	border: 1px solid rgba(180, 195, 219, 0.28);
	border-radius: 0.62rem;
	color: var(--footer-link);
	font-size: 0.84rem;
	font-weight: 600;
	min-height: 2.06rem;
	white-space: nowrap;
}

#footer.avalon-footer .localization-btn .iti-flag {
	box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.2);
	flex: 0 0 auto;
	transform: translateY(-0.5px);
}

#footer.avalon-footer .localization-btn .localization-label {
	display: inline-block;
	font-weight: 600;
	line-height: 1.2;
}

#footer.avalon-footer .localization-btn:hover,
#footer.avalon-footer .localization-btn:focus {
	background: rgba(159, 180, 206, 0.14);
	color: #eef5ff;
}

.avalon-client .master-breadcrumb {
	background: transparent;
}

.avalon-client .master-breadcrumb .breadcrumb {
	background: #f7faff;
	border: 1px solid var(--line);
	border-radius: 0.72rem;
	margin-top: 0.7rem;
	padding: 0.62rem 0.92rem;
}

.avalon-client .master-breadcrumb .breadcrumb-item,
.avalon-client .master-breadcrumb .breadcrumb-item a {
	color: var(--muted);
	font-weight: 600;
}

/* Global Avalon button system */
.avalon-client .btn.btn-primary,
.avalon-client input.btn.btn-primary,
.avalon-client button.btn.btn-primary {
	background: linear-gradient(135deg, var(--accent), #f8c44f);
	border: 0;
	border-radius: 0.68rem;
	box-shadow: 0 9px 20px rgba(203, 134, 10, 0.24);
	color: var(--navy);
	font-size: 1rem;
	font-weight: 800;
	line-height: 1.2;
	min-height: 2.7rem;
	padding: 0.54rem 1.12rem;
	text-transform: none;
	transition:
		background-color 0.16s ease,
		border-color 0.16s ease,
		box-shadow 0.16s ease,
		color 0.16s ease,
		transform 0.16s ease;
}

.avalon-client .btn.btn-primary:hover,
.avalon-client .btn.btn-primary:focus,
.avalon-client input.btn.btn-primary:hover,
.avalon-client input.btn.btn-primary:focus,
.avalon-client button.btn.btn-primary:hover,
.avalon-client button.btn.btn-primary:focus {
	background: linear-gradient(135deg, #ffd166, #f7b733);
	border-color: transparent;
	box-shadow: 0 12px 24px rgba(203, 134, 10, 0.3);
	color: var(--navy);
	transform: translateY(-1px);
}

.avalon-client .btn.btn-primary:active,
.avalon-client input.btn.btn-primary:active,
.avalon-client button.btn.btn-primary:active {
	background: linear-gradient(135deg, #f0b236, #e39e17);
	box-shadow: 0 6px 14px rgba(203, 134, 10, 0.22);
	transform: translateY(0);
}

.avalon-client .btn.btn-primary:disabled,
.avalon-client .btn.btn-primary.disabled,
.avalon-client input.btn.btn-primary:disabled,
.avalon-client button.btn.btn-primary:disabled {
	background: linear-gradient(135deg, #f0d28b, #eac977);
	box-shadow: none;
	color: rgba(28, 39, 56, 0.72);
	opacity: 1;
	transform: none;
}

.avalon-client .btn.btn-default,
.avalon-client input.btn.btn-default,
.avalon-client button.btn.btn-default {
	background: #f7faff;
	border: 1px solid #c9d8ef;
	border-radius: 0.66rem;
	color: #314a70;
	font-size: 0.95rem;
	font-weight: 700;
	line-height: 1.2;
	min-height: 2.38rem;
	padding: 0.5rem 0.9rem;
	transition:
		background-color 0.16s ease,
		border-color 0.16s ease,
		color 0.16s ease,
		transform 0.16s ease;
}

.avalon-client .btn.btn-default:hover,
.avalon-client .btn.btn-default:focus,
.avalon-client input.btn.btn-default:hover,
.avalon-client input.btn.btn-default:focus,
.avalon-client button.btn.btn-default:hover,
.avalon-client button.btn.btn-default:focus {
	background: #edf4ff;
	border-color: #9fb7da;
	color: #213e63;
	transform: translateY(-1px);
}

.avalon-client .btn.btn-default:disabled,
.avalon-client .btn.btn-default.disabled,
.avalon-client input.btn.btn-default:disabled,
.avalon-client button.btn.btn-default:disabled {
	background: #f2f6fd;
	border-color: #d5e0ef;
	color: #7488a6;
	opacity: 1;
	transform: none;
}

.avalon-client .master-breadcrumb .breadcrumb:empty,
.avalon-client .master-breadcrumb .breadcrumb:not(:has(li)) {
	display: none;
}

.avalon-client .master-breadcrumb:has(.breadcrumb:empty),
.avalon-client .master-breadcrumb:has(.breadcrumb:not(:has(li))) {
	display: none;
}

/* Login page UX polish */
.avalon-client .login-form .card {
	background: linear-gradient(180deg, #ffffff, #fbfdff);
	border: 1px solid var(--line);
	border-radius: 0.98rem;
	box-shadow: 0 14px 34px rgba(18, 36, 69, 0.1);
	overflow: hidden;
}

.avalon-client .login-form .card-body {
	padding: 2rem 2.15rem !important;
}

.avalon-client .login-form .h3 {
	color: var(--navy);
	font-size: clamp(1.7rem, 1.48rem + 0.48vw, 2rem);
	font-weight: 800;
	line-height: 1.18;
	margin-bottom: 0.32rem;
}

.avalon-client .login-form .text-muted {
	color: #5f6f88 !important;
	font-size: 1.02rem;
	line-height: 1.45;
}

.avalon-client .login-form .form-control-label {
	color: #334b6e;
	font-size: 0.94rem;
	font-weight: 700;
	letter-spacing: 0.01em;
	margin-bottom: 0.36rem;
}

.avalon-client .login-form .input-group-text {
	background: #f5f9ff;
	border: 1px solid #c8d5e8;
	color: #49648b;
	min-width: 2.55rem;
	justify-content: center;
}

.avalon-client .login-form .form-control {
	background: #ffffff;
	border: 1px solid #c8d5e8;
	font-size: 0.98rem;
	font-weight: 600;
	min-height: 2.7rem;
	padding: 0.56rem 0.75rem;
}

.avalon-client .login-form .input-group .btn.btn-default {
	background: #f7faff;
	border: 1px solid #c8d5e8;
	color: #3f5d87;
	min-width: 2.5rem;
}

.avalon-client .login-form .input-group .btn.btn-default:hover,
.avalon-client .login-form .input-group .btn.btn-default:focus {
	background: #eef5ff;
	border-color: #9eb7dc;
	color: #294b78;
}

.avalon-client .login-form .card-footer {
	background: #f8fbff;
	border-top: 1px solid var(--line);
	padding: 0.9rem 2.15rem !important;
}

@media (max-width: 767.98px) {
	.avalon-client .login-form .card-body {
		padding: 1.3rem 1.05rem !important;
	}

	.avalon-client .login-form .card-footer {
		padding: 0.78rem 1.05rem !important;
	}
}

.avalon-client a:focus,
.avalon-client button:focus,
.avalon-client input:focus {
	box-shadow: 0 0 0 0.18rem rgba(250, 180, 27, 0.28) !important;
	outline: none;
}

/* Support ticket page UX polish */
.avalon-client form[action*="submitticket.php"] .card {
	border: 1px solid var(--line);
	border-radius: 0.9rem;
	box-shadow: 0 10px 24px rgba(18, 36, 69, 0.06);
}

.avalon-client form[action*="submitticket.php"] .card-body.extra-padding {
	padding: 1.5rem !important;
}

.avalon-client form[action*="submitticket.php"] .card-title {
	font-size: clamp(1.25rem, 1.1rem + 0.35vw, 1.46rem);
	margin-bottom: 1rem;
}

.avalon-client form[action*="submitticket.php"] .btn {
	border-radius: 0.66rem;
	font-size: var(--ui-fs-sm);
	font-weight: 700;
	line-height: 1.2;
	min-height: 2.35rem;
	padding: 0.5rem 0.86rem;
	transition:
		background-color 0.16s ease,
		border-color 0.16s ease,
		color 0.16s ease,
		box-shadow 0.16s ease,
		transform 0.16s ease;
}

.avalon-client
	form[action*="submitticket.php"]
	#openTicketSubmit.btn.btn-primary {
	background: linear-gradient(135deg, var(--accent), #f8c44f);
	border-color: transparent;
	box-shadow: 0 8px 18px rgba(203, 134, 10, 0.24);
	color: var(--navy);
}

.avalon-client
	form[action*="submitticket.php"]
	#openTicketSubmit.btn.btn-primary:hover,
.avalon-client
	form[action*="submitticket.php"]
	#openTicketSubmit.btn.btn-primary:focus {
	background: linear-gradient(135deg, #ffd166, #f7b733);
	border-color: transparent;
	box-shadow: 0 10px 22px rgba(203, 134, 10, 0.28);
	color: var(--navy);
	transform: translateY(-1px);
}

.avalon-client form[action*="submitticket.php"] .btn.btn-default {
	background: #f7faff;
	border: 1px solid #c9d8ef;
	color: #314a70;
}

.avalon-client form[action*="submitticket.php"] .btn.btn-default:hover,
.avalon-client form[action*="submitticket.php"] .btn.btn-default:focus {
	background: #edf4ff;
	border-color: #9fb7da;
	color: #213e63;
	transform: translateY(-1px);
}

.avalon-client form[action*="submitticket.php"] .md-editor {
	border: 1px solid var(--line);
	border-radius: 0.72rem;
	overflow: hidden;
}

.avalon-client
	form[action*="submitticket.php"]
	.md-editor
	> .md-header.btn-toolbar {
	align-items: center;
	background: #f7faff !important;
	border-bottom: 1px solid var(--line);
	gap: 0.35rem;
	padding: 0.45rem 0.5rem;
}

.avalon-client
	form[action*="submitticket.php"]
	.md-editor
	> .md-header
	.btn-group {
	display: inline-flex;
	gap: 0.2rem;
	margin-right: 0.12rem;
}

.avalon-client form[action*="submitticket.php"] .md-editor > .md-header .btn {
	background: #ffffff;
	border: 1px solid #ccd8ec;
	border-radius: 0.5rem;
	color: #324b70;
	font-size: 0.86rem;
	line-height: 1;
	min-height: 2rem;
	min-width: 2rem;
	padding: 0.35rem 0.5rem;
}

.avalon-client
	form[action*="submitticket.php"]
	.md-editor
	> .md-header
	.btn:hover,
.avalon-client
	form[action*="submitticket.php"]
	.md-editor
	> .md-header
	.btn:focus {
	background: #edf4ff;
	border-color: #9fb7da;
	color: #1f3d64;
	transform: none;
}

.avalon-client
	form[action*="submitticket.php"]
	.md-editor
	> .md-header
	.btn.btn-primary {
	background: #369;
	border-color: #369;
	box-shadow: none;
	color: #fff;
	min-width: auto;
	padding: 0.25rem 0.5rem;
}

.avalon-client
	form[action*="submitticket.php"]
	.md-editor
	> .md-header
	.btn.btn-primary:hover,
.avalon-client
	form[action*="submitticket.php"]
	.md-editor
	> .md-header
	.btn.btn-primary:focus {
	background: #29537c;
	border-color: #264d73;
	box-shadow: none;
	color: #fff;
}

.avalon-client form[action*="submitticket.php"] .md-editor .md-controls {
	margin-left: auto;
	padding-right: 0.2rem;
}

/* Knowledgebase page UX polish */
.avalon-client .kb-search {
	border: 1px solid var(--line);
	border-radius: 0.86rem;
	box-shadow: 0 8px 20px rgba(18, 36, 69, 0.06);
	overflow: hidden;
}

.avalon-client .kb-search .form-control {
	background: #ffffff;
	border: 0;
	font-size: var(--ui-fs-lg);
	font-weight: 500;
	min-height: 3.15rem;
	padding: 0.72rem 0.95rem;
}

.avalon-client .kb-search .form-control::placeholder {
	color: #6c7f9b;
}

.avalon-client .kb-search .btn#btnKnowledgebaseSearch {
	background: linear-gradient(135deg, #2f5f95, #244d7a);
	border: 0;
	border-radius: 0;
	color: #ffffff;
	font-size: var(--ui-fs-md);
	font-weight: 700;
	min-width: 6.4rem;
	padding: 0.7rem 1.1rem;
}

.avalon-client .kb-search .btn#btnKnowledgebaseSearch:hover,
.avalon-client .kb-search .btn#btnKnowledgebaseSearch:focus {
	background: linear-gradient(135deg, #3a6ca4, #2a5787);
	color: #ffffff;
}

.avalon-client .kb-category {
	border: 1px solid var(--line);
	border-radius: 0.82rem;
	box-shadow: 0 8px 20px rgba(18, 36, 69, 0.05);
	transition:
		transform 0.16s ease,
		box-shadow 0.16s ease,
		border-color 0.16s ease;
}

.avalon-client .kb-category:hover {
	border-color: #a9c0e0;
	box-shadow: 0 12px 24px rgba(20, 40, 70, 0.1);
	transform: translateY(-1px);
}

.avalon-client .kb-category .card-body {
	padding: 0.88rem 0.92rem;
	text-decoration: none;
}

.avalon-client .kb-category .h5 {
	color: #25456c;
	font-size: var(--ui-fs-xl);
	font-weight: 700;
	line-height: 1.3;
}

.avalon-client .kb-category p,
.avalon-client .kb-category p small {
	color: #5e7393 !important;
	font-size: var(--ui-fs-sm);
	line-height: 1.45;
}

.avalon-client .kb-category .badge.badge-info {
	background: #20a6bb;
	border-radius: 0.45rem;
	font-size: var(--ui-fs-xs);
	font-weight: 700;
	padding: 0.27rem 0.48rem;
}

.avalon-client .kb-article-item {
	border-color: #e4ebf7;
	display: block;
	font-size: var(--ui-fs-md);
	font-weight: 600;
	line-height: 1.45;
	padding: 0.86rem 1rem 0.86rem 2.15rem;
	position: relative;
	transition:
		background-color 0.16s ease,
		border-color 0.16s ease,
		box-shadow 0.16s ease,
		color 0.16s ease,
		transform 0.16s ease;
}

.avalon-client .kb-article-item i.fal.fa-file-alt,
.avalon-client .kb-article-item i.far.fa-file-alt,
.avalon-client .kb-article-item i.fas.fa-file-alt,
.avalon-client .kb-article-item i.fa-file-alt {
	color: #7a91b2 !important;
	font-size: 0.95rem;
	left: 0.88rem;
	line-height: 1;
	position: absolute;
	top: 1.06rem;
}

.avalon-client .kb-article-item small {
	color: #627a9b;
	display: block;
	font-size: 0.9rem;
	font-weight: 500;
	line-height: 1.5;
	margin-top: 0.34rem;
}

.avalon-client .kb-article-item:hover,
.avalon-client .kb-article-item:focus {
	background: linear-gradient(145deg, #f8fbff, #f3f8ff);
	border-color: #c9d9ef;
	box-shadow: inset 0 0 0 1px rgba(141, 171, 212, 0.16);
	color: #1f3f67;
	text-decoration: none;
	transform: translateX(1px);
}

.avalon-client .primary-content .card .card-title.m-0 {
	align-items: center;
	display: inline-flex;
	gap: 0.52rem;
	line-height: 1.25;
}

.avalon-client .primary-content .card .card-title.m-0 i {
	color: #59789f;
}

.avalon-client .primary-content .card .list-group.list-group-flush {
	border-top: 1px solid #dbe6f6;
}

@media (max-width: 767.98px) {
	.avalon-client .kb-article-item {
		padding: 0.78rem 0.82rem 0.78rem 1.95rem;
	}

	.avalon-client .kb-article-item i.fal.fa-file-alt,
	.avalon-client .kb-article-item i.far.fa-file-alt,
	.avalon-client .kb-article-item i.fas.fa-file-alt,
	.avalon-client .kb-article-item i.fa-file-alt {
		left: 0.74rem;
		top: 0.94rem;
	}
}

@media (max-width: 1199.98px) {
	.avalon-header-shell .main-navbar-wrapper {
		border-top: 0;
	}

	.avalon-header-shell .main-navbar-wrapper .navbar-collapse {
		background: #ffffff;
		border: 1px solid var(--line);
		border-radius: 0.9rem;
		margin-top: 0.7rem;
		padding: 0.8rem;
	}

	.avalon-footer-grid {
		grid-template-columns: 1fr;
	}

	.avalon-footer .footer-payment {
		justify-content: flex-start;
	}

	.avalon-footer .footer-nav-row-primary {
		grid-template-columns: repeat(2, minmax(180px, 1fr));
	}

	.avalon-footer .footer-nav-row-secondary {
		grid-template-columns: repeat(2, minmax(180px, 1fr));
	}
}

@media (max-width: 767.98px) {
	.avalon-header-shell .topbar .topbar-link + .topbar-link {
		margin-left: 0.6rem;
	}

	.avalon-footer .footer-brand-logo {
		max-height: 2.35rem;
	}

	.avalon-footer-newsletter {
		padding: 1.1rem;
	}

	.avalon-footer-grid {
		grid-template-columns: 1fr;
	}

	.avalon-footer .footer-nav-row-primary,
	.avalon-footer .footer-nav-row-secondary {
		grid-template-columns: 1fr;
	}

	.avalon-footer-bottom {
		text-align: center;
	}
}
