/* --- 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 replaced by: d-none d-lg-flex */
.ipac-navbar__cta {
	align-items: center;
	gap: 16px;
}
.ipac-navbar__cta .btn-primary { font-size: 19px; padding: 8px 24px; }
/* 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 replaced by: d-flex d-lg-none */
.ipac-navbar__mobile {
	align-items: center;
	gap: 12px;
}
.ipac-navbar__mobile-cta {
	display: inline-block;
}

/* 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); }
