name: 3d-creator-portfolio description: "Use this plugin when the user wants a dark, premium 3D-creator / designer portfolio landing page: a full-viewport hero with a gradient-text headline and a mouse-following magnetic 3D portrait, a scroll-driven horizontal image marquee, an About section with corner 3D decorations and character-by-character scroll-reveal text, a white Services list, and sticky-stacking project cards. Invoke for '3D creator portfolio', 'designer landing page', 'creative portfolio with magnetic hero', or when the user references the Jack 3D Creator template." version: 0.1.0 od: mode: prototype surface: web scenario: design preview: type: html entry: example.html design_system: requires: false
Jack — 3D Creator Portfolio
Produce a dark, premium 3D-creator portfolio landing page. 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 tokens, gradient text, magnetic-hover portrait, scroll marquee, char-reveal text, sticky-stacking cards, and responsive behavior described below.
This is the authoritative build brief. Follow it exactly — the named colors, gradients, fonts, sizes, image URLs, and animations are locked.
Inlined images (critical): example.html ships the hero portrait and the four About-section 3D decorations as inlined data:image/webp;base64,… URIs — keep those exactly as they are. Do not swap them back for the original shrug-person-78902957.figma.site/... URLs: that host rate-limits / 403s inside the preview sandbox and renders as broken images. When you copy the seed, the inlined images come with it; only replace one if the user supplies their own asset, and prefer a data URI over a remote URL. The 21 motionsites marquee GIFs and the 9 higgs/cloudfront project images stay as remote URLs (large stable CDNs).
Stack
- Default output: a single self-contained HTML file (the
example.htmlseed) using vanilla CSS + JS. It already includes everything inline. - If the user explicitly asks for the React project: port the seed faithfully to React 18 + TypeScript + Vite + Tailwind CSS + Framer Motion + lucide-react. Same tokens, same markup structure, same animations. Section order:
HeroSection → MarqueeSection → AboutSection → ServicesSection → ProjectsSection → ContactSection (footer). 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.)
Global styles — locked
- Background
#0C0C0Conhtml, body, #root, and the main wrapper. - Font: Kanit (Google Fonts, weights 300–900),
'Kanit', sans-serif. - Page title:
Jack — 3D Creator. - Global reset:
box-sizing: border-box; margin: 0; padding: 0. - Main wrapper:
overflow-x: clip. .hero-headinggradient text:background: linear-gradient(180deg, #646973 0%, #BBCCD7 100%)with-webkit-background-clip: textand-webkit-text-fill-color: transparent.
1. Hero Section (h-screen, flex column, overflow-x: clip)
- Navbar: flex
justify-between, 4 links — "About", "Price", "Projects", "Contact". Color#D7E2EA, font-medium, uppercase,tracking-wider. Sizestext-sm md:text-lg lg:text-[1.4rem]. Paddingpx-6 md:px-10 pt-6 md:pt-8. Hover: opacity 70%, 200ms. The four links map to anchors that must ALL resolve: "About" →#about, "Price" → the Services section (id="price"), "Projects" →#projects, "Contact" → the Contact footer (id="contact"). No dead anchors. - Hero heading: massive
<h1>"Hi, i'm jack" (lowercase "i", curly apostrophe')..hero-headinggradient, font-black, uppercase, tracking-tight, leading-none, whitespace-nowrap,w-full. Sizestext-[14vw] sm:text-[15vw] md:text-[16vw] lg:text-[17.5vw]. Margin topmt-6 sm:mt-4 md:-mt-5. Wrapped in anoverflow-hiddencontainer. - Bottom bar: flex
justify-between items-end,pb-7 sm:pb-8 md:pb-10.- Left: paragraph "a 3d creator driven by crafting striking and unforgettable projects", color
#D7E2EA, font-light, uppercase, tracking-wide, leading-snug,font-size: clamp(0.75rem, 1.4vw, 1.5rem),max-w-[160px] sm:max-w-[220px] md:max-w-[260px]. - Right: ContactButton (see Reusable components).
- Left: paragraph "a 3d creator driven by crafting striking and unforgettable projects", color
- Hero portrait: centered, wrapped in a Magnet component (mouse-following). Image is the inlined portrait
data:URI (originallyRectangle_40443.81459862.png). Magnet:padding 150, strength 3, activeTransition "transform 0.3s ease-out", inactiveTransition "transform 0.6s ease-in-out". Positioningabsolute left-1/2 -translate-x-1/2 z-10. Widthw-[280px] sm:w-[360px] md:w-[440px] lg:w-[520px]. On mobile:top-1/2 -translate-y-1/2; onsm+:sm:top-auto sm:translate-y-0 sm:bottom-0. - FadeIn delays: Navbar
delay 0, y -20. Headingdelay 0.15, y 40. Left textdelay 0.35, y 20. Contact buttondelay 0.5, y 20. Portraitdelay 0.6, y 30.
2. Marquee Section
Two rows of images that scroll horizontally based on page scroll position. Background #0C0C0C. Padding pt-24 sm:pt-32 md:pt-40 pb-10.
- 21 GIFs from
motionsites.ai/assets/...(exact URLs in the seed — keep them). - Row 1: first 11 images, tripled for seamless scroll. Moves RIGHT:
translateX(offset - 200). - Row 2: remaining 10 images, tripled. Moves LEFT:
translateX(-(offset - 200)). - Scroll offset:
(window.scrollY - sectionTop + window.innerHeight) * 0.3. - Each tile: 420×270px,
rounded-2xl,object-cover, lazy-loaded. Gapgap-3between tiles and between rows. will-change: transform; scroll listener is passive.
3. About Section (min-h-screen, centered, px-5 sm:px-8 md:px-10 py-20)
Four decorative 3D images positioned absolutely in corners (all inlined data: URIs in the seed):
Top-left — moon icon (
moon_icon.11395d36.png):w-[120px] sm:w-[160px] md:w-[210px],top-[4%] left-[1%] sm:left-[2%] md:left-[4%]. FadeIndelay 0.1, x -80, dur 0.9.Bottom-left — 3D object (
p59_1.4659672e.png):w-[100px] sm:w-[140px] md:w-[180px],bottom-[8%] left-[3%] sm:left-[6%] md:left-[10%]. FadeIndelay 0.25, x -80, dur 0.9.Top-right — lego icon (
lego_icon-1.703bb594.png):w-[120px] sm:w-[160px] md:w-[210px],top-[4%] right-[1%] sm:right-[2%] md:right-[4%]. FadeIndelay 0.15, x 80, dur 0.9.Bottom-right — 3D group (
Group_134-1.2e04f3ce.png):w-[130px] sm:w-[170px] md:w-[220px],bottom-[8%] right-[3%] sm:right-[6%] md:right-[10%]. FadeIndelay 0.3, x 80, dur 0.9.Heading: "About me",
.hero-headinggradient, font-black, uppercase, leading-none, tracking-tight, centered,font-size: clamp(3rem, 12vw, 160px). FadeIndelay 0, y 40.Animated paragraph (AnimatedText): char-by-char scroll-driven opacity (0.2 → 1) based on scroll progress, offset
['start 0.8', 'end 0.2']. Text: "With more than five years of experience in design, i focus on branding, web design, and user experience, i truly enjoy working with businesses that aim to stand out and present their best image. Let's build something incredible together!" Color#D7E2EA, font-medium, centered, leading-relaxed,max-w-[560px],font-size: clamp(1rem, 2vw, 1.35rem).ContactButton below the text. Gap heading→text
gap-10 sm:gap-14 md:gap-16; gap text→buttongap-16 sm:gap-20 md:gap-24.
4. Services Section (white #FFFFFF, rounded-t-[40px] sm:rounded-t-[50px] md:rounded-t-[60px])
Padding px-5 sm:px-8 md:px-10 py-20 sm:py-24 md:py-32.
- Heading: "Services" in
#0C0C0C, font-black, uppercase, centered,font-size: clamp(3rem, 12vw, 160px),mb-16 sm:mb-20 md:mb-28. - 5 items, vertical list,
max-w-5xl, centered. Each: number (font-black,clamp(3rem, 10vw, 140px),#0C0C0C) on the left + name & description stacked on the right. Name: font-medium, uppercase,clamp(1rem, 2.2vw, 2.1rem). Description: font-light, leading-relaxed,max-w-2xl,clamp(0.85rem, 1.6vw, 1.25rem), opacity 0.6. 1px bordersrgba(12,12,12,0.15). Paddingpy-8 sm:py-10 md:py-12. Staggered FadeIn: each itemdelay = i * 0.1.01 — 3D Modeling: "Creation of detailed objects, characters, or environments tailored to specific client needs, ideal for games, products, and visualizations."02 — Rendering: "High-quality, photorealistic renders that showcase designs with custom lighting, textures, and materials to bring concepts to life."03 — Motion Design: "Dynamic animations and motion graphics that add energy and storytelling to brands, products, and digital experiences."04 — Branding: "Crafting cohesive visual identities — from logos to full brand systems — that communicate a clear and memorable presence."05 — Web Design: "Designing clean, modern, and conversion-focused websites with attention to layout, typography, and user experience."
5. Projects Section (dark #0C0C0C, rounded-t-[40px] sm:rounded-t-[50px] md:rounded-t-[60px], -mt-10 sm:-mt-12 md:-mt-14, z-10)
- Heading: "Project" (singular),
.hero-headinggradient, same styling as other headings. - 3 sticky-stacking project cards that scale down as you scroll past them (Framer Motion
useScroll+useTransform). Each card issticky top-24 md:top-32inside anh-[85vh]container. - Scale:
targetScale = 1 - (totalCards - 1 - index) * 0.03. Each card offsettop: ${index * 28}px. - Card:
rounded-[40px] sm:rounded-[50px] md:rounded-[60px],border-2 border-[#D7E2EA], background#0C0C0C, paddingp-4 sm:p-6 md:p-8.- Top row: number (huge, same style as services), category label, project name, and a LiveProjectButton ("Live Project" ghost pill).
- Bottom row: two-column image grid — left column (40%) has 2 stacked images, right column (60%) has 1 tall image. All
rounded-[40px] sm:rounded-[50px] md:rounded-[60px]. Left-top heightclamp(130px, 16vw, 230px); left-bottom heightclamp(160px, 22vw, 340px).
- Project data (higgs/cloudfront URLs are in the seed — keep them):
01 — Nextlevel Studio(Client)02 — Aura Brand Identity(Personal)03 — Solaris Digital(Client)
6. Contact Section (footer)
A closing <footer id="contact"> so the navbar's Contact link resolves to a real target. Dark background #0C0C0C, centered column, generous padding (e.g. 80px 24px 120px, gap ~32px). Contains a large gradient headline using .hero-heading (e.g. "Let's talk") and a ContactButton ("Contact Me"). Keep it minimal — its job is to be a real, scrollable anchor target consistent with the bundled example.html.
Reusable Components
- ContactButton: rounded-full pill. Background
linear-gradient(123deg, #18011F 7%, #B600A8 37%, #7621B0 72%, #BE4C00 100%). Box-shadow0px 4px 4px rgba(181,1,167,0.25), 4px 4px 12px #7721B1 inset. White 2px outline with-3pxoffset. Text: white, font-medium, uppercase, tracking-widest. Sizespx-8 py-3 sm:px-10 sm:py-3.5 md:px-12 md:py-4,text-xs sm:text-sm md:text-base. Label "Contact Me". - LiveProjectButton: ghost/outline pill. Rounded-full,
border-2 border-[#D7E2EA], text#D7E2EA, font-medium, uppercase, tracking-widest. Sizespx-8 py-3 sm:px-10 sm:py-3.5,text-sm sm:text-base. Hoverbg-[#D7E2EA]/10. Label "Live Project". - FadeIn: Framer Motion wrapper,
whileInViewwithviewport={{ once: true, margin: "50px", amount: 0 }}. Props:delay,duration(default 0.7),x(default 0),y(default 30). Easing[0.25, 0.1, 0.25, 1]. Usemotion.create()for dynamic element types. (In the vanilla seed this is anIntersectionObserver+ CSS transition.) - Magnet: mouse-following magnetic hover. Track mouse position relative to element center; apply
translate3ddivided bystrength. Activates when cursor is withinpaddingdistance of the element edge. Transition-in0.3s ease-out, out0.6s ease-in-out.will-change: transform. - AnimatedText: char-by-char scroll reveal. Each character goes opacity 0.2 → 1 based on its position relative to scroll progress. Framer Motion
useScrollon the paragraph, offset['start 0.8', 'end 0.2']. Each char uses an invisible placeholder + an absolutely-positioned animated span. (In the seed, a scroll listener lights up character spans progressively.)
Key Dependencies (React port)
react, react-dom (^18.3.1), framer-motion (^12.38.0), lucide-react (^0.344.0), tailwindcss (^3.4.1), vite, typescript.
Responsive
Tailwind default breakpoints (sm 640, md 768, lg 1024), mobile-first. Heavy use of clamp() for fluid typography. The design must scale gracefully from mobile to ultra-wide.
Color Rules — hard
Dark theme anchored on #0C0C0C background and #D7E2EA foreground text. Hero/heading gradient #646973 → #BBCCD7 is locked. ContactButton multi-stop gradient (#18011F → #B600A8 → #7621B0 → #BE4C00) is locked — do not flatten it to a single color. Services section is the only light (#FFFFFF) block.