/* components/nav-menu.css */
/* ───────────────────────────────────── */
/*	 LEFT SIDE BURGER TRIGGER	 */
/* ───────────────────────────────────── */

.menu-trigger {
	position: fixed;
	top: 0;
	left: 0;
	width: 52px;
	height: 100vh;
	background: none;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	z-index: 1000;
}

.menu-trigger > p {
	position: absolute;
	color: #aaa;
	opacity: 0;
	font-size: 0.8rem;
	letter-spacing: 0.12rem;
	transform: translateY(60px) rotate(-90deg);
	transition: 0.35s ease;
}

.menu-trigger:hover > p {
	opacity: 1;
	transform: translateY(40px) rotate(-90deg);
}

.bars {
	display: flex;
	width: 50%;
	justify-content: space-between;
}

.bars span {
	width: 4px;
	height: 38px;
	border-radius: 999px;
	background: #5b5b76;
	transition: 0.35s ease;
}

.menu-trigger:hover .bars span:first-child,
.menu-trigger:hover .bars span:last-child {
	transform: translateY(-5px);
	opacity: 0.3;
}

.menu-trigger:hover .bars span:nth-child(2) {
	transform: scaleY(1.2);
	transform-origin: bottom center;
}

body.nav-open .bars span:nth-child(1) {
	transform: translateX(10px) rotate(45deg);
	height: 30px;
	opacity: 1;
	background: var(--accent-strong);
}
body.nav-open .bars span:nth-child(2) {
	opacity: 0;
}
body.nav-open .bars span:nth-child(3) {
	transform: translateX(-10px) rotate(-45deg);
	height: 30px;
	opacity: 1;
	background: var(--accent-strong);
}

/* ───────────────────────────────────── */
/*	 nav-menu BACKDROP	 */
/* ───────────────────────────────────── */

.nav-menu-backdrop {
	position: fixed;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 16px;

	background:
radial-gradient(circle at 15% 0,
	var(--nav-overlay-pink),
	transparent 55%),
radial-gradient(circle at 85% 100%,
	var(--nav-overlay-purple),
	transparent 55%),
var(--nav-overlay-dark);

	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	z-index: 999;

	opacity: 0;
	pointer-events: none;
	transition: opacity 0.3s ease;
	
}

/* When nav is open, show backdrop */
body.nav-open .nav-menu-backdrop {
	opacity: 1;
	pointer-events: auto;
}

/* ───────────────────────────────────── */
/*	 nav-menu PANEL (your card)	*/
/* ───────────────────────────────────── */

.nav-menu {
	max-width: var(--nav-card-width);
	width: 100%;
	border-radius: var(--nav-card-radius);
	/* was: padding: 26px 24px 24px; */
	padding: 30px 32px 26px;
	background:
linear-gradient(
	180deg,
	var(--nav-card-bg-top) 0%,
	#1a1529 45%,
	var(--nav-card-bg-bottom) 100%
);
	border: 1px solid var(--nav-card-border);
	box-shadow: var(--nav-card-shadow);

	position: relative;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	gap: 1.8rem;

	transform: translateX(-40vw) scale(0.96);
	opacity: 0;
	transition:
transform 0.45s cubic-bezier(.785,.135,.15,.86),
opacity 0.30s ease;

	user-select: none;
}


/* slide into centre when open */
body.nav-open .nav-menu {
	transform: translateX(0) scale(1);
	opacity: 1;
}

.nav-menu::before {
	content: "";
	position: absolute;
	inset: -40%;
	background:
radial-gradient(circle at 0% 0%, rgba(255,79,174,0.26), transparent 55%),
radial-gradient(circle at 100% 0%, rgba(163,125,255,0.22), transparent 55%);
	opacity: 0.75;
	mix-blend-mode: screen;
	pointer-events: none;
}

.nav-menu > * {
	position: relative;
	z-index: 1;
}

.nav-menu-header {
	text-align: center;
}

.nav-menu-header h1 {
	margin: 48px 0 18px;
	font-size: 1.3rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
}

.nav-menu h2 {
	margin: 0 0 5px;
	font-size: 1.2rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	text-align: center;
}

.nav-menu-header p {
	margin: 0;
	font-size: 0.9rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--text-soft);
}

.nav-menu p strong {
	color: var(--text-main);
	font-weight: 600;
}

.nav-menu-actions {
	display: flex;
	flex-wrap: nowrap;
	gap: 10px;
	justify-content: space-between;
}

.nav-menu-list {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	padding-block: 0.25rem; /* new */
}

/* ───────────────────────────────────── */
/*	 BUTTONS */
/* ───────────────────────────────────── */

/* LIST LAYOUT */

.nav-menu-list {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

/* BASE PILL */

.nav-link-pill {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	padding: 1.05rem 1.7rem;
	overflow: hidden;

	border-radius: var(--radius-pill);
	border: 1px solid var(--nav-pill-border);
	background: var(--nav-pill-bg);
	color: var(--text-main);

	font-size: 0.98rem;
	font-weight: 600;
	letter-spacing: 0.16em;
	text-transform: uppercase;

	cursor: pointer;
	outline: none;
	box-shadow: 0 12px 24px rgba(0,0,0,0.9);
	transition:
		background-color 1s ease-out,
		box-shadow 180ms ease-out,
		transform 160ms ease-out,
		border-color 180ms ease-out,
		filter 160ms ease-out;
	
	text-decoration: none;
}

/* soft inner sheen */
.nav-link-pill::after {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: inherit;
	background:
radial-gradient(circle at 15% 0, rgba(255,255,255,0.12), transparent 55%);
	opacity: 0;
	pointer-events: none;
	transition: opacity 220ms ease-out;
}

/* HOLOGRAPHIC SWEEP (like your example) */
.nav-link-pill::before {
	content: "";
	position: absolute;
	top: -120%;
	left: -40%;
	width: 180%;
	height: 260%;

	background: linear-gradient(
120deg,
transparent 0%,
transparent 30%,
var(--nav-holo-main) 48%,
var(--nav-holo-alt) 55%,
transparent 72%,
transparent 100%
	);

	transform: translateX(-40%);
	opacity: 0;
	mix-blend-mode: screen;
	pointer-events: none;
	transition:
transform 0.55s ease,
opacity 0.55s ease;
}

/* HOVER */

.nav-link-pill:hover {
	transform: translateY(-1px);
	box-shadow:
		0 16px 30px rgba(0,0,0,0.95),
		0 0 16px rgba(0,0,0,0.85);
	border-color: rgba(255,255,255,0.22);
	background: var(--nav-pill-hover-bg);
	/*animation:
		nav-link-hover-bg 1s ease-in;
	*/
}

@keyframes nav-link-hover-bg {
	0% {
background: var(--nav-pill-bg);
	}
	100% {
background: var(--nav-pill-hover-bg);
	}
}

.nav-link-pill:hover::after {
	opacity: 1;
}

.nav-link-pill:hover::before {
	opacity: 1;
	transform: translateX(45%);
}

/* ACTIVE / CURRENT PAGE */

.nav-link-pill.nav-link-active {
	background: linear-gradient(
90deg,
var(--nav-pill-active-left),
var(--nav-pill-active-right)
	);
	color: #ffffff;
	border-color: rgba(255,255,255,0.65);
	box-shadow:
0 18px 36px rgba(0,0,0,0.95),
0 0 22px rgba(163,125,255,0.7);
}

.nav-link-pill.nav-link-active:hover {
	background: linear-gradient(
90deg,
var(--nav-pill-active-left),
var(--nav-pill-active-right)
	);
	color: #ffffff;
	border-color: rgba(255,255,255,0.65);
	box-shadow:
0 18px 36px rgba(0,0,0,0.95),
0 0 22px rgba(163,125,255,0.7);
	animation: none;
}

/* holo sweep always visible but slower on active */
.nav-link-pill.nav-link-active::before {
	opacity: 1;
	transform: translateX(45%);
}

.nav-link-pill:active {
	transform: translateY(0);
	box-shadow:
0 8px 16px rgba(0,0,0,0.9),
0 0 10px rgba(0,0,0,0.9);
}

/* ───────────────────────────────────── */
/*	 DEV LABEL (optional)*/
/* ───────────────────────────────────── */

.dev-label {
	position: fixed;
	top: 12px;
	left: 50%;
	transform: translateX(-50%);
	padding: 4px 10px;
	border-radius: 999px;
	font-size: 0.7rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	background: rgba(0, 0, 0, 0.6);
	color: var(--text-mute);
	border: 1px solid rgba(255, 255, 255, 0.1);
	z-index: 1001;
}

@media (max-width: 480px) {
	.nav-menu {
padding: 18px 16px 16px;
	}
	.nav-menu-actions {
justify-content: stretch;
	}
	.nav-menu-actions .btn {
flex: 1 1 auto;
text-align: center;
	}
}

/* ───────────────────────────────────── */
/*	 CLOSE BUTTON “X”*/
/* ───────────────────────────────────── */

/* ───────────────────────────── */
/*	 CLOSE “X” BUTTON*/
/* (just recoloured to match)*/
/* ───────────────────────────── */

.nav-close {
	position: absolute;
	top: 10px;
	right: 10px;
	width: 48px;
	height: 48px;
	z-index: 3;
}

.nav-close a {
	width: 100%;
	height: 100%;
	position: relative;
	background: var(--nav-close-bg);
	border-radius: 50%;
	box-shadow: var(--nav-close-shadow);
	transition: var(--transition-nav);
	display: flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	overflow: hidden;
}

.nav-close a:hover {
	background: var(--nav-close-bg-hover);
}

/* bars & pearls reuse your existing colours */
.nav-close a .bar {
	position: absolute;
	left: 50%;
	top: 50%;
	width: 16px;
	height: 2px;
	margin-left: -15px;
	margin-top: -2px;
	border-radius: 999px;
	background-color: var(--accent-strong);
	transition: var(--transition-nav);
	overflow: hidden;
}

.nav-close a .bar-left {
	transform: rotate(45deg);
}

.nav-close a .bar-right {
	transform: rotate(-45deg);
	color: rgb(0, 0, 0);
}

.nav-close a .bar .circle {
	position: absolute;
	top: -1px;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background-color: #000000;
	transition: var(--transition-nav);
}

.nav-close a .bar .circle-left	{ transform: translateX(0); }
.nav-close a .bar .circle-right { transform: translateX(0); }

.nav-close a:hover .bar {
	background-color: var(--nav-close-color1);
}

.nav-close a:hover .bar .circle {
	background-color: var(--nav-close-color2);
}

.nav-close a:hover .bar-left	.circle-left,
.nav-close a:hover .bar-right .circle-left {
	transform: translateX(52px);
}

.nav-close a:hover .bar-left	.circle-right,
.nav-close a:hover .bar-right .circle-right {
	transform: translateX(-52px);
}

/* Slightly tighter on small screens */
@media (max-width: 540px) {
	.nav-close {
		width: 36px;
		height: 36px;
		top: 8px;
		right: 8px;
	}
}

.nav-divider {
	width: 100%;
	height: 3px;

	background: linear-gradient(
		to right,
		transparent 0%,
		rgba(255,255,255,0.25) 20%,
		rgba(255,255,255,0.45) 50%,
		rgba(255,255,255,0.25) 80%,
		transparent 100%
	);
}

.section-heading {
	font-size: 0.9rem;
	text-transform: uppercase;
	letter-spacing: 0.22em;
	color: var(--text-main);
	text-align: center;
	margin: 0.75rem 0 0.75rem;
}

.section-heading::before,
.section-heading::after {
	content: "";
	display: inline-block;
	width: 3rem;
	height: 1px;
	background: linear-gradient(to right, transparent, rgba(255,255,255,0.25));
	vertical-align: middle;
}

.section-heading::after {
	transform: scaleX(-1);
}


/* ─────────────────────────────
	 Language dropdown (clean)
	 ───────────────────────────── */

.nav-lang {
	width: 100%;
}

/* Make the toggle behave like your other pills, but with a known layout */
.nav-lang__toggle {
	display: flex;
	align-items: center;
	justify-content: center; /* keep label centered */
	position: relative;
}

/* Keep "Language" perfectly centered */
.nav-lang__label {
	pointer-events: none;
}

/* Chevron: always visible, anchored right */
.nav-lang__chev {
	position: absolute;
	right: 1.25rem;
	top: 50%;
	transform: translateY(-50%);
	opacity: 0.85;
	font-size: 0.95rem;
	line-height: 1;
	pointer-events: none;
}

/* Rotate chevron when open */
.nav-lang__toggle[aria-expanded="true"] .nav-lang__chev {
	transform: translateY(-50%) rotate(180deg);
}

/* Dropdown panel - CLOSED by default via max-height/opacity (no [hidden]) */
.nav-lang__panel {
	margin-top: 0.55rem;
	display: grid;
	gap: 0.45rem;

	max-height: 0;
	opacity: 0;
	overflow: hidden;
	pointer-events: none;

	transition:
	max-height 220ms ease,
	opacity 180ms ease;
}

/* Open state */
.nav-lang.is-open .nav-lang__panel {
	max-height: min(44vh, 320px);
	opacity: 1;
	pointer-events: auto;
	overflow: auto;
	-webkit-overflow-scrolling: touch;
}

/* Options - subordinate pills */
.nav-lang__opt {
	width: 100%;
	border-radius: 999px;
	padding: 0.65rem 1rem;

	background: rgba(0,0,0,0.28);
	border: 1px solid rgba(255,255,255,0.10);

	color: var(--text-muted);
	font-size: 0.82rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: none;

	cursor: pointer;
	transition: border-color 140ms ease, color 140ms ease, transform 140ms ease;
}

.nav-lang__opt:hover {
	color: var(--text-main);
	border-color: rgba(255,255,255,0.24);
	transform: translateY(-1px);
}

/* Active locale highlight */
.nav-lang__opt.is-active {
	color: var(--text-main);
	border-color: rgba(255,255,255,0.26);
	background:
	linear-gradient(90deg, rgba(163,125,255,0.20), rgba(255,79,174,0.18)),
	rgba(0,0,0,0.25);
}

/* Search input hidden by default */
.nav-lang__search {
	width: 100%;
	margin-top: 0.55rem;
	padding: 0.65rem 1rem;

	border-radius: 999px;
	border: 1px solid rgba(255,255,255,0.12);
	background: rgba(0,0,0,0.30);
	color: var(--text-main);

	opacity: 0;
	max-height: 0;
	pointer-events: none;
	transform: translateY(-4px);

	transition:
	opacity 160ms ease,
	max-height 220ms ease,
	transform 160ms ease;
}

.nav-lang__search::placeholder {
	color: var(--text-soft);
}

/* Reveal search only when language is open */
.nav-lang.is-open .nav-lang__search {
	opacity: 1;
	max-height: 48px;
	pointer-events: auto;
	transform: translateY(0);
}


/* ─────────────────────────────
	 Language list scrollbar
	 ───────────────────────────── */

/* Chrome / Edge / Safari */
.nav-lang__panel::-webkit-scrollbar {
	width: 8px;
}

.nav-lang__panel::-webkit-scrollbar-track {
	background: rgba(0,0,0,0.25);
	border-radius: 999px;
}

.nav-lang__panel::-webkit-scrollbar-thumb {
	background:
	linear-gradient(
		180deg,
		rgba(163,125,255,0.65),
		rgba(255,79,174,0.65)
	);
	border-radius: 999px;
	border: 2px solid rgba(0,0,0,0.35); /* gives it “floating” depth */
}

.nav-lang__panel::-webkit-scrollbar-thumb:hover {
	background:
	linear-gradient(
		180deg,
		rgba(163,125,255,0.85),
		rgba(255,79,174,0.85)
	);
}

/* Firefox */
.nav-lang__panel {
	scrollbar-width: thin;
	scrollbar-color:
	rgba(255,79,174,0.65)
	rgba(0,0,0,0.25);
}

:root {
	--bg: #050608;
	--bg-soft: #101118;
	--surface: #151626;
	--surface-soft: #191a2a;

	--text-main: #f5f1ff;
	--text-muted: #b4adc7;
	--text-soft: #8c849f;

	--accent: #ff4fae;
	--accent-soft: rgba(255,79,174,0.16);
	--accent-strong: #ff7bc2;

	--accent-alt: #a37dff; /* for future purple theme */

	--radius-pill: 999px;
	--radius-card: 1.6rem;

	--shadow-soft: 0 22px 45px rgba(0, 0, 0, 0.8);
	--shadow-subtle: 0 0 0 1px rgba(255, 255, 255, 0.04);
	
	/* NAV: card + pills */
	--nav-card-radius: 1.9rem;
	--nav-card-width: 520px;
	--nav-card-bg-top: #25152f;
	--nav-card-bg-bottom: #070712;
	--nav-card-border: rgba(255,255,255,0.08);
	--nav-card-shadow:
0 26px 60px rgba(0,0,0,0.92),
0 0 32px rgba(255,255,255,0.9);

	--nav-close-bg: rgba(0,0,0,0.85);
	--nav-close-shadow: 
0 26px 60px rgba(0,0,0,0.92),
0 0 32px rgba(255,255,255,0.9);
	--nav-close-bg-hover: rgba(0,0,0,0.92);
	--nav-close-color1: #ff7bc2;
	--nav-close-color2: #ff4fae;

	/* darker buttons than old mock */
	--nav-pill-bg: #0d0e18;
	--nav-pill-hover-bg: rgba(255,79,174,0.55);
	--nav-pill-border: rgba(255,255,255,0.10);

	/* active gradient */
	--nav-pill-active-left: rgba(163,125,255,0.7);
	--nav-pill-active-right: #ff4fae;

	/* holographic sweep colours */
	--nav-holo-main: rgba(255,79,174,0.55);
	--nav-holo-alt: rgba(163,125,255,0.55);

	/* backdrop */
	--nav-overlay-dark: rgba(0,0,0,0.80);
	--nav-overlay-pink: rgba(255,79,174,0.22);
	--nav-overlay-purple: rgba(163,125,255,0.22);
}

* {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

body {
	min-height: 100vh;
	font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	background:
radial-gradient(circle at top, #18192b 0, #050608 55%, #020208 100%);
	color: var(--text-main);
	display: flex;
	flex-direction: column;
}

.page {
	position: relative;
	max-width: 100%;
	margin: 0 auto;
}

.page-content {
	position: relative;
	max-width: 960px;
	margin: 0 auto;
	padding: 2.5rem 1.5rem 3rem;
	z-index: 20;
	border-radius: 50px;
	background-color: rgba(0,0,0,0.7);
	backdrop-filter: blur(12px);
}

/* Header / Title */

.page-title {
	font-size: clamp(2.6rem, 4vw + 1.2rem, 3.4rem);
	font-weight: 700;
	letter-spacing: 0.03em;
	margin-bottom: 0.5rem;
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}

.page-header {
	position: relative;
	min-height: 420px;
	overflow: hidden;
	background: radial-gradient(circle at 20% 0, #2a1449 0, #050615 55%, #01010a 100%);
	color: #fff;
	
	width: 100%;
	height: auto;
	
	margin: 0 auto;
	
}

.header-nari {
	max-width: 2160px;
	min-height: 480px;
	margin: 0 auto;
	position: relative;
}

.page-subtitle {
	justify-content: center;
	font-size: 0.98rem;
	color: var(--text-muted);
	max-width: 36rem;
	line-height: 1.6;
	margin-bottom: 2.2rem;
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}

/* Section headings */
.section-heading {
	font-size: 0.9rem;
	text-transform: uppercase;
	letter-spacing: 0.22em;
	color: var(--text-soft);
	text-align: center;
	margin: 2.2rem 0 1.2rem;
}

.section-heading::before,
.section-heading::after {
	content: "";
	display: inline-block;
	width: 3rem;
	height: 1px;
	background: linear-gradient(to right, transparent, rgba(255,255,255,0.25));
	vertical-align: middle;
	margin: 0 0.75rem;
}

.section-heading::after {
	transform: scaleX(-1);
}

/* Link cards */
.link-list {
	display: flex;
	flex-direction: column;
	gap: 0.9rem;
	user-select: none;
}

.link-card {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1.25rem;
	padding: 0.95rem 1.4rem;
	border-radius: var(--radius-card);
	background:
radial-gradient(circle at 0 0, rgba(255,79,174,0.20) 0, transparent 55%),
radial-gradient(circle at 100% 0, rgba(163,125,255,0.20) 0, transparent 55%),
linear-gradient(135deg, #11121f, #121322 55%, #11101c 100%);
	box-shadow: var(--shadow-soft);
	border: 1px solid rgba(255,255,255,0.07);
	text-decoration: none;
	color: var(--text-main);
	overflow: hidden;
	transition:
transform 240ms ease,
box-shadow 240ms ease,
border-color 240ms ease;

	cursor: pointer;
	overflow: hidden;
}

.link-card .holo-layer {
	position: absolute;
	top: -120%;
	left: -40%;
	width: 180%;
	height: 260%;

	background: linear-gradient(
120deg,
transparent 0%,
transparent 32%,
rgba(255,255,255,0.18) 46%,
rgba(255,180,255,0.35) 52%,
rgba(255,255,255,0.18) 58%,
transparent 72%,
transparent 100%
	);
	
	transform: scaleX(0) translateX(-40%);
	transform-origin: left center;
	opacity: 0;

	mix-blend-mode: screen;
	pointer-events: none;

	transition:
transform 640ms ease-out,
opacity 640ms ease-out;
}

.link-card:hover {
	transform: translateY(-1px);
	border-color: rgba(255,255,255,0.18);
	box-shadow: 0 0px 15px rgba(255,255,255,0.9);
}

.link-card:hover .holo-layer {
	transform: scaleX(1) translateX(45%);
	opacity: 1;
}

/* Pink swell overlay */
.link-card::before {
	content: "";
	position: absolute;
	inset: 0;
	
	top: -120%;
	left: -40%;
	width: 180%;
	height: 260%;
	
	border-radius: inherit;
	/* same pink, but softened with alpha so it isn't blinding */
	background: 
linear-gradient( 90deg, rgba(255,79,174,0.30), rgba(255,79,174,0.30) );

	transform-origin: left center;/* anchor on the left */
	transform: scaleX(0);/* start collapsed */
	opacity: 0;	/* invisible at rest */
	pointer-events: none;
	transition:
transform 640ms ease-out,
opacity 640ms ease-out;
}

/* On hover: swell from left → right and cover the bar */
.link-card:hover::before {
	transform: scaleX(1);
	opacity: 1;
}

.link-main {
	display: flex;
	align-items: center;
	gap: 0.9rem;
	min-width: 0;
	z-index: 5;
}
	
.link-icon {
	position: relative;
	width: 48px;
	height: 48px;
	align-items: center;
	justify-content: center;
	color: #ffffff;
	font-weight: 600;
	font-size: 0.9rem;
	perspective: 36px;
	transition:
	transform 320ms ease-out,
	background 220ms ease,
	box-shadow 220ms ease;
	transform-style: preserve-3d;
}
	
.link-card:hover .link-icon {
	transform: rotateY(180deg);
}

.link-icon-front,
.link-icon-back {
	position: absolute;
	display: flex;
	width: 100%;
	height: 100%;
	backface-visibility: hidden;
	justify-content: center;
	text-align: center;
	border-radius: 999px;
	box-shadow: 0 0 0 1px rgba(255,255,255,0.1);
	
	inset: 0;
	transition:
transform 320ms ease-out,
background 220ms ease,
box-shadow 220ms ease;
}
	
.link-icon-front {
	background: radial-gradient(circle at 25% 0,
#ffe3f4 0, #ff4fae 40%, #7a1a5e 75%, #1c081f 100%);
}
	
.link-icon-back {
	background: radial-gradient(circle at 25% 0,
#f7e9ff 0, #b58cff 40%, #4b2c84 75%, #190b33 100%);
	box-shadow:
0 0 5px #ffffff,
0 0 18px rgba(255,79,174,0.8);
	transform: rotateY(180deg);
}

.link-icon.icon svg {
	margin: auto;
	width: 60%;
	height: 60%;
	display: block;
	fill: #ffffff; /* enforced white */
}

.link-icon.audiochan img {
	width: 48px;
	height: auto;
	margin: auto;
	border-radius: 50%;
	--bubble-bg: rgba(20, 20, 30, 0.65);
	--bubble-glow: rgba(130, 100, 200, 0.35);
}

/* Placeholder icon style; swap with real SVGs later */
.link-icon span {
	margin: auto;
	font-size: 0.9rem;
	font-weight: 600;
}

.link-text {
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
	min-width: 0;
}

.link-title {
	font-size: 1rem;
	font-weight: 600;
}

.link-sub {
	font-size: 0.84rem;
	color: var(--text-soft);
	white-space: nowrap;
	text-overflow: ellipsis;
	overflow: hidden;
}

.link-badge {
	padding: 0.25rem 0.9rem;
	border-radius: var(--radius-pill);
	border: 3px solid rgba(255,255,255,0.00);
	background: var(--accent-soft);
	color: var(--accent-strong);
	font-size: 0.78rem;
	font-weight: 500;
	white-space: nowrap;
	box-shadow: var(--shadow-subtle);
	z-index: 10;
}

.link-badge.secondary {
	background: rgba(0,0,0,0.4);
	color: var(--text-soft);
}

.link-card:hover .link-badge.secondary {
	background: rgba(0,0,0,0.3);
	color: var(--text-main);
}

.link-badge.premium {
	background: rgba(255, 215, 0, 0.08);
	color: #ffd76a;
	border-color: rgba(255, 215, 0, 0.7);
}

.link-badge.free {
	background: rgba(46, 204, 113, 0.12);
	color: #7cffb3;
	border-color: rgba(124, 255, 179, 0.7);
}

/* Support blurb */

.support-copy {
	font-size: 0.88rem;
	color: var(--text-soft);
	text-align: center;
	max-width: 42rem;
	margin: 0.3rem auto 1.6rem;
	line-height: 1.7;
}

@media (max-width: 640px) {
	.page {
padding-top: 2rem;
	}

	.link-card {
padding: 0.9rem 1.1rem;
	}
}

.link-cta {
	padding: 0.45rem 1.4rem;
	border-radius: var(--radius-pill);
	border: 2px solid rgba(255, 130, 190, 0.9);
	background:
radial-gradient(circle at 0 0, #ffd7f1 0, transparent 40%),
linear-gradient(135deg, #ff4fae, #ff7bc2);
	color: #170b12;
	font-size: 0.82rem;
	font-weight: 600;
	letter-spacing: 0.03em;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;

	box-shadow:
0 0 0 1px rgba(255,255,255,0.16),
0 8px 22px rgba(0,0,0,0.65);

	transition:
transform 140ms ease,
box-shadow 140ms ease,
filter 140ms ease,
border-color 140ms ease;

	z-index: 10;
}

.link-card:hover .link-cta {
	background:
radial-gradient(circle at 0 0, #e6d8ff 0, transparent 40%),
linear-gradient(135deg, #b794ff, #8e5bff, #5328a8);
	color: var(--text-main);
	border: 2px solid rgba(255, 255, 255, 0.6);
}

/* Special tweaks for the Twitter card, if needed */
.link-card--twitter .twitter-follow-chip {
	position: static;	/* no absolute */
	top: auto;
	right: auto;
	transform: none;
	z-index: 3;
}

/* Hover / active states to make it feel alive */
.link-cta:hover {
	transform: translateY(-1px) scale(1.03);
	filter: brightness(1.03);
	box-shadow:
0 0 8px rgba(255, 200, 235, 0.8),
0 12px 26px rgba(0,0,0,0.85);
}

.link-cta:active {
	transform: translateY(0) scale(0.97);
	box-shadow:
0 0 4px rgba(255, 200, 235, 0.7),
0 6px 16px rgba(0,0,0,0.9);
}



.nari-hero-bg {
	position: absolute;
	inset: 0;
	overflow: hidden;
}

.nari-hero-inner {
	position: relative;
	max-width: 1100px;
	margin: 0 auto;
	padding: 3.5rem 1.5rem 5rem;
}

.nari-hero-sticky {
	position: fixed;
	top: 0;
	left: 15%;
	z-index: 20;
	display: inline-block;
	pointer-events: none;
	width: max-content;
}

/* SVG sizing */
.hero-logo {
	position: relative;
	display: block;
}

.hero-logo-nari {
	z-index: 1;
	padding-top: 2rem;
	width: 75%;
	height: auto;
	color: #ffffff;
	filter: drop-shadow(0 0 24px rgba(255,255,255,0.4));
	border: 0px solid #ffffff;

	/* TWO animations: glow + float */
	animation:
logo-nari-glow 5s ease-in-out infinite alternate,
logo-nari-float 36s linear infinite alternate;
}

.svg-swap {
	position: relative;
	width: 100%;
	height: auto;
	
	filter:
drop-shadow(0 0 22px rgba(226, 108, 255, 0.9));
	
	animation: 
logo-asmr-float 36s linear infinite alternate;
}

.svg-swap .icon {
	position: absolute;
	inset: 0;

	margin-top: -4rem;
	margin-left: 12.5rem;
	transform-origin: left center;
	color: rgb(226, 108, 255);
	z-index: 0;
}

.svg-swap .a { 
	opacity: 1; 
	width: 75%;
	animation-fill-mode: both;
	animation: logo-asmr-va-switch 60s linear infinite alternate-reverse;
	z-index: 1;
}
.svg-swap .b {
	width: 50%;
	margin-left: 50%;
	opacity: 0;
	animation-fill-mode: both;
	animation: logo-asmr-va-switch 60s linear infinite alternate;
	z-index: 0;
}

@keyframes logo-asmr-va-switch {
	0%, 45% { opacity: 0; }
	47.5% { opacity: 0; transform: scale(0); }
	50% { filter: blur(12px); }
	52.5%, 100% { opacity: 1; transform: scale(1); filter: blur(0px); }
}

.hero-logo-asmr {
	position: absolute;
	width: 75%;
	margin-top: -4rem;
	margin-left: 12.5rem;
	filter:
drop-shadow(0 0 22px rgba(226, 108, 255, 0.9));
	transform-origin: left center;
	color: rgb(226, 108, 255);
	z-index: 0;

	/* just the float animation, opposite phase */
	animation: logo-asmr-float 36s linear infinite alternate;
}

@keyframes logo-nari-glow {
	from {
filter:
	drop-shadow(0 0 24px rgba(255,255,255,0.4));
	}
	to {
filter:
	drop-shadow(0 0 48px rgba(255,255,255,1));
	}
}

/* Nari floats mostly upward-first */
@keyframes logo-nari-float {
	0% {
transform: translate(0, 0);
	}
	10% {
transform: translate(-3px, 3px);
	}
	20% {
transform: translate(-6px, 6px);
	}
	30% {
transform: translate(-9px, 12px);
	}
	40% {
transform: translate(-12px, 6px);
	}
	50% {
transform: translate(-15px, 0px);
	}
	60% {
transform: translate(-12px, -6px);
	}
	70% {
transform: translate(-9px, -12px);
	}
	80% {
transform: translate(-6px, -6px);
	}
	90% {
transform: translate(-3px, -3px);
	}
	100% {
transform: translate(0px, 0px);
	}
}

/* ASMR floats in the opposite rhythm */
@keyframes logo-asmr-float {
	0% {
transform: translate(0, 0);
	}
	10% {
transform: translate(3px, -6px);
	}
	20% {
transform: translate(6px, -8px);
	}
	30% {
transform: translate(9px, -8px);
	}
	40% {
transform: translate(12px, -6px);
	}
	50% {
transform: translate(15px, 0px);
	}
	60% {
transform: translate(12px, 6px);
	}
	70% {
transform: translate(9px, 8px);
	}
	80% {
transform: translate(6px, 8px);
	}
	90% {
transform: translate(3px, 6px);
	}
	100% {
transform: translate(0px, 0px);
	}
}

.nari-mascot {
	position: fixed;
	display: inline-block;
	pointer-events: none;
	width: max-content;
	bottom: 0;
	z-index: 0;
}

.nari-mascot.nari {
	right: 0;
	top: 0;
	filter: 
drop-shadow(0 0 24px rgba(226, 108, 255, 0.9))
brightness(80%);
	animation: nari-mrmeowzers 60s ease-in-out infinite alternate;
}

.nari-mascot.mrmeowzers {
	left: 0;
	bottom: -10px;
	filter: 
drop-shadow(0 0 12px var(--accent))
brightness(80%);
	animation: nari-mrmeowzers 60s ease-in-out infinite alternate-reverse;
}

@keyframes nari-mrmeowzers {
	from {
filter: drop-shadow(0 0 24px rgba(226, 108, 255, 0.9));

	}
	to {
filter: drop-shadow(0 0 12px var(--accent));

	}
}

.mascot-dim {
	z-index: 1;
	position: fixed;
	inset: 0;
	pointer-events: none;
	background: radial-gradient(circle at 75% 40%, rgba(0,0,0,0.5), transparent 70%);
	opacity: var(--scroll-dim, 0);
	transition: opacity 600ms ease;
}


/* Phones */
@media (max-width: 360px) {
	
}	 /* XS */
@media (max-width: 390px) {
	
}	 /* S/M */
@media (max-width: 412px) {
	
}	 /* L */
@media (max-width: 430px) {
	
}	 /* XL */

/* Foldables / Landscape Phones / Small Tablets */
@media (max-width: 768px) {
	
}

/* Tablets */
@media (max-width: 1024px) {
	
}

/* Desktops */

/* 
@media (max-width: 1280px) {
	
}

/* 1440 x 900 (NOT 1440p!!) */
@media (max-width: 1440px) {
	
}

/* 1080p FHD */
@media (max-width: 1920px) {
	
}

/* 1440p */
@media (max-width:	2560px) {
	
}

/* 4K */
@media (max-width: 3840px) {
	
}

/* 8K */
@media (min-width: 3841px) and (max-width: 7680px) {
	.nari-mascot.nari {
transform-origin: center top;
transform: translate(-1024px, 0px) scale(4);
	}
	
	.nari-mascot.mrmeowzers {
transform-origin: center bottom;
transform: translate(1000px, 0px) scale(5);
	}
}

.cat-wrap {
	position: relative;
	display: inline-block;
}

.nari-bubble,
.cat-bubble {
	position: absolute;
	width: 100px;
	
	white-space: nowrap;
	
	padding: 0.75rem 0.75rem;
	border-radius: 999px;
	background: rgba(200,200,200,0.92);
	color: #111;
	font-weight: 700;
	font-size: 0.95rem;

	transform: translate(-50%, -50%) scale(0.75);
	opacity: 0;
	pointer-events: none;

	box-shadow:
0 12px 24px rgba(0,0,0,0.35),
0 0 18px rgba(255,79,174,0.35);

	z-index: 1;
}

.nari-bubble {
	left: 65%;
	top: 42%;
	
	min-width: 20ch;
	
	z-index: 10;
}

.cat-bubble {
	left: 105%;
	top: 36%;
	
	min-width: 10ch;
}

/* Bubble tail */
.nari-bubble::after,
.cat-bubble::after {
	content: "";
	position: absolute;
	left: 0%;
	bottom: 0px;
	width: 50px;
	height: 38px;
	background: rgba(200,200,200,0.92);
	transform: rotate(0deg);
	border-radius: 3px;
	z-index: -1;
}

/* Triggered state */
.nari-bubble.is-open,
.cat-bubble.is-open {
	animation: bubble-pop 4s ease-out forwards;
}

@keyframes bubble-pop {
	0%	 { opacity: 0; transform: translate(-50%, -50%) scale(0.6); filter: blur(2px); }
	20%	{ opacity: 1; transform: translate(-50%, -56%) scale(1.05); filter: blur(0); }
	45%	{ opacity: 1; transform: translate(-50%, -50%) scale(1); }
	100% { opacity: 0; transform: translate(-50%, -44%) scale(0.98); }
}


.site-notice {
	position: fixed;
	left: 50%;
	top: 1rem;
	transform: translateX(-50%);
	width: min(980px, calc(100% - 2rem));
	z-index: 9999;

	border-radius: 18px;
	border: 1px solid rgba(255,255,255,0.14);
	background:
	radial-gradient(circle at 0 0, rgba(255,79,174,0.18) 0, transparent 55%),
	radial-gradient(circle at 100% 0, rgba(163,125,255,0.18) 0, transparent 55%),
	linear-gradient(135deg, #11121f, #121322 55%, #11101c 100%);

	box-shadow:
	0 18px 36px rgba(0,0,0,0.65),
	0 0 22px rgba(255,79,174,0.18);

	backdrop-filter: blur(10px);
	
	animation: notice-enter 420ms ease-out both;
}

@keyframes notice-enter {
	from {
opacity: 0;
transform: translate(-50%, -6px);
	}
	to {
opacity: 1;
transform: translate(-50%, 0);
	}
}

.site-notice[hidden] { display: none; }

.site-notice__inner {
	display: grid;
	grid-template-columns: auto 1fr auto auto;
	gap: 0.9rem;
	align-items: center;
	padding: 0.85rem 1rem;
}

.site-notice__icon {
	width: 34px;
	height: 34px;
	border-radius: 999px;
	display: grid;
	place-items: center;
	font-weight: 900;

	background: rgba(255,255,255,0.10);
	border: 1px solid rgba(255,255,255,0.14);
	color: var(--text-main);
}

.site-notice__title {
	font-weight: 800;
	letter-spacing: 0.02em;
	margin-bottom: 0.15rem;
}

.site-notice__message {
	color: var(--text-muted);
	line-height: 1.3;
}

.site-notice__link {
	color: var(--text-main);
	text-decoration: none;
	font-weight: 700;
	padding: 0.55rem 0.85rem;
	border-radius: 999px;
	border: 1px solid rgba(255,255,255,0.14);
	background: rgba(0,0,0,0.25);
	opacity: 0.85;
}

.site-notice__link:hover {
	opacity: 1;
	border-color: rgba(255,255,255,0.25);
}

.site-notice__close {
	appearance: none;
	border: none;
	background: transparent;
	color: var(--text-muted);
	font-size: 1.1rem;
	cursor: pointer;
	padding: 0.35rem 0.55rem;
	border-radius: 10px;
}

.site-notice__close:hover {
	color: var(--text-main);
	background: rgba(255,255,255,0.08);
}

/* Variants */
.site-notice[data-variant="info"]	.site-notice__icon { box-shadow: 0 0 18px rgba(163,125,255,0.35); }
.site-notice[data-variant="warn"]	.site-notice__icon { box-shadow: 0 0 18px rgba(255,193,79,0.35); }
.site-notice[data-variant="down"]	.site-notice__icon { box-shadow: 0 0 22px rgba(255,79,174,0.45); }


/* TESTING NAV INTEGRATION BELOW */

/* ─────────────────────────────────────────────
	 NAV variant: link-cards, but centered title only
	 ───────────────────────────────────────────── */

.nav-menu .nav-card {
	/* turn <button> into "anchor-like" without losing your card look */
	appearance: none;
	-webkit-appearance: none;
	border: 1px solid rgba(255,255,255,0.07); /* keep yours */
	width: 100%;

	/* override link-card layout */
	justify-content: center;
	gap: 0;
	padding: 1.05rem 1.4rem;				 /* tune to taste */
}

/* Kill any “space-between” intent coming from .link-card */
.nav-menu .nav-card > * {
	flex: 0 0 auto;
}

/* Single centered title */
.nav-menu .nav-card__title {
	z-index: 5;											/* above ::before overlay */
	text-align: center;

	font-size: 0.98rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;

	/* stops weird selection highlights on rapid clicking */
	user-select: none;
}

/* Keep the holo-layer & swell exactly as your link-cards already do.
	 (No change needed — your .link-card::before and .holo-layer rules apply.) */

/* Keyboard focus: match your aesthetic (and keep it accessible) */
.nav-menu .nav-card:focus-visible {
	outline: 2px solid rgba(255, 255, 255, 0.55);
	outline-offset: 3px;
}

/* Active/current page state for nav */
.nav-menu .nav-card.nav-link-active {
	border-color: rgba(255,255,255,0.22);
	box-shadow: 0 0px 18px rgba(255,255,255,0.65);
}

/* Optional: make active feel “locked in” (less motion if you want) */
.nav-menu .nav-card.nav-link-active:hover {
	transform: translateY(-1px);
}

.nav-menu .nav-lang__toggle {
	position: relative;
}

.nav-menu .nav-lang__chev {
	position: absolute;
	right: 1.25rem;
	top: 50%;
	transform: translateY(-50%);
	z-index: 6;
	opacity: 0.9;
	pointer-events: none;
}

.nav-menu .nav-lang__toggle[aria-expanded="true"] .nav-lang__chev {
	transform: translateY(-50%) rotate(180deg);
}






/* --- NAV CLOSE (variable-driven) ----------------------------------- */

.nav-close a#nav-close-btn{
	width: var(--nav-close-size);
	height: var(--nav-close-size);
	position: relative;
	display: block;

	background-color: var(--nav-close-btn-bg);
	border-radius: var(--nav-close-btn-radius);
	opacity: 1;

	transition: var(--nav-close-transition);

	-webkit-box-shadow: var(--nav-close-btn-shadow);
	-moz-box-shadow: var(--nav-close-btn-shadow);
	box-shadow: var(--nav-close-btn-shadow);

	text-decoration: none;
}

.nav-close a#nav-close-btn > .bar{
	background-color: var(--nav-close-bar-bg);
	height: var(--nav-close-bar-height);
	width: var(--nav-close-bar-width);
	border-radius: var(--nav-close-bar-radius);

	position: absolute;
	top: 50%;
	left: var(--nav-close-bar-left);
	margin-top: calc(var(--nav-close-bar-height) / -2);

	display: flex;
	justify-content: space-between;

	transition: var(--nav-close-transition);
}

.nav-close a#nav-close-btn > .bar .circle{
	display: block;
	background-color: var(--nav-close-circle-bg);
	width: var(--nav-close-bar-height);
	height: var(--nav-close-bar-height);
	border-radius: var(--nav-close-bar-radius);

	position: absolute;
	left: 0;
	top: 0;

	transition: var(--nav-close-transition);
}

.nav-close a#nav-close-btn > .bar-left{
	transform: rotate(45deg);
	transform-origin: center;
}
.nav-close a#nav-close-btn > .bar-left .circle-left{ margin-left: 0; }
.nav-close a#nav-close-btn > .bar-left .circle-right{ margin-left: var(--nav-close-circle-offset); }

.nav-close a#nav-close-btn > .bar-right{
	transform: rotate(-45deg);
	transform-origin: center;
}
.nav-close a#nav-close-btn > .bar-right .circle-left{ margin-left: 0; }
.nav-close a#nav-close-btn > .bar-right .circle-right{ margin-left: var(--nav-close-circle-offset); }

.nav-close a#nav-close-btn:hover > .bar{
	background-color: var(--nav-close-hover-bar-bg);
}
.nav-close a#nav-close-btn:hover > .bar .circle{
	background-color: var(--nav-close-hover-circle-bg);
}

.nav-close a#nav-close-btn:hover > .bar-left .circle-left{ margin-left: var(--nav-close-circle-offset); }
.nav-close a#nav-close-btn:hover > .bar-left .circle-right{ margin-left: 0; }

.nav-close a#nav-close-btn:hover > .bar-right .circle-left{ margin-left: var(--nav-close-circle-offset); }
.nav-close a#nav-close-btn:hover > .bar-right .circle-right{ margin-left: 0; }
