/**
 * Member area — aligned with site theme (app/assets/css/style.css)
 * Primary #a58bbd · Surface #f6f7fd · Ink #0a0928
 */

:root {
	--site-accent: #a58bbd;
	--site-accent-dark: #8f73a6;
	--site-accent-deep: #6d4f87;
	--site-ink: #0a0928;
	--site-text: #2f3138;
	--site-muted: #6b7088;
	--site-surface: #f6f7fd;
	--site-card-border: rgba(165, 139, 189, 0.22);
	--site-shadow: 0 12px 40px rgba(10, 9, 40, 0.08);
	--site-radius: 14px;
	--site-radius-sm: 10px;
	--font-body: "Open Sans", "Kanit", system-ui, sans-serif;
	--font-heading: "Raleway", "Kanit", system-ui, sans-serif;
}

/* --------------------------------------------------------------------------
   Public / login (member + admin back_end index)
   -------------------------------------------------------------------------- */
body.member-login-page,
body.admin-login-page,
body.member-public-page {
	font-family: var(--font-body);
	color: var(--site-text);
}

body.member-public-page .body-container,
body.member-login-page .body-container,
body.admin-login-page .body-container {
	background: linear-gradient(150deg, #1e1428 0%, #3d2a4d 40%, #5c3d6b 100%) !important;
	background-attachment: fixed;
	min-height: 100vh;
}

body.member-public-page #row-1 > .col-12,
body.member-login-page #row-1 > .col-12,
body.admin-login-page #row-1 > .col-12 {
	border-radius: 18px !important;
	box-shadow: 0 28px 60px -12px rgba(10, 9, 40, 0.5) !important;
	border: 1px solid rgba(255, 255, 255, 0.14);
}

@media (max-width: 991.98px) {
	body.member-public-page #row-1 > .col-12,
	body.member-login-page #row-1 > .col-12,
	body.admin-login-page #row-1 > .col-12 {
		border-radius: 14px !important;
	}
}

#loginBgCarousel .carousel-item > div {
	min-height: 100%;
	min-height: min(560px, 85vh);
	background: linear-gradient(
			165deg,
			rgba(45, 31, 61, 0.94) 0%,
			rgba(109, 79, 135, 0.88) 52%,
			rgba(74, 53, 96, 0.92) 100%
		),
		url(ACE/assets/image/login-bg-1.svg) center/cover no-repeat !important;
}

#loginBgCarousel .hero-tagline {
	font-size: 0.95rem;
	line-height: 1.55;
	opacity: 0.95;
}

#loginBgCarousel .hero-year {
	font-size: 0.85rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	opacity: 0.8;
}

#id-col-main {
	padding-top: 2.25rem !important;
	padding-bottom: 2rem !important;
}

.member-welcome-title {
	font-family: var(--font-heading);
	font-weight: 600;
	color: var(--site-ink);
	letter-spacing: -0.02em;
}

.member-welcome-sub {
	color: var(--site-muted);
	font-size: 0.92rem;
	margin-top: 0.35rem;
}

#id-login-username,
#id-login-password,
#id-recover-email {
	border-radius: 12px !important;
	border: 1px solid #d8dce8 !important;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

#id-login-username:focus,
#id-login-password:focus,
#id-recover-email:focus {
	border-color: var(--site-accent) !important;
	box-shadow: 0 0 0 3px rgba(165, 139, 189, 0.28) !important;
}

.member-login-page .btn-primary.btn-block,
.admin-login-page .btn-primary.btn-block {
	border-radius: 12px !important;
	padding: 0.7rem 1.2rem !important;
	font-family: var(--font-heading);
	font-weight: 600;
	border: none !important;
	background: linear-gradient(180deg, #c9b0dc 0%, var(--site-accent) 45%, var(--site-accent-dark) 100%) !important;
	box-shadow: 0 10px 24px -8px rgba(109, 79, 135, 0.55);
	color: #fff !important;
}

.member-login-page .btn-primary.btn-block:hover,
.admin-login-page .btn-primary.btn-block:hover {
	filter: brightness(1.05);
	transform: translateY(-1px);
}

.member-login-page .btn-orange.btn-block,
.admin-login-page .btn-orange.btn-block {
	border-radius: 12px !important;
	font-weight: 600;
	box-shadow: 0 6px 18px -8px rgba(200, 120, 40, 0.45);
}

.member-help {
	background: linear-gradient(180deg, #faf8fc 0%, #f3eef8 100%);
	border: 1px solid rgba(165, 139, 189, 0.35);
	border-radius: 12px;
	padding: 0.85rem 1.1rem;
	font-size: 0.88rem;
	color: #3d3550;
	line-height: 1.45;
}

.member-help a {
	color: var(--site-accent-deep);
	font-weight: 600;
}

.member-signup-row {
	font-size: 0.92rem;
	color: var(--site-muted);
}

.member-mobile-brand .member-mobile-logo {
	max-height: 72px;
	width: auto;
	border-radius: 8px;
}

body.member-login-page a.text-primary-m1,
body.member-login-page .text-blue-d1,
body.admin-login-page a.text-primary-m1,
body.admin-login-page .text-blue-d1 {
	color: var(--site-accent-deep) !important;
}

/* --------------------------------------------------------------------------
   Portal — member (navbar-blue) & back_end admin (navbar-skyblue)
   -------------------------------------------------------------------------- */
body.member-portal, body.admin-portal {
	font-family: var(--font-body);
	color: var(--site-text);
}

body.member-portal .body-container, body.admin-portal .body-container {
	background: var(--site-surface);
	min-height: 100vh;
}

/* Full bar + inner: one surface so “Welcome / name” is never white-on-white */
body.member-portal .navbar.navbar-blue, body.admin-portal .navbar.navbar-skyblue,
body.member-portal .navbar.navbar-blue > .navbar-inner, body.admin-portal .navbar.navbar-skyblue > .navbar-inner {
	background: linear-gradient(90deg, #2d1f3d 0%, #6d4f87 42%, var(--site-accent) 100%) !important;
	border: none !important;
	box-shadow: 0 4px 24px rgba(10, 9, 40, 0.18);
}

body.member-portal .navbar.navbar-blue .navbar-intro, body.admin-portal .navbar.navbar-skyblue .navbar-intro,
body.member-portal .navbar.navbar-blue .navbar-menu, body.admin-portal .navbar.navbar-skyblue .navbar-menu,
body.member-portal .navbar.navbar-blue .navbar-menu.navbar-collapse, body.admin-portal .navbar.navbar-skyblue .navbar-menu.navbar-collapse {
	background: transparent !important;
	background-color: transparent !important;
}

/* Welcome row: light text only on the toggle link (not inside .dropdown-menu — avoids white icons on pale rows) */
body.member-portal .navbar.navbar-blue .navbar-nav > .nav > .nav-item.dropdown > .nav-link, body.admin-portal .navbar.navbar-skyblue .navbar-nav > .nav > .nav-item.dropdown > .nav-link,
body.member-portal .navbar.navbar-blue .navbar-nav > .nav > .nav-item.dropdown > .nav-link .nav-user-name, body.admin-portal .navbar.navbar-skyblue .navbar-nav > .nav > .nav-item.dropdown > .nav-link .nav-user-name,
body.member-portal .navbar.navbar-blue .navbar-nav > .nav > .nav-item.dropdown > .nav-link #id-user-welcome, body.admin-portal .navbar.navbar-skyblue .navbar-nav > .nav > .nav-item.dropdown > .nav-link #id-user-welcome,
body.member-portal .navbar.navbar-blue .navbar-nav > .nav > .nav-item.dropdown > .nav-link .text-90, body.admin-portal .navbar.navbar-skyblue .navbar-nav > .nav > .nav-item.dropdown > .nav-link .text-90 {
	color: #fff !important;
	opacity: 1 !important;
}

body.member-portal .navbar.navbar-blue .navbar-nav > .nav > .nav-item.dropdown > .nav-link > .caret, body.admin-portal .navbar.navbar-skyblue .navbar-nav > .nav > .nav-item.dropdown > .nav-link > .caret {
	color: #fff !important;
}

body.member-portal .navbar.navbar-blue .navbar-nav > .nav > .nav-item.dropdown:hover > .nav-link:not(.disabled), body.admin-portal .navbar.navbar-skyblue .navbar-nav > .nav > .nav-item.dropdown:hover > .nav-link:not(.disabled),
body.member-portal .navbar.navbar-blue .navbar-nav > .nav > .nav-item.dropdown.show > .nav-link:not(.disabled), body.admin-portal .navbar.navbar-skyblue .navbar-nav > .nav > .nav-item.dropdown.show > .nav-link:not(.disabled) {
	color: #fff !important;
}

/* ACE caps .nav-user-name at 100px + ellipsis (desktop) — widen welcome area */
body.member-portal .navbar .nav-user-name, body.admin-portal .navbar .nav-user-name {
	white-space: normal !important;
	overflow: visible !important;
	text-overflow: unset !important;
	line-height: 1.3;
	display: inline-block;
	vertical-align: middle;
}

@media (min-width: 992px) {
	body.member-portal .navbar .nav-user-name, body.admin-portal .navbar .nav-user-name {
		max-width: min(28rem, 42vw) !important;
	}

	body.member-portal .navbar .navbar-nav > .nav > .nav-item.dropdown > .nav-link, body.admin-portal .navbar .navbar-nav > .nav > .nav-item.dropdown > .nav-link {
		max-width: none !important;
		padding-left: 1rem !important;
		padding-right: 1rem !important;
	}
}

@media (max-width: 991.98px) {
	body.member-portal .navbar .nav-user-name, body.admin-portal .navbar .nav-user-name {
		max-width: min(20rem, 78vw) !important;
	}
}

/* Dropdown items: icons readable on light / tinted backgrounds */
body.member-portal .navbar .dropdown-menu .dropdown-item .fa.fa-user, body.admin-portal .navbar .dropdown-menu .dropdown-item .fa.fa-user {
	color: var(--site-accent-deep) !important;
	opacity: 1 !important;
}

body.member-portal .navbar .dropdown-menu .dropdown-item:hover .fa.fa-user, body.admin-portal .navbar .dropdown-menu .dropdown-item:hover .fa.fa-user,
body.member-portal .navbar .dropdown-menu .dropdown-item:focus .fa.fa-user, body.admin-portal .navbar .dropdown-menu .dropdown-item:focus .fa.fa-user {
	color: #fff !important;
}

body.member-portal .navbar .dropdown-menu .dropdown-item .fa.fa-power-off, body.admin-portal .navbar .dropdown-menu .dropdown-item .fa.fa-power-off {
	color: #c2410c !important;
	opacity: 1 !important;
}

body.member-portal .navbar .dropdown-menu .dropdown-item:hover .fa.fa-power-off, body.admin-portal .navbar .dropdown-menu .dropdown-item:hover .fa.fa-power-off,
body.member-portal .navbar .dropdown-menu .dropdown-item:focus .fa.fa-power-off, body.admin-portal .navbar .dropdown-menu .dropdown-item:focus .fa.fa-power-off {
	color: #fff !important;
}

body.member-portal .navbar-brand, body.admin-portal .navbar-brand {
	font-family: var(--font-heading);
	font-weight: 600;
	letter-spacing: 0.03em;
	color: #fff !important;
}

body.member-portal .navbar-brand span:first-child, body.admin-portal .navbar-brand span:first-child {
	font-size: 1.05rem;
}

body.member-portal .navbar .btn-burger, body.admin-portal .navbar .btn-burger {
	color: #fff !important;
}

body.member-portal .main-container.bgc-white, body.admin-portal .main-container.bgc-white {
	background: transparent !important;
}

body.member-portal .main-content, body.admin-portal .main-content {
	background: var(--site-surface) !important;
	min-height: calc(100vh - 48px);
}

body.member-portal .main-content .page-content, body.admin-portal .main-content .page-content {
	background: transparent;
	padding-top: 0.5rem;
	padding-bottom: 2rem;
}

body.member-portal .sidebar, body.admin-portal .sidebar {
	border-right: 1px solid rgba(165, 139, 189, 0.18) !important;
	box-shadow: 4px 0 24px rgba(10, 9, 40, 0.04);
}

body.member-portal .sidebar .nav-item.active > .nav-link, body.admin-portal .sidebar .nav-item.active > .nav-link,
body.member-portal .sidebar .nav-item .nav-link.active, body.admin-portal .sidebar .nav-item .nav-link.active {
	color: var(--site-accent-deep) !important;
	font-weight: 600;
}

body.member-portal .sidebar .nav-item.active > .nav-link::before, body.admin-portal .sidebar .nav-item.active > .nav-link::before,
body.member-portal .sidebar .nav-item .nav-link.active::before, body.admin-portal .sidebar .nav-item .nav-link.active::before {
	background: var(--site-accent) !important;
}

body.member-portal .page-header, body.admin-portal .page-header {
	margin-bottom: 0.5rem !important;
}

body.member-portal .page-header .page-title, body.admin-portal .page-header .page-title {
	font-family: var(--font-heading);
	font-weight: 600 !important;
	color: var(--site-ink) !important;
	letter-spacing: -0.02em;
}

body.member-portal .page-header .page-title small.page-info, body.admin-portal .page-header .page-title small.page-info {
	display: block;
	margin-top: 0.4rem;
	font-family: var(--font-body);
	font-size: 0.9rem !important;
	font-weight: 400;
	color: var(--site-muted) !important;
	line-height: 1.45;
}

body.member-portal .card.dcard, body.admin-portal .card.dcard,
body.member-portal .card.acard, body.admin-portal .card.acard,
body.member-portal .card.bcard, body.admin-portal .card.bcard {
	border-radius: var(--site-radius);
	border: 1px solid var(--site-card-border);
	box-shadow: var(--site-shadow);
	overflow: hidden;
}

body.member-portal .card .card-header, body.admin-portal .card .card-header {
	background: linear-gradient(180deg, #faf8fc 0%, #f3eef8 100%);
	border-bottom: 1px solid var(--site-card-border);
}

body.member-portal .card .card-header .card-title, body.admin-portal .card .card-header .card-title {
	font-family: var(--font-heading);
	font-weight: 600;
	color: var(--site-ink);
}

body.member-portal .card-body, body.admin-portal .card-body {
	background: #fff;
}

body.member-portal .table, body.admin-portal .table {
	border-radius: var(--site-radius-sm);
	overflow: hidden;
}

body.member-portal .table thead th, body.admin-portal .table thead th {
	background: linear-gradient(180deg, #efe8f5 0%, #e5daf0 100%);
	font-weight: 600;
	font-size: 0.82rem;
	letter-spacing: 0.03em;
	color: #3d3550;
	border-color: rgba(165, 139, 189, 0.2) !important;
}

body.member-portal .table-striped tbody tr:nth-of-type(odd), body.admin-portal .table-striped tbody tr:nth-of-type(odd) {
	background-color: rgba(246, 247, 253, 0.85);
}

body.member-portal table.dataTable thead th, body.admin-portal table.dataTable thead th,
body.member-portal table.dataTable thead td, body.admin-portal table.dataTable thead td {
	border-bottom: 2px solid rgba(165, 139, 189, 0.25) !important;
}

body.member-portal .form-control, body.admin-portal .form-control {
	border-radius: var(--site-radius-sm);
	border-color: #d5d2dc;
}

body.member-portal .form-control:focus, body.admin-portal .form-control:focus {
	border-color: var(--site-accent);
	box-shadow: 0 0 0 3px rgba(165, 139, 189, 0.2);
}

body.member-portal .col-form-label, body.admin-portal .col-form-label {
	color: #4a4458;
	font-weight: 500;
}

body.member-portal .btn-primary, body.admin-portal .btn-primary {
	font-family: var(--font-heading);
	background: linear-gradient(180deg, #c9b0dc 0%, var(--site-accent) 40%, var(--site-accent-dark) 100%);
	border: none;
	box-shadow: 0 4px 16px rgba(109, 79, 135, 0.3);
	color: #fff;
}

body.member-portal .btn-primary:hover, body.admin-portal .btn-primary:hover {
	filter: brightness(1.06);
	color: #fff;
}

body.member-portal .btn-success, body.admin-portal .btn-success,
body.member-portal .btn-info, body.admin-portal .btn-info {
	border-radius: var(--site-radius-sm);
	font-weight: 600;
}

body.member-portal .btn-pink, body.admin-portal .btn-pink {
	border-radius: var(--site-radius-sm);
}

body.member-portal hr.brc-secondary-l2, body.admin-portal hr.brc-secondary-l2 {
	border-color: rgba(165, 139, 189, 0.2) !important;
	opacity: 1;
}

body.member-portal .about-text h4, body.admin-portal .about-text h4,
body.member-portal h4, body.admin-portal h4 {
	font-family: var(--font-heading);
	color: var(--site-ink);
	font-weight: 600;
}

body.member-portal .about-pic img, body.admin-portal .about-pic img {
	border-radius: var(--site-radius-sm);
	box-shadow: var(--site-shadow);
}

body.member-portal .page-content.container-plus, body.admin-portal .page-content.container-plus {
	max-width: 1200px;
}

body.member-portal .footer-sm .btn-group, body.admin-portal .footer-sm .btn-group {
	border-radius: var(--site-radius) var(--site-radius) 0 0;
}

/* Register report · same top bar as conference site */
body.member-public-page .navbar.navbar-darkgreen,
body.member-public-page .navbar-fixed.navbar-darkgreen {
	background: linear-gradient(90deg, #2d1f3d 0%, #5c3d6b 55%, var(--site-accent-dark) 100%) !important;
	box-shadow: 0 4px 24px rgba(10, 9, 40, 0.18);
}
