diff --git a/src/web/icons/eye.svg b/src/web/icons/eye.svg new file mode 100644 index 0000000..6696613 --- /dev/null +++ b/src/web/icons/eye.svg @@ -0,0 +1 @@ + diff --git a/src/web/icons/mod.rs b/src/web/icons/mod.rs index 719f9c2..f1a751e 100644 --- a/src/web/icons/mod.rs +++ b/src/web/icons/mod.rs @@ -3,6 +3,7 @@ pub const ARROW_RIGHT: &str = include_str!("arrow-right.svg"); pub const CALENDAR_1: &str = include_str!("calendar-1.svg"); pub const CLIPBOARD_CLOCK: &str = include_str!("clipboard-clock.svg"); pub const CONTACT: &str = include_str!("contact.svg"); +pub const EYE: &str = include_str!("eye.svg"); pub const FILE_IMAGE: &str = include_str!("file-image.svg"); pub const INFO: &str = include_str!("info.svg"); pub const LAYOUT_DASHBOARD: &str = include_str!("layout-dashboard.svg"); diff --git a/src/web/pages/mod.rs b/src/web/pages/mod.rs index da2c150..c93375e 100644 --- a/src/web/pages/mod.rs +++ b/src/web/pages/mod.rs @@ -12,6 +12,7 @@ pub fn pages() -> Router { .route("/login", get(login::page)) .route("/dashboard", get(dashboard::page)) .route("/users", get(users::page)) + .route("/users/{id}", get(users::profile::page)) } pub fn base(title: &str, inner: Markup) -> Markup { diff --git a/src/web/pages/users.rs b/src/web/pages/users.rs index 91144ea..5d5c21a 100644 --- a/src/web/pages/users.rs +++ b/src/web/pages/users.rs @@ -16,6 +16,8 @@ use crate::{ }, }; +pub mod profile; + pub async fn page(req: Request) -> Result { let u = User::authenticate(req.headers())?; let us = match u.is_some() { diff --git a/src/web/pages/users/profile.rs b/src/web/pages/users/profile.rs new file mode 100644 index 0000000..542c2ab --- /dev/null +++ b/src/web/pages/users/profile.rs @@ -0,0 +1,268 @@ +use axum::{ + extract::{Path, Request}, + response::{IntoResponse, Redirect, Response}, +}; +use chrono::{DateTime, Utc}; +use maud::{PreEscaped, html}; +use uuid::Uuid; + +use crate::{ + persons::Name, + quotes::{Quote, QuoteLine}, + users::{ + User, UserError, + auth::{AuthError, UserAuthenticate}, + }, + web::{ + components::{nav::nav, quote::quote}, + icons, + pages::base, + }, +}; + +pub async fn page(Path(id): Path, req: Request) -> Result { + let u = match User::authenticate(req.headers())? { + Some(u) => u, + None => return Ok(Redirect::to("/users").into_response()), + }; + let user = match User::get_by_id(id) { + Ok(u) => u, + Err(UserError::NoUserWithId(_)) => { + return Ok(base( + "No such user | Mnemosyne", + html!( + (nav(Some(&u), req.uri().path())) + div class="mx-auto max-w-4xl mt-16 text-center" { + div class="text-6xl mb-4" { "?" } + p class="text-red-400 text-lg" { "No such user found." } + p class="text-neutral-500 text-sm mt-2" { "The user you're looking for doesn't exist or has been removed." } + a href="/users" class="inline-block mt-6 text-sm bg-neutral-200/5 hover:bg-neutral-200/10 text-neutral-200 border border-neutral-200/25 hover:border-neutral-200/50 rounded px-4 py-2 transition-colors" { + "Back to Users" + } + } + ), + ) + .into_response()); + } + _ => { + return Ok(base("Error | Mnemosyne", html!( + (nav(Some(&u), req.uri().path())) + p class="text-red-400 text-center my-4" { "An error occurred while loading this profile." } + )).into_response()); + } + }; + + let is_own_profile = u.id == user.id; + let is_special = user.is_infradmin() || user.is_systemuser(); + let initial = user + .handle + .as_str() + .chars() + .next() + .unwrap_or('?') + .to_uppercase() + .to_string(); + let joined_str = user.created_at().map(|d| d.format("%Y-%m-%d").to_string()); + let sample_quotes = sample_quotes_for_display(); + + Ok(base( + &format!("@{} | Mnemosyne", user.handle), + html!( + (nav(Some(&u), req.uri().path())) + + // banner + div class="relative w-full h-48 sm:h-56 md:h-64 bg-gradient-to-b from-neutral-800 from-25% to-emerald-950 overflow-hidden" { + div class="absolute bottom-0 left-0 right-0 h-px bg-neutral-500/50 --bg-gradient-to-r --from-transparent --via-neutral-500/50 --to-transparent" {} + } + + div class="mx-auto max-w-4xl px-4 sm:px-6 relative" { + div class="-mt-16 sm:-mt-20 flex flex-col sm:flex-row sm:items-end gap-4 sm:gap-6" { + + div class="w-28 h-28 sm:w-36 sm:h-36 rounded-full bg-neutral-800 border-4 border-neutral-900 flex items-center justify-center shadow-xl shrink-0 ring-2 ring-neutral-700/50" { + span class="text-4xl sm:text-5xl font-lora font-semibold text-neutral-300 select-none" {(initial)} + } + + div class="flex flex-col gap-1 pb-1" { + div class="flex items-center gap-3 flex-wrap" { + h1 class="text-2xl md:text-4xl font-semibold font-lora" { + (user.handle) + } + + @if is_special { + span class="mt-1 inline-flex items-center gap-1 rounded-full bg-emerald-500/10 border border-emerald-500/30 text-emerald-400 text-xs px-2.5 py-0.5" { + span class="scale-[.65]"{(PreEscaped(icons::SHIELD_USER))} + "System Account" + } + } + @if is_own_profile { + span class="mt-1 inline-flex items-center gap-1 rounded-full bg-neutral-200/5 border border-neutral-200/15 text-neutral-500 text-xs px-2.5 py-0.5" { + span class="scale-[.65]"{(PreEscaped(icons::EYE))} + "This is you" + } + } + } + } + } + + div class="my-6 h-px bg-neutral-200/10" {} + + // about/details + div class="grid grid-cols-1 md:grid-cols-3 gap-6" { + div class="md:col-span-2" { + h2 class="text-sm font-semibold text-neutral-400 uppercase tracking-wider mb-3 flex items-center gap-2" { + span class="scale-[.7]" {(PreEscaped(icons::INFO))} + "About" + } + div class="border border-neutral-200/15 bg-neutral-200/[.03] rounded-lg p-4" { + @if is_own_profile { + p class="text-neutral-500 italic text-sm leading-relaxed" { + "You haven't written a bio yet. Tell people a bit about yourself!" + } + } @else if is_special { + p class="text-neutral-500 italic text-sm leading-relaxed" { + @if user.is_infradmin() { + "The infrastructure administrator account for this Mnemosyne instance." + } @else { + "The internal system account used by Mnemosyne for automated actions." + } + } + } @else { + p class="text-neutral-500 italic text-sm leading-relaxed" { + "This user hasn't written a bio yet." + } + } + } + } + + div class="md:col-span-1" { + h2 class="text-sm font-semibold text-neutral-400 uppercase tracking-wider mb-3 flex items-center gap-2" { + span class="scale-[.7]" {(PreEscaped(icons::CLIPBOARD_CLOCK))} + "Details" + } + div class="border border-neutral-200/15 bg-neutral-200/[.03] rounded-lg p-4 space-y-3" { + div { + p class="text-xs text-neutral-500 uppercase tracking-wide" {"Handle"} + p class="text-sm text-neutral-300 mt-0.5" {"@" (user.handle)} + } + div class="h-px bg-neutral-200/10" {} + div { + p class="text-xs text-neutral-500 uppercase tracking-wide" {"Member Since"} + p class="text-sm text-neutral-300 mt-0.5" { + @if let Some(ref date) = joined_str {(date)} + @else {span class="text-neutral-500" {"Does not apply"}} + } + } + div class="h-px bg-neutral-200/10" {} + div { + p class="text-xs text-neutral-500 uppercase tracking-wide" {"Account Type"} + p class="text-sm text-neutral-300 mt-0.5" { + @if user.is_infradmin() { + "Infrastructure Admin" + } @else if user.is_systemuser() { + "System" + } @else { + "Standard" + } + } + } + } + } + } + + div class="my-6 h-px bg-neutral-200/10" {} + + // quotes-by + div class="mb-12" { + h2 class="text-sm font-semibold text-neutral-400 uppercase tracking-wider mb-1 flex items-center gap-2" { + span class="scale-[.7]" {(PreEscaped(icons::SCROLL_TEXT))} + "Quotes by " (user.handle) + } + p class="text-xs text-neutral-500 font-light mb-4" { + "Recent quotes added to Mnemosyne by this user." + } + div class="grid grid-cols-1 ---sm:grid-cols-2 gap-4" { + @for q in &sample_quotes { + div class="[&>div]:h-full" {(quote(q))} + } + } + @if sample_quotes.is_empty() { + div class="border border-neutral-200/10 border-dashed rounded-lg p-8 text-center" { + div class="scale-[1.5] text-neutral-700 mx-auto w-fit mb-3" {(PreEscaped(icons::QUOTE))} + p class="text-neutral-500 text-sm" {"No quotes found for this user yet."} + } + } + } + } + ), + ) + .into_response()) +} + +fn sample_quotes_for_display() -> Vec { + vec![ + Quote { + id: Uuid::now_v7(), + public: true, + location: Some(String::from("Poznań")), + context: Some(String::from("Wykład z językoznawstwa")), + created_by: Uuid::max(), + timestamp: DateTime::from(Utc::now()), + lines: vec![ + QuoteLine { + id: Uuid::now_v7(), + content: String::from("Nie wiem, czy są tutaj osoby fanowskie zipline-ów?"), + attribution: Name { + id: Uuid::nil(), + created_by: Uuid::max(), + person_id: Uuid::now_v7(), + is_primary: true, + name: String::from("dr. Barbara Konat"), + }, + }, + QuoteLine { + id: Uuid::now_v7(), + content: String::from("Taka uprząż co robi pziuuum!"), + attribution: Name { + id: Uuid::nil(), + created_by: Uuid::max(), + person_id: Uuid::now_v7(), + is_primary: true, + name: String::from("dr. Barbara Konat"), + }, + }, + ], + }, + Quote { + id: Uuid::now_v7(), + public: true, + location: Some(String::from("Discord VC")), + context: Some(String::from("O narysowanej dziewczynie")), + created_by: Uuid::max(), + timestamp: DateTime::from(Utc::now()), + lines: vec![ + QuoteLine { + id: Uuid::now_v7(), + content: String::from("Czy tu proporcje są zachowane?"), + attribution: Name { + id: Uuid::now_v7(), + created_by: Uuid::max(), + person_id: Uuid::now_v7(), + is_primary: true, + name: String::from("Adam"), + }, + }, + QuoteLine { + id: Uuid::now_v7(), + content: String::from("Adam, ona nie ma kolan."), + attribution: Name { + id: Uuid::nil(), + created_by: Uuid::max(), + person_id: Uuid::now_v7(), + is_primary: true, + name: String::from("Mollin"), + }, + }, + ], + }, + ] +} diff --git a/src/web/styles.css b/src/web/styles.css index dcee3e0..caeac01 100644 --- a/src/web/styles.css +++ b/src/web/styles.css @@ -1,2 +1,2 @@ /*! tailwindcss v4.2.1 | 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-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-border-style:solid;--tw-font-weight:initial;--tw-tracking: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-500:oklch(63.7% .237 25.331);--color-neutral-200:oklch(92.2% 0 0);--color-neutral-300:oklch(87% 0 0);--color-neutral-400:oklch(70.8% 0 0);--color-neutral-500:oklch(55.6% 0 0);--color-neutral-700:oklch(37.1% 0 0);--color-neutral-800:oklch(26.9% 0 0);--color-neutral-900:oklch(20.5% 0 0);--color-neutral-950:oklch(14.5% 0 0);--spacing:.25rem;--container-4xl:56rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--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-4xl:2.25rem;--text-4xl--line-height:calc(2.5 / 2.25);--text-6xl:3.75rem;--text-6xl--line-height:1;--text-8xl:6rem;--text-8xl--line-height:1;--font-weight-light:300;--font-weight-normal:400;--font-weight-semibold:600;--radius-md:.375rem;--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);--font-lora:"Lora", ui-serif, Georgia, Cambria, "Times New Roman", serif;--font-lexend:"Lexend", sans-serif;--animate-marquee:marquee 180s linear infinite}}@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}::-webkit-calendar-picker-indicator{line-height:1}:-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}}@layer components;@layer utilities{.absolute{position:absolute}.relative{position:relative}.static{position:static}.top-1{top:calc(var(--spacing) * 1)}.top-4{top:calc(var(--spacing) * 4)}.right-1{right:calc(var(--spacing) * 1)}.right-6{right:calc(var(--spacing) * 6)}.bottom-1{bottom:calc(var(--spacing) * 1)}.left-1{left:calc(var(--spacing) * 1)}.mx-2{margin-inline:calc(var(--spacing) * 2)}.mx-auto{margin-inline:auto}.my-4{margin-block:calc(var(--spacing) * 4)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-8{margin-top:calc(var(--spacing) * 8)}.mt-16{margin-top:calc(var(--spacing) * 16)}.mt-24{margin-top:calc(var(--spacing) * 24)}.mt-auto{margin-top:auto}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-16{margin-bottom:calc(var(--spacing) * 16)}.-ml-1{margin-left:calc(var(--spacing) * -1)}.ml-3{margin-left:calc(var(--spacing) * 3)}.ml-6{margin-left:calc(var(--spacing) * 6)}.ml-auto{margin-left:auto}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.aspect-square{aspect-ratio:1}.h-5{height:calc(var(--spacing) * 5)}.min-h-screen{min-height:100vh}.w-4\/5{width:80%}.w-70{width:calc(var(--spacing) * 70)}.w-full{width:100%}.w-px{width:1px}.max-w-4xl{max-width:var(--container-4xl)}.flex-1{flex:1}.shrink-0{flex-shrink:0}.scale-x-\[\.65\]{--tw-scale-x:.65;scale:var(--tw-scale-x) var(--tw-scale-y)}.scale-x-\[4\.5\]{--tw-scale-x:4.5;scale:var(--tw-scale-x) var(--tw-scale-y)}.scale-y-\[\.5\]{--tw-scale-y:.5;scale:var(--tw-scale-x) var(--tw-scale-y)}.scale-y-\[4\]{--tw-scale-y:4;scale:var(--tw-scale-x) var(--tw-scale-y)}.scale-\[\.5\]{scale:.5}.scale-\[\.75\]{scale:.75}.scale-\[2\]{scale:2}.-rotate-12{rotate:-12deg}.animate-marquee{animation:var(--animate-marquee)}.cursor-pointer{cursor:pointer}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:calc(var(--spacing) * 2)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-8{gap:calc(var(--spacing) * 8)}.gap-\[6px\]{gap:6px}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-clip{overflow:clip}.overflow-hidden{overflow:hidden}.overflow-x-hidden{overflow-x:hidden}.rounded{border-radius:.25rem}.rounded-full{border-radius:3.40282e38px}.rounded-md{border-radius:var(--radius-md)}.border{border-style:var(--tw-border-style);border-width:1px}.border-y{border-block-style:var(--tw-border-style);border-block-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-neutral-200\/15{border-color:#e5e5e526}@supports (color:color-mix(in lab, red, red)){.border-neutral-200\/15{border-color:color-mix(in oklab, var(--color-neutral-200) 15%, transparent)}}.border-neutral-200\/25{border-color:#e5e5e540}@supports (color:color-mix(in lab, red, red)){.border-neutral-200\/25{border-color:color-mix(in oklab, var(--color-neutral-200) 25%, transparent)}}.border-neutral-500\/20{border-color:#73737333}@supports (color:color-mix(in lab, red, red)){.border-neutral-500\/20{border-color:color-mix(in oklab, var(--color-neutral-500) 20%, transparent)}}.border-transparent{border-color:#0000}.bg-neutral-200\/5{background-color:#e5e5e50d}@supports (color:color-mix(in lab, red, red)){.bg-neutral-200\/5{background-color:color-mix(in oklab, var(--color-neutral-200) 5%, transparent)}}.bg-neutral-200\/10{background-color:#e5e5e51a}@supports (color:color-mix(in lab, red, red)){.bg-neutral-200\/10{background-color:color-mix(in oklab, var(--color-neutral-200) 10%, transparent)}}.bg-neutral-200\/15{background-color:#e5e5e526}@supports (color:color-mix(in lab, red, red)){.bg-neutral-200\/15{background-color:color-mix(in oklab, var(--color-neutral-200) 15%, transparent)}}.bg-neutral-900{background-color:var(--color-neutral-900)}.bg-neutral-950\/50{background-color:#0a0a0a80}@supports (color:color-mix(in lab, red, red)){.bg-neutral-950\/50{background-color:color-mix(in oklab, var(--color-neutral-950) 50%, transparent)}}.bg-transparent{background-color:#0000}.p-2{padding:calc(var(--spacing) * 2)}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-4{padding-block:calc(var(--spacing) * 4)}.pt-4{padding-top:calc(var(--spacing) * 4)}.pr-1{padding-right:calc(var(--spacing) * 1)}.pr-8{padding-right:calc(var(--spacing) * 8)}.pb-1{padding-bottom:calc(var(--spacing) * 1)}.pl-2{padding-left:calc(var(--spacing) * 2)}.pl-\[2px\]{padding-left:2px}.text-center{text-align:center}.font-lexend{font-family:var(--font-lexend)}.font-lora{font-family:var(--font-lora)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[10px\]{font-size:10px}.font-light{--tw-font-weight:var(--font-weight-light);font-weight:var(--font-weight-light)}.font-normal{--tw-font-weight:var(--font-weight-normal);font-weight:var(--font-weight-normal)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-\[0\.3em\]{--tw-tracking:.3em;letter-spacing:.3em}.text-neutral-200{color:var(--color-neutral-200)}.text-neutral-300{color:var(--color-neutral-300)}.text-neutral-400{color:var(--color-neutral-400)}.text-neutral-500{color:var(--color-neutral-500)}.text-neutral-500\/40{color:#73737366}@supports (color:color-mix(in lab, red, red)){.text-neutral-500\/40{color:color-mix(in oklab, var(--color-neutral-500) 40%, transparent)}}.text-neutral-700{color:var(--color-neutral-700)}.text-neutral-800\/25{color:#26262640}@supports (color:color-mix(in lab, red, red)){.text-neutral-800\/25{color:color-mix(in oklab, var(--color-neutral-800) 25%, transparent)}}.text-red-400{color:var(--color-red-400)}.text-red-500{color:var(--color-red-500)}.uppercase{text-transform:uppercase}.italic{font-style:italic}.opacity-\[\.3\]{opacity:.3}.opacity-\[\.025\]{opacity:.025}.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))}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}@media (hover:hover){.hover\:border-neutral-200\/25:hover{border-color:#e5e5e540}@supports (color:color-mix(in lab, red, red)){.hover\:border-neutral-200\/25:hover{border-color:color-mix(in oklab, var(--color-neutral-200) 25%, transparent)}}.hover\:border-neutral-200\/35:hover{border-color:#e5e5e559}@supports (color:color-mix(in lab, red, red)){.hover\:border-neutral-200\/35:hover{border-color:color-mix(in oklab, var(--color-neutral-200) 35%, transparent)}}.hover\:border-neutral-200\/50:hover{border-color:#e5e5e580}@supports (color:color-mix(in lab, red, red)){.hover\:border-neutral-200\/50:hover{border-color:color-mix(in oklab, var(--color-neutral-200) 50%, transparent)}}.hover\:bg-neutral-200\/5:hover{background-color:#e5e5e50d}@supports (color:color-mix(in lab, red, red)){.hover\:bg-neutral-200\/5:hover{background-color:color-mix(in oklab, var(--color-neutral-200) 5%, transparent)}}.hover\:bg-neutral-200\/10:hover{background-color:#e5e5e51a}@supports (color:color-mix(in lab, red, red)){.hover\:bg-neutral-200\/10:hover{background-color:color-mix(in oklab, var(--color-neutral-200) 10%, transparent)}}.hover\:underline:hover{text-decoration-line:underline}}@media (min-width:30rem){.xs\:block{display:block}.xs\:text-6xl{font-size:var(--text-6xl);line-height:var(--tw-leading,var(--text-6xl--line-height))}}@media (min-width:40rem){.sm\:mx-0{margin-inline:calc(var(--spacing) * 0)}.sm\:mr-2{margin-right:calc(var(--spacing) * 2)}.sm\:block{display:block}.sm\:hidden{display:none}.sm\:w-fit{width:fit-content}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.sm\:text-6xl{font-size:var(--text-6xl);line-height:var(--tw-leading,var(--text-6xl--line-height))}.sm\:text-8xl{font-size:var(--text-8xl);line-height:var(--tw-leading,var(--text-8xl--line-height))}}@media (min-width:48rem){.md\:text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}}@media (min-width:64rem){.lg\:block{display:block}}.\[\&\>div\]\:h-full>div{height:100%}}@keyframes marquee{0%{transform:translate(0%)}to{transform:translate(-100%)}}@media (prefers-reduced-motion:reduce){.animate-marquee{animation-play-state:paused}}@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-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false} \ No newline at end of file +@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-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-gradient-position:initial;--tw-gradient-from:#0000;--tw-gradient-via:#0000;--tw-gradient-to:#0000;--tw-gradient-stops:initial;--tw-gradient-via-stops:initial;--tw-gradient-from-position:0%;--tw-gradient-via-position:50%;--tw-gradient-to-position:100%;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking: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}}}@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-500:oklch(63.7% .237 25.331);--color-emerald-400:oklch(76.5% .177 163.223);--color-emerald-500:oklch(69.6% .17 162.48);--color-emerald-950:oklch(26.2% .051 172.552);--color-neutral-200:oklch(92.2% 0 0);--color-neutral-300:oklch(87% 0 0);--color-neutral-400:oklch(70.8% 0 0);--color-neutral-500:oklch(55.6% 0 0);--color-neutral-700:oklch(37.1% 0 0);--color-neutral-800:oklch(26.9% 0 0);--color-neutral-900:oklch(20.5% 0 0);--color-neutral-950:oklch(14.5% 0 0);--spacing:.25rem;--container-4xl:56rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--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-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;--text-8xl:6rem;--text-8xl--line-height:1;--font-weight-light:300;--font-weight-normal:400;--font-weight-semibold:600;--tracking-wide:.025em;--tracking-wider:.05em;--leading-relaxed:1.625;--radius-md:.375rem;--radius-lg:.5rem;--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);--font-lora:"Lora", ui-serif, Georgia, Cambria, "Times New Roman", serif;--font-lexend:"Lexend", sans-serif;--animate-marquee:marquee 180s linear infinite}}@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}::-webkit-calendar-picker-indicator{line-height:1}:-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}}@layer components;@layer utilities{.absolute{position:absolute}.relative{position:relative}.static{position:static}.top-1{top:calc(var(--spacing) * 1)}.top-4{top:calc(var(--spacing) * 4)}.right-0{right:calc(var(--spacing) * 0)}.right-1{right:calc(var(--spacing) * 1)}.right-6{right:calc(var(--spacing) * 6)}.bottom-0{bottom:calc(var(--spacing) * 0)}.bottom-1{bottom:calc(var(--spacing) * 1)}.left-0{left:calc(var(--spacing) * 0)}.left-1{left:calc(var(--spacing) * 1)}.mx-2{margin-inline:calc(var(--spacing) * 2)}.mx-auto{margin-inline:auto}.my-4{margin-block:calc(var(--spacing) * 4)}.my-6{margin-block:calc(var(--spacing) * 6)}.-mt-16{margin-top:calc(var(--spacing) * -16)}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-6{margin-top:calc(var(--spacing) * 6)}.mt-8{margin-top:calc(var(--spacing) * 8)}.mt-16{margin-top:calc(var(--spacing) * 16)}.mt-24{margin-top:calc(var(--spacing) * 24)}.mt-auto{margin-top:auto}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-12{margin-bottom:calc(var(--spacing) * 12)}.mb-16{margin-bottom:calc(var(--spacing) * 16)}.-ml-1{margin-left:calc(var(--spacing) * -1)}.ml-3{margin-left:calc(var(--spacing) * 3)}.ml-6{margin-left:calc(var(--spacing) * 6)}.ml-auto{margin-left:auto}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.aspect-square{aspect-ratio:1}.h-5{height:calc(var(--spacing) * 5)}.h-28{height:calc(var(--spacing) * 28)}.h-48{height:calc(var(--spacing) * 48)}.h-px{height:1px}.min-h-screen{min-height:100vh}.w-4\/5{width:80%}.w-28{width:calc(var(--spacing) * 28)}.w-70{width:calc(var(--spacing) * 70)}.w-fit{width:fit-content}.w-full{width:100%}.w-px{width:1px}.max-w-4xl{max-width:var(--container-4xl)}.flex-1{flex:1}.shrink-0{flex-shrink:0}.scale-x-\[\.65\]{--tw-scale-x:.65;scale:var(--tw-scale-x) var(--tw-scale-y)}.scale-x-\[4\.5\]{--tw-scale-x:4.5;scale:var(--tw-scale-x) var(--tw-scale-y)}.scale-y-\[\.5\]{--tw-scale-y:.5;scale:var(--tw-scale-x) var(--tw-scale-y)}.scale-y-\[4\]{--tw-scale-y:4;scale:var(--tw-scale-x) var(--tw-scale-y)}.scale-\[\.5\]{scale:.5}.scale-\[\.7\]{scale:.7}.scale-\[\.65\]{scale:.65}.scale-\[\.75\]{scale:.75}.scale-\[1\.5\]{scale:1.5}.scale-\[2\]{scale:2}.-rotate-12{rotate:-12deg}.animate-marquee{animation:var(--animate-marquee)}.cursor-pointer{cursor:pointer}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.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-6{gap:calc(var(--spacing) * 6)}.gap-8{gap:calc(var(--spacing) * 8)}.gap-\[6px\]{gap:6px}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)))}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-clip{overflow:clip}.overflow-hidden{overflow:hidden}.overflow-x-hidden{overflow-x:hidden}.rounded{border-radius:.25rem}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.border{border-style:var(--tw-border-style);border-width:1px}.border-4{border-style:var(--tw-border-style);border-width:4px}.border-y{border-block-style:var(--tw-border-style);border-block-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-dashed{--tw-border-style:dashed;border-style:dashed}.border-emerald-500\/30{border-color:#00bb7f4d}@supports (color:color-mix(in lab, red, red)){.border-emerald-500\/30{border-color:color-mix(in oklab, var(--color-emerald-500) 30%, transparent)}}.border-neutral-200\/10{border-color:#e5e5e51a}@supports (color:color-mix(in lab, red, red)){.border-neutral-200\/10{border-color:color-mix(in oklab, var(--color-neutral-200) 10%, transparent)}}.border-neutral-200\/15{border-color:#e5e5e526}@supports (color:color-mix(in lab, red, red)){.border-neutral-200\/15{border-color:color-mix(in oklab, var(--color-neutral-200) 15%, transparent)}}.border-neutral-200\/25{border-color:#e5e5e540}@supports (color:color-mix(in lab, red, red)){.border-neutral-200\/25{border-color:color-mix(in oklab, var(--color-neutral-200) 25%, transparent)}}.border-neutral-500\/20{border-color:#73737333}@supports (color:color-mix(in lab, red, red)){.border-neutral-500\/20{border-color:color-mix(in oklab, var(--color-neutral-500) 20%, transparent)}}.border-neutral-900{border-color:var(--color-neutral-900)}.border-transparent{border-color:#0000}.bg-emerald-500\/10{background-color:#00bb7f1a}@supports (color:color-mix(in lab, red, red)){.bg-emerald-500\/10{background-color:color-mix(in oklab, var(--color-emerald-500) 10%, transparent)}}.bg-neutral-200\/5{background-color:#e5e5e50d}@supports (color:color-mix(in lab, red, red)){.bg-neutral-200\/5{background-color:color-mix(in oklab, var(--color-neutral-200) 5%, transparent)}}.bg-neutral-200\/10{background-color:#e5e5e51a}@supports (color:color-mix(in lab, red, red)){.bg-neutral-200\/10{background-color:color-mix(in oklab, var(--color-neutral-200) 10%, transparent)}}.bg-neutral-200\/15{background-color:#e5e5e526}@supports (color:color-mix(in lab, red, red)){.bg-neutral-200\/15{background-color:color-mix(in oklab, var(--color-neutral-200) 15%, transparent)}}.bg-neutral-200\/\[\.03\]{background-color:#e5e5e508}@supports (color:color-mix(in lab, red, red)){.bg-neutral-200\/\[\.03\]{background-color:color-mix(in oklab, var(--color-neutral-200) 3%, transparent)}}.bg-neutral-500\/50{background-color:#73737380}@supports (color:color-mix(in lab, red, red)){.bg-neutral-500\/50{background-color:color-mix(in oklab, var(--color-neutral-500) 50%, transparent)}}.bg-neutral-800{background-color:var(--color-neutral-800)}.bg-neutral-900{background-color:var(--color-neutral-900)}.bg-neutral-950\/50{background-color:#0a0a0a80}@supports (color:color-mix(in lab, red, red)){.bg-neutral-950\/50{background-color:color-mix(in oklab, var(--color-neutral-950) 50%, transparent)}}.bg-transparent{background-color:#0000}.bg-gradient-to-b{--tw-gradient-position:to bottom in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.from-neutral-800{--tw-gradient-from:var(--color-neutral-800);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-25\%{--tw-gradient-from-position:25%}.to-emerald-950{--tw-gradient-to:var(--color-emerald-950);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.p-2{padding:calc(var(--spacing) * 2)}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.p-8{padding:calc(var(--spacing) * 8)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-2\.5{padding-inline:calc(var(--spacing) * 2.5)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-4{padding-block:calc(var(--spacing) * 4)}.pt-4{padding-top:calc(var(--spacing) * 4)}.pr-1{padding-right:calc(var(--spacing) * 1)}.pr-8{padding-right:calc(var(--spacing) * 8)}.pb-1{padding-bottom:calc(var(--spacing) * 1)}.pl-2{padding-left:calc(var(--spacing) * 2)}.pl-\[2px\]{padding-left:2px}.text-center{text-align:center}.font-lexend{font-family:var(--font-lexend)}.font-lora{font-family:var(--font-lora)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-6xl{font-size:var(--text-6xl);line-height:var(--tw-leading,var(--text-6xl--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-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[10px\]{font-size:10px}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.font-light{--tw-font-weight:var(--font-weight-light);font-weight:var(--font-weight-light)}.font-normal{--tw-font-weight:var(--font-weight-normal);font-weight:var(--font-weight-normal)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-\[0\.3em\]{--tw-tracking:.3em;letter-spacing:.3em}.tracking-wide{--tw-tracking:var(--tracking-wide);letter-spacing:var(--tracking-wide)}.tracking-wider{--tw-tracking:var(--tracking-wider);letter-spacing:var(--tracking-wider)}.text-emerald-400{color:var(--color-emerald-400)}.text-neutral-200{color:var(--color-neutral-200)}.text-neutral-300{color:var(--color-neutral-300)}.text-neutral-400{color:var(--color-neutral-400)}.text-neutral-500{color:var(--color-neutral-500)}.text-neutral-500\/40{color:#73737366}@supports (color:color-mix(in lab, red, red)){.text-neutral-500\/40{color:color-mix(in oklab, var(--color-neutral-500) 40%, transparent)}}.text-neutral-700{color:var(--color-neutral-700)}.text-neutral-800\/25{color:#26262640}@supports (color:color-mix(in lab, red, red)){.text-neutral-800\/25{color:color-mix(in oklab, var(--color-neutral-800) 25%, transparent)}}.text-red-400{color:var(--color-red-400)}.text-red-500{color:var(--color-red-500)}.uppercase{text-transform:uppercase}.italic{font-style:italic}.opacity-\[\.3\]{opacity:.3}.opacity-\[\.025\]{opacity:.025}.shadow-xl{--tw-shadow:0 20px 25px -5px var(--tw-shadow-color,#0000001a), 0 8px 10px -6px 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)}.ring-2{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + 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)}.ring-neutral-700\/50{--tw-ring-color:#40404080}@supports (color:color-mix(in lab, red, red)){.ring-neutral-700\/50{--tw-ring-color:color-mix(in oklab, var(--color-neutral-700) 50%, transparent)}}.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))}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}@media (hover:hover){.hover\:border-neutral-200\/25:hover{border-color:#e5e5e540}@supports (color:color-mix(in lab, red, red)){.hover\:border-neutral-200\/25:hover{border-color:color-mix(in oklab, var(--color-neutral-200) 25%, transparent)}}.hover\:border-neutral-200\/35:hover{border-color:#e5e5e559}@supports (color:color-mix(in lab, red, red)){.hover\:border-neutral-200\/35:hover{border-color:color-mix(in oklab, var(--color-neutral-200) 35%, transparent)}}.hover\:border-neutral-200\/50:hover{border-color:#e5e5e580}@supports (color:color-mix(in lab, red, red)){.hover\:border-neutral-200\/50:hover{border-color:color-mix(in oklab, var(--color-neutral-200) 50%, transparent)}}.hover\:bg-neutral-200\/5:hover{background-color:#e5e5e50d}@supports (color:color-mix(in lab, red, red)){.hover\:bg-neutral-200\/5:hover{background-color:color-mix(in oklab, var(--color-neutral-200) 5%, transparent)}}.hover\:bg-neutral-200\/10:hover{background-color:#e5e5e51a}@supports (color:color-mix(in lab, red, red)){.hover\:bg-neutral-200\/10:hover{background-color:color-mix(in oklab, var(--color-neutral-200) 10%, transparent)}}.hover\:underline:hover{text-decoration-line:underline}}@media (min-width:30rem){.xs\:block{display:block}.xs\:text-6xl{font-size:var(--text-6xl);line-height:var(--tw-leading,var(--text-6xl--line-height))}}@media (min-width:40rem){.sm\:mx-0{margin-inline:calc(var(--spacing) * 0)}.sm\:-mt-20{margin-top:calc(var(--spacing) * -20)}.sm\:mr-2{margin-right:calc(var(--spacing) * 2)}.sm\:block{display:block}.sm\:hidden{display:none}.sm\:h-36{height:calc(var(--spacing) * 36)}.sm\:h-56{height:calc(var(--spacing) * 56)}.sm\:w-36{width:calc(var(--spacing) * 36)}.sm\:w-fit{width:fit-content}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:items-end{align-items:flex-end}.sm\:gap-6{gap:calc(var(--spacing) * 6)}.sm\:px-6{padding-inline:calc(var(--spacing) * 6)}.sm\:text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.sm\:text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading,var(--text-5xl--line-height))}.sm\:text-6xl{font-size:var(--text-6xl);line-height:var(--tw-leading,var(--text-6xl--line-height))}.sm\:text-8xl{font-size:var(--text-8xl);line-height:var(--tw-leading,var(--text-8xl--line-height))}}@media (min-width:48rem){.md\:col-span-1{grid-column:span 1/span 1}.md\:col-span-2{grid-column:span 2/span 2}.md\:h-64{height:calc(var(--spacing) * 64)}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.md\:text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}}@media (min-width:64rem){.lg\:block{display:block}}.\[\&\>div\]\:h-full>div{height:100%}}@keyframes marquee{0%{transform:translate(0%)}to{transform:translate(-100%)}}@media (prefers-reduced-motion:reduce){.animate-marquee{animation-play-state:paused}}@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-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-gradient-position{syntax:"*";inherits:false}@property --tw-gradient-from{syntax:"";inherits:false;initial-value:#0000}@property --tw-gradient-via{syntax:"";inherits:false;initial-value:#0000}@property --tw-gradient-to{syntax:"";inherits:false;initial-value:#0000}@property --tw-gradient-stops{syntax:"*";inherits:false}@property --tw-gradient-via-stops{syntax:"*";inherits:false}@property --tw-gradient-from-position{syntax:"";inherits:false;initial-value:0%}@property --tw-gradient-via-position{syntax:"";inherits:false;initial-value:50%}@property --tw-gradient-to-position{syntax:"";inherits:false;initial-value:100%}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{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} \ No newline at end of file