name: mindloop-landing description: "Use this plugin when the user wants a dark, pure-monochrome newsletter / content-platform landing page (Mindloop): fullscreen video hero, Instrument-Serif italic accent words, liquid-glass controls, scroll-driven word-by-word mission reveal, and an HLS-video CTA. Invoke for 'Mindloop landing', 'black monochrome newsletter landing page', 'video hero content platform', or when the user references the Mindloop template." version: 0.1.0 od: mode: prototype surface: web scenario: design preview: type: html entry: example.html design_system: requires: false
Mindloop — Dark Monochrome Content-Platform Landing
Produce a premium, pure-black monochrome landing page for Mindloop, a newsletter / content platform. A complete, rendered reference implementation ships beside this skill at example.html — start from it. Copy example.html, then adjust copy and data; do not rewrite the CSS or invent a new visual language. The seed already encodes the exact HSL tokens, liquid-glass treatment, fonts, section layout, fadeUp reveal, scroll-driven mission reveal, and the HLS CTA.
This is the authoritative build brief. Follow it exactly — the HSL variables, fonts, video URLs, and animation patterns are locked.
Monochrome is hard-locked. Background is pure black #000 (0 0% 0%), foreground pure white. There are no colors or gradients beyond monochrome — the only non-grey token is --accent: 170 15% 45% (a muted teal-grey) and it is essentially unused in the visible UI. Do not introduce brand colors, blues, purples, or vivid gradients.
Assets (critical): example.html already ships the 3 hero avatars and the 3 platform icons (ChatGPT / Perplexity / Google AI) as inlined data:image/svg+xml;base64,… URIs. Keep them exactly as they are. Do not swap them for i.pravatar.cc, api.dicebear.com, dicebear, or any other remote avatar / icon host — external hosts rate-limit or 403 inside the preview sandbox and render broken. Only replace an asset if the user supplies a real image, and prefer a data URI over a remote URL. The four large background videos stay on their stable cloudfront.net / stream.mux.com CDNs.
Stack
- Default output: a single self-contained HTML file (the
example.htmlseed). It already includes everything inline. - If the user explicitly asks for the full project, port the seed faithfully to React + Vite + TypeScript + Tailwind CSS + shadcn/ui + Framer Motion. Same tokens, same markup structure. Install
hls.jsandframer-motion. Fonts via@fontsource/inter(400, 500, 600, 700) and@fontsource/instrument-serif(400, 400-italic).lucide-reactfor icons.tailwindcss-animateplugin. Do not change the design while porting. - Motion loading (locked). If you emit a single self-contained inline-JSX file instead of the Vite project, Motion's React hooks (
useScroll,useTransform,useAnimationFrame, …) exist only in the React UMD build: load<script src="https://unpkg.com/framer-motion@11.11.13/dist/framer-motion.js"></script>and read them offwindow.Motion— never the vanillahttps://unpkg.com/motion@.../dist/motion.jsDOM bundle, which lacksuseScrolland renders a blank page. (The Vite project imports from npm and is unaffected.)
Fonts
- Inter (sans) — body and UI, weights 400/500/600/700.
- Instrument Serif (serif, italic) — used ONLY for the italic accent word inside headings (
.serif:font-style: italic; font-weight: 400). Loaded from Google Fonts in the seed;@fontsource/instrument-serifin the React port.
Design System — locked HSL tokens (:root, values only, no hsl() wrapper)
--background: 0 0% 0%
--foreground: 0 0% 100%
--card: 0 0% 5%
--card-foreground: 0 0% 100%
--primary: 0 0% 100%
--primary-foreground: 0 0% 0%
--secondary: 0 0% 12%
--secondary-foreground: 0 0% 85%
--muted: 0 0% 15%
--muted-foreground: 0 0% 65%
--accent: 170 15% 45%
--accent-foreground: 0 0% 100%
--border: 0 0% 20%
--input: 0 0% 18%
--ring: 0 0% 40%
--hero-subtitle: 210 17% 95%
Consume tokens via hsl(var(--token)) / hsl(var(--token) / 0.3).
Liquid Glass (.liquid-glass) — locked
.liquid-glass {
background: rgba(255, 255, 255, 0.01);
background-blend-mode: luminosity;
backdrop-filter: blur(4px);
-webkit-backdrop-filter: blur(4px);
border: none;
box-shadow: inset 0 1px 1px rgba(255, 255, 255, 0.1);
position: relative;
overflow: hidden;
}
.liquid-glass::before {
content: '';
position: absolute; inset: 0; border-radius: inherit; padding: 1.4px;
background: linear-gradient(180deg,
rgba(255,255,255,0.45) 0%, rgba(255,255,255,0.15) 20%,
rgba(255,255,255,0) 40%, rgba(255,255,255,0) 60%,
rgba(255,255,255,0.15) 80%, rgba(255,255,255,0.45) 100%);
-webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
-webkit-mask-composite: xor;
mask-composite: exclude;
pointer-events: none;
}
Used on: the 3 navbar social buttons (circular w-10 h-10), the hero email-form container (rounded-full), and the "Start Writing" CTA button (rounded-lg).
Animation pattern — fadeUp (Framer-Motion whileInView)
Reusable staggered reveal. In React:
const fadeUp = (delay: number) => ({
initial: { opacity: 0, y: 20 },
whileInView: { opacity: 1, y: 0 },
viewport: { once: true, margin: "-100px" },
transition: { duration: 0.6, delay, ease: "easeOut" },
});
In the seed this is mapped down to an IntersectionObserver (threshold 0.08, 0.08s steps). Keep rootMargin: -100px) that adds a .in class; siblings within a parent get a staggered transition-delay (once: true semantics (unobserve after reveal).
Page structure (top to bottom)
Navbar — fixed, transparent, top-0 z-50, padding px-8 md:px-28 py-4
- Left: concentric-circles logo (outer
w-7 h-7border-2 border-foreground/60, innerw-3 h-3border border-foreground/60) + bold "Mindloop". - Center-left: nav links
["Home", "How It Works", "Philosophy", "Use Cases"]separated by•dots; linkstext-muted-foreground hover:text-foreground. Hidden on mobile. - Right: 3 social icons (Instagram, LinkedIn, Twitter —
lucide-reactin the port, inline SVG in the seed) in liquid-glass circularw-10 h-10 rounded-fullbuttons.
Hero — full viewport height
- Background: autoplay/loop/muted/playsInline MP4 covering the section,
object-cover.- URL:
https://plugin-assets.open-design.ai/plugins/mindloop-landing/hf_20260325_120549_0cd82c36-56b3-4dd9-b190-069cfc3a623f-9b476a.mp4
- URL:
- Bottom gradient:
h-64(256px)bg-gradient-to-t from-background to-transparentfor a smooth fade to black. - Content (centered,
z-10,pt-28 md:pt-32):- Avatar row: 3 overlapping circular avatars (
-space-x-2,w-8 h-8 rounded-full border-2 border-background, inlined data URIs) + "7,000+ people already subscribed" (text-muted-foreground text-sm). - Heading:
text-5xl md:text-7xl lg:text-8xl font-medium tracking-[-2px]— "Get Inspired with Us", where "Inspired" is.serif(Instrument Serif italic,font-normal). - Subtitle:
text-lg, colorhsl(var(--hero-subtitle))— "Join our feed for meaningful updates, news around technology and a shared journey toward depth and direction." - Email form:
liquid-glass rounded-full p-2 max-w-lgcontaining an email input and abg-foreground text-background rounded-full px-8 py-3"SUBSCRIBE" button (whileHover scale 1.03,whileTap scale 0.98).
- Avatar row: 3 overlapping circular avatars (
"Search has changed" section — pt-52 md:pt-64 pb-6 md:pb-9, centered
- Heading:
text-5xl md:text-7xl lg:text-8xl— "Search has changed. Have you?" with "changed." in serif italic. - Subtitle:
text-muted-foreground text-lg max-w-2xl mx-auto mb-24. - 3 platform cards (
grid md:grid-cols-3 gap-12 md:gap-8 mb-20): each = a ~200×200 icon image centered, platform name (font-semibold text-base), description (text-muted-foreground text-sm).- ChatGPT → inlined
icon-chatgptdata URI. Perplexity → inlinedicon-perplexitydata URI. Google AI → inlinedicon-googledata URI.
- ChatGPT → inlined
- Bottom tagline: "If you don't answer the questions, someone else will." (
text-muted-foreground text-sm text-center).
Mission section — pt-0 pb-32 md:pb-44, centered
- Large ~800×800 looping autoplay muted video, centered.
- URL:
https://plugin-assets.open-design.ai/plugins/mindloop-landing/hf_20260325_132944_a0d124bb-eaa1-4082-aa30-2310efb42b4b-d0e30d.mp4
- URL:
- Scroll-driven word-by-word reveal (
useScroll+useTransformin the port; in the seed a passivescrolllistener that maps each word's viewport position to opacity0.15 → 1).- Paragraph 1 (
text-2xl md:text-4xl lg:text-5xl font-medium tracking-[-1px]): "We're building a space where curiosity meets clarity — where readers find depth, writers find reach, and every newsletter becomes a conversation worth having." Words "curiosity", "meets", "clarity" snap to--foreground; the rest sit in--hero-subtitle. - Paragraph 2 (
text-xl md:text-2xl lg:text-3xl font-medium mt-10): "A platform where content, community, and insight flow together — with less noise, less friction, and more meaning for everyone involved."
- Paragraph 1 (
Solution section — py-32 md:py-44, border-t border-border/30
- Label: "SOLUTION" (
text-xs tracking-[3px] uppercase text-muted-foreground). - Heading:
text-4xl md:text-6xl— "The platform for meaningful content" (serif italic on "meaningful"). - Video:
rounded-2xl aspect-[3/1] object-cover.- URL:
https://plugin-assets.open-design.ai/plugins/mindloop-landing/hf_20260325_125119_8e5ae31c-0021-4396-bc08-f7aebeb877a2-1f0a78.mp4
- URL:
- 4-column feature grid (
md:grid-cols-4 gap-8): Curated Feed, Writer Tools, Community, Distribution — each title (font-semibold text-base) + description (text-muted-foreground text-sm).
CTA section — py-32 md:py-44, border-t border-border/30, overflow-hidden
- Background video via HLS (hls.js):
absolute inset-0 object-cover z-0.- HLS URL:
https://stream.mux.com/8wrHPCX2dC3msyYU9ObwqNdm00u3ViXvOSHUMRYSEe5Q.m3u8 - Use
Hls.isSupported(); fall back to native HLS (canPlayType('application/vnd.apple.mpegurl')) for Safari.
- HLS URL:
- Overlay:
absolute inset-0 bg-background/45 z-[1]. - Content (
z-10, centered): concentric-circles logo (w-10 h-10outer,w-5 h-5inner); heading "Start Your Journey" (serif italic on "Journey"); subtitletext-muted-foreground; two buttons — "Subscribe Now" (bg-foreground text-background rounded-lg px-8 py-3.5) and "Start Writing" (liquid-glass rounded-lg).
Footer — py-12 px-8 md:px-28
- Left: "© 2026 Mindloop. All rights reserved." (
text-muted-foreground text-sm). - Right: Privacy, Terms, Contact (
text-muted-foreground text-sm hover:text-foreground).
Responsive
- Headings use clamped /
md:/lg:breakpoints exactly as listed; mobile drops the navbar center links. platform-gridandfeature-gridcollapse to a single (or 2) column undermd.- Mission video and hero video are
object-coverand never letterbox.
Color rules — hard
Pure black/white monochrome only. The ONLY tokens in play are the greyscale ramp plus --hero-subtitle (a near-white 210 17% 95%) for hero/mission body text. No accent colors in the visible UI — no blue, purple, teal swatches, no vivid gradients. The single gradient allowed is the hero's black-to-transparent bottom fade and the liquid-glass border highlight. Keep it monochrome.