@font-face {
    font-family: 'All Round Gothic';
    src: url('../fonts/FONTSPRINGDEMO-AllRoundGothicBoldRegular.woff2') format('woff2'),
        url('../fonts/FONTSPRINGDEMO-AllRoundGothicBoldRegular.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'All Round Gothic Book';
    src: url('../fonts/FONTSPRINGDEMO-AllRoundGothicBookRegular.woff2') format('woff2'),
        url('../fonts/FONTSPRINGDEMO-AllRoundGothicBookRegular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'DB Helvethaica X';
    src: url('../fonts/DBHelvethaicaX-55Regular.woff2') format('woff2'),
        url('../fonts/DBHelvethaicaX-55Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
	/* unicode-range: U+0E01-0E3A, U+0E3F-0E5B; */
}

@font-face {
    font-family: 'DB Helvethaica X';
    src: url('../fonts/DBHelvethaicaX-74BdExtIt.woff2') format('woff2'),
        url('../fonts/DBHelvethaicaX-74BdExtIt.woff') format('woff');
    font-weight: normal;
    font-style: italic;
    font-display: swap;
	/* unicode-range: U+0E01-0E3A, U+0E3F-0E5B; */
}

/* Font Awesome — override font-display:block → swap */
@font-face {
	font-family: "Font Awesome 7 Free";
	font-style: normal;
	font-weight: 900;
	font-display: swap;
	src: url('/vendor/font-awesome/webfonts/fa-solid-900.woff2') format('woff2');
}
@font-face {
	font-family: "Font Awesome 7 Free";
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url('/vendor/font-awesome/webfonts/fa-regular-400.woff2') format('woff2');
}
@font-face {
	font-family: "Font Awesome 7 Brands";
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url('/vendor/font-awesome/webfonts/fa-brands-400.woff2') format('woff2');
}

.construction {
	position: absolute;
	max-width: 100%;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	text-align: center;
}

/* ── Extended Bootstrap spacing: 6 = 4rem (64px), 7 = 5rem (80px) ── */
.pt-6{padding-top:4rem!important}.pb-6{padding-bottom:4rem!important}.py-6{padding-top:4rem!important;padding-bottom:4rem!important}
.ps-6{padding-left:4rem!important}.pe-6{padding-right:4rem!important}.px-6{padding-left:4rem!important;padding-right:4rem!important}.p-6{padding:4rem!important}
.mt-6{margin-top:4rem!important}.mb-6{margin-bottom:4rem!important}.my-6{margin-top:4rem!important;margin-bottom:4rem!important}
.ms-6{margin-left:4rem!important}.me-6{margin-right:4rem!important}.mx-6{margin-left:4rem!important;margin-right:4rem!important}.m-6{margin:4rem!important}
.gap-6{gap:4rem!important}
.pt-7{padding-top:5rem!important}.pb-7{padding-bottom:5rem!important}.py-7{padding-top:5rem!important;padding-bottom:5rem!important}
.ps-7{padding-left:5rem!important}.pe-7{padding-right:5rem!important}.px-7{padding-left:5rem!important;padding-right:5rem!important}.p-7{padding:5rem!important}
.mt-7{margin-top:5rem!important}.mb-7{margin-bottom:5rem!important}.my-7{margin-top:5rem!important;margin-bottom:5rem!important}
.ms-7{margin-left:5rem!important}.me-7{margin-right:5rem!important}.mx-7{margin-left:5rem!important;margin-right:5rem!important}.m-7{margin:5rem!important}
.gap-7{gap:5rem!important}
@media(min-width:576px){
	.pt-sm-6{padding-top:4rem!important}.pb-sm-6{padding-bottom:4rem!important}.py-sm-6{padding-top:4rem!important;padding-bottom:4rem!important}
	.mt-sm-6{margin-top:4rem!important}.mb-sm-6{margin-bottom:4rem!important}.my-sm-6{margin-top:4rem!important;margin-bottom:4rem!important}
	.gap-sm-6{gap:4rem!important}
	.pt-sm-7{padding-top:5rem!important}.pb-sm-7{padding-bottom:5rem!important}.py-sm-7{padding-top:5rem!important;padding-bottom:5rem!important}
	.mt-sm-7{margin-top:5rem!important}.mb-sm-7{margin-bottom:5rem!important}.my-sm-7{margin-top:5rem!important;margin-bottom:5rem!important}
	.gap-sm-7{gap:5rem!important}
}
@media(min-width:768px){
	.pt-md-6{padding-top:4rem!important}.pb-md-6{padding-bottom:4rem!important}.py-md-6{padding-top:4rem!important;padding-bottom:4rem!important}
	.mt-md-6{margin-top:4rem!important}.mb-md-6{margin-bottom:4rem!important}.my-md-6{margin-top:4rem!important;margin-bottom:4rem!important}
	.gap-md-6{gap:4rem!important}
	.pt-md-7{padding-top:5rem!important}.pb-md-7{padding-bottom:5rem!important}.py-md-7{padding-top:5rem!important;padding-bottom:5rem!important}
	.mt-md-7{margin-top:5rem!important}.mb-md-7{margin-bottom:5rem!important}.my-md-7{margin-top:5rem!important;margin-bottom:5rem!important}
	.gap-md-7{gap:5rem!important}
}
@media(min-width:992px){
	.pt-lg-6{padding-top:4rem!important}.pb-lg-6{padding-bottom:4rem!important}.py-lg-6{padding-top:4rem!important;padding-bottom:4rem!important}
	.mt-lg-6{margin-top:4rem!important}.mb-lg-6{margin-bottom:4rem!important}.my-lg-6{margin-top:4rem!important;margin-bottom:4rem!important}
	.gap-lg-6{gap:4rem!important}
	.pt-lg-7{padding-top:5rem!important}.pb-lg-7{padding-bottom:5rem!important}.py-lg-7{padding-top:5rem!important;padding-bottom:5rem!important}
	.mt-lg-7{margin-top:5rem!important}.mb-lg-7{margin-bottom:5rem!important}.my-lg-7{margin-top:5rem!important;margin-bottom:5rem!important}
	.gap-lg-7{gap:5rem!important}
}

/* START BOOTSTRAP */
:root {
	/* Custom */
	--body-font-size: 24px;
	--primary-color: #F04E30;
	--primary-color-rgb: 240, 78, 48;
	--secondary-color: #F2A598;
	--secondary-color-rgb: 242, 165, 152;
	--alternative-color: #0E3178;
	--alternative-color-rgb: 14, 49, 120;
	/* BS */
	--bs-body-line-height: 1.5;
	--bs-nav-link-font-size: 26px;
	--bs-body-color: #1d1d1f;
	--bs-primary-rgb: var(--primary-color-rgb);
	--bs-border-color: #e8e8ed;
	/* Design tokens */
	--ipac-bg: #F5F5F7;
	--ipac-text-dark: #1d1d1f;
	--ipac-text-medium: #6e6e73;
	--ipac-text-light: #86868b;
	--ipac-radius-sm: 14px;
	--ipac-radius-md: 20px;
	--ipac-radius-lg: 28px;
	--ipac-radius-pill: 9999px;
	--ipac-max-width: 1320px;
	--ipac-shadow: 0 2px 24px rgba(0,0,0,0.06);
	--ipac-shadow-hover: 0 12px 48px rgba(0,0,0,0.1);
	--ipac-transition: 0.3s ease;
	--ipac-navbar-height: 72px;
}

@media (min-width: 992px) { .py-lg-2r { padding-top: 2rem !important; padding-bottom: 2rem !important; } }
.mb-2r { margin-bottom: 2rem !important; }

body {
	font-family: "DB Helvethaica X", "All Round Gothic", "Font Awesome 7 Free", sans-serif;
	--bs-body-font-size: var(--body-font-size);
	background-color: var(--ipac-bg);
	color: var(--ipac-text-dark);
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}

.form-control {
	padding: 2px 10px;
	font-size: 24px;
}

.form-check-input:checked {
	background-color: var(--primary-color);
	border-color: var(--primary-color);
}
.form-check-input:focus {
	border-color: var(--primary-color);
	box-shadow: 0 0 0 0.25rem rgba(var(--primary-color-rgb), 0.25);
}

/* Global image-broken placeholder — frosted blur */
.img-broken {
	background: linear-gradient(135deg, rgba(var(--primary-color-rgb),0.08) 0%, rgba(var(--alternative-color-rgb),0.12) 50%, rgba(var(--primary-color-rgb),0.06) 100%);
	-webkit-backdrop-filter: blur(20px);
	backdrop-filter: blur(20px);
	display: flex;
	align-items: center;
	justify-content: center;
}
.img-broken::before {
	content: "\f03e";
	font-weight: 900;
	font-size: 48px;
	color: rgba(var(--alternative-color-rgb), 0.12);
}

.anchor {
    top: -150px;
    position: relative;
    display: block;
}

h1, .h1 {
	font-size: 44px;
}

h2 {
	font-weight: bold;
}

h3 {
	font-size: 38px;
}

h4 {
	font-weight: bold;
}

h5 {
	font-size: 34px;
	margin: 0;
}

h6 {
	font-size: 28px;
	margin: 0;
}

a {
	color: var(--primary-color);
	text-decoration: none;
}
a:hover {
	color: var(--bs-body-color);
}

@media (max-width: 767.98px) {
	/* Mobile */
	h5 {
		font-size: 30px;
		margin: 0;
	}

	h6 {
		font-size: 24px;
		margin: 0;
	}
}

#reCAPTCHA {
	display: inline-block;
	margin: 0 auto;
}

.dashboard-container > div {
	background-color: #fff;
}

/* =====================================================
   USER DASHBOARD — Apple-style redesign
   ===================================================== */
.ipac-ud-page { background: var(--ipac-bg); min-height: 100vh; }
.ipac-ud-wrapper {
	padding-top: 24px;
	padding-bottom: 24px;
	display: flex;
	flex-direction: column;
	gap: 24px;
}
@media (min-width: 992px) {
	.ipac-ud-wrapper { flex-direction: row; gap: 32px; padding-top: 40px; padding-bottom: 40px; align-items: flex-start; }
}

/* ── Sidebar ── */
.ipac-ud-sidebar {
	display: none;
}
@media (min-width: 992px) {
	.ipac-ud-sidebar {
		display: block;
		width: 260px;
		flex-shrink: 0;
		background: #fff;
		border-radius: var(--ipac-radius-md);
		box-shadow: var(--ipac-shadow);
		overflow: hidden;
		position: sticky;
		top: 90px;
	}
}
.ipac-ud-sidebar__user {
	padding: 20px 20px 16px;
	border-bottom: 1px solid #f0f0f0;
	display: flex;
	align-items: center;
	gap: 12px;
}
.ipac-ud-sidebar__avatar {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--primary-color), rgba(240,78,48,0.7));
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-size: 20px;
	flex-shrink: 0;
}
.ipac-ud-sidebar__info {
	min-width: 0;
	line-height: 1.0;
}
.ipac-ud-sidebar__name {
	font-size: 24px;
	color: var(--ipac-text-dark);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.ipac-ud-sidebar__email {
	font-size: 20px;
	color: var(--ipac-text-light);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.ipac-ud-sidebar__nav { padding: 8px 0; }
.ipac-ud-sidebar__nav a {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 10px 20px;
	font-size: 22px;
	color: var(--ipac-text-dark);
	text-decoration: none;
	transition: background var(--ipac-transition), color var(--ipac-transition);
	position: relative;
	line-height: 1.3;
}
.ipac-ud-sidebar__nav a i {
	width: 20px;
	text-align: center;
	color: var(--ipac-text-light);
	font-size: 18px;
	flex-shrink: 0;
}
.ipac-ud-sidebar__nav a:hover { background: var(--ipac-bg); }
.ipac-ud-sidebar__nav a.active {
	background: rgba(240,78,48,0.08);
	color: var(--primary-color);
}
.ipac-ud-sidebar__nav a.active i { color: var(--primary-color); }
.ipac-ud-sidebar__nav a.active::after {
	content: "";
	position: absolute;
	right: 16px;
	top: 50%;
	transform: translateY(-50%);
	width: 4px;
	height: 20px;
	border-radius: 2px;
	background: var(--primary-color);
}

.ipac-ud-sidebar__actions {
	border-top: 1px solid #f0f0f0;
	padding: 8px 0;
}
.ipac-ud-sidebar__actions a {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 10px 20px;
	font-size: 22px;
	text-decoration: none;
	transition: background var(--ipac-transition);
}
.ipac-ud-sidebar__actions a i {
	width: 20px;
	text-align: center;
	font-size: 18px;
	flex-shrink: 0;
}
.ipac-ud-sidebar__actions .ipac-ud-line-link { color: #06c755; }
.ipac-ud-sidebar__actions .ipac-ud-line-link:hover { background: rgba(6,199,85,0.05); }
.ipac-ud-sidebar__actions .ipac-ud-line-connected {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 10px 20px;
	font-size: 22px;
	color: #495057;
	cursor: default;
	opacity: 0.7;
}
.ipac-ud-sidebar__actions .ipac-ud-line-connected i {
	width: 20px;
	text-align: center;
	font-size: 18px;
}
.ipac-ud-sidebar__actions .ipac-ud-logout-link { color: var(--ipac-text-light); }
.ipac-ud-sidebar__actions .ipac-ud-logout-link:hover { color: #ef4444; background: rgba(239,68,68,0.05); }

/* ── Mobile nav ── */
.ipac-ud-mobile-nav {
	display: flex;
	overflow-x: auto;
	gap: 8px;
	padding-bottom: 4px;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
}
.ipac-ud-mobile-nav::-webkit-scrollbar { display: none; }
.ipac-ud-mobile-nav a {
	display: flex;
	align-items: center;
	gap: 6px;
	padding: 8px 16px;
	font-size: 20px;
	color: var(--ipac-text-dark);
	text-decoration: none;
	background: #fff;
	border-radius: var(--ipac-radius-pill);
	white-space: nowrap;
	box-shadow: 0 1px 4px rgba(0,0,0,0.06);
	transition: all var(--ipac-transition);
	flex-shrink: 0;
}
.ipac-ud-mobile-nav a i { color: var(--ipac-text-light); font-size: 16px; }
.ipac-ud-mobile-nav a.active {
	background: var(--primary-color);
	color: #fff;
}
.ipac-ud-mobile-nav a.active i { color: #fff; }
@media (min-width: 992px) { .ipac-ud-mobile-nav { display: none; } }

/* ── Content ── */
.ipac-ud-content {
	flex: 1;
	min-width: 0;
	background: #fff;
	border-radius: var(--ipac-radius-md);
	box-shadow: var(--ipac-shadow);
	padding: 20px;
	overflow: visible;
	max-width: 100%;
}
@media (min-width: 576px) { .ipac-ud-content { padding: 32px; } }
@media (min-width: 992px) { .ipac-ud-content { padding: 40px; } }

/* ── Typography ── */
.ipac-ud-title {
	font-size: 30px;
	color: var(--ipac-text-dark);
	margin-bottom: 4px;
	font-weight: 500;
}
@media (min-width: 576px) { .ipac-ud-title { font-size: 34px; } }
.ipac-ud-subtitle {
	font-size: 22px;
	color: var(--ipac-text-light);
	margin-bottom: 32px;
}

/* ── Input layout (icon-prefix) ── */
.ipac-ud-input-wrap {
	position: relative;
}
.ipac-ud-input-wrap .ipac-ud-input-icon {
	position: absolute;
	left: 16px;
	top: 50%;
	transform: translateY(-50%);
	color: #aeaeb2;
	font-size: 18px;
	pointer-events: none;
}

/* ── Note box ── */
.ipac-ud-note {
	background: rgba(240,78,48,0.05);
	border-radius: var(--ipac-radius-sm);
	padding: 12px 20px;
	margin-bottom: 24px;
}
.ipac-ud-note p {
	font-size: 20px;
	color: var(--primary-color);
	line-height: 1.5;
	margin: 0;
}

/* ── Divider ── */
.ipac-ud-divider {
	border-top: 1px solid gray;
	margin: 32px 0;
}

/* ── Section header ── */
.ipac-ud-section-header {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 20px;
}
.ipac-ud-section-title {
	font-size: 26px;
	color: var(--ipac-text-dark);
	font-weight: 500;
	margin: 0;
}
.ipac-ud-section-subtitle {
	font-size: 20px;
	color: var(--ipac-text-light);
	margin: 2px 0 0;
}

/* ── Bootstrap overrides for user dashboard ── */
.ipac-ud-page .form-label {
	font-size: 22px;
	color: var(--ipac-text-medium);
	margin-bottom: 6px;
}
.ipac-ud-page .form-control {
	border: 1px solid #e8e8ed;
	border-radius: 12px;
	font-size: 24px;
	color: var(--ipac-text-dark);
	padding: 12px 16px;
	font-family: inherit;
}
.ipac-ud-page .form-control:focus {
	border-color: rgba(var(--primary-color-rgb), 0.5);
	box-shadow: 0 0 0 3px rgba(var(--primary-color-rgb), 0.1);
}
.ipac-ud-page .form-control:disabled {
	background: var(--ipac-bg);
	color: var(--ipac-text-light);
}
.ipac-ud-page textarea.form-control { resize: vertical; }
.ipac-ud-page .ipac-ud-input-wrap .ipac-ud-input-icon + .form-control {
	padding-left: 48px;
}
.ipac-ud-page .alert {
	border-radius: var(--ipac-radius-sm);
	font-size: 22px;
	border: none;
}
.ipac-ud-page .alert-danger {
	--bs-alert-bg: rgba(239,68,68,0.08);
	--bs-alert-color: #ef4444;
}
.ipac-ud-page .alert-success {
	--bs-alert-bg: rgba(34,197,94,0.08);
	--bs-alert-color: #16a34a;
}
.ipac-ud-page .table-responsive {
	border-radius: var(--ipac-radius-sm);
	border: 1px solid #f0f0f0;
}
.ipac-ud-page .table { margin-bottom: 0; }
.ipac-ud-page .table thead tr { background: var(--ipac-bg); }
.ipac-ud-page .table thead th {
	font-weight: 500;
	font-size: 20px;
	color: var(--ipac-text-medium);
	white-space: nowrap;
	border-color: #f0f0f0;
}
.ipac-ud-page .table tbody td {
	font-size: 22px;
	color: var(--ipac-text-dark);
	border-color: var(--ipac-bg);
}
.ipac-ud-page .table tbody tr:hover { background: #fafafa; }
.ipac-ud-page .nav-pills {
	display: inline-grid;
	grid-auto-flow: column;
	grid-auto-columns: 1fr;
	background: var(--ipac-bg);
	border-radius: var(--ipac-radius-pill);
	padding: 4px;
}
.ipac-ud-page .nav-pills .nav-link {
	text-align: center;
	border-radius: var(--ipac-radius-pill);
	font-size: 22px;
	color: var(--ipac-text-light);
	padding: 8px 20px;
	white-space: nowrap;
	font-family: inherit;
}
.ipac-ud-page .nav-pills .nav-link:hover { color: var(--ipac-text-dark); }
.ipac-ud-page .nav-pills .nav-link.active {
	background: #fff;
	color: var(--ipac-text-dark);
	box-shadow: 0 1px 4px rgba(0,0,0,0.08);
}
.ipac-ud-page .form-check-input[type="radio"] {
	width: 22px;
	height: 22px;
	border-color: #e8e8ed;
}
.ipac-ud-page .form-check-input[type="radio"]:checked {
	background-color: var(--primary-color);
	border-color: var(--primary-color);
}
.ipac-ud-page .form-check-label {
	font-size: 24px;
	color: var(--ipac-text-dark);
}

/* ── Provider cards ── */
.ipac-ud-provider-grid {
	display: flex;
	justify-content: center;
	gap: 16px;
	margin-bottom: 32px;
	flex-wrap: wrap;
}
.ipac-ud-provider-card {
	position: relative;
}
.ipac-ud-provider-card input[type="radio"] { display: none; }
.ipac-ud-provider-card label {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 160px;
	height: 100px;
	border-radius: 16px;
	background: var(--ipac-bg);
	border: 2px solid transparent;
	cursor: pointer;
	transition: all var(--ipac-transition);
	padding: 12px;
}
.ipac-ud-provider-card label img { max-width: 100%; max-height: 100%; object-fit: contain; }
.ipac-ud-provider-card input[type="radio"]:checked + label {
	border-color: var(--primary-color);
	background: rgba(var(--primary-color-rgb), 0.05);
	box-shadow: 0 2px 8px rgba(var(--primary-color-rgb), 0.15);
}

/* ── Download button ── */
.ipac-ud-download-btn {
	display: inline-flex;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: rgba(var(--primary-color-rgb), 0.1);
	color: var(--primary-color);
	align-items: center;
	justify-content: center;
	transition: all var(--ipac-transition);
	text-decoration: none;
}
.ipac-ud-download-btn:hover {
	background: var(--primary-color);
	color: #fff;
}

/* ── Docs ── */
.ipac-ud-docs-columns {
	display: flex;
	align-items: center;
	padding: 0 16px 12px;
	border-bottom: 1px solid #f0f0f0;
	margin-bottom: 8px;
}
.ipac-ud-docs-columns__name { flex: 1; font-size: 20px; color: #86868b; }
.ipac-ud-docs-columns__lang { width: 56px; text-align: center; font-size: 20px; color: #86868b; }
.ipac-ud-docs-section { margin-bottom: 16px; }
.ipac-ud-docs-header {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 16px;
	border-radius: 12px;
	margin-bottom: 4px;
}
.ipac-ud-docs-header img { height: 24px; width: auto; object-fit: contain; }
.ipac-ud-docs-row {
	display: flex;
	align-items: center;
	padding: 14px 16px;
	border-bottom: 1px solid #f5f5f7;
	border-radius: 8px;
}
.ipac-ud-docs-row:last-child { border-bottom: none; }
.ipac-ud-docs-row__name { flex: 1; font-size: 22px; color: var(--ipac-text-dark); padding-right: 16px; }
.ipac-ud-docs-row__action { width: 56px; display: flex; justify-content: center; }
.ipac-ud-docs-row__empty { font-size: 16px; color: #d1d1d6; }

/* ── Empty table row ── */
.ipac-ud-empty-row {
	padding: 48px 16px;
	color: #aeaeb2;
}

/* ── Inline link ── */
.ipac-ud-inline-link {
	font-size: 22px;
	color: var(--primary-color);
	text-decoration: none;
}
.ipac-ud-inline-link:hover { text-decoration: underline; }

/* ── Read-only field ── */
.ipac-ud-readonly-field {
	margin-bottom: 16px;
}
.ipac-ud-readonly-label {
	font-size: 20px;
	color: var(--ipac-text-medium);
	margin-bottom: 4px;
}
.ipac-ud-readonly-value {
	font-size: 24px;
	color: var(--ipac-text-dark);
}

/* ── Password group in history ── */
.ipac-ud-page .password-group .input-group { margin-bottom: 4px; }
.ipac-ud-page .password-group .form-control { font-size: 20px; }

/* ── Table styles inside ud-page ── */
.ipac-ud-page .table tbody tr:nth-child(n+11) { display: none; }
.ipac-ud-page .table th,
.ipac-ud-page .table td {
	border-color: #f0f0f0;
}
.ipac-ud-page .table thead {
	--bs-table-bg: var(--ipac-bg);
	color: var(--ipac-text-medium);
	text-align: left;
}
.ipac-ud-page .table thead th {
	font-weight: 500;
	font-size: 20px;
	white-space: nowrap;
}
.ipac-ud-page .table tbody td {
	font-size: 22px;
	color: var(--ipac-text-dark);
}
.ipac-paginate-info {
	font-size: 20px;
	color: var(--ipac-text-light);
}
.ipac-paginate-group .btn {
	font-size: 18px;
	padding: 4px 12px;
	--bs-btn-border-color: #e0e0e0;
	--bs-btn-disabled-border-color: #e0e0e0;
	--bs-btn-color: var(--ipac-text-light);
	--bs-btn-bg: #fff;
	--bs-btn-hover-bg: var(--ipac-bg);
	--bs-btn-hover-color: var(--ipac-text-dark);
	--bs-btn-hover-border-color: #d0d0d0;
	--bs-btn-disabled-bg: var(--ipac-bg);
	--bs-btn-disabled-color: #aeaeb2;
	--bs-btn-disabled-opacity: 1;
}
.ipac-paginate-group .btn.btn-primary {
	--bs-btn-bg: var(--primary-color);
	--bs-btn-color: #fff;
	--bs-btn-border-color: var(--primary-color);
	--bs-btn-disabled-bg: var(--primary-color);
	--bs-btn-disabled-color: #fff;
	--bs-btn-disabled-border-color: var(--primary-color);
}
.ipac-paginate-group .ipac-paginate-nav {
	--bs-btn-border-color: transparent;
	--bs-btn-hover-bg: transparent;
	--bs-btn-hover-color: var(--ipac-text-dark);
	--bs-btn-hover-border-color: transparent;
	--bs-btn-disabled-bg: transparent;
	--bs-btn-disabled-border-color: transparent;
	--bs-btn-disabled-color: #aeaeb2;
}

/* History status */
.ipac-ud-page .history-status a { color: var(--primary-color); text-decoration: none; }
.ipac-ud-page .history-status a:hover { text-decoration: underline; }



.booking textarea {
	border-color: var(--primary-color);
}


table.dataTable th, table.dataTable td {
	border-color: var(--primary-color) !important;
}
table.dataTable thead {
	--bs-table-bg: var(--primary-color);
	color: #fff;
	text-align: center;
}
table.dataTable thead th {
	font-weight: normal !important;
}

.btn-link {
	--bs-btn-color: var(--primary-color);
	--bs-btn-hover-color: var(--primary-color);
	text-decoration: none;
}

.btn-link:hover {
	text-decoration: underline;
}


table.dataTable {
	margin: 0 0 1em 0  !important;
}
div.dataTables_wrapper div.dataTables_info {
	padding-top: 0;
}

table.dataTable thead > tr > th.sorting::before, table.dataTable thead > tr > th.sorting::after, table.dataTable thead > tr > th.sorting_asc::before, table.dataTable thead > tr > th.sorting_asc::after, table.dataTable thead > tr > th.sorting_desc::before, table.dataTable thead > tr > th.sorting_desc::after, table.dataTable thead > tr > th.sorting_asc_disabled::before, table.dataTable thead > tr > th.sorting_asc_disabled::after, table.dataTable thead > tr > th.sorting_desc_disabled::before, table.dataTable thead > tr > th.sorting_desc_disabled::after, table.dataTable thead > tr > td.sorting::before, table.dataTable thead > tr > td.sorting::after, table.dataTable thead > tr > td.sorting_asc::before, table.dataTable thead > tr > td.sorting_asc::after, table.dataTable thead > tr > td.sorting_desc::before, table.dataTable thead > tr > td.sorting_desc::after, table.dataTable thead > tr > td.sorting_asc_disabled::before, table.dataTable thead > tr > td.sorting_asc_disabled::after, table.dataTable thead > tr > td.sorting_desc_disabled::before, table.dataTable thead > tr > td.sorting_desc_disabled::after {
	opacity: 0.5;
	font-size:1em;
}

table.dataTable thead > tr > th.sorting_asc::before, table.dataTable thead > tr > th.sorting_desc::after, table.dataTable thead > tr > td.sorting_asc::before, table.dataTable thead > tr > td.sorting_desc::after {
	opacity: 1;
}

table.dataTable thead > tr > th.sorting::before, table.dataTable thead > tr > th.sorting_asc::before, table.dataTable thead > tr > th.sorting_desc::before, table.dataTable thead > tr > th.sorting_asc_disabled::before, table.dataTable thead > tr > th.sorting_desc_disabled::before, table.dataTable thead > tr > td.sorting::before, table.dataTable thead > tr > td.sorting_asc::before, table.dataTable thead > tr > td.sorting_desc::before, table.dataTable thead > tr > td.sorting_asc_disabled::before, table.dataTable thead > tr > td.sorting_desc_disabled::before {
	content: "\f0de";
	font-weight: 900;
}

table.dataTable thead > tr > th.sorting::after, table.dataTable thead > tr > th.sorting_asc::after, table.dataTable thead > tr > th.sorting_desc::after, table.dataTable thead > tr > th.sorting_asc_disabled::after, table.dataTable thead > tr > th.sorting_desc_disabled::after, table.dataTable thead > tr > td.sorting::after, table.dataTable thead > tr > td.sorting_asc::after, table.dataTable thead > tr > td.sorting_desc::after, table.dataTable thead > tr > td.sorting_asc_disabled::after, table.dataTable thead > tr > td.sorting_desc_disabled::after {
	content: "\f0dd";
	font-weight: 900;
}

.pagination {
	--bs-pagination-font-size: var(--body-font-size);
	--bs-pagination-color: var(--primary-color);
	--bs-pagination-border-color: var(--primary-color);
	--bs-pagination-border-radius: 7px;
	--bs-pagination-hover-color: #fff;
	--bs-pagination-hover-bg: var(--primary-color);
	--bs-pagination-hover-border-color: var(--primary-color);
	--bs-pagination-focus-color: var(--primary-color);
	--bs-pagination-focus-bg: var(--primary-color);
	--bs-pagination-active-color: #fff;
	--bs-pagination-active-bg: var(--primary-color);
	--bs-pagination-active-border-color: var(--primary-color);
	--bs-pagination-disabled-border-color: var(--primary-color);
}

table.dataTable thead th, table.dataTable thead td, table.dataTable tfoot th, table.dataTable tfoot td {
	text-align: inherit;
}

footer {
	background-color: #fff;
}

.construction {
	position: absolute;
	max-width: 100%;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	text-align: center;
}


#frmBooked .fa-angle-double-right {
	font-size: 15px;
}

body.kiosk {
	background-image: URL("../img/kiosk-background.png");
	background-size: cover;
	background-position: center ;
	background-repeat: no-repeat;
	background-attachment: fixed;
	min-height: 100vh;
}

.kiosk-navbar {
	background: #fff;
	box-shadow: 0 1px 8px rgba(0,0,0,0.08);
}

.kiosk-body {
	margin: 50px 0;
	background-color: #fff;
	padding: 50px;
	border-radius: 25px;
}

/* ── Kiosk reception (from styles-v2) ── */
.th {
	font-size: 100%;
	line-height: 100%;
}
.btn-linear {
	background: linear-gradient(20deg, rgba(242,160,110,1) 5%, rgba(253,121,10,1) 41%, rgba(194,95,63,1) 100%);
	color: #FFF;
	font-size: 24px;
	border-radius: 3rem;
	padding: 0.75rem 3rem;
	display: inline-block;
}
.btn-linear:hover {
	background: linear-gradient(20deg, rgba(255,181,136,1) 5%, rgba(240,110,0,1) 41%, rgba(147,27,0,1) 100%);
	color: #FFF;
}
.download-queue {
	background-color: #F2F2F2;
	padding: 1rem;
	text-align: center;
	max-width: 320px;
	margin: 0 auto;
}
.download-queue-inner {
	background-color: #FFF;
	padding: 1rem;
	border-radius: var(--bs-border-radius);
}
.download-queue-inner table {
	background-color: #FFF;
}
.download-queue-inner h1 {
	font-size: 120px;
}
.download-queue-inner h2 {
	font-size: 24px;
	letter-spacing: 0.4px;
}
.dashboard-layout {
	background-color: #F2F2F2;
}
.m-checkbox-inline .checkbox {
	display: inline-block;
}
.m-checkbox-inline .radio {
	display: inline-block;
}
.m-checkbox-inline label {
	margin-right: 20px;
}


.carousel-feature .carousel-caption {
	top: unset;
	left: 5%;
	bottom: 5%;
	right: unset;
	transform: none;
	max-width: 500px;
	text-align: left;
	white-space: normal;
}

.carousel-feature .carousel-item .ratio::after {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(0,0,0,0.25);
}

@media (max-width: 767.98px) {
	/* Mobile */
	.carousel-feature .carousel-caption {
		left: 10px;
		bottom: 10px;
		right: 10px;
	}
}

/* ============================================================
   REDESIGN — Apple-inspired components
   ============================================================ */

/* --- Utilities --- */
.text-primary { color: var(--primary-color) !important; }
.bg-primary { background-color: var(--primary-color) !important; }

/* --- Navbar --- */
.ipac-navbar {
	--bs-nav-link-color: var(--ipac-text-medium);
	--bs-nav-link-hover-color: var(--ipac-text-dark);
	--bs-nav-link-font-size: 24px;
	--bs-nav-link-padding-y: 0;
	--bs-nav-link-padding-x: 0;
	z-index: 1050;
	height: var(--ipac-navbar-height);
	background: rgba(255,255,255,1);
	transition: background var(--ipac-transition), box-shadow var(--ipac-transition);
}
@media (max-width: 991.98px) {
	.ipac-navbar {
		height: auto;
		min-height: var(--ipac-navbar-height);
		background: rgba(255,255,255,0.8);
		-webkit-backdrop-filter: blur(20px);
		backdrop-filter: blur(20px);
	}
}
.ipac-navbar.scrolled {
	background: rgba(255,255,255,0.8);
	-webkit-backdrop-filter: blur(20px);
	backdrop-filter: blur(20px);
	box-shadow: 0 1px 3px rgba(0,0,0,0.06);
}
.ipac-navbar__inner {
	--bs-gutter-x: 40px;
	height: var(--ipac-navbar-height);
	display: flex;
	align-items: center;
	justify-content: space-between;
	position: relative;
}
@media (min-width: 992px) {
	.ipac-navbar__inner { --bs-gutter-x: 48px; }
}
.ipac-navbar__logo { padding: 0; margin: 0; }
.ipac-navbar__logo img {
	height: 36px;
	width: auto;
	object-fit: contain;
}
@media (min-width: 576px) { .ipac-navbar__logo img { height: 40px; } }
@media (min-width: 992px) { .ipac-navbar__logo img { height: 44px; } }

.ipac-navbar__links {
	display: none;
	align-items: center;
	gap: 32px;
}
@media (min-width: 992px) {
	.ipac-navbar__links {
		display: flex;
		position: absolute;
		left: 50%;
		transform: translateX(-50%);
	}
}
.ipac-navbar__link.active { color: var(--primary-color); }

.ipac-navbar__cta {
	display: none;
	align-items: center;
	gap: 16px;
}
.ipac-navbar__cta .btn-primary { font-size: 19px; padding: 8px 24px; }
@media (min-width: 992px) {
	.ipac-navbar__cta { display: flex; }
}
.ipac-navbar__login {
	font-size: 20px;
	color: var(--ipac-text-dark);
	text-decoration: none;
	font-weight: 500;
	transition: color 0.2s;
}
.ipac-navbar__login:hover { color: var(--primary-color); }

/* Logged-in user pill */
.ipac-navbar__user {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 4px 6px 4px 16px;
	font-size: 20px;
	font-weight: 500;
	color: var(--ipac-text-dark);
	text-decoration: none;
	border-radius: var(--ipac-radius-pill);
	background: var(--ipac-bg);
	transition: all 0.2s;
}
.ipac-navbar__user i {
	width: 32px;
	height: 32px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: var(--primary-color);
	color: #fff;
	font-size: 16px;
}
.ipac-navbar__user:hover { background: #e8e8ed; color: var(--ipac-text-dark); }

/* Logout icon */
.ipac-navbar__logout {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	font-size: 16px;
	color: var(--ipac-text-light);
	text-decoration: none;
	transition: all 0.2s;
}
.ipac-navbar__logout:hover {
	color: #ef4444;
	background: #fef2f2;
}

.ipac-navbar__mobile {
	display: flex;
	align-items: center;
	gap: 12px;
}
@media (min-width: 992px) {
	.ipac-navbar__mobile { display: none; }
}
.ipac-navbar__mobile-cta {
	display: inline-block;
}

/* ── Site-wide Bootstrap button overrides ── */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	border-radius: var(--ipac-radius-pill);
	font-weight: 500;
	font-size: 24px;
	padding: 12px 28px;
	transition: all var(--ipac-transition);
	line-height: 1.4;
}
.btn-primary {
	--bs-btn-bg: var(--primary-color);
	--bs-btn-border-color: var(--primary-color);
	--bs-btn-hover-bg: rgba(240,78,48,0.9);
	--bs-btn-hover-border-color: rgba(240,78,48,0.9);
	--bs-btn-active-bg: var(--primary-color);
	--bs-btn-active-border-color: var(--primary-color);
	--bs-btn-disabled-bg: var(--primary-color);
	--bs-btn-disabled-border-color: var(--primary-color);
}
.btn-primary:hover {
	box-shadow: 0 4px 16px rgba(240,78,48,0.25);
}
.btn-primary:active { transform: scale(0.97); }
.btn-outline-primary {
	--bs-btn-color: var(--primary-color);
	--bs-btn-border-color: transparent;
	--bs-btn-bg: rgba(var(--primary-color-rgb), 0.08);
	--bs-btn-hover-bg: rgba(var(--primary-color-rgb), 0.15);
	--bs-btn-hover-color: var(--primary-color);
	--bs-btn-hover-border-color: transparent;
	--bs-btn-active-bg: rgba(var(--primary-color-rgb), 0.2);
	--bs-btn-active-color: var(--primary-color);
	--bs-btn-active-border-color: transparent;
}
.btn-outline-danger {
	--bs-btn-color: #ef4444;
	--bs-btn-border-color: transparent;
	--bs-btn-bg: rgba(239,68,68,0.08);
	--bs-btn-hover-bg: rgba(239,68,68,0.15);
	--bs-btn-hover-color: #ef4444;
	--bs-btn-hover-border-color: transparent;
	--bs-btn-active-bg: rgba(239,68,68,0.2);
	--bs-btn-active-color: #ef4444;
	--bs-btn-active-border-color: transparent;
}
.btn-light {
	--bs-btn-bg: var(--ipac-bg);
	--bs-btn-color: var(--ipac-text-medium);
	--bs-btn-border-color: transparent;
	--bs-btn-hover-bg: #e8e8ed;
	--bs-btn-hover-color: var(--ipac-text-dark);
	--bs-btn-hover-border-color: transparent;
}

/* Navbar toggler (BS base) */
.ipac-navbar .navbar-toggler {
	border: none;
	padding: 4px;
	font-size: 20px;
	box-shadow: none;
}
.ipac-navbar .navbar-toggler:focus { box-shadow: none; }
.ipac-navbar .navbar-toggler-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background-image: none;
	width: 24px;
	height: 24px;
}
.ipac-navbar .navbar-toggler-icon::before {
	font-weight: 900;
	content: "\f0c9";
	color: rgba(29,29,31,0.8);
}

/* Mobile menu (BS collapse) */
@media (min-width: 992px) {
	.ipac-mobile-menu { display: none !important; }
}
.ipac-mobile-menu {
	padding: 16px 24px;
	max-height: calc(100vh - var(--ipac-navbar-height));
	max-height: calc(100dvh - var(--ipac-navbar-height));
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	overscroll-behavior: contain;
}
.ipac-mobile-menu > a {
	display: block;
	font-size: 24px;
	padding: 12px 0;
	border-bottom: 1px solid #f0f0f0;
	color: var(--ipac-text-dark);
}
.ipac-mobile-menu > a:last-of-type { border-bottom: none; }
.ipac-mobile-menu > a:hover,
.ipac-mobile-menu > a.active { color: var(--primary-color); }

/* Mobile menu — profile section (card) */
.ipac-mobile-menu__profile {
	margin-top: 12px;
	background: #fff;
	border-radius: var(--ipac-radius-md);
	border: 1px solid #f0f0f0;
	box-shadow: var(--ipac-shadow);
	overflow: hidden;
}
.ipac-mobile-menu__profile-header {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 16px 16px 12px;
}
.ipac-mobile-menu__avatar {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: var(--ipac-bg);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--primary-color);
	font-size: 20px;
	flex-shrink: 0;
}
.ipac-mobile-menu__user-info {
	min-width: 0;
	line-height: 1.0;
}
.ipac-mobile-menu__profile-name {
	display: block;
	font-size: 22px;
	font-weight: 500;
	color: var(--ipac-text-dark);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.ipac-mobile-menu__email {
	display: block;
	font-size: 18px;
	color: var(--ipac-text-light);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	margin-top: 2px;
}
.ipac-mobile-menu__nav {
	padding: 4px 8px;
	border-top: 1px solid #f0f0f0;
}
.ipac-mobile-menu__nav a {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 10px 8px;
	font-size: 22px;
	color: var(--ipac-text-dark);
	text-decoration: none;
	border-bottom: none;
	border-radius: 8px;
}
.ipac-mobile-menu__nav a:hover { background: var(--ipac-bg); }
.ipac-mobile-menu__nav a i {
	width: 20px;
	text-align: center;
	color: var(--ipac-text-light);
	font-size: 18px;
	flex-shrink: 0;
}
.ipac-mobile-menu__actions {
	padding: 4px 8px;
	border-top: 1px solid #f0f0f0;
}
.ipac-mobile-menu__actions a,
.ipac-mobile-menu__actions span {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 10px 8px;
	font-size: 22px;
	text-decoration: none;
	border-bottom: none;
	border-radius: 8px;
}
.ipac-mobile-menu__actions a i,
.ipac-mobile-menu__actions span i {
	width: 20px;
	text-align: center;
	font-size: 18px;
	flex-shrink: 0;
}
.ipac-mobile-menu__line-link { color: #06c755; }
.ipac-mobile-menu__line-link:hover { background: rgba(6,199,85,0.05); }
.ipac-mobile-menu__line-connected {
	color: #06c755;
	cursor: default;
	opacity: 0.7;
}
.ipac-mobile-menu__logout { color: #ef4444 !important; }
.ipac-mobile-menu__logout:hover { background: rgba(239,68,68,0.05) !important; }
.ipac-mobile-menu__logout i { color: #ef4444 !important; }

/* Body spacing for fixed navbar */
body { padding-top: var(--ipac-navbar-height); }
body.kiosk { padding-top: 0; }

/* --- HeroBanner (Bootstrap Carousel) --- */
.ipac-hero {
	width: 100%;
	overflow: hidden;
	margin-top: calc(-1 * var(--ipac-navbar-height));
}
.ipac-hero__slide {
	position: relative;
	width: 100%;
	height: 100vh;
}
.ipac-hero__slide img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.ipac-hero__slide.img-broken::before {
	font-size: 64px;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 0;
}
.ipac-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to right, rgba(29,29,31,0.8) 0%, rgba(29,29,31,0.5) 40%, transparent 70%);
}
@media (max-width: 767.98px) {
	.ipac-hero__overlay {
		background: linear-gradient(to top, rgba(29,29,31,0.7) 0%, transparent 60%),
		            linear-gradient(to right, rgba(29,29,31,0.6) 0%, transparent 60%);
	}
}
.ipac-hero__content {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: 0 24px 64px;
	z-index: 1;
}
@media (min-width: 768px) {
	.ipac-hero__content {
		justify-content: center;
		padding: 0 72px;
	}
}
@media (min-width: 992px) {
	.ipac-hero__content { padding: 0 96px; }
}
.ipac-hero__content-inner { max-width: 560px; }
.ipac-hero__title {
	font-size: 32px;
	color: #fff;
	line-height: 1.15;
	margin-bottom: 16px;
}
.ipac-hero__title .highlight { color: var(--secondary-color); }
@media (min-width: 576px) { .ipac-hero__title { font-size: 40px; } }
@media (min-width: 768px) { .ipac-hero__title { font-size: 48px; } }
@media (min-width: 992px) { .ipac-hero__title { font-size: 52px; } }

.ipac-hero__subtitle {
	font-size: 22px;
	color: rgba(255,255,255,0.75);
	line-height: 1.6;
	max-width: 440px;
	margin-bottom: 24px;
}
@media (min-width: 768px) { .ipac-hero__subtitle { margin-bottom: 32px; } }

/* Hero carousel indicators */
/* Hero carousel indicators — override Bootstrap defaults */
.ipac-hero__indicators.carousel-indicators {
	bottom: 20px;
	gap: 8px;
	margin: 0 auto;
	padding: 0;
}
@media (min-width: 768px) { .ipac-hero__indicators.carousel-indicators { bottom: 28px; } }
.ipac-hero__indicators.carousel-indicators [data-bs-target] {
	width: 20px;
	height: 6px;
	padding: 0;
	margin: 0;
	border-radius: 9999px;
	background: rgba(255,255,255,0.3);
	background-clip: unset;
	border: none;
	opacity: 1;
	text-indent: 0;
	box-sizing: border-box;
	flex: none;
	transition: width 0.3s;
	position: relative;
	overflow: hidden;
}
.ipac-hero__indicators.carousel-indicators [data-bs-target]::after {
	content: '';
	position: absolute;
	left: 0; top: 0; bottom: 0;
	width: 0;
	background: #fff;
	border-radius: 9999px;
}
.ipac-hero__indicators.carousel-indicators .active {
	width: 40px;
	background: rgba(255,255,255,0.3);
}
.ipac-hero__indicators.carousel-indicators .active::after {
	animation: ipac-dot-progress 5s linear forwards;
}
@keyframes ipac-dot-progress {
	from { width: 0; }
	to { width: 100%; }
}

/* Hero carousel controls */
.ipac-hero__control {
	display: none;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: rgba(255,255,255,0.15);
	-webkit-backdrop-filter: blur(8px);
	backdrop-filter: blur(8px);
	border: 1px solid rgba(255,255,255,0.2);
	top: 50%;
	transform: translateY(-50%);
	bottom: auto;
	opacity: 1;
	transition: background 0.3s;
}
@media (min-width: 768px) {
	.ipac-hero__control {
		display: flex;
		align-items: center;
		justify-content: center;
	}
}
.ipac-hero__control:hover { background: rgba(255,255,255,0.3); }
.ipac-hero__control i { font-size: 20px; color: #fff; }
.carousel-control-prev.ipac-hero__control { left: 16px; }
.carousel-control-next.ipac-hero__control { right: 16px; }
@media (min-width: 992px) {
	.carousel-control-prev.ipac-hero__control { left: 24px; }
	.carousel-control-next.ipac-hero__control { right: 24px; }
}
/* Hide default Bootstrap carousel icons */
.ipac-hero__control .carousel-control-prev-icon,
.ipac-hero__control .carousel-control-next-icon { display: none; }

/* --- Section common --- */
/* .ipac-section replaced by: py-5 py-sm-6 py-lg-7 */
/* .ipac-section-header spacing replaced by: text-center mb-5 mb-lg-6 */
.ipac-section-header h2 {
	font-size: 32px;
	color: var(--ipac-text-dark);
	margin-bottom: 12px;
	font-weight: 500;
}
@media (min-width: 576px) { .ipac-section-header h2 { font-size: 40px; } }
@media (min-width: 992px) { .ipac-section-header h2 { font-size: 44px; } }
.ipac-section-header p {
	font-size: 22px;
	color: var(--ipac-text-medium);
	max-width: 500px;
	margin: 0 auto;
	line-height: 1.6;
}

/* --- Section header & Content cards --- */
.ipac-section-header {
	margin-bottom: 32px;
}
@media (min-width: 576px) {
	.ipac-section-header {
		margin-bottom: 40px;
	}
}
.ipac-section-header .subtitle {
	font-size: 24px;
	color: var(--primary-color);
	margin-bottom: 4px;
}
.ipac-section-header h2 {
	font-size: 40px;
	color: var(--ipac-text-dark);
	line-height: 1.15;
	margin: 0;
}
@media (min-width: 576px) { .ipac-section-header h2 { font-size: 44px; } }
@media (min-width: 992px) { .ipac-section-header h2 { font-size: 52px; } }

.ipac-link-arrow {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 24px;
	color: var(--primary-color);
	text-decoration: none;
	transition: gap var(--ipac-transition);
}
.ipac-link-arrow:hover { gap: 12px; color: var(--primary-color); }

/* Base card theming via BS custom properties */
.ipac-content-card,
.ipac-article-card,
.ipac-bento-card,
.ipac-about-card,
.ipac-team-card,
.ipac-pub-card {
	--bs-card-border-width: 0;
	--bs-card-border-radius: var(--ipac-radius-md);
	--bs-card-box-shadow: var(--ipac-shadow);
	box-shadow: var(--bs-card-box-shadow);
	overflow: hidden;
	transition: all var(--ipac-transition);
}
.ipac-bento-card,
.ipac-about-card,
.ipac-team-card {
	--bs-card-border-radius: var(--ipac-radius-lg);
}

.ipac-card-grid-3 {
	display: grid;
	grid-template-columns: 1fr;
	gap: 24px;
}
@media (min-width: 576px) { .ipac-card-grid-3 { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 992px) { .ipac-card-grid-3 { grid-template-columns: repeat(3, 1fr); gap: 32px; } }

.ipac-content-card {
	text-decoration: none;
	color: inherit;
}
.ipac-content-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--ipac-shadow-hover);
	color: inherit;
}
.ipac-content-card__image {
	position: relative;
	aspect-ratio: 16/10;
	overflow: hidden;
	background: linear-gradient(135deg, rgba(var(--primary-color-rgb),0.08) 0%, rgba(var(--alternative-color-rgb),0.12) 50%, rgba(var(--primary-color-rgb),0.06) 100%);
}
.ipac-content-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s;
}
.ipac-content-card:hover .ipac-content-card__image img { transform: scale(1.05); }
.ipac-content-card__body { padding: 24px; }
.ipac-content-card__date {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 19px;
	color: var(--ipac-text-light);
	margin-bottom: 12px;
}
.ipac-content-card__title {
	font-size: 24px;
	font-weight: 500;
	color: var(--ipac-text-dark);
	line-height: 1.4;
	margin-bottom: 12px;
	display: -webkit-box;
	line-clamp: 2;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	transition: color var(--ipac-transition);
}
.ipac-content-card:hover .ipac-content-card__title { color: var(--primary-color); }
.ipac-content-card__excerpt {
	font-size: 20px;
	color: var(--ipac-text-light);
	line-height: 1.5;
	display: -webkit-box;
	line-clamp: 2;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.ipac-content-card__readmore {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 20px;
	color: var(--primary-color);
	margin-top: 20px;
	opacity: 0;
	transition: opacity var(--ipac-transition);
}
.ipac-content-card:hover .ipac-content-card__readmore { opacity: 1; }

/* --- BentoGrid (Services) --- */
.ipac-bento-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 20px;
}
@media (min-width: 992px) {
	.ipac-bento-grid { grid-template-columns: 7fr 5fr; gap: 28px; }
}
.ipac-bento-flex {
	display: flex;
	flex-direction: column;
	gap: 20px;
}
@media (min-width: 992px) { .ipac-bento-flex { gap: 28px; } }

.ipac-bento-card {
	flex: 1;
	transition: all 0.5s;
}
.ipac-bento-card:hover {
	box-shadow: var(--ipac-shadow-hover);
	transform: translateY(-4px);
}
.ipac-bento-card__image {
	position: relative;
	height: 200px;
	overflow: hidden;
}
@media (min-width: 576px) { .ipac-bento-card__image { height: 240px; } }
@media (min-width: 992px) { .ipac-bento-card__image { height: 260px; } }
.ipac-bento-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.7s;
}
.ipac-bento-card:hover .ipac-bento-card__image img { transform: scale(1.05); }
.ipac-bento-card__image::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(0,0,0,0.4), rgba(0,0,0,0.1), transparent);
}
.ipac-bento-card__image-title {
	position: absolute;
	bottom: 20px;
	left: 20px;
	right: 20px;
	z-index: 1;
	font-size: 26px;
	color: #fff;
	line-height: 1.3;
}
.ipac-bento-card__body { padding: 20px; display: flex; flex-direction: column; flex: 1; }
@media (min-width: 576px) { .ipac-bento-card__body { padding: 24px; } }
@media (min-width: 992px) { .ipac-bento-card__body { padding: 28px; } }
.ipac-bento-card__body p {
	font-size: 22px;
	color: var(--ipac-text-medium);
	line-height: 1.7;
	margin-bottom: 24px;
}

.ipac-bento-channels {
	display: grid;
	grid-template-columns: 1fr;
	gap: 16px;
	align-items: stretch;
	margin-top: auto;
}
@media (min-width: 576px) { .ipac-bento-channels { grid-template-columns: 1fr 1fr; } }
.ipac-bento-channel {
	background: var(--ipac-bg);
	border-radius: 16px;
	padding: 16px;
}
.ipac-bento-channel__header {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 12px;
}
.ipac-bento-channel__icon {
	width: 32px;
	height: 32px;
	border-radius: 12px;
	background: rgba(240,78,48,0.1);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--primary-color);
	font-size: 18px;
}
.ipac-bento-channel__name {
	font-size: 22px;
	color: var(--ipac-text-dark);
	font-weight: 500;
}
.ipac-bento-channel__detail {
	font-size: 20px;
	color: var(--ipac-text-medium);
	line-height: 1.6;
}
.ipac-bento-channel__detail .item {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 4px;
}

.ipac-bento-tags {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
	gap: 12px;
	margin-top: auto;
}
.ipac-bento-tags > img {
	width: 100%;
	height: 60px;
	object-fit: contain;
	background: var(--ipac-bg);
	border-radius: var(--ipac-radius-pill);
	padding: 4px 16px;
}
.ipac-bento-tag {
	background: var(--ipac-bg);
	font-size: 20px;
	color: var(--ipac-text-dark);
	padding: 4px 16px;
	border-radius: var(--ipac-radius-pill);
	display: inline-flex;
	align-items: center;
}
.ipac-bento-tag img {
	height: 60px;
	width: 140px;
	object-fit: contain;
	display: block;
}

/* Benefits gradient card */
.ipac-bento-benefits {
	flex: 1;
	background: linear-gradient(135deg, var(--primary-color), #d93d1f);
	border-radius: var(--ipac-radius-lg);
	padding: 20px;
	box-shadow: var(--ipac-shadow);
	transition: all 0.5s;
	color: #fff;
}
@media (min-width: 576px) { .ipac-bento-benefits { padding: 24px; } }
.ipac-bento-benefits:hover {
	box-shadow: 0 12px 48px rgba(240,78,48,0.2);
	transform: translateY(-4px);
}
.ipac-bento-benefits h4 {
	font-size: 26px;
	color: #fff;
	margin-bottom: 16px;
	font-weight: 500;
}
.ipac-bento-benefits__item {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	margin-bottom: 10px;
}
.ipac-bento-benefits__item i {
	color: rgba(255,255,255,0.8);
	margin-top: 4px;
	flex-shrink: 0;
}
.ipac-bento-benefits__item span {
	font-size: 22px;
	color: rgba(255,255,255,0.9);
	line-height: 1.5;
}

/* --- Benefits Section --- */
.ipac-benefits { background: var(--ipac-bg); }
.ipac-benefits__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 16px;
}
@media (min-width: 576px) { .ipac-benefits__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 992px) {
	.ipac-benefits__grid { grid-template-columns: repeat(6, 1fr); }
	.ipac-benefits__card:nth-child(-n+3) { grid-column: span 2; }
	.ipac-benefits__card:nth-child(n+4) { grid-column: span 3; }
}
.ipac-benefits__card {
	background: #fff;
	border-radius: var(--ipac-radius-md);
	padding: 28px 24px;
	box-shadow: var(--ipac-shadow);
	transition: all 0.3s;
}
.ipac-benefits__card:hover {
	transform: translateY(-4px);
	box-shadow: 0 8px 32px rgba(0,0,0,0.1);
}
.ipac-benefits__icon {
	width: 48px;
	height: 48px;
	border-radius: 14px;
	background: rgba(var(--primary-color-rgb), 0.1);
	color: var(--primary-color);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 22px;
	margin-bottom: 16px;
}
.ipac-benefits__card h4 {
	font-size: 24px;
	font-weight: 600;
	color: var(--ipac-text-dark);
	margin-bottom: 8px;
}
.ipac-benefits__card p {
	font-size: 22px;
	color: var(--ipac-text-medium);
	line-height: 1.5;
	margin: 0;
}

/* --- AboutSection --- */
.ipac-about-card {
	padding: 24px;
}
@media (min-width: 576px) { .ipac-about-card { padding: 32px; } }
@media (min-width: 992px) { .ipac-about-card { padding: 40px; } }
.ipac-about-image {
	position: relative;
	border-radius: 22px;
	overflow: hidden;
}
.ipac-about-image img {
	width: 100%;
	height: 280px;
	object-fit: cover;
}
@media (min-width: 576px) { .ipac-about-image img { height: 340px; } }
@media (min-width: 992px) { .ipac-about-image img { height: 420px; } }
.ipac-about-float {
	position: absolute;
	bottom: 20px;
	right: 20px;
	background: rgba(255,255,255,0.7);
	-webkit-backdrop-filter: blur(20px);
	backdrop-filter: blur(20px);
	border-radius: 20px;
	box-shadow: 0 8px 32px rgba(0,0,0,0.12);
	padding: 16px 24px;
	border: 1px solid rgba(255,255,255,0.5);
}
.ipac-about-float__big {
	font-size: 40px;
	color: var(--primary-color);
	line-height: 1;
	margin-bottom: 4px;
	font-weight: 500;
}
.ipac-about-float__small {
	font-size: 26px;
	color: var(--ipac-text-medium);
}
.ipac-about-items { display: flex; flex-direction: column; gap: 32px; }
@media (min-width: 992px) { .ipac-about-items { gap: 40px; padding-top: 8px; } }
.ipac-about-item {
	display: flex;
	gap: 16px;
}
@media (min-width: 576px) { .ipac-about-item { gap: 20px; } }
.ipac-about-item__num {
	font-size: 44px;
	color: var(--primary-color);
	line-height: 1;
	flex-shrink: 0;
	width: 48px;
	font-weight: 700;
}
@media (min-width: 576px) { .ipac-about-item__num { font-size: 48px; width: 56px; } }
.ipac-about-item__content { flex: 1; padding-top: 4px; }
.ipac-about-item__title {
	font-size: 30px;
	color: var(--ipac-text-dark);
	margin-bottom: 8px;
	font-weight: 500;
}
.ipac-about-item__text {
	font-size: 26px;
	color: var(--ipac-text-medium);
	line-height: 1.7;
	margin: 0;
}
.ipac-about-item__eng {
	font-size: 24px;
	color: rgba(240,78,48,0.6);
	margin-top: 6px;
}

/* --- TeamSection --- */
.ipac-team-card {
	padding: 24px;
	margin-bottom: 24px;
}
@media (min-width: 576px) { .ipac-team-card { padding: 32px; } }
@media (min-width: 992px) { .ipac-team-card { padding: 40px; margin-bottom: 28px; } }
.ipac-team-card__header {
	text-align: center;
	margin-bottom: 32px;
}
@media (min-width: 576px) { .ipac-team-card__header { margin-bottom: 40px; } }
.ipac-team-card__header h3 {
	font-size: 30px;
	color: var(--ipac-text-dark);
	font-weight: 500;
	margin: 0;
}
@media (min-width: 576px) { .ipac-team-card__header h3 { font-size: 32px; } }
/* .ipac-team-grid replaced by: row row-cols-2 row-cols-sm-3 row-cols-md-4 g-4 justify-content-center */
.ipac-team-member {
	text-align: center;
}
.ipac-team-avatar {
	width: 104px;
	height: 104px;
	border-radius: 50%;
	margin: 0 auto 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 42px;
	font-weight: 500;
	overflow: hidden;
	transition: transform 0.3s;
}
@media (min-width: 576px) { .ipac-team-avatar { width: 120px; height: 120px; font-size: 48px; } }
.ipac-team-member:hover .ipac-team-avatar { transform: scale(1.05); }
.ipac-team-avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
/* Avatar color variants */
.ipac-team-avatar--1 { background: rgba(240,78,48,0.15); color: var(--primary-color); }
.ipac-team-avatar--2 { background: rgba(242,165,152,0.25); color: var(--primary-color); }
.ipac-team-avatar--3 { background: #fef3c7; color: #b45309; }
.ipac-team-avatar--4 { background: #e0f2fe; color: #0369a1; }
.ipac-team-avatar--5 { background: #ede9fe; color: #6d28d9; }
.ipac-team-avatar--6 { background: #d1fae5; color: #047857; }
.ipac-team-avatar--7 { background: #ffe4e6; color: #dc2626; }
.ipac-team-avatar--8 { background: #e0e7ff; color: #4338ca; }
.ipac-team-avatar--9 { background: #ccfbf1; color: #0f766e; }

/* Director highlight */
.ipac-team-director .ipac-team-avatar {
	width: 128px;
	height: 128px;
	font-size: 52px;
	box-shadow: 0 0 0 4px rgba(240,78,48,0.1);
}
@media (min-width: 576px) {
	.ipac-team-director .ipac-team-avatar { width: 148px; height: 148px; font-size: 56px; }
}

.ipac-team-member__name {
	font-size: 24px;
	color: var(--ipac-text-dark);
	line-height: 1.4;
}
.ipac-team-member__role {
	font-size: 22px;
	color: var(--primary-color);
	margin-top: 2px;
	line-height: 1.4;
}

/* --- NetworkSection (marquee) --- */
.ipac-network-track {
	overflow: hidden;
	width: 100%;
	padding: 8px 0;
}
.ipac-network-marquee {
	display: flex;
	gap: 24px;
	width: max-content;
	animation: ipac-marquee 30s linear infinite;
}
@media (min-width: 576px) { .ipac-network-marquee { gap: 32px; } }
@keyframes ipac-marquee {
	0% { transform: translateX(0); }
	100% { transform: translateX(-50%); }
}
.ipac-network-logo {
	flex-shrink: 0;
	width: 100px;
	height: 100px;
	border-radius: 24px;
	background: #fff;
	box-shadow: var(--ipac-shadow);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 12px;
}
@media (min-width: 576px) { .ipac-network-logo { width: 120px; height: 120px; } }
.ipac-network-logo img {
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
}

/* --- ContactSection --- */
.ipac-contact {
	position: relative;
	background: var(--ipac-text-dark);
	color: #fff;
	overflow: hidden;
}
.ipac-contact__bg {
	position: absolute;
	inset: 0;
	z-index: 0;
}
.ipac-contact__bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.ipac-contact__bg::after {
	content: '';
	position: absolute;
	inset: 0;
	background: rgba(29,29,31,0.92);
	-webkit-backdrop-filter: blur(8px);
	backdrop-filter: blur(8px);
}
.ipac-contact__inner {
	position: relative;
	z-index: 1;
	padding-top: 56px;
	padding-bottom: 56px;
}
@media (min-width: 576px) { .ipac-contact__inner { padding-top: 64px; padding-bottom: 64px; } }
@media (min-width: 992px) { .ipac-contact__inner { padding-top: 80px; padding-bottom: 80px; } }
.ipac-contact__header {
	text-align: center;
	margin-bottom: 32px;
}
@media (min-width: 576px) { .ipac-contact__header { margin-bottom: 40px; } }
.ipac-contact__header h2 {
	font-size: 32px;
	color: #fff;
	margin-bottom: 8px;
}
@media (min-width: 576px) { .ipac-contact__header h2 { font-size: 40px; } }
@media (min-width: 992px) { .ipac-contact__header h2 { font-size: 44px; } }
.ipac-contact__header p {
	font-size: 22px;
	color: rgba(255,255,255,0.6);
	max-width: 460px;
	margin: 0 auto;
}

.ipac-contact__map {
	border-radius: var(--ipac-radius-md);
	overflow: hidden;
	box-shadow: 0 4px 32px rgba(0,0,0,0.2);
	min-height: 280px;
	position: relative;
}
@media (min-width: 992px) { .ipac-contact__map { min-height: 320px; } }
.ipac-contact__map iframe {
	width: 100%;
	height: 100%;
	min-height: 280px;
	border: 0;
	display: block;
}
@media (min-width: 992px) { .ipac-contact__map iframe { min-height: 320px; } }

.ipac-contact-info {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	background: rgba(255,255,255,0.08);
	-webkit-backdrop-filter: blur(12px);
	backdrop-filter: blur(12px);
	border-radius: var(--ipac-radius-sm);
	padding: 16px;
	border: 1px solid rgba(255,255,255,0.1);
}
.ipac-contact-info__icon {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: rgba(240,78,48,0.2);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	color: var(--primary-color);
	font-size: 16px;
}
.ipac-contact-info__label {
	display: block;
	font-size: 20px;
	color: rgba(255,255,255,0.5);
	margin-bottom: 2px;
}
.ipac-contact-info__value {
	display: block;
	font-size: 22px;
	color: #fff;
	line-height: 1.5;
}

/* Contact form (dark card) */
.ipac-contact-form-dark {
	background: rgba(255,255,255,0.08);
	border: 1px solid rgba(255,255,255,0.1);
	border-radius: 24px;
	padding: 20px;
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	display: flex;
	flex-direction: column;
}
@media (min-width: 576px) { .ipac-contact-form-dark { padding: 24px; } }
@media (min-width: 992px) { .ipac-contact-form-dark { padding: 32px; } }
.ipac-contact-form-dark .form-label {
	color: rgba(255,255,255,0.7);
	margin-bottom: 6px;
}
.ipac-contact-form-dark .form-control {
	background: rgba(255,255,255,0.1);
	border: 1px solid rgba(255,255,255,0.15);
	color: #fff;
	border-radius: 14px;
	padding: 12px 16px;
	transition: border-color 0.2s;
}
.ipac-contact-form-dark .form-control::placeholder { color: rgba(255,255,255,0.3); }
.ipac-contact-form-dark .form-control:focus {
	background: rgba(255,255,255,0.1);
	border-color: rgba(240,78,48,0.6);
	box-shadow: none;
	color: #fff;
}
.ipac-contact-form-dark textarea.form-control { resize: none; min-height: 100px; }
.ipac-contact-form-dark__submit {
	border-radius: 50px;
	padding: 14px 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
}
.ipac-contact-form-dark .alert { border: none; border-radius: 14px; }
.ipac-contact-form-dark .alert-success {
	background: rgba(25,135,84,0.15);
	color: #75d5a3;
}
.ipac-contact-form-dark .alert-danger {
	background: rgba(220,53,69,0.15);
	color: #f5a3ab;
}
.ipac-contact-form-dark .alert-danger ul { margin: 0; padding-left: 16px; }

/* Contact footer (integrated) */
.ipac-contact-footer {
	margin-top: 40px;
	padding-top: 24px;
	border-top: 1px solid rgba(255,255,255,0.1);
}
@media (min-width: 576px) { .ipac-contact-footer { margin-top: 48px; } }
@media (min-width: 992px) { .ipac-contact-footer { margin-top: 56px; } }
.ipac-contact-footer__brand img {
	height: 32px;
	width: auto;
	filter: brightness(0) invert(1);
}
.ipac-contact-footer__brand span {
	font-size: 24px;
	color: rgba(255,255,255,0.5);
	line-height: 1.4;
}
.ipac-contact-footer__social a {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: rgba(255,255,255,0.4);
	text-decoration: none;
	transition: color 0.3s;
}
.ipac-contact-footer__social a:hover { color: #fff; }
.ipac-contact-footer__copyright {
	font-size: 24px;
	text-align: center;
	color: rgba(255,255,255,0.3);
}
@media (min-width: 576px) { .ipac-contact-footer__copyright { text-align: left; } }
.ipac-contact-footer__hotline {
	font-size: 32px;
	color: #fff;
	text-decoration: none;
	transition: color 0.3s;
}
.ipac-contact-footer__hotline:hover { color: rgba(255,255,255,0.8); }

/* --- Footer --- */
.ipac-footer {
	background: #1d1d1f;
	/* padding replaced by: py-5 */
	margin-top: auto;
}
.ipac-footer .ipac-contact-footer {
	margin-top: 0;
	padding-top: 0;
	border-top: none;
}

/* --- Knowledge Cards (home) --- */
.ipac-knowledge-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 16px;
}
@media (min-width: 576px) { .ipac-knowledge-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 992px) { .ipac-knowledge-grid { gap: 24px; } }
.ipac-knowledge-card {
	display: block;
	position: relative;
	border-radius: var(--ipac-radius-md);
	overflow: hidden;
	aspect-ratio: 1;
	text-decoration: none;
	box-shadow: var(--ipac-shadow);
	transition: all var(--ipac-transition);
	background: linear-gradient(135deg, rgba(var(--primary-color-rgb),0.08) 0%, rgba(var(--alternative-color-rgb),0.12) 50%, rgba(var(--primary-color-rgb),0.06) 100%);
}
.ipac-knowledge-card.img-broken::before {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 0;
}
.ipac-knowledge-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--ipac-shadow-hover);
}
.ipac-knowledge-card img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s;
}
.ipac-knowledge-card:hover img { transform: scale(1.05); }
.ipac-knowledge-card__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(0,0,0,0.6), transparent);
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: 16px;
}
@media (min-width: 576px) { .ipac-knowledge-card__overlay { padding: 20px; } }
.ipac-knowledge-card__title {
	font-size: 24px;
	color: #fff;
	font-weight: 500;
	line-height: 1.4;
}
.ipac-knowledge-card__more {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 18px;
	color: rgba(255,255,255,0.8);
	margin-top: 8px;
	opacity: 0;
	transition: opacity var(--ipac-transition);
}
.ipac-knowledge-card:hover .ipac-knowledge-card__more { opacity: 1; }

/* =====================================================
   INNER PAGES — shared components
   ===================================================== */

/* --- Page wrapper --- */
/* .ipac-page replaced by: py-5 py-sm-6 py-lg-7 */

/* --- Back link --- */
.ipac-back-link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 20px;
	color: var(--ipac-text-medium);
	text-decoration: none;
	margin-bottom: 32px;
	transition: color 0.2s;
}
.ipac-back-link:hover { color: var(--primary-color); }
.ipac-back-link i { font-size: 18px; }

/* --- Page header (centered) --- */
/* .ipac-page-header spacing replaced by: text-center mb-5 mb-sm-6 */
.ipac-page-header h1 {
	font-size: 36px;
	color: var(--ipac-text-dark);
	margin-bottom: 12px;
	font-weight: 500;
}
@media (min-width: 576px) { .ipac-page-header h1 { font-size: 44px; } }
@media (min-width: 992px) { .ipac-page-header h1 { font-size: 52px; } }
.ipac-page-header p {
	font-size: 22px;
	color: var(--ipac-text-medium);
	max-width: 520px;
	margin: 0 auto;
	line-height: 1.6;
}

/* --- Search bar (pill) --- */
/* .ipac-search-bar layout replaced by: d-flex align-items-center */
.ipac-search-bar {
	background: #fff;
	border-radius: var(--ipac-radius-pill);
	box-shadow: 0 2px 20px rgba(0,0,0,0.06);
	padding: 8px;
	margin-bottom: 40px;
}
@media (min-width: 576px) { .ipac-search-bar { margin-bottom: 48px; } }
.ipac-search-bar__wrap {
	position: relative;
	flex: 1;
}
.ipac-search-bar__icon {
	position: absolute;
	left: 16px;
	top: 50%;
	transform: translateY(-50%);
	color: var(--ipac-text-light);
	font-size: 20px;
}
.ipac-search-bar input {
	width: 100%;
	background: transparent;
	border: none;
	outline: none;
	padding: 10px 20px 10px 50px;
	font-size: 22px;
	color: var(--ipac-text-dark);
	border-radius: var(--ipac-radius-pill);
}
.ipac-search-bar input::placeholder { color: var(--ipac-text-light); }
.ipac-search-bar .form-control:focus {
	background: transparent;
	border: none;
	box-shadow: none;
}

.ipac-results-count {
	font-size: 19px;
	color: var(--ipac-text-light);
	margin-bottom: 24px;
}

/* --- Article card grid --- */
.ipac-card-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 24px;
}
@media (min-width: 576px) { .ipac-card-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 992px) { .ipac-card-grid { grid-template-columns: repeat(3, 1fr); gap: 32px; } }

/* --- Article card --- */
.ipac-article-card {
	--bs-card-box-shadow: 0 2px 20px rgba(0,0,0,0.06);
	text-decoration: none;
}
.ipac-article-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 8px 40px rgba(0,0,0,0.12);
}
.ipac-article-card__image {
	position: relative;
	aspect-ratio: 16/10;
	overflow: hidden;
	background: linear-gradient(135deg, rgba(var(--primary-color-rgb),0.08) 0%, rgba(var(--alternative-color-rgb),0.12) 50%, rgba(var(--primary-color-rgb),0.06) 100%);
}
.ipac-article-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s;
}
.ipac-article-card:hover .ipac-article-card__image img { transform: scale(1.05); }
.ipac-article-card__body {
	padding: 24px;
}
.ipac-article-card__date {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 19px;
	color: var(--ipac-text-light);
	margin-bottom: 12px;
}
.ipac-article-card__title {
	font-size: 24px;
	color: var(--ipac-text-dark);
	line-height: 1.4;
	margin-bottom: 12px;
	display: -webkit-box;
	line-clamp: 2;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	transition: color 0.2s;
}
.ipac-article-card:hover .ipac-article-card__title { color: var(--primary-color); }
.ipac-article-card__excerpt {
	font-size: 20px;
	color: var(--ipac-text-light);
	line-height: 1.5;
	display: -webkit-box;
	line-clamp: 2;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.ipac-article-card__more {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 20px;
	color: var(--primary-color);
	margin-top: 20px;
	opacity: 0;
	transition: opacity 0.3s;
}
.ipac-article-card:hover .ipac-article-card__more { opacity: 1; }
/* --- Pagination (BS base) --- */
.ipac-pagination {
	--bs-pagination-padding-x: 0;
	--bs-pagination-padding-y: 0;
	--bs-pagination-bg: #fff;
	--bs-pagination-border-color: #e8e8ed;
	--bs-pagination-color: var(--ipac-text-medium);
	--bs-pagination-hover-color: var(--primary-color);
	--bs-pagination-hover-border-color: var(--primary-color);
	--bs-pagination-hover-bg: #fff;
	--bs-pagination-active-bg: var(--primary-color);
	--bs-pagination-active-border-color: var(--primary-color);
	--bs-pagination-active-color: #fff;
	--bs-pagination-disabled-color: var(--ipac-text-light);
	--bs-pagination-disabled-border-color: #e8e8ed;
	--bs-pagination-disabled-bg: #fff;
	gap: 8px;
	justify-content: center;
	margin-top: 48px;
}
.ipac-pagination .page-link {
	width: 40px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50% !important;
	font-size: 19px;
}
.ipac-pagination .page-item.active .page-link {
	box-shadow: 0 4px 12px rgba(var(--primary-color-rgb), 0.2);
}

/* --- Empty state --- */
/* .ipac-empty spacing replaced by: text-center py-7 */
.ipac-empty__icon {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	background: var(--ipac-bg);
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 16px;
	font-size: 28px;
	color: var(--ipac-text-light);
}
.ipac-empty p {
	font-size: 20px;
	color: var(--ipac-text-medium);
}

/* =====================================================
   PUBLICATION PAGE
   ===================================================== */
.ipac-pub-card {
	--bs-card-box-shadow: 0 2px 20px rgba(0,0,0,0.06);
	margin-bottom: 24px;
}
.ipac-pub-card:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 40px rgba(0,0,0,0.1);
}
@media (min-width: 576px) { .ipac-pub-card { flex-direction: row; } }
.ipac-pub-card__cover {
	flex-shrink: 0;
	width: 100%;
	overflow: hidden;
	background: linear-gradient(135deg, rgba(var(--primary-color-rgb),0.08) 0%, rgba(var(--alternative-color-rgb),0.12) 50%, rgba(var(--primary-color-rgb),0.06) 100%);
}
.ipac-pub-card__cover.img-broken { min-height: 180px; }
.ipac-pub-card__cover.img-broken::before { content: "\f1c1"; }
@media (min-width: 576px) { .ipac-pub-card__cover { width: 200px; } }
@media (min-width: 992px) { .ipac-pub-card__cover { width: 240px; } }
.ipac-pub-card__cover img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s;
}
.ipac-pub-card:hover .ipac-pub-card__cover img { transform: scale(1.05); }
.ipac-pub-card__body {
	flex: 1;
	padding: 24px;
	display: flex;
	flex-direction: column;
	justify-content: center;
}
@media (min-width: 576px) { .ipac-pub-card__body { padding: 32px; } }
.ipac-pub-card__date {
	font-size: 19px;
	color: var(--ipac-text-light);
	margin-bottom: 12px;
}
.ipac-pub-card__title {
	font-size: 24px;
	color: var(--ipac-text-dark);
	line-height: 1.3;
	margin-bottom: 8px;
}
@media (min-width: 576px) { .ipac-pub-card__title { font-size: 28px; } }
.ipac-pub-card__subtitle {
	font-size: 20px;
	color: var(--ipac-text-dark);
	line-height: 1.3;
	margin-bottom: 24px;
}

/* =====================================================
   ARTICLE DETAIL PAGE
   ===================================================== */
.ipac-detail-hero {
	position: relative;
	width: 100%;
	aspect-ratio: 21/9;
	overflow: hidden;
}
@media (max-width: 575.98px) { .ipac-detail-hero { aspect-ratio: 16/10; min-height: 420px; } }
.ipac-detail-hero--no-image,
.ipac-detail-hero.img-broken {
	background: linear-gradient(135deg, rgba(var(--primary-color-rgb),0.08) 0%, rgba(var(--alternative-color-rgb),0.12) 50%, rgba(var(--primary-color-rgb),0.06) 100%);
}
.ipac-detail-hero--no-image .ipac-detail-hero__overlay,
.ipac-detail-hero.img-broken .ipac-detail-hero__overlay { background: none; }
.ipac-detail-hero--no-image .ipac-detail-hero__title,
.ipac-detail-hero.img-broken .ipac-detail-hero__title { color: var(--ipac-text-dark); }
.ipac-detail-hero img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.ipac-detail-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(0,0,0,0.6), transparent);
}
.ipac-detail-hero__back {
	position: absolute;
	top: 20px;
	left: 20px;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: rgba(255,255,255,0.9);
	-webkit-backdrop-filter: blur(8px);
	backdrop-filter: blur(8px);
	color: var(--ipac-text-dark);
	font-size: 19px;
	padding: 10px 20px;
	border-radius: var(--ipac-radius-pill);
	text-decoration: none;
	box-shadow: 0 2px 8px rgba(0,0,0,0.1);
	transition: background 0.2s;
	z-index: 2;
}
@media (min-width: 576px) { .ipac-detail-hero__back { top: 32px; left: 32px; } }
.ipac-detail-hero__back:hover { background: #fff; color: var(--ipac-text-dark); }
.ipac-detail-hero__content {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 20px 20px 32px;
	z-index: 1;
}
@media (min-width: 576px) { .ipac-detail-hero__content { padding: 20px 32px 48px; } }
.ipac-detail-hero__content .container { max-width: 900px; }
.ipac-detail-hero__badge {
	--bs-badge-font-size: 18px;
	--bs-badge-padding-y: 6px;
	--bs-badge-padding-x: 20px;
	--bs-badge-border-radius: var(--ipac-radius-pill);
	margin-bottom: 16px;
}
.ipac-detail-hero__title {
	font-size: 32px;
	color: #fff;
	line-height: 1.2;
}
@media (min-width: 576px) { .ipac-detail-hero__title { font-size: 40px; } }
@media (min-width: 992px) { .ipac-detail-hero__title { font-size: 52px; } }

/* Article content area */
.ipac-detail-content {
	max-width: 900px;
	margin: 0 auto;
	padding: 40px 20px;
}
@media (min-width: 576px) { .ipac-detail-content { padding: 56px 24px; } }
@media (min-width: 992px) { .ipac-detail-content { padding: 64px 24px; } }

/* .ipac-detail-meta layout replaced by: d-flex flex-wrap align-items-center */
.ipac-detail-meta {
	gap: 20px;
	font-size: 19px;
	color: var(--ipac-text-light);
	margin-bottom: 40px;
	padding-bottom: 32px;
	border-bottom: 1px solid #e8e8ed;
}
/* .ipac-detail-meta__item replaced by: d-flex align-items-center gap-2 */
/* .ipac-detail-meta__actions replaced by: d-flex gap-2 ms-auto */
.ipac-detail-meta__btn {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	border: 1px solid #e8e8ed;
	background: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	color: #86868b;
	font-size: 18px;
	transition: all 0.2s;
}
.ipac-detail-meta__btn:hover {
	border-color: var(--primary-color);
	color: var(--primary-color);
}
.ipac-detail-body {
	margin-bottom: 56px;
	font-size: 22px;
	color: #424245;
	line-height: 1.8;
}
.ipac-detail-body p {
	margin-bottom: 24px;
}
.ipac-detail-body h2 {
	font-size: 30px;
	color: var(--ipac-text-dark);
	font-weight: 600;
	margin: 40px 0 16px;
}
.ipac-detail-body h3 {
	font-size: 26px;
	color: var(--ipac-text-dark);
	font-weight: 600;
	margin: 32px 0 12px;
}
.ipac-detail-body h4 {
	font-size: 24px;
	color: var(--ipac-text-dark);
	font-weight: 600;
	margin: 24px 0 12px;
}
.ipac-detail-body ul,
.ipac-detail-body ol {
	padding-left: 24px;
	margin-bottom: 24px;
}
.ipac-detail-body li {
	margin-bottom: 8px;
}
.ipac-detail-body a {
	color: var(--primary-color);
	text-decoration: underline;
}
.ipac-detail-body a:hover { opacity: 0.8; }
.ipac-detail-body strong { color: var(--ipac-text-dark); }
.ipac-detail-body blockquote {
	border-left: 4px solid var(--primary-color);
	padding: 16px 24px;
	margin: 24px 0;
	background: var(--ipac-bg);
	border-radius: 0 var(--ipac-radius-sm) var(--ipac-radius-sm) 0;
}
.ipac-detail-body table {
	width: 100%;
	border-collapse: collapse;
	margin: 24px 0;
}
.ipac-detail-body th,
.ipac-detail-body td {
	padding: 12px 16px;
	border: 1px solid #e8e8ed;
	text-align: left;
}
.ipac-detail-body th {
	background: var(--ipac-bg);
	font-weight: 600;
	color: var(--ipac-text-dark);
}
.ipac-detail-body img {
	max-width: 100%;
	height: auto;
	border-radius: var(--ipac-radius-sm);
	margin: 16px 0;
}
.ipac-detail-body iframe,
.ipac-detail-body video {
	max-width: 100%;
	margin: 16px 0;
	border-radius: var(--ipac-radius-sm);
}

/* CTA banner */
.ipac-detail-cta {
	background: var(--ipac-bg);
	border-radius: var(--ipac-radius-md);
	padding: 32px;
	text-align: center;
	margin-bottom: 64px;
}
@media (min-width: 576px) { .ipac-detail-cta { padding: 40px; } }
.ipac-detail-cta h3 {
	font-size: 26px;
	color: var(--ipac-text-dark);
	margin-bottom: 12px;
}
@media (min-width: 576px) { .ipac-detail-cta h3 { font-size: 30px; } }
.ipac-detail-cta p {
	font-size: 20px;
	color: var(--ipac-text-medium);
	margin-bottom: 24px;
}

.ipac-related { background: var(--ipac-bg); }

/* =====================================================
   KNOWLEDGE CMS PAGE
   ===================================================== */
.ipac-knowledge-page {
	display: flex;
	flex-direction: column;
	gap: 32px;
}
@media (min-width: 768px) {
	.ipac-knowledge-page {
		flex-direction: row;
		gap: 40px;
	}
}
.ipac-knowledge-page__main {
	flex: 1;
	min-width: 0;
}
.ipac-knowledge-page__main img {
	max-width: 100%;
	height: auto;
	border-radius: var(--ipac-radius-sm);
	margin-bottom: 20px;
}
.ipac-knowledge-page__main h1 {
	font-size: 32px;
	color: var(--ipac-text-dark);
	margin-bottom: 24px;
}
@media (min-width: 576px) { .ipac-knowledge-page__main h1 { font-size: 40px; } }
.ipac-knowledge-page__sidebar {
	flex-shrink: 0;
	width: 100%;
}
@media (min-width: 768px) { .ipac-knowledge-page__sidebar { width: 260px; order: 2; } }

/* Sidebar nav */
.ipac-knowledge-nav {
	background: #fff;
	border-radius: var(--ipac-radius-md);
	box-shadow: var(--ipac-shadow);
	padding: 24px;
	position: sticky;
	top: 100px;
}
.ipac-knowledge-nav ul {
	list-style: none;
	padding: 0;
	margin: 0;
}
.ipac-knowledge-nav li {
	margin-bottom: 4px;
}
.ipac-knowledge-nav a {
	display: block;
	padding: 10px 16px;
	border-radius: 10px;
	font-size: 20px;
	color: var(--ipac-text-medium);
	text-decoration: none;
	transition: all 0.2s;
}
.ipac-knowledge-nav a:hover {
	background: rgba(var(--primary-color-rgb), 0.06);
	color: var(--primary-color);
}
.ipac-knowledge-nav li.active a {
	background: rgba(var(--primary-color-rgb), 0.1);
	color: var(--primary-color);
	font-weight: 500;
}

/* =====================================================
   LOGIN / REGISTER PAGE
   ===================================================== */
.body-auth {
	background: #f5f5f7;
	padding-top: 0 !important;
}
.ipac-auth {
	min-height: 100vh;
	display: flex;
}
.ipac-auth__side {
	display: none;
	position: sticky;
	top: 0;
	height: 100vh;
	background: #1d1d1f;
	overflow: hidden;
}
@media (min-width: 992px) {
	.ipac-auth__side { display: flex; width: 45%; }
}
@media (min-width: 1200px) {
	.ipac-auth__side { width: 50%; }
}
.ipac-auth__side-inner {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	height: 100%;
	padding: 40px;
}
@media (min-width: 1200px) { .ipac-auth__side-inner { padding: 56px; } }
.ipac-auth__side-logo {
	height: 40px;
	width: auto;
	filter: brightness(0) invert(1);
}
.ipac-auth__side h2 {
	font-size: 36px;
	color: #fff;
	line-height: 1.2;
	margin-bottom: 16px;
}
@media (min-width: 1200px) { .ipac-auth__side h2 { font-size: 44px; } }
.ipac-auth__side p {
	font-size: 22px;
	color: rgba(255,255,255,0.6);
	line-height: 1.6;
}
.ipac-auth__side-copy {
	font-size: 18px;
	color: rgba(255,255,255,0.3);
}

/* Form side */
.ipac-auth__form {
	flex: 1;
	display: flex;
	flex-direction: column;
	background: #fff;
	min-height: 100vh;
	scrollbar-gutter: stable;
	overflow-y: auto;
}
.ipac-auth__topbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 20px 24px;
	flex-shrink: 0;
}
@media (min-width: 576px) { .ipac-auth__topbar { padding: 20px 40px; } }
.ipac-auth__topbar-logo {
	height: 32px;
	width: auto;
}
.ipac-auth__form-wrap {
	flex: 1;
	display: flex;
	align-items: flex-start;
	justify-content: center;
	padding: 0 24px 40px;
}
@media (min-width: 576px) { .ipac-auth__form-wrap { padding: 0 40px 40px; } }
@media (min-width: 992px) { .ipac-auth__form-wrap { align-items: center; } }
.ipac-auth__form-inner {
	width: 100%;
	max-width: 560px;
}

/* Mode toggle pill */
.ipac-auth-toggle {
	display: flex;
	background: var(--ipac-bg);
	border-radius: var(--ipac-radius-pill);
	padding: 4px;
	margin-bottom: 32px;
}
.ipac-auth-toggle a {
	flex: 1;
	text-align: center;
	padding: 10px 0;
	border-radius: var(--ipac-radius-pill);
	font-size: 22px;
	color: var(--ipac-text-light);
	text-decoration: none;
	transition: all 0.3s;
}
.ipac-auth-toggle a:hover { color: var(--ipac-text-dark); }
.ipac-auth-toggle a.active {
	background: #fff;
	color: var(--ipac-text-dark);
	box-shadow: 0 1px 4px rgba(0,0,0,0.08);
}

/* Auth heading */
.ipac-auth__heading h1 {
	font-size: 36px;
	color: var(--primary-color);
	margin-bottom: 8px;
}
@media (min-width: 576px) { .ipac-auth__heading h1 { font-size: 40px; } }
.ipac-auth__heading p {
	font-size: 22px;
	color: var(--ipac-text-light);
	margin-bottom: 32px;
	line-height: 1.5;
}

/* Auth form layout */
.ipac-auth-input-wrap {
	position: relative;
}
.ipac-auth-input-wrap i.icon {
	position: absolute;
	left: 14px;
	top: 50%;
	transform: translateY(-50%);
	color: #aeaeb2;
	font-size: 22px;
	z-index: 2;
	pointer-events: none;
}
.ipac-auth-input-wrap .toggle-pw {
	position: absolute;
	right: 14px;
	top: 50%;
	transform: translateY(-50%);
	background: none;
	border: none;
	color: #aeaeb2;
	cursor: pointer;
	padding: 0;
	font-size: 19px;
	transition: color 0.2s;
	z-index: 2;
}
.ipac-auth-input-wrap .toggle-pw:hover { color: var(--ipac-text-dark); }

/* Auth links */
.ipac-auth-link {
	text-align: center;
	font-size: 22px;
	color: var(--ipac-text-light);
	margin-top: 16px;
}
.ipac-auth-link a {
	color: var(--primary-color);
	text-decoration: none;
}
.ipac-auth-link a:hover { text-decoration: underline; }

/* Auth icon (password pages) */
.ipac-auth__icon {
	width: 56px;
	height: 56px;
	border-radius: 16px;
	background: linear-gradient(135deg, var(--primary-color), #e8890c);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 16px;
}
.ipac-auth__icon i {
	font-size: 28px;
	color: #fff;
}

/* Contact form card */
.ipac-contact-form-card {
	background: #fff;
	border-radius: var(--ipac-radius-lg);
	padding: 24px;
	box-shadow: 0 2px 16px rgba(0,0,0,0.08);
}
@media (min-width: 576px) { .ipac-contact-form-card { padding: 32px; } }
.ipac-contact-form-card h3 {
	font-size: 28px;
	font-weight: 700;
	color: var(--ipac-text-dark);
	margin-bottom: 24px;
}

/* ── Bootstrap overrides for auth & contact forms ── */
.ipac-auth .form-label,
.ipac-contact-form-card .form-label {
	font-size: 22px;
	color: var(--ipac-text-medium);
	margin-bottom: 6px;
}
.ipac-auth .form-control,
.ipac-contact-form-card .form-control {
	border: 1px solid #e8e8ed;
	border-radius: 12px;
	padding: 12px 16px;
	font-size: 24px;
	color: var(--ipac-text-dark);
	font-family: inherit;
}
.ipac-auth .form-control:focus,
.ipac-contact-form-card .form-control:focus {
	border-color: rgba(var(--primary-color-rgb), 0.5);
	box-shadow: 0 0 0 3px rgba(var(--primary-color-rgb), 0.1);
}
.ipac-auth-input-wrap .form-control {
	padding-left: 48px;
}
.ipac-auth textarea.form-control,
.ipac-contact-form-card textarea.form-control {
	resize: vertical;
	background: #fafafa;
}
.ipac-auth textarea.form-control:focus,
.ipac-contact-form-card textarea.form-control:focus {
	background: #fff;
}
.ipac-auth .btn-primary {
	display: block;
	margin: 0 auto;
	padding: 14px 32px;
	font-size: 22px;
}
.ipac-auth__side-bg {
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(29,29,31,0.85), rgba(45,45,47,0.7), rgba(29,29,31,0.85)), url('/assets/img/form-background.jpg') center/cover no-repeat;
}
.ipac-auth__side-content { max-width: 440px; }
.ipac-auth__forgot { text-align: right; margin-bottom: 24px; }
.ipac-auth__forgot a { font-size: 22px; color: var(--primary-color); text-decoration: none; }
.ipac-auth__forgot a:hover { text-decoration: underline; }
.ipac-auth__recaptcha { display: flex; justify-content: center; margin-bottom: 24px; }
.ipac-auth__radio-group { display: flex; align-items: center; gap: 24px; margin-bottom: 20px; }
.ipac-auth__prefix-col { width: 110px; }
.ipac-auth__id-message { font-size: 20px; color: #dc2626; margin-top: 4px; }
.ipac-auth__pw-hint { font-size: 20px; color: #aeaeb2; margin-top: -8px; margin-bottom: 20px; }
.ipac-auth__pdpa { display: flex; align-items: center; justify-content: center; gap: 8px; margin-bottom: 24px; }
.ipac-auth__pdpa .form-check-input { margin: 0; flex-shrink: 0; }
.ipac-auth__pdpa a { color: var(--primary-color); text-decoration: none; font-size: 22px; }
.ipac-auth__pdpa a:hover { text-decoration: underline; }
/* ── Choices.js custom dropdown overrides ── */
/* Native select — match .form-control so Choices.js swap is seamless */
.ipac-ud-page .form-select,
.ipac-auth .form-select {
	border: 1px solid #e8e8ed;
	border-radius: 12px;
	font-size: 24px;
	color: var(--ipac-text-dark);
	padding: 12px 40px 12px 16px;
	font-family: inherit;
	background-color: #fff;
	line-height: 1.5;
}
.choices {
	margin-bottom: 0;
	font-family: inherit;
}
.choices__inner,
.choices[data-type*="select-one"] .choices__inner {
	border: 1px solid #e8e8ed;
	border-radius: 12px;
	font-size: 24px;
	padding: 12px 16px;
	min-height: auto;
	background: #fff;
	color: var(--ipac-text-dark);
	font-family: inherit;
	line-height: 1.5;
	display: flex;
	align-items: center;
	overflow: visible;
}
.choices__inner .choices__list--single { padding: 0; }
.choices__inner .choices__item { font-size: 24px; color: var(--ipac-text-dark); }
.choices__inner .choices__placeholder { color: var(--ipac-text-light); opacity: 1; }
.is-focused .choices__inner,
.choices[data-type="select-one"].is-open .choices__inner {
	border-color: rgba(var(--primary-color-rgb), 0.5);
	box-shadow: 0 0 0 3px rgba(var(--primary-color-rgb), 0.1);
}
/* Keep rounded corners when dropdown is open */
.is-open .choices__inner,
.is-flipped.is-open .choices__inner {
	border-radius: 12px;
}
.choices__list--dropdown,
.choices .choices__list[aria-expanded] {
	border: 1px solid #e8e8ed;
	border-radius: 12px;
	box-shadow: 0 8px 32px rgba(0,0,0,0.1);
	background: #fff;
	margin-top: 4px;
	overflow: hidden;
	z-index: 100;
}
.is-flipped .choices__list--dropdown,
.is-flipped .choices__list[aria-expanded] {
	margin-top: 0;
	margin-bottom: 4px;
	border-radius: 12px;
}
.choices__list--dropdown .choices__item,
.choices .choices__list[aria-expanded] .choices__item {
	font-size: 24px;
	padding: 10px 16px;
	color: var(--ipac-text-dark);
	font-family: inherit;
}
.choices__list--dropdown .choices__item--selectable.is-highlighted,
.choices .choices__list[aria-expanded] .choices__item--selectable.is-highlighted {
	background: var(--ipac-bg);
	color: var(--ipac-text-dark);
}
.choices__list--dropdown .choices__item--selectable.is-selected,
.choices .choices__list[aria-expanded] .choices__item--selectable.is-selected {
	background: rgba(var(--primary-color-rgb), 0.08);
	color: var(--primary-color);
}
.choices[data-type="select-one"]::after {
	border-color: var(--secondary-color) transparent transparent;
	right: 16px;
	margin-top: -2px;
}
.choices[data-type="select-one"].is-open::after {
	border-color: transparent transparent var(--secondary-color);
	margin-top: -6px;
}
.choices__list--dropdown .choices__input,
.choices .choices__list[aria-expanded] .choices__input {
	font-size: 22px;
	padding: 10px 16px;
	border-bottom: 1px solid #e8e8ed;
	font-family: inherit;
}
.choices.is-disabled .choices__inner {
	background: var(--ipac-bg);
	color: var(--ipac-text-light);
	cursor: not-allowed;
}
.choices.is-disabled::after {
	border-color: var(--ipac-text-light) transparent transparent;
}
/* Auth page compact prefix */
.ipac-auth__prefix-col .choices__inner,
.ipac-auth__prefix-col .choices[data-type*="select-one"] .choices__inner {
	padding: 12px 10px;
}
.ipac-auth__prefix-col .choices[data-type="select-one"]::after {
	right: 10px;
}

/* ── Global Modal ── */
.ipac-modal .modal-content {
	border: none;
	border-radius: var(--ipac-radius-md);
	box-shadow: 0 24px 80px rgba(0,0,0,0.16);
	overflow: hidden;
}
.ipac-modal .modal-header {
	padding: 24px;
	border-bottom: none;
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
}
.ipac-modal__title-group {
	display: flex;
	align-items: center;
	gap: 12px;
}
.ipac-modal__icon {
	width: 36px;
	height: 36px;
	border-radius: 10px;
	background: rgba(var(--primary-color-rgb), 0.1);
	color: var(--primary-color);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 20px;
}
.ipac-modal .modal-title {
	font-size: 24px;
	font-weight: 600;
	color: var(--ipac-text-dark);
	margin-bottom: 0;
}
.ipac-modal__close {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	border: none;
	background: rgba(0,0,0,0.06);
	color: var(--ipac-text-medium);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 18px;
	cursor: pointer;
	transition: all 0.2s;
}
.ipac-modal__close:hover {
	background: rgba(0,0,0,0.1);
	color: var(--ipac-text-dark);
}
.ipac-modal .modal-body {
	padding: 16px 24px;
	font-size: 22px;
	line-height: 1.7;
	background:
		linear-gradient(var(--bs-modal-bg) 20%, transparent) center top,
		linear-gradient(transparent, var(--bs-modal-bg) 80%) center bottom,
		radial-gradient(farthest-side at 50% 0, var(--bs-modal-bg), transparent) center top,
		radial-gradient(farthest-side at 50% 100%, var(--bs-modal-bg), transparent) center bottom;
	background-repeat: no-repeat;
	background-size: 100% 40px, 100% 40px, 100% 12px, 100% 12px;
	background-attachment: local, local, scroll, scroll;
}
.ipac-modal .modal-footer {
	padding: 8px 24px 24px;
	border-top: none;
}
.ipac-modal .modal-footer .btn {
	padding: 12px 28px;
	font-size: 22px;
}
.ipac-auth .alert,
.ipac-contact-form-card .alert {
	border-radius: 12px;
	font-size: 18px;
}
.ipac-auth .alert-danger,
.ipac-contact-form-card .alert-danger {
	--bs-alert-bg: #fef2f2;
	--bs-alert-color: #dc2626;
	border: 1px solid #fecaca;
}
.ipac-auth .alert-danger ul,
.ipac-contact-form-card .alert-danger ul {
	list-style: none;
	padding: 0;
	margin: 0;
}
.ipac-auth .alert-danger li,
.ipac-contact-form-card .alert-danger li {
	padding: 2px 0;
}
.ipac-auth .alert-danger li + li,
.ipac-contact-form-card .alert-danger li + li {
	margin-top: 4px;
}
.ipac-auth .alert-danger li a,
.ipac-contact-form-card .alert-danger li a {
	color: #dc2626;
	text-decoration: underline;
}
.ipac-auth .alert-success,
.ipac-contact-form-card .alert-success {
	--bs-alert-bg: #f0fdf4;
	--bs-alert-color: #16a34a;
	border: 1px solid #bbf7d0;
	display: flex;
	align-items: flex-start;
	gap: 10px;
	line-height: 1.5;
}
.ipac-auth .alert-success i,
.ipac-contact-form-card .alert-success i {
	font-size: 22px;
	margin-top: 1px;
	flex-shrink: 0;
}

/* ===== About Page ===== */
.ipac-about-items {
	display: flex;
	flex-direction: column;
	gap: 28px;
}
.ipac-about-item {
	display: flex;
	gap: 20px;
	align-items: flex-start;
}
.ipac-about-item__icon {
	width: 48px;
	height: 48px;
	border-radius: 14px;
	background: linear-gradient(135deg, var(--primary-color), #e8890c);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.ipac-about-item__icon i {
	font-size: 28px;
	color: #fff;
}
.ipac-about-item h3 {
	font-size: 28px;
	font-weight: 700;
	color: var(--ipac-text-dark);
	margin-bottom: 8px;
}
.ipac-about-item p {
	font-size: 23px;
	color: var(--ipac-text-medium);
	line-height: 1.7;
	margin: 0;
}

/* Team section (About page) */
.ipac-team-section {
	margin-bottom: 56px;
}
.ipac-team-section:last-child { margin-bottom: 0; }
.ipac-team-section__title {
	font-size: 30px;
	font-weight: 700;
	color: var(--primary-color);
	text-align: center;
	margin-bottom: 32px;
}
.ipac-team-section .ipac-team-member {
	text-align: center;
}
.ipac-team-member__photo {
	width: 100%;
	aspect-ratio: 1;
	border-radius: var(--ipac-radius-lg);
	overflow: hidden;
	margin-bottom: 14px;
	background: #e8e8ed;
}
.ipac-team-member__photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.ipac-team-section .ipac-team-member__name {
	font-size: 24px;
	font-weight: 600;
	color: var(--ipac-text-dark);
	margin-bottom: 4px;
}
.ipac-team-section .ipac-team-member__role {
	font-size: 22px;
	color: var(--primary-color);
	margin: 0;
}
.ipac-team-member--featured .ipac-team-member__photo {
	max-width: 240px;
	margin-left: auto;
	margin-right: auto;
}

/* Network marquee (About page) */
.ipac-network-marquee {
	margin-top: 16px;
}
.ipac-network-item {
	padding: 0 16px;
}
.ipac-network-item img {
	height: 80px;
	width: auto;
	object-fit: contain;
	border-radius: 12px;
	background: #fff;
	padding: 12px;
	box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}

/* Contact page */
.ipac-contact-page {
	background: var(--ipac-bg);
}
.ipac-contact-submit {
	border-radius: var(--ipac-radius-pill);
	padding: 12px 40px;
	font-size: 22px;
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

/* Contact info card (sidebar) */
.ipac-contact-info-card {
	background: #fff;
	border-radius: var(--ipac-radius-md);
	padding: 24px;
	box-shadow: 0 2px 16px rgba(0,0,0,0.08);
}
.ipac-contact-info-card h3 {
	font-size: 24px;
	font-weight: 700;
	color: var(--ipac-text-dark);
	margin-bottom: 16px;
}
.ipac-contact-info-list {
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.ipac-contact-info-list__item {
	display: flex;
	align-items: flex-start;
	gap: 12px;
}
.ipac-contact-info-list__icon {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: rgba(var(--primary-color-rgb), 0.1);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	color: var(--primary-color);
	font-size: 16px;
}
.ipac-contact-info-list__label {
	display: block;
	font-size: 20px;
	color: var(--ipac-text-light);
	margin-bottom: 2px;
}
.ipac-contact-info-list__value {
	display: block;
	font-size: 24px;
	color: var(--ipac-text-dark);
	line-height: 1.5;
}

/* Contact map card (sidebar) */
.ipac-contact-map-card {
	background: #fff;
	border-radius: var(--ipac-radius-md);
	overflow: hidden;
	box-shadow: 0 2px 16px rgba(0,0,0,0.08);
	height: 280px;
}
.ipac-contact-map-card iframe {
	width: 100%;
	height: 100%;
	border: 0;
	display: block;
}

/* =====================================================
   Kiosk — Theme overrides
   ===================================================== */
body.kiosk .btn-primary {
	--bs-btn-bg: var(--primary-color);
	--bs-btn-border-color: var(--primary-color);
	--bs-btn-hover-bg: var(--primary-color);
	--bs-btn-hover-border-color: var(--primary-color);
	--bs-btn-active-bg: var(--primary-color);
	--bs-btn-active-border-color: var(--primary-color);
	border-radius: var(--ipac-radius-pill);
}

/* =====================================================
   Cookie Consent
   ===================================================== */

/* ── Cookie Banner ── */
.ipac-cookie-banner {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 1050;
	padding: 12px;
	transform: translateY(100%);
	visibility: hidden;
	transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1), visibility 0.4s;
}
.ipac-cookie-banner.show {
	transform: translateY(0);
	visibility: visible;
}
@media (min-width: 576px) { .ipac-cookie-banner { padding: 16px; } }
@media (min-width: 992px) { .ipac-cookie-banner { padding: 20px 24px; } }

.ipac-cookie-banner__inner {
	max-width: 1200px;
	margin: 0 auto;
	background: rgba(255,255,255,0.85);
	-webkit-backdrop-filter: blur(24px) saturate(180%);
	backdrop-filter: blur(24px) saturate(180%);
	border: 1px solid rgba(0,0,0,0.08);
	border-radius: var(--ipac-radius-md);
	box-shadow: 0 8px 40px rgba(0,0,0,0.12), 0 0 0 1px rgba(0,0,0,0.04);
	padding: 20px;
	display: flex;
	flex-direction: column;
	gap: 16px;
}
@media (min-width: 768px) {
	.ipac-cookie-banner__inner {
		flex-direction: row;
		align-items: center;
		gap: 20px;
		padding: 20px 24px;
	}
}

.ipac-cookie-banner__icon {
	width: 44px;
	height: 44px;
	border-radius: 12px;
	background: rgba(var(--primary-color-rgb), 0.1);
	color: var(--primary-color);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 24px;
	flex-shrink: 0;
}

.ipac-cookie-banner__body {
	flex: 1;
	min-width: 0;
}
.ipac-cookie-banner__title {
	font-size: 21px;
	font-weight: 600;
	color: var(--ipac-text-dark);
	margin-bottom: 4px;
}
.ipac-cookie-banner__text {
	font-size: 18px;
	color: var(--ipac-text-medium);
	line-height: 1.5;
	margin: 0;
}

.ipac-cookie-banner__actions {
	display: flex;
	gap: 8px;
	flex-shrink: 0;
	flex-wrap: wrap;
}
@media (max-width: 767.98px) {
	.ipac-cookie-banner__actions {
		justify-content: stretch;
	}
	.ipac-cookie-banner__actions .ipac-cookie-btn {
		flex: 1;
		justify-content: center;
	}
}

/* ── Cookie Buttons ── */
.ipac-cookie-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 10px 20px;
	border-radius: var(--ipac-radius-pill);
	font-size: 19px;
	font-weight: 500;
	border: none;
	cursor: pointer;
	white-space: nowrap;
	transition: all 0.2s ease;
}
.ipac-cookie-btn--primary {
	background: var(--primary-color);
	color: #fff;
}
.ipac-cookie-btn--primary:hover {
	background: rgba(var(--primary-color-rgb), 0.88);
	box-shadow: 0 4px 16px rgba(var(--primary-color-rgb), 0.25);
}
.ipac-cookie-btn--outline {
	background: transparent;
	color: var(--ipac-text-dark);
	border: 1px solid rgba(0,0,0,0.15);
}
.ipac-cookie-btn--outline:hover {
	background: rgba(0,0,0,0.04);
	border-color: rgba(0,0,0,0.25);
}
.ipac-cookie-btn--ghost {
	background: transparent;
	color: var(--ipac-text-medium);
}
.ipac-cookie-btn--ghost:hover {
	background: rgba(0,0,0,0.04);
	color: var(--ipac-text-dark);
}
.ipac-cookie-btn--block {
	width: 100%;
}

/* ── Floating Button ── */
.ipac-cookie-fab {
	position: fixed;
	bottom: 20px;
	left: 20px;
	z-index: 1040;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	border: none;
	background: rgba(255,255,255,0.85);
	-webkit-backdrop-filter: blur(16px) saturate(180%);
	backdrop-filter: blur(16px) saturate(180%);
	color: var(--primary-color);
	font-size: 24px;
	align-items: center;
	justify-content: center;
	box-shadow: 0 4px 20px rgba(0,0,0,0.1), 0 0 0 1px rgba(0,0,0,0.06);
	cursor: pointer;
	opacity: 0;
	transform: scale(0);
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.ipac-cookie-fab.show {
	display: flex !important;
	opacity: 1;
	transform: scale(1);
}
.ipac-cookie-fab:hover {
	transform: scale(1.08);
	box-shadow: 0 6px 24px rgba(0,0,0,0.14), 0 0 0 1px rgba(0,0,0,0.08);
}

/* ── Cookie Modal ── */
.ipac-cookie-modal__desc {
	font-size: 18px;
	color: var(--ipac-text-medium);
	line-height: 1.5;
	margin: 4px 0 0;
}

.ipac-cookie-option {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 16px 0;
	border-bottom: 1px solid rgba(0,0,0,0.06);
}
.ipac-cookie-option:last-child { border-bottom: none; }

.ipac-cookie-option__info {
	flex: 1;
	min-width: 0;
}
.ipac-cookie-option__name {
	display: block;
	font-size: 19px;
	font-weight: 600;
	color: var(--ipac-text-dark);
	margin-bottom: 2px;
}
.ipac-cookie-option__desc {
	display: block;
	font-size: 17px;
	color: var(--ipac-text-light);
	line-height: 1.5;
}

/* Custom toggle */
.ipac-cookie-toggle {
	position: relative;
	flex-shrink: 0;
	cursor: pointer;
}
.ipac-cookie-toggle input { display: none; }
.ipac-cookie-toggle__track {
	display: block;
	width: 44px;
	height: 26px;
	border-radius: 13px;
	background: rgba(0,0,0,0.12);
	position: relative;
	transition: background 0.25s;
}
.ipac-cookie-toggle__track::after {
	content: '';
	position: absolute;
	top: 3px;
	left: 3px;
	width: 20px;
	height: 20px;
	border-radius: 50%;
	background: #fff;
	box-shadow: 0 1px 4px rgba(0,0,0,0.15);
	transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}
.ipac-cookie-toggle input:checked + .ipac-cookie-toggle__track {
	background: var(--primary-color);
}
.ipac-cookie-toggle input:checked + .ipac-cookie-toggle__track::after {
	transform: translateX(18px);
}
.ipac-cookie-toggle input:disabled + .ipac-cookie-toggle__track {
	opacity: 0.5;
	cursor: not-allowed;
}