/* =========================================================================
   Hub homepage — front-page.php
   Hero + 3D spinning gallery + lightbox + 13 preview mockups + manifesto
   ========================================================================= */

/* ============================================================
   HERO (compact, leads into the wall)
   ============================================================ */
.hub-hero {
	position: relative;
	min-height: 80vh;
	display: flex; align-items: center;
	padding: clamp(80px, 11vw, 140px) 0 clamp(50px, 7vw, 80px);
	overflow: hidden;
}
.hub-hero__gradient {
	position: absolute; inset: 0;
	background:
		radial-gradient(70% 60% at 50% 0%, rgba(34,85,211,.18), transparent 60%),
		radial-gradient(50% 40% at 100% 100%, rgba(5,147,106,.15), transparent 60%);
	pointer-events: none;
}
.hub-hero__grid {
	position: absolute; inset: 0;
	background-image:
		linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
	background-size: 80px 80px;
	mask-image: radial-gradient(80% 60% at 50% 50%, #000, transparent 80%);
	-webkit-mask-image: radial-gradient(80% 60% at 50% 50%, #000, transparent 80%);
	pointer-events: none;
}
.hub-hero__inner {
	position: relative; z-index: 2;
	max-width: 1100px;
	margin: 0 auto;
	padding: 0 max(24px, 5vw);
	width: 100%;
}
.hub-hero__eyebrow { margin-bottom: 24px; }
.hub-hero__title {
	font-family: var(--ac-display);
	font-weight: 800;
	font-size: clamp(2.8rem, 8vw, 6rem);
	line-height: .95;
	text-transform: uppercase;
	letter-spacing: -.025em;
	margin: 0 0 .4em;
}
.hub-hero__title span { display: block; }
.hub-hero__title-accent {
	background: linear-gradient(95deg, var(--ac-blue-hi) 0%, var(--ac-green-hi) 100%);
	-webkit-background-clip: text; background-clip: text;
	color: transparent;
}
.hub-hero__lede {
	max-width: 56ch;
	font-size: clamp(1.05rem, 1.5vw, 1.2rem);
	color: var(--ac-fg-mute);
	line-height: 1.55;
	margin: 0 0 36px;
}
.hub-hero__cta { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 56px; }
.hub-hero__stats {
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px;
	padding-top: 30px;
	border-top: 1px solid rgba(255,255,255,.08);
	margin: 0;
}
@media (max-width: 720px) { .hub-hero__stats { grid-template-columns: 1fr; gap: 18px; } }
.hub-hero__stats div { display: flex; flex-direction: column; gap: 4px; }
.hub-hero__stats dt {
	font-family: var(--ac-mono); font-size: .72rem;
	letter-spacing: .14em; text-transform: uppercase;
	color: var(--ac-fg-dim);
}
.hub-hero__stats dd {
	margin: 0; font-family: var(--ac-display);
	font-size: 1.4rem; letter-spacing: -.005em;
	color: var(--ac-fg);
}

/* ============================================================
   SPINNING GALLERY
   ============================================================ */
.gp {
	padding: clamp(60px, 9vw, 120px) 0;
	background:
		radial-gradient(80% 50% at 50% 50%, rgba(34,85,211,.08), transparent 70%),
		var(--ac-bg);
	overflow: hidden;
	position: relative;
}
.gp__intro {
	text-align: center;
	margin-bottom: 50px;
}
.gp__title {
	font-family: var(--ac-display); font-weight: 800;
	font-size: clamp(2.2rem, 6vw, 4.5rem);
	line-height: .95;
	text-transform: uppercase;
	letter-spacing: -.02em;
	margin: 0 0 .4em;
}
.gp__title em {
	font-style: italic;
	font-family: 'Fraunces', serif;
	font-weight: 400;
	color: var(--ac-green-hi);
}
.gp__lede {
	max-width: 56ch;
	margin: 0 auto;
	font-size: clamp(1rem, 1.4vw, 1.1rem);
	color: var(--ac-fg-mute);
	line-height: 1.55;
}

/* ---------- 3D Stage ---------- */
.gp-stage {
	position: relative;
	height: clamp(440px, 60vh, 600px);
	perspective: 1400px;
	perspective-origin: 50% 45%;
	margin: 0 auto;
	user-select: none;
	cursor: grab;
}
.gp-stage:active { cursor: grabbing; }
.gp-stage::before, .gp-stage::after {
	content: ''; position: absolute; top: 0; bottom: 0;
	width: 18vw; z-index: 5; pointer-events: none;
}
.gp-stage::before {
	left: 0;
	background: linear-gradient(90deg, var(--ac-bg) 0%, transparent 100%);
}
.gp-stage::after {
	right: 0;
	background: linear-gradient(90deg, transparent 0%, var(--ac-bg) 100%);
}

.gp-ring {
	position: absolute; top: 50%; left: 50%;
	width: 320px; height: 200px;
	transform-style: preserve-3d;
	transform: translate(-50%, -50%) rotateY(0deg);
	transition: transform .8s cubic-bezier(.4, 0, .2, 1);
	will-change: transform;
}
.gp-ring.is-dragging { transition: none; }

/* ---------- The cards ---------- */
.gp-card {
	position: absolute; top: 50%; left: 50%;
	width: 320px; height: 380px;
	margin: -190px 0 0 -160px;
	background: #FFFFFF;
	border-radius: 14px;
	border: 0;
	padding: 0;
	cursor: pointer;
	transform: rotateY(var(--angle)) translateZ(min(45vw, 580px));
	transition: filter .35s, box-shadow .35s;
	box-shadow:
		0 30px 60px -20px rgba(0,0,0,.6),
		0 0 0 1px rgba(255,255,255,.05);
	overflow: hidden;
	display: flex; flex-direction: column;
	text-align: left;
	color: inherit;
}
.gp-card:hover {
	box-shadow:
		0 40px 80px -20px rgba(0,0,0,.7),
		0 0 0 2px var(--ac-blue-hi);
	filter: brightness(1.05);
}
@media (max-width: 760px) {
	.gp-card {
		width: 260px; height: 320px;
		margin: -160px 0 0 -130px;
		transform: rotateY(var(--angle)) translateZ(min(56vw, 380px));
	}
}

.gp-card__chrome {
	display: flex; align-items: center; gap: 6px;
	padding: 10px 14px;
	background: #F4F5F7;
	border-bottom: 1px solid #E1E4E8;
	flex: 0 0 auto;
}
.gp-card__dot {
	width: 10px; height: 10px; border-radius: 50%; display: inline-block;
}
.gp-card__dot--r { background: #FF5F57; }
.gp-card__dot--y { background: #FEBC2E; }
.gp-card__dot--g { background: #28C840; }
.gp-card__url {
	flex: 1; text-align: center;
	font-family: var(--ac-mono);
	font-size: .68rem; letter-spacing: .04em;
	color: #6A7280;
	background: rgba(0,0,0,.04);
	padding: 4px 12px;
	border-radius: 100px;
	margin-left: 10px;
	white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.gp-card__view {
	flex: 1;
	position: relative;
	overflow: hidden;
}
.gp-card__bar {
	padding: 12px 14px;
	background: #FFFFFF;
	border-top: 1px solid #E1E4E8;
	display: flex; justify-content: space-between; align-items: center;
	flex: 0 0 auto;
	color: #0A0A0A;
}
.gp-card__bar strong {
	font-family: var(--ac-display); font-weight: 700;
	font-size: .92rem; letter-spacing: -.005em;
	color: #0A0A0A;
}
.gp-card__bar span {
	font-family: var(--ac-mono);
	font-size: .65rem; letter-spacing: .08em;
	text-transform: uppercase;
	color: #6A7280;
}

/* ---------- Controls ---------- */
.gp-controls {
	display: flex; align-items: center; justify-content: center;
	gap: 14px;
	margin-top: 40px;
}
.gp-ctrl {
	width: 48px; height: 48px;
	background: transparent;
	border: 1px solid rgba(255,255,255,.15);
	border-radius: 50%;
	color: var(--ac-fg);
	font-size: 1.2rem;
	cursor: pointer;
	transition: background .25s, border-color .25s, transform .25s;
	display: flex; align-items: center; justify-content: center;
}
.gp-ctrl:hover { background: rgba(255,255,255,.06); border-color: var(--ac-blue-hi); transform: translateY(-2px); }
.gp-ctrl--play { background: var(--ac-blue-hi); border-color: var(--ac-blue-hi); color: var(--ac-bg); }
.gp-ctrl--play:hover { background: var(--ac-green-hi); border-color: var(--ac-green-hi); }
.gp-counter {
	margin-left: 14px;
	font-family: var(--ac-mono); font-size: .82rem; letter-spacing: .08em;
	color: var(--ac-fg-mute);
}

/* ============================================================
   LIGHTBOX
   ============================================================ */
.gp-lb {
	position: fixed; inset: 0;
	z-index: 1000;
	display: none;
	align-items: center; justify-content: center;
	opacity: 0;
	transition: opacity .35s;
}
.gp-lb.is-open { display: flex; opacity: 1; }
.gp-lb__backdrop {
	position: absolute; inset: 0;
	background: rgba(0,0,0,.85);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
}
.gp-lb__close {
	position: absolute; top: 20px; right: 20px;
	width: 48px; height: 48px;
	background: rgba(255,255,255,.1);
	border: 0; border-radius: 50%;
	color: #FFF;
	font-size: 1.8rem; line-height: 1;
	cursor: pointer;
	z-index: 10;
	transition: background .25s, transform .25s;
}
.gp-lb__close:hover { background: rgba(255,255,255,.2); transform: rotate(90deg); }
.gp-lb__inner {
	position: relative;
	z-index: 2;
	display: grid; grid-template-columns: 1.4fr 1fr;
	gap: 30px;
	max-width: 1200px;
	width: 92%;
	max-height: 90vh;
	padding: 24px;
	transform: scale(.94) translateY(20px);
	opacity: 0;
	transition: transform .5s cubic-bezier(.2,.8,.2,1) .1s, opacity .4s .1s;
}
.gp-lb.is-open .gp-lb__inner { transform: scale(1) translateY(0); opacity: 1; }
@media (max-width: 980px) { .gp-lb__inner { grid-template-columns: 1fr; max-height: 92vh; overflow: auto; } }

.gp-lb__frame {
	background: #FFFFFF;
	border-radius: 14px;
	overflow: hidden;
	box-shadow: 0 50px 100px -20px rgba(0,0,0,.7);
	aspect-ratio: 4/3;
	display: flex; flex-direction: column;
}
.gp-lb__chrome {
	display: flex; align-items: center; gap: 6px;
	padding: 12px 18px;
	background: #F4F5F7;
	border-bottom: 1px solid #E1E4E8;
}
.gp-lb__url {
	flex: 1; text-align: center;
	font-family: var(--ac-mono);
	font-size: .78rem; letter-spacing: .04em;
	color: #6A7280;
	background: rgba(0,0,0,.04);
	padding: 6px 16px;
	border-radius: 100px;
	margin-left: 14px;
}
.gp-lb__view {
	flex: 1;
	position: relative;
	overflow: hidden;
}

.gp-lb__side {
	padding: 30px 10px;
	display: flex; flex-direction: column; justify-content: center;
	color: #FFF;
}
.gp-lb__eyebrow {
	font-family: var(--ac-mono); font-size: .78rem;
	letter-spacing: .14em; text-transform: uppercase;
	color: var(--ac-blue-hi); margin: 0 0 14px;
}
.gp-lb__title {
	font-family: var(--ac-display); font-weight: 800;
	font-size: clamp(2rem, 4vw, 2.8rem);
	line-height: 1; text-transform: uppercase;
	letter-spacing: -.02em;
	color: #FFF;
	margin: 0 0 14px;
}
.gp-lb__tag {
	font-size: 1.05rem;
	color: rgba(255,255,255,.7);
	line-height: 1.55;
	margin: 0 0 28px;
}
.gp-lb__cta { align-self: flex-start; margin-bottom: 24px; }
.gp-lb__nav {
	display: flex; gap: 12px;
	padding-top: 20px;
	border-top: 1px solid rgba(255,255,255,.1);
}
.gp-lb__nav button {
	flex: 1;
	background: transparent;
	border: 1px solid rgba(255,255,255,.15);
	color: rgba(255,255,255,.7);
	padding: 12px 14px;
	border-radius: 8px;
	cursor: pointer;
	font-family: var(--ac-sans);
	font-size: .82rem;
	transition: background .25s, color .25s, border-color .25s;
}
.gp-lb__nav button:hover { background: rgba(255,255,255,.06); color: #FFF; border-color: var(--ac-blue-hi); }

/* The lightbox view scales the preview up */
.gp-lb__view .prv { transform: scale(1.4); transform-origin: 50% 50%; }

/* ============================================================
   PREVIEW BASE
   ============================================================ */
.prv {
	position: absolute; inset: 0;
	display: flex; flex-direction: column;
	padding: 16px;
	font-family: var(--ac-sans);
	font-size: 11px;
	overflow: hidden;
}

/* ====== preview: OpenClaw ====== */
.prv--openclaw {
	background: #0E1117;
	color: #C9D1D9;
	font-family: var(--ac-mono);
	padding: 18px;
	justify-content: space-between;
}
.prv__term { font-size: 11px; line-height: 1.6; }
.prv__prompt { color: #58A6FF; }
.prv__line--out { color: #8B949E; }
.prv__line--ok { color: #56D364; }
.prv__caret { animation: prv-blink 1s infinite; }
@keyframes prv-blink { 50% { opacity: 0; } }
.prv__pills {
	display: flex; gap: 6px; flex-wrap: wrap;
	margin-top: 16px;
}
.prv__pills span {
	background: rgba(88,166,255,.1);
	color: #58A6FF;
	padding: 3px 9px;
	border-radius: 100px;
	font-size: 9px; letter-spacing: .04em;
	border: 1px solid rgba(88,166,255,.2);
}

/* ====== preview: Agent Creative ====== */
.prv--ac {
	background: #050811;
	color: #F2F4F8;
	padding: 22px;
	font-family: 'Barlow Condensed', sans-serif;
	font-weight: 800;
	font-size: 2.2rem;
	line-height: 1;
	text-transform: uppercase;
	justify-content: center;
	gap: 8px;
}
.prv__rotator {
	display: flex; align-items: center; gap: 10px;
	overflow: hidden; height: 1em;
	position: relative;
}
.prv__word { color: #444; opacity: .3; }
.prv__word--on {
	color: transparent;
	background: linear-gradient(95deg, #4F8BFF, #1ACB99);
	-webkit-background-clip: text; background-clip: text;
	opacity: 1;
}
.prv__shards { position: absolute; top: 16px; right: 16px; display: flex; gap: 4px; opacity: .5; }
.prv__shards span {
	width: 10px; height: 10px;
	border: 1px solid #4F8BFF;
	transform: rotate(45deg);
}
.prv__lede {
	font-family: 'Fraunces', serif;
	font-weight: 400; font-style: italic;
	font-size: 1rem;
	color: #1ACB99;
	text-transform: none;
	margin-top: 6px;
}

/* ====== preview: Sean Frohman ====== */
.prv--sf {
	background: #EFE8D8;
	color: #1A1A1A;
	padding: 18px;
	justify-content: center; align-items: center;
	font-family: 'Fraunces', serif;
}
.prv__portrait {
	position: relative;
	width: 100px; height: 100px;
	margin-bottom: 14px;
}
.prv__face {
	position: absolute; inset: 0;
	background: radial-gradient(circle at 50% 40%, #F4D6B0 0%, #C99B6A 80%);
	border-radius: 50%;
}
.prv__glasses {
	position: absolute; top: 36px; left: 18px; right: 18px;
	height: 18px;
	border: 2px solid #1A1A1A;
	border-radius: 8px;
}
.prv__glasses::before, .prv__glasses::after {
	content: ''; position: absolute; top: 4px;
	width: 22px; height: 8px;
	border: 2px solid #1A1A1A;
	border-radius: 4px;
}
.prv__glasses::before { left: 4px; }
.prv__glasses::after { right: 4px; }
.prv__shine {
	position: absolute; top: 38px; right: 26px;
	width: 6px; height: 4px;
	background: #FFF;
	border-radius: 2px;
	animation: prv-shine 3s ease-in-out infinite;
}
@keyframes prv-shine { 0%,90%,100% { opacity: .7; } 95% { opacity: 1; box-shadow: 0 0 6px #FFF; } }
.prv__hello {
	font-weight: 500;
	font-size: 1.4rem;
	letter-spacing: -.01em;
}
.prv__role {
	font-family: 'Manrope', sans-serif;
	font-size: .72rem;
	color: #555;
	margin-top: 4px;
}

/* ====== preview: D&L Auto ====== */
.prv--dl {
	background: #11161E;
	color: #F4F5F7;
	padding: 16px;
	justify-content: space-between;
	font-family: 'Oswald', sans-serif;
}
.prv__plate {
	display: inline-flex; align-items: center; gap: 0;
	background: #F4F5F7; color: #11161E;
	border-radius: 4px; overflow: hidden;
	font-weight: 700; align-self: flex-start;
	font-size: .68rem; letter-spacing: .1em;
}
.prv__plate span { background: #4C8BF5; color: #FFF; padding: 3px 6px; }
.prv__plate strong { padding: 3px 10px; }
.prv__bigtitle {
	font-weight: 700;
	font-size: 2rem;
	letter-spacing: .005em;
	text-transform: uppercase;
	color: #F08C1E;
	margin: 12px 0;
	line-height: 1;
}
.prv--dl .prv__tiles {
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 4px;
}
.prv--dl .prv__tiles span {
	background: #1B2330;
	border-left: 2px solid #F08C1E;
	padding: 8px;
	text-align: center;
	font-size: 1.1rem;
	border-radius: 2px;
}
.prv--dl .prv__tiles span:nth-child(2) { border-color: #4C8BF5; }

/* ====== preview: Maison Horlogère ====== */
.prv--mh {
	background:
		radial-gradient(50% 50% at 50% 50%, rgba(201,162,74,.08), transparent 70%),
		#0A0907;
	color: #EFE7D2;
	justify-content: center; align-items: center;
	gap: 16px;
}
.prv__dial {
	width: 130px; height: 130px;
	position: relative;
}
.prv__dial-inner {
	width: 100%; height: 100%;
	border-radius: 50%;
	background: radial-gradient(circle at 30% 30%, #1a1814 0%, #0A0907 70%);
	border: 2px solid #C9A24A;
	box-shadow:
		inset 0 0 16px rgba(0,0,0,.8),
		0 0 0 4px #0A0907,
		0 0 0 5px rgba(201,162,74,.4);
	position: relative;
}
.prv__ix { position: absolute; width: 2px; height: 8px; background: #C9A24A; left: calc(50% - 1px); }
.prv__ix--12 { top: 6px; }
.prv__ix--3 { right: 6px; top: calc(50% - 4px); width: 8px; height: 2px; left: auto; }
.prv__ix--6 { bottom: 6px; top: auto; }
.prv__ix--9 { left: 6px; top: calc(50% - 4px); width: 8px; height: 2px; }
.prv__hand-h {
	position: absolute; left: 50%; bottom: 50%;
	width: 3px; height: 30px;
	background: #C9A24A;
	transform-origin: 50% 100%; transform: translateX(-50%) rotate(45deg);
	border-radius: 2px;
}
.prv__hand-m {
	position: absolute; left: 50%; bottom: 50%;
	width: 2px; height: 45px;
	background: #EFE7D2;
	transform-origin: 50% 100%; transform: translateX(-50%) rotate(180deg);
	border-radius: 1px;
	animation: prv-mh-tick 60s linear infinite;
}
@keyframes prv-mh-tick { to { transform: translateX(-50%) rotate(540deg); } }
@media (prefers-reduced-motion: reduce) { .prv__hand-m { animation: none; } }
.prv__pin {
	position: absolute; left: 50%; top: 50%;
	width: 8px; height: 8px;
	background: #C9A24A;
	border-radius: 50%;
	transform: translate(-50%, -50%);
}
.prv__brand {
	font-family: 'Cormorant Garamond', serif;
	font-size: 1.2rem; letter-spacing: .05em;
}
.prv__brand em { font-style: italic; color: #C9A24A; }

/* ====== preview: Retro Pulse ====== */
.prv--rp {
	background: linear-gradient(180deg, #0E0420 0%, #1B0A3E 60%, #FF2EA6 110%);
	color: #F2E8FF;
	justify-content: flex-end; align-items: center;
	padding-bottom: 30px;
	position: relative; overflow: hidden;
}
.prv__sun {
	position: absolute; bottom: 10%; left: 50%; transform: translateX(-50%);
	width: 100px; height: 100px;
	background: radial-gradient(circle, #FFD23F 0%, #FF6B9D 60%, transparent 80%);
	border-radius: 50%;
	mix-blend-mode: screen;
}
.prv__grid3d {
	position: absolute; bottom: 0; left: -20%; right: -20%; height: 50%;
	background-image:
		linear-gradient(rgba(91,224,255,.6) 1px, transparent 1px),
		linear-gradient(90deg, rgba(91,224,255,.6) 1px, transparent 1px);
	background-size: 30px 30px;
	transform: perspective(200px) rotateX(60deg);
	transform-origin: 50% 100%;
	animation: prv-grid 2s linear infinite;
}
@keyframes prv-grid { from{background-position: 0 0;} to{background-position: 0 30px;} }
@media (prefers-reduced-motion: reduce) { .prv__grid3d { animation: none; } }
.prv__rptitle {
	position: relative;
	font-family: 'Orbitron', sans-serif;
	font-weight: 900;
	font-size: 1.5rem;
	letter-spacing: .05em;
	color: #FFF;
	text-shadow: 0 0 12px #FF2EA6, 0 0 24px rgba(91,224,255,.4);
	z-index: 2;
}
.prv__rpsub {
	font-family: 'Space Mono', monospace;
	font-size: .8rem;
	color: #FFD23F;
	letter-spacing: .3em;
	z-index: 2;
}

/* ====== preview: Fantasma ====== */
.prv--ft {
	background: #0B0014;
	color: #F0E9FF;
	justify-content: center; align-items: center;
	font-family: 'VT323', monospace;
	position: relative;
	overflow: hidden;
}
.prv--ft::before {
	content: ''; position: absolute; inset: 0;
	background: repeating-linear-gradient(180deg, transparent 0 2px, rgba(0,240,255,.08) 2px 3px);
	pointer-events: none;
}
.prv__bootlines {
	font-family: 'Major Mono Display', monospace;
	font-size: .58rem;
	color: #00F0FF;
	letter-spacing: .08em;
	display: flex; flex-direction: column; gap: 2px;
	margin-bottom: 18px;
}
.prv__fttitle {
	position: relative;
	font-family: 'Major Mono Display', monospace;
	font-size: 2.2rem;
	letter-spacing: .04em;
	color: #F0E9FF;
}
.prv__fttitle::before, .prv__fttitle::after {
	content: attr(data-text);
	position: absolute; inset: 0;
	mix-blend-mode: screen;
}
.prv__fttitle::before { color: #FF2E63; transform: translate(-2px, 0); }
.prv__fttitle::after { color: #00F0FF; transform: translate(2px, 0); }
.prv__fttags {
	font-family: 'Major Mono Display', monospace;
	font-size: .58rem;
	color: #FFD23F;
	margin-top: 12px;
	letter-spacing: .08em;
}

/* ====== preview: Electricon ====== */
.prv--ec {
	background:
		radial-gradient(60% 80% at 70% 30%, rgba(0,229,168,.15), transparent 60%),
		#0B1220;
	color: #E7F1FF;
	font-family: 'IBM Plex Sans', sans-serif;
	padding: 18px;
	justify-content: space-between;
	position: relative;
}
.prv__ecvan {
	position: absolute; bottom: 60px; left: 18px;
	width: 80px; height: 50px;
}
.prv__ecvan-body {
	width: 100%; height: 32px;
	background: linear-gradient(180deg, #00E5A8 0%, #00B589 100%);
	border-radius: 6px 4px 2px 2px;
	margin-top: 14px;
}
.prv__ecvan-cab {
	position: absolute; top: 0; right: 4px;
	width: 30px; height: 18px;
	background: #00C094;
	border-radius: 6px 4px 0 0;
}
.prv__ecvan-w {
	position: absolute; bottom: -4px;
	width: 12px; height: 12px;
	background: #111; border-radius: 50%;
	border: 2px solid #333;
}
.prv__ecvan-w--f { left: 8px; }
.prv__ecvan-w--b { right: 8px; }
.prv__ecbolt {
	position: absolute; top: 60px; left: 95px;
	width: 24px; height: 24px;
	background: #FFD23F; color: #0B1220;
	display: flex; align-items: center; justify-content: center;
	border-radius: 50%;
	font-size: .8rem; font-weight: 700;
	box-shadow: 0 0 10px rgba(255,210,63,.6);
	animation: prv-ec-bolt 1.6s ease-in-out infinite;
}
@keyframes prv-ec-bolt { 50% { transform: scale(1.15); } }
@media (prefers-reduced-motion: reduce) { .prv__ecbolt { animation: none; } }
.prv__ecbatt {
	position: absolute; top: 20px; right: 20px;
	width: 60px; height: 22px;
	border: 2px solid #00E5A8;
	border-radius: 3px;
	padding: 2px;
	position: absolute;
}
.prv__ecbatt::after {
	content: ''; position: absolute; right: -6px; top: 5px;
	width: 4px; height: 8px;
	background: #00E5A8;
	border-radius: 0 2px 2px 0;
}
.prv__ecbatt-fill {
	width: 80%; height: 100%;
	background: linear-gradient(90deg, #00E5A8, #FFD23F);
	border-radius: 1px;
	animation: prv-ec-fill 5s ease-in-out infinite;
}
@keyframes prv-ec-fill { 0%{width: 0;} 80%{width: 80%;} 100%{width: 80%;} }
@media (prefers-reduced-motion: reduce) { .prv__ecbatt-fill { animation: none; } }
.prv__ectitle {
	margin-top: auto;
	font-family: 'IBM Plex Sans', sans-serif;
	font-weight: 700;
	font-size: 1.1rem;
	line-height: 1.05;
	letter-spacing: -.01em;
	background: linear-gradient(95deg, #00E5A8, #FFD23F);
	-webkit-background-clip: text; background-clip: text;
	color: transparent;
}

/* ====== preview: Handyguys ====== */
.prv--hg {
	background: #FFF4D6;
	color: #1B1108;
	padding: 18px;
	justify-content: center; align-items: center;
	font-family: 'Plus Jakarta Sans', sans-serif;
	position: relative;
}
.prv__hghat {
	position: relative;
	width: 70px; height: 60px;
	margin-bottom: 12px;
	animation: prv-hg-float 2.6s ease-in-out infinite;
}
@keyframes prv-hg-float { 50% { transform: translateY(-6px); } }
@media (prefers-reduced-motion: reduce) { .prv__hghat { animation: none; } }
.prv__hghat-top {
	position: absolute; top: 0; left: 10%; right: 10%; height: 70%;
	background: radial-gradient(ellipse at 30% 20%, #FFE066 0%, #F5B400 50%, #C98A00 100%);
	border-radius: 50% 50% 30% 30% / 60% 60% 40% 40%;
	box-shadow: inset -4px -8px 12px rgba(0,0,0,.15);
}
.prv__hghat-brim {
	position: absolute; bottom: 0; left: 0; right: 0; height: 14px;
	background: linear-gradient(180deg, #F5B400 0%, #B07A00 100%);
	border-radius: 50%;
}
.prv__hggreet {
	font-family: 'Caveat', cursive;
	font-size: 1.2rem;
	color: #E5392B;
	transform: rotate(-2deg);
	margin-bottom: 2px;
}
.prv__hgtitle {
	font-family: 'Archivo Black', sans-serif;
	font-size: 2rem;
	letter-spacing: -.02em;
	color: #1B1108;
	line-height: 1;
}
.prv__hgsub {
	font-family: 'Archivo Black', sans-serif;
	font-size: .82rem;
	color: #1B1108;
	margin-top: 4px;
	text-align: center;
}
.prv__hgsub em {
	font-style: normal;
	background: #F5B400;
	padding: 0 4px;
}

/* ====== preview: Heritage Motors ====== */
.prv--hm {
	background:
		radial-gradient(70% 60% at 50% 100%, rgba(184,133,42,.15), transparent 60%),
		#15110D;
	color: #F1E7D2;
	padding: 22px;
	justify-content: space-between; align-items: center;
	font-family: 'Bodoni Moda', serif;
	position: relative;
}
.prv__hmcar {
	position: relative;
	width: 160px; height: 60px;
	margin-top: 14px;
}
.prv__hmcar-body {
	width: 100%; height: 30px;
	background: linear-gradient(180deg, #C8493B 0%, #8A2A20 100%);
	border-radius: 14px 24px 4px 4px;
	margin-top: 16px;
	box-shadow: 0 4px 10px -4px rgba(0,0,0,.6);
}
.prv__hmcar-roof {
	position: absolute; top: 0; left: 28%; right: 18%;
	height: 22px;
	background: linear-gradient(180deg, #8A2A20 0%, #5A1810 100%);
	border-radius: 14px 8px 0 0;
}
.prv__hmcar-w {
	position: absolute; bottom: -6px;
	width: 18px; height: 18px;
	background: radial-gradient(circle at 30% 30%, #444, #111);
	border-radius: 50%;
	border: 1px solid #222;
}
.prv__hmcar-w--f { left: 16px; }
.prv__hmcar-w--b { right: 16px; }
.prv__hmtitle {
	font-family: 'Bodoni Moda', serif;
	font-weight: 400;
	font-size: 1.8rem;
	letter-spacing: -.01em;
	color: #F1E7D2;
}
.prv__hmtitle em { font-style: italic; color: #B8852A; }
.prv__hmsub {
	font-family: 'Bodoni Moda', serif;
	font-style: italic;
	font-size: .72rem; letter-spacing: .2em;
	color: #B5A988;
	text-transform: uppercase;
	margin-top: 4px;
}

/* ====== preview: A. Knox ====== */
.prv--ak {
	background: #F2F0EC;
	color: #0A0A0A;
	padding: 18px;
	font-family: 'Archivo', sans-serif;
	display: grid;
	grid-template-columns: auto 1fr;
	grid-template-rows: auto 1fr auto;
	gap: 8px 16px;
	position: relative;
}
.prv__akmark {
	font-family: 'Archivo Black', sans-serif;
	font-size: 2rem; line-height: 1;
	grid-row: 1;
}
.prv__aktitle {
	font-family: 'Archivo Black', sans-serif;
	font-size: 1.8rem; line-height: .95;
	letter-spacing: -.03em;
	grid-column: 2; grid-row: 1;
}
.prv__aksub {
	font-family: 'Archivo', sans-serif;
	font-weight: 800;
	font-size: .8rem;
	line-height: 1.15;
	color: #2A2A2A;
	grid-column: 1 / -1; grid-row: 2;
	align-self: center;
	border-top: 1px solid #0A0A0A;
	padding-top: 12px;
	margin-top: 8px;
}
.prv__akhot {
	grid-column: 1 / -1; grid-row: 3;
	height: 30px;
	background: #FF3B00;
}

/* ====== preview: La Vela ====== */
.prv--lv {
	background:
		radial-gradient(50% 60% at 30% 30%, rgba(217,108,54,.2), transparent 60%),
		#1A0E07;
	color: #F2E4CF;
	padding: 18px;
	justify-content: flex-end;
	font-family: 'DM Serif Display', serif;
	position: relative;
	overflow: hidden;
}
.prv__lvflame {
	position: absolute; top: 16px; left: 24px;
	width: 14px; height: 22px;
	background: radial-gradient(ellipse at 50% 65%, #FFE680 0%, #F2C77E 35%, #D96C36 70%, transparent 100%);
	border-radius: 50% 50% 35% 35% / 60% 60% 40% 40%;
	filter: blur(.5px);
	animation: prv-lv-flame 1.2s ease-in-out infinite;
	transform-origin: 50% 100%;
}
@keyframes prv-lv-flame {
	0%, 100% { transform: scale(1,1) skewX(0deg); }
	25%      { transform: scale(.95,1.05) skewX(2deg); }
	50%      { transform: scale(1.05,.95) skewX(-3deg); }
	75%      { transform: scale(.92,1.08) skewX(1deg); }
}
@media (prefers-reduced-motion: reduce) { .prv__lvflame { animation: none; } }
.prv__lvglow {
	position: absolute; top: -10px; left: -20px;
	width: 120px; height: 120px;
	background: radial-gradient(circle, rgba(242,199,126,.3) 0%, transparent 60%);
	border-radius: 50%;
	filter: blur(20px);
}
.prv__lvscript {
	font-family: 'Allura', cursive;
	font-size: 2rem; line-height: 1;
	color: #D96C36;
}
.prv__lvtitle {
	font-family: 'DM Serif Display', serif;
	font-size: 2.6rem; line-height: 1;
	letter-spacing: -.02em;
	color: #F2E4CF;
	margin-bottom: 12px;
}
.prv__lvmenu {
	display: grid; grid-template-columns: 1fr auto;
	gap: 4px 12px;
	border-top: 1px dotted rgba(217,108,54,.4);
	padding-top: 8px;
}
.prv__lvmenu span {
	font-style: italic;
	font-size: .82rem;
	color: #C8B89C;
}
.prv__lvmenu em {
	font-style: normal;
	font-family: 'DM Sans', sans-serif;
	font-size: .78rem;
	color: #D96C36;
}

/* ====== preview: Forge ====== */
.prv--fg {
	background: #0A0A0A;
	color: #F4F4F0;
	padding: 18px;
	justify-content: center; align-items: flex-start;
	font-family: 'Anton', sans-serif;
	position: relative;
	overflow: hidden;
}
.prv__fgstrip {
	position: absolute; top: 30%; left: -10%; right: -10%;
	font-size: 2.5rem; line-height: 1;
	letter-spacing: .02em;
	color: rgba(255,90,31,.12);
	white-space: nowrap;
	transform: rotate(-2deg);
}
.prv__fgtitle {
	position: relative; z-index: 1;
	line-height: .9;
	letter-spacing: .005em;
	text-transform: uppercase;
}
.prv__fgtitle span {
	display: block;
	font-size: 2rem;
}
.prv__fgaccent { color: #FF5A1F; }
.prv__fgstroke {
	color: transparent;
	-webkit-text-stroke: 1.5px #F4F4F0;
}

/* ============================================================
   MANIFESTO
   ============================================================ */
.hub-manifesto {
	background: #06090F;
	padding: clamp(80px, 12vw, 160px) 0;
}
.hub-manifesto__inner {
	display: grid; grid-template-columns: 1fr 1.2fr; gap: 80px; align-items: start;
}
@media (max-width: 980px) { .hub-manifesto__inner { grid-template-columns: 1fr; gap: 40px; } }
.hub-manifesto__sticky {
	position: sticky; top: 100px;
}
@media (max-width: 980px) { .hub-manifesto__sticky { position: static; } }
.hub-manifesto__title {
	font-family: var(--ac-display); font-weight: 800;
	font-size: clamp(2rem, 5vw, 3.6rem);
	line-height: 1; text-transform: uppercase;
	letter-spacing: -.025em;
	margin: 12px 0 24px;
}
.hub-manifesto__title span {
	background: linear-gradient(95deg, var(--ac-blue-hi) 0%, var(--ac-green-hi) 100%);
	-webkit-background-clip: text; background-clip: text;
	color: transparent;
}
.hub-manifesto__rest {
	max-width: 50ch;
	color: var(--ac-fg-mute);
	line-height: 1.6;
	font-size: 1.05rem;
}
.hub-manifesto__rest em { color: var(--ac-blue-hi); font-style: italic; font-family: 'Fraunces', serif; }
.hub-manifesto__scroll { display: flex; flex-direction: column; gap: 24px; }
.hub-belief {
	background: rgba(255,255,255,.02);
	border: 1px solid rgba(255,255,255,.05);
	border-left: 3px solid var(--ac-blue-hi);
	border-radius: 8px;
	padding: 28px;
	transition: transform .35s var(--ac-ease-out), border-color .25s;
}
.hub-belief:hover { transform: translateX(4px); border-left-color: var(--ac-green-hi); }
.hub-belief__num {
	font-family: var(--ac-mono); font-size: .78rem; letter-spacing: .12em;
	color: var(--ac-green-hi); margin-bottom: 14px;
}
.hub-belief h3 {
	font-family: var(--ac-display); font-weight: 800;
	font-size: 1.3rem; text-transform: uppercase;
	letter-spacing: -.005em;
	margin: 0 0 10px; color: var(--ac-fg);
}
.hub-belief p {
	margin: 0;
	color: var(--ac-fg-mute);
	line-height: 1.55;
	font-size: .98rem;
}

/* ============================================================
   ADDITIONAL PREVIEWS (cases 14–22)
   ============================================================ */

/* Tighten card sizes for larger ring (22 cards) */
@media (min-width: 980px) {
	.gp-ring { width: 280px; }
	.gp-card { width: 280px; height: 340px; margin: -170px 0 0 -140px; transform: rotateY(var(--angle)) translateZ(min(60vw, 780px)); }
}

/* ====== preview: Rosenberg & Hite ====== */
.prv--rh { background: linear-gradient(180deg, #14141A 0%, #0E0E10 100%); color: #F2EAD3; padding: 18px; justify-content: flex-end; font-family: 'Fraunces', serif; position: relative; overflow: hidden; }
.prv__rhrain { position: absolute; inset: 0; background-image: repeating-linear-gradient(95deg, transparent 0 6px, rgba(178,193,210,.25) 6px 7px, transparent 7px 12px); opacity: .35; animation: prv-rh-rain 1.4s linear infinite; mask-image: linear-gradient(180deg, transparent, #000 30%); -webkit-mask-image: linear-gradient(180deg, transparent, #000 30%); }
@keyframes prv-rh-rain { from{transform:translate(0,0);} to{transform:translate(-30px,160px);} }
@media (prefers-reduced-motion: reduce) { .prv__rhrain { animation: none; } }
.prv__rhskyline { position: absolute; bottom: 0; left: 0; right: 0; height: 40%; background: repeating-linear-gradient(90deg, #1F1F26 0 40px, #15151A 40px 72px); clip-path: polygon(0 50%, 10% 30%, 22% 45%, 35% 20%, 50% 38%, 65% 25%, 78% 45%, 90% 30%, 100% 40%, 100% 100%, 0 100%); }
.prv__rhfigure { position: absolute; bottom: 18%; left: 45%; width: 30px; height: 50px; }
.prv__rhumbrella { position: absolute; top: 0; left: 50%; transform: translateX(-50%); width: 28px; height: 12px; background: #0A0A0C; border-radius: 50% 50% 0 0 / 100% 100% 0 0; }
.prv__rhbody { position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); width: 10px; height: 30px; background: #0A0A0C; border-radius: 5px 5px 2px 2px; }
.prv__rhsign { position: absolute; top: 24%; right: 8%; font-family: 'Fraunces', serif; font-style: italic; font-size: .7rem; letter-spacing: .12em; color: #C9A24A; text-shadow: 0 0 8px rgba(201,162,74,.6); z-index: 2; }
.prv__rhtag { position: relative; z-index: 2; font-family: 'JetBrains Mono', monospace; font-size: .62rem; letter-spacing: .12em; color: #C9A24A; }

/* ====== preview: CT Electric ====== */
.prv--cte { background: radial-gradient(70% 70% at 70% 30%, rgba(229,57,43,.08), transparent 60%), #F5EFE6; color: #0A0A0A; padding: 16px; font-family: 'Archivo Black', sans-serif; justify-content: space-between; position: relative; }
.prv__ctebolt { position: absolute; top: 12px; right: 18px; font-size: 3.6rem; color: #F5B400; filter: drop-shadow(0 4px 10px rgba(245,180,0,.5)); animation: prv-cte-bolt 2.2s ease-in-out infinite; }
@keyframes prv-cte-bolt { 50% { transform: rotate(8deg) scale(1.08); } }
@media (prefers-reduced-motion: reduce) { .prv__ctebolt { animation: none; } }
.prv__ctetitle { display: flex; flex-direction: column; gap: 4px; margin-top: auto; line-height: .92; text-transform: uppercase; }
.prv__ctetitle span { display: block; font-size: 1.5rem; letter-spacing: -.015em; }
.prv__cteright { color: #E5392B; }
.prv__ctesub { font-family: 'JetBrains Mono', monospace; font-size: .62rem; letter-spacing: .14em; color: #4A4438; margin-top: 8px; }

/* ====== preview: Gooden ====== */
.prv--gd { background: radial-gradient(60% 60% at 70% 30%, rgba(244,197,66,.1), transparent 60%), #1A4D2E; color: #F0E7D2; padding: 16px; font-family: 'Anton', sans-serif; justify-content: space-between; position: relative; }
.prv__gdbadge { position: absolute; top: 14px; right: 14px; width: 56px; height: 56px; background: radial-gradient(circle at 30% 30%, #F4C542 0%, #C89800 100%); border-radius: 50%; display: flex; align-items: center; justify-content: center; box-shadow: 0 6px 18px -6px rgba(244,197,66,.6); animation: prv-gd-spin 18s linear infinite; }
@keyframes prv-gd-spin { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce) { .prv__gdbadge { animation: none; } }
.prv__gdmark { font-size: 1.5rem; }
.prv__gdtitle { margin-top: auto; line-height: .9; text-transform: uppercase; letter-spacing: .005em; }
.prv__gdtitle span { display: block; font-size: 1.4rem; }
.prv__gdtitle em { font-style: italic; color: #F4C542; font-family: 'Fraunces', serif; font-weight: 400; }
.prv__gdgrit { color: #F4C542; }
.prv__gdsub { font-family: 'JetBrains Mono', monospace; font-size: .62rem; letter-spacing: .12em; color: #C8C4B0; margin-top: 8px; }

/* ====== preview: Mastri Appliance ====== */
.prv--ma { background: #FFFEFA; color: #0F1B3D; padding: 16px; font-family: 'Oswald', sans-serif; justify-content: space-between; position: relative; overflow: hidden; }
.prv__mastripes { position: absolute; top: 0; right: -20px; width: 90px; height: 100%; background: repeating-linear-gradient(180deg, #C8102E 0 8px, #FFFEFA 8px 14px, #0F1B3D 14px 22px, #FFFEFA 22px 28px); opacity: .15; transform: skewX(-10deg); }
.prv__matitle { margin-top: auto; line-height: .95; text-transform: uppercase; font-weight: 700; }
.prv__matitle span { display: block; font-size: 1.4rem; letter-spacing: -.01em; }
.prv__mared { color: #C8102E; }
.prv__mastars { color: #FFD700; font-size: 1.1rem; letter-spacing: .15em; margin-top: 8px; }
.prv__masub { font-family: 'JetBrains Mono', monospace; font-size: .54rem; letter-spacing: .12em; color: #4A4F66; margin-top: 6px; font-weight: 400; }

/* ====== preview: Mastri Financial ====== */
.prv--mf { background: radial-gradient(60% 50% at 50% 30%, rgba(201,162,74,.1), transparent 60%), #0E1726; color: #EDE5D0; padding: 18px; font-family: 'Cormorant Garamond', serif; justify-content: space-between; align-items: center; position: relative; }
.prv__mfemblem { width: 80px; height: 80px; border-radius: 50%; background: radial-gradient(circle at 30% 30%, #D9B25A 0%, #8A6A1E 100%); display: flex; align-items: center; justify-content: center; box-shadow: 0 8px 20px -8px rgba(201,162,74,.6); margin-top: 16px; position: relative; }
.prv__mfemblem::before { content: ''; position: absolute; inset: -8px; border: 1px dashed #C9A24A; border-radius: 50%; opacity: .4; animation: prv-mf-spin 20s linear infinite; }
@keyframes prv-mf-spin { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce) { .prv__mfemblem::before { animation: none; } }
.prv__mfemblem span { font-family: 'Cormorant Garamond', serif; font-size: 2.4rem; color: #0E1726; font-weight: 500; }
.prv__mftitle { text-align: center; line-height: 1; }
.prv__mftitle span { display: block; }
.prv__mfital em { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 1.6rem; color: #C9A24A; }
.prv__mftitle span:last-child { font-family: 'Cormorant Garamond', serif; font-weight: 500; font-size: 1.1rem; letter-spacing: .12em; color: #EDE5D0; margin-top: 2px; }
.prv__mfdata { font-family: 'JetBrains Mono', monospace; font-size: .52rem; letter-spacing: .14em; color: #C9A24A; text-align: center; }

/* ====== preview: Voyages ====== */
.prv--vy { background: radial-gradient(80% 60% at 50% 30%, #1B1240 0%, #070710 70%); color: #F2F4F8; padding: 20px; font-family: 'Fraunces', serif; justify-content: flex-end; position: relative; overflow: hidden; }
.prv__vystars { position: absolute; inset: 0; pointer-events: none; }
.prv__vystars span { position: absolute; width: 2px; height: 2px; background: #FFF; border-radius: 50%; opacity: .4; animation: prv-vy-twinkle 3s ease-in-out infinite; }
@keyframes prv-vy-twinkle { 0%,100%{ opacity: .2; } 50%{ opacity: 1; transform: scale(1.4); } }
@media (prefers-reduced-motion: reduce) { .prv__vystars span { animation: none; } }
.prv__vytitle { position: relative; z-index: 2; line-height: 1; }
.prv__vytitle span { display: block; }
.prv__vytitle span:first-child { font-family: 'Fraunces', serif; font-weight: 400; font-size: 2rem; letter-spacing: -.015em; }
.prv__vyital em { font-style: italic; font-family: 'Fraunces', serif; font-size: 1rem; color: transparent; background: linear-gradient(95deg, #7AB8FF, #FFD891); -webkit-background-clip: text; background-clip: text; margin-top: 6px; display: inline-block; }

/* ====== preview: Meridian ====== */
.prv--md { background: radial-gradient(70% 60% at 70% 50%, rgba(142,90,28,.08), transparent 60%), #F3EDE0; color: #1B1410; padding: 18px; font-family: 'Fraunces', serif; justify-content: space-between; align-items: center; position: relative; }
.prv__mdclock { width: 110px; height: 110px; border-radius: 50%; background: radial-gradient(circle at 30% 30%, #FFFEFA 0%, #E5DCC5 100%); border: 2px solid #1B1410; position: relative; margin-top: 16px; box-shadow: 0 10px 30px -10px rgba(0,0,0,.3); }
.prv__mdh { position: absolute; left: 50%; bottom: 50%; width: 3px; height: 26px; background: #1B1410; transform-origin: 50% 100%; transform: translateX(-50%) rotate(45deg); border-radius: 2px; }
.prv__mdm { position: absolute; left: 50%; bottom: 50%; width: 2.5px; height: 38px; background: #1B1410; transform-origin: 50% 100%; transform: translateX(-50%) rotate(180deg); border-radius: 1px; animation: prv-md-m 60s linear infinite; }
.prv__mds { position: absolute; left: 50%; bottom: 50%; width: 1.5px; height: 44px; background: #8E5A1C; transform-origin: 50% 100%; transform: translateX(-50%) rotate(90deg); border-radius: 1px; animation: prv-md-s 60s steps(60) infinite; }
@keyframes prv-md-m { to { transform: translateX(-50%) rotate(540deg); } }
@keyframes prv-md-s { to { transform: translateX(-50%) rotate(450deg); } }
@media (prefers-reduced-motion: reduce) { .prv__mdm, .prv__mds { animation: none; } }
.prv__mdpin { position: absolute; left: 50%; top: 50%; width: 7px; height: 7px; background: #8E5A1C; border-radius: 50%; transform: translate(-50%, -50%); }
.prv__mdtitle em { font-family: 'Fraunces', serif; font-style: italic; font-weight: 500; font-size: 1.8rem; color: #8E5A1C; }
.prv__mdsub { font-family: 'JetBrains Mono', monospace; font-size: .62rem; letter-spacing: .12em; color: #4A3E2A; text-transform: uppercase; }

/* ====== preview: Halton & Voss ====== */
.prv--hv { background: #FAFAFA; color: #0A0A0A; padding: 16px; font-family: 'Archivo Black', sans-serif; position: relative; overflow: hidden; }
.prv__hvgrid { position: absolute; inset: 0; display: grid; grid-template-columns: repeat(12, 1fr); pointer-events: none; }
.prv__hvgrid span { border-right: 1px solid rgba(0,0,0,.04); }
.prv__hvgrid span:last-child { border-right: 0; }
.prv__hvmeta { position: relative; z-index: 2; font-family: 'IBM Plex Mono', monospace; font-size: .62rem; letter-spacing: .14em; padding-bottom: 8px; border-bottom: 1px solid #0A0A0A; margin-bottom: 16px; }
.prv__hvtitle { position: relative; z-index: 2; line-height: .9; letter-spacing: -.04em; text-transform: uppercase; display: flex; flex-wrap: wrap; align-items: baseline; gap: 8px; }
.prv__hvtitle span { display: inline-block; font-size: 1.8rem; }
.prv__hvnum { font-family: 'IBM Plex Mono', monospace; font-size: .56rem !important; letter-spacing: .04em; color: #0A0A0A; background: #E8FF00; padding: 3px 8px; margin-right: 4px; }
.prv__hvamp { color: #E8FF00; }

/* ====== preview: agentcreative.io v1 ====== */
.prv--av1 { background: radial-gradient(50% 50% at 50% 50%, rgba(0,127,255,.04), transparent 60%), #FAFBFC; color: #0A0A0A; padding: 18px; font-family: 'Inter', sans-serif; justify-content: space-between; align-items: center; }
.prv__av1mock { background: #FFF; border-radius: 12px; box-shadow: 0 14px 30px -12px rgba(0,0,0,.2); border: 1px solid rgba(0,0,0,.06); overflow: hidden; width: 90%; margin-top: 18px; }
.prv__av1bar { height: 18px; background: linear-gradient(180deg, #FAFBFC 0%, #F2F4F8 100%); border-bottom: 1px solid #E1E4E8; position: relative; }
.prv__av1bar::before { content: ''; position: absolute; top: 50%; left: 8px; transform: translateY(-50%); width: 6px; height: 6px; border-radius: 50%; background: #FF5F57; box-shadow: 10px 0 0 #FEBC2E, 20px 0 0 #28C840; }
.prv__av1cells { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; padding: 12px; }
.prv__av1cells div { background: #FAFBFC; border-radius: 6px; padding: 10px 8px; text-align: center; }
.prv__av1cells strong { display: block; font-weight: 700; font-size: 1rem; color: #007FFF; letter-spacing: -.01em; }
.prv__av1cells div:nth-child(2) strong, .prv__av1cells div:nth-child(3) strong { color: #FFA500; }
.prv__av1cells span { font-family: 'JetBrains Mono', monospace; font-size: .54rem; letter-spacing: .08em; color: #6A7280; text-transform: uppercase; }
.prv__av1tag { font-family: 'JetBrains Mono', monospace; font-size: .68rem; letter-spacing: .14em; color: #007FFF; text-transform: uppercase; }

/* ============================================================
   REAL SCREENSHOTS — gallery tile + lightbox
   When assets/img/screens/{slug}.png exists, wac_render_preview()
   outputs <img class="gp-card__shot"> instead of the CSS mockup.
   ============================================================ */
.gp-card__shot {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: top center;
	display: block;
}
/* In the lightbox, show the real site like a tall browser viewport that
   reveals more of the page on hover-scroll. */
.gp-lb__view .gp-card__shot {
	height: auto;
	min-height: 100%;
	object-fit: cover;
	object-position: top center;
	transition: object-position 4s ease;
}
.gp-lb__frame:hover .gp-card__shot {
	object-position: bottom center;
}
@media (prefers-reduced-motion: reduce) {
	.gp-lb__view .gp-card__shot { transition: none; }
}

/* ============================================================
   CASE-PAGE SCREENSHOT BAND (full-bleed, top of every case page
   that has a real screenshot — injected centrally via header.php)
   ============================================================ */
.wac-shotband {
	position: relative;
	width: 100%;
	background: #08090c;
	border-bottom: 1px solid rgba(255,255,255,.08);
	overflow: hidden;
}
.wac-shotband__frame {
	max-width: 1240px;
	margin: 0 auto;
	padding: clamp(24px, 5vw, 64px) clamp(16px, 4vw, 48px) 0;
}
.wac-shotband__chrome {
	display: flex;
	align-items: center;
	gap: 8px;
	background: #1b1d22;
	border-radius: 12px 12px 0 0;
	padding: 12px 16px;
	border: 1px solid rgba(255,255,255,.08);
	border-bottom: 0;
}
.wac-shotband__dot { width: 11px; height: 11px; border-radius: 50%; }
.wac-shotband__dot--r { background: #ff5f57; }
.wac-shotband__dot--y { background: #febc2e; }
.wac-shotband__dot--g { background: #28c840; }
.wac-shotband__url {
	margin-left: 12px;
	font-family: 'JetBrains Mono', monospace;
	font-size: .8rem;
	color: #9aa0aa;
	letter-spacing: .02em;
}
.wac-shotband__live {
	margin-left: auto;
	font-family: 'JetBrains Mono', monospace;
	font-size: .72rem;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: #28c840;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.wac-shotband__live::before {
	content: '';
	width: 7px; height: 7px; border-radius: 50%;
	background: #28c840;
	box-shadow: 0 0 8px #28c840;
}
.wac-shotband__live:hover { color: #5cff7a; }
.wac-shotband__imgwrap {
	border: 1px solid rgba(255,255,255,.08);
	border-radius: 0 0 12px 12px;
	overflow: hidden;
	max-height: 70vh;
	box-shadow: 0 40px 90px -40px rgba(0,0,0,.8);
}
.wac-shotband__img {
	width: 100%;
	display: block;
	object-fit: cover;
	object-position: top center;
}
