personal website

vibes

+113 -3
public/vibes/20210711_141551.jpg

This is a binary file and will not be displayed.

public/vibes/2022-12-29_07.46.32.webp

This is a binary file and will not be displayed.

public/vibes/2022-12-30_21.18.55.webp

This is a binary file and will not be displayed.

public/vibes/2023-01-01_16.55.57.webp

This is a binary file and will not be displayed.

public/vibes/20231018_125321.jpg

This is a binary file and will not be displayed.

public/vibes/2024-11-16_17.03.36.webp

This is a binary file and will not be displayed.

public/vibes/2024-11-24_19.10.43.webp

This is a binary file and will not be displayed.

public/vibes/2024-11-27_21.webp

This is a binary file and will not be displayed.

public/vibes/2024-12-03_17.36.34.webp

This is a binary file and will not be displayed.

public/vibes/20240407_221011.jpg

This is a binary file and will not be displayed.

public/vibes/2025-04-12_23.31.10.webp

This is a binary file and will not be displayed.

public/vibes/2025-04-12_23.34.36.webp

This is a binary file and will not be displayed.

public/vibes/2025-04-12_23.34.40.webp

This is a binary file and will not be displayed.

public/vibes/2025_Marathon_Reveal_Press_Kit_LARGE_008.png

This is a binary file and will not be displayed.

public/vibes/287ad63ae93cd0aa93eefcfba452c8822fc5d32a.png

This is a binary file and will not be displayed.

public/vibes/3x3ep44awthe1.jpeg

This is a binary file and will not be displayed.

public/vibes/4 tqagds.jpg

This is a binary file and will not be displayed.

public/vibes/736336c6a98ba15014172d07b6d7af5f.jpg

This is a binary file and will not be displayed.

public/vibes/76200c17-83db-437d-95eb-394b5d865634.png

This is a binary file and will not be displayed.

public/vibes/79d98eda-4ebc-458b-aa4c-3b0bd9ed2d1f.png

This is a binary file and will not be displayed.

public/vibes/7aeddaf4055c06b3c87c58709c078f93.jpg

This is a binary file and will not be displayed.

public/vibes/81730978_p0_master1200.jpg

This is a binary file and will not be displayed.

public/vibes/85786433-3946-4a94-a863-c12999082023_373x306.webp

This is a binary file and will not be displayed.

public/vibes/8aa3ebb1-899f-4d2f-99ea-ad7db0fecc4f.jpg

This is a binary file and will not be displayed.

public/vibes/Destiny_2_replay_2022.09.25-16.18-00.00.27.568-00.00.34.213.mp4

This is a binary file and will not be displayed.

public/vibes/F3Zo4EhWEAA8kr2.jpg

This is a binary file and will not be displayed.

public/vibes/F8ZXP27bkAApO87.jpg

This is a binary file and will not be displayed.

public/vibes/Gid2GfkXIAAJJl3.jpg

This is a binary file and will not be displayed.

public/vibes/GiiZC2eXoAAzh6q.png

This is a binary file and will not be displayed.

public/vibes/GlCsl2kX0AAwRAZ.png

This is a binary file and will not be displayed.

public/vibes/Go5y3GaaEAEqQST.jpg

This is a binary file and will not be displayed.

public/vibes/GoBTrx0a8AAbB5S.jpg

This is a binary file and will not be displayed.

public/vibes/GofnSN8XoAAyhnh.jpg

This is a binary file and will not be displayed.

public/vibes/GonrdcQXoAAY-SL.jpg

This is a binary file and will not be displayed.

public/vibes/GozvOzPaAAARBPe.jpg

This is a binary file and will not be displayed.

public/vibes/Gp7ncqtawAMun8V.webp

This is a binary file and will not be displayed.

public/vibes/GpVNXnEWsAA6gm7.jpg

This is a binary file and will not be displayed.

public/vibes/GpaCQIBXgAEDsXj.png

This is a binary file and will not be displayed.

public/vibes/GpaRcnsXcAAsVjq.jpg

This is a binary file and will not be displayed.

public/vibes/Gpd47v3bkAAV2lY.png

This is a binary file and will not be displayed.

public/vibes/GpjVUBIbwAAZzff.jpg

This is a binary file and will not be displayed.

public/vibes/IMG_0083.PNG

This is a binary file and will not be displayed.

public/vibes/IMG_0091.png

This is a binary file and will not be displayed.

public/vibes/IMG_0095.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_0095.png

This is a binary file and will not be displayed.

public/vibes/IMG_0103.jpg

This is a binary file and will not be displayed.

public/vibes/IMG_0129.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_0235.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_0247.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_0282.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_0406.png

This is a binary file and will not be displayed.

public/vibes/IMG_0718.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_0752.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_1070.jpg

This is a binary file and will not be displayed.

public/vibes/IMG_1837.png

This is a binary file and will not be displayed.

public/vibes/IMG_2109.png

This is a binary file and will not be displayed.

public/vibes/IMG_2110.png

This is a binary file and will not be displayed.

public/vibes/IMG_2595.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_2599.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_2605.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_2621.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_2655.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_2675 2.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_2675.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_2685.WEBP

This is a binary file and will not be displayed.

public/vibes/IMG_2735.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_2788.WEBP

This is a binary file and will not be displayed.

public/vibes/IMG_2849.AVIF

This is a binary file and will not be displayed.

public/vibes/IMG_2850.AVIF

This is a binary file and will not be displayed.

public/vibes/IMG_2860.PNG

This is a binary file and will not be displayed.

public/vibes/IMG_2870.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_3022.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_3049.PNG

This is a binary file and will not be displayed.

public/vibes/IMG_3058.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_3078.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_3136.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_3210.webp

This is a binary file and will not be displayed.

public/vibes/IMG_3230.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_3256.PNG

This is a binary file and will not be displayed.

public/vibes/IMG_3269.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_3278.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_3282.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_3288.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_3289 2.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_3289.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_3291.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_3292.JPG

This is a binary file and will not be displayed.

public/vibes/IMG_3293.jpg

This is a binary file and will not be displayed.

public/vibes/IMG_3392.png

This is a binary file and will not be displayed.

public/vibes/IMG_5835.png

This is a binary file and will not be displayed.

public/vibes/IMG_5836.jpg

This is a binary file and will not be displayed.

public/vibes/IMG_5885.webp

This is a binary file and will not be displayed.

public/vibes/IMG_5994.jpg

This is a binary file and will not be displayed.

public/vibes/IMG_9417.jpg

This is a binary file and will not be displayed.

public/vibes/IMG_9793.jpg

This is a binary file and will not be displayed.

public/vibes/Natsuko_cosplay_Himeko_-_HonkaiStar_Rail_77.jpg

This is a binary file and will not be displayed.

public/vibes/PXL_20230705_203143689.jpg

This is a binary file and will not be displayed.

public/vibes/PXL_20230805_223400932.jpg

This is a binary file and will not be displayed.

public/vibes/PXL_20230818_213328823.jpg

This is a binary file and will not be displayed.

public/vibes/PXL_20230820_161352256.jpg

This is a binary file and will not be displayed.

public/vibes/PXL_20231121_164748536.jpg

This is a binary file and will not be displayed.

public/vibes/PXL_20231122_163549147.jpg

This is a binary file and will not be displayed.

public/vibes/PXL_20231122_165815931.jpg

This is a binary file and will not be displayed.

public/vibes/PXL_20231124_193140506.jpg

This is a binary file and will not be displayed.

public/vibes/PXL_20240113_192702373.jpg

This is a binary file and will not be displayed.

public/vibes/PXL_20240121_211338666.jpg

This is a binary file and will not be displayed.

public/vibes/PXL_20240308_230057122.jpg

This is a binary file and will not be displayed.

public/vibes/PXL_20240311_012623545.jpg

This is a binary file and will not be displayed.

public/vibes/PXL_20240317_191104003.jpg

This is a binary file and will not be displayed.

public/vibes/PXL_20240325_165913386.jpg

This is a binary file and will not be displayed.

public/vibes/PXL_20240408_192007680.jpg

This is a binary file and will not be displayed.

public/vibes/PXL_20240502_131050536-1.jpg

This is a binary file and will not be displayed.

public/vibes/PXL_20240502_131050536.jpg

This is a binary file and will not be displayed.

public/vibes/RDT_20230106_0144143661212588690263489.jpg

This is a binary file and will not be displayed.

public/vibes/RDT_20231009_2001048696124852856704244.jpg

This is a binary file and will not be displayed.

public/vibes/Screenshot 2025-04-27 at 2.35.47 AM.png

This is a binary file and will not be displayed.

public/vibes/Screenshot_20230114_021449.webp

This is a binary file and will not be displayed.

public/vibes/Screenshot_20240102_120522.png

This is a binary file and will not be displayed.

public/vibes/Tumblr_l_65973710062162.png

This is a binary file and will not be displayed.

public/vibes/__hatsune_miku_vocaloid_drawn_by_mosh_mallow__44df1f18b1645081857d4da85a871043.jpg

This is a binary file and will not be displayed.

public/vibes/__manjuu_enterprise_and_enterprise_azur_lane_drawn_by_sciamano240__172400e5c5ee0c95ee1f602c404484f4.jpg

This is a binary file and will not be displayed.

public/vibes/__texas_and_lappland_arknights_drawn_by_puppy_user_kfpt4478__8ef71ff15354d25d3d1059adfc91e4f2.jpg

This is a binary file and will not be displayed.

public/vibes/a1680503-25bb-455f-bcb5-db38780cf3ec.png

This is a binary file and will not be displayed.

public/vibes/afsdasdf.png

This is a binary file and will not be displayed.

public/vibes/attachment 2.jpg

This is a binary file and will not be displayed.

public/vibes/attachment 3.jpg

This is a binary file and will not be displayed.

public/vibes/attachment 4.jpg

This is a binary file and will not be displayed.

public/vibes/attachment.jpg

This is a binary file and will not be displayed.

public/vibes/attachment.png

This is a binary file and will not be displayed.

public/vibes/bafkreiaaia3g5lwpeyhtpuufknd3ws6ns7oqiz2p64su6q32rne47f5pte.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreiaax5lv7kfrzy3pwq745v7ypzjwxxasupfhdbwcjzhz3ohu46fabq.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreiagdb7qhtccfgtfg2dx7o23xiehagrvfrpichmidozqolaa2ui6su.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreiagm4fgp4pxnuk5r5xfqwdi2o7ezji4c64jrdgtpywp764bnrqppq.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreiarrfvh2scs2bzdspz3u24l4xcdobsu33cqgnukhvgi3klpdaue6q.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreiasjkh35y3nu3tz5ldmj2l2xpsh5rwqgp4v5yovdi5dyd2tqzz3va.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreibql6eo4xst3kbiicflzesrqy2422eunlfma2ulllthzn7kn7cdvq.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreic3mk7a234laor5lhtbjlsuv2ui5rfd5cyg5lmobrbginw6gylblu.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreic62lafal5cwtvjgud3zs7kbutnpcxya6ctehqumwytjhwqjqgdii.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreicc42kwpdk464lw4iv62qudccwwnzpgnrjpqeg5decxz226l3tgzm.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreicidyvdaijdsxhpkfc57re37g4dgwa6mg7mnlb36335xuaat6pxvy.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreicq74ss2lnb73fwgl3ihxqe4el7vt56nxhhxnpagjpjny5m6g3mze.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreicrfm23nnctbdrj2wfhhlegf34cufthifzdtxgo4ntpcfv7ezqq6i.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreid7plghykzgkvfrsmghlbxfmovmlju3ohlgezaj6kshbi2ckw2mcu.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreidiqctpedei6hhdauxk6ywhiswtfs67c5oovr75eabepgrges54cy.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreidteiaeygoy6wrhuuc2a5l6uaqtnf3e2ugvsqoaowcrru6wxlah4q.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreidv227afm7ps2geuzvwn2znakpvefoty5i675qip7fkurotitgh6e.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreidx2d4brqitkdf4flh7bktetwfnzm7bbqv75iv6f6fnvpw5nzknya.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreie6te7m2p42fdenu5r45mhsjc7k2mmwkl6kovne3gcoby2hgjmd34.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreif34w4lgfbqjv5vqxqrmh33qzfvro4mg65kflfd2tmxcjg722hmay.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreifryay7tg45u6zu3mwq6l52wujyr5kzgymvg6cwmcnv6wwfmpxfxq@jpeg.webp

This is a binary file and will not be displayed.

public/vibes/bafkreifs7mafsacnvlau3kskuabrv2esvobuhmb22epsfxrvmrywi6bh5q.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreig4yxs4gt4rflzwv2kbv47u4shhpet6eowfn6ocbwrwi5xikq52fm.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreigdfydcw3fhrxzll67dli5pesnws7zhxzjjuryliostlvy4jypdky@jpeg.webp

This is a binary file and will not be displayed.

public/vibes/bafkreigpvzbssycljzaqclvzs7h4doltrfdb7t2o52363i2pssqbcvwdxa.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreigsbsgkfzco45jnyhfah7wb5czqptpetjx2mxlym7pns7uvzcsxke.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreigxfyig4ubitqtbolmlfjyigeijic44nr3r4r4qjskiuol4cfvvka.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreihdlgy3uyxjd6ozu22ltcjin5zjqpxifodtc7ntvcw56rjcbesn4e.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreihffziagadmdpbqylqqmejxj4exsvadztfhmrsk5tjq36esv5vjca.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreihirmzdqnkdhaoux2ypigusht4djnymz4kmwfafx4dhfx5d5o2ncu.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreihjioibfdw2witu6trx34jocyra6zjfy7yuyhexzusqjh6tpffl7e.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreihv2isoqe2aisrfw37isoooczabedxvmomiznplpfmo2inmetkfc4.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreihv4ylbotmgb3xp3lsu4idyf3y76gyjrks2hsdacbxaffi5pyyk2i.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreihvmv2rstow3s6ezqk2qi5wlfqfulfyjyl5qzzqlfxq6q42bkd5ma.jpg

This is a binary file and will not be displayed.

public/vibes/bafkreihygg2vutfbjqvszbs26cvihs42ivkibuewe62dzs6vwxm36duvuyjpeg.png

This is a binary file and will not be displayed.

public/vibes/cb001fdc393ead3e2ac562c2db0baf6f.png

This is a binary file and will not be displayed.

public/vibes/d58b3qwqkkue1.png

This is a binary file and will not be displayed.

public/vibes/dsad.png

This is a binary file and will not be displayed.

public/vibes/ebc7fb5169074a2e75bd3c0c00119560.jpg

This is a binary file and will not be displayed.

public/vibes/genshin.png

This is a binary file and will not be displayed.

public/vibes/image 2.png

This is a binary file and will not be displayed.

public/vibes/image 3.png

This is a binary file and will not be displayed.

public/vibes/image 4.png

This is a binary file and will not be displayed.

public/vibes/image-1.png

This is a binary file and will not be displayed.

public/vibes/image-1.webp

This is a binary file and will not be displayed.

public/vibes/image-10.webp

This is a binary file and will not be displayed.

public/vibes/image-11.webp

This is a binary file and will not be displayed.

public/vibes/image-2.webp

This is a binary file and will not be displayed.

public/vibes/image-3.webp

This is a binary file and will not be displayed.

public/vibes/image-4.webp

This is a binary file and will not be displayed.

public/vibes/image-5.webp

This is a binary file and will not be displayed.

public/vibes/image-6.webp

This is a binary file and will not be displayed.

public/vibes/image-7.webp

This is a binary file and will not be displayed.

public/vibes/image-8.webp

This is a binary file and will not be displayed.

public/vibes/image-9.webp

This is a binary file and will not be displayed.

public/vibes/image.jpg

This is a binary file and will not be displayed.

public/vibes/image.png

This is a binary file and will not be displayed.

public/vibes/image.webp

This is a binary file and will not be displayed.

public/vibes/image0 2.jpg

This is a binary file and will not be displayed.

public/vibes/image0.jpg

This is a binary file and will not be displayed.

public/vibes/images.jpg

This is a binary file and will not be displayed.

public/vibes/images.png

This is a binary file and will not be displayed.

public/vibes/jygj279u53rc1.webp

This is a binary file and will not be displayed.

public/vibes/lkw06l1nykye1.png

This is a binary file and will not be displayed.

public/vibes/lurk.png

This is a binary file and will not be displayed.

public/vibes/sample_8d92473c6e28defd5b3594efadbcb1aa.jpg

This is a binary file and will not be displayed.

public/vibes/sda.png

This is a binary file and will not be displayed.

public/vibes/slug.png

This is a binary file and will not be displayed.

public/vibes/tra.png

This is a binary file and will not be displayed.

public/vibes/tsconfig.jpg

This is a binary file and will not be displayed.

public/vibes/tumblr_2861f1bc82f459f679789f9ba2891cc2_31516384_1280.jpg

This is a binary file and will not be displayed.

public/vibes/twinkyuri.jpg

This is a binary file and will not be displayed.

+27 -3
src/App.tsx
··· 5 5 import { Work } from "./components/sections/Work" 6 6 import { Connect } from "./components/sections/Connect" 7 7 import { GuestbookPage } from "./components/sections/GuestbookPage" 8 + import { Vibes } from "./components/sections/Vibes" 8 9 import { sections } from "./data/portfolio" 9 10 10 11 export function App() { ··· 20 21 }, []) 21 22 22 23 useEffect(() => { 23 - if (currentPath === '/guestbook') return // Skip observer on guestbook page 24 + if (currentPath === '/guestbook' || currentPath === '/vibes') return // Skip observer on sub-pages 24 25 25 26 const observer = new IntersectionObserver( 26 27 (entries) => { ··· 41 42 return () => observer.disconnect() 42 43 }, [currentPath]) 43 44 45 + // Vibes page 46 + if (currentPath === '/vibes') { 47 + return ( 48 + <div className="min-h-screen dark:bg-background text-foreground relative"> 49 + <div className="fixed top-6 left-6 z-50"> 50 + <button 51 + onClick={() => { 52 + window.history.pushState({}, '', '/') 53 + setCurrentPath('/') 54 + }} 55 + className="px-4 py-2 rounded-full text-sm font-medium bg-white dark:bg-gray-800 text-gray-700 dark:text-gray-200 shadow-md hover:shadow-lg border border-gray-200 dark:border-gray-700 hover:bg-gray-50 dark:hover:bg-gray-700 transition-all flex items-center gap-2" 56 + > 57 + <svg className="w-4 h-4" fill="none" stroke="currentColor" viewBox="0 0 24 24" strokeWidth={2}> 58 + <path strokeLinecap="round" strokeLinejoin="round" d="M10 19l-7-7m0 0l7-7m-7 7h18" /> 59 + </svg> 60 + Back 61 + </button> 62 + </div> 63 + <Vibes /> 64 + </div> 65 + ) 66 + } 67 + 44 68 // Guestbook page 45 69 if (currentPath === '/guestbook') { 46 70 return ( ··· 70 94 71 95 <main> 72 96 <div className="max-w-4xl mx-auto px-6 sm:px-8 lg:px-16"> 73 - <Header 74 - sectionRef={(el) => (sectionsRef.current[0] = el)} 97 + <Header 98 + sectionRef={(el) => (sectionsRef.current[0] = el)} 75 99 onGuestbookClick={() => { 76 100 window.history.pushState({}, '', '/guestbook') 77 101 setCurrentPath('/guestbook')
+25
src/components/sections/Vibes.tsx
··· 1 + import { useEffect, useState } from "react" 2 + 3 + export function Vibes() { 4 + const [vibes, setVibes] = useState<string[]>([]) 5 + 6 + useEffect(() => { 7 + fetch("/api/vibes") 8 + .then((res) => res.json()) 9 + .then(setVibes) 10 + .catch(() => setVibes([])) 11 + }, []) 12 + 13 + return ( 14 + <div className="vibes-container"> 15 + {vibes.map((vibe, index) => { 16 + const isVideo = vibe.endsWith(".mp4") || vibe.endsWith(".mov") || vibe.endsWith(".webm") 17 + return isVideo ? ( 18 + <video key={index} src={vibe} className="vibe-item" controls loop muted /> 19 + ) : ( 20 + <img key={index} src={vibe} alt="" className="vibe-item" loading="lazy" /> 21 + ) 22 + })} 23 + </div> 24 + ) 25 + }
+15
src/index.ts
··· 1 1 import { serve } from "bun"; 2 + import { readdir } from "fs/promises"; 2 3 import index from "./index.html"; 3 4 4 5 const server = serve({ ··· 31 32 } catch { 32 33 return new Response("File not found", { status: 404 }); 33 34 } 35 + }, 36 + 37 + "/api/vibes": async () => { 38 + const files = await readdir("public/vibes"); 39 + return Response.json(files.map((f) => `/vibes/${f}`)); 40 + }, 41 + 42 + "/vibes/*": async (req) => { 43 + const url = new URL(req.url); 44 + const file = Bun.file(`public${url.pathname}`); 45 + if (await file.exists()) { 46 + return new Response(file); 47 + } 48 + return new Response("Not found", { status: 404 }); 34 49 }, 35 50 36 51 // Serve index.html for all unmatched routes.
+46
styles/globals.css
··· 121 121 animation: bounce-slow 1s ease-in-out infinite; 122 122 } 123 123 124 + /* Vibes gallery */ 125 + .vibes-container { 126 + display: flex; 127 + flex-wrap: wrap; 128 + justify-content: center; 129 + align-items: flex-start; 130 + gap: 10px; 131 + padding: 5rem 2rem 2rem; 132 + } 133 + 134 + .vibe-item { 135 + max-width: 25%; 136 + height: auto; 137 + object-fit: contain; 138 + filter: contrast(1.05); 139 + transition: transform 0.2s; 140 + border: 3px solid #fff; 141 + margin-bottom: 10px; 142 + } 143 + 144 + .vibe-item:hover { 145 + transform: scale(1.05) rotate(calc(var(--hover-rotate) * 1deg)); 146 + z-index: 10; 147 + box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3); 148 + } 149 + 150 + /* Random rotations for chaotic effect */ 151 + .vibe-item:nth-child(11n+1) { --hover-rotate: 3; } 152 + .vibe-item:nth-child(7n+2) { --hover-rotate: -4; } 153 + .vibe-item:nth-child(5n+3) { --hover-rotate: 2; } 154 + .vibe-item:nth-child(13n+4) { --hover-rotate: -3; } 155 + .vibe-item:nth-child(17n+5) { --hover-rotate: 5; } 156 + .vibe-item:nth-child(19n+6) { --hover-rotate: -2; } 157 + 158 + /* Random margins for messiness */ 159 + .vibe-item:nth-child(8n) { margin-top: 15px; } 160 + .vibe-item:nth-child(12n) { margin-left: 10px; } 161 + .vibe-item:nth-child(9n) { margin-right: 10px; } 162 + .vibe-item:nth-child(15n) { margin-bottom: 20px; } 163 + 164 + @media (max-width: 768px) { 165 + .vibe-item { 166 + max-width: 45%; 167 + } 168 + } 169 + 124 170 /* Glassmorphism utilities */ 125 171 @layer utilities { 126 172 .glass {