/* ────────────────────────────────────────────────────────────
   SQUIZITO · Italian crafted streetwear · Art-Fashion esclusivo
   Stylesheet — MMXXVI
   ──────────────────────────────────────────────────────────── */

:root {
	/* palette — acid lime is the canvas; ink, paper, cream are the contrast */
	--acid    : #CBF224;   /* core brand color · body background */
	--acid-d  : #A8CC15;
	--acid-l  : #DAFA4D;
	--paper   : #F4EFE6;
	--cream   : #ECE5D7;
	--cream-2 : #DDD2BB;
	--bone    : #C8BBA0;
	--ink     : #0E0D0A;
	--ink-2   : #1F1D17;
	--smoke   : #5C5945;
	--rosso   : #E84A1A;

	/* typography — Montserrat + JetBrains Mono (per Auro reference) */
	--f-sans    : "Montserrat", system-ui, sans-serif;
	--f-display : "Montserrat", system-ui, sans-serif;
	--f-mono    : "JetBrains Mono", ui-monospace, monospace;

	/* metrics */
	--frame   : 24px;
	--nav-h   : 78px;
	--rule    : 1px solid var(--ink);
}

/* ─── RESET ──────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
	font-family: var(--f-sans);
	font-weight: 400;
	color: var(--ink);
	background: var(--acid);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-variant-ligatures: contextual;
	overflow-x: hidden;
	cursor: none;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; border: none; background: transparent; color: inherit; cursor: none; padding: 0; }
ol, ul { list-style: none; margin: 0; padding: 0; }
h1, h2, h3, h4, p { margin: 0; }
input { font: inherit; }

.sr-only {
	position: absolute; width: 1px; height: 1px; padding: 0;
	margin: -1px; overflow: hidden; clip: rect(0,0,0,0);
	white-space: nowrap; border: 0;
}

/* helpers */
.display { font-family: var(--f-display); font-weight: 900; text-transform: uppercase; letter-spacing: -0.02em; }
.mono    { font-family: var(--f-mono); font-weight: 400; letter-spacing: 0.04em; text-transform: uppercase; }
.small   { font-size: 11px; }
/* legacy aliases used in markup — neutralise italic, force display sans */
.serif  { font-family: var(--f-display); font-weight: 800; font-style: normal; text-transform: uppercase; letter-spacing: -0.02em; }
.italic { font-style: normal; }


/* ─── GRAIN OVERLAY ──────────────────────────────────────── */
.grain {
	position: fixed; inset: 0;
	pointer-events: none;
	z-index: 9000;
	opacity: 0.22;
	mix-blend-mode: multiply;
	background-image: url("data:image/svg+xml;utf8,<svg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.06  0 0 0 0 0.06  0 0 0 0 0.05  0 0 0 0.45 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
	background-size: 220px 220px;
}

/* ─── EDGE FRAME (fixed corner ticks) ────────────────────── */
.edge-frame {
	position: fixed; inset: 0;
	pointer-events: none;
	z-index: 50;
}
.edge {
	position: absolute;
	font-family: var(--f-mono);
	font-size: 10px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--ink);
	opacity: 0.7;
}
.edge-tl { top: var(--frame); left: var(--frame); }
.edge-tr { top: var(--frame); right: var(--frame); }
.edge-bl { bottom: var(--frame); left: var(--frame); }
.edge-br { bottom: var(--frame); right: var(--frame); }


/* ─── LOADER ─────────────────────────────────────────────── */
.loader {
	position: fixed; inset: 0;
	z-index: 9999;
	background: var(--acid);
	color: var(--ink);
	display: flex; align-items: center; justify-content: center;
	flex-direction: column;
	gap: 32px;
	transition: opacity .8s ease, visibility .8s ease;
}
.loader-svg { color: var(--ink); }
.loader-svg > circle:first-of-type { stroke-opacity: 0.18; }
.loader-arc { stroke: var(--ink) !important; }
.loader-foot { color: var(--ink); }
.loader-num { color: var(--ink); opacity: 0.65; }
.loader-inner {
	position: relative;
	width: 160px; height: 160px;
	display: flex; align-items: center; justify-content: center;
}
.loader-svg { width: 100%; height: 100%; color: var(--ink); }
.loader-arc { animation: arc 1.8s ease forwards; transform: rotate(-90deg); transform-origin: center; }
@keyframes arc { to { stroke-dashoffset: 0; } }
.loader-mark {
	position: absolute;
	font-family: var(--f-display);
	font-style: normal;
	font-weight: 900;
	font-size: 38px;
	letter-spacing: -0.04em;
	text-transform: lowercase;
	color: var(--paper);
}
.loader-pittogramma {
	position: absolute;
	width: 64px; height: 64px;
	object-fit: contain;
}
.loader-foot {
	display: flex; gap: 16px; align-items: center;
	font-family: var(--f-mono); font-size: 11px;
	letter-spacing: 0.12em; text-transform: uppercase;
}
.loader-num { color: var(--smoke); }
body.is-loaded .loader { opacity: 0; visibility: hidden; }


/* ─── CUSTOM CURSOR ──────────────────────────────────────── */
.cursor {
	position: fixed; top: 0; left: 0;
	pointer-events: none;
	z-index: 10000;
	will-change: transform;
}
.cursor-ring {
	width: 38px; height: 38px;
	border: 1px solid var(--ink);
	border-radius: 50%;
	transform: translate(-50%, -50%);
	transition: width .25s ease, height .25s ease, background-color .25s ease, border-color .25s ease;
}
.cursor-dot {
	width: 4px; height: 4px;
	background: var(--ink);
	border-radius: 50%;
	transform: translate(-50%, -50%);
}
.cursor-ring.is-hover {
	width: 64px; height: 64px;
	background: var(--ink);
	border-color: var(--ink);
}
.cursor-ring.is-view {
	width: 96px; height: 96px;
	background: var(--paper);
	border-color: var(--ink);
}
.cursor-ring.is-view::after {
	content: "VIEW";
	position: absolute; inset: 0;
	display: flex; align-items: center; justify-content: center;
	color: var(--ink);
	font-family: var(--f-mono); font-size: 10px;
	letter-spacing: 0.16em;
}
@media (hover: none), (pointer: coarse) {
	body { cursor: auto; }
	button, a, input { cursor: pointer; }
	.cursor { display: none; }
}


/* ─── NAVIGATION ─────────────────────────────────────────── */
.nav {
	position: fixed; top: 0; left: 0; right: 0;
	z-index: 200;
	padding: 18px var(--frame);
	transition: padding .3s ease, background-color .3s ease;
}
.nav-inner {
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: 32px;
	padding: 8px 22px;
	border: var(--rule);
	background: rgba(14,13,10,0.92);
	color: var(--paper);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	border-radius: 999px;
}
.nav-inner * { color: inherit; }
.nav-inner .nav-links a span { color: var(--acid); }
.nav-inner .nav-lang span:not(.is-active) { color: var(--bone); }
.nav-inner .nav-lang span.is-active { color: var(--acid); }
.nav-links a::after { background: var(--acid); }
body.is-scrolled .nav { padding-top: 12px; padding-bottom: 12px; }
body.is-scrolled .nav-inner { background: rgba(14,13,10,0.98); }

.nav-logo {
	display: inline-flex; align-items: center;
	gap: 4px;
	font-family: var(--f-display);
	font-weight: 800;
	font-size: 18px;
	letter-spacing: -0.02em;
	line-height: 1;
	text-transform: lowercase;
}
.nav-logo-img { height: 22px; width: auto; display: block; }
.nav-logo-mark { display: inline-block; }
.nav-logo-sup { font-size: 9px; margin-left: 4px; margin-top: 2px; font-family: var(--f-mono); font-weight: 400; }

.nav-links {
	display: flex; justify-content: center; align-items: center;
	gap: 28px;
}
.nav-links a {
	font-family: var(--f-sans);
	font-weight: 500;
	font-size: 13px;
	letter-spacing: 0.02em;
	display: inline-flex; align-items: baseline; gap: 6px;
	position: relative;
	padding: 4px 0;
}
.nav-links a span {
	font-family: var(--f-mono); font-size: 9px;
	color: var(--smoke); font-weight: 400;
}
.nav-links a::after {
	content: ""; position: absolute; left: 0; right: 0; bottom: -2px;
	height: 1px; background: var(--ink);
	transform: scaleX(0); transform-origin: right center;
	transition: transform .35s cubic-bezier(.65,0,.35,1);
}
.nav-links a:hover::after { transform: scaleX(1); transform-origin: left center; }
.nav-links a.is-current { color: var(--acid); }
.nav-links a.is-current::after { transform: scaleX(1); background: var(--acid); }

.nav-utility {
	display: inline-flex; align-items: center; gap: 18px;
	font-family: var(--f-mono); font-size: 11px;
	letter-spacing: 0.08em; text-transform: uppercase;
}
.nav-lang span.is-active { color: var(--ink); font-weight: 700; }
.nav-lang span:not(.is-active) { color: var(--smoke); }
.nav-vora {
	display: inline-flex; align-items: center; gap: 4px;
	padding: 8px 14px;
	border: 1px solid rgba(244,239,230,0.4);
	border-radius: 999px;
	font-family: var(--f-mono); font-size: 11px;
	letter-spacing: 0.08em; text-transform: uppercase;
	color: var(--paper) !important;
	transition: background-color .3s ease, color .3s ease, border-color .3s ease;
}
.nav-vora-arrow { font-size: 13px; transition: transform .3s ease; }
.nav-vora:hover { background: var(--paper); color: var(--ink) !important; border-color: var(--paper); }
.nav-vora:hover .nav-vora-arrow { transform: translate(2px,-2px); }

.nav-bag {
	display: inline-flex; align-items: baseline; gap: 4px;
	padding: 8px 14px;
	border: 1px solid var(--acid);
	border-radius: 999px;
	background: var(--acid);
	color: var(--ink) !important;
	transition: background-color .3s ease, color .3s ease, border-color .3s ease;
}
.nav-bag em { font-style: normal; color: var(--ink); }
.nav-bag:hover { background: var(--paper); border-color: var(--paper); }


/* ─── HERO ───────────────────────────────────────────────── */
.content { padding-top: calc(var(--nav-h) + 14px); }

.hero {
	padding: 56px var(--frame) 80px;
	position: relative;
	min-height: 92vh;
}
.hero-grid {
	display: grid;
	grid-template-columns: 220px 1fr 320px;
	grid-template-rows: auto 1fr auto;
	gap: 40px 48px;
	align-items: start;
}
.hero-meta { grid-column: 1; grid-row: 1 / span 2; padding-top: 6px; }
.hero-meta .mono { line-height: 1.7; color: var(--ink-2); }
.hero-meta-token { color: var(--ink); font-weight: 700; }
.hero-lat { margin-top: 32px; padding-top: 16px; border-top: var(--rule); }
.dot { display: inline-block; width: 8px; height: 8px; background: var(--ink); border-radius: 50%; margin-right: 6px; animation: pulse 2s ease-in-out infinite; }
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.3; } }

.hero-title {
	grid-column: 2;
	grid-row: 1 / span 2;
	font-family: var(--f-display);
	font-weight: 900;
	font-size: clamp(56px, 10.5vw, 176px);
	line-height: 0.88;
	letter-spacing: -0.035em;
	text-transform: uppercase;
	color: var(--ink);
	align-self: center;
}
.hero-title .line { display: block; }
.hero-title .line-2 { text-align: right; margin-top: 0.04em; }
.hero-title em.italic { font-style: normal; font-weight: 400; letter-spacing: -0.025em; }
.hero-title .hl {
	display: inline-block;
	background: var(--ink);
	color: var(--acid);
	padding: 0.02em 0.16em 0.06em;
}
.hero-title .line-2 .hl { background: var(--paper); color: var(--ink); }
.hero-title .outline {
	-webkit-text-stroke: 2px var(--ink);
	color: transparent;
	font-weight: 900;
}

.hero-side { grid-column: 3; grid-row: 1 / span 2; align-self: center; }
.hero-tile {
	margin: 0;
	border: var(--rule);
	padding: 12px;
	background: var(--paper);
	transform: rotate(2.4deg);
	transition: transform .6s cubic-bezier(.2,.8,.2,1);
	box-shadow: 8px 8px 0 var(--ink);
}
.hero-tile:hover { transform: rotate(-1deg) scale(1.03); }
.hero-tile-img {
	aspect-ratio: 3 / 4;
	background-size: cover;
	background-position: center;
	filter: contrast(1.05) saturate(0.85);
}
.hero-tile figcaption {
	margin-top: 10px;
	font-size: 10px;
	color: var(--ink-2);
	line-height: 1.5;
}

.hero-foot {
	grid-column: 1 / -1;
	grid-row: 3;
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: end;
	padding-top: 48px;
	border-top: var(--rule);
	color: var(--ink-2);
}
.hero-foot p:nth-child(2) { text-align: center; }
.hero-foot p:nth-child(3) { text-align: right; }
.hero-foot .num { font-size: 22px; font-family: var(--f-mono); font-weight: 500; color: var(--ink); letter-spacing: 0.04em; text-transform: uppercase; }


/* ─── EDITORIAL PILLARS ──────────────────────────────────── */
.editorial {
	background: var(--ink);
	color: var(--paper);
	border-top: var(--rule);
	border-bottom: var(--rule);
	padding: 56px var(--frame) 64px;
	position: relative;
}
.ed-head, .ed-foot {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: 24px;
	color: var(--bone);
	padding-bottom: 14px;
}
.ed-head { border-bottom: 1px solid rgba(244,239,230,0.18); margin-bottom: 0; }
.ed-foot {
	padding-top: 24px;
	border-top: 1px solid rgba(244,239,230,0.18);
	margin-top: 0;
}
.ed-head-r { color: var(--smoke); }
.ed-divider { color: var(--acid); font-size: 12px; }

.ed-row {
	display: grid;
	grid-template-columns: 56px 1fr auto;
	align-items: baseline;
	gap: 24px;
	padding: 22px 0;
	border-bottom: 1px solid rgba(244,239,230,0.16);
}
.ed-row:last-of-type { border-bottom: none; }

.ed-row-a .ed-rank   { grid-column: 1; text-align: left; }
.ed-row-a .ed-h      { grid-column: 2; text-align: left; }
.ed-row-a .ed-tag    { grid-column: 3; text-align: right; }

.ed-row-b .ed-tag    { grid-column: 1 / span 1; text-align: left; }
.ed-row-b .ed-h      { grid-column: 2; text-align: right; }
.ed-row-b .ed-rank   { grid-column: 3; text-align: right; }
.ed-row-b            { grid-template-columns: auto 1fr 56px; }

.ed-rank {
	color: var(--acid);
	font-size: 13px;
	letter-spacing: 0.06em;
	font-weight: 500;
	align-self: center;
}
.ed-tag {
	color: var(--bone);
	max-width: 38ch;
	line-height: 1.55;
	align-self: center;
}

.ed-h {
	font-family: var(--f-display);
	font-weight: 900;
	font-size: clamp(56px, 11vw, 180px);
	line-height: 0.86;
	letter-spacing: -0.05em;
	text-transform: lowercase;
	color: var(--paper);
	margin: 0;
}
.ed-h-big { font-size: clamp(64px, 13vw, 220px); }

.ed-row-acid .ed-h {
	color: var(--acid);
	-webkit-text-stroke: 0;
}
.ed-row-acid {
	background: linear-gradient(90deg, transparent 0%, rgba(203,242,36,0.06) 50%, transparent 100%);
}

@media (max-width: 1100px) {
	.ed-row, .ed-row-b { grid-template-columns: 44px 1fr; gap: 12px; padding: 18px 0; }
	.ed-row-a .ed-rank { grid-column: 1; grid-row: 1; }
	.ed-row-a .ed-h    { grid-column: 2; grid-row: 1; text-align: left; }
	.ed-row-a .ed-tag  { grid-column: 1 / -1; grid-row: 2; text-align: left; padding-left: 0; }
	.ed-row-b .ed-rank { grid-column: 1; grid-row: 1; text-align: left; }
	.ed-row-b .ed-h    { grid-column: 2; grid-row: 1; text-align: left; }
	.ed-row-b .ed-tag  { grid-column: 1 / -1; grid-row: 2; text-align: left; }
	.ed-h { font-size: clamp(48px, 14vw, 96px); }
	.ed-h-big { font-size: clamp(56px, 16vw, 112px); }
	.ed-head, .ed-foot { flex-wrap: wrap; }
}


/* ─── MANIFESTO ──────────────────────────────────────────── */
.manifesto { padding: 140px var(--frame); position: relative; }
.manifesto-grid {
	display: grid;
	grid-template-columns: 1fr 320px;
	gap: 80px 48px;
	max-width: 1400px;
	margin: 0 auto;
}
.manifesto-eyebrow { grid-column: 1 / -1; }
.manifesto-eyebrow .mono { color: var(--smoke); }
.manifesto-text {
	font-family: var(--f-display);
	font-weight: 800;
	font-size: clamp(28px, 4vw, 60px);
	line-height: 1.04;
	letter-spacing: -0.025em;
	text-transform: uppercase;
	color: var(--ink);
}
.manifesto-text em.italic { font-style: normal; font-weight: 400; }
.manifesto-text .strike { text-decoration: line-through; text-decoration-thickness: 2px; color: var(--smoke); }
.manifesto-text .hl {
	background: var(--ink); color: var(--acid);
	padding: 0 0.16em 0.04em;
	display: inline-block;
}
.manifesto-text .underline {
	background-image: linear-gradient(var(--ink), var(--ink));
	background-position: 0 92%;
	background-repeat: no-repeat;
	background-size: 100% 3px;
}

.manifesto-card {
	border: var(--rule);
	background: var(--paper);
	padding: 28px 24px;
	align-self: end;
	position: relative;
	min-height: 280px;
	display: flex; flex-direction: column;
	box-shadow: 10px 10px 0 var(--ink);
}
.manifesto-card .label { color: var(--smoke); }
.manifesto-card .signature {
	font-family: var(--f-display);
	font-weight: 900;
	font-size: 28px;
	line-height: 1;
	letter-spacing: -0.03em;
	text-transform: lowercase;
	margin-top: 8px;
}
.manifesto-card .mono.small:last-of-type { margin-top: 6px; color: var(--ink-2); }
.seal {
	margin-top: auto;
	align-self: flex-end;
	width: 92px; height: 92px;
	color: var(--ink);
	animation: spin 18s linear infinite;
}
.seal text { font-size: 7px; letter-spacing: 0.16em; fill: currentColor; }
@keyframes spin { to { transform: rotate(360deg); } }


/* ─── SECTION HEADS (shared) ─────────────────────────────── */
.section-head {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 48px;
	align-items: end;
	padding-bottom: 48px;
	margin-bottom: 40px;
	border-bottom: var(--rule);
}
.head-left .mono { color: var(--smoke); margin-bottom: 16px; display: block; }
.head-title {
	font-family: var(--f-display);
	font-weight: 900;
	font-size: clamp(48px, 7.2vw, 120px);
	line-height: 0.9;
	letter-spacing: -0.035em;
	text-transform: uppercase;
}
.head-title em.italic { font-style: normal; font-weight: 400; }
.head-right { padding-bottom: 12px; }
.head-right .mono { color: var(--ink-2); margin-bottom: 16px; }
.head-lede {
	font-family: var(--f-sans);
	font-weight: 500;
	font-size: clamp(18px, 2.2vw, 28px);
	line-height: 1.25;
	color: var(--ink-2);
	max-width: 28ch;
}


/* ─── CO-CREATE (Vora section) ───────────────────────────── */
.cocreate {
	background: var(--ink);
	color: var(--paper);
	padding: 140px var(--frame);
	border-top: var(--rule);
	border-bottom: var(--rule);
	position: relative;
}

.section-head-dark {
	border-bottom-color: rgba(244,239,230,0.18) !important;
}
.section-head-dark .head-left .mono,
.section-head-dark .head-right .mono { color: var(--bone); }
.section-head-dark .head-title { color: var(--paper); }
.section-head-dark .head-title em.italic { color: var(--acid); }
.section-head-dark .head-lede { color: var(--bone); }
.section-head-dark .head-lede em { color: var(--paper); font-style: normal; font-weight: 700; }

/* IDEA-CHALLENGE FLOW · 4 linear steps */
.idea-flow {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0;
	max-width: 1600px;
	margin: 0 auto 64px;
	border-top: 1px solid rgba(244,239,230,0.18);
	border-bottom: 1px solid rgba(244,239,230,0.18);
}
.idea-step {
	padding: 48px 36px;
	border-right: 1px solid rgba(244,239,230,0.18);
	position: relative;
	transition: background-color .35s ease;
}
.idea-step:last-child { border-right: none; }
.idea-step-final {
	background: rgba(203,242,36,0.05);
}
.idea-step:hover { background: rgba(203,242,36,0.04); }
.idea-step-final:hover { background: rgba(203,242,36,0.12); }

/* Arrow connector between steps (desktop) */
.idea-step::after {
	content: "→";
	position: absolute;
	top: 64px;
	right: -14px;
	width: 28px; height: 28px;
	background: var(--ink);
	color: var(--acid);
	border-radius: 50%;
	display: flex; align-items: center; justify-content: center;
	font-family: var(--f-display);
	font-weight: 900;
	font-size: 16px;
	line-height: 1;
	z-index: 3;
	border: 1px solid rgba(244,239,230,0.2);
}
.idea-step:last-child::after { display: none; }

.is-num {
	display: block;
	color: var(--acid);
	margin-bottom: 32px;
	letter-spacing: 0.14em;
}
.is-h {
	font-family: var(--f-display);
	font-weight: 900;
	font-size: clamp(24px, 2.4vw, 34px);
	line-height: 0.98;
	letter-spacing: -0.03em;
	text-transform: uppercase;
	margin-bottom: 18px;
	color: var(--paper);
}
.is-h em {
	font-style: normal;
	font-weight: 400;
	color: var(--acid);
}
.is-p {
	font-size: 14px;
	line-height: 1.55;
	color: var(--bone);
	margin: 0;
}

/* COLLABORATION CALLOUT */
.collab-callout {
	max-width: 1500px;
	margin: 0 auto 56px;
	padding: 40px 56px;
	background: var(--acid);
	color: var(--ink);
	border-radius: 4px;
	position: relative;
	overflow: hidden;
}
.collab-callout::before {
	content: "★";
	position: absolute;
	top: -20px; right: -20px;
	font-size: 240px;
	line-height: 1;
	color: var(--ink);
	opacity: 0.08;
	font-family: var(--f-display);
}
.collab-eyebrow {
	display: block;
	margin-bottom: 12px;
	color: var(--ink-2);
}
.collab-text {
	font-family: var(--f-display);
	font-weight: 800;
	font-size: clamp(22px, 2.4vw, 32px);
	line-height: 1.15;
	letter-spacing: -0.02em;
	text-transform: none;
	max-width: 28ch;
	margin: 0;
	color: var(--ink);
	position: relative;
	z-index: 1;
}
.collab-text em {
	font-style: normal;
	font-weight: 900;
	background: var(--ink);
	color: var(--acid);
	padding: 0 0.16em 0.04em;
	display: inline-block;
}

.cocreate-cta {
	display: inline-flex; align-items: center; gap: 14px;
	padding: 22px 32px;
	background: var(--acid);
	color: var(--ink);
	border-radius: 999px;
	font-family: var(--f-display);
	font-weight: 800;
	font-size: 18px;
	letter-spacing: -0.01em;
	text-transform: uppercase;
	transition: transform .4s cubic-bezier(.2,.8,.2,1), background-color .3s ease;
	margin-top: 8px;
}
.cocreate-cta:hover { background: var(--paper); transform: translateY(-2px); }
.cta-arrow { font-size: 22px; transition: transform .35s ease; line-height: 1; }
.cocreate-cta:hover .cta-arrow { transform: translate(4px,-4px); }
.cocreate-fine { margin-top: 16px; color: var(--bone); }
.cocreate-fine strong { color: var(--acid); font-weight: 700; }


/* ─── CHALLENGES NOW (live queue — featured upcoming challenge) ─── */
.challenges-now {
	padding: 120px var(--frame);
	background: var(--acid);
	position: relative;
	overflow: hidden;
}
.challenges-now::before {
	content: "";
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 6px;
	background: var(--ink);
}

.ch-head {
	max-width: 1000px;
	margin: 0 auto 56px;
	text-align: center;
}
.ch-eyebrow { display: block; margin-bottom: 20px; color: var(--ink-2); letter-spacing: 0.14em; }
.ch-h {
	font-family: var(--f-display);
	font-weight: 900;
	font-size: clamp(48px, 7vw, 104px);
	line-height: 0.92;
	letter-spacing: -0.04em;
	text-transform: lowercase;
	color: var(--ink);
	margin-bottom: 20px;
}
.ch-h em { font-style: normal; color: var(--acid); background: var(--ink); padding: 0 0.16em 0.04em; display: inline-block; }
.ch-lede {
	font-family: var(--f-sans);
	font-size: 16px;
	line-height: 1.55;
	color: var(--ink-2);
	max-width: 60ch;
	margin: 0 auto;
}

/* The featured upcoming-challenge card */
.ch-feature {
	max-width: 1400px;
	margin: 0 auto;
	background: var(--paper);
	border: 2px solid var(--ink);
	box-shadow: 12px 12px 0 var(--ink);
	overflow: hidden;
	transition: transform .5s cubic-bezier(.2,.8,.2,1), box-shadow .5s cubic-bezier(.2,.8,.2,1);
}
.ch-feature:hover { transform: translate(-2px, -2px); box-shadow: 14px 14px 0 var(--ink); }

.ch-feature-top {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 18px 32px;
	background: var(--ink);
	color: var(--paper);
	flex-wrap: wrap;
	gap: 12px;
}
.ch-status-pill {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 6px 14px;
	background: var(--acid);
	color: var(--ink);
	border-radius: 999px;
	letter-spacing: 0.16em;
}
.ch-status-dot {
	width: 8px; height: 8px;
	background: var(--ink);
	border-radius: 50%;
	animation: pulse 2s ease-in-out infinite;
}
.ch-feature-tag {
	color: var(--bone);
	letter-spacing: 0.12em;
}

.ch-feature-grid {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: 0;
}

/* LEFT — brief + name + winner benefits */
.ch-feature-left {
	padding: 48px 56px;
	border-right: 2px solid var(--ink);
	display: grid;
	gap: 32px;
}
.ch-name {
	font-family: var(--f-display);
	font-weight: 900;
	font-size: clamp(64px, 8vw, 120px);
	line-height: 0.88;
	letter-spacing: -0.045em;
	text-transform: lowercase;
	color: var(--ink);
	margin: 0;
}
.ch-vision {
	font-family: var(--f-sans);
	font-style: italic;
	font-size: clamp(18px, 1.8vw, 22px);
	line-height: 1.4;
	color: var(--ink-2);
	max-width: 36ch;
	margin: -8px 0 0;
}
.ch-brief, .ch-winner {
	padding-top: 24px;
	border-top: 1px solid var(--ink);
}
.ch-brief-l, .ch-winner-l, .ch-timeline-l {
	display: block;
	color: var(--smoke);
	margin-bottom: 16px;
	letter-spacing: 0.14em;
}
.ch-brief-t {
	font-family: var(--f-sans);
	font-size: 16px;
	line-height: 1.55;
	color: var(--ink);
	margin: 0 0 14px;
}
.ch-brief-t em {
	font-style: normal;
	font-weight: 700;
	background: var(--acid);
	padding: 0 0.12em;
}
.ch-brief-format {
	color: var(--ink-2);
	letter-spacing: 0.1em;
}
.ch-winner-list {
	display: grid;
	gap: 14px;
}
.ch-winner-item {
	display: grid;
	grid-template-columns: 36px 1fr;
	gap: 16px;
	align-items: baseline;
	font-family: var(--f-sans);
	font-size: 15px;
	line-height: 1.45;
	color: var(--ink);
}
.ch-w-num {
	color: var(--acid);
	background: var(--ink);
	padding: 4px 8px;
	border-radius: 4px;
	text-align: center;
	letter-spacing: 0.1em;
	font-size: 10px;
}

/* RIGHT — timeline + meta strip + CTA */
.ch-feature-right {
	padding: 48px 40px;
	background: var(--ink);
	color: var(--paper);
	display: grid;
	gap: 28px;
	align-content: start;
}
.ch-feature-right .ch-timeline-l { color: var(--bone); }
.ch-timeline-row {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	padding: 10px 0;
	border-bottom: 1px solid rgba(244,239,230,0.18);
}
.ch-timeline-row:last-child { border-bottom: none; padding-bottom: 0; }
.ch-tr-l { color: var(--bone); }
.ch-tr-v {
	font-family: var(--f-display);
	font-weight: 800;
	font-size: 14px;
	letter-spacing: 0.04em;
	color: var(--acid);
}

.ch-meta-strip {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px;
	padding: 20px 0;
	border-top: 1px solid rgba(244,239,230,0.18);
	border-bottom: 1px solid rgba(244,239,230,0.18);
}
.ch-meta-cell { display: flex; flex-direction: column; gap: 4px; }
.ch-mc-l { color: var(--bone); }
.ch-mc-v {
	font-family: var(--f-display);
	font-weight: 900;
	font-size: 28px;
	letter-spacing: -0.025em;
	color: var(--paper);
}

.ch-cta {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	padding: 18px 24px;
	background: var(--acid);
	color: var(--ink);
	border-radius: 999px;
	font-family: var(--f-display);
	font-weight: 800;
	font-size: 14px;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	transition: background-color .3s ease, transform .3s ease;
	margin-top: 4px;
}
.ch-cta:hover { background: var(--paper); transform: translateY(-2px); }
.ch-cta-arrow { font-size: 18px; transition: transform .3s ease; }
.ch-cta:hover .ch-cta-arrow { transform: translate(3px, -3px); }
.ch-fine { color: var(--bone); margin: 0; }

.ch-foot {
	text-align: center;
	margin: 48px auto 0;
	max-width: 720px;
	color: var(--ink-2);
}
.ch-foot strong {
	font-family: var(--f-display);
	font-weight: 800;
	color: var(--ink);
	letter-spacing: -0.01em;
	text-transform: lowercase;
}
.ch-foot a { color: var(--ink); text-decoration: underline; text-underline-offset: 4px; }


/* ─── SERIES (new — active drop + next 13) ──────────────── */
.series { padding: 120px var(--frame); }

.series-lede {
	font-family: var(--f-display);
	font-style: normal;
	font-weight: 500;
	font-size: clamp(18px, 1.8vw, 22px);
	line-height: 1.4;
	color: var(--ink);
	max-width: 50ch;
	margin-top: 16px;
}
.series-lede em {
	font-style: normal;
	font-weight: 800;
	background: var(--ink);
	color: var(--acid);
	padding: 0 0.12em;
}

/* Featured: active drop card */
.featured-drop {
	margin: 64px 0 96px;
	position: relative;
}
.featured-drop-link {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0;
	border: var(--rule);
	background: var(--paper);
	overflow: hidden;
	transition: transform .6s cubic-bezier(.2,.8,.2,1), box-shadow .6s cubic-bezier(.2,.8,.2,1);
	box-shadow: 12px 12px 0 var(--ink);
}
.featured-drop-link:hover {
	transform: translate(-4px, -4px);
	box-shadow: 16px 16px 0 var(--ink);
}
.featured-drop-art {
	position: relative;
	aspect-ratio: 1 / 1;
	overflow: hidden;
	border-right: var(--rule);
	background: var(--acid);
	color: var(--ink);
}
.featured-drop-art .art-block-stack {
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	font-family: var(--f-display);
	font-weight: 900;
	font-size: clamp(120px, 18vw, 260px);
	line-height: 0.82;
	letter-spacing: -0.07em;
	color: var(--ink);
}
.featured-drop-art .art-block-stack span { display: block; }
.featured-drop-art .art-block-stack span:nth-child(2) { transform: translateX(-2%); }
.featured-drop-art .art-block-stack span:nth-child(3) {
	background: var(--ink);
	color: var(--acid);
	padding: 0 0.06em;
}
.featured-live-dot {
	position: absolute;
	top: 14px; right: 14px;
	width: 12px; height: 12px;
	background: #FF3D00;
	border-radius: 50%;
	box-shadow: 0 0 0 4px var(--acid);
	animation: pulse 2s ease-in-out infinite;
}

.featured-drop-body {
	padding: 48px 56px;
	display: grid;
	grid-template-rows: auto auto 1fr auto auto;
	gap: 20px;
	background: var(--paper);
	color: var(--ink);
}
.featured-tag {
	color: var(--smoke);
	letter-spacing: 0.14em;
}
.featured-name {
	font-family: var(--f-display);
	font-weight: 900;
	font-size: clamp(56px, 7vw, 96px);
	line-height: 0.92;
	letter-spacing: -0.045em;
	text-transform: lowercase;
	color: var(--ink);
	margin: 0;
}
.featured-story {
	font-family: var(--f-sans);
	font-size: 16px;
	line-height: 1.55;
	color: var(--ink-2);
	max-width: 50ch;
	margin: 0;
}
.featured-story em {
	font-style: normal;
	font-weight: 700;
	background: var(--acid);
	color: var(--ink);
	padding: 0 0.12em;
}
.featured-meta {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 8px 24px;
	padding-top: 20px;
	border-top: 1px solid var(--ink);
}
.fm-cell { display: flex; flex-direction: column; gap: 4px; }
.fm-l { color: var(--smoke); }
.fm-v {
	font-family: var(--f-display);
	font-weight: 900;
	font-size: 24px;
	letter-spacing: -0.025em;
	color: var(--ink);
}
.featured-cta {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 14px 20px;
	background: var(--ink);
	color: var(--acid);
	border-radius: 999px;
	width: fit-content;
	font-size: 12px;
	letter-spacing: 0.12em;
	transition: gap .35s cubic-bezier(.65,0,.35,1);
}
.featured-drop-link:hover .featured-cta { gap: 14px; }
.featured-cta-arrow { font-size: 16px; }

/* The next 13 — editorial list */
.series-next { margin: 80px 0 40px; }
.series-next-head {
	max-width: 1100px;
	margin: 0 auto 48px;
	text-align: center;
}
.series-next-head .mono { display: block; color: var(--smoke); margin-bottom: 16px; }
.series-next-h {
	font-family: var(--f-display);
	font-weight: 900;
	font-size: clamp(40px, 6vw, 88px);
	line-height: 0.92;
	letter-spacing: -0.04em;
	text-transform: lowercase;
	color: var(--ink);
}
.series-next-h em { font-style: normal; color: var(--ink); background: var(--acid); padding: 0 0.16em 0.04em; display: inline-block; }
.series-next-sub {
	max-width: 56ch;
	margin: 16px auto 0;
	font-family: var(--f-sans);
	font-size: 15px;
	line-height: 1.5;
	color: var(--ink-2);
}
.series-next-sub em {
	font-style: normal;
	font-weight: 700;
	background: var(--ink);
	color: var(--acid);
	padding: 0 0.12em;
}

.series-next-list {
	border-top: 1px solid var(--ink);
}
.snd-row {
	display: grid;
	grid-template-columns: 80px 1fr 2fr auto;
	gap: 32px;
	align-items: baseline;
	padding: 28px 16px;
	border-bottom: 1px solid var(--ink);
	transition: background-color .35s ease;
	position: relative;
}
.snd-row::before {
	content: "✦";
	position: absolute;
	left: -8px; top: 50%;
	transform: translateY(-50%);
	font-size: 14px;
	color: var(--ink);
	opacity: 0;
	transition: opacity .3s ease, left .3s ease;
}
.snd-row:hover { background: var(--ink); color: var(--paper); }
.snd-row:hover::before { opacity: 1; left: 0; color: var(--acid); }
.snd-row:hover .snd-num,
.snd-row:hover .snd-status { color: var(--acid); }
.snd-row:hover .snd-name { color: var(--paper); }
.snd-row:hover .snd-story { color: var(--bone); }
.snd-row-final { background: rgba(14,13,10,0.06); }

.snd-num {
	color: var(--smoke);
	font-size: 12px;
	letter-spacing: 0.14em;
	transition: color .3s ease;
}
.snd-name {
	font-family: var(--f-display);
	font-weight: 900;
	font-size: clamp(26px, 3.4vw, 44px);
	line-height: 0.95;
	letter-spacing: -0.035em;
	text-transform: lowercase;
	color: var(--ink);
	transition: color .3s ease;
	margin: 0;
}
.snd-story {
	font-family: var(--f-sans);
	font-style: italic;
	font-weight: 400;
	font-size: clamp(14px, 1.3vw, 17px);
	line-height: 1.4;
	color: var(--ink-2);
	transition: color .3s ease;
	margin: 0;
}
.snd-status {
	color: var(--smoke);
	text-align: right;
	transition: color .3s ease;
}
.series-next-foot {
	text-align: center;
	margin: 48px auto 0;
	max-width: 700px;
	color: var(--smoke);
	padding: 16px 20px;
	border: 1px dashed var(--ink);
	border-radius: 4px;
}


/* ─── COLLECTION (legacy — kept for any leftover references) ─ */
.collection { padding: 120px var(--frame); }

.filters {
	display: flex; flex-wrap: wrap; gap: 8px;
	margin-top: 8px;
}
.filter {
	font-family: var(--f-mono); font-size: 11px;
	letter-spacing: 0.08em; text-transform: uppercase;
	padding: 8px 14px;
	border: var(--rule);
	border-radius: 999px;
	color: var(--ink);
	background: transparent;
	transition: background-color .3s ease, color .3s ease;
	display: inline-flex; align-items: baseline; gap: 4px;
}
.filter sup { font-size: 9px; color: var(--smoke); font-weight: 400; }
.filter:hover { background: var(--paper); }
.filter.is-active { background: var(--ink); color: var(--paper); }
.filter.is-active sup { color: var(--acid); }

.grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 56px 32px;
}
.card-wide { grid-column: span 2; }

.card { position: relative; }
.card-inner {
	display: flex; flex-direction: column;
	gap: 0;
	position: relative;
	transition: transform .6s cubic-bezier(.2,.8,.2,1);
}
.card:hover .card-inner { transform: translateY(-6px); }

.card-meta {
	display: flex; justify-content: space-between;
	font-family: var(--f-mono); font-size: 10px;
	letter-spacing: 0.1em; text-transform: uppercase;
	padding-bottom: 10px;
	color: var(--ink-2);
}

.card-img {
	aspect-ratio: 4 / 5;
	background-size: cover; background-position: center;
	background-color: var(--paper);
	border: var(--rule);
	overflow: hidden;
	position: relative;
	filter: contrast(1.04) saturate(0.85);
	transition: filter .4s ease, transform .6s cubic-bezier(.2,.8,.2,1);
}
.card:hover .card-img { filter: contrast(1.04) saturate(1) brightness(.95); }
.card-wide .card-img { aspect-ratio: 8 / 5; }

.card-img-art {
	display: flex; align-items: center; justify-content: center;
	filter: none;
}
.card-art.art-1 .card-img { background: var(--ink); color: var(--acid); }
.card-art.art-1 .tee-svg { width: 70%; }
.card-art.art-1 .tee-svg path { stroke: var(--acid); }
.card-art.art-1 .tee-glyph { font-family: var(--f-display); font-weight: 900; fill: var(--acid); font-size: 22px; letter-spacing: -0.04em; text-transform: uppercase; }
.card-art.art-1 .tee-glyph-small { font-family: var(--f-mono); fill: var(--paper); font-size: 5px; letter-spacing: 0.2em; }

.card-art.art-2 .card-img { background: var(--paper); color: var(--ink); }
.card-img-quote { display: flex; flex-direction: column; justify-content: center; gap: 12px; padding: 48px; }
.archivio-quote {
	font-family: var(--f-display);
	font-weight: 900;
	font-size: clamp(28px, 3.2vw, 52px);
	line-height: 0.96;
	letter-spacing: -0.035em;
	text-transform: uppercase;
	color: var(--ink);
	max-width: 600px;
}
.archivio-attr { color: var(--ink-2); }

.card-art.art-3 .card-img { background: var(--ink); color: var(--paper); }
.card-art.art-3 .art-word { color: var(--paper); }


/* ─── EXCESSIVE ART TILES (poster compositions in lieu of photos) ─── */

/* shared corner labels */
.art-corner, .art-corner-br {
	position: absolute;
	font-size: 9px;
	letter-spacing: 0.12em;
	z-index: 3;
	background: rgba(244,239,230,0.92);
	color: var(--ink);
	padding: 4px 8px;
	border-radius: 2px;
	backdrop-filter: blur(4px);
}
.art-corner    { top: 12px;    right: 12px; }
.art-corner-br { bottom: 12px; right: 12px; }
.card-img-art .nft-chip { z-index: 4; }

/* === ART · BLOCK (Card 01) === */
.art-block {
	background: var(--acid);
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	position: relative;
	filter: none;
}
.art-block::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		repeating-linear-gradient(
			135deg,
			transparent 0 28px,
			rgba(14,13,10,0.06) 28px 30px
		);
}
.art-block-stack {
	display: flex;
	flex-direction: column;
	align-items: center;
	font-family: var(--f-display);
	font-weight: 900;
	font-size: clamp(56px, 11vw, 96px);
	line-height: 0.78;
	letter-spacing: -0.06em;
	color: var(--ink);
	transform: rotate(-3deg);
	position: relative;
	z-index: 2;
}
.art-block-stack span { display: block; }
.art-block-stack span:nth-child(2) { transform: translateX(-6%); }
.art-block-stack span:nth-child(4) { transform: translateX(8%); }

/* === ART · PAVEMENT (Card 03) === */
.art-pavement {
	background: var(--acid);
	overflow: hidden;
	position: relative;
	filter: none;
}
.art-pavement::before {
	content: "";
	position: absolute;
	inset: -10%;
	background:
		repeating-linear-gradient(
			60deg,
			var(--ink) 0 8px,
			transparent 8px 22px
		);
	opacity: 0.92;
	transform: rotate(2deg);
}
.art-pave-rot {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%) rotate(-90deg);
	display: flex;
	flex-direction: column;
	gap: 4px;
	font-family: var(--f-display);
	font-weight: 900;
	font-size: clamp(28px, 4vw, 44px);
	line-height: 0.92;
	letter-spacing: -0.05em;
	text-transform: uppercase;
	color: var(--acid);
	z-index: 2;
	white-space: nowrap;
}
.art-pave-rot span:nth-child(2) {
	color: var(--ink);
	background: var(--acid);
	padding: 0 8px;
}

/* === ART · NOCTURNE (Card 05) === */
.art-nocturne {
	background: var(--ink);
	color: var(--acid);
	overflow: hidden;
	position: relative;
	filter: none;
}
.art-noct-svg {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
}
.art-noct-star    { font-size: 22px; }
.art-noct-star-s  { font-size: 12px; }
.art-noct-vert {
	position: absolute;
	left: 50%;
	bottom: 24px;
	transform: translateX(-50%);
	font-family: var(--f-display);
	font-weight: 900;
	font-size: clamp(28px, 3vw, 36px);
	letter-spacing: 0.5em;
	text-transform: uppercase;
	color: var(--acid);
	z-index: 2;
}

/* === ART · RELIC (Card 04 wide / card 07) === */
.art-relic {
	background: var(--acid);
	overflow: hidden;
	position: relative;
	filter: none;
	display: flex;
	align-items: center;
	justify-content: center;
}
.art-relic-svg {
	width: 100%;
	height: 100%;
	animation: spin 60s linear infinite;
}
.art-relic-num {
	font-family: var(--f-display);
	font-weight: 900;
	font-size: 36px;
	text-anchor: middle;
	fill: var(--acid);
	letter-spacing: -0.06em;
}
.art-relic-circle {
	font-family: var(--f-mono);
	font-size: 6.4px;
	letter-spacing: 0.18em;
}

/* === ART · PLAZA (Card 08) === */
.art-plaza {
	background: var(--acid);
	overflow: hidden;
	position: relative;
	filter: none;
}
.art-plaza-svg {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
}
.art-plaza-tag {
	font-family: var(--f-mono);
	font-size: 9px;
	letter-spacing: 0.16em;
	text-anchor: middle;
}
.art-plaza-word {
	position: absolute;
	left: 16px;
	bottom: 28px;
	font-family: var(--f-display);
	font-weight: 900;
	font-size: clamp(36px, 5.5vw, 64px);
	line-height: 1;
	letter-spacing: -0.05em;
	text-transform: uppercase;
	color: var(--ink);
	z-index: 2;
	background: var(--acid);
	padding: 4px 8px;
	transform: rotate(-2deg);
}

/* === HERO TILE ART === */
.hero-tile-art {
	aspect-ratio: 3 / 4;
	overflow: hidden;
	position: relative;
	background: var(--acid);
}
.hero-tile-svg {
	width: 100%;
	height: 100%;
	display: block;
}
.hero-art-001 {
	font-family: var(--f-display);
	font-weight: 900;
	font-size: 80px;
	text-anchor: middle;
	letter-spacing: -0.08em;
}
.hero-art-tag {
	font-family: var(--f-display);
	font-weight: 800;
	font-size: 14px;
	letter-spacing: -0.01em;
	text-transform: uppercase;
}
.hero-art-mini {
	font-family: var(--f-mono);
	font-size: 7px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

/* === LOOKBOOK ART TILES === */
.img-frame-art {
	display: block;
	overflow: hidden;
	filter: none !important;
	background: var(--ink);
	border: 1px solid var(--paper);
}
.lookbook-img-a .img-frame-art { aspect-ratio: 3 / 4; }
.lookbook-img-b .img-frame-art { aspect-ratio: 3 / 4; margin-top: 100px; }
.lb-svg { width: 100%; height: 100%; display: block; }
.lb-numeral {
	font-family: var(--f-display);
	font-weight: 900;
	font-size: 280px;
	letter-spacing: -0.08em;
	dominant-baseline: alphabetic;
}
.lb-numeral-r {
	font-size: 320px;
}
.lb-tag {
	font-family: var(--f-display);
	font-weight: 800;
	font-size: 16px;
	letter-spacing: -0.01em;
	text-transform: uppercase;
}
.lb-tag-s {
	font-family: var(--f-mono);
	font-size: 8px;
	letter-spacing: 0.16em;
	text-transform: uppercase;
}
.lb-mini {
	font-family: var(--f-mono);
	font-size: 8px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
}
.art-stack {
	display: flex; flex-direction: column; gap: 4px;
	transform: rotate(-4deg);
	font-size: clamp(28px, 4vw, 56px);
	line-height: 1;
}
.art-word { font-family: var(--f-display); font-style: normal; font-weight: 900; text-transform: uppercase; letter-spacing: -0.035em; }
.art-word.strikeout { text-decoration: line-through; text-decoration-thickness: 3px; color: var(--rosso); }
.art-stack .art-word:last-child { color: var(--acid); font-weight: 700; }

.card-foot {
	padding-top: 18px;
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 4px 16px;
	align-items: baseline;
}
.card-title {
	font-family: var(--f-display);
	font-weight: 800;
	font-size: 24px;
	line-height: 1;
	letter-spacing: -0.025em;
	text-transform: uppercase;
}
.card-foot .mono { grid-column: 1 / -1; color: var(--ink-2); font-size: 10px; }

.nft-chip {
	position: absolute;
	bottom: 12px;
	left: 12px;
	padding: 6px 10px;
	background: rgba(14,13,10,0.88);
	color: var(--acid);
	border: 1px solid rgba(203,242,36,0.45);
	border-radius: 999px;
	font-size: 9px;
	letter-spacing: 0.08em;
	z-index: 2;
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
}
.nft-chip-light {
	background: rgba(244,239,230,0.92);
	color: var(--ink);
	border-color: rgba(14,13,10,0.4);
}
.card-art.art-1 .nft-chip,
.card-art.art-3 .nft-chip {
	background: rgba(244,239,230,0.92);
	color: var(--ink);
	border-color: rgba(14,13,10,0.3);
}

.card-cta {
	position: absolute;
	top: 22px; right: 14px;
	padding: 6px 12px;
	background: var(--ink);
	color: var(--acid);
	border: 1px solid var(--ink);
	border-radius: 999px;
	opacity: 0;
	transform: translateY(-4px);
	transition: opacity .4s ease, transform .4s ease;
	font-size: 10px;
	z-index: 2;
}
.card:hover .card-cta { opacity: 1; transform: translateY(0); }

.card.is-hidden { display: none; }

.all-link {
	display: inline-flex; align-items: baseline; gap: 8px;
	margin-top: 64px;
	padding-bottom: 4px;
	border-bottom: var(--rule);
}
.all-link-arrow { transition: transform .35s cubic-bezier(.65,0,.35,1); display: inline-block; }
.all-link:hover .all-link-arrow { transform: translateX(8px); }


/* ─── LOOKBOOK ───────────────────────────────────────────── */
.lookbook {
	background: var(--ink);
	color: var(--paper);
	padding: 140px var(--frame);
}
.lookbook-grid {
	display: grid;
	grid-template-columns: 1.1fr 1fr 0.9fr;
	gap: 56px;
	align-items: center;
	max-width: 1500px;
	margin: 0 auto;
}
.lookbook-img-a .img-frame { aspect-ratio: 3 / 4; }
.lookbook-img-b .img-frame { aspect-ratio: 3 / 4; margin-top: 100px; }
.img-frame {
	background-size: cover; background-position: center;
	border: 1px solid var(--paper);
	padding: 0;
	filter: contrast(1.05) brightness(0.92) saturate(0.9);
	transition: transform .8s cubic-bezier(.2,.8,.2,1);
}
.lookbook-img-a:hover .img-frame, .lookbook-img-b:hover .img-frame { transform: scale(1.02); }
.img-caption { margin-top: 12px; color: var(--bone); }

.lookbook-text { padding: 0 8px; }
.lookbook-text .mono { color: var(--bone); display: block; margin-bottom: 24px; }
.lookbook-title {
	font-family: var(--f-display);
	font-weight: 900;
	font-size: clamp(40px, 5.2vw, 88px);
	line-height: 0.92;
	letter-spacing: -0.035em;
	text-transform: uppercase;
	margin-bottom: 32px;
}
.lookbook-title em.italic { font-style: normal; font-weight: 400; }
.lookbook-title .hl {
	background: var(--acid);
	color: var(--ink);
	padding: 0 0.16em 0.04em;
	display: inline-block;
}
.lookbook-body {
	font-size: 17px;
	line-height: 1.55;
	color: var(--bone);
	max-width: 38ch;
	margin-bottom: 32px;
	font-weight: 400;
}
.lookbook-body em { color: var(--paper); font-style: normal; font-weight: 700; }

.lookbook-cta {
	display: inline-flex; align-items: center; gap: 12px;
	padding: 16px 24px;
	border: 1px solid var(--paper);
	border-radius: 999px;
	font-size: 13px;
	letter-spacing: 0.04em;
	transition: background-color .3s ease, color .3s ease;
}
.lookbook-cta:hover { background: var(--acid); color: var(--ink); border-color: var(--acid); }
.lookbook-cta-arrow { font-size: 16px; transition: transform .35s ease; }
.lookbook-cta:hover .lookbook-cta-arrow { transform: translate(4px, -4px); }


/* ─── SARTORIA ───────────────────────────────────────────── */
.sartoria { padding: 140px var(--frame); }
.sartoria-list {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 48px;
	counter-reset: sart;
}
.sartoria-item {
	padding-top: 32px;
	border-top: 2px solid var(--ink);
	position: relative;
}
.sart-num {
	font-family: var(--f-mono);
	font-size: 11px;
	letter-spacing: 0.16em;
	color: var(--smoke);
	display: block;
	margin-bottom: 64px;
}
.sart-h {
	font-family: var(--f-display);
	font-weight: 800;
	font-size: clamp(24px, 2.2vw, 30px);
	line-height: 1.08;
	letter-spacing: -0.025em;
	text-transform: uppercase;
	margin-bottom: 16px;
}
.sart-h em.italic { font-style: normal; font-weight: 400; }
.sart-p {
	font-size: 15px;
	line-height: 1.5;
	color: var(--ink-2);
	max-width: 36ch;
}
.sart-token {
	display: inline-block;
	margin-top: 16px;
	padding: 6px 12px;
	background: var(--ink);
	color: var(--acid);
	border-radius: 999px;
	font-size: 10px;
}
.sartoria-item-token { position: relative; }
.sartoria-item-token::after {
	content: "";
	position: absolute;
	top: -2px; left: 0; right: 0;
	height: 4px;
	background: var(--ink);
}


/* ─── NEWSLETTER ─────────────────────────────────────────── */
.newsletter {
	padding: 140px var(--frame);
	background: var(--paper);
	border-top: var(--rule);
	border-bottom: var(--rule);
	position: relative;
}
.newsletter::before {
	content: "";
	position: absolute;
	top: 0; left: 50%;
	width: 1px; height: 64px;
	background: var(--ink);
	transform: translateX(-50%);
}
.newsletter::after {
	content: "✦";
	position: absolute;
	top: 56px; left: 50%;
	transform: translateX(-50%);
	font-size: 18px;
	color: var(--ink);
	background: var(--paper);
	padding: 0 8px;
}
.newsletter-inner {
	max-width: 880px; margin: 0 auto;
	text-align: center;
}
.newsletter-inner .mono { color: var(--smoke); display: block; margin-bottom: 24px; }
.newsletter-title {
	font-family: var(--f-display);
	font-weight: 900;
	font-size: clamp(48px, 8vw, 128px);
	line-height: 0.88;
	letter-spacing: -0.04em;
	text-transform: uppercase;
	margin-bottom: 24px;
}
.newsletter-title em.italic { font-style: normal; font-weight: 400; }
.newsletter-lede {
	font-family: var(--f-sans);
	font-style: normal;
	font-weight: 400;
	font-size: clamp(16px, 1.6vw, 20px);
	line-height: 1.45;
	color: var(--ink-2);
	max-width: 44ch;
	margin: 0 auto 40px;
}
.newsletter-form {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 12px;
	max-width: 560px;
	margin: 0 auto;
	border: var(--rule);
	background: var(--acid);
	border-radius: 999px;
	padding: 6px 6px 6px 24px;
	position: relative;
}
.newsletter-form input {
	border: none; background: transparent;
	font-family: var(--f-mono); font-size: 13px;
	color: var(--ink);
	padding: 12px 0;
	outline: none;
}
.newsletter-form input::placeholder { color: var(--smoke); }
.newsletter-form button {
	background: var(--ink); color: var(--paper);
	padding: 14px 24px;
	border-radius: 999px;
	font-family: var(--f-mono); font-size: 12px;
	letter-spacing: 0.08em; text-transform: uppercase;
	display: inline-flex; align-items: center; gap: 8px;
	transition: background-color .3s ease, color .3s ease;
}
.newsletter-form button:hover { background: var(--paper); color: var(--ink); }
.btn-arrow { transition: transform .35s ease; }
.newsletter-form button:hover .btn-arrow { transform: translateX(4px); }
.newsletter-sent {
	position: absolute;
	left: 0; right: 0; bottom: -34px;
	color: var(--acid-d);
	opacity: 0;
	transition: opacity .4s ease;
}
.newsletter-form.is-sent .newsletter-sent { opacity: 1; color: #4a7d00; }
.newsletter-form.is-sent input, .newsletter-form.is-sent button { opacity: 0.4; pointer-events: none; }
.newsletter-fine { color: var(--smoke); margin-top: 24px; }


/* ─── FOOTER ─────────────────────────────────────────────── */
.footer {
	background: var(--ink);
	color: var(--paper);
	padding: 80px var(--frame) 40px;
	position: relative;
	overflow: hidden;
}
.footer-mark {
	overflow: hidden;
	margin-bottom: 80px;
	border-bottom: 1px solid rgba(244,239,230,0.18);
	padding-bottom: 40px;
	display: flex;
	justify-content: center;
}
.footer-mark-img {
	display: block;
	width: 100%;
	max-width: 100%;
	height: auto;
	margin: 0 -2vw;
}
.footer-mark-img {
	display: block;
	width: 100%;
	max-width: 100%;
	height: auto;
}
.footer-word {
	display: block;
	font-family: var(--f-display);
	font-style: normal;
	font-weight: 900;
	font-size: clamp(110px, 23vw, 360px);
	line-height: 0.85;
	letter-spacing: -0.06em;
	text-transform: lowercase;
	color: var(--acid);
	-webkit-text-stroke: 0;
	white-space: nowrap;
}
.footer-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 40px;
	padding-bottom: 80px;
}
.footer-label { color: var(--bone); display: block; margin-bottom: 24px; padding-bottom: 12px; border-bottom: 1px solid rgba(244,239,230,0.18); }
.footer-line {
	font-family: var(--f-sans);
	font-size: 14px;
	line-height: 1.55;
	color: var(--paper);
	margin-bottom: 4px;
}
.footer-line a { position: relative; transition: color .3s ease; }
.footer-line a:hover { color: var(--acid); }
.footer-line a sup { font-size: 10px; }
.footer-soon { color: var(--bone) !important; margin-top: 12px; font-size: 10px !important; }

.footer-base {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	gap: 24px;
	padding-top: 24px;
	border-top: 1px solid rgba(244,239,230,0.18);
	color: var(--bone);
}
.footer-base p:nth-child(2) { text-align: center; }
.footer-base p:nth-child(3) { text-align: right; }
.footer-base a { color: var(--paper); }


/* ─── REVEAL ANIMATIONS ──────────────────────────────────── */
[data-reveal] {
	opacity: 0;
	transform: translateY(28px);
	transition: opacity .9s cubic-bezier(.2,.8,.2,1), transform .9s cubic-bezier(.2,.8,.2,1);
}
[data-reveal].is-visible {
	opacity: 1;
	transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
	[data-reveal] { opacity: 1; transform: none; }
	.seal, .loader-arc { animation: none; }
	html { scroll-behavior: auto; }
}


/* ─── RESPONSIVE ─────────────────────────────────────────── */
@media (max-width: 1100px) {
	.hero-grid {
		grid-template-columns: 1fr 260px;
		grid-template-rows: auto auto auto auto;
		gap: 32px;
	}
	.hero-meta { grid-column: 1; grid-row: 1; }
	.hero-title { grid-column: 1 / -1; grid-row: 2; font-size: clamp(56px, 12vw, 120px); }
	.hero-title .line-2 { text-align: left; }
	.hero-side { grid-column: 2; grid-row: 1; }
	.hero-foot { grid-column: 1 / -1; grid-row: 3; }
	.nav-links { display: none; }
	.nav-inner { grid-template-columns: 1fr auto; }
	.grid { grid-template-columns: repeat(2, 1fr); }
	.card-wide { grid-column: span 2; }
	.featured-drop-link { grid-template-columns: 1fr; }
	.featured-drop-art { border-right: none; border-bottom: var(--rule); aspect-ratio: 16 / 10; }
	.featured-drop-body { padding: 32px; }
	.ch-feature-grid { grid-template-columns: 1fr; }
	.ch-feature-left { border-right: none; border-bottom: 2px solid var(--ink); padding: 36px 32px; }
	.ch-feature-right { padding: 36px 32px; }
	.ch-feature-top { padding: 14px 24px; }
	.featured-meta { grid-template-columns: repeat(2, 1fr); }
	.snd-row { grid-template-columns: 60px 1fr; gap: 12px; padding: 20px 12px; }
	.snd-row > .snd-story { grid-column: 2; }
	.snd-row > .snd-status { grid-column: 2; text-align: left; }
	.lookbook-grid { grid-template-columns: 1fr 1fr; }
	.lookbook-img-b { display: none; }
	.sartoria-list { grid-template-columns: 1fr; gap: 24px; }
	.idea-flow { grid-template-columns: repeat(2, 1fr); }
	.idea-step { border-right: 1px solid rgba(244,239,230,0.18); padding: 36px 24px; }
	.idea-step:nth-child(2n) { border-right: none; }
	.idea-step:nth-child(-n+2) { border-bottom: 1px solid rgba(244,239,230,0.18); }
	.idea-step::after { top: auto; right: -14px; }
	.idea-step:nth-child(2)::after,
	.idea-step:nth-child(4)::after { display: none; }
	.idea-step:nth-child(1)::after,
	.idea-step:nth-child(3)::after { top: 50%; transform: translateY(-50%); }
	.collab-callout { padding: 28px 24px; }
	.collab-callout::before { font-size: 180px; }
	.idea-flow { grid-template-columns: 1fr; }
	.idea-step { border-right: none; border-bottom: 1px solid rgba(244,239,230,0.18); }
	.idea-step:last-child { border-bottom: none; }
	.idea-step::after { display: none; }
	.manifesto-grid { grid-template-columns: 1fr; }
	.manifesto-card { max-width: 380px; }
	.footer-grid { grid-template-columns: repeat(2, 1fr); }
	.nav-vora { display: none; }
}
@media (max-width: 680px) {
	:root { --frame: 16px; }
	.edge { font-size: 9px; }
	.edge-tr, .edge-bl { display: none; }
	.hero { padding: 32px var(--frame) 56px; }
	.hero-grid { grid-template-columns: 1fr; }
	.hero-meta, .hero-title, .hero-side, .hero-foot { grid-column: 1; }
	.hero-side { transform: scale(.9); transform-origin: left top; }
	.hero-foot { grid-template-columns: 1fr; gap: 16px; }
	.hero-foot p:nth-child(2), .hero-foot p:nth-child(3) { text-align: left; }
	.section-head { grid-template-columns: 1fr; gap: 24px; }
	.collection, .lookbook, .sartoria, .newsletter, .manifesto, .cocreate { padding: 80px var(--frame); }
	.cocreate-cta { padding: 18px 24px; font-size: 16px; }
	.grid { grid-template-columns: 1fr; gap: 40px; }
	.card-wide { grid-column: 1; }
	.lookbook-grid { grid-template-columns: 1fr; gap: 32px; }
	.lookbook-img-b { display: block; }
	.lookbook-img-b .img-frame { margin-top: 0; }
	.footer-grid { grid-template-columns: 1fr; gap: 32px; padding-bottom: 48px; }
	.footer-base { grid-template-columns: 1fr; }
	.footer-base p:nth-child(2), .footer-base p:nth-child(3) { text-align: left; }
	.newsletter-form { grid-template-columns: 1fr; border-radius: 18px; padding: 12px; }
	.challenges-now { padding: 80px var(--frame); }
	.ch-feature { box-shadow: 6px 6px 0 var(--ink); }
	.ch-feature:hover { box-shadow: 7px 7px 0 var(--ink); }
	.ch-feature-left, .ch-feature-right { padding: 28px 22px; }
	.ch-meta-strip { grid-template-columns: 1fr; gap: 14px; }
	.newsletter-form input { padding: 8px 12px; }
	.cursor { display: none; }
	body { cursor: auto; }
	a, button, input { cursor: pointer; }
}
