/* ============================================================
   InternetIsFun — Design system
   ============================================================ */

:root {
	/* Brand */
	--iif-accent:   #7c5cff;
	--iif-accent-2: #ff3d8a;
	--iif-accent-3: #00e5d1;
	--iif-accent-4: #ffc94d;

	/* Surfaces (dark first) */
	--iif-bg:        #0b0418;
	--iif-bg-2:      #14082b;
	--iif-bg-3:      #1f0f3d;
	--iif-surface:   rgba(255,255,255,0.04);
	--iif-surface-2: rgba(255,255,255,0.08);
	--iif-border:    rgba(255,255,255,0.10);
	--iif-border-2:  rgba(255,255,255,0.18);

	/* Text */
	--iif-text:      #f6f3ff;
	--iif-text-2:    #c8c0e6;
	--iif-text-3:    #8d83b8;
	--iif-text-link: #b9a8ff;

	/* Effects */
	--iif-glass:     blur(20px) saturate(160%);
	--iif-shadow-1:  0 8px 24px rgba(0,0,0,0.25);
	--iif-shadow-2:  0 24px 60px rgba(0,0,0,0.35);
	--iif-glow:      0 0 32px rgba(124,92,255,0.35);

	/* Radii */
	--iif-r-sm:  10px;
	--iif-r-md:  16px;
	--iif-r-lg:  22px;
	--iif-r-xl:  28px;
	--iif-r-2xl: 40px;
	--iif-r-pill: 999px;

	/* Spacing scale */
	--iif-s-0:  4px;
	--iif-s-1:  8px;
	--iif-s-2:  12px;
	--iif-s-3:  16px;
	--iif-s-4:  24px;
	--iif-s-5:  32px;
	--iif-s-6:  48px;
	--iif-s-7:  64px;
	--iif-s-8:  96px;

	/* Type */
	--iif-font-sans:  'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
	--iif-font-disp:  'Space Grotesk', var(--iif-font-sans);
	--iif-font-mono:  'JetBrains Mono', ui-monospace, 'Consolas', monospace;

	/* Motion */
	--iif-ease:    cubic-bezier(.2, .8, .2, 1);
	--iif-ease-2:  cubic-bezier(.16, 1, .3, 1);
	--iif-d-fast:  120ms;
	--iif-d-base:  240ms;
	--iif-d-slow:  420ms;

	/* Layout */
	--iif-container: 1240px;
	--iif-gutter: clamp(16px, 4vw, 32px);
}

/* Light-mode override (kept simple — site is dark-first) */
@media (prefers-color-scheme: light) {
	:root.iif-prefers-light {
		--iif-bg:        #faf8ff;
		--iif-bg-2:      #f0eaff;
		--iif-bg-3:      #e7defb;
		--iif-surface:   rgba(0,0,0,0.04);
		--iif-surface-2: rgba(0,0,0,0.07);
		--iif-border:    rgba(0,0,0,0.10);
		--iif-border-2:  rgba(0,0,0,0.18);
		--iif-text:      #14082b;
		--iif-text-2:    #4a3a7b;
		--iif-text-3:    #7065a8;
	}
}

/* ============================================================
   Reset + base
   ============================================================ */
*,*::before,*::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
	margin: 0;
	background: var(--iif-bg);
	color: var(--iif-text);
	font-family: var(--iif-font-sans);
	font-size: 16px;
	line-height: 1.55;
	-webkit-font-smoothing: antialiased;
	overflow-x: hidden;
}
img, video, svg { max-width: 100%; height: auto; display: block; }
button { font: inherit; cursor: pointer; }
a { color: var(--iif-text-link); text-decoration: none; }
a:hover { color: var(--iif-accent); }
hr { border: 0; height: 1px; background: var(--iif-border); margin: var(--iif-s-5) 0; }
::selection { background: var(--iif-accent); color: #fff; }

h1, h2, h3, h4, h5 { font-family: var(--iif-font-disp); letter-spacing: -0.02em; line-height: 1.1; margin: 0; }
h1 { font-size: clamp(2rem, 4vw + 1rem, 4rem); font-weight: 700; }
h2 { font-size: clamp(1.6rem, 2vw + 1rem, 2.4rem); font-weight: 700; }
h3 { font-size: 1.25rem; font-weight: 600; }
h4 { font-size: 1.05rem; font-weight: 600; }

p { margin: 0 0 var(--iif-s-3); color: var(--iif-text-2); }

/* ============================================================
   Layout primitives
   ============================================================ */
.iif-container { max-width: var(--iif-container); margin: 0 auto; padding-left: var(--iif-gutter); padding-right: var(--iif-gutter); }
.iif-section { padding: var(--iif-s-7) 0; position: relative; }
.iif-section__head { margin-bottom: var(--iif-s-5); }
.iif-section__head--split { display: flex; align-items: end; justify-content: space-between; gap: var(--iif-s-3); flex-wrap: wrap; }
.iif-section__head h2 { display: flex; align-items: center; gap: var(--iif-s-2); }
.iif-section__head p { color: var(--iif-text-3); margin-top: var(--iif-s-2); max-width: 60ch; }
.iif-section__emoji { display: inline-block; transform: translateY(-2px); filter: drop-shadow(0 0 12px rgba(124,92,255,0.4)); }

.iif-skip { position: absolute; left: -9999px; }
.iif-skip:focus { left: 16px; top: 16px; background: var(--iif-accent); color: #fff; padding: 8px 12px; border-radius: 6px; z-index: 9999; }

.iif-eyebrow {
	display: inline-block;
	padding: 6px 12px;
	background: var(--iif-surface);
	border: 1px solid var(--iif-border);
	border-radius: var(--iif-r-pill);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--iif-text-2);
}

.iif-muted { color: var(--iif-text-3); }

/* ============================================================
   Atmosphere — noise + aurora
   ============================================================ */
.iif-noise {
	position: fixed; inset: 0; z-index: 0; pointer-events: none; opacity: 0.04;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9'/><feColorMatrix type='matrix' values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 .25 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}
.iif-aurora {
	position: fixed; inset: 0; z-index: 0; pointer-events: none; filter: blur(120px); opacity: 0.55;
}
.iif-aurora span {
	position: absolute; width: 50vmin; height: 50vmin; border-radius: 50%;
	mix-blend-mode: screen;
}
.iif-aurora span:nth-child(1) { background: var(--iif-accent);   top: -10%; left: -10%; animation: iif-orb 22s ease-in-out infinite; }
.iif-aurora span:nth-child(2) { background: var(--iif-accent-2); bottom: -15%; right: -10%; animation: iif-orb 28s ease-in-out infinite reverse; }
.iif-aurora span:nth-child(3) { background: var(--iif-accent-3); top: 40%; right: 30%; animation: iif-orb 34s ease-in-out infinite; }
@keyframes iif-orb {
	0%, 100% { transform: translate(0,0) scale(1); }
	50%      { transform: translate(8vw,-6vh) scale(1.15); }
}

@media (prefers-reduced-motion: reduce) {
	.iif-aurora span { animation: none; }
	html { scroll-behavior: auto; }
}

/* ============================================================
   Header
   ============================================================ */
.iif-header {
	position: sticky; top: 0; z-index: 80;
	background: linear-gradient(to bottom, rgba(11,4,24,0.92), rgba(11,4,24,0.65));
	backdrop-filter: var(--iif-glass);
	-webkit-backdrop-filter: var(--iif-glass);
	border-bottom: 1px solid var(--iif-border);
}
.iif-header__inner {
	display: flex; align-items: center; justify-content: space-between; gap: var(--iif-s-3);
	min-height: 64px;
	padding-top: 12px; padding-bottom: 12px;
}
.iif-logo {
	display: inline-flex; align-items: center; gap: 8px;
	font-family: var(--iif-font-disp); font-weight: 700; font-size: 1.15rem; color: var(--iif-text);
	letter-spacing: -0.02em;
}
.iif-logo__mark {
	font-size: 1.7rem; filter: drop-shadow(0 0 16px rgba(124,92,255,0.55));
	transition: transform var(--iif-d-base) var(--iif-ease);
}
.iif-logo:hover .iif-logo__mark { transform: rotate(-15deg) scale(1.1); }
.iif-logo__text em { font-style: normal; background: linear-gradient(135deg, var(--iif-accent), var(--iif-accent-2)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.iif-nav { flex: 1; }
.iif-nav__list { display: flex; gap: var(--iif-s-2); margin: 0; padding: 0; list-style: none; justify-content: center; }
.iif-nav__list a {
	display: inline-block; padding: 8px 14px; border-radius: var(--iif-r-pill);
	color: var(--iif-text-2); font-weight: 500; font-size: 14px;
	transition: background var(--iif-d-fast), color var(--iif-d-fast);
}
.iif-nav__list a:hover, .iif-nav__list .current-menu-item a { background: var(--iif-surface); color: var(--iif-text); }
.iif-header__actions { display: flex; align-items: center; gap: var(--iif-s-2); }
.iif-search-toggle, .iif-surprise {
	width: 40px; height: 40px; border-radius: 50%; border: 1px solid var(--iif-border);
	background: var(--iif-surface); color: var(--iif-text); display: inline-flex; align-items: center; justify-content: center;
	transition: transform var(--iif-d-fast), border-color var(--iif-d-fast);
}
.iif-search-toggle:hover, .iif-surprise:hover { transform: scale(1.06); border-color: var(--iif-accent); }
.iif-surprise { font-size: 18px; }
.iif-avatar { position: relative; display: inline-flex; align-items: center; gap: 8px; }
.iif-avatar img { width: 32px; height: 32px; border-radius: 50%; border: 1px solid var(--iif-border-2); }

/* ============================================================
   Buttons
   ============================================================ */
.iif-btn {
	display: inline-flex; align-items: center; justify-content: center; gap: 8px;
	padding: 11px 18px; border: 1px solid var(--iif-border-2); border-radius: var(--iif-r-pill);
	background: var(--iif-surface); color: var(--iif-text); font-weight: 600;
	text-decoration: none; line-height: 1;
	transition: transform var(--iif-d-fast), background var(--iif-d-fast), border-color var(--iif-d-fast), box-shadow var(--iif-d-fast);
	cursor: pointer;
}
.iif-btn:hover { transform: translateY(-1px); border-color: var(--iif-accent); background: var(--iif-surface-2); }
.iif-btn:active { transform: translateY(0); }
.iif-btn--lg { padding: 14px 22px; font-size: 1.05rem; }
.iif-btn--ghost { background: transparent; }
.iif-btn--primary {
	background: linear-gradient(135deg, var(--iif-accent), var(--iif-accent-2));
	border-color: transparent; color: #fff;
	box-shadow: 0 6px 24px rgba(124,92,255,0.45);
}
.iif-btn--primary:hover { box-shadow: 0 10px 32px rgba(124,92,255,0.6), 0 0 0 1px rgba(255,255,255,0.15) inset; }

/* CTA — affiliate */
.iif-cta {
	display: inline-flex; align-items: center; justify-content: center; gap: 10px;
	padding: 14px 22px; border-radius: var(--iif-r-pill);
	background: linear-gradient(135deg, var(--iif-accent), var(--iif-accent-2));
	color: #fff; font-weight: 700; text-decoration: none; letter-spacing: 0.01em;
	box-shadow: 0 10px 30px rgba(255,61,138,0.35);
	transition: transform var(--iif-d-fast), box-shadow var(--iif-d-fast);
}
.iif-cta:hover { transform: translateY(-2px); box-shadow: 0 14px 40px rgba(255,61,138,0.5); color: #fff; }
.iif-cta--full { width: 100%; }
.iif-cta--lg { padding: 18px 26px; font-size: 1.1rem; }
.iif-cta__arrow { transition: transform var(--iif-d-base); }
.iif-cta:hover .iif-cta__arrow { transform: translateX(4px); }

/* ============================================================
   Glass surfaces
   ============================================================ */
.glass {
	background: var(--iif-surface);
	backdrop-filter: var(--iif-glass);
	-webkit-backdrop-filter: var(--iif-glass);
	border: 1px solid var(--iif-border);
	border-radius: var(--iif-r-lg);
}

/* ============================================================
   Hero
   ============================================================ */
.iif-hero { position: relative; padding: clamp(48px, 8vw, 120px) 0 var(--iif-s-7); overflow: hidden; }
.iif-hero__bg { position: absolute; inset: 0; z-index: 0; pointer-events: none; }
.iif-hero__orb { position: absolute; width: 60vmin; height: 60vmin; border-radius: 50%; filter: blur(120px); opacity: 0.4; }
.iif-hero__orb--a { background: var(--iif-accent);   top: -10%; left: -5%; animation: iif-orb 26s ease-in-out infinite; }
.iif-hero__orb--b { background: var(--iif-accent-2); top: 30%;  right: -10%; animation: iif-orb 30s ease-in-out infinite reverse; }
.iif-hero__orb--c { background: var(--iif-accent-3); bottom: -15%; left: 30%; animation: iif-orb 34s ease-in-out infinite; }

.iif-hero__inner { display: grid; grid-template-columns: 1.3fr 1fr; gap: var(--iif-s-6); position: relative; z-index: 1; align-items: center; }
@media (max-width: 880px) { .iif-hero__inner { grid-template-columns: 1fr; } }

.iif-hero__copy { display: flex; flex-direction: column; gap: var(--iif-s-3); }
.iif-hero__title { font-size: clamp(2.4rem, 5vw, 4.5rem); font-weight: 800; line-height: 1.05; min-height: 1.2em; }
.iif-hero__rotator-item {
	display: inline-block; opacity: 0; transform: translateY(12px);
	background: linear-gradient(135deg, var(--iif-accent), var(--iif-accent-2), var(--iif-accent-3));
	-webkit-background-clip: text; background-clip: text; color: transparent;
	transition: opacity var(--iif-d-slow) var(--iif-ease), transform var(--iif-d-slow) var(--iif-ease);
}
.iif-hero__rotator-item.is-active { opacity: 1; transform: translateY(0); }
.iif-hero__sub { color: var(--iif-text-2); font-size: 1.15rem; max-width: 50ch; }
.iif-hero__cta { display: flex; gap: var(--iif-s-2); flex-wrap: wrap; margin-top: var(--iif-s-2); }
.iif-hero__stats { display: flex; gap: var(--iif-s-4); margin-top: var(--iif-s-4); flex-wrap: wrap; }
.iif-hero__stats div { display: flex; flex-direction: column; }
.iif-hero__stats strong { font-family: var(--iif-font-disp); font-size: 1.6rem; }
.iif-hero__stats span { color: var(--iif-text-3); font-size: 13px; }

.iif-hero__widget {
	position: relative; padding: var(--iif-s-3);
	background: var(--iif-surface); border: 1px solid var(--iif-border-2); border-radius: var(--iif-r-xl);
	backdrop-filter: var(--iif-glass);
	box-shadow: var(--iif-shadow-2);
}
.iif-hero__widget-tabs { display: flex; gap: 4px; padding: 4px; background: var(--iif-surface); border-radius: var(--iif-r-pill); margin-bottom: var(--iif-s-3); }
.iif-hero__widget-tabs button {
	flex: 1; padding: 8px 12px; border: 0; border-radius: var(--iif-r-pill);
	background: transparent; color: var(--iif-text-2); font-weight: 500;
	transition: background var(--iif-d-fast);
}
.iif-hero__widget-tabs button.is-active { background: var(--iif-surface-2); color: var(--iif-text); }

.iif-hero__pick { display: flex; gap: var(--iif-s-2); padding: 12px; border-radius: var(--iif-r-md); color: var(--iif-text); }
.iif-hero__pick:hover { background: var(--iif-surface-2); }
.iif-hero__pick-emoji { font-size: 1.4rem; }
.iif-hero__pick-body { display: flex; flex-direction: column; }
.iif-hero__pick-body small { color: var(--iif-text-3); font-size: 12px; }

.iif-hero__mood { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin: 8px 0; }
.iif-hero__mood button {
	padding: 10px; border-radius: var(--iif-r-md); background: var(--iif-surface); border: 1px solid var(--iif-border);
	color: var(--iif-text);
}
.iif-hero__mood button:hover { border-color: var(--iif-accent); transform: translateY(-1px); }
.iif-hero__widget-q { color: var(--iif-text-2); font-size: 14px; }

.iif-hero__ticker {
	margin-top: var(--iif-s-6);
	overflow: hidden;
	border-block: 1px solid var(--iif-border);
	padding: 14px 0;
	mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
.iif-hero__ticker-track {
	display: flex; gap: 28px; white-space: nowrap;
	animation: iif-marquee 60s linear infinite;
	width: max-content;
}
.iif-hero__ticker-item { color: var(--iif-text-3); font-size: 14px; }
.iif-hero__ticker-item:hover { color: var(--iif-text); }
@keyframes iif-marquee {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); }
}

/* ============================================================
   Today / dashboard
   ============================================================ */
.iif-today__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--iif-s-3); }
@media (max-width: 1024px) { .iif-today__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px)  { .iif-today__grid { grid-template-columns: 1fr; } }
.iif-today__tile { padding: var(--iif-s-4); display: flex; flex-direction: column; gap: 8px; min-height: 160px; }
.iif-today__tile small { color: var(--iif-text-3); text-transform: uppercase; letter-spacing: 0.08em; font-size: 11px; }
.iif-today__big { font-size: 3rem; }
.iif-today__tile ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.iif-today__tile li { display: flex; justify-content: space-between; font-size: 14px; color: var(--iif-text-2); }
.iif-today__tile li em { color: var(--iif-accent-3); font-style: normal; font-weight: 600; font-size: 12px; }
.iif-today__tile--wide { grid-column: span 4; }
@media (max-width: 1024px) { .iif-today__tile--wide { grid-column: span 2; } }
@media (max-width: 560px)  { .iif-today__tile--wide { grid-column: 1; } }
.iif-today__meter { display: flex; flex-direction: column; gap: 8px; }
.iif-today__meter span {
	position: relative; padding: 6px 12px; background: var(--iif-surface-2); border-radius: var(--iif-r-pill); font-size: 14px;
	overflow: hidden;
}
.iif-today__meter span::before {
	content: ''; position: absolute; inset: 0; width: var(--p, 0%); background: linear-gradient(135deg, var(--iif-accent), var(--iif-accent-2));
	opacity: 0.35;
}
.iif-today__trend.up  { color: var(--iif-accent-3); font-size: 12px; }
.iif-today__trend.down { color: var(--iif-accent-2); font-size: 12px; }

/* ============================================================
   Grids + cards
   ============================================================ */
.iif-grid { display: grid; gap: var(--iif-s-3); }
.iif-grid--cards { grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); }
.iif-grid--featured { grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); }
.iif-grid--wide { grid-template-columns: repeat(auto-fill, minmax(360px, 1fr)); }
.iif-grid--products { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }

.iif-card {
	position: relative;
	display: flex; flex-direction: column;
	overflow: hidden;
	background: var(--iif-surface);
	border: 1px solid var(--iif-border);
	border-radius: var(--iif-r-lg);
	color: var(--iif-text); text-decoration: none;
	transition: transform var(--iif-d-base) var(--iif-ease), border-color var(--iif-d-base), box-shadow var(--iif-d-base);
	min-height: 220px;
	isolation: isolate;
}
.iif-card:hover {
	transform: translateY(-4px);
	border-color: var(--iif-accent);
	box-shadow: 0 20px 50px rgba(0,0,0,0.4), 0 0 0 1px rgba(124,92,255,0.5) inset;
	color: var(--iif-text);
}
.iif-card__media { position: relative; aspect-ratio: 16/9; overflow: hidden; }
.iif-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--iif-d-slow) var(--iif-ease); }
.iif-card:hover .iif-card__media img { transform: scale(1.06); }
.iif-card__gradient {
	width: 100%; height: 100%; display: grid; place-items: center;
	background: linear-gradient(135deg, color-mix(in oklab, var(--iif-accent) 70%, var(--iif-bg)), color-mix(in oklab, var(--iif-accent-2) 70%, var(--iif-bg)));
}
.iif-card__emoji { font-size: clamp(3rem, 6vw, 5rem); filter: drop-shadow(0 0 20px rgba(255,255,255,0.4)); }

.iif-card__body { padding: var(--iif-s-3); display: flex; flex-direction: column; gap: 8px; }
.iif-card__type { color: var(--iif-text-3); font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; }
.iif-card__title { font-size: 1.1rem; line-height: 1.25; }
.iif-card__tagline { color: var(--iif-text-2); font-size: 14px; margin: 0; }
.iif-card__meta { margin-top: auto; display: flex; gap: 12px; align-items: center; padding-top: 8px; color: var(--iif-text-3); font-size: 12px; }
.iif-card__arrow { margin-left: auto; transition: transform var(--iif-d-base); }
.iif-card:hover .iif-card__arrow { transform: translateX(4px); color: var(--iif-accent); }

.iif-card__badge {
	position: absolute; top: 12px; left: 12px; z-index: 2;
	padding: 5px 10px; border-radius: var(--iif-r-pill);
	background: rgba(0,0,0,0.55); backdrop-filter: blur(8px);
	color: #fff; font-size: 11px; font-weight: 600;
	border: 1px solid rgba(255,255,255,0.15);
}
.iif-card__badge--trending { background: linear-gradient(135deg, var(--iif-accent-2), var(--iif-accent)); }

.iif-card--featured { min-height: 280px; }
.iif-card--featured .iif-card__media { aspect-ratio: 4/3; }
.iif-card--wide { flex-direction: row; min-height: 160px; }
.iif-card--wide .iif-card__media { width: 40%; aspect-ratio: auto; }
.iif-card--wide .iif-card__body  { flex: 1; }

/* ============================================================
   Product card
   ============================================================ */
.iif-prod-card {
	display: flex; flex-direction: column; gap: 12px; padding: 16px;
	background: var(--iif-surface); border: 1px solid var(--iif-border); border-radius: var(--iif-r-lg);
	transition: transform var(--iif-d-base), border-color var(--iif-d-base);
}
.iif-prod-card:hover { transform: translateY(-3px); border-color: var(--iif-accent); }
.iif-prod-card__link { color: inherit; text-decoration: none; display: contents; }
.iif-prod-card__media { position: relative; aspect-ratio: 1; border-radius: var(--iif-r-md); overflow: hidden; background: var(--iif-bg-2); }
.iif-prod-card__media img { width: 100%; height: 100%; object-fit: cover; }
.iif-prod-card__badge {
	position: absolute; top: 10px; left: 10px;
	padding: 5px 10px; border-radius: var(--iif-r-pill);
	background: var(--badge, var(--iif-accent)); color: #fff; font-size: 11px; font-weight: 700;
}
.iif-prod-card__body { display: flex; flex-direction: column; gap: 4px; }
.iif-prod-card__title { font-size: 1.05rem; }
.iif-prod-card__tag { color: var(--iif-text-3); font-size: 13px; margin: 0; }
.iif-prod-card__meta { display: flex; justify-content: space-between; align-items: center; margin-top: 8px; }
.iif-prod-card__price { font-family: var(--iif-font-mono); font-weight: 600; color: var(--iif-accent-3); }

.iif-rating { position: relative; display: inline-flex; align-items: center; gap: 6px; }
.iif-rating__bar { display: inline-block; width: 80px; height: 8px; background: var(--iif-surface-2); border-radius: 4px; position: relative; overflow: hidden; }
.iif-rating__bar::before {
	content: ''; position: absolute; inset: 0 auto 0 0; width: var(--rating, 0%);
	background: linear-gradient(90deg, var(--iif-accent), var(--iif-accent-2));
}
.iif-rating small { color: var(--iif-text-3); font-size: 12px; }

/* ============================================================
   Article / single
   ============================================================ */
.iif-page { padding-block: var(--iif-s-5) var(--iif-s-8); }
.iif-article { max-width: 920px; margin: 0 auto; }
.iif-article__head { margin-bottom: var(--iif-s-5); display: flex; flex-direction: column; gap: var(--iif-s-2); }
.iif-article__lede { color: var(--iif-text-2); font-size: 1.15rem; max-width: 60ch; }
.iif-article__meta { color: var(--iif-text-3); font-size: 13px; }
.iif-article__hero { border-radius: var(--iif-r-lg); overflow: hidden; margin-bottom: var(--iif-s-4); }
.iif-article__content { font-size: 1.05rem; line-height: 1.7; color: var(--iif-text); }
.iif-article__content h2 { margin-top: var(--iif-s-5); margin-bottom: var(--iif-s-3); }
.iif-article__content h3 { margin-top: var(--iif-s-4); margin-bottom: var(--iif-s-2); }
.iif-article__content ul, .iif-article__content ol { margin: 0 0 var(--iif-s-3) 1.25em; }
.iif-article__content a { border-bottom: 1px solid color-mix(in oklab, var(--iif-text-link) 50%, transparent); }
.iif-article__content blockquote {
	margin: var(--iif-s-4) 0;
	padding: var(--iif-s-3) var(--iif-s-4);
	border-left: 3px solid var(--iif-accent);
	background: var(--iif-surface);
	border-radius: 0 var(--iif-r-md) var(--iif-r-md) 0;
	color: var(--iif-text);
}
.iif-article__related { margin-top: var(--iif-s-7); }

/* Breadcrumbs */
.iif-breadcrumbs { margin-bottom: var(--iif-s-3); font-size: 13px; }
.iif-breadcrumbs ol { list-style: none; margin: 0; padding: 0; display: flex; gap: 8px; flex-wrap: wrap; color: var(--iif-text-3); }
.iif-breadcrumbs li + li::before { content: '/'; margin-right: 8px; color: var(--iif-text-3); }
.iif-breadcrumbs a { color: var(--iif-text-2); }

/* Share row */
.iif-share-row { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; padding: 12px 0; }
.iif-share-row small { color: var(--iif-text-3); margin-right: 4px; }
.iif-share {
	width: 36px; height: 36px; border-radius: 50%;
	background: var(--iif-surface); border: 1px solid var(--iif-border); color: var(--iif-text);
	display: inline-flex; align-items: center; justify-content: center; font-size: 16px;
	transition: transform var(--iif-d-fast), background var(--iif-d-fast);
}
.iif-share:hover { transform: scale(1.08); background: var(--iif-surface-2); color: var(--iif-text); }

/* Disclosure */
.iif-disclosure {
	display: flex; gap: 10px; align-items: flex-start;
	padding: 12px 16px;
	background: var(--iif-surface); border: 1px solid var(--iif-border); border-radius: var(--iif-r-md);
	font-size: 13px; color: var(--iif-text-3); margin-block: var(--iif-s-3);
}
.iif-disclosure__icon { color: var(--iif-accent); font-weight: 700; }

/* ============================================================
   Footer
   ============================================================ */
.iif-footer { padding: var(--iif-s-7) 0 var(--iif-s-4); border-top: 1px solid var(--iif-border); margin-top: var(--iif-s-8); position: relative; z-index: 1; background: linear-gradient(to top, var(--iif-bg-2), transparent); }
.iif-footer__top { display: grid; grid-template-columns: 1fr 2fr; gap: var(--iif-s-6); }
@media (max-width: 880px) { .iif-footer__top { grid-template-columns: 1fr; } }
.iif-footer__brand p { color: var(--iif-text-3); max-width: 38ch; }
.iif-socials { display: flex; gap: 8px; margin-top: var(--iif-s-2); }
.iif-socials a {
	width: 38px; height: 38px; border-radius: 50%; background: var(--iif-surface);
	display: inline-flex; align-items: center; justify-content: center; color: var(--iif-text);
}
.iif-footer__cols { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--iif-s-4); }
@media (max-width: 600px) { .iif-footer__cols { grid-template-columns: repeat(2, 1fr); } }
.iif-footer__cols h4 { color: var(--iif-text); margin-bottom: 12px; font-size: 13px; text-transform: uppercase; letter-spacing: 0.1em; }
.iif-footer__cols ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.iif-footer__cols a { color: var(--iif-text-3); font-size: 14px; }
.iif-footer__cols a:hover { color: var(--iif-text); }
.iif-footer__bottom { display: flex; justify-content: space-between; gap: var(--iif-s-3); padding-top: var(--iif-s-5); border-top: 1px solid var(--iif-border); margin-top: var(--iif-s-5); color: var(--iif-text-3); font-size: 12px; flex-wrap: wrap; }

/* ============================================================
   Search overlay
   ============================================================ */
.iif-search-overlay {
	position: fixed; inset: 0; z-index: 100;
	background: rgba(11,4,24,0.85); backdrop-filter: blur(12px);
	display: grid; place-items: start center; padding-top: 12vh;
	animation: iif-fade-in var(--iif-d-base) var(--iif-ease);
}
/* HTML [hidden] attribute must beat the display rule above. */
.iif-search-overlay[hidden] { display: none !important; }
.iif-search-overlay__inner { width: min(720px, 90vw); position: relative; }
.iif-search-overlay__input {
	width: 100%; padding: 22px 56px 22px 24px; font-size: 1.4rem;
	background: var(--iif-surface); color: var(--iif-text); border: 1px solid var(--iif-border-2);
	border-radius: var(--iif-r-xl); outline: none;
	box-shadow: var(--iif-shadow-2);
}
.iif-search-overlay__input:focus { border-color: var(--iif-accent); }
.iif-search-overlay__close {
	position: absolute; top: 14px; right: 16px; width: 40px; height: 40px;
	background: transparent; color: var(--iif-text); border: 0; font-size: 28px; line-height: 1;
}
.iif-search-overlay__results { margin-top: var(--iif-s-3); display: flex; flex-direction: column; gap: 4px; }
.iif-search-overlay__results a {
	display: flex; gap: 12px; padding: 12px 16px; border-radius: var(--iif-r-md);
	color: var(--iif-text); background: var(--iif-surface); align-items: center;
}
.iif-search-overlay__results a:hover { background: var(--iif-surface-2); }
.iif-search-overlay__results small { color: var(--iif-text-3); }
.iif-search-overlay__suggestions { display: flex; gap: 8px; flex-wrap: wrap; margin-top: var(--iif-s-3); color: var(--iif-text-3); align-items: center; }
.iif-chip {
	padding: 6px 12px; border-radius: var(--iif-r-pill); background: var(--iif-surface);
	border: 1px solid var(--iif-border); color: var(--iif-text-2); font-size: 13px;
}
.iif-chip:hover { color: var(--iif-text); border-color: var(--iif-accent); }
@keyframes iif-fade-in { from { opacity: 0; } to { opacity: 1; } }

/* ============================================================
   Floating CTA + mobile bar
   ============================================================ */
.iif-floating-cta { position: fixed; bottom: 96px; right: 24px; z-index: 60; max-width: 320px; }
.iif-floating-cta[hidden] { display: none !important; }
.iif-floating-cta__inner {
	display: flex; gap: 10px; align-items: center; padding: 12px 16px;
	border: 1px solid var(--iif-border-2);
	box-shadow: var(--iif-shadow-2);
	animation: iif-slide-up var(--iif-d-slow) var(--iif-ease);
}
.iif-floating-cta__emoji { font-size: 1.6rem; }
.iif-floating-cta__body strong { display: block; line-height: 1.1; }
.iif-floating-cta__body small { color: var(--iif-text-3); font-size: 12px; }
.iif-floating-cta__close { background: transparent; border: 0; color: var(--iif-text-3); font-size: 20px; }
@keyframes iif-slide-up { from { transform: translateY(20px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }

.iif-mobile-bar {
	display: none;
	position: fixed; bottom: 0; left: 0; right: 0; z-index: 70;
	background: rgba(11,4,24,0.85); backdrop-filter: blur(20px);
	border-top: 1px solid var(--iif-border);
	padding: 8px env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);
	justify-content: space-around; align-items: center;
}
.iif-mobile-bar__item {
	display: flex; flex-direction: column; align-items: center; gap: 2px;
	color: var(--iif-text-2); text-decoration: none; background: transparent; border: 0;
	padding: 8px 12px; font-size: 11px;
}
.iif-mobile-bar__item span { font-size: 22px; }
.iif-mobile-bar__item--center { transform: translateY(-12px); }
.iif-mobile-bar__big {
	width: 56px; height: 56px; display: grid; place-items: center;
	background: linear-gradient(135deg, var(--iif-accent), var(--iif-accent-2));
	border-radius: 50%; box-shadow: 0 12px 30px rgba(255,61,138,0.4);
	font-size: 26px !important;
}

/* ============================================================
   Archive head + filters
   ============================================================ */
.iif-archive-head { margin-bottom: var(--iif-s-5); }
.iif-archive-head h1 { margin-bottom: var(--iif-s-2); }
.iif-archive-filters { margin-top: var(--iif-s-3); }
.iif-archive-filters input[type="search"] {
	padding: 12px 18px; background: var(--iif-surface); border: 1px solid var(--iif-border); border-radius: var(--iif-r-pill);
	color: var(--iif-text); min-width: 280px;
}

/* ============================================================
   404
   ============================================================ */
.iif-404 { text-align: center; }
.iif-404__inner { padding: var(--iif-s-7) 0; }
.iif-404__emoji { font-size: 6rem; margin-bottom: var(--iif-s-3); animation: iif-float 4s ease-in-out infinite; }
@keyframes iif-float { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }

/* ============================================================
   Spinner
   ============================================================ */
.iif-spinner {
	width: 18px; height: 18px; border-radius: 50%;
	border: 2px solid var(--iif-border); border-top-color: var(--iif-accent);
	display: inline-block; animation: iif-spin 600ms linear infinite;
}
@keyframes iif-spin { to { transform: rotate(360deg); } }
.iif-feed__sentinel { display: flex; gap: 10px; align-items: center; justify-content: center; padding: var(--iif-s-5); color: var(--iif-text-3); }

/* Pagination */
.pagination, .nav-links { display: flex; gap: 4px; justify-content: center; margin-top: var(--iif-s-5); flex-wrap: wrap; }
.pagination a, .nav-links a, .pagination .current, .nav-links .current {
	padding: 8px 14px; border-radius: var(--iif-r-pill); background: var(--iif-surface); color: var(--iif-text); text-decoration: none; border: 1px solid var(--iif-border);
}
.pagination .current, .nav-links .current { background: var(--iif-accent); color: #fff; border-color: transparent; }

/* Newsletter */
.iif-newsletter__card { display: grid; grid-template-columns: 1.5fr 1fr; padding: var(--iif-s-6); align-items: center; gap: var(--iif-s-4); overflow: hidden; position: relative; }
@media (max-width: 760px) { .iif-newsletter__card { grid-template-columns: 1fr; } }
.iif-newsletter__form { display: flex; gap: 8px; margin-top: var(--iif-s-3); align-items: center; flex-wrap: wrap; }
.iif-newsletter__form input { padding: 14px 18px; background: var(--iif-surface-2); border: 1px solid var(--iif-border-2); border-radius: var(--iif-r-pill); color: var(--iif-text); min-width: 240px; flex: 1; }
.iif-newsletter__form small { color: var(--iif-text-3); display: block; width: 100%; }
.iif-newsletter__viz { position: relative; height: 200px; display: grid; place-items: center; }
.iif-newsletter__emoji { font-size: 6rem; filter: drop-shadow(0 0 40px rgba(124,92,255,0.5)); animation: iif-float 5s ease-in-out infinite; }
.iif-newsletter__sparkle { position: absolute; color: var(--iif-accent-3); font-size: 1.2rem; opacity: 0.8; animation: iif-twinkle 3s ease-in-out infinite; }
.iif-newsletter__sparkle:nth-child(2) { top: 20%; left: 20%; }
.iif-newsletter__sparkle:nth-child(3) { top: 60%; right: 20%; animation-delay: 1s; }
.iif-newsletter__sparkle:nth-child(4) { bottom: 20%; left: 50%; animation-delay: 2s; }
@keyframes iif-twinkle { 0%,100% { transform: scale(1); opacity: 0.8; } 50% { transform: scale(1.4); opacity: 1; } }

/* Hover lift utility */
.iif-lift { transition: transform var(--iif-d-base) var(--iif-ease); }
.iif-lift:hover { transform: translateY(-4px); }

/* Viral badge */
.viral-badge { display: inline-flex; gap: 4px; align-items: center; padding: 4px 10px; background: var(--iif-surface); border-radius: var(--iif-r-pill); font-weight: 600; font-size: 12px; }

/* Level / user */
.iif-level { display: inline-flex; flex-direction: column; gap: 3px; }
.iif-level__name { font-size: 11px; color: var(--iif-text-3); }
.iif-level__bar { width: 80px; height: 4px; background: var(--iif-surface); border-radius: 2px; overflow: hidden; }
.iif-level__bar span { display: block; height: 100%; background: linear-gradient(90deg, var(--iif-accent), var(--iif-accent-3)); border-radius: 2px; }
