diff --git a/_config.yml b/_config.yml
index 1db3643a..14d7a31a 100755
--- a/_config.yml
+++ b/_config.yml
@@ -485,4 +485,4 @@ cdn:
developer:
# Whether to enable developer mode (only for developers who want to modify the theme source code, not for ordinary users)
enable: false
-# DEVELOPER MODE <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< end
+# DEVELOPER MODE <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< end
\ No newline at end of file
diff --git a/layout/pages/masonry/masonry.ejs b/layout/pages/masonry/masonry.ejs
index 2c8fea0b..a21f8318 100644
--- a/layout/pages/masonry/masonry.ejs
+++ b/layout/pages/masonry/masonry.ejs
@@ -17,12 +17,223 @@ const images = theme.masonry;
<% images.forEach(function(image) { %>
-
+
-

-
<%- image.title %>
-
<%- image.description %>
+

+
<%- image.title %>
+
<%- image.description %>
<% }); %>
+
+
+
\ No newline at end of file
diff --git a/source/css/build/tailwind.css b/source/css/build/tailwind.css
index 76e095a2..2582702f 100644
--- a/source/css/build/tailwind.css
+++ b/source/css/build/tailwind.css
@@ -1,2 +1,2 @@
-/*! tailwindcss v4.1.12 | MIT License | https://tailwindcss.com */
-@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-space-x-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-red-400:oklch(70.4% .191 22.216);--color-red-600:oklch(57.7% .245 27.325);--color-gray-200:oklch(92.8% .006 264.531);--color-gray-300:oklch(87.2% .01 258.338);--color-gray-500:oklch(55.1% .027 264.364);--color-zinc-50:oklch(98.5% 0 0);--color-zinc-800:oklch(27.4% .006 286.033);--color-white:#fff;--spacing:.25rem;--text-xs:.75rem;--text-xs--line-height:calc(1/.75);--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--text-base:1rem;--text-base--line-height:calc(1.5/1);--text-lg:1.125rem;--text-lg--line-height:calc(1.75/1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75/1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2/1.5);--text-3xl:1.875rem;--text-3xl--line-height:calc(2.25/1.875);--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5/2.25);--text-5xl:3rem;--text-5xl--line-height:1;--text-6xl:3.75rem;--text-6xl--line-height:1;--font-weight-light:300;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-tight:-.025em;--radius-xs:.125rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--radius-3xl:1.5rem;--ease-in:cubic-bezier(.4,0,1,1);--ease-out:cubic-bezier(0,0,.2,1);--ease-in-out:cubic-bezier(.4,0,.2,1);--blur-lg:16px;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--margin-spacing-unit:38px;--z-index-1:1001;--radius-none:0px;--radius-small:9px;--radius-medium:14px;--radius-large:18px;--color-primary:var(--primary-color);--color-background-color:var(--background-color);--color-background-color-transparent:var(--background-color-transparent);--color-background-color-transparent-15:var(--background-color-transparent-15);--color-background-color-transparent-40:var(--background-color-transparent-40);--color-second-background-color:var(--second-background-color);--color-third-background-color:var(--third-background-color);--color-first-text-color:var(--first-text-color);--color-second-text-color:var(--second-text-color);--color-third-text-color:var(--third-text-color);--color-default-text-color:var(--default-text-color);--color-border-color:var(--border-color);--color-shadow-color-1:var(--shadow-color-1);--color-shadow-color-2:var(--shadow-color-2)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}*,:after,:before,::backdrop{border-color:var(--color-gray-200,currentcolor)}::file-selector-button{border-color:var(--color-gray-200,currentcolor)}:root{--background:0 0% 100%;--foreground:240 10% 3.9%;--card:0 0% 100%;--card-foreground:240 10% 3.9%;--popover:0 0% 100%;--popover-foreground:240 10% 3.9%;--primary:240 5.9% 10%;--primary-foreground:0 0% 98%;--secondary:240 4.8% 95.9%;--secondary-foreground:240 5.9% 10%;--muted:240 4.8% 95.9%;--muted-foreground:240 3.8% 46.1%;--accent:240 4.8% 95.9%;--accent-foreground:240 5.9% 10%;--destructive:0 84.2% 60.2%;--destructive-foreground:0 0% 98%;--border:240 5.9% 90%;--input:240 5.9% 90%;--ring:240 10% 3.9%;--radius:.5rem;--chart-1:12 76% 61%;--chart-2:173 58% 39%;--chart-3:197 37% 24%;--chart-4:43 74% 66%;--chart-5:27 87% 67%}.dark{--background:240 10% 3.9%;--foreground:0 0% 98%;--card:240 10% 3.9%;--card-foreground:0 0% 98%;--popover:240 10% 3.9%;--popover-foreground:0 0% 98%;--primary:0 0% 98%;--primary-foreground:240 5.9% 10%;--secondary:240 3.7% 15.9%;--secondary-foreground:0 0% 98%;--muted:240 3.7% 15.9%;--muted-foreground:240 5% 64.9%;--accent:240 3.7% 15.9%;--accent-foreground:0 0% 98%;--destructive:0 62.8% 30.6%;--destructive-foreground:0 0% 98%;--border:240 3.7% 15.9%;--input:240 3.7% 15.9%;--ring:240 4.9% 83.9%;--chart-1:220 70% 50%;--chart-2:160 60% 45%;--chart-3:30 80% 55%;--chart-4:280 65% 60%;--chart-5:340 75% 55%}}@layer components;@layer utilities{.collapse{visibility:collapse}.invisible{visibility:hidden}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.top-0{top:calc(var(--spacing)*0)}.top-3{top:calc(var(--spacing)*3)}.top-\[2px\]{top:2px}.top-\[12px\]{top:12px}.right-0{right:calc(var(--spacing)*0)}.right-\[12px\]{right:12px}.bottom-0{bottom:calc(var(--spacing)*0)}.bottom-0\.5{bottom:calc(var(--spacing)*.5)}.left-0{left:calc(var(--spacing)*0)}.left-\[50\.5px\]{left:50.5px}.isolate{isolation:isolate}.z-1{z-index:var(--z-index-1)}.z-\[1100\]{z-index:1100}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.mx-0{margin-inline:calc(var(--spacing)*0)}.mx-0\.5{margin-inline:calc(var(--spacing)*.5)}.mx-2{margin-inline:calc(var(--spacing)*2)}.mx-6{margin-inline:calc(var(--spacing)*6)}.my-0\.5{margin-block:calc(var(--spacing)*.5)}.my-1{margin-block:calc(var(--spacing)*1)}.my-1\.5{margin-block:calc(var(--spacing)*1.5)}.my-2\.5{margin-block:calc(var(--spacing)*2.5)}.my-6{margin-block:calc(var(--spacing)*6)}.my-8{margin-block:calc(var(--spacing)*8)}.mt-1\.5{margin-top:calc(var(--spacing)*1.5)}.mt-2{margin-top:calc(var(--spacing)*2)}.mt-4{margin-top:calc(var(--spacing)*4)}.mt-5{margin-top:calc(var(--spacing)*5)}.mt-8{margin-top:calc(var(--spacing)*8)}.mt-10{margin-top:calc(var(--spacing)*10)}.mr-0\.5{margin-right:calc(var(--spacing)*.5)}.mr-2{margin-right:calc(var(--spacing)*2)}.mr-3{margin-right:calc(var(--spacing)*3)}.mr-4{margin-right:calc(var(--spacing)*4)}.mr-\[3px\]{margin-right:3px}.mb-2{margin-bottom:calc(var(--spacing)*2)}.mb-4{margin-bottom:calc(var(--spacing)*4)}.mb-5{margin-bottom:calc(var(--spacing)*5)}.mb-6{margin-bottom:calc(var(--spacing)*6)}.mb-12{margin-bottom:calc(var(--spacing)*12)}.mb-14{margin-bottom:calc(var(--spacing)*14)}.mb-spacing-unit{margin-bottom:var(--margin-spacing-unit)}.ml-1\.5{margin-left:calc(var(--spacing)*1.5)}.ml-\[0\.2em\]{margin-left:.2em}.box-border{box-sizing:border-box}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.table{display:table}.table-cell{display:table-cell}.aspect-square{aspect-ratio:1}.size-1{width:calc(var(--spacing)*1);height:calc(var(--spacing)*1)}.h-2{height:calc(var(--spacing)*2)}.h-2\.5{height:calc(var(--spacing)*2.5)}.h-4{height:calc(var(--spacing)*4)}.h-5{height:calc(var(--spacing)*5)}.h-6{height:calc(var(--spacing)*6)}.h-8{height:calc(var(--spacing)*8)}.h-10{height:calc(var(--spacing)*10)}.h-12{height:calc(var(--spacing)*12)}.h-16{height:calc(var(--spacing)*16)}.h-32{height:calc(var(--spacing)*32)}.h-40{height:calc(var(--spacing)*40)}.h-60{height:calc(var(--spacing)*60)}.h-84{height:calc(var(--spacing)*84)}.h-\[46px\]{height:46px}.h-\[150px\]{height:150px}.h-auto{height:auto}.h-dvh{height:100dvh}.h-fit{height:fit-content}.h-full{height:100%}.h-screen{height:100vh}.min-h-dvh{min-height:100dvh}.w-2{width:calc(var(--spacing)*2)}.w-5{width:calc(var(--spacing)*5)}.w-6{width:calc(var(--spacing)*6)}.w-8{width:calc(var(--spacing)*8)}.w-10{width:calc(var(--spacing)*10)}.w-12{width:calc(var(--spacing)*12)}.w-16{width:calc(var(--spacing)*16)}.w-20{width:calc(var(--spacing)*20)}.w-64{width:calc(var(--spacing)*64)}.w-\[1px\]{width:1px}.w-\[46px\]{width:46px}.w-fit{width:fit-content}.w-full{width:100%}.w-screen{width:100vw}.\!max-w-none{max-width:none!important}.max-w-48{max-width:calc(var(--spacing)*48)}.max-w-\[1340px\]{max-width:1340px}.max-w-full{max-width:100%}.max-w-none{max-width:none}.min-w-0{min-width:calc(var(--spacing)*0)}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.shrink{flex-shrink:1}.shrink-0{flex-shrink:0}.grow{flex-grow:1}.-translate-x-1{--tw-translate-x:calc(var(--spacing)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-y-0\.5{--tw-translate-y:calc(var(--spacing)*.5);translate:var(--tw-translate-x)var(--tw-translate-y)}.scale-100{--tw-scale-x:100%;--tw-scale-y:100%;--tw-scale-z:100%;scale:var(--tw-scale-x)var(--tw-scale-y)}.scale-125{--tw-scale-x:125%;--tw-scale-y:125%;--tw-scale-z:125%;scale:var(--tw-scale-x)var(--tw-scale-y)}.-rotate-45{rotate:-45deg}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.transform\!{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)!important}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.resize{resize:both}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-row-reverse{flex-direction:row-reverse}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-around{justify-content:space-around}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-start{justify-content:flex-start}.gap-1{gap:calc(var(--spacing)*1)}.gap-2{gap:calc(var(--spacing)*2)}.gap-3{gap:calc(var(--spacing)*3)}.gap-4{gap:calc(var(--spacing)*4)}.gap-5{gap:calc(var(--spacing)*5)}.gap-6{gap:calc(var(--spacing)*6)}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*2)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*2)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-x-0\.5>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing)*.5)*var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing)*.5)*calc(1 - var(--tw-space-x-reverse)))}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-3xl{border-radius:var(--radius-3xl)}.rounded-\[6\.2px\]{border-radius:6.2px}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-medium{border-radius:var(--radius-medium)}.rounded-small{border-radius:var(--radius-small)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-xs{border-radius:var(--radius-xs)}.rounded-t-large{border-top-left-radius:var(--radius-large);border-top-right-radius:var(--radius-large)}.rounded-t-lg{border-top-left-radius:var(--radius-lg);border-top-right-radius:var(--radius-lg)}.rounded-l-lg{border-top-left-radius:var(--radius-lg);border-bottom-left-radius:var(--radius-lg)}.rounded-tl-none{border-top-left-radius:0;border-top-left-radius:var(--radius-none)}.rounded-bl-lg{border-bottom-left-radius:var(--radius-lg)}.border{border-style:var(--tw-border-style);border-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-t-2{border-top-style:var(--tw-border-style);border-top-width:2px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-l{border-left-style:var(--tw-border-style);border-left-width:1px}.border-l-2{border-left-style:var(--tw-border-style);border-left-width:2px}.border-solid{--tw-border-style:solid;border-style:solid}.border-border-color{border-color:var(--color-border-color)}.border-shadow-color-1{border-color:var(--color-shadow-color-1)}.border-transparent{border-color:#0000}.border-white\/20{border-color:#fff3}@supports (color:color-mix(in lab, red, red)){.border-white\/20{border-color:color-mix(in oklab,var(--color-white)20%,transparent)}}.border-t-border-color{border-top-color:var(--color-border-color)}.bg-background-color{background-color:var(--color-background-color)}.bg-background-color-transparent{background-color:var(--color-background-color-transparent)}.bg-background-color-transparent-15{background-color:var(--color-background-color-transparent-15)}.bg-background-color-transparent-40{background-color:var(--color-background-color-transparent-40)}.bg-gray-300\/50{background-color:#d1d5dc80}@supports (color:color-mix(in lab, red, red)){.bg-gray-300\/50{background-color:color-mix(in oklab,var(--color-gray-300)50%,transparent)}}.bg-second-background-color{background-color:var(--color-second-background-color)}.bg-third-background-color{background-color:var(--color-third-background-color)}.bg-third-text-color{background-color:var(--color-third-text-color)}.bg-zinc-50{background-color:var(--color-zinc-50)}.bg-cover{background-size:cover}.object-contain{object-fit:contain}.object-cover{object-fit:cover}.p-3{padding:calc(var(--spacing)*3)}.p-4{padding:calc(var(--spacing)*4)}.p-5{padding:calc(var(--spacing)*5)}.p-\[1px\]{padding:1px}.px-2{padding-inline:calc(var(--spacing)*2)}.px-3{padding-inline:calc(var(--spacing)*3)}.px-4{padding-inline:calc(var(--spacing)*4)}.px-6{padding-inline:calc(var(--spacing)*6)}.px-7{padding-inline:calc(var(--spacing)*7)}.px-8{padding-inline:calc(var(--spacing)*8)}.px-\[10px\]{padding-inline:10px}.py-0\.5{padding-block:calc(var(--spacing)*.5)}.py-1\.5{padding-block:calc(var(--spacing)*1.5)}.py-2{padding-block:calc(var(--spacing)*2)}.py-3{padding-block:calc(var(--spacing)*3)}.py-5{padding-block:calc(var(--spacing)*5)}.py-8{padding-block:calc(var(--spacing)*8)}.py-\[2px\]{padding-block:2px}.pt-5{padding-top:calc(var(--spacing)*5)}.pt-6{padding-top:calc(var(--spacing)*6)}.pt-7{padding-top:calc(var(--spacing)*7)}.pt-10{padding-top:calc(var(--spacing)*10)}.pb-2{padding-bottom:calc(var(--spacing)*2)}.pb-4{padding-bottom:calc(var(--spacing)*4)}.pb-7{padding-bottom:calc(var(--spacing)*7)}.pb-8{padding-bottom:calc(var(--spacing)*8)}.pl-0{padding-left:calc(var(--spacing)*0)}.text-center{text-align:center}.align-baseline{vertical-align:baseline}.align-text-top{vertical-align:text-top}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[0\.7em\]{font-size:.7em}.text-\[0\.7rem\]{font-size:.7rem}.text-\[0\.65rem\]{font-size:.65rem}.text-\[3\.2rem\]{font-size:3.2rem}.leading-\[1\.5\]{--tw-leading:1.5;line-height:1.5}.leading-\[1\]{--tw-leading:1;line-height:1}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-light{--tw-font-weight:var(--font-weight-light);font-weight:var(--font-weight-light)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.text-wrap{text-wrap:wrap}.whitespace-nowrap{white-space:nowrap}.text-background-color{color:var(--color-background-color)}.text-border-color{color:var(--color-border-color)}.text-default-text-color{color:var(--color-default-text-color)}.text-red-600{color:var(--color-red-600)}.text-second-text-color{color:var(--color-second-text-color)}.text-third-text-color{color:var(--color-third-text-color)}.capitalize{text-transform:capitalize}.lowercase{text-transform:lowercase}.uppercase{text-transform:uppercase}.italic{font-style:italic}.ordinal{--tw-ordinal:ordinal;font-variant-numeric:var(--tw-ordinal,)var(--tw-slashed-zero,)var(--tw-numeric-figure,)var(--tw-numeric-spacing,)var(--tw-numeric-fraction,)}.line-through{text-decoration-line:line-through}.overline{text-decoration-line:overline}.underline{text-decoration-line:underline}.opacity-0{opacity:0}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-none{--tw-shadow:0 0 #0000;box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-redefine-flat{--tw-shadow:0px 1px 4px 0px var(--tw-shadow-color,var(--shadow-color-2)),0px 0px 0px 1px var(--tw-shadow-color,var(--shadow-color-1));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(1px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-shadow-color-2{--tw-shadow-color:var(--color-shadow-color-2)}@supports (color:color-mix(in lab, red, red)){.shadow-shadow-color-2{--tw-shadow-color:color-mix(in oklab,var(--color-shadow-color-2)var(--tw-shadow-alpha),transparent)}}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.blur\!{--tw-blur:blur(8px)!important;filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)!important}.grayscale{--tw-grayscale:grayscale(100%);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.invert{--tw-invert:invert(100%);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.backdrop-blur-lg{--tw-backdrop-blur:blur(var(--blur-lg));-webkit-backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,visibility,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-shadow{transition-property:box-shadow;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-100{--tw-duration:.1s;transition-duration:.1s}.duration-200{--tw-duration:.2s;transition-duration:.2s}.duration-300{--tw-duration:.3s;transition-duration:.3s}.ease-in{--tw-ease:var(--ease-in);transition-timing-function:var(--ease-in)}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}.ease-linear{--tw-ease:linear;transition-timing-function:linear}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}.will-change-transform{will-change:transform}@media (hover:hover){.group-hover\:visible:is(:where(.group):hover *){visibility:visible}.group-hover\:translate-x-0:is(:where(.group):hover *){--tw-translate-x:calc(var(--spacing)*0);translate:var(--tw-translate-x)var(--tw-translate-y)}.group-hover\:translate-y-0:is(:where(.group):hover *){--tw-translate-y:calc(var(--spacing)*0);translate:var(--tw-translate-x)var(--tw-translate-y)}.group-hover\:translate-y-1:is(:where(.group):hover *){--tw-translate-y:calc(var(--spacing)*1);translate:var(--tw-translate-x)var(--tw-translate-y)}.group-hover\:scale-105:is(:where(.group):hover *){--tw-scale-x:105%;--tw-scale-y:105%;--tw-scale-z:105%;scale:var(--tw-scale-x)var(--tw-scale-y)}.group-hover\:\!text-primary:is(:where(.group):hover *){color:var(--color-primary)!important}.group-hover\:text-primary:is(:where(.group):hover *){color:var(--color-primary)}.group-hover\:opacity-100:is(:where(.group):hover *){opacity:1}}.group-active\:visible:is(:where(.group):active *){visibility:visible}.group-active\:translate-y-0:is(:where(.group):active *){--tw-translate-y:calc(var(--spacing)*0);translate:var(--tw-translate-x)var(--tw-translate-y)}.group-active\:opacity-100:is(:where(.group):active *){opacity:1}.last\:mb-0:last-child{margin-bottom:calc(var(--spacing)*0)}@media (hover:hover){.hover\:-translate-y-1:hover{--tw-translate-y:calc(var(--spacing)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.hover\:scale-102:hover{--tw-scale-x:102%;--tw-scale-y:102%;--tw-scale-z:102%;scale:var(--tw-scale-x)var(--tw-scale-y)}.hover\:transform:hover{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.hover\:border-primary:hover{border-color:var(--color-primary)}.hover\:border-second-background-color:hover{border-color:var(--color-second-background-color)}.hover\:bg-second-background-color:hover{background-color:var(--color-second-background-color)}.hover\:\!text-primary:hover{color:var(--color-primary)!important}.hover\:text-first-text-color:hover{color:var(--color-first-text-color)}.hover\:text-primary:hover{color:var(--color-primary)}.hover\:underline:hover{text-decoration-line:underline}.hover\:underline-offset-1:hover{text-underline-offset:1px}.hover\:shadow-none:hover{--tw-shadow:0 0 #0000;box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.hover\:shadow-redefine-flat-hover:hover{--tw-shadow:0px 1px 4px 0px var(--tw-shadow-color,var(--shadow-color-2)),0px 0px 0px 1px var(--tw-shadow-color,var(--shadow-color-1)),0px 0px 0px 1px inset var(--tw-shadow-color,var(--shadow-color-1));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.hover\:shadow-shadow-color-2:hover{--tw-shadow-color:var(--color-shadow-color-2)}@supports (color:color-mix(in lab, red, red)){.hover\:shadow-shadow-color-2:hover{--tw-shadow-color:color-mix(in oklab,var(--color-shadow-color-2)var(--tw-shadow-alpha),transparent)}}}.active\:scale-95:active{--tw-scale-x:95%;--tw-scale-y:95%;--tw-scale-z:95%;scale:var(--tw-scale-x)var(--tw-scale-y)}.active\:\!text-primary:active{color:var(--color-primary)!important}.active\:underline:active{text-decoration-line:underline}@media (min-width:40rem){.sm\:mx-6{margin-inline:calc(var(--spacing)*6)}.sm\:h-10{height:calc(var(--spacing)*10)}.sm\:h-72{height:calc(var(--spacing)*72)}.sm\:w-10{width:calc(var(--spacing)*10)}.sm\:scale-110{--tw-scale-x:110%;--tw-scale-y:110%;--tw-scale-z:110%;scale:var(--tw-scale-x)var(--tw-scale-y)}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:gap-2{gap:calc(var(--spacing)*2)}.sm\:rounded-t-large{border-top-left-radius:var(--radius-large);border-top-right-radius:var(--radius-large)}.sm\:px-6{padding-inline:calc(var(--spacing)*6)}.sm\:px-12{padding-inline:calc(var(--spacing)*12)}.sm\:py-0{padding-block:calc(var(--spacing)*0)}.sm\:py-6{padding-block:calc(var(--spacing)*6)}.sm\:text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.sm\:text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.sm\:shadow-redefine{--tw-shadow:0px 6px 24px 0px var(--tw-shadow-color,var(--shadow-color-2)),0px 0px 0px 1px var(--tw-shadow-color,var(--shadow-color-1));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}@media (hover:hover){.sm\:hover\:shadow-redefine-hover:hover{--tw-shadow:0px 6px 24px 0px var(--tw-shadow-color,var(--shadow-color-2)),0px 0px 0px 1px var(--tw-shadow-color,var(--shadow-color-1)),0px 0px 0px 1px inset var(--tw-shadow-color,var(--shadow-color-1));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}}}@media (min-width:48rem){.md\:sticky{position:sticky}.md\:top-\[var\(--navbar-height\)\]{top:var(--navbar-height)}.md\:mx-8{margin-inline:calc(var(--spacing)*8)}.md\:my-2\.5{margin-block:calc(var(--spacing)*2.5)}.md\:block{display:block}.md\:hidden{display:none}.md\:h-44{height:calc(var(--spacing)*44)}.md\:h-80{height:calc(var(--spacing)*80)}.md\:w-48{width:calc(var(--spacing)*48)}.md\:flex-row{flex-direction:row}.md\:gap-12{gap:calc(var(--spacing)*12)}.md\:px-8{padding-inline:calc(var(--spacing)*8)}.md\:px-12{padding-inline:calc(var(--spacing)*12)}.md\:pb-0{padding-bottom:calc(var(--spacing)*0)}.md\:pl-8{padding-left:calc(var(--spacing)*8)}.md\:text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.md\:text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading,var(--text-5xl--line-height))}.md\:text-6xl{font-size:var(--text-6xl);line-height:var(--tw-leading,var(--text-6xl--line-height))}.md\:text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.md\:whitespace-normal{white-space:normal}}@media (min-width:64rem){.lg\:absolute{position:absolute}.lg\:top-1\/2{top:50%}.lg\:right-\[20px\]{right:20px}.lg\:left-\[20px\]{left:20px}.lg\:\!block{display:block!important}.lg\:block{display:block}.lg\:-translate-y-1\/2{--tw-translate-y:calc(calc(1/2*100%)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:text-left{text-align:left}.lg\:text-right{text-align:right}}.dark\:block:is(.dark *){display:block}.dark\:hidden:is(.dark *){display:none}.dark\:border-gray-500\/30:is(.dark *){border-color:#6a72824d}@supports (color:color-mix(in lab, red, red)){.dark\:border-gray-500\/30:is(.dark *){border-color:color-mix(in oklab,var(--color-gray-500)30%,transparent)}}.dark\:bg-gray-500\/40:is(.dark *){background-color:#6a728266}@supports (color:color-mix(in lab, red, red)){.dark\:bg-gray-500\/40:is(.dark *){background-color:color-mix(in oklab,var(--color-gray-500)40%,transparent)}}.dark\:bg-zinc-800:is(.dark *){background-color:var(--color-zinc-800)}.dark\:text-red-400:is(.dark *){color:var(--color-red-400)}.dark\:brightness-75:is(.dark *){--tw-brightness:brightness(75%);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}}.scrollbar-hide{-ms-overflow-style:none;scrollbar-width:none}.scrollbar-hide::-webkit-scrollbar{display:none}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-space-x-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}
\ No newline at end of file
+/*! tailwindcss v4.1.17 | MIT License | https://tailwindcss.com */
+@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-space-x-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-red-400:oklch(70.4% .191 22.216);--color-red-600:oklch(57.7% .245 27.325);--color-gray-200:oklch(92.8% .006 264.531);--color-gray-300:oklch(87.2% .01 258.338);--color-gray-500:oklch(55.1% .027 264.364);--color-zinc-50:oklch(98.5% 0 0);--color-zinc-800:oklch(27.4% .006 286.033);--color-white:#fff;--spacing:.25rem;--text-xs:.75rem;--text-xs--line-height:calc(1/.75);--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--text-base:1rem;--text-base--line-height:calc(1.5/1);--text-lg:1.125rem;--text-lg--line-height:calc(1.75/1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75/1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2/1.5);--text-3xl:1.875rem;--text-3xl--line-height:calc(2.25/1.875);--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5/2.25);--text-5xl:3rem;--text-5xl--line-height:1;--text-6xl:3.75rem;--text-6xl--line-height:1;--font-weight-light:300;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-tight:-.025em;--radius-xs:.125rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--radius-3xl:1.5rem;--ease-in:cubic-bezier(.4,0,1,1);--ease-out:cubic-bezier(0,0,.2,1);--ease-in-out:cubic-bezier(.4,0,.2,1);--blur-lg:16px;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--margin-spacing-unit:38px;--z-index-1:1001;--radius-none:0px;--radius-small:9px;--radius-medium:14px;--radius-large:18px;--color-primary:var(--primary-color);--color-background-color:var(--background-color);--color-background-color-transparent:var(--background-color-transparent);--color-background-color-transparent-15:var(--background-color-transparent-15);--color-background-color-transparent-40:var(--background-color-transparent-40);--color-second-background-color:var(--second-background-color);--color-third-background-color:var(--third-background-color);--color-first-text-color:var(--first-text-color);--color-second-text-color:var(--second-text-color);--color-third-text-color:var(--third-text-color);--color-default-text-color:var(--default-text-color);--color-border-color:var(--border-color);--color-shadow-color-1:var(--shadow-color-1);--color-shadow-color-2:var(--shadow-color-2)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}*,:after,:before,::backdrop{border-color:var(--color-gray-200,currentcolor)}::file-selector-button{border-color:var(--color-gray-200,currentcolor)}:root{--background:0 0% 100%;--foreground:240 10% 3.9%;--card:0 0% 100%;--card-foreground:240 10% 3.9%;--popover:0 0% 100%;--popover-foreground:240 10% 3.9%;--primary:240 5.9% 10%;--primary-foreground:0 0% 98%;--secondary:240 4.8% 95.9%;--secondary-foreground:240 5.9% 10%;--muted:240 4.8% 95.9%;--muted-foreground:240 3.8% 46.1%;--accent:240 4.8% 95.9%;--accent-foreground:240 5.9% 10%;--destructive:0 84.2% 60.2%;--destructive-foreground:0 0% 98%;--border:240 5.9% 90%;--input:240 5.9% 90%;--ring:240 10% 3.9%;--radius:.5rem;--chart-1:12 76% 61%;--chart-2:173 58% 39%;--chart-3:197 37% 24%;--chart-4:43 74% 66%;--chart-5:27 87% 67%}.dark{--background:240 10% 3.9%;--foreground:0 0% 98%;--card:240 10% 3.9%;--card-foreground:0 0% 98%;--popover:240 10% 3.9%;--popover-foreground:0 0% 98%;--primary:0 0% 98%;--primary-foreground:240 5.9% 10%;--secondary:240 3.7% 15.9%;--secondary-foreground:0 0% 98%;--muted:240 3.7% 15.9%;--muted-foreground:240 5% 64.9%;--accent:240 3.7% 15.9%;--accent-foreground:0 0% 98%;--destructive:0 62.8% 30.6%;--destructive-foreground:0 0% 98%;--border:240 3.7% 15.9%;--input:240 3.7% 15.9%;--ring:240 4.9% 83.9%;--chart-1:220 70% 50%;--chart-2:160 60% 45%;--chart-3:30 80% 55%;--chart-4:280 65% 60%;--chart-5:340 75% 55%}}@layer components;@layer utilities{.collapse{visibility:collapse}.invisible{visibility:hidden}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.top-0{top:calc(var(--spacing)*0)}.top-3{top:calc(var(--spacing)*3)}.top-\[2px\]{top:2px}.top-\[12px\]{top:12px}.right-0{right:calc(var(--spacing)*0)}.right-\[12px\]{right:12px}.bottom-0{bottom:calc(var(--spacing)*0)}.bottom-0\.5{bottom:calc(var(--spacing)*.5)}.left-0{left:calc(var(--spacing)*0)}.left-\[50\.5px\]{left:50.5px}.isolate{isolation:isolate}.z-1{z-index:var(--z-index-1)}.z-\[1100\]{z-index:1100}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.mx-0{margin-inline:calc(var(--spacing)*0)}.mx-0\.5{margin-inline:calc(var(--spacing)*.5)}.mx-2{margin-inline:calc(var(--spacing)*2)}.mx-6{margin-inline:calc(var(--spacing)*6)}.my-0\.5{margin-block:calc(var(--spacing)*.5)}.my-1{margin-block:calc(var(--spacing)*1)}.my-1\.5{margin-block:calc(var(--spacing)*1.5)}.my-2\.5{margin-block:calc(var(--spacing)*2.5)}.my-6{margin-block:calc(var(--spacing)*6)}.my-8{margin-block:calc(var(--spacing)*8)}.mt-1\.5{margin-top:calc(var(--spacing)*1.5)}.mt-2{margin-top:calc(var(--spacing)*2)}.mt-4{margin-top:calc(var(--spacing)*4)}.mt-5{margin-top:calc(var(--spacing)*5)}.mt-8{margin-top:calc(var(--spacing)*8)}.mt-10{margin-top:calc(var(--spacing)*10)}.mr-0\.5{margin-right:calc(var(--spacing)*.5)}.mr-2{margin-right:calc(var(--spacing)*2)}.mr-3{margin-right:calc(var(--spacing)*3)}.mr-4{margin-right:calc(var(--spacing)*4)}.mr-\[3px\]{margin-right:3px}.mb-2{margin-bottom:calc(var(--spacing)*2)}.mb-4{margin-bottom:calc(var(--spacing)*4)}.mb-5{margin-bottom:calc(var(--spacing)*5)}.mb-6{margin-bottom:calc(var(--spacing)*6)}.mb-12{margin-bottom:calc(var(--spacing)*12)}.mb-14{margin-bottom:calc(var(--spacing)*14)}.mb-spacing-unit{margin-bottom:var(--margin-spacing-unit)}.ml-1\.5{margin-left:calc(var(--spacing)*1.5)}.ml-\[0\.2em\]{margin-left:.2em}.box-border{box-sizing:border-box}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.table{display:table}.table-cell{display:table-cell}.aspect-square{aspect-ratio:1}.size-1{width:calc(var(--spacing)*1);height:calc(var(--spacing)*1)}.h-2{height:calc(var(--spacing)*2)}.h-2\.5{height:calc(var(--spacing)*2.5)}.h-4{height:calc(var(--spacing)*4)}.h-5{height:calc(var(--spacing)*5)}.h-6{height:calc(var(--spacing)*6)}.h-8{height:calc(var(--spacing)*8)}.h-10{height:calc(var(--spacing)*10)}.h-12{height:calc(var(--spacing)*12)}.h-16{height:calc(var(--spacing)*16)}.h-32{height:calc(var(--spacing)*32)}.h-40{height:calc(var(--spacing)*40)}.h-60{height:calc(var(--spacing)*60)}.h-84{height:calc(var(--spacing)*84)}.h-\[46px\]{height:46px}.h-\[150px\]{height:150px}.h-auto{height:auto}.h-dvh{height:100dvh}.h-fit{height:fit-content}.h-full{height:100%}.h-screen{height:100vh}.min-h-dvh{min-height:100dvh}.w-2{width:calc(var(--spacing)*2)}.w-5{width:calc(var(--spacing)*5)}.w-6{width:calc(var(--spacing)*6)}.w-8{width:calc(var(--spacing)*8)}.w-10{width:calc(var(--spacing)*10)}.w-12{width:calc(var(--spacing)*12)}.w-16{width:calc(var(--spacing)*16)}.w-20{width:calc(var(--spacing)*20)}.w-64{width:calc(var(--spacing)*64)}.w-\[1px\]{width:1px}.w-\[46px\]{width:46px}.w-fit{width:fit-content}.w-full{width:100%}.w-screen{width:100vw}.\!max-w-none{max-width:none!important}.max-w-48{max-width:calc(var(--spacing)*48)}.max-w-\[1340px\]{max-width:1340px}.max-w-full{max-width:100%}.max-w-none{max-width:none}.min-w-0{min-width:calc(var(--spacing)*0)}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.shrink{flex-shrink:1}.shrink-0{flex-shrink:0}.grow{flex-grow:1}.-translate-x-1{--tw-translate-x:calc(var(--spacing)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-y-0\.5{--tw-translate-y:calc(var(--spacing)*.5);translate:var(--tw-translate-x)var(--tw-translate-y)}.scale-100{--tw-scale-x:100%;--tw-scale-y:100%;--tw-scale-z:100%;scale:var(--tw-scale-x)var(--tw-scale-y)}.scale-125{--tw-scale-x:125%;--tw-scale-y:125%;--tw-scale-z:125%;scale:var(--tw-scale-x)var(--tw-scale-y)}.-rotate-45{rotate:-45deg}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.transform\!{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)!important}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.resize{resize:both}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-row-reverse{flex-direction:row-reverse}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-around{justify-content:space-around}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-start{justify-content:flex-start}.gap-1{gap:calc(var(--spacing)*1)}.gap-2{gap:calc(var(--spacing)*2)}.gap-3{gap:calc(var(--spacing)*3)}.gap-4{gap:calc(var(--spacing)*4)}.gap-5{gap:calc(var(--spacing)*5)}.gap-6{gap:calc(var(--spacing)*6)}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*2)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*2)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-x-0\.5>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing)*.5)*var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing)*.5)*calc(1 - var(--tw-space-x-reverse)))}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-3xl{border-radius:var(--radius-3xl)}.rounded-\[6\.2px\]{border-radius:6.2px}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-medium{border-radius:var(--radius-medium)}.rounded-small{border-radius:var(--radius-small)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-xs{border-radius:var(--radius-xs)}.rounded-t-large{border-top-left-radius:var(--radius-large);border-top-right-radius:var(--radius-large)}.rounded-t-lg{border-top-left-radius:var(--radius-lg);border-top-right-radius:var(--radius-lg)}.rounded-l-lg{border-top-left-radius:var(--radius-lg);border-bottom-left-radius:var(--radius-lg)}.rounded-tl-none{border-top-left-radius:var(--radius-none)}.rounded-bl-lg{border-bottom-left-radius:var(--radius-lg)}.border{border-style:var(--tw-border-style);border-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-t-2{border-top-style:var(--tw-border-style);border-top-width:2px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-l{border-left-style:var(--tw-border-style);border-left-width:1px}.border-l-2{border-left-style:var(--tw-border-style);border-left-width:2px}.border-solid{--tw-border-style:solid;border-style:solid}.border-border-color{border-color:var(--color-border-color)}.border-shadow-color-1{border-color:var(--color-shadow-color-1)}.border-transparent{border-color:#0000}.border-white\/20{border-color:#fff3}@supports (color:color-mix(in lab, red, red)){.border-white\/20{border-color:color-mix(in oklab,var(--color-white)20%,transparent)}}.border-t-border-color{border-top-color:var(--color-border-color)}.bg-background-color{background-color:var(--color-background-color)}.bg-background-color-transparent{background-color:var(--color-background-color-transparent)}.bg-background-color-transparent-15{background-color:var(--color-background-color-transparent-15)}.bg-background-color-transparent-40{background-color:var(--color-background-color-transparent-40)}.bg-gray-300\/50{background-color:#d1d5dc80}@supports (color:color-mix(in lab, red, red)){.bg-gray-300\/50{background-color:color-mix(in oklab,var(--color-gray-300)50%,transparent)}}.bg-second-background-color{background-color:var(--color-second-background-color)}.bg-third-background-color{background-color:var(--color-third-background-color)}.bg-third-text-color{background-color:var(--color-third-text-color)}.bg-zinc-50{background-color:var(--color-zinc-50)}.bg-cover{background-size:cover}.object-contain{object-fit:contain}.object-cover{object-fit:cover}.p-3{padding:calc(var(--spacing)*3)}.p-4{padding:calc(var(--spacing)*4)}.p-5{padding:calc(var(--spacing)*5)}.p-\[1px\]{padding:1px}.px-2{padding-inline:calc(var(--spacing)*2)}.px-3{padding-inline:calc(var(--spacing)*3)}.px-4{padding-inline:calc(var(--spacing)*4)}.px-6{padding-inline:calc(var(--spacing)*6)}.px-7{padding-inline:calc(var(--spacing)*7)}.px-8{padding-inline:calc(var(--spacing)*8)}.px-\[10px\]{padding-inline:10px}.py-0\.5{padding-block:calc(var(--spacing)*.5)}.py-1\.5{padding-block:calc(var(--spacing)*1.5)}.py-2{padding-block:calc(var(--spacing)*2)}.py-3{padding-block:calc(var(--spacing)*3)}.py-5{padding-block:calc(var(--spacing)*5)}.py-8{padding-block:calc(var(--spacing)*8)}.py-\[2px\]{padding-block:2px}.pt-5{padding-top:calc(var(--spacing)*5)}.pt-6{padding-top:calc(var(--spacing)*6)}.pt-7{padding-top:calc(var(--spacing)*7)}.pt-10{padding-top:calc(var(--spacing)*10)}.pb-2{padding-bottom:calc(var(--spacing)*2)}.pb-4{padding-bottom:calc(var(--spacing)*4)}.pb-7{padding-bottom:calc(var(--spacing)*7)}.pb-8{padding-bottom:calc(var(--spacing)*8)}.pl-0{padding-left:calc(var(--spacing)*0)}.text-center{text-align:center}.align-baseline{vertical-align:baseline}.align-text-top{vertical-align:text-top}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[0\.7em\]{font-size:.7em}.text-\[0\.7rem\]{font-size:.7rem}.text-\[0\.65rem\]{font-size:.65rem}.text-\[3\.2rem\]{font-size:3.2rem}.leading-\[1\.5\]{--tw-leading:1.5;line-height:1.5}.leading-\[1\]{--tw-leading:1;line-height:1}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-light{--tw-font-weight:var(--font-weight-light);font-weight:var(--font-weight-light)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.text-wrap{text-wrap:wrap}.whitespace-nowrap{white-space:nowrap}.text-background-color{color:var(--color-background-color)}.text-border-color{color:var(--color-border-color)}.text-default-text-color{color:var(--color-default-text-color)}.text-red-600{color:var(--color-red-600)}.text-second-text-color{color:var(--color-second-text-color)}.text-third-text-color{color:var(--color-third-text-color)}.capitalize{text-transform:capitalize}.lowercase{text-transform:lowercase}.uppercase{text-transform:uppercase}.italic{font-style:italic}.ordinal{--tw-ordinal:ordinal;font-variant-numeric:var(--tw-ordinal,)var(--tw-slashed-zero,)var(--tw-numeric-figure,)var(--tw-numeric-spacing,)var(--tw-numeric-fraction,)}.line-through{text-decoration-line:line-through}.overline{text-decoration-line:overline}.underline{text-decoration-line:underline}.opacity-0{opacity:0}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-none{--tw-shadow:0 0 #0000;box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-redefine-flat{--tw-shadow:0px 1px 4px 0px var(--tw-shadow-color,var(--shadow-color-2)),0px 0px 0px 1px var(--tw-shadow-color,var(--shadow-color-1));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(1px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-shadow-color-2{--tw-shadow-color:var(--color-shadow-color-2)}@supports (color:color-mix(in lab, red, red)){.shadow-shadow-color-2{--tw-shadow-color:color-mix(in oklab,var(--color-shadow-color-2)var(--tw-shadow-alpha),transparent)}}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.blur\!{--tw-blur:blur(8px)!important;filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)!important}.grayscale{--tw-grayscale:grayscale(100%);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.invert{--tw-invert:invert(100%);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.backdrop-blur-lg{--tw-backdrop-blur:blur(var(--blur-lg));-webkit-backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-shadow{transition-property:box-shadow;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-100{--tw-duration:.1s;transition-duration:.1s}.duration-200{--tw-duration:.2s;transition-duration:.2s}.duration-300{--tw-duration:.3s;transition-duration:.3s}.ease-in{--tw-ease:var(--ease-in);transition-timing-function:var(--ease-in)}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}.ease-linear{--tw-ease:linear;transition-timing-function:linear}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}.will-change-transform{will-change:transform}@media (hover:hover){.group-hover\:visible:is(:where(.group):hover *){visibility:visible}.group-hover\:translate-x-0:is(:where(.group):hover *){--tw-translate-x:calc(var(--spacing)*0);translate:var(--tw-translate-x)var(--tw-translate-y)}.group-hover\:translate-y-0:is(:where(.group):hover *){--tw-translate-y:calc(var(--spacing)*0);translate:var(--tw-translate-x)var(--tw-translate-y)}.group-hover\:translate-y-1:is(:where(.group):hover *){--tw-translate-y:calc(var(--spacing)*1);translate:var(--tw-translate-x)var(--tw-translate-y)}.group-hover\:scale-105:is(:where(.group):hover *){--tw-scale-x:105%;--tw-scale-y:105%;--tw-scale-z:105%;scale:var(--tw-scale-x)var(--tw-scale-y)}.group-hover\:\!text-primary:is(:where(.group):hover *){color:var(--color-primary)!important}.group-hover\:text-primary:is(:where(.group):hover *){color:var(--color-primary)}.group-hover\:opacity-100:is(:where(.group):hover *){opacity:1}}.group-active\:visible:is(:where(.group):active *){visibility:visible}.group-active\:translate-y-0:is(:where(.group):active *){--tw-translate-y:calc(var(--spacing)*0);translate:var(--tw-translate-x)var(--tw-translate-y)}.group-active\:opacity-100:is(:where(.group):active *){opacity:1}.last\:mb-0:last-child{margin-bottom:calc(var(--spacing)*0)}@media (hover:hover){.hover\:-translate-y-1:hover{--tw-translate-y:calc(var(--spacing)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.hover\:scale-102:hover{--tw-scale-x:102%;--tw-scale-y:102%;--tw-scale-z:102%;scale:var(--tw-scale-x)var(--tw-scale-y)}.hover\:transform:hover{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.hover\:border-primary:hover{border-color:var(--color-primary)}.hover\:border-second-background-color:hover{border-color:var(--color-second-background-color)}.hover\:bg-second-background-color:hover{background-color:var(--color-second-background-color)}.hover\:\!text-primary:hover{color:var(--color-primary)!important}.hover\:text-first-text-color:hover{color:var(--color-first-text-color)}.hover\:text-primary:hover{color:var(--color-primary)}.hover\:underline:hover{text-decoration-line:underline}.hover\:underline-offset-1:hover{text-underline-offset:1px}.hover\:shadow-none:hover{--tw-shadow:0 0 #0000;box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.hover\:shadow-redefine-flat-hover:hover{--tw-shadow:0px 1px 4px 0px var(--tw-shadow-color,var(--shadow-color-2)),0px 0px 0px 1px var(--tw-shadow-color,var(--shadow-color-1)),0px 0px 0px 1px inset var(--tw-shadow-color,var(--shadow-color-1));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.hover\:shadow-shadow-color-2:hover{--tw-shadow-color:var(--color-shadow-color-2)}@supports (color:color-mix(in lab, red, red)){.hover\:shadow-shadow-color-2:hover{--tw-shadow-color:color-mix(in oklab,var(--color-shadow-color-2)var(--tw-shadow-alpha),transparent)}}}.active\:scale-95:active{--tw-scale-x:95%;--tw-scale-y:95%;--tw-scale-z:95%;scale:var(--tw-scale-x)var(--tw-scale-y)}.active\:\!text-primary:active{color:var(--color-primary)!important}.active\:underline:active{text-decoration-line:underline}@media (min-width:40rem){.sm\:mx-6{margin-inline:calc(var(--spacing)*6)}.sm\:h-10{height:calc(var(--spacing)*10)}.sm\:h-72{height:calc(var(--spacing)*72)}.sm\:w-10{width:calc(var(--spacing)*10)}.sm\:scale-110{--tw-scale-x:110%;--tw-scale-y:110%;--tw-scale-z:110%;scale:var(--tw-scale-x)var(--tw-scale-y)}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:gap-2{gap:calc(var(--spacing)*2)}.sm\:rounded-t-large{border-top-left-radius:var(--radius-large);border-top-right-radius:var(--radius-large)}.sm\:px-6{padding-inline:calc(var(--spacing)*6)}.sm\:px-12{padding-inline:calc(var(--spacing)*12)}.sm\:py-0{padding-block:calc(var(--spacing)*0)}.sm\:py-6{padding-block:calc(var(--spacing)*6)}.sm\:text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.sm\:text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.sm\:shadow-redefine{--tw-shadow:0px 6px 24px 0px var(--tw-shadow-color,var(--shadow-color-2)),0px 0px 0px 1px var(--tw-shadow-color,var(--shadow-color-1));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}@media (hover:hover){.sm\:hover\:shadow-redefine-hover:hover{--tw-shadow:0px 6px 24px 0px var(--tw-shadow-color,var(--shadow-color-2)),0px 0px 0px 1px var(--tw-shadow-color,var(--shadow-color-1)),0px 0px 0px 1px inset var(--tw-shadow-color,var(--shadow-color-1));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}}}@media (min-width:48rem){.md\:sticky{position:sticky}.md\:top-\[var\(--navbar-height\)\]{top:var(--navbar-height)}.md\:mx-8{margin-inline:calc(var(--spacing)*8)}.md\:my-2\.5{margin-block:calc(var(--spacing)*2.5)}.md\:block{display:block}.md\:hidden{display:none}.md\:h-44{height:calc(var(--spacing)*44)}.md\:h-80{height:calc(var(--spacing)*80)}.md\:w-48{width:calc(var(--spacing)*48)}.md\:flex-row{flex-direction:row}.md\:gap-12{gap:calc(var(--spacing)*12)}.md\:px-8{padding-inline:calc(var(--spacing)*8)}.md\:px-12{padding-inline:calc(var(--spacing)*12)}.md\:pb-0{padding-bottom:calc(var(--spacing)*0)}.md\:pl-8{padding-left:calc(var(--spacing)*8)}.md\:text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.md\:text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading,var(--text-5xl--line-height))}.md\:text-6xl{font-size:var(--text-6xl);line-height:var(--tw-leading,var(--text-6xl--line-height))}.md\:text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.md\:whitespace-normal{white-space:normal}}@media (min-width:64rem){.lg\:absolute{position:absolute}.lg\:top-1\/2{top:50%}.lg\:right-\[20px\]{right:20px}.lg\:left-\[20px\]{left:20px}.lg\:\!block{display:block!important}.lg\:block{display:block}.lg\:-translate-y-1\/2{--tw-translate-y:calc(calc(1/2*100%)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:text-left{text-align:left}.lg\:text-right{text-align:right}}.dark\:block:is(.dark *){display:block}.dark\:hidden:is(.dark *){display:none}.dark\:border-gray-500\/30:is(.dark *){border-color:#6a72824d}@supports (color:color-mix(in lab, red, red)){.dark\:border-gray-500\/30:is(.dark *){border-color:color-mix(in oklab,var(--color-gray-500)30%,transparent)}}.dark\:bg-gray-500\/40:is(.dark *){background-color:#6a728266}@supports (color:color-mix(in lab, red, red)){.dark\:bg-gray-500\/40:is(.dark *){background-color:color-mix(in oklab,var(--color-gray-500)40%,transparent)}}.dark\:bg-zinc-800:is(.dark *){background-color:var(--color-zinc-800)}.dark\:text-red-400:is(.dark *){color:var(--color-red-400)}.dark\:brightness-75:is(.dark *){--tw-brightness:brightness(75%);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}}.scrollbar-hide{-ms-overflow-style:none;scrollbar-width:none}.scrollbar-hide::-webkit-scrollbar{display:none}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-space-x-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}
\ No newline at end of file
diff --git a/source/css/layout/masonry-modal.styl b/source/css/layout/masonry-modal.styl
new file mode 100644
index 00000000..8f74a855
--- /dev/null
+++ b/source/css/layout/masonry-modal.styl
@@ -0,0 +1,197 @@
+@require '../common/variables'
+
+// 瀑布流项目悬停效果
+.masonry-item
+ cursor pointer
+ transition transform 0.3s ease
+ position relative
+ overflow hidden
+ border-radius 8px
+
+ &:hover
+ transform scale(1.05)
+
+ .masonry-item-title,
+ .masonry-item-description
+ opacity 1
+
+// 图片悬停overlay
+.image-container
+ position relative
+ width 100%
+ height 100%
+ overflow hidden
+
+// 标题 - 左上角
+.masonry-item-title
+ position absolute
+ top 10px
+ left 10px
+ font-size 13px
+ font-weight bold
+ color rgba(31, 32, 32, 0.5)
+ z-index 100
+ padding 8px 12px
+ background rgba(165, 162, 159, 0.95)
+ border-radius 10px
+ max-width calc(100% - 40px)
+ line-height 1.4
+ word-break break-word
+ opacity 0
+ transition opacity 0.3s ease
+
+// 描述 - 右下角
+.masonry-item-description
+ position absolute
+ bottom 10px
+ right 10px
+ font-size 13px
+ color rgba(31, 32, 32, 0.5)
+ z-index 100
+ padding 8px 12px
+ background rgba(165, 162, 159, 0.95)
+ border-radius 10px
+ max-width calc(100% - 40px)
+ text-align right
+ line-height 1.4
+ word-break break-word
+ display -webkit-box
+ -webkit-line-clamp 2
+ -webkit-box-orient vertical
+ overflow hidden
+ opacity 0
+ transition opacity 0.3s ease
+
+// 模态框背景
+.masonry-modal
+ position fixed
+ top 0
+ left 0
+ right 0
+ bottom 0
+ background rgba(0, 0, 0, 0.5)
+ display flex
+ align-items center
+ justify-content center
+ z-index 9999
+ opacity 0
+ transition opacity 0.3s ease
+
+ &.show
+ opacity 1
+
+// 模态框内容
+.masonry-modal-content
+ background var(--background-color)
+ border-radius 12px
+ max-width 1200px
+ width 95%
+ max-height 90vh
+ overflow-y auto
+ position relative
+ box-shadow 0 10px 40px rgba(0, 0, 0, 0.3)
+
+// 关闭按钮
+.masonry-modal-close
+ position absolute
+ top 15px
+ right 15px
+ background none
+ border none
+ font-size 28px
+ cursor pointer
+ color #999
+ z-index 10000
+ transition color 0.3s ease
+
+ &:hover
+ color var(--text-color)
+
+// 模态框主体
+.masonry-modal-body
+ display flex
+ gap 30px
+ padding 30px
+
+ +redefine-tablet()
+ padding 20px
+ gap 20px
+
+ +redefine-mobile()
+ flex-direction column
+ padding 20px
+ gap 20px
+
+// 图片容器
+.masonry-modal-image
+ flex 1
+ min-width 400px
+ display flex
+ align-items center
+ justify-content center
+ overflow hidden
+ background var(--second-background-color)
+ border-radius 8px
+ position relative
+
+ img
+ width 100%
+ height auto
+ border-radius 8px
+ display block
+ cursor grab
+ transition cursor 0.2s ease
+ transform-origin center
+ transform-box fill-box
+
+ &:active
+ cursor grabbing
+
+// 信息容器
+.masonry-modal-info
+ flex 0 0 300px
+ display flex
+ flex-direction column
+ gap 20px
+
+ +redefine-tablet()
+ flex 1
+ min-width auto
+
+ h2
+ margin 0
+ font-size 24px
+ color var(--text-color)
+ font-weight bold
+
+// 元数据容器
+.masonry-modal-meta
+ display flex
+ flex-direction column
+ gap 12px
+
+// 元数据项
+.meta-item
+ display flex
+ align-items center
+ gap 10px
+
+ .meta-label
+ font-weight bold
+ color var(--second-text-color)
+ min-width 80px
+
+ .meta-value
+ color var(--text-color)
+
+// 描述文本
+.masonry-modal-description
+ flex 1
+ overflow-y auto
+ padding-right 10px
+
+ p
+ margin 0
+ color var(--text-color)
+ line-height 1.6
+ word-break break-word
diff --git a/source/css/style.styl b/source/css/style.styl
index 9321fd37..4edb4bf5 100755
--- a/source/css/style.styl
+++ b/source/css/style.styl
@@ -21,6 +21,7 @@
@require 'layout/article-content.styl'
@require 'layout/category-content.styl'
@require 'layout/tag-content.styl'
+@require 'layout/masonry-modal.styl'
if (hexo-config('home.sidebar.enable') == true)
@require 'layout/home-sidebar.styl'
\ No newline at end of file
diff --git a/source/js/build/main.js b/source/js/build/main.js
index 2429c200..3025362c 100644
--- a/source/js/build/main.js
+++ b/source/js/build/main.js
@@ -1,2 +1,2 @@
-import _ from"./utils.js";import e from"./plugins/typed.js";import t from"./tools/lightDarkSwitch.js";import o from"./layouts/lazyload.js";import r from"./tools/scrollTopBottom.js";import n from"./tools/localSearch.js";import a from"./tools/codeBlock.js";import i from"./layouts/bookmarkNav.js";export const main={themeInfo:{theme:`Redefine v${theme.version}`,author:"EvanNotFound",repository:"https://github.com/EvanNotFound/hexo-theme-redefine"},localStorageKey:"REDEFINE-THEME-STATUS",styleStatus:{isExpandPageWidth:!1,isDark:theme.colors.default_mode&&"dark"===theme.colors.default_mode,fontSizeLevel:0,isOpenPageAside:!0},printThemeInfo:()=>{console.log(' ______ __ __ ______ __ __ ______ \r\n /\\__ _/\\ \\_\\ \\/\\ ___\\/\\ "-./ \\/\\ ___\\ \r\n \\/_/\\ \\\\ \\ __ \\ \\ __\\\\ \\ \\-./\\ \\ \\ __\\ \r\n \\ \\_\\\\ \\_\\ \\_\\ \\_____\\ \\_\\ \\ \\_\\ \\_____\\ \r\n \\/_/ \\/_/\\/_/\\/_____/\\/_/ \\/_/\\/_____/ \r\n \r\n ______ ______ _____ ______ ______ __ __ __ ______ \r\n/\\ == \\/\\ ___\\/\\ __-./\\ ___\\/\\ ___/\\ \\/\\ "-.\\ \\/\\ ___\\ \r\n\\ \\ __<\\ \\ __\\\\ \\ \\/\\ \\ \\ __\\\\ \\ __\\ \\ \\ \\ \\-. \\ \\ __\\ \r\n \\ \\_\\ \\_\\ \\_____\\ \\____-\\ \\_____\\ \\_\\ \\ \\_\\ \\_\\\\"\\_\\ \\_____\\ \r\n \\/_/ /_/\\/_____/\\/____/ \\/_____/\\/_/ \\/_/\\/_/ \\/_/\\/_____/\r\n \r\n Github: https://github.com/EvanNotFound/hexo-theme-redefine')},setStyleStatus:()=>{localStorage.setItem(main.localStorageKey,JSON.stringify(main.styleStatus))},getStyleStatus:()=>{let _=localStorage.getItem(main.localStorageKey);if(_){_=JSON.parse(_);for(let e in main.styleStatus)main.styleStatus[e]=_[e];return _}return null},refresh:()=>{_(),t(),r(),i(),0!==theme.home_banner.subtitle.text.length&&location.pathname===config.root&&e("subtitle"),!0===theme.navbar.search.enable&&n(),!0===theme.articles.code_block.copy&&a(),!0===theme.articles.lazyload&&o()}};export function initMain(){main.printThemeInfo(),main.refresh()}document.addEventListener("DOMContentLoaded",initMain);try{swup.hooks.on("page:view",(()=>{main.refresh()}))}catch(s){}
+import _ from"./utils.js";import e from"./plugins/typed.js";import t from"./tools/lightDarkSwitch.js";import o from"./layouts/lazyload.js";import r from"./tools/scrollTopBottom.js";import n from"./tools/localSearch.js";import a from"./tools/codeBlock.js";import s from"./layouts/bookmarkNav.js";import i from"./plugins/masonry.js";import l from"./plugins/masonry-modal.js";export const main={themeInfo:{theme:`Redefine v${theme.version}`,author:"EvanNotFound",repository:"https://github.com/EvanNotFound/hexo-theme-redefine"},localStorageKey:"REDEFINE-THEME-STATUS",styleStatus:{isExpandPageWidth:!1,isDark:theme.colors.default_mode&&"dark"===theme.colors.default_mode,fontSizeLevel:0,isOpenPageAside:!0},printThemeInfo:()=>{console.log(' ______ __ __ ______ __ __ ______ \r\n /\\__ _/\\ \\_\\ \\/\\ ___\\/\\ "-./ \\/\\ ___\\ \r\n \\/_/\\ \\\\ \\ __ \\ \\ __\\\\ \\ \\-./\\ \\ \\ __\\ \r\n \\ \\_\\\\ \\_\\ \\_\\ \\_____\\ \\_\\ \\ \\_\\ \\_____\\ \r\n \\/_/ \\/_/\\/_/\\/_____/\\/_/ \\/_/\\/_____/ \r\n \r\n ______ ______ _____ ______ ______ __ __ __ ______ \r\n/\\ == \\/\\ ___\\/\\ __-./\\ ___\\/\\ ___/\\ \\/\\ "-.\\ \\/\\ ___\\ \r\n\\ \\ __<\\ \\ __\\\\ \\ \\/\\ \\ \\ __\\\\ \\ __\\ \\ \\ \\ \\-. \\ \\ __\\ \r\n \\ \\_\\ \\_\\ \\_____\\ \\____-\\ \\_____\\ \\_\\ \\ \\_\\ \\_\\\\"\\_\\ \\_____\\ \r\n \\/_/ /_/\\/_____/\\/____/ \\/_____/\\/_/ \\/_/\\/_/ \\/_/\\/_____/\r\n \r\n Github: https://github.com/EvanNotFound/hexo-theme-redefine')},setStyleStatus:()=>{localStorage.setItem(main.localStorageKey,JSON.stringify(main.styleStatus))},getStyleStatus:()=>{let _=localStorage.getItem(main.localStorageKey);if(_){_=JSON.parse(_);for(let e in main.styleStatus)main.styleStatus[e]=_[e];return _}return null},refresh:()=>{console.log("[MAIN] refresh() called"),_(),t(),r(),s(),i(),l(),0!==theme.home_banner.subtitle.text.length&&location.pathname===config.root&&e("subtitle"),!0===theme.navbar.search.enable&&n(),!0===theme.articles.code_block.copy&&a(),!0===theme.articles.lazyload&&o()}};export function initMain(){main.printThemeInfo(),main.refresh()}document.addEventListener("DOMContentLoaded",initMain);try{swup.hooks.on("page:view",(()=>{main.refresh()}))}catch(m){}
//# sourceMappingURL=main.js.map
\ No newline at end of file
diff --git a/source/js/build/main.js.map b/source/js/build/main.js.map
index 6172ed8e..7afe5c7a 100644
--- a/source/js/build/main.js.map
+++ b/source/js/build/main.js.map
@@ -1 +1 @@
-{"version":3,"file":"main.js","names":["initUtils","initTyped","initModeToggle","initLazyLoad","initScrollTopBottom","initLocalSearch","initCopyCode","initBookmarkNav","main","themeInfo","theme","version","author","repository","localStorageKey","styleStatus","isExpandPageWidth","isDark","colors","default_mode","fontSizeLevel","isOpenPageAside","printThemeInfo","console","log","setStyleStatus","localStorage","setItem","JSON","stringify","getStyleStatus","temp","getItem","parse","key","refresh","home_banner","subtitle","text","length","location","pathname","config","root","navbar","search","enable","articles","code_block","copy","lazyload","initMain","document","addEventListener","swup","hooks","on","e"],"sources":["0"],"mappings":"OACOA,MAAe,oBACfC,MAAe,4BACfC,MAAoB,oCACpBC,MAAkB,+BAClBC,MAAyB,oCACzBC,MAAqB,gCACrBC,MAAkB,8BAClBC,MAAqB,kCAErB,MAAMC,KAAO,CAClBC,UAAW,CACTC,MAAO,aAAaA,MAAMC,UAC1BC,OAAQ,eACRC,WAAY,uDAEdC,gBAAiB,wBACjBC,YAAa,CACXC,mBAAmB,EACnBC,OAAQP,MAAMQ,OAAOC,cAA8C,SAA9BT,MAAMQ,OAAOC,aAClDC,cAAe,EACfC,iBAAiB,GAEnBC,eAAgB,KACdC,QAAQC,IACN,m/BACD,EAEHC,eAAgB,KACdC,aAAaC,QACXnB,KAAKM,gBACLc,KAAKC,UAAUrB,KAAKO,aACrB,EAEHe,eAAgB,KACd,IAAIC,EAAOL,aAAaM,QAAQxB,KAAKM,iBACrC,GAAIiB,EAAM,CACRA,EAAOH,KAAKK,MAAMF,GAClB,IAAK,IAAIG,KAAO1B,KAAKO,YACnBP,KAAKO,YAAYmB,GAAOH,EAAKG,GAE/B,OAAOH,CACT,CACE,OAAO,IACT,EAEFI,QAAS,KACPnC,IACAE,IACAE,IACAG,IAG6C,IAA3CG,MAAM0B,YAAYC,SAASC,KAAKC,QAChCC,SAASC,WAAaC,OAAOC,MAE7B1C,EAAU,aAGuB,IAA/BS,MAAMkC,OAAOC,OAAOC,QACtBzC,KAGqC,IAAnCK,MAAMqC,SAASC,WAAWC,MAC5B3C,KAG8B,IAA5BI,MAAMqC,SAASG,UACjB/C,GACF,UAIG,SAASgD,WACd3C,KAAKc,iBACLd,KAAK2B,SACP,CAEAiB,SAASC,iBAAiB,mBAAoBF,UAE9C,IACEG,KAAKC,MAAMC,GAAG,aAAa,KACzBhD,KAAK2B,SAAS,GAElB,CAAE,MAAOsB,GAAI","ignoreList":[]}
\ No newline at end of file
+{"version":3,"file":"main.js","names":["initUtils","initTyped","initModeToggle","initLazyLoad","initScrollTopBottom","initLocalSearch","initCopyCode","initBookmarkNav","initMasonryPlugin","initMasonryModalPlugin","main","themeInfo","theme","version","author","repository","localStorageKey","styleStatus","isExpandPageWidth","isDark","colors","default_mode","fontSizeLevel","isOpenPageAside","printThemeInfo","console","log","setStyleStatus","localStorage","setItem","JSON","stringify","getStyleStatus","temp","getItem","parse","key","refresh","home_banner","subtitle","text","length","location","pathname","config","root","navbar","search","enable","articles","code_block","copy","lazyload","initMain","document","addEventListener","swup","hooks","on","e"],"sources":["0"],"mappings":"OACOA,MAAe,oBACfC,MAAe,4BACfC,MAAoB,oCACpBC,MAAkB,+BAClBC,MAAyB,oCACzBC,MAAqB,gCACrBC,MAAkB,8BAClBC,MAAqB,kCACrBC,MAAuB,8BACvBC,MAA4B,oCAE5B,MAAMC,KAAO,CAClBC,UAAW,CACTC,MAAO,aAAaA,MAAMC,UAC1BC,OAAQ,eACRC,WAAY,uDAEdC,gBAAiB,wBACjBC,YAAa,CACXC,mBAAmB,EACnBC,OAAQP,MAAMQ,OAAOC,cAA8C,SAA9BT,MAAMQ,OAAOC,aAClDC,cAAe,EACfC,iBAAiB,GAEnBC,eAAgB,KACdC,QAAQC,IACN,m/BACD,EAEHC,eAAgB,KACdC,aAAaC,QACXnB,KAAKM,gBACLc,KAAKC,UAAUrB,KAAKO,aACrB,EAEHe,eAAgB,KACd,IAAIC,EAAOL,aAAaM,QAAQxB,KAAKM,iBACrC,GAAIiB,EAAM,CACRA,EAAOH,KAAKK,MAAMF,GAClB,IAAK,IAAIG,KAAO1B,KAAKO,YACnBP,KAAKO,YAAYmB,GAAOH,EAAKG,GAE/B,OAAOH,CACT,CACE,OAAO,IACT,EAEFI,QAAS,KACPZ,QAAQC,IAAI,2BACZ1B,IACAE,IACAE,IACAG,IACAC,IACAC,IAG6C,IAA3CG,MAAM0B,YAAYC,SAASC,KAAKC,QAChCC,SAASC,WAAaC,OAAOC,MAE7B5C,EAAU,aAGuB,IAA/BW,MAAMkC,OAAOC,OAAOC,QACtB3C,KAGqC,IAAnCO,MAAMqC,SAASC,WAAWC,MAC5B7C,KAG8B,IAA5BM,MAAMqC,SAASG,UACjBjD,GACF,UAIG,SAASkD,WACd3C,KAAKc,iBACLd,KAAK2B,SACP,CAEAiB,SAASC,iBAAiB,mBAAoBF,UAE9C,IACEG,KAAKC,MAAMC,GAAG,aAAa,KACzBhD,KAAK2B,SAAS,GAElB,CAAE,MAAOsB,GAAI","ignoreList":[]}
\ No newline at end of file
diff --git a/source/js/build/plugins/masonry-modal.js b/source/js/build/plugins/masonry-modal.js
new file mode 100644
index 00000000..aca999cd
--- /dev/null
+++ b/source/js/build/plugins/masonry-modal.js
@@ -0,0 +1,2 @@
+export function initMasonryModal(){function initMasonryClickHandlers(){console.log("[MasonryModal] initMasonryClickHandlers() binding .masonry-item click handlers"),document.querySelectorAll(".masonry-item").forEach((e=>{e.hasListener||(e.hasListener=!0,e.addEventListener("click",(function(e){("IMG"===e.target.tagName||e.target.closest("img"))&&(e.preventDefault(),e.stopImmediatePropagation()),function showMasonryModal(e){const t=document.getElementById("masonry-modal");t&&t.remove();let n=e.date;try{const t=new Date(e.date);isNaN(t)||(n=t.toLocaleString("zh-CN",{year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit",second:"2-digit"}))}catch(e){}const a=document.createElement("div");a.id="masonry-modal",a.className="masonry-modal",a.style.zIndex="999999",a.innerHTML=`\n \n
\n
\n
\n

\n
\n
\n
\n
\n `,document.body.appendChild(a);const o=a.querySelector(".masonry-modal-image img");let s=1,i=!1,l=0,d=0,r=0,c=0;const m=a.querySelector(".masonry-modal-image");m.addEventListener("wheel",(e=>{e.preventDefault();const t=e.deltaY>0?.9:1.1;s=Math.max(.5,Math.min(3,s*t)),updateImageTransform()})),m.addEventListener("mousedown",(e=>{s>1&&(i=!0,l=e.clientX-r,d=e.clientY-c,m.style.cursor="grabbing",e.preventDefault())})),document.addEventListener("mousemove",(e=>{if(i){const t=m.getBoundingClientRect(),n=t.width*(s-1)/2,a=t.height*(s-1)/2;r=Math.max(-n,Math.min(n,e.clientX-l)),c=Math.max(-a,Math.min(a,e.clientY-d)),updateImageTransform()}})),document.addEventListener("mouseup",(()=>{i=!1,m.style.cursor="grab"}));let u=0;function updateImageTransform(){1===s&&(r=0,c=0),o.style.transform=`scale(${s}) translate(${r/s}px, ${c/s}px)`}m.addEventListener("touchstart",(e=>{if(2===e.touches.length){const t=e.touches[0].clientX-e.touches[1].clientX,n=e.touches[0].clientY-e.touches[1].clientY;u=Math.sqrt(t*t+n*n)}})),m.addEventListener("touchmove",(e=>{if(2===e.touches.length){e.preventDefault();const t=e.touches[0].clientX-e.touches[1].clientX,n=e.touches[0].clientY-e.touches[1].clientY,a=Math.sqrt(t*t+n*n),o=a/u;s=Math.max(.5,Math.min(3,s*o)),u=a,updateImageTransform()}})),m.addEventListener("dblclick",(()=>{s=1,r=0,c=0,updateImageTransform()})),m.style.cursor="grab",m.style.overflow="hidden",m.style.userSelect="none",a.querySelector(".masonry-modal-close").addEventListener("click",(()=>{a.remove()})),a.addEventListener("click",(e=>{e.target===a&&a.remove()})),setTimeout((()=>{a.classList.add("show")}),10)}({title:this.dataset.title,description:this.dataset.description,date:this.dataset.date,location:this.dataset.location,image:this.querySelector("img").src})}),!0))}))}console.log("[MasonryModal] initMasonryModal() called"),"loading"===document.readyState?document.addEventListener("DOMContentLoaded",initMasonryClickHandlers):initMasonryClickHandlers();try{swup.hooks.on("page:view",(()=>{console.log("[MasonryModal] swup page:view fired"),initMasonryClickHandlers()})),swup.hooks.on("content:replace",(()=>{console.log("[MasonryModal] swup content:replace fired"),initMasonryClickHandlers()}))}catch(e){}}export default function initMasonryModalPlugin(){document.querySelector("#masonry-container")&&initMasonryModal()}
+//# sourceMappingURL=masonry-modal.js.map
\ No newline at end of file
diff --git a/source/js/build/plugins/masonry-modal.js.map b/source/js/build/plugins/masonry-modal.js.map
new file mode 100644
index 00000000..6ffdd197
--- /dev/null
+++ b/source/js/build/plugins/masonry-modal.js.map
@@ -0,0 +1 @@
+{"version":3,"file":"masonry-modal.js","names":["initMasonryModal","initMasonryClickHandlers","console","log","document","querySelectorAll","forEach","item","hasListener","addEventListener","e","target","tagName","closest","preventDefault","stopImmediatePropagation","showMasonryModal","data","oldModal","getElementById","remove","displayDate","date","dateObj","Date","isNaN","toLocaleString","year","month","day","hour","minute","second","modal","createElement","id","className","style","zIndex","innerHTML","image","title","location","description","body","appendChild","modalImg","querySelector","scale","isDragging","dragStartX","dragStartY","translateX","translateY","imageContainer","delta","deltaY","Math","max","min","updateImageTransform","clientX","clientY","cursor","containerRect","getBoundingClientRect","maxTranslateX","width","maxTranslateY","height","lastDistance","transform","touches","length","dx","dy","sqrt","distance","overflow","userSelect","setTimeout","classList","add","this","dataset","src","readyState","swup","hooks","on","initMasonryModalPlugin"],"sources":["0"],"mappings":"OAAO,SAASA,mBA0Jd,SAASC,2BACPC,QAAQC,IAAI,kFACZC,SAASC,iBAAiB,iBAAiBC,SAASC,IAC7CA,EAAKC,cACRD,EAAKC,aAAc,EACnBD,EAAKE,iBAAiB,SAAS,SAAUC,IACd,QAArBA,EAAEC,OAAOC,SAAqBF,EAAEC,OAAOE,QAAQ,UACjDH,EAAEI,iBACFJ,EAAEK,4BAhKZ,SAASC,iBAAiBC,GACxB,MAAMC,EAAWd,SAASe,eAAe,iBACrCD,GAAUA,EAASE,SAEvB,IAAIC,EAAcJ,EAAKK,KACvB,IACE,MAAMC,EAAU,IAAIC,KAAKP,EAAKK,MACzBG,MAAMF,KACTF,EAAcE,EAAQG,eAAe,QAAS,CAC5CC,KAAM,UACNC,MAAO,UACPC,IAAK,UACLC,KAAM,UACNC,OAAQ,UACRC,OAAQ,YAGd,CAAE,MAAOtB,GAAI,CAEb,MAAMuB,EAAQ7B,SAAS8B,cAAc,OACrCD,EAAME,GAAK,gBACXF,EAAMG,UAAY,gBAClBH,EAAMI,MAAMC,OAAS,SACrBL,EAAMM,UAAY,2NAKEtB,EAAKuB,eAAevB,EAAKwB,0FAG/BxB,EAAKwB,oMAIoBpB,0KAIAJ,EAAKyB,oIAI7BzB,EAAK0B,4FAOpBvC,SAASwC,KAAKC,YAAYZ,GAE1B,MAAMa,EAAWb,EAAMc,cAAc,4BACrC,IAAIC,EAAQ,EAGRC,GAAa,EACbC,EAAa,EACbC,EAAa,EACbC,EAAa,EACbC,EAAa,EAEjB,MAAMC,EAAiBrB,EAAMc,cAAc,wBAC3CO,EAAe7C,iBAAiB,SAAUC,IACxCA,EAAEI,iBACF,MAAMyC,EAAQ7C,EAAE8C,OAAS,EAAI,GAAM,IACnCR,EAAQS,KAAKC,IAZE,GAYYD,KAAKE,IAXjB,EAW+BX,EAAQO,IACtDK,sBAAsB,IAGxBN,EAAe7C,iBAAiB,aAAcC,IACxCsC,EAAQ,IACVC,GAAa,EACbC,EAAaxC,EAAEmD,QAAUT,EACzBD,EAAazC,EAAEoD,QAAUT,EACzBC,EAAejB,MAAM0B,OAAS,WAC9BrD,EAAEI,iBACJ,IAGFV,SAASK,iBAAiB,aAAcC,IACtC,GAAIuC,EAAY,CACd,MAAMe,EAAgBV,EAAeW,wBAC/BC,EAAiBF,EAAcG,OAASnB,EAAQ,GAAM,EACtDoB,EAAiBJ,EAAcK,QAAUrB,EAAQ,GAAM,EAE7DI,EAAaK,KAAKC,KAAKQ,EAAeT,KAAKE,IAAIO,EAAexD,EAAEmD,QAAUX,IAC1EG,EAAaI,KAAKC,KAAKU,EAAeX,KAAKE,IAAIS,EAAe1D,EAAEoD,QAAUX,IAC1ES,sBACF,KAGFxD,SAASK,iBAAiB,WAAW,KACnCwC,GAAa,EACbK,EAAejB,MAAM0B,OAAS,MAAM,IAGtC,IAAIO,EAAe,EAsBnB,SAASV,uBACO,IAAVZ,IACFI,EAAa,EACbC,EAAa,GAEfP,EAAST,MAAMkC,UAAY,SAASvB,gBAAoBI,EAAaJ,QAAYK,EAAaL,MAChG,CA3BAM,EAAe7C,iBAAiB,cAAeC,IAC7C,GAAyB,IAArBA,EAAE8D,QAAQC,OAAc,CAC1B,MAAMC,EAAKhE,EAAE8D,QAAQ,GAAGX,QAAUnD,EAAE8D,QAAQ,GAAGX,QACzCc,EAAKjE,EAAE8D,QAAQ,GAAGV,QAAUpD,EAAE8D,QAAQ,GAAGV,QAC/CQ,EAAeb,KAAKmB,KAAKF,EAAKA,EAAKC,EAAKA,EAC1C,KAGFrB,EAAe7C,iBAAiB,aAAcC,IAC5C,GAAyB,IAArBA,EAAE8D,QAAQC,OAAc,CAC1B/D,EAAEI,iBACF,MAAM4D,EAAKhE,EAAE8D,QAAQ,GAAGX,QAAUnD,EAAE8D,QAAQ,GAAGX,QACzCc,EAAKjE,EAAE8D,QAAQ,GAAGV,QAAUpD,EAAE8D,QAAQ,GAAGV,QACzCe,EAAWpB,KAAKmB,KAAKF,EAAKA,EAAKC,EAAKA,GACpCpB,EAAQsB,EAAWP,EACzBtB,EAAQS,KAAKC,IA3DA,GA2DcD,KAAKE,IA1DnB,EA0DiCX,EAAQO,IACtDe,EAAeO,EACfjB,sBACF,KAWFN,EAAe7C,iBAAiB,YAAY,KAC1CuC,EAAQ,EACRI,EAAa,EACbC,EAAa,EACbO,sBAAsB,IAGxBN,EAAejB,MAAM0B,OAAS,OAC9BT,EAAejB,MAAMyC,SAAW,SAChCxB,EAAejB,MAAM0C,WAAa,OAElC9C,EAAMc,cAAc,wBAAwBtC,iBAAiB,SAAS,KACpEwB,EAAMb,QAAQ,IAEhBa,EAAMxB,iBAAiB,SAAUC,IAC3BA,EAAEC,SAAWsB,GACfA,EAAMb,QACR,IAGF4D,YAAW,KACT/C,EAAMgD,UAAUC,IAAI,OAAO,GAC1B,GACL,CAaQlE,CAAiB,CACfyB,MAAO0C,KAAKC,QAAQ3C,MACpBE,YAAawC,KAAKC,QAAQzC,YAC1BrB,KAAM6D,KAAKC,QAAQ9D,KACnBoB,SAAUyC,KAAKC,QAAQ1C,SACvBF,MAAO2C,KAAKpC,cAAc,OAAOsC,KAErC,IAAG,GACL,GAEJ,CA9KAnF,QAAQC,IAAI,4CAgLgB,YAAxBC,SAASkF,WACXlF,SAASK,iBAAiB,mBAAoBR,0BAE9CA,2BAGF,IAEEsF,KAAKC,MAAMC,GAAG,aAAa,KACzBvF,QAAQC,IAAI,uCACZF,0BAA0B,IAE5BsF,KAAKC,MAAMC,GAAG,mBAAmB,KAC/BvF,QAAQC,IAAI,6CACZF,0BAA0B,GAE9B,CAAE,MAAOS,GAAI,CACf,gBAEe,SAASgF,yBAClBtF,SAAS2C,cAAc,uBACzB/C,kBAEJ","ignoreList":[]}
\ No newline at end of file
diff --git a/source/js/build/plugins/masonry.js b/source/js/build/plugins/masonry.js
index a087fcf4..912cfcf4 100644
--- a/source/js/build/plugins/masonry.js
+++ b/source/js/build/plugins/masonry.js
@@ -1,2 +1,2 @@
-export function initMasonry(){var n=document.querySelector(".loading-placeholder"),e=document.querySelector("#masonry-container");if(n&&e){n.style.display="block",e.style.display="none";for(var t=document.querySelectorAll("#masonry-container .masonry-item img"),o=0,a=0;a{var t;n.style.display="none",e.style.display="block",t=window.innerWidth>=768?255:150,new MiniMasonry({baseWidth:t,container:e,gutterX:10,gutterY:10,surroundingGutter:!1}).layout(),e.style.opacity=1}),100)}}if(data.masonry){try{swup.hooks.on("page:view",initMasonry)}catch(n){}document.addEventListener("DOMContentLoaded",initMasonry)}
+export function initMasonry(){var n=document.querySelector(".loading-placeholder"),o=document.querySelector("#masonry-container");if(n&&o){n.style.display="block",o.style.display="none";for(var e=document.querySelectorAll("#masonry-container .masonry-item img"),t=0,i=0;i{var e;n.style.display="none",o.style.display="block",e=window.innerWidth>=768?255:150,new MiniMasonry({baseWidth:e,container:o,gutterX:10,gutterY:10,surroundingGutter:!1}).layout(),o.style.opacity=1}),100)}}export default function initMasonryPlugin(){document.querySelector("#masonry-container")&&initMasonry()}"loading"===document.readyState?document.addEventListener("DOMContentLoaded",(()=>{console.log("[Masonry] DOMContentLoaded: Initializing"),initMasonryPlugin()})):(console.log("[Masonry] Document already loaded: Initializing"),initMasonryPlugin());try{swup.hooks.on("page:view",(()=>{console.log("[Masonry] SWUP page:view: Initializing"),document.querySelector("#masonry-container")&&initMasonry()}))}catch(n){}
//# sourceMappingURL=masonry.js.map
\ No newline at end of file
diff --git a/source/js/build/plugins/masonry.js.map b/source/js/build/plugins/masonry.js.map
index f959692c..ec76761b 100644
--- a/source/js/build/plugins/masonry.js.map
+++ b/source/js/build/plugins/masonry.js.map
@@ -1 +1 @@
-{"version":3,"file":"masonry.js","names":["initMasonry","loadingPlaceholder","document","querySelector","masonryContainer","style","display","images","querySelectorAll","loadedCount","i","length","img","complete","onImageLoad","addEventListener","initializeMasonryLayout","opacity","setTimeout","baseWidth","window","innerWidth","MiniMasonry","container","gutterX","gutterY","surroundingGutter","layout","data","masonry","swup","hooks","on","e"],"sources":["0"],"mappings":"OAAO,SAASA,cACd,IAAIC,EAAqBC,SAASC,cAAc,wBAC5CC,EAAmBF,SAASC,cAAc,sBAC9C,GAAKF,GAAuBG,EAA5B,CAEAH,EAAmBI,MAAMC,QAAU,QACnCF,EAAiBC,MAAMC,QAAU,OAcjC,IAZA,IAAIC,EAASL,SAASM,iBACpB,wCAEEC,EAAc,EASTC,EAAI,EAAGA,EAAIH,EAAOI,OAAQD,IAAK,CACtC,IAAIE,EAAML,EAAOG,GACbE,EAAIC,SACNC,cAEAF,EAAIG,iBAAiB,OAAQD,YAEjC,CAEIL,IAAgBF,EAAOI,QACzBK,yBA3BkD,CAUpD,SAASF,gBACPL,IACoBF,EAAOI,QACzBK,yBAEJ,CAcA,SAASA,0BACPf,EAAmBI,MAAMY,QAAU,EACnCC,YAAW,KAGT,IACIC,EAHJlB,EAAmBI,MAAMC,QAAU,OACnCF,EAAiBC,MAAMC,QAAU,QAI/Ba,EAHgBC,OAAOC,YAEN,IACL,IAEA,IAEA,IAAIC,YAAY,CAC5BH,UAAWA,EACXI,UAAWnB,EACXoB,QAAS,GACTC,QAAS,GACTC,mBAAmB,IAEbC,SACRvB,EAAiBC,MAAMY,QAAU,CAAC,GACjC,IACL,CACF,CAEA,GAAIW,KAAKC,QAAS,CAChB,IACEC,KAAKC,MAAMC,GAAG,YAAahC,YAC7B,CAAE,MAAOiC,GAAI,CAEb/B,SAASa,iBAAiB,mBAAoBf,YAChD","ignoreList":[]}
\ No newline at end of file
+{"version":3,"file":"masonry.js","names":["initMasonry","loadingPlaceholder","document","querySelector","masonryContainer","style","display","images","querySelectorAll","loadedCount","i","length","img","complete","onImageLoad","addEventListener","initializeMasonryLayout","opacity","setTimeout","baseWidth","window","innerWidth","MiniMasonry","container","gutterX","gutterY","surroundingGutter","layout","initMasonryPlugin","readyState","console","log","swup","hooks","on","e"],"sources":["0"],"mappings":"OAAO,SAASA,cACd,IAAIC,EAAqBC,SAASC,cAAc,wBAC5CC,EAAmBF,SAASC,cAAc,sBAC9C,GAAKF,GAAuBG,EAA5B,CAEAH,EAAmBI,MAAMC,QAAU,QACnCF,EAAiBC,MAAMC,QAAU,OAcjC,IAZA,IAAIC,EAASL,SAASM,iBACpB,wCAEEC,EAAc,EASTC,EAAI,EAAGA,EAAIH,EAAOI,OAAQD,IAAK,CACtC,IAAIE,EAAML,EAAOG,GACbE,EAAIC,SACNC,cAEAF,EAAIG,iBAAiB,OAAQD,YAEjC,CAEIL,IAAgBF,EAAOI,QACzBK,yBA3BkD,CAUpD,SAASF,gBACPL,IACoBF,EAAOI,QACzBK,yBAEJ,CAcA,SAASA,0BACPf,EAAmBI,MAAMY,QAAU,EACnCC,YAAW,KAGT,IACIC,EAHJlB,EAAmBI,MAAMC,QAAU,OACnCF,EAAiBC,MAAMC,QAAU,QAI/Ba,EAHgBC,OAAOC,YAEN,IACL,IAEA,IAEA,IAAIC,YAAY,CAC5BH,UAAWA,EACXI,UAAWnB,EACXoB,QAAS,GACTC,QAAS,GACTC,mBAAmB,IAEbC,SACRvB,EAAiBC,MAAMY,QAAU,CAAC,GACjC,IACL,CACF,gBAEe,SAASW,oBAElB1B,SAASC,cAAc,uBACzBH,aAEJ,CAG4B,YAAxBE,SAAS2B,WACX3B,SAASa,iBAAiB,oBAAoB,KAC5Ce,QAAQC,IAAI,4CACZH,mBAAmB,KAGrBE,QAAQC,IAAI,mDACZH,qBAIF,IACEI,KAAKC,MAAMC,GAAG,aAAa,KACzBJ,QAAQC,IAAI,0CACR7B,SAASC,cAAc,uBACzBH,aACF,GAEJ,CAAE,MAAOmC,GAAI","ignoreList":[]}
\ No newline at end of file
diff --git a/source/js/main.js b/source/js/main.js
index fe61fa73..f1688fce 100755
--- a/source/js/main.js
+++ b/source/js/main.js
@@ -7,6 +7,8 @@ import initScrollTopBottom from "./tools/scrollTopBottom.js";
import initLocalSearch from "./tools/localSearch.js";
import initCopyCode from "./tools/codeBlock.js";
import initBookmarkNav from "./layouts/bookmarkNav.js";
+import initMasonryPlugin from "./plugins/masonry.js";
+import initMasonryModalPlugin from "./plugins/masonry-modal.js";
export const main = {
themeInfo: {
@@ -45,10 +47,13 @@ export const main = {
}
},
refresh: () => {
+ console.log('[MAIN] refresh() called');
initUtils();
initModeToggle();
initScrollTopBottom();
initBookmarkNav();
+ initMasonryPlugin();
+ initMasonryModalPlugin();
if (
theme.home_banner.subtitle.text.length !== 0 &&
diff --git a/source/js/plugins/masonry-modal.js b/source/js/plugins/masonry-modal.js
new file mode 100644
index 00000000..f6224517
--- /dev/null
+++ b/source/js/plugins/masonry-modal.js
@@ -0,0 +1,205 @@
+export function initMasonryModal() {
+ console.log('[MasonryModal] initMasonryModal() called');
+ function showMasonryModal(data) {
+ const oldModal = document.getElementById("masonry-modal");
+ if (oldModal) oldModal.remove();
+
+ let displayDate = data.date;
+ try {
+ const dateObj = new Date(data.date);
+ if (!isNaN(dateObj)) {
+ displayDate = dateObj.toLocaleString('zh-CN', {
+ year: 'numeric',
+ month: '2-digit',
+ day: '2-digit',
+ hour: '2-digit',
+ minute: '2-digit',
+ second: '2-digit'
+ });
+ }
+ } catch (e) {}
+
+ const modal = document.createElement("div");
+ modal.id = "masonry-modal";
+ modal.className = "masonry-modal";
+ modal.style.zIndex = "999999";
+ modal.innerHTML = `
+
+
+
+
+

+
+
+
+
+ `;
+
+ document.body.appendChild(modal);
+
+ const modalImg = modal.querySelector(".masonry-modal-image img");
+ let scale = 1;
+ const minScale = 0.5;
+ const maxScale = 3;
+ let isDragging = false;
+ let dragStartX = 0;
+ let dragStartY = 0;
+ let translateX = 0;
+ let translateY = 0;
+
+ const imageContainer = modal.querySelector(".masonry-modal-image");
+ imageContainer.addEventListener("wheel", (e) => {
+ e.preventDefault();
+ const delta = e.deltaY > 0 ? 0.9 : 1.1;
+ scale = Math.max(minScale, Math.min(maxScale, scale * delta));
+ updateImageTransform();
+ });
+
+ imageContainer.addEventListener("mousedown", (e) => {
+ if (scale > 1) {
+ isDragging = true;
+ dragStartX = e.clientX - translateX;
+ dragStartY = e.clientY - translateY;
+ imageContainer.style.cursor = "grabbing";
+ e.preventDefault();
+ }
+ });
+
+ document.addEventListener("mousemove", (e) => {
+ if (isDragging) {
+ const containerRect = imageContainer.getBoundingClientRect();
+ const maxTranslateX = (containerRect.width * (scale - 1)) / 2;
+ const maxTranslateY = (containerRect.height * (scale - 1)) / 2;
+
+ translateX = Math.max(-maxTranslateX, Math.min(maxTranslateX, e.clientX - dragStartX));
+ translateY = Math.max(-maxTranslateY, Math.min(maxTranslateY, e.clientY - dragStartY));
+ updateImageTransform();
+ }
+ });
+
+ document.addEventListener("mouseup", () => {
+ isDragging = false;
+ imageContainer.style.cursor = "grab";
+ });
+
+ let lastDistance = 0;
+ imageContainer.addEventListener("touchstart", (e) => {
+ if (e.touches.length === 2) {
+ const dx = e.touches[0].clientX - e.touches[1].clientX;
+ const dy = e.touches[0].clientY - e.touches[1].clientY;
+ lastDistance = Math.sqrt(dx * dx + dy * dy);
+ }
+ });
+
+ imageContainer.addEventListener("touchmove", (e) => {
+ if (e.touches.length === 2) {
+ e.preventDefault();
+ const dx = e.touches[0].clientX - e.touches[1].clientX;
+ const dy = e.touches[0].clientY - e.touches[1].clientY;
+ const distance = Math.sqrt(dx * dx + dy * dy);
+ const delta = distance / lastDistance;
+ scale = Math.max(minScale, Math.min(maxScale, scale * delta));
+ lastDistance = distance;
+ updateImageTransform();
+ }
+ });
+
+ function updateImageTransform() {
+ if (scale === 1) {
+ translateX = 0;
+ translateY = 0;
+ }
+ modalImg.style.transform = `scale(${scale}) translate(${translateX / scale}px, ${translateY / scale}px)`;
+ }
+
+ imageContainer.addEventListener("dblclick", () => {
+ scale = 1;
+ translateX = 0;
+ translateY = 0;
+ updateImageTransform();
+ });
+
+ imageContainer.style.cursor = "grab";
+ imageContainer.style.overflow = "hidden";
+ imageContainer.style.userSelect = "none";
+
+ modal.querySelector(".masonry-modal-close").addEventListener("click", () => {
+ modal.remove();
+ });
+ modal.addEventListener("click", (e) => {
+ if (e.target === modal) {
+ modal.remove();
+ }
+ });
+
+ setTimeout(() => {
+ modal.classList.add("show");
+ }, 10);
+ }
+
+ function initMasonryClickHandlers() {
+ console.log('[MasonryModal] initMasonryClickHandlers() binding .masonry-item click handlers');
+ // 使用 requestAnimationFrame 确保 DOM 已经完全渲染
+ requestAnimationFrame(() => {
+ // 清除所有 masonry-item 的 hasListener 标记,以便重新绑定(处理 swup 切换后的新 DOM)
+ document.querySelectorAll(".masonry-item").forEach((item) => {
+ // 移除旧的监听器(如果存在)
+ if (item.hasListener && item._masonryClickHandler) {
+ item.removeEventListener("click", item._masonryClickHandler, true);
+ }
+ item.hasListener = false;
+ });
+
+ // 重新绑定所有 masonry-item 的点击事件
+ document.querySelectorAll(".masonry-item").forEach((item) => {
+ if (!item.hasListener) {
+ item.hasListener = true;
+ // 创建事件处理函数并保存引用,以便后续移除
+ item._masonryClickHandler = function (e) {
+ if (e.target.tagName === "IMG" || e.target.closest("img")) {
+ e.preventDefault();
+ e.stopImmediatePropagation();
+ }
+
+ showMasonryModal({
+ title: this.dataset.title,
+ description: this.dataset.description,
+ date: this.dataset.date,
+ location: this.dataset.location,
+ image: this.querySelector("img").src,
+ });
+ };
+ item.addEventListener("click", item._masonryClickHandler, true);
+ }
+ });
+ });
+ }
+
+ if (document.readyState === 'loading') {
+ document.addEventListener('DOMContentLoaded', initMasonryClickHandlers);
+ } else {
+ initMasonryClickHandlers();
+ }
+}
+
+export default function initMasonryModalPlugin() {
+ if (document.querySelector("#masonry-container")) {
+ initMasonryModal();
+ }
+}
+
diff --git a/source/js/plugins/masonry.js b/source/js/plugins/masonry.js
index 9b5b8b4b..39e9cac3 100644
--- a/source/js/plugins/masonry.js
+++ b/source/js/plugins/masonry.js
@@ -55,10 +55,31 @@ export function initMasonry() {
}
}
-if (data.masonry) {
- try {
- swup.hooks.on("page:view", initMasonry);
- } catch (e) {}
+export default function initMasonryPlugin() {
+ // 检查是否存在masonry容器
+ if (document.querySelector("#masonry-container")) {
+ initMasonry();
+ }
+}
- document.addEventListener("DOMContentLoaded", initMasonry);
+// 直接初始化masonry,不依赖main.refresh
+if (document.readyState === 'loading') {
+ document.addEventListener('DOMContentLoaded', () => {
+ console.log('[Masonry] DOMContentLoaded: Initializing');
+ initMasonryPlugin();
+ });
+} else {
+ console.log('[Masonry] Document already loaded: Initializing');
+ initMasonryPlugin();
}
+
+// 支持页面导航时重新初始化
+try {
+ swup.hooks.on("page:view", () => {
+ console.log('[Masonry] SWUP page:view: Initializing');
+ if (document.querySelector("#masonry-container")) {
+ initMasonry();
+ }
+ });
+} catch (e) {}
+