/* =========================================================================
   SwiftPay App Navigation — Frontend Styles
   Namespacing: every selector is prefixed with .sann- to avoid any clash
   with other SwiftPay plugins or theme styles.
   ========================================================================= */

:root {
	--sann-primary: #1E3A8A;
	--sann-secondary: #22C55E;
	--sann-bg: #F8FAFC;
	--sann-card: #FFFFFF;
	--sann-text: #111827;
	--sann-border: #E5E7EB;
	--sann-warning: #FACC15;
	--sann-error: #EF4444;
	--sann-glow: #00FF88;

	--sann-bottom-h: 68px;
	--sann-top-h: 64px;
	--sann-radius: 18px;
	--sann-ease: cubic-bezier(.22, 1, .36, 1);
}

.sann-nav,
.sann-nav * {
	box-sizing: border-box;
}

.sann-nav-list {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
}

.sann-nav-link {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	color: var(--sann-text);
	-webkit-tap-highlight-color: transparent;
	outline-offset: 4px;
}

.sann-nav-icon svg,
.sann-icon-img {
	width: 22px;
	height: 22px;
	display: block;
}

/* -------------------------------------------------------------------------
   BOTTOM NAV — fixed, mobile, app-style
   ------------------------------------------------------------------------- */

.sann-nav--bottom {
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 99990;
	background: var(--sann-card);
	border-top: 1px solid var(--sann-border);
	border-radius: var(--sann-radius) var(--sann-radius) 0 0;
	box-shadow: 0 -8px 30px rgba(17, 24, 39, 0.08);
	padding-bottom: env(safe-area-inset-bottom, 0px);
}

.sann-nav--bottom .sann-nav-list {
	height: var(--sann-bottom-h);
}

.sann-nav--bottom .sann-nav-item {
	flex: 1 1 0;
	display: flex;
}

.sann-nav--bottom .sann-nav-link {
	flex-direction: column;
	gap: 4px;
	width: 100%;
	padding: 8px 4px 6px;
	color: #9CA3AF;
}

.sann-nav--bottom .sann-nav-label {
	font-size: 11px;
	font-weight: 600;
	letter-spacing: .01em;
	line-height: 1;
}

.sann-nav--bottom .sann-nav-icon {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 28px;
	border-radius: 12px;
}

.sann-anim-on .sann-nav--bottom .sann-nav-icon,
.sann-anim-on .sann-nav--bottom .sann-nav-label {
	transition: color .25s var(--sann-ease), background-color .25s var(--sann-ease), transform .25s var(--sann-ease);
}

.sann-nav--bottom .sann-nav-item.is-active .sann-nav-link {
	color: var(--sann-item-color, var(--sann-secondary));
}

.sann-nav--bottom .sann-nav-item.is-active .sann-nav-icon {
	background: color-mix(in srgb, var(--sann-item-color, var(--sann-secondary)) 12%, transparent);
}

.sann-anim-on .sann-nav--bottom .sann-nav-item.is-active .sann-nav-icon {
	transform: translateY(-2px);
}

/* small neon accent glow dot on active item */
.sann-glow {
	position: absolute;
	top: 2px;
	right: 50%;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--sann-glow);
	box-shadow: 0 0 8px var(--sann-glow);
	opacity: 0;
	transform: translate(10px, 0) scale(.5);
}

.sann-nav-item.is-active .sann-glow {
	opacity: .9;
	transform: translate(10px, -2px) scale(1);
}

.sann-anim-on .sann-glow {
	transition: opacity .25s var(--sann-ease), transform .25s var(--sann-ease);
}

/* press feedback */
.sann-anim-on .sann-nav--bottom .sann-nav-link.is-pressed .sann-nav-icon {
	transform: scale(.88);
}

/* -------------------------------------------------------------------------
   TOP NAV — sticky, desktop
   ------------------------------------------------------------------------- */

.sann-nav--top {
	position: sticky;
	top: 0;
	z-index: 99980;
	background: var(--sann-card);
	border-bottom: 1px solid var(--sann-border);
}

.sann-nav--top.sann-is-scrolled {
	box-shadow: 0 6px 24px rgba(17, 24, 39, 0.06);
}

.sann-anim-on .sann-nav--top {
	transition: box-shadow .25s var(--sann-ease);
}

.sann-nav--top .sann-nav-list {
	height: var(--sann-top-h);
	max-width: 1180px;
	margin: 0 auto;
	align-items: center;
	gap: 6px;
	padding: 0 24px;
}

.sann-nav--top .sann-nav-item {
	display: flex;
}

.sann-nav--top .sann-nav-link {
	flex-direction: row;
	gap: 8px;
	padding: 10px 16px;
	border-radius: 999px;
	font-weight: 600;
	font-size: 14px;
	color: var(--sann-primary);
}

.sann-anim-on .sann-nav--top .sann-nav-link {
	transition: background-color .2s var(--sann-ease), color .2s var(--sann-ease), transform .2s var(--sann-ease);
}

.sann-nav--top .sann-nav-link:hover {
	background: var(--sann-bg);
}

.sann-anim-on .sann-nav--top .sann-nav-link:hover {
	transform: translateY(-1px);
}

.sann-nav--top .sann-nav-item.is-active .sann-nav-link {
	color: var(--sann-item-color, var(--sann-secondary));
	background: color-mix(in srgb, var(--sann-item-color, var(--sann-secondary)) 10%, transparent);
}

.sann-nav--top .sann-glow {
	display: none; /* keep the neon glow dot exclusive to mobile app feel */
}

/* -------------------------------------------------------------------------
   Responsive switch — bottom bar on phones/tablets, top bar on desktop
   ------------------------------------------------------------------------- */

@media (max-width: 1023.98px) {
	.sann-nav--top {
		display: none;
	}
}

@media (min-width: 1024px) {
	.sann-nav--bottom {
		display: none;
	}
}

/* Reserve space so page content never sits under the fixed bottom bar */
@media (max-width: 1023.98px) {
	body {
		padding-bottom: calc(var(--sann-bottom-h) + env(safe-area-inset-bottom, 0px));
	}
}

/* Respect users who prefer reduced motion regardless of admin setting */
@media (prefers-reduced-motion: reduce) {
	.sann-nav * {
		transition: none !important;
		animation: none !important;
	}
}

/* PWA standalone display: tighten safe-area for notch devices */
@media (display-mode: standalone) {
	.sann-nav--bottom {
		padding-bottom: calc(env(safe-area-inset-bottom, 0px) + 4px);
	}
}

@media print {
	.sann-nav {
		display: none !important;
	}
}
