/* Product shared styles — Liquid Glass components used by all product pages.
   Load order: layout.css → design.css → product-shared.css → product style.css */

/* Container */
.container { width: min(1120px, calc(100% - 2rem)); margin-inline: auto; }

/* Bakery banner */
.bakery-banner {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 10px 24px;
	font-size: 13px;
	color: var(--text-secondary);
	background: rgba(255,255,255,0.35);
	backdrop-filter: blur(18px) saturate(1.4);
	-webkit-backdrop-filter: blur(18px) saturate(1.4);
	border-bottom: 1px solid rgba(255,255,255,0.35);
}

@media (prefers-color-scheme: dark) {
	.bakery-banner {
		background: rgba(18,18,22,0.55);
		border-bottom-color: rgba(255,255,255,0.08);
	}
}

.bakery-banner img {
	width: 20px;
	height: 20px;
	display: inline-block;
	border-radius: 5px;
}

.bakery-banner a {
	color: var(--text);
	text-decoration: none;
	font-weight: 600;
}

.bakery-banner a:hover { text-decoration: underline; }

/* Sticky glass header — the signature Liquid Glass surface */
.site-header {
	position: sticky;
	top: 12px;
	z-index: 40;
	margin: 12px auto 0;
	width: min(1120px, calc(100% - 2rem));
	backdrop-filter: blur(28px) saturate(1.8);
	-webkit-backdrop-filter: blur(28px) saturate(1.8);
	background: rgba(255, 255, 255, 0.55);
	border: 1px solid rgba(255,255,255,0.55);
	border-radius: 22px;
	box-shadow:
		0 10px 40px rgba(20, 22, 40, 0.10),
		inset 0 1px 0 rgba(255,255,255,0.8);
}

@media (prefers-color-scheme: dark) {
	.site-header {
		background: rgba(22, 22, 28, 0.55);
		border-color: rgba(255,255,255,0.12);
		box-shadow:
			0 10px 40px rgba(0,0,0,0.5),
			inset 0 1px 0 rgba(255,255,255,0.18);
	}
}

/* Navigation */
.nav {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: 0.6rem 1rem;
	width: 100%;
}
.brand {
	display: inline-flex;
	align-items: center;
	gap: 0.6rem;
	font-weight: 700;
	text-decoration: none;
	color: var(--text);
	letter-spacing: -0.01em;
}
.brand img { border-radius: 9px; box-shadow: 0 4px 14px rgba(20,22,40,0.18); }
.menu {
	list-style: none;
	display: flex;
	gap: 0.25rem;
	padding: 0;
	margin: 0 auto 0 1rem;
}
.menu a {
	text-decoration: none;
	color: var(--text-secondary);
	transition: color 0.2s, background 0.2s;
	padding: 0.45rem 0.85rem;
	border-radius: 999px;
	font-size: 14px;
	font-weight: 500;
}
.menu a:hover {
	color: var(--text);
	background: rgba(255,255,255,0.5);
}

@media (prefers-color-scheme: dark) {
	.menu a:hover { background: rgba(255,255,255,0.08); }
}

/* Language picker — glass pill */
.language-form {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
}

.language-picker-label {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.75rem;
	height: 2.75rem;
	border: 1px solid rgba(255,255,255,0.55);
	border-radius: 999px;
	background: rgba(255,255,255,0.45);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	box-shadow: inset 0 1px 0 rgba(255,255,255,0.7);
}

@media (prefers-color-scheme: dark) {
	.language-picker-label {
		background: rgba(255,255,255,0.08);
		border-color: rgba(255,255,255,0.16);
		box-shadow: inset 0 1px 0 rgba(255,255,255,0.14);
	}
}

.language-form select {
	min-width: 11rem;
	min-height: 2.75rem;
	background: rgba(255,255,255,0.55);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	color: var(--text);
	border: 1px solid rgba(255,255,255,0.55);
	border-radius: 999px;
	padding: 0.65rem 1rem;
	font-family: inherit;
	font-size: 14px;
	box-shadow: inset 0 1px 0 rgba(255,255,255,0.7);
	appearance: none;
	-webkit-appearance: none;
}

@media (prefers-color-scheme: dark) {
	.language-form select {
		background: rgba(255,255,255,0.08);
		border-color: rgba(255,255,255,0.16);
		box-shadow: inset 0 1px 0 rgba(255,255,255,0.14);
	}
}

.language-form select:focus {
	outline: 2px solid var(--accent);
	outline-offset: 2px;
}

/* Buttons — liquid pills */
.button {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	padding: 0.75rem 1.35rem;
	border-radius: 999px;
	border: 1px solid transparent;
	font-weight: 600;
	font-size: 15px;
	letter-spacing: -0.01em;
	transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.25s ease;
	isolation: isolate;
	overflow: hidden;
}

.button::before {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: inherit;
	background: linear-gradient(180deg, rgba(255,255,255,0.45) 0%, rgba(255,255,255,0) 48%);
	pointer-events: none;
}

.button:hover { transform: translateY(-1px); }
.button:active { transform: translateY(0); }

.button.primary {
	background: var(--accent-gradient);
	color: #fff;
	box-shadow:
		0 10px 30px rgba(10,132,255,0.35),
		inset 0 1px 0 rgba(255,255,255,0.5);
}

.button.primary:hover {
	box-shadow:
		0 16px 38px rgba(10,132,255,0.45),
		inset 0 1px 0 rgba(255,255,255,0.5);
}

.button.ghost {
	background: rgba(255,255,255,0.5);
	backdrop-filter: blur(18px) saturate(1.4);
	-webkit-backdrop-filter: blur(18px) saturate(1.4);
	border-color: rgba(255,255,255,0.6);
	color: var(--text);
	box-shadow: inset 0 1px 0 rgba(255,255,255,0.7), 0 4px 14px rgba(20,22,40,0.08);
}

@media (prefers-color-scheme: dark) {
	.button.ghost {
		background: rgba(255,255,255,0.08);
		border-color: rgba(255,255,255,0.18);
		box-shadow: inset 0 1px 0 rgba(255,255,255,0.14), 0 4px 14px rgba(0,0,0,0.35);
	}
}

.button.ghost:hover {
	background: rgba(255,255,255,0.7);
}

@media (prefers-color-scheme: dark) {
	.button.ghost:hover { background: rgba(255,255,255,0.12); }
}

/* Lightbox */
.lightbox { position: fixed; inset: 0; display: none; z-index: 80; }
.lightbox:target { display: block; }
.lightbox-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(10, 12, 24, 0.78);
	backdrop-filter: blur(20px) saturate(1.3);
	-webkit-backdrop-filter: blur(20px) saturate(1.3);
}
.lightbox-content { position: relative; z-index: 1; width: 100%; height: 100%; overflow: auto; padding: 4rem 2rem 2rem; }
.lightbox-content img {
	width: min(1280px, 95vw);
	max-width: none;
	margin: 0 auto;
	border-radius: 18px;
	border: 1px solid rgba(255,255,255,0.2);
	box-shadow: 0 1.5rem 4rem rgba(0,0,0,0.55);
}
.lightbox-close {
	position: sticky;
	top: 0;
	display: inline-flex;
	margin-left: auto;
	margin-bottom: 1rem;
	padding: 0.5rem 0.95rem;
	border-radius: 999px;
	text-decoration: none;
	background: rgba(255,255,255,0.16);
	backdrop-filter: blur(20px) saturate(1.4);
	-webkit-backdrop-filter: blur(20px) saturate(1.4);
	border: 1px solid rgba(255,255,255,0.28);
	color: #fff;
	font-size: 14px;
	font-weight: 600;
	box-shadow: inset 0 1px 0 rgba(255,255,255,0.25);
}

/* Footer */
.site-footer {
	margin-top: 2rem;
	border-top: 1px solid rgba(255,255,255,0.28);
	padding: 1.5rem 0;
}

@media (prefers-color-scheme: dark) {
	.site-footer { border-top-color: rgba(255,255,255,0.08); }
}

.footer-inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
	color: var(--text-secondary);
	font-size: 13px;
}

.footer-inner a { color: var(--text-secondary); text-decoration: none; transition: color 0.2s; }
.footer-inner a:hover { color: var(--text); }

.footer-bakery {
	display: flex;
	align-items: center;
	gap: 6px;
}

.footer-bakery img { width: 18px; height: 18px; border-radius: 5px; }
.footer-bakery a { font-weight: 600; }

/* Responsive — shared breakpoints */
@media (max-width: 680px) {
	.menu { display: none; }
	.footer-inner { flex-direction: column; text-align: center; }
	.site-header { top: 8px; margin-top: 8px; border-radius: 18px; }
}

/* Accessibility — focus rings for glass surfaces */
.brand:focus-visible,
.menu a:focus-visible,
.footer-inner a:focus-visible,
.button.ghost:focus-visible,
.button.primary:focus-visible,
.lightbox-close:focus-visible {
	outline: 2px solid var(--accent);
	outline-offset: 3px;
	border-radius: 999px;
}

.menu a:focus-visible { padding: 0.45rem 0.85rem; }

/* Labels replacing <strong> for SEO limits */
.platform-label {
	font-weight: 700;
	font-size: 14px;
	color: var(--text);
	margin-bottom: 0.5rem;
}

.support-label {
	font-weight: 600;
	color: var(--text);
}

/* App Specific Icons */
.hero-icon-badge.prax,
.card-icon.prax {
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #30d158, #34c759);
    box-shadow:
      0 18px 44px rgba(48, 209, 88, 0.38),
      inset 0 1px 0 rgba(255,255,255,0.55),
      inset 0 -1px 0 rgba(0,0,0,0.08);
    position: relative;
    overflow: hidden;
}

.hero-icon-badge.prax {
    width: 88px;
    height: 88px;
    margin: 0 auto 20px;
    border-radius: 24px;
    font-size: 42px;
}

.card-icon.prax {
    width: 56px;
    height: 56px;
    border-radius: 14px;
    font-size: 28px;
    margin: 0 auto 16px;
}

.hero-icon-badge.prax::after,
.card-icon.prax::after {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 48%;
    background: linear-gradient(180deg, rgba(255,255,255,0.4), rgba(255,255,255,0));
    pointer-events: none;
}
