/* ==========================================================================
   styles.css – Site styles
   Structure: theme vars → base reset → utilities → :root/.dark → base overrides
   → @property → keyframes → scrollbar → page layout (end)
   ========================================================================== */

@layer properties;
@layer theme, base, components, utilities;

/* ----- Theme (design tokens) ----- */
@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-gray-50: oklch(98.5% 0.002 247.839);
  --color-gray-100: oklch(96.7% 0.003 264.542);
  --color-gray-200: oklch(92.8% 0.006 264.531);
  --color-gray-400: oklch(70.7% 0.022 261.325);
  --color-gray-500: oklch(55.1% 0.027 264.364);
  --color-gray-600: oklch(44.6% 0.03 256.802);
  --color-gray-700: oklch(37.3% 0.034 259.733);
  --color-gray-900: oklch(21% 0.034 264.665);
  --color-black: #000;
  --color-white: #fff;
  --spacing: 0.25rem;
  --container-sm: 24rem;
  --container-lg: 32rem;
  --container-3xl: 48rem;
  --container-5xl: 64rem;
  --text-xs: 0.75rem;
  --text-xs--line-height: calc(1 / 0.75);
  --text-sm: 0.875rem;
  --text-sm--line-height: calc(1.25 / 0.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-5xl: 3rem;
  --text-5xl--line-height: 1;
  --font-weight-normal: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;
  --font-weight-extrabold: 800;
  --tracking-tight: -0.025em;
  --tracking-wider: 0.05em;
  --tracking-widest: 0.1em;
  --leading-tight: 1.25;
  --leading-relaxed: 1.625;
  --radius-xs: 0.125rem;
  --radius-2xl: 1rem;
  --radius-3xl: 1.5rem;
  --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
  --animate-pulse: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
  --blur-sm: 8px;
  --aspect-video: 16 / 9;
  --default-transition-duration: 150ms;
  --default-transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  --default-font-family: var(--font-sans);
  --default-mono-font-family: var(--font-mono);
  --color-border: var(--border);
}
}

/* ----- Base (reset & element defaults) ----- */
@layer base {
  *, ::after, ::before, ::backdrop, ::file-selector-button { box-sizing: border-box; margin: 0; padding: 0; border: 0 solid; }
  html, :host { line-height: 1.5; -webkit-text-size-adjust: 100%; tab-size: 4; 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; 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 { font-size: 75%; line-height: 0; position: relative; vertical-align: baseline; }
  sub { bottom: -0.25em; }
  sup { top: -0.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 { display: block; }
  img, video { max-width: 100%; height: auto; }
  button, input, select, optgroup, textarea, ::file-selector-button { font: inherit; font-feature-settings: inherit; font-variation-settings: inherit; letter-spacing: inherit; color: inherit; border-radius: 0; background-color: transparent; opacity: 1; }
  :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)) { 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, ::-webkit-datetime-edit-year-field, ::-webkit-datetime-edit-month-field, ::-webkit-datetime-edit-day-field, ::-webkit-datetime-edit-hour-field, ::-webkit-datetime-edit-minute-field, ::-webkit-datetime-edit-second-field, ::-webkit-datetime-edit-millisecond-field, ::-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"]), ::file-selector-button { appearance: button; }
  ::-webkit-inner-spin-button, ::-webkit-outer-spin-button { height: auto; }
  [hidden]:where(:not([hidden="until-found"])) { display: none !important; }
}

/* ----- Utilities ----- */
@layer utilities {
  .\@container\/card-header { container-type: inline-size; container-name: card-header; }
  .pointer-events-none { pointer-events: none; }
  .invisible { visibility: hidden; }
  .sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border-width: 0; }
  .absolute { position: absolute; }
  .fixed { position: fixed; }
  .relative { position: relative; }
  .inset-0 { inset: calc(var(--spacing) * 0); }
  .inset-x-0 { inset-inline: calc(var(--spacing) * 0); }
  .inset-y-0 { inset-block: calc(var(--spacing) * 0); }
  .-top-12 { top: calc(var(--spacing) * -12); }
  .top-0 { top: calc(var(--spacing) * 0); }
  .top-1\.5 { top: calc(var(--spacing) * 1.5); }
  .top-1\/2 { top: calc(1/2 * 100%); }
  .top-3 { top: calc(var(--spacing) * 3); }
  .top-3\.5 { top: calc(var(--spacing) * 3.5); }
  .top-4 { top: calc(var(--spacing) * 4); }
  .top-\[1px\] { top: 1px; }
  .top-\[50\%\] { top: 50%; }
  .top-\[60\%\] { top: 60%; }
  .top-full { top: 100%; }
  .-right-12 { right: calc(var(--spacing) * -12); }
  .right-0 { right: calc(var(--spacing) * 0); }
  .right-1 { right: calc(var(--spacing) * 1); }
  .right-2 { right: calc(var(--spacing) * 2); }
  .right-3 { right: calc(var(--spacing) * 3); }
  .right-4 { right: calc(var(--spacing) * 4); }
  .-bottom-12 { bottom: calc(var(--spacing) * -12); }
  .bottom-0 { bottom: calc(var(--spacing) * 0); }
  .-left-12 { left: calc(var(--spacing) * -12); }
  .left-0 { left: calc(var(--spacing) * 0); }
  .left-1 { left: calc(var(--spacing) * 1); }
  .left-1\/2 { left: calc(1/2 * 100%); }
  .left-2 { left: calc(var(--spacing) * 2); }
  .left-\[50\%\] { left: 50%; }
  .isolate { isolation: isolate; }
  .z-10 { z-index: 10; }
  .z-20 { z-index: 20; }
  .z-50 { z-index: 50; }
  .z-\[1\] { z-index: 1; }
  .col-start-2 { grid-column-start: 2; }
  .row-span-2 { grid-row: span 2 / span 2; }
  .row-start-1 { grid-row-start: 1; }
  .-mx-1 { margin-inline: calc(var(--spacing) * -1); }
  .mx-2 { margin-inline: calc(var(--spacing) * 2); }
  .mx-3\.5 { margin-inline: calc(var(--spacing) * 3.5); }
  .mx-auto { margin-inline: auto; }
  .my-0\.5 { margin-block: calc(var(--spacing) * 0.5); }
  .my-1 { margin-block: calc(var(--spacing) * 1); }
  .my-8 { margin-block: calc(var(--spacing) * 8); }
  .-mt-4 { margin-top: calc(var(--spacing) * -4); }
  .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-8 { margin-top: calc(var(--spacing) * 8); }
  .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-8 {
  margin-bottom: calc(var(--spacing) * 8);
}
.mb-10 {
  margin-bottom: calc(var(--spacing) * 10);
}
.-ml-4 {
  margin-left: calc(var(--spacing) * -4);
}
.ml-1 {
  margin-left: calc(var(--spacing) * 1);
}
.ml-auto {
  margin-left: auto;
}
  .line-clamp-1 { overflow: hidden; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 1; line-clamp: 1; }
  .line-clamp-3 { overflow: hidden; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 3; line-clamp: 3; }
  .block { display: block; }
  .flex { display: flex; }
  .grid { display: grid; }
  .hidden { display: none; }
  .inline-block { display: inline-block; }
  .inline-flex { display: inline-flex; }
  .table { display: table; }

/* Responsive header + life cards */
.header-toggle { display: inline-flex; }
.nav-links { display: none; }
.mobile-menu { display: none; }
.mobile-menu.is-open { display: block; }
@media (min-width: 768px) {
  .header-toggle { display: none; }
  .nav-links { display: flex; }
  .mobile-menu { display: none; }
}
@media (max-width: 767px) {
  .life-card.is-open .life-overlay { opacity: 1 !important; }
  .life-card.is-open .life-overlay p { transform: translateY(0); }
}
.table-caption {
  display: table-caption;
}
.table-cell {
  display: table-cell;
}
.table-row {
  display: table-row;
}
.field-sizing-content {
  field-sizing: content;
}
.aspect-square {
  aspect-ratio: 1 / 1;
}
.aspect-video {
  aspect-ratio: var(--aspect-video);
}
.size-2 {
  width: calc(var(--spacing) * 2);
  height: calc(var(--spacing) * 2);
}
.size-2\.5 {
  width: calc(var(--spacing) * 2.5);
  height: calc(var(--spacing) * 2.5);
}
.size-3 {
  width: calc(var(--spacing) * 3);
  height: calc(var(--spacing) * 3);
}
.size-3\.5 {
  width: calc(var(--spacing) * 3.5);
  height: calc(var(--spacing) * 3.5);
}
.size-4 {
  width: calc(var(--spacing) * 4);
  height: calc(var(--spacing) * 4);
}
.size-7 {
  width: calc(var(--spacing) * 7);
  height: calc(var(--spacing) * 7);
}
.size-8 {
  width: calc(var(--spacing) * 8);
  height: calc(var(--spacing) * 8);
}
.size-9 {
  width: calc(var(--spacing) * 9);
  height: calc(var(--spacing) * 9);
}
.size-10 {
  width: calc(var(--spacing) * 10);
  height: calc(var(--spacing) * 10);
}
.size-full {
  width: 100%;
  height: 100%;
}
.h-1\.5 {
  height: calc(var(--spacing) * 1.5);
}
.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-7 {
  height: calc(var(--spacing) * 7);
}
.h-8 {
  height: calc(var(--spacing) * 8);
}
.h-9 {
  height: calc(var(--spacing) * 9);
}
.h-10 {
  height: calc(var(--spacing) * 10);
}
.h-12 {
  height: calc(var(--spacing) * 12);
}
.h-32 {
  height: calc(var(--spacing) * 32);
}
.h-48 {
  height: calc(var(--spacing) * 48);
}
.h-64 {
  height: calc(var(--spacing) * 64);
}
.h-\[1\.15rem\] {
  height: 1.15rem;
}
.h-\[calc\(100\%-1px\)\] {
  height: calc(100% - 1px);
}
.h-\[var\(--radix-navigation-menu-viewport-height\)\] {
  height: var(--radix-navigation-menu-viewport-height);
}
.h-\[var\(--radix-select-trigger-height\)\] {
  height: var(--radix-select-trigger-height);
}
.h-auto {
  height: auto;
}
.h-full {
  height: 100%;
}
.h-px {
  height: 1px;
}
.h-svh {
  height: 100svh;
}
.max-h-\(--radix-context-menu-content-available-height\) {
  max-height: var(--radix-context-menu-content-available-height);
}
.max-h-\(--radix-dropdown-menu-content-available-height\) {
  max-height: var(--radix-dropdown-menu-content-available-height);
}
.max-h-\(--radix-select-content-available-height\) {
  max-height: var(--radix-select-content-available-height);
}
.max-h-\[300px\] {
  max-height: 300px;
}
.min-h-0 {
  min-height: calc(var(--spacing) * 0);
}
.min-h-4 {
  min-height: calc(var(--spacing) * 4);
}
.min-h-16 {
  min-height: calc(var(--spacing) * 16);
}
.min-h-\[40px\] {
  min-height: 40px;
}
.min-h-screen {
  min-height: 100vh;
}
.min-h-svh {
  min-height: 100svh;
}
.w-\(--sidebar-width\) {
  width: var(--sidebar-width);
}
.w-0 {
  width: calc(var(--spacing) * 0);
}
.w-1 {
  width: calc(var(--spacing) * 1);
}
.w-2 {
  width: calc(var(--spacing) * 2);
}
.w-2\.5 {
  width: calc(var(--spacing) * 2.5);
}
.w-3 {
  width: calc(var(--spacing) * 3);
}
.w-3\/4 {
  width: calc(3/4 * 100%);
}
.w-4 {
  width: calc(var(--spacing) * 4);
}
.w-5 {
  width: calc(var(--spacing) * 5);
}
.w-8 {
  width: calc(var(--spacing) * 8);
}
.w-9 {
  width: calc(var(--spacing) * 9);
}
.w-10 {
  width: calc(var(--spacing) * 10);
}
.w-12 {
  width: calc(var(--spacing) * 12);
}
.w-32 {
  width: calc(var(--spacing) * 32);
}
.w-64 {
  width: calc(var(--spacing) * 64);
}
.w-72 {
  width: calc(var(--spacing) * 72);
}
.w-\[100px\] {
  width: 100px;
}
.w-auto {
  width: auto;
}
.w-fit {
  width: fit-content;
}
.w-full {
  width: 100%;
}
.w-max {
  width: max-content;
}
.w-px {
  width: 1px;
}
.max-w-\(--skeleton-width\) {
  max-width: var(--skeleton-width);
}
.max-w-3xl {
  max-width: var(--container-3xl);
}
.max-w-5xl {
  max-width: var(--container-5xl);
}
.max-w-\[calc\(100\%-2rem\)\] {
  max-width: calc(100% - 2rem);
}
.max-w-max {
  max-width: max-content;
}
.max-w-sm {
  max-width: var(--container-sm);
}
.min-w-0 {
  min-width: calc(var(--spacing) * 0);
}
.min-w-5 {
  min-width: calc(var(--spacing) * 5);
}
.min-w-8 {
  min-width: calc(var(--spacing) * 8);
}
.min-w-9 {
  min-width: calc(var(--spacing) * 9);
}
.min-w-10 {
  min-width: calc(var(--spacing) * 10);
}
.min-w-\[8rem\] {
  min-width: 8rem;
}
.min-w-\[12rem\] {
  min-width: 12rem;
}
.min-w-\[260px\] {
  min-width: 260px;
}
.min-w-\[var\(--radix-select-trigger-width\)\] {
  min-width: var(--radix-select-trigger-width);
}
.flex-1 {
  flex: 1;
}
.shrink-0 {
  flex-shrink: 0;
}
.flex-grow {
  flex-grow: 1;
}
.grow {
  flex-grow: 1;
}
.grow-0 {
  flex-grow: 0;
}
.basis-full {
  flex-basis: 100%;
}
.caption-bottom {
  caption-side: bottom;
}
.border-collapse {
  border-collapse: collapse;
}
.origin-\(--radix-context-menu-content-transform-origin\) {
  transform-origin: var(--radix-context-menu-content-transform-origin);
}
.origin-\(--radix-dropdown-menu-content-transform-origin\) {
  transform-origin: var(--radix-dropdown-menu-content-transform-origin);
}
.origin-\(--radix-hover-card-content-transform-origin\) {
  transform-origin: var(--radix-hover-card-content-transform-origin);
}
.origin-\(--radix-menubar-content-transform-origin\) {
  transform-origin: var(--radix-menubar-content-transform-origin);
}
.origin-\(--radix-popover-content-transform-origin\) {
  transform-origin: var(--radix-popover-content-transform-origin);
}
.origin-\(--radix-select-content-transform-origin\) {
  transform-origin: var(--radix-select-content-transform-origin);
}
.origin-\(--radix-tooltip-content-transform-origin\) {
  transform-origin: var(--radix-tooltip-content-transform-origin);
}
.-translate-x-1\/2 {
  --tw-translate-x: calc(calc(1/2 * 100%) * -1);
  translate: var(--tw-translate-x) var(--tw-translate-y);
}
.-translate-x-px {
  --tw-translate-x: -1px;
  translate: var(--tw-translate-x) var(--tw-translate-y);
}
.translate-x-\[-50\%\] {
  --tw-translate-x: -50%;
  translate: var(--tw-translate-x) var(--tw-translate-y);
}
.translate-x-px {
  --tw-translate-x: 1px;
  translate: var(--tw-translate-x) var(--tw-translate-y);
}
.-translate-y-1\/2 {
  --tw-translate-y: calc(calc(1/2 * 100%) * -1);
  translate: var(--tw-translate-x) var(--tw-translate-y);
}
.translate-y-0\.5 {
  --tw-translate-y: calc(var(--spacing) * 0.5);
  translate: var(--tw-translate-x) var(--tw-translate-y);
}
.translate-y-4 {
  --tw-translate-y: calc(var(--spacing) * 4);
  translate: var(--tw-translate-x) var(--tw-translate-y);
}
.translate-y-\[-50\%\] {
  --tw-translate-y: -50%;
  translate: var(--tw-translate-x) var(--tw-translate-y);
}
.translate-y-\[calc\(-50\%_-_2px\)\] {
  --tw-translate-y: calc(-50% - 2px);
  translate: var(--tw-translate-x) var(--tw-translate-y);
}
.rotate-45 {
  rotate: 45deg;
}
.rotate-90 {
  rotate: 90deg;
}
.transform {
  transform: var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,);
}
.animate-caret-blink {
  animation: caret-blink 1.25s ease-out infinite;
}
.animate-in {
  animation: enter var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none);
}
.animate-pulse {
  animation: var(--animate-pulse);
}
.cursor-default {
  cursor: default;
}
.touch-none {
  touch-action: none;
}
.resize-none {
  resize: none;
}
.scroll-my-1 {
  scroll-margin-block: calc(var(--spacing) * 1);
}
.scroll-py-1 {
  scroll-padding-block: calc(var(--spacing) * 1);
}
.list-none {
  list-style-type: none;
}
.auto-rows-min {
  grid-auto-rows: min-content;
}
.grid-cols-\[0_1fr\] {
  grid-template-columns: 0 1fr;
}
.grid-rows-\[auto_auto\] {
  grid-template-rows: auto auto;
}
.flex-col {
  flex-direction: column;
}
.flex-col-reverse {
  flex-direction: column-reverse;
}
.flex-row {
  flex-direction: row;
}
.flex-wrap {
  flex-wrap: wrap;
}
.items-center {
  align-items: center;
}
.items-end {
  align-items: flex-end;
}
.items-start {
  align-items: flex-start;
}
.items-stretch {
  align-items: stretch;
}
.justify-between {
  justify-content: space-between;
}
.justify-center {
  justify-content: center;
}
.justify-end {
  justify-content: flex-end;
}
.justify-items-start {
  justify-items: start;
}
.gap-1 {
  gap: calc(var(--spacing) * 1);
}
.gap-1\.5 {
  gap: calc(var(--spacing) * 1.5);
}
.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);
}
.space-y-6 {
  :where(& > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)));
  }
}
.space-x-1 {
  :where(& > :not(:last-child)) {
    --tw-space-x-reverse: 0;
    margin-inline-start: calc(calc(var(--spacing) * 1) * var(--tw-space-x-reverse));
    margin-inline-end: calc(calc(var(--spacing) * 1) * calc(1 - var(--tw-space-x-reverse)));
  }
}
.space-x-6 {
  :where(& > :not(:last-child)) {
    --tw-space-x-reverse: 0;
    margin-inline-start: calc(calc(var(--spacing) * 6) * var(--tw-space-x-reverse));
    margin-inline-end: calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-x-reverse)));
  }
}
.gap-y-0\.5 {
  row-gap: calc(var(--spacing) * 0.5);
}
.self-center {
  align-self: center;
}
.self-start {
  align-self: flex-start;
}
.justify-self-end {
  justify-self: flex-end;
}
.overflow-auto {
  overflow: auto;
}
.overflow-hidden {
  overflow: hidden;
}
.overflow-x-auto {
  overflow-x: auto;
}
.overflow-x-hidden {
  overflow-x: hidden;
}
.overflow-y-auto {
  overflow-y: auto;
}
.rounded-2xl {
  border-radius: var(--radius-2xl);
}
.rounded-3xl {
  border-radius: var(--radius-3xl);
}
.rounded-\[2px\] {
  border-radius: 2px;
}
.rounded-\[4px\] {
  border-radius: 4px;
}
.rounded-\[inherit\] {
  border-radius: inherit;
}
.rounded-full {
  border-radius: calc(infinity * 1px);
}
.rounded-lg {
  border-radius: var(--radius);
}
.rounded-md {
  border-radius: calc(var(--radius) - 2px);
}
.rounded-none {
  border-radius: 0;
}
.rounded-sm {
  border-radius: calc(var(--radius) - 4px);
}
.rounded-xl {
  border-radius: calc(var(--radius) + 4px);
}
.rounded-xs {
  border-radius: var(--radius-xs);
}
.rounded-tl-sm {
  border-top-left-radius: calc(var(--radius) - 4px);
}
.border {
  border-style: var(--tw-border-style);
  border-width: 1px;
}
.border-\[1\.5px\] {
  border-style: var(--tw-border-style);
  border-width: 1.5px;
}
.border-y {
  border-block-style: var(--tw-border-style);
  border-block-width: 1px;
}
.border-t {
  border-top-style: var(--tw-border-style);
  border-top-width: 1px;
}
.border-r {
  border-right-style: var(--tw-border-style);
  border-right-width: 1px;
}
.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-dashed {
  --tw-border-style: dashed;
  border-style: dashed;
}
.border-\(--color-border\) {
  border-color: var(--color-border);
}
.border-border\/50 {
  border-color: var(--border);
  @supports (color: color-mix(in lab, red, red)) {
    border-color: color-mix(in oklab, var(--border) 50%, transparent);
  }
}
.border-gray-100 {
  border-color: var(--color-gray-100);
}
.border-gray-200 {
  border-color: var(--color-gray-200);
}
.border-input {
  border-color: var(--input);
}
.border-primary {
  border-color: var(--primary);
}
.border-sidebar-border {
  border-color: var(--sidebar-border);
}
.border-transparent {
  border-color: transparent;
}
.border-t-transparent {
  border-top-color: transparent;
}
.border-l-transparent {
  border-left-color: transparent;
}
.bg-\(--color-bg\) {
  background-color: var(--color-bg);
}
.bg-\[\#98c1d9\]\/20 {
  background-color: color-mix(in oklab, #98c1d9 20%, transparent);
}
.bg-accent {
  background-color: var(--accent);
}
.bg-background {
  background-color: var(--background);
}
.bg-black\/50 {
  background-color: color-mix(in srgb, #000 50%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in oklab, var(--color-black) 50%, transparent);
  }
}
.bg-border {
  background-color: var(--border);
}
.bg-card {
  background-color: var(--card);
}
.bg-destructive {
  background-color: var(--destructive);
}
.bg-foreground {
  background-color: var(--foreground);
}
.bg-gray-50 {
  background-color: var(--color-gray-50);
}
.bg-gray-50\/80 {
  background-color: color-mix(in srgb, oklch(98.5% 0.002 247.839) 80%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in oklab, var(--color-gray-50) 80%, transparent);
  }
}
.bg-gray-100 {
  background-color: var(--color-gray-100);
}
.bg-gray-200 {
  background-color: var(--color-gray-200);
}
.bg-gray-900 {
  background-color: var(--color-gray-900);
}
.bg-input-background {
  background-color: var(--input-background);
}
.bg-muted {
  background-color: var(--muted);
}
.bg-muted\/50 {
  background-color: var(--muted);
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in oklab, var(--muted) 50%, transparent);
  }
}
.bg-popover {
  background-color: var(--popover);
}
.bg-primary {
  background-color: var(--primary);
}
.bg-primary\/20 {
  background-color: var(--primary);
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in oklab, var(--primary) 20%, transparent);
  }
}
.bg-secondary {
  background-color: var(--secondary);
}
.bg-sidebar {
  background-color: var(--sidebar);
}
.bg-sidebar-border {
  background-color: var(--sidebar-border);
}
.bg-transparent {
  background-color: transparent;
}
.bg-white {
  background-color: var(--color-white);
}
.bg-white\/90 {
  background-color: color-mix(in srgb, #fff 90%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in oklab, var(--color-white) 90%, transparent);
  }
}
.bg-gradient-to-t {
  --tw-gradient-position: to top in oklab;
  background-image: linear-gradient(var(--tw-gradient-stops));
}
.from-black\/90 {
  --tw-gradient-from: color-mix(in srgb, #000 90%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    --tw-gradient-from: color-mix(in oklab, var(--color-black) 90%, transparent);
  }
  --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));
}
.via-black\/40 {
  --tw-gradient-via: color-mix(in srgb, #000 40%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    --tw-gradient-via: color-mix(in oklab, var(--color-black) 40%, transparent);
  }
  --tw-gradient-via-stops: var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-via) var(--tw-gradient-via-position), var(--tw-gradient-to) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-via-stops);
}
.to-transparent {
  --tw-gradient-to: transparent;
  --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));
}
.fill-current {
  fill: currentcolor;
}
.fill-primary {
  fill: var(--primary);
}
.object-cover {
  object-fit: cover;
}
.p-0 {
  padding: calc(var(--spacing) * 0);
}
.p-1 {
  padding: calc(var(--spacing) * 1);
}
.p-1\.5 {
  padding: calc(var(--spacing) * 1.5);
}
.p-2 {
  padding: calc(var(--spacing) * 2);
}
.p-3 {
  padding: calc(var(--spacing) * 3);
}
.p-4 {
  padding: calc(var(--spacing) * 4);
}
.p-5 {
  padding: calc(var(--spacing) * 5);
}
.p-6 {
  padding: calc(var(--spacing) * 6);
}
.p-\[3px\] {
  padding: 3px;
}
.p-px {
  padding: 1px;
}
.px-1 {
  padding-inline: calc(var(--spacing) * 1);
}
.px-1\.5 {
  padding-inline: calc(var(--spacing) * 1.5);
}
.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);
}
.px-5 {
  padding-inline: calc(var(--spacing) * 5);
}
.px-6 {
  padding-inline: calc(var(--spacing) * 6);
}
.py-0\.5 {
  padding-block: calc(var(--spacing) * 0.5);
}
.py-1 {
  padding-block: calc(var(--spacing) * 1);
}
.py-1\.5 {
  padding-block: calc(var(--spacing) * 1.5);
}
.py-2 {
  padding-block: calc(var(--spacing) * 2);
}
.py-2\.5 {
  padding-block: calc(var(--spacing) * 2.5);
}
.py-3 {
  padding-block: calc(var(--spacing) * 3);
}
.py-4 {
  padding-block: calc(var(--spacing) * 4);
}
.py-5 {
  padding-block: calc(var(--spacing) * 5);
}
.py-6 {
  padding-block: calc(var(--spacing) * 6);
}
.py-8 {
  padding-block: calc(var(--spacing) * 8);
}
.py-10 {
  padding-block: calc(var(--spacing) * 10);
}
.pt-0 {
  padding-top: calc(var(--spacing) * 0);
}
.pt-1 {
  padding-top: calc(var(--spacing) * 1);
}
.pt-3 {
  padding-top: calc(var(--spacing) * 3);
}
.pt-4 {
  padding-top: calc(var(--spacing) * 4);
}
.pt-6 {
  padding-top: calc(var(--spacing) * 6);
}
.pr-2 {
  padding-right: calc(var(--spacing) * 2);
}
.pr-2\.5 {
  padding-right: calc(var(--spacing) * 2.5);
}
.pr-8 {
  padding-right: calc(var(--spacing) * 8);
}
.pb-3 {
  padding-bottom: calc(var(--spacing) * 3);
}
.pb-4 {
  padding-bottom: calc(var(--spacing) * 4);
}
.pb-6 {
  padding-bottom: calc(var(--spacing) * 6);
}
.pl-2 {
  padding-left: calc(var(--spacing) * 2);
}
.pl-4 {
  padding-left: calc(var(--spacing) * 4);
}
.pl-8 {
  padding-left: calc(var(--spacing) * 8);
}
.text-center {
  text-align: center;
}
.text-left {
  text-align: left;
}
.align-middle {
  vertical-align: middle;
}
.font-mono {
  font-family: var(--font-mono);
}
.font-sans {
  font-family: var(--font-sans);
}
.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-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\.8rem\] {
  font-size: 0.8rem;
}
.leading-none {
  --tw-leading: 1;
  line-height: 1;
}
.leading-relaxed {
  --tw-leading: var(--leading-relaxed);
  line-height: var(--leading-relaxed);
}
.leading-tight {
  --tw-leading: var(--leading-tight);
  line-height: var(--leading-tight);
}
.font-bold {
  --tw-font-weight: var(--font-weight-bold);
  font-weight: var(--font-weight-bold);
}
.font-extrabold {
  --tw-font-weight: var(--font-weight-extrabold);
  font-weight: var(--font-weight-extrabold);
}
.font-medium {
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
}
.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-tight {
  --tw-tracking: var(--tracking-tight);
  letter-spacing: var(--tracking-tight);
}
.tracking-wider {
  --tw-tracking: var(--tracking-wider);
  letter-spacing: var(--tracking-wider);
}
.tracking-widest {
  --tw-tracking: var(--tracking-widest);
  letter-spacing: var(--tracking-widest);
}
.text-balance {
  text-wrap: balance;
}
.break-words {
  overflow-wrap: break-word;
}
.whitespace-nowrap {
  white-space: nowrap;
}
.text-\[\#3d5a80\] {
  color: #3d5a80;
}
.text-\[\#ee6c4d\] {
  color: #ee6c4d;
}
.text-accent-foreground {
  color: var(--accent-foreground);
}
.text-card-foreground {
  color: var(--card-foreground);
}
.text-current {
  color: currentcolor;
}
.text-destructive {
  color: var(--destructive);
}
.text-foreground {
  color: var(--foreground);
}
.text-gray-200 {
  color: var(--color-gray-200);
}
.text-gray-400 {
  color: var(--color-gray-400);
}
.text-gray-500 {
  color: var(--color-gray-500);
}
.text-gray-600 {
  color: var(--color-gray-600);
}
.text-gray-700 {
  color: var(--color-gray-700);
}
.text-gray-900 {
  color: var(--color-gray-900);
}
.text-muted-foreground {
  color: var(--muted-foreground);
}
.text-popover-foreground {
  color: var(--popover-foreground);
}
.text-primary {
  color: var(--primary);
}
.text-primary-foreground {
  color: var(--primary-foreground);
}
.text-secondary-foreground {
  color: var(--secondary-foreground);
}
.text-sidebar-foreground {
  color: var(--sidebar-foreground);
}
.text-sidebar-foreground\/70 {
  color: var(--sidebar-foreground);
  @supports (color: color-mix(in lab, red, red)) {
    color: color-mix(in oklab, var(--sidebar-foreground) 70%, transparent);
  }
}
.text-white {
  color: var(--color-white);
}
.uppercase {
  text-transform: uppercase;
}
.tabular-nums {
  --tw-numeric-spacing: tabular-nums;
  font-variant-numeric: var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,);
}
.underline-offset-4 {
  text-underline-offset: 4px;
}
.opacity-0 {
  opacity: 0%;
}
.opacity-50 {
  opacity: 50%;
}
.opacity-70 {
  opacity: 70%;
}
.shadow {
  --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 1px 2px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
  box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
}
.shadow-\[0_0_0_1px_hsl\(var\(--sidebar-border\)\)\] {
  --tw-shadow: 0 0 0 1px var(--tw-shadow-color, hsl(var(--sidebar-border)));
  box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
}
.shadow-lg {
  --tw-shadow: 0 10px 15px -3px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 4px 6px -4px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
  box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
}
.shadow-md {
  --tw-shadow: 0 4px 6px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 2px 4px -2px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
  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-sm {
  --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 1px 2px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
  box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
}
.shadow-xl {
  --tw-shadow: 0 20px 25px -5px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 8px 10px -6px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
  box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
}
.shadow-xs {
  --tw-shadow: 0 1px 2px 0 var(--tw-shadow-color, rgb(0 0 0 / 0.05));
  box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
}
.ring-0 {
  --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(0px + 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-4 {
  --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(4px + 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-\[\#98c1d9\]\/50 {
  --tw-ring-color: color-mix(in oklab, #98c1d9 50%, transparent);
}
.ring-ring\/50 {
  --tw-ring-color: var(--ring);
  @supports (color: color-mix(in lab, red, red)) {
    --tw-ring-color: color-mix(in oklab, var(--ring) 50%, transparent);
  }
}
.ring-sidebar-ring {
  --tw-ring-color: var(--sidebar-ring);
}
.ring-offset-background {
  --tw-ring-offset-color: var(--background);
}
.outline-hidden {
  --tw-outline-style: none;
  outline-style: none;
  @media (forced-colors: active) {
    outline: 2px solid transparent;
    outline-offset: 2px;
  }
}
.outline {
  outline-style: var(--tw-outline-style);
  outline-width: 1px;
}
.backdrop-blur-sm {
  --tw-backdrop-blur: blur(var(--blur-sm));
  -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-\[color\,box-shadow\] {
  transition-property: color,box-shadow;
  transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
  transition-duration: var(--tw-duration, var(--default-transition-duration));
}
.transition-\[left\,right\,width\] {
  transition-property: left,right,width;
  transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
  transition-duration: var(--tw-duration, var(--default-transition-duration));
}
.transition-\[margin\,opacity\] {
  transition-property: margin,opacity;
  transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
  transition-duration: var(--tw-duration, var(--default-transition-duration));
}
.transition-\[width\,height\,padding\] {
  transition-property: width,height,padding;
  transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
  transition-duration: var(--tw-duration, var(--default-transition-duration));
}
.transition-\[width\] {
  transition-property: width;
  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-opacity {
  transition-property: opacity;
  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));
}
.transition-none {
  transition-property: none;
}
.delay-75 {
  transition-delay: 75ms;
}
.delay-150 {
  transition-delay: 150ms;
}
.duration-200 {
  --tw-duration: 200ms;
  transition-duration: 200ms;
}
.duration-300 {
  --tw-duration: 300ms;
  transition-duration: 300ms;
}
.duration-500 {
  --tw-duration: 500ms;
  transition-duration: 500ms;
}
.duration-1000 {
  --tw-duration: 1000ms;
  transition-duration: 1000ms;
}
.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;
}
.delay-75 {
  animation-delay: calc(75*1ms);
  animation-delay: 75ms;
  --tw-animation-delay: calc(75*1ms);
  --tw-animation-delay: 75ms;
}
.delay-150 {
  animation-delay: calc(150*1ms);
  animation-delay: .15s;
  --tw-animation-delay: calc(150*1ms);
  --tw-animation-delay: .15s;
}
.fade-in-0 {
  --tw-enter-opacity: calc(0/100);
  --tw-enter-opacity: 0;
}
.outline-none {
  --tw-outline-style: none;
  outline-style: none;
}
.select-none {
  -webkit-user-select: none;
  user-select: none;
}
.zoom-in-95 {
  --tw-enter-scale: calc(95*1%);
  --tw-enter-scale: .95;
}
.group-focus-within\/menu-item\:opacity-100 {
  &:is(:where(.group\/menu-item):focus-within *) {
    opacity: 100%;
  }
}
.group-hover\:translate-y-0 {
  &:is(:where(.group):hover *) {
    @media (hover: hover) {
      --tw-translate-y: calc(var(--spacing) * 0);
      translate: var(--tw-translate-x) var(--tw-translate-y);
    }
  }
}
.group-hover\:scale-105 {
  &:is(:where(.group):hover *) {
    @media (hover: hover) {
      --tw-scale-x: 105%;
      --tw-scale-y: 105%;
      --tw-scale-z: 105%;
      scale: var(--tw-scale-x) var(--tw-scale-y);
    }
  }
}
.group-hover\:bg-\[\#3d5a80\] {
  &:is(:where(.group):hover *) {
    @media (hover: hover) {
      background-color: #3d5a80;
    }
  }
}
.group-hover\:bg-\[\#98c1d9\] {
  &:is(:where(.group):hover *) {
    @media (hover: hover) {
      background-color: #98c1d9;
    }
  }
}
.group-hover\:bg-\[\#ee6c4d\] {
  &:is(:where(.group):hover *) {
    @media (hover: hover) {
      background-color: #ee6c4d;
    }
  }
}
.group-hover\:opacity-100 {
  &:is(:where(.group):hover *) {
    @media (hover: hover) {
      opacity: 100%;
    }
  }
}
.group-hover\/menu-item\:opacity-100 {
  &:is(:where(.group\/menu-item):hover *) {
    @media (hover: hover) {
      opacity: 100%;
    }
  }
}
.group-has-data-\[sidebar\=menu-action\]\/menu-item\:pr-8 {
  &:is(:where(.group\/menu-item):has(*[data-sidebar="menu-action"]) *) {
    padding-right: calc(var(--spacing) * 8);
  }
}
.group-data-\[collapsible\=icon\]\:-mt-8 {
  &:is(:where(.group)[data-collapsible="icon"] *) {
    margin-top: calc(var(--spacing) * -8);
  }
}
.group-data-\[collapsible\=icon\]\:hidden {
  &:is(:where(.group)[data-collapsible="icon"] *) {
    display: none;
  }
}
.group-data-\[collapsible\=icon\]\:size-8\! {
  &:is(:where(.group)[data-collapsible="icon"] *) {
    width: calc(var(--spacing) * 8) !important;
    height: calc(var(--spacing) * 8) !important;
  }
}
.group-data-\[collapsible\=icon\]\:w-\(--sidebar-width-icon\) {
  &:is(:where(.group)[data-collapsible="icon"] *) {
    width: var(--sidebar-width-icon);
  }
}
.group-data-\[collapsible\=icon\]\:w-\[calc\(var\(--sidebar-width-icon\)\+\(--spacing\(4\)\)\)\] {
  &:is(:where(.group)[data-collapsible="icon"] *) {
    width: calc(var(--sidebar-width-icon) + (calc(var(--spacing) * 4)));
  }
}
.group-data-\[collapsible\=icon\]\:w-\[calc\(var\(--sidebar-width-icon\)\+\(--spacing\(4\)\)\+2px\)\] {
  &:is(:where(.group)[data-collapsible="icon"] *) {
    width: calc(var(--sidebar-width-icon) + (calc(var(--spacing) * 4)) + 2px);
  }
}
.group-data-\[collapsible\=icon\]\:overflow-hidden {
  &:is(:where(.group)[data-collapsible="icon"] *) {
    overflow: hidden;
  }
}
.group-data-\[collapsible\=icon\]\:p-0\! {
  &:is(:where(.group)[data-collapsible="icon"] *) {
    padding: calc(var(--spacing) * 0) !important;
  }
}
.group-data-\[collapsible\=icon\]\:p-2\! {
  &:is(:where(.group)[data-collapsible="icon"] *) {
    padding: calc(var(--spacing) * 2) !important;
  }
}
.group-data-\[collapsible\=icon\]\:opacity-0 {
  &:is(:where(.group)[data-collapsible="icon"] *) {
    opacity: 0%;
  }
}
.group-data-\[collapsible\=offcanvas\]\:right-\[calc\(var\(--sidebar-width\)\*-1\)\] {
  &:is(:where(.group)[data-collapsible="offcanvas"] *) {
    right: calc(var(--sidebar-width) * -1);
  }
}
.group-data-\[collapsible\=offcanvas\]\:left-\[calc\(var\(--sidebar-width\)\*-1\)\] {
  &:is(:where(.group)[data-collapsible="offcanvas"] *) {
    left: calc(var(--sidebar-width) * -1);
  }
}
.group-data-\[collapsible\=offcanvas\]\:w-0 {
  &:is(:where(.group)[data-collapsible="offcanvas"] *) {
    width: calc(var(--spacing) * 0);
  }
}
.group-data-\[collapsible\=offcanvas\]\:translate-x-0 {
  &:is(:where(.group)[data-collapsible="offcanvas"] *) {
    --tw-translate-x: calc(var(--spacing) * 0);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
}
.group-data-\[disabled\=true\]\:pointer-events-none {
  &:is(:where(.group)[data-disabled="true"] *) {
    pointer-events: none;
  }
}
.group-data-\[disabled\=true\]\:opacity-50 {
  &:is(:where(.group)[data-disabled="true"] *) {
    opacity: 50%;
  }
}
.group-data-\[side\=left\]\:-right-4 {
  &:is(:where(.group)[data-side="left"] *) {
    right: calc(var(--spacing) * -4);
  }
}
.group-data-\[side\=left\]\:border-r {
  &:is(:where(.group)[data-side="left"] *) {
    border-right-style: var(--tw-border-style);
    border-right-width: 1px;
  }
}
.group-data-\[side\=right\]\:left-0 {
  &:is(:where(.group)[data-side="right"] *) {
    left: calc(var(--spacing) * 0);
  }
}
.group-data-\[side\=right\]\:rotate-180 {
  &:is(:where(.group)[data-side="right"] *) {
    rotate: 180deg;
  }
}
.group-data-\[side\=right\]\:border-l {
  &:is(:where(.group)[data-side="right"] *) {
    border-left-style: var(--tw-border-style);
    border-left-width: 1px;
  }
}
.group-data-\[state\=open\]\:rotate-180 {
  &:is(:where(.group)[data-state="open"] *) {
    rotate: 180deg;
  }
}
.group-data-\[variant\=floating\]\:rounded-lg {
  &:is(:where(.group)[data-variant="floating"] *) {
    border-radius: var(--radius);
  }
}
.group-data-\[variant\=floating\]\:border {
  &:is(:where(.group)[data-variant="floating"] *) {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }
}
.group-data-\[variant\=floating\]\:border-sidebar-border {
  &:is(:where(.group)[data-variant="floating"] *) {
    border-color: var(--sidebar-border);
  }
}
.group-data-\[variant\=floating\]\:shadow-sm {
  &:is(:where(.group)[data-variant="floating"] *) {
    --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 1px 2px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
}
.group-data-\[vaul-drawer-direction\=bottom\]\/drawer-content\:block {
  &:is(:where(.group\/drawer-content)[data-vaul-drawer-direction="bottom"] *) {
    display: block;
  }
}
.group-data-\[viewport\=false\]\/navigation-menu\:top-full {
  &:is(:where(.group\/navigation-menu)[data-viewport="false"] *) {
    top: 100%;
  }
}
.group-data-\[viewport\=false\]\/navigation-menu\:mt-1\.5 {
  &:is(:where(.group\/navigation-menu)[data-viewport="false"] *) {
    margin-top: calc(var(--spacing) * 1.5);
  }
}
.group-data-\[viewport\=false\]\/navigation-menu\:overflow-hidden {
  &:is(:where(.group\/navigation-menu)[data-viewport="false"] *) {
    overflow: hidden;
  }
}
.group-data-\[viewport\=false\]\/navigation-menu\:rounded-md {
  &:is(:where(.group\/navigation-menu)[data-viewport="false"] *) {
    border-radius: calc(var(--radius) - 2px);
  }
}
.group-data-\[viewport\=false\]\/navigation-menu\:border {
  &:is(:where(.group\/navigation-menu)[data-viewport="false"] *) {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }
}
.group-data-\[viewport\=false\]\/navigation-menu\:bg-popover {
  &:is(:where(.group\/navigation-menu)[data-viewport="false"] *) {
    background-color: var(--popover);
  }
}
.group-data-\[viewport\=false\]\/navigation-menu\:text-popover-foreground {
  &:is(:where(.group\/navigation-menu)[data-viewport="false"] *) {
    color: var(--popover-foreground);
  }
}
.group-data-\[viewport\=false\]\/navigation-menu\:shadow {
  &:is(:where(.group\/navigation-menu)[data-viewport="false"] *) {
    --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 1px 2px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
}
.group-data-\[viewport\=false\]\/navigation-menu\:duration-200 {
  &:is(:where(.group\/navigation-menu)[data-viewport="false"] *) {
    --tw-duration: 200ms;
    transition-duration: 200ms;
  }
}
.peer-hover\/menu-button\:text-sidebar-accent-foreground {
  &:is(:where(.peer\/menu-button):hover ~ *) {
    @media (hover: hover) {
      color: var(--sidebar-accent-foreground);
    }
  }
}
.peer-disabled\:cursor-not-allowed {
  &:is(:where(.peer):disabled ~ *) {
    cursor: not-allowed;
  }
}
.peer-disabled\:opacity-50 {
  &:is(:where(.peer):disabled ~ *) {
    opacity: 50%;
  }
}
.peer-data-\[active\=true\]\/menu-button\:text-sidebar-accent-foreground {
  &:is(:where(.peer\/menu-button)[data-active="true"] ~ *) {
    color: var(--sidebar-accent-foreground);
  }
}
.peer-data-\[size\=default\]\/menu-button\:top-1\.5 {
  &:is(:where(.peer\/menu-button)[data-size="default"] ~ *) {
    top: calc(var(--spacing) * 1.5);
  }
}
.peer-data-\[size\=lg\]\/menu-button\:top-2\.5 {
  &:is(:where(.peer\/menu-button)[data-size="lg"] ~ *) {
    top: calc(var(--spacing) * 2.5);
  }
}
.peer-data-\[size\=sm\]\/menu-button\:top-1 {
  &:is(:where(.peer\/menu-button)[data-size="sm"] ~ *) {
    top: calc(var(--spacing) * 1);
  }
}
.selection\:bg-\[\#98c1d9\]\/30 {
  & *::selection {
    background-color: color-mix(in oklab, #98c1d9 30%, transparent);
  }
  &::selection {
    background-color: color-mix(in oklab, #98c1d9 30%, transparent);
  }
}
.selection\:bg-primary {
  & *::selection {
    background-color: var(--primary);
  }
  &::selection {
    background-color: var(--primary);
  }
}
.selection\:text-\[\#3d5a80\] {
  & *::selection {
    color: #3d5a80;
  }
  &::selection {
    color: #3d5a80;
  }
}
.selection\:text-primary-foreground {
  & *::selection {
    color: var(--primary-foreground);
  }
  &::selection {
    color: var(--primary-foreground);
  }
}
.file\:inline-flex {
  &::file-selector-button {
    display: inline-flex;
  }
}
.file\:h-7 {
  &::file-selector-button {
    height: calc(var(--spacing) * 7);
  }
}
.file\:border-0 {
  &::file-selector-button {
    border-style: var(--tw-border-style);
    border-width: 0px;
  }
}
.file\:bg-transparent {
  &::file-selector-button {
    background-color: transparent;
  }
}
.file\:text-sm {
  &::file-selector-button {
    font-size: var(--text-sm);
    line-height: var(--tw-leading, var(--text-sm--line-height));
  }
}
.file\:font-medium {
  &::file-selector-button {
    --tw-font-weight: var(--font-weight-medium);
    font-weight: var(--font-weight-medium);
  }
}
.file\:text-foreground {
  &::file-selector-button {
    color: var(--foreground);
  }
}
.placeholder\:text-muted-foreground {
  &::placeholder {
    color: var(--muted-foreground);
  }
}
.after\:absolute {
  &::after {
    content: var(--tw-content);
    position: absolute;
  }
}
.after\:-inset-2 {
  &::after {
    content: var(--tw-content);
    inset: calc(var(--spacing) * -2);
  }
}
.after\:inset-y-0 {
  &::after {
    content: var(--tw-content);
    inset-block: calc(var(--spacing) * 0);
  }
}
.after\:left-1\/2 {
  &::after {
    content: var(--tw-content);
    left: calc(1/2 * 100%);
  }
}
.after\:w-1 {
  &::after {
    content: var(--tw-content);
    width: calc(var(--spacing) * 1);
  }
}
.after\:w-\[2px\] {
  &::after {
    content: var(--tw-content);
    width: 2px;
  }
}
.after\:-translate-x-1\/2 {
  &::after {
    content: var(--tw-content);
    --tw-translate-x: calc(calc(1/2 * 100%) * -1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
}
.group-data-\[collapsible\=offcanvas\]\:after\:left-full {
  &:is(:where(.group)[data-collapsible="offcanvas"] *) {
    &::after {
      content: var(--tw-content);
      left: 100%;
    }
  }
}
.first\:rounded-l-md {
  &:first-child {
    border-top-left-radius: calc(var(--radius) - 2px);
    border-bottom-left-radius: calc(var(--radius) - 2px);
  }
}
.first\:border-l {
  &:first-child {
    border-left-style: var(--tw-border-style);
    border-left-width: 1px;
  }
}
.last\:rounded-r-md {
  &:last-child {
    border-top-right-radius: calc(var(--radius) - 2px);
    border-bottom-right-radius: calc(var(--radius) - 2px);
  }
}
.last\:border-b-0 {
  &:last-child {
    border-bottom-style: var(--tw-border-style);
    border-bottom-width: 0px;
  }
}
.focus-within\:relative {
  &:focus-within {
    position: relative;
  }
}
.focus-within\:z-20 {
  &:focus-within {
    z-index: 20;
  }
}
.hover\:-translate-y-0\.5 {
  &:hover {
    @media (hover: hover) {
      --tw-translate-y: calc(var(--spacing) * -0.5);
      translate: var(--tw-translate-x) var(--tw-translate-y);
    }
  }
}
.hover\:-translate-y-1 {
  &:hover {
    @media (hover: hover) {
      --tw-translate-y: calc(var(--spacing) * -1);
      translate: var(--tw-translate-x) var(--tw-translate-y);
    }
  }
}
.hover\:border-\[\#3d5a80\] {
  &:hover {
    @media (hover: hover) {
      border-color: #3d5a80;
    }
  }
}
.hover\:border-\[\#ee6c4d\] {
  &:hover {
    @media (hover: hover) {
      border-color: #ee6c4d;
    }
  }
}
.hover\:bg-\[\#3d5a80\] {
  &:hover {
    @media (hover: hover) {
      background-color: #3d5a80;
    }
  }
}
.hover\:bg-accent {
  &:hover {
    @media (hover: hover) {
      background-color: var(--accent);
    }
  }
}
.hover\:bg-destructive\/90 {
  &:hover {
    @media (hover: hover) {
      background-color: var(--destructive);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--destructive) 90%, transparent);
      }
    }
  }
}
.hover\:bg-gray-50 {
  &:hover {
    @media (hover: hover) {
      background-color: var(--color-gray-50);
    }
  }
}
.hover\:bg-muted {
  &:hover {
    @media (hover: hover) {
      background-color: var(--muted);
    }
  }
}
.hover\:bg-muted\/50 {
  &:hover {
    @media (hover: hover) {
      background-color: var(--muted);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--muted) 50%, transparent);
      }
    }
  }
}
.hover\:bg-primary {
  &:hover {
    @media (hover: hover) {
      background-color: var(--primary);
    }
  }
}
.hover\:bg-primary\/90 {
  &:hover {
    @media (hover: hover) {
      background-color: var(--primary);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--primary) 90%, transparent);
      }
    }
  }
}
.hover\:bg-secondary\/80 {
  &:hover {
    @media (hover: hover) {
      background-color: var(--secondary);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--secondary) 80%, transparent);
      }
    }
  }
}
.hover\:bg-sidebar-accent {
  &:hover {
    @media (hover: hover) {
      background-color: var(--sidebar-accent);
    }
  }
}
.hover\:text-\[\#3d5a80\] {
  &:hover {
    @media (hover: hover) {
      color: #3d5a80;
    }
  }
}
.hover\:text-\[\#ee6c4d\] {
  &:hover {
    @media (hover: hover) {
      color: #ee6c4d;
    }
  }
}
.hover\:text-accent-foreground {
  &:hover {
    @media (hover: hover) {
      color: var(--accent-foreground);
    }
  }
}
.hover\:text-foreground {
  &:hover {
    @media (hover: hover) {
      color: var(--foreground);
    }
  }
}
.hover\:text-muted-foreground {
  &:hover {
    @media (hover: hover) {
      color: var(--muted-foreground);
    }
  }
}
.hover\:text-primary-foreground {
  &:hover {
    @media (hover: hover) {
      color: var(--primary-foreground);
    }
  }
}
.hover\:text-sidebar-accent-foreground {
  &:hover {
    @media (hover: hover) {
      color: var(--sidebar-accent-foreground);
    }
  }
}
.hover\:underline {
  &:hover {
    @media (hover: hover) {
      text-decoration-line: underline;
    }
  }
}
.hover\:opacity-100 {
  &:hover {
    @media (hover: hover) {
      opacity: 100%;
    }
  }
}
.hover\:shadow-\[0_0_0_1px_hsl\(var\(--sidebar-accent\)\)\] {
  &:hover {
    @media (hover: hover) {
      --tw-shadow: 0 0 0 1px var(--tw-shadow-color, hsl(var(--sidebar-accent)));
      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-md {
  &:hover {
    @media (hover: hover) {
      --tw-shadow: 0 4px 6px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 2px 4px -2px var(--tw-shadow-color, rgb(0 0 0 / 0.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-xl {
  &:hover {
    @media (hover: hover) {
      --tw-shadow: 0 20px 25px -5px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 8px 10px -6px var(--tw-shadow-color, rgb(0 0 0 / 0.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\:ring-4 {
  &:hover {
    @media (hover: hover) {
      --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(4px + 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);
    }
  }
}
.hover\:group-data-\[collapsible\=offcanvas\]\:bg-sidebar {
  &:hover {
    @media (hover: hover) {
      &:is(:where(.group)[data-collapsible="offcanvas"] *) {
        background-color: var(--sidebar);
      }
    }
  }
}
.hover\:after\:bg-sidebar-border {
  &:hover {
    @media (hover: hover) {
      &::after {
        content: var(--tw-content);
        background-color: var(--sidebar-border);
      }
    }
  }
}
.focus\:z-10 {
  &:focus {
    z-index: 10;
  }
}
.focus\:bg-accent {
  &:focus {
    background-color: var(--accent);
  }
}
.focus\:bg-primary {
  &:focus {
    background-color: var(--primary);
  }
}
.focus\:text-accent-foreground {
  &:focus {
    color: var(--accent-foreground);
  }
}
.focus\:text-primary-foreground {
  &:focus {
    color: var(--primary-foreground);
  }
}
.focus\:ring-2 {
  &:focus {
    --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);
  }
}
.focus\:ring-ring {
  &:focus {
    --tw-ring-color: var(--ring);
  }
}
.focus\:ring-offset-2 {
  &:focus {
    --tw-ring-offset-width: 2px;
    --tw-ring-offset-shadow: var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  }
}
.focus\:outline-hidden {
  &:focus {
    --tw-outline-style: none;
    outline-style: none;
    @media (forced-colors: active) {
      outline: 2px solid transparent;
      outline-offset: 2px;
    }
  }
}
.focus-visible\:z-10 {
  &:focus-visible {
    z-index: 10;
  }
}
.focus-visible\:border-ring {
  &:focus-visible {
    border-color: var(--ring);
  }
}
.focus-visible\:ring-1 {
  &:focus-visible {
    --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);
  }
}
.focus-visible\:ring-2 {
  &:focus-visible {
    --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);
  }
}
.focus-visible\:ring-4 {
  &:focus-visible {
    --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(4px + 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);
  }
}
.focus-visible\:ring-\[3px\] {
  &:focus-visible {
    --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(3px + 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);
  }
}
.focus-visible\:ring-destructive\/20 {
  &:focus-visible {
    --tw-ring-color: var(--destructive);
    @supports (color: color-mix(in lab, red, red)) {
      --tw-ring-color: color-mix(in oklab, var(--destructive) 20%, transparent);
    }
  }
}
.focus-visible\:ring-ring {
  &:focus-visible {
    --tw-ring-color: var(--ring);
  }
}
.focus-visible\:ring-ring\/50 {
  &:focus-visible {
    --tw-ring-color: var(--ring);
    @supports (color: color-mix(in lab, red, red)) {
      --tw-ring-color: color-mix(in oklab, var(--ring) 50%, transparent);
    }
  }
}
.focus-visible\:ring-offset-1 {
  &:focus-visible {
    --tw-ring-offset-width: 1px;
    --tw-ring-offset-shadow: var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  }
}
.focus-visible\:outline-hidden {
  &:focus-visible {
    --tw-outline-style: none;
    outline-style: none;
    @media (forced-colors: active) {
      outline: 2px solid transparent;
      outline-offset: 2px;
    }
  }
}
.focus-visible\:outline-1 {
  &:focus-visible {
    outline-style: var(--tw-outline-style);
    outline-width: 1px;
  }
}
.focus-visible\:outline-ring {
  &:focus-visible {
    outline-color: var(--ring);
  }
}
.active\:bg-sidebar-accent {
  &:active {
    background-color: var(--sidebar-accent);
  }
}
.active\:text-sidebar-accent-foreground {
  &:active {
    color: var(--sidebar-accent-foreground);
  }
}
.disabled\:pointer-events-none {
  &:disabled {
    pointer-events: none;
  }
}
.disabled\:cursor-not-allowed {
  &:disabled {
    cursor: not-allowed;
  }
}
.disabled\:opacity-50 {
  &:disabled {
    opacity: 50%;
  }
}
.in-data-\[side\=left\]\:cursor-w-resize {
  :where(*[data-side="left"]) & {
    cursor: w-resize;
  }
}
.in-data-\[side\=right\]\:cursor-e-resize {
  :where(*[data-side="right"]) & {
    cursor: e-resize;
  }
}
.has-disabled\:opacity-50 {
  &:has(*:disabled) {
    opacity: 50%;
  }
}
.has-data-\[slot\=card-action\]\:grid-cols-\[1fr_auto\] {
  &:has(*[data-slot="card-action"]) {
    grid-template-columns: 1fr auto;
  }
}
.has-data-\[variant\=inset\]\:bg-sidebar {
  &:has(*[data-variant="inset"]) {
    background-color: var(--sidebar);
  }
}
.has-\[\>svg\]\:grid-cols-\[calc\(var\(--spacing\)\*4\)_1fr\] {
  &:has(>svg) {
    grid-template-columns: calc(var(--spacing) * 4) 1fr;
  }
}
.has-\[\>svg\]\:gap-x-3 {
  &:has(>svg) {
    column-gap: calc(var(--spacing) * 3);
  }
}
.has-\[\>svg\]\:px-2\.5 {
  &:has(>svg) {
    padding-inline: calc(var(--spacing) * 2.5);
  }
}
.has-\[\>svg\]\:px-3 {
  &:has(>svg) {
    padding-inline: calc(var(--spacing) * 3);
  }
}
.has-\[\>svg\]\:px-4 {
  &:has(>svg) {
    padding-inline: calc(var(--spacing) * 4);
  }
}
.aria-disabled\:pointer-events-none {
  &[aria-disabled="true"] {
    pointer-events: none;
  }
}
.aria-disabled\:opacity-50 {
  &[aria-disabled="true"] {
    opacity: 50%;
  }
}
.aria-invalid\:border-destructive {
  &[aria-invalid="true"] {
    border-color: var(--destructive);
  }
}
.aria-invalid\:ring-destructive\/20 {
  &[aria-invalid="true"] {
    --tw-ring-color: var(--destructive);
    @supports (color: color-mix(in lab, red, red)) {
      --tw-ring-color: color-mix(in oklab, var(--destructive) 20%, transparent);
    }
  }
}
.aria-selected\:bg-accent {
  &[aria-selected="true"] {
    background-color: var(--accent);
  }
}
.aria-selected\:bg-primary {
  &[aria-selected="true"] {
    background-color: var(--primary);
  }
}
.aria-selected\:text-accent-foreground {
  &[aria-selected="true"] {
    color: var(--accent-foreground);
  }
}
.aria-selected\:text-muted-foreground {
  &[aria-selected="true"] {
    color: var(--muted-foreground);
  }
}
.aria-selected\:text-primary-foreground {
  &[aria-selected="true"] {
    color: var(--primary-foreground);
  }
}
.aria-selected\:opacity-100 {
  &[aria-selected="true"] {
    opacity: 100%;
  }
}
.data-\[active\=true\]\:z-10 {
  &[data-active="true"] {
    z-index: 10;
  }
}
.data-\[active\=true\]\:border-ring {
  &[data-active="true"] {
    border-color: var(--ring);
  }
}
.data-\[active\=true\]\:bg-accent\/50 {
  &[data-active="true"] {
    background-color: var(--accent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--accent) 50%, transparent);
    }
  }
}
.data-\[active\=true\]\:bg-sidebar-accent {
  &[data-active="true"] {
    background-color: var(--sidebar-accent);
  }
}
.data-\[active\=true\]\:font-medium {
  &[data-active="true"] {
    --tw-font-weight: var(--font-weight-medium);
    font-weight: var(--font-weight-medium);
  }
}
.data-\[active\=true\]\:text-accent-foreground {
  &[data-active="true"] {
    color: var(--accent-foreground);
  }
}
.data-\[active\=true\]\:text-sidebar-accent-foreground {
  &[data-active="true"] {
    color: var(--sidebar-accent-foreground);
  }
}
.data-\[active\=true\]\:ring-\[3px\] {
  &[data-active="true"] {
    --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(3px + 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);
  }
}
.data-\[active\=true\]\:ring-ring\/50 {
  &[data-active="true"] {
    --tw-ring-color: var(--ring);
    @supports (color: color-mix(in lab, red, red)) {
      --tw-ring-color: color-mix(in oklab, var(--ring) 50%, transparent);
    }
  }
}
.data-\[active\=true\]\:hover\:bg-accent {
  &[data-active="true"] {
    &:hover {
      @media (hover: hover) {
        background-color: var(--accent);
      }
    }
  }
}
.data-\[active\=true\]\:focus\:bg-accent {
  &[data-active="true"] {
    &:focus {
      background-color: var(--accent);
    }
  }
}
.data-\[active\=true\]\:aria-invalid\:border-destructive {
  &[data-active="true"] {
    &[aria-invalid="true"] {
      border-color: var(--destructive);
    }
  }
}
.data-\[active\=true\]\:aria-invalid\:ring-destructive\/20 {
  &[data-active="true"] {
    &[aria-invalid="true"] {
      --tw-ring-color: var(--destructive);
      @supports (color: color-mix(in lab, red, red)) {
        --tw-ring-color: color-mix(in oklab, var(--destructive) 20%, transparent);
      }
    }
  }
}
.data-\[disabled\]\:pointer-events-none {
  &[data-disabled] {
    pointer-events: none;
  }
}
.data-\[disabled\]\:opacity-50 {
  &[data-disabled] {
    opacity: 50%;
  }
}
.data-\[disabled\=true\]\:pointer-events-none {
  &[data-disabled="true"] {
    pointer-events: none;
  }
}
.data-\[disabled\=true\]\:opacity-50 {
  &[data-disabled="true"] {
    opacity: 50%;
  }
}
.data-\[error\=true\]\:text-destructive {
  &[data-error="true"] {
    color: var(--destructive);
  }
}
.data-\[inset\]\:pl-8 {
  &[data-inset] {
    padding-left: calc(var(--spacing) * 8);
  }
}
.data-\[motion\=from-end\]\:slide-in-from-right-52 {
  &[data-motion="from-end"] {
    --tw-enter-translate-x: calc(var(--spacing) * 52);
  }
}
.data-\[motion\=from-start\]\:slide-in-from-left-52 {
  &[data-motion="from-start"] {
    --tw-enter-translate-x: calc(var(--spacing) * 52*-1);
  }
}
.data-\[motion\=to-end\]\:slide-out-to-right-52 {
  &[data-motion="to-end"] {
    --tw-exit-translate-x: calc(var(--spacing) * 52);
  }
}
.data-\[motion\=to-start\]\:slide-out-to-left-52 {
  &[data-motion="to-start"] {
    --tw-exit-translate-x: calc(var(--spacing) * 52*-1);
  }
}
.data-\[motion\^\=from-\]\:animate-in {
  &[data-motion^="from-"] {
    animation: enter var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none);
  }
}
.data-\[motion\^\=from-\]\:fade-in {
  &[data-motion^="from-"] {
    --tw-enter-opacity: 0;
  }
}
.data-\[motion\^\=to-\]\:animate-out {
  &[data-motion^="to-"] {
    animation: exit var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none);
  }
}
.data-\[motion\^\=to-\]\:fade-out {
  &[data-motion^="to-"] {
    --tw-exit-opacity: 0;
  }
}
.data-\[orientation\=horizontal\]\:h-4 {
  &[data-orientation="horizontal"] {
    height: calc(var(--spacing) * 4);
  }
}
.data-\[orientation\=horizontal\]\:h-full {
  &[data-orientation="horizontal"] {
    height: 100%;
  }
}
.data-\[orientation\=horizontal\]\:h-px {
  &[data-orientation="horizontal"] {
    height: 1px;
  }
}
.data-\[orientation\=horizontal\]\:w-full {
  &[data-orientation="horizontal"] {
    width: 100%;
  }
}
.data-\[orientation\=vertical\]\:h-full {
  &[data-orientation="vertical"] {
    height: 100%;
  }
}
.data-\[orientation\=vertical\]\:min-h-44 {
  &[data-orientation="vertical"] {
    min-height: calc(var(--spacing) * 44);
  }
}
.data-\[orientation\=vertical\]\:w-1\.5 {
  &[data-orientation="vertical"] {
    width: calc(var(--spacing) * 1.5);
  }
}
.data-\[orientation\=vertical\]\:w-auto {
  &[data-orientation="vertical"] {
    width: auto;
  }
}
.data-\[orientation\=vertical\]\:w-full {
  &[data-orientation="vertical"] {
    width: 100%;
  }
}
.data-\[orientation\=vertical\]\:w-px {
  &[data-orientation="vertical"] {
    width: 1px;
  }
}
.data-\[orientation\=vertical\]\:flex-col {
  &[data-orientation="vertical"] {
    flex-direction: column;
  }
}
.data-\[panel-group-direction\=vertical\]\:h-px {
  &[data-panel-group-direction="vertical"] {
    height: 1px;
  }
}
.data-\[panel-group-direction\=vertical\]\:w-full {
  &[data-panel-group-direction="vertical"] {
    width: 100%;
  }
}
.data-\[panel-group-direction\=vertical\]\:flex-col {
  &[data-panel-group-direction="vertical"] {
    flex-direction: column;
  }
}
.data-\[panel-group-direction\=vertical\]\:after\:left-0 {
  &[data-panel-group-direction="vertical"] {
    &::after {
      content: var(--tw-content);
      left: calc(var(--spacing) * 0);
    }
  }
}
.data-\[panel-group-direction\=vertical\]\:after\:h-1 {
  &[data-panel-group-direction="vertical"] {
    &::after {
      content: var(--tw-content);
      height: calc(var(--spacing) * 1);
    }
  }
}
.data-\[panel-group-direction\=vertical\]\:after\:w-full {
  &[data-panel-group-direction="vertical"] {
    &::after {
      content: var(--tw-content);
      width: 100%;
    }
  }
}
.data-\[panel-group-direction\=vertical\]\:after\:translate-x-0 {
  &[data-panel-group-direction="vertical"] {
    &::after {
      content: var(--tw-content);
      --tw-translate-x: calc(var(--spacing) * 0);
      translate: var(--tw-translate-x) var(--tw-translate-y);
    }
  }
}
.data-\[panel-group-direction\=vertical\]\:after\:-translate-y-1\/2 {
  &[data-panel-group-direction="vertical"] {
    &::after {
      content: var(--tw-content);
      --tw-translate-y: calc(calc(1/2 * 100%) * -1);
      translate: var(--tw-translate-x) var(--tw-translate-y);
    }
  }
}
.data-\[placeholder\]\:text-muted-foreground {
  &[data-placeholder] {
    color: var(--muted-foreground);
  }
}
.data-\[selected\=true\]\:bg-accent {
  &[data-selected="true"] {
    background-color: var(--accent);
  }
}
.data-\[selected\=true\]\:text-accent-foreground {
  &[data-selected="true"] {
    color: var(--accent-foreground);
  }
}
.data-\[side\=bottom\]\:translate-y-1 {
  &[data-side="bottom"] {
    --tw-translate-y: calc(var(--spacing) * 1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
}
.data-\[side\=bottom\]\:slide-in-from-top-2 {
  &[data-side="bottom"] {
    --tw-enter-translate-y: calc(var(--spacing) * 2*-1);
  }
}
.data-\[side\=left\]\:-translate-x-1 {
  &[data-side="left"] {
    --tw-translate-x: calc(var(--spacing) * -1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
}
.data-\[side\=left\]\:slide-in-from-right-2 {
  &[data-side="left"] {
    --tw-enter-translate-x: calc(var(--spacing) * 2);
  }
}
.data-\[side\=right\]\:translate-x-1 {
  &[data-side="right"] {
    --tw-translate-x: calc(var(--spacing) * 1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
}
.data-\[side\=right\]\:slide-in-from-left-2 {
  &[data-side="right"] {
    --tw-enter-translate-x: calc(var(--spacing) * 2*-1);
  }
}
.data-\[side\=top\]\:-translate-y-1 {
  &[data-side="top"] {
    --tw-translate-y: calc(var(--spacing) * -1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
}
.data-\[side\=top\]\:slide-in-from-bottom-2 {
  &[data-side="top"] {
    --tw-enter-translate-y: calc(var(--spacing) * 2);
  }
}
.data-\[size\=default\]\:h-9 {
  &[data-size="default"] {
    height: calc(var(--spacing) * 9);
  }
}
.data-\[size\=sm\]\:h-8 {
  &[data-size="sm"] {
    height: calc(var(--spacing) * 8);
  }
}
.\*\:data-\[slot\=alert-description\]\:text-destructive\/90 {
  :is(& > *) {
    &[data-slot="alert-description"] {
      color: var(--destructive);
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, var(--destructive) 90%, transparent);
      }
    }
  }
}
.\*\*\:data-\[slot\=command-input-wrapper\]\:h-12 {
  :is(& *) {
    &[data-slot="command-input-wrapper"] {
      height: calc(var(--spacing) * 12);
    }
  }
}
.\*\*\:data-\[slot\=navigation-menu-link\]\:focus\:ring-0 {
  :is(& *) {
    &[data-slot="navigation-menu-link"] {
      &:focus {
        --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(0px + 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);
      }
    }
  }
}
.\*\*\:data-\[slot\=navigation-menu-link\]\:focus\:outline-none {
  :is(& *) {
    &[data-slot="navigation-menu-link"] {
      &:focus {
        --tw-outline-style: none;
        outline-style: none;
      }
    }
  }
}
.\*\:data-\[slot\=select-value\]\:line-clamp-1 {
  :is(& > *) {
    &[data-slot="select-value"] {
      overflow: hidden;
      display: -webkit-box;
      -webkit-box-orient: vertical;
      -webkit-line-clamp: 1;
      line-clamp: 1;
    }
  }
}
.\*\:data-\[slot\=select-value\]\:flex {
  :is(& > *) {
    &[data-slot="select-value"] {
      display: flex;
    }
  }
}
.\*\:data-\[slot\=select-value\]\:items-center {
  :is(& > *) {
    &[data-slot="select-value"] {
      align-items: center;
    }
  }
}
.\*\:data-\[slot\=select-value\]\:gap-2 {
  :is(& > *) {
    &[data-slot="select-value"] {
      gap: calc(var(--spacing) * 2);
    }
  }
}
.data-\[state\=active\]\:bg-card {
  &[data-state="active"] {
    background-color: var(--card);
  }
}
.data-\[state\=checked\]\:translate-x-\[calc\(100\%-2px\)\] {
  &[data-state="checked"] {
    --tw-translate-x: calc(100% - 2px);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
}
.data-\[state\=checked\]\:border-primary {
  &[data-state="checked"] {
    border-color: var(--primary);
  }
}
.data-\[state\=checked\]\:bg-primary {
  &[data-state="checked"] {
    background-color: var(--primary);
  }
}
.data-\[state\=checked\]\:text-primary-foreground {
  &[data-state="checked"] {
    color: var(--primary-foreground);
  }
}
.data-\[state\=closed\]\:animate-accordion-up {
  &[data-state="closed"] {
    animation: accordion-up var(--tw-animation-duration,var(--tw-duration,.2s))var(--tw-ease,ease-out)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none);
  }
}
.data-\[state\=closed\]\:animate-out {
  &[data-state="closed"] {
    animation: exit var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none);
  }
}
.data-\[state\=closed\]\:duration-300 {
  &[data-state="closed"] {
    --tw-duration: 300ms;
    transition-duration: 300ms;
  }
}
.data-\[state\=closed\]\:fade-out-0 {
  &[data-state="closed"] {
    --tw-exit-opacity: calc(0/100);
    --tw-exit-opacity: 0;
  }
}
.data-\[state\=closed\]\:zoom-out-95 {
  &[data-state="closed"] {
    --tw-exit-scale: calc(95*1%);
    --tw-exit-scale: .95;
  }
}
.data-\[state\=closed\]\:slide-out-to-bottom {
  &[data-state="closed"] {
    --tw-exit-translate-y: 100%;
  }
}
.data-\[state\=closed\]\:slide-out-to-left {
  &[data-state="closed"] {
    --tw-exit-translate-x: -100%;
  }
}
.data-\[state\=closed\]\:slide-out-to-right {
  &[data-state="closed"] {
    --tw-exit-translate-x: 100%;
  }
}
.data-\[state\=closed\]\:slide-out-to-top {
  &[data-state="closed"] {
    --tw-exit-translate-y: -100%;
  }
}
.group-data-\[viewport\=false\]\/navigation-menu\:data-\[state\=closed\]\:animate-out {
  &:is(:where(.group\/navigation-menu)[data-viewport="false"] *) {
    &[data-state="closed"] {
      animation: exit var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none);
    }
  }
}
.group-data-\[viewport\=false\]\/navigation-menu\:data-\[state\=closed\]\:fade-out-0 {
  &:is(:where(.group\/navigation-menu)[data-viewport="false"] *) {
    &[data-state="closed"] {
      --tw-exit-opacity: calc(0/100);
      --tw-exit-opacity: 0;
    }
  }
}
.group-data-\[viewport\=false\]\/navigation-menu\:data-\[state\=closed\]\:zoom-out-95 {
  &:is(:where(.group\/navigation-menu)[data-viewport="false"] *) {
    &[data-state="closed"] {
      --tw-exit-scale: calc(95*1%);
      --tw-exit-scale: .95;
    }
  }
}
.data-\[state\=hidden\]\:animate-out {
  &[data-state="hidden"] {
    animation: exit var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none);
  }
}
.data-\[state\=hidden\]\:fade-out {
  &[data-state="hidden"] {
    --tw-exit-opacity: 0;
  }
}
.data-\[state\=on\]\:bg-accent {
  &[data-state="on"] {
    background-color: var(--accent);
  }
}
.data-\[state\=on\]\:text-accent-foreground {
  &[data-state="on"] {
    color: var(--accent-foreground);
  }
}
.data-\[state\=open\]\:animate-accordion-down {
  &[data-state="open"] {
    animation: accordion-down var(--tw-animation-duration,var(--tw-duration,.2s))var(--tw-ease,ease-out)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none);
  }
}
.data-\[state\=open\]\:animate-in {
  &[data-state="open"] {
    animation: enter var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none);
  }
}
.data-\[state\=open\]\:bg-accent {
  &[data-state="open"] {
    background-color: var(--accent);
  }
}
.data-\[state\=open\]\:bg-accent\/50 {
  &[data-state="open"] {
    background-color: var(--accent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--accent) 50%, transparent);
    }
  }
}
.data-\[state\=open\]\:bg-secondary {
  &[data-state="open"] {
    background-color: var(--secondary);
  }
}
.data-\[state\=open\]\:text-accent-foreground {
  &[data-state="open"] {
    color: var(--accent-foreground);
  }
}
.data-\[state\=open\]\:text-muted-foreground {
  &[data-state="open"] {
    color: var(--muted-foreground);
  }
}
.data-\[state\=open\]\:opacity-100 {
  &[data-state="open"] {
    opacity: 100%;
  }
}
.data-\[state\=open\]\:duration-500 {
  &[data-state="open"] {
    --tw-duration: 500ms;
    transition-duration: 500ms;
  }
}
.data-\[state\=open\]\:fade-in-0 {
  &[data-state="open"] {
    --tw-enter-opacity: calc(0/100);
    --tw-enter-opacity: 0;
  }
}
.data-\[state\=open\]\:zoom-in-90 {
  &[data-state="open"] {
    --tw-enter-scale: calc(90*1%);
    --tw-enter-scale: .9;
  }
}
.data-\[state\=open\]\:zoom-in-95 {
  &[data-state="open"] {
    --tw-enter-scale: calc(95*1%);
    --tw-enter-scale: .95;
  }
}
.data-\[state\=open\]\:slide-in-from-bottom {
  &[data-state="open"] {
    --tw-enter-translate-y: 100%;
  }
}
.data-\[state\=open\]\:slide-in-from-left {
  &[data-state="open"] {
    --tw-enter-translate-x: -100%;
  }
}
.data-\[state\=open\]\:slide-in-from-right {
  &[data-state="open"] {
    --tw-enter-translate-x: 100%;
  }
}
.data-\[state\=open\]\:slide-in-from-top {
  &[data-state="open"] {
    --tw-enter-translate-y: -100%;
  }
}
.group-data-\[viewport\=false\]\/navigation-menu\:data-\[state\=open\]\:animate-in {
  &:is(:where(.group\/navigation-menu)[data-viewport="false"] *) {
    &[data-state="open"] {
      animation: enter var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none);
    }
  }
}
.group-data-\[viewport\=false\]\/navigation-menu\:data-\[state\=open\]\:fade-in-0 {
  &:is(:where(.group\/navigation-menu)[data-viewport="false"] *) {
    &[data-state="open"] {
      --tw-enter-opacity: calc(0/100);
      --tw-enter-opacity: 0;
    }
  }
}
.group-data-\[viewport\=false\]\/navigation-menu\:data-\[state\=open\]\:zoom-in-95 {
  &:is(:where(.group\/navigation-menu)[data-viewport="false"] *) {
    &[data-state="open"] {
      --tw-enter-scale: calc(95*1%);
      --tw-enter-scale: .95;
    }
  }
}
.data-\[state\=open\]\:hover\:bg-accent {
  &[data-state="open"] {
    &:hover {
      @media (hover: hover) {
        background-color: var(--accent);
      }
    }
  }
}
.data-\[state\=open\]\:hover\:bg-sidebar-accent {
  &[data-state="open"] {
    &:hover {
      @media (hover: hover) {
        background-color: var(--sidebar-accent);
      }
    }
  }
}
.data-\[state\=open\]\:hover\:text-sidebar-accent-foreground {
  &[data-state="open"] {
    &:hover {
      @media (hover: hover) {
        color: var(--sidebar-accent-foreground);
      }
    }
  }
}
.data-\[state\=open\]\:focus\:bg-accent {
  &[data-state="open"] {
    &:focus {
      background-color: var(--accent);
    }
  }
}
.data-\[state\=selected\]\:bg-muted {
  &[data-state="selected"] {
    background-color: var(--muted);
  }
}
.data-\[state\=unchecked\]\:translate-x-0 {
  &[data-state="unchecked"] {
    --tw-translate-x: calc(var(--spacing) * 0);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
}
.data-\[state\=unchecked\]\:bg-switch-background {
  &[data-state="unchecked"] {
    background-color: var(--switch-background);
  }
}
.data-\[state\=visible\]\:animate-in {
  &[data-state="visible"] {
    animation: enter var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none);
  }
}
.data-\[state\=visible\]\:fade-in {
  &[data-state="visible"] {
    --tw-enter-opacity: 0;
  }
}
.data-\[variant\=destructive\]\:text-destructive {
  &[data-variant="destructive"] {
    color: var(--destructive);
  }
}
.data-\[variant\=destructive\]\:focus\:bg-destructive\/10 {
  &[data-variant="destructive"] {
    &:focus {
      background-color: var(--destructive);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--destructive) 10%, transparent);
      }
    }
  }
}
.data-\[variant\=destructive\]\:focus\:text-destructive {
  &[data-variant="destructive"] {
    &:focus {
      color: var(--destructive);
    }
  }
}
.data-\[variant\=outline\]\:border-l-0 {
  &[data-variant="outline"] {
    border-left-style: var(--tw-border-style);
    border-left-width: 0px;
  }
}
.data-\[variant\=outline\]\:shadow-xs {
  &[data-variant="outline"] {
    --tw-shadow: 0 1px 2px 0 var(--tw-shadow-color, rgb(0 0 0 / 0.05));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
}
.data-\[variant\=outline\]\:first\:border-l {
  &[data-variant="outline"] {
    &:first-child {
      border-left-style: var(--tw-border-style);
      border-left-width: 1px;
    }
  }
}
.data-\[vaul-drawer-direction\=bottom\]\:inset-x-0 {
  &[data-vaul-drawer-direction="bottom"] {
    inset-inline: calc(var(--spacing) * 0);
  }
}
.data-\[vaul-drawer-direction\=bottom\]\:bottom-0 {
  &[data-vaul-drawer-direction="bottom"] {
    bottom: calc(var(--spacing) * 0);
  }
}
.data-\[vaul-drawer-direction\=bottom\]\:mt-24 {
  &[data-vaul-drawer-direction="bottom"] {
    margin-top: calc(var(--spacing) * 24);
  }
}
.data-\[vaul-drawer-direction\=bottom\]\:max-h-\[80vh\] {
  &[data-vaul-drawer-direction="bottom"] {
    max-height: 80vh;
  }
}
.data-\[vaul-drawer-direction\=bottom\]\:rounded-t-lg {
  &[data-vaul-drawer-direction="bottom"] {
    border-top-left-radius: var(--radius);
    border-top-right-radius: var(--radius);
  }
}
.data-\[vaul-drawer-direction\=bottom\]\:border-t {
  &[data-vaul-drawer-direction="bottom"] {
    border-top-style: var(--tw-border-style);
    border-top-width: 1px;
  }
}
.data-\[vaul-drawer-direction\=left\]\:inset-y-0 {
  &[data-vaul-drawer-direction="left"] {
    inset-block: calc(var(--spacing) * 0);
  }
}
.data-\[vaul-drawer-direction\=left\]\:left-0 {
  &[data-vaul-drawer-direction="left"] {
    left: calc(var(--spacing) * 0);
  }
}
.data-\[vaul-drawer-direction\=left\]\:w-3\/4 {
  &[data-vaul-drawer-direction="left"] {
    width: calc(3/4 * 100%);
  }
}
.data-\[vaul-drawer-direction\=left\]\:border-r {
  &[data-vaul-drawer-direction="left"] {
    border-right-style: var(--tw-border-style);
    border-right-width: 1px;
  }
}
.data-\[vaul-drawer-direction\=right\]\:inset-y-0 {
  &[data-vaul-drawer-direction="right"] {
    inset-block: calc(var(--spacing) * 0);
  }
}
.data-\[vaul-drawer-direction\=right\]\:right-0 {
  &[data-vaul-drawer-direction="right"] {
    right: calc(var(--spacing) * 0);
  }
}
.data-\[vaul-drawer-direction\=right\]\:w-3\/4 {
  &[data-vaul-drawer-direction="right"] {
    width: calc(3/4 * 100%);
  }
}
.data-\[vaul-drawer-direction\=right\]\:border-l {
  &[data-vaul-drawer-direction="right"] {
    border-left-style: var(--tw-border-style);
    border-left-width: 1px;
  }
}
.data-\[vaul-drawer-direction\=top\]\:inset-x-0 {
  &[data-vaul-drawer-direction="top"] {
    inset-inline: calc(var(--spacing) * 0);
  }
}
.data-\[vaul-drawer-direction\=top\]\:top-0 {
  &[data-vaul-drawer-direction="top"] {
    top: calc(var(--spacing) * 0);
  }
}
.data-\[vaul-drawer-direction\=top\]\:mb-24 {
  &[data-vaul-drawer-direction="top"] {
    margin-bottom: calc(var(--spacing) * 24);
  }
}
.data-\[vaul-drawer-direction\=top\]\:max-h-\[80vh\] {
  &[data-vaul-drawer-direction="top"] {
    max-height: 80vh;
  }
}
.data-\[vaul-drawer-direction\=top\]\:rounded-b-lg {
  &[data-vaul-drawer-direction="top"] {
    border-bottom-right-radius: var(--radius);
    border-bottom-left-radius: var(--radius);
  }
}
.data-\[vaul-drawer-direction\=top\]\:border-b {
  &[data-vaul-drawer-direction="top"] {
    border-bottom-style: var(--tw-border-style);
    border-bottom-width: 1px;
  }
}
.sm\:block {
  @media (width >= 40rem) {
    display: block;
  }
}
.sm\:flex {
  @media (width >= 40rem) {
    display: flex;
  }
}
.sm\:max-w-lg {
  @media (width >= 40rem) {
    max-width: var(--container-lg);
  }
}
.sm\:max-w-sm {
  @media (width >= 40rem) {
    max-width: var(--container-sm);
  }
}
.sm\:grid-cols-2 {
  @media (width >= 40rem) {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
.sm\:flex-row {
  @media (width >= 40rem) {
    flex-direction: row;
  }
}
.sm\:justify-end {
  @media (width >= 40rem) {
    justify-content: flex-end;
  }
}
.sm\:gap-2\.5 {
  @media (width >= 40rem) {
    gap: calc(var(--spacing) * 2.5);
  }
}
.sm\:pr-2\.5 {
  @media (width >= 40rem) {
    padding-right: calc(var(--spacing) * 2.5);
  }
}
.sm\:pl-2\.5 {
  @media (width >= 40rem) {
    padding-left: calc(var(--spacing) * 2.5);
  }
}
.sm\:text-left {
  @media (width >= 40rem) {
    text-align: left;
  }
}
.data-\[vaul-drawer-direction\=left\]\:sm\:max-w-sm {
  &[data-vaul-drawer-direction="left"] {
    @media (width >= 40rem) {
      max-width: var(--container-sm);
    }
  }
}
.data-\[vaul-drawer-direction\=right\]\:sm\:max-w-sm {
  &[data-vaul-drawer-direction="right"] {
    @media (width >= 40rem) {
      max-width: var(--container-sm);
    }
  }
}
.md\:absolute {
  @media (width >= 48rem) {
    position: absolute;
  }
}
.md\:block {
  @media (width >= 48rem) {
    display: block;
  }
}
.md\:flex {
  @media (width >= 48rem) {
    display: flex;
  }
}
.md\:h-40 {
  @media (width >= 48rem) {
    height: calc(var(--spacing) * 40);
  }
}
.md\:h-auto {
  @media (width >= 48rem) {
    height: auto;
  }
}
.md\:w-1\/3 {
  @media (width >= 48rem) {
    width: calc(1/3 * 100%);
  }
}
.md\:w-40 {
  @media (width >= 48rem) {
    width: calc(var(--spacing) * 40);
  }
}
.md\:w-\[var\(--radix-navigation-menu-viewport-width\)\] {
  @media (width >= 48rem) {
    width: var(--radix-navigation-menu-viewport-width);
  }
}
.md\:w-auto {
  @media (width >= 48rem) {
    width: auto;
  }
}
.md\:grid-cols-2 {
  @media (width >= 48rem) {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
.md\:grid-cols-3 {
  @media (width >= 48rem) {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
.md\:grid-cols-4 {
  @media (width >= 48rem) {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}
.md\:flex-row {
  @media (width >= 48rem) {
    flex-direction: row;
  }
}
.md\:p-8 {
  @media (width >= 48rem) {
    padding: calc(var(--spacing) * 8);
  }
}
.md\:px-8 {
  @media (width >= 48rem) {
    padding-inline: calc(var(--spacing) * 8);
  }
}
.md\:pl-8 {
  @media (width >= 48rem) {
    padding-left: calc(var(--spacing) * 8);
  }
}
.md\:text-2xl {
  @media (width >= 48rem) {
    font-size: var(--text-2xl);
    line-height: var(--tw-leading, var(--text-2xl--line-height));
  }
}
.md\:text-5xl {
  @media (width >= 48rem) {
    font-size: var(--text-5xl);
    line-height: var(--tw-leading, var(--text-5xl--line-height));
  }
}
.md\:text-sm {
  @media (width >= 48rem) {
    font-size: var(--text-sm);
    line-height: var(--tw-leading, var(--text-sm--line-height));
  }
}
.md\:opacity-0 {
  @media (width >= 48rem) {
    opacity: 0%;
  }
}
.md\:peer-data-\[variant\=inset\]\:m-2 {
  @media (width >= 48rem) {
    &:is(:where(.peer)[data-variant="inset"] ~ *) {
      margin: calc(var(--spacing) * 2);
    }
  }
}
.md\:peer-data-\[variant\=inset\]\:ml-0 {
  @media (width >= 48rem) {
    &:is(:where(.peer)[data-variant="inset"] ~ *) {
      margin-left: calc(var(--spacing) * 0);
    }
  }
}
.md\:peer-data-\[variant\=inset\]\:rounded-xl {
  @media (width >= 48rem) {
    &:is(:where(.peer)[data-variant="inset"] ~ *) {
      border-radius: calc(var(--radius) + 4px);
    }
  }
}
.md\:peer-data-\[variant\=inset\]\:shadow-sm {
  @media (width >= 48rem) {
    &:is(:where(.peer)[data-variant="inset"] ~ *) {
      --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 1px 2px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
      box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
    }
  }
}
.md\:peer-data-\[variant\=inset\]\:peer-data-\[state\=collapsed\]\:ml-2 {
  @media (width >= 48rem) {
    &:is(:where(.peer)[data-variant="inset"] ~ *) {
      &:is(:where(.peer)[data-state="collapsed"] ~ *) {
        margin-left: calc(var(--spacing) * 2);
      }
    }
  }
}
.md\:after\:hidden {
  @media (width >= 48rem) {
    &::after {
      content: var(--tw-content);
      display: none;
    }
  }
}
.lg\:col-span-4 {
  @media (width >= 64rem) {
    grid-column: span 4 / span 4;
  }
}
.lg\:col-span-8 {
  @media (width >= 64rem) {
    grid-column: span 8 / span 8;
  }
}
.lg\:grid-cols-12 {
  @media (width >= 64rem) {
    grid-template-columns: repeat(12, minmax(0, 1fr));
  }
}
.dark\:border-input {
  &:is(.dark *) {
    border-color: var(--input);
  }
}
.dark\:bg-destructive\/60 {
  &:is(.dark *) {
    background-color: var(--destructive);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--destructive) 60%, transparent);
    }
  }
}
.dark\:bg-input\/30 {
  &:is(.dark *) {
    background-color: var(--input);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--input) 30%, transparent);
    }
  }
}
.dark\:text-muted-foreground {
  &:is(.dark *) {
    color: var(--muted-foreground);
  }
}
.dark\:hover\:bg-accent\/50 {
  &:is(.dark *) {
    &:hover {
      @media (hover: hover) {
        background-color: var(--accent);
        @supports (color: color-mix(in lab, red, red)) {
          background-color: color-mix(in oklab, var(--accent) 50%, transparent);
        }
      }
    }
  }
}
.dark\:hover\:bg-input\/50 {
  &:is(.dark *) {
    &:hover {
      @media (hover: hover) {
        background-color: var(--input);
        @supports (color: color-mix(in lab, red, red)) {
          background-color: color-mix(in oklab, var(--input) 50%, transparent);
        }
      }
    }
  }
}
.dark\:focus-visible\:ring-destructive\/40 {
  &:is(.dark *) {
    &:focus-visible {
      --tw-ring-color: var(--destructive);
      @supports (color: color-mix(in lab, red, red)) {
        --tw-ring-color: color-mix(in oklab, var(--destructive) 40%, transparent);
      }
    }
  }
}
.dark\:aria-invalid\:ring-destructive\/40 {
  &:is(.dark *) {
    &[aria-invalid="true"] {
      --tw-ring-color: var(--destructive);
      @supports (color: color-mix(in lab, red, red)) {
        --tw-ring-color: color-mix(in oklab, var(--destructive) 40%, transparent);
      }
    }
  }
}
.dark\:data-\[active\=true\]\:aria-invalid\:ring-destructive\/40 {
  &:is(.dark *) {
    &[data-active="true"] {
      &[aria-invalid="true"] {
        --tw-ring-color: var(--destructive);
        @supports (color: color-mix(in lab, red, red)) {
          --tw-ring-color: color-mix(in oklab, var(--destructive) 40%, transparent);
        }
      }
    }
  }
}
.dark\:data-\[state\=active\]\:border-input {
  &:is(.dark *) {
    &[data-state="active"] {
      border-color: var(--input);
    }
  }
}
.dark\:data-\[state\=active\]\:bg-input\/30 {
  &:is(.dark *) {
    &[data-state="active"] {
      background-color: var(--input);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--input) 30%, transparent);
      }
    }
  }
}
.dark\:data-\[state\=active\]\:text-foreground {
  &:is(.dark *) {
    &[data-state="active"] {
      color: var(--foreground);
    }
  }
}
.dark\:data-\[state\=checked\]\:bg-primary {
  &:is(.dark *) {
    &[data-state="checked"] {
      background-color: var(--primary);
    }
  }
}
.dark\:data-\[state\=checked\]\:bg-primary-foreground {
  &:is(.dark *) {
    &[data-state="checked"] {
      background-color: var(--primary-foreground);
    }
  }
}
.dark\:data-\[state\=unchecked\]\:bg-card-foreground {
  &:is(.dark *) {
    &[data-state="unchecked"] {
      background-color: var(--card-foreground);
    }
  }
}
.dark\:data-\[state\=unchecked\]\:bg-input\/80 {
  &:is(.dark *) {
    &[data-state="unchecked"] {
      background-color: var(--input);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--input) 80%, transparent);
      }
    }
  }
}
.dark\:data-\[variant\=destructive\]\:focus\:bg-destructive\/20 {
  &:is(.dark *) {
    &[data-variant="destructive"] {
      &:focus {
        background-color: var(--destructive);
        @supports (color: color-mix(in lab, red, red)) {
          background-color: color-mix(in oklab, var(--destructive) 20%, transparent);
        }
      }
    }
  }
}
.\[\&_\.recharts-cartesian-axis-tick_text\]\:fill-muted-foreground {
  & .recharts-cartesian-axis-tick text {
    fill: var(--muted-foreground);
  }
}
.\[\&_\.recharts-cartesian-grid_line\[stroke\=\'\#ccc\'\]\]\:stroke-border\/50 {
  & .recharts-cartesian-grid line[stroke='#ccc'] {
    stroke: var(--border);
    @supports (color: color-mix(in lab, red, red)) {
      stroke: color-mix(in oklab, var(--border) 50%, transparent);
    }
  }
}
.\[\&_\.recharts-curve\.recharts-tooltip-cursor\]\:stroke-border {
  & .recharts-curve.recharts-tooltip-cursor {
    stroke: var(--border);
  }
}
.\[\&_\.recharts-dot\[stroke\=\'\#fff\'\]\]\:stroke-transparent {
  & .recharts-dot[stroke='#fff'] {
    stroke: transparent;
  }
}
.\[\&_\.recharts-layer\]\:outline-hidden {
  & .recharts-layer {
    --tw-outline-style: none;
    outline-style: none;
    @media (forced-colors: active) {
      outline: 2px solid transparent;
      outline-offset: 2px;
    }
  }
}
.\[\&_\.recharts-polar-grid_\[stroke\=\'\#ccc\'\]\]\:stroke-border {
  & .recharts-polar-grid [stroke='#ccc'] {
    stroke: var(--border);
  }
}
.\[\&_\.recharts-radial-bar-background-sector\]\:fill-muted {
  & .recharts-radial-bar-background-sector {
    fill: var(--muted);
  }
}
.\[\&_\.recharts-rectangle\.recharts-tooltip-cursor\]\:fill-muted {
  & .recharts-rectangle.recharts-tooltip-cursor {
    fill: var(--muted);
  }
}
.\[\&_\.recharts-reference-line_\[stroke\=\'\#ccc\'\]\]\:stroke-border {
  & .recharts-reference-line [stroke='#ccc'] {
    stroke: var(--border);
  }
}
.\[\&_\.recharts-sector\]\:outline-hidden {
  & .recharts-sector {
    --tw-outline-style: none;
    outline-style: none;
    @media (forced-colors: active) {
      outline: 2px solid transparent;
      outline-offset: 2px;
    }
  }
}
.\[\&_\.recharts-sector\[stroke\=\'\#fff\'\]\]\:stroke-transparent {
  & .recharts-sector[stroke='#fff'] {
    stroke: transparent;
  }
}
.\[\&_\.recharts-surface\]\:outline-hidden {
  & .recharts-surface {
    --tw-outline-style: none;
    outline-style: none;
    @media (forced-colors: active) {
      outline: 2px solid transparent;
      outline-offset: 2px;
    }
  }
}
.\[\&_\[cmdk-group-heading\]\]\:px-2 {
  & [cmdk-group-heading] {
    padding-inline: calc(var(--spacing) * 2);
  }
}
.\[\&_\[cmdk-group-heading\]\]\:py-1\.5 {
  & [cmdk-group-heading] {
    padding-block: calc(var(--spacing) * 1.5);
  }
}
.\[\&_\[cmdk-group-heading\]\]\:text-xs {
  & [cmdk-group-heading] {
    font-size: var(--text-xs);
    line-height: var(--tw-leading, var(--text-xs--line-height));
  }
}
.\[\&_\[cmdk-group-heading\]\]\:font-medium {
  & [cmdk-group-heading] {
    --tw-font-weight: var(--font-weight-medium);
    font-weight: var(--font-weight-medium);
  }
}
.\[\&_\[cmdk-group-heading\]\]\:text-muted-foreground {
  & [cmdk-group-heading] {
    color: var(--muted-foreground);
  }
}
.\[\&_\[cmdk-group\]\]\:px-2 {
  & [cmdk-group] {
    padding-inline: calc(var(--spacing) * 2);
  }
}
.\[\&_\[cmdk-group\]\:not\(\[hidden\]\)_\~\[cmdk-group\]\]\:pt-0 {
  & [cmdk-group]:not([hidden]) ~[cmdk-group] {
    padding-top: calc(var(--spacing) * 0);
  }
}
.\[\&_\[cmdk-input-wrapper\]_svg\]\:h-5 {
  & [cmdk-input-wrapper] svg {
    height: calc(var(--spacing) * 5);
  }
}
.\[\&_\[cmdk-input-wrapper\]_svg\]\:w-5 {
  & [cmdk-input-wrapper] svg {
    width: calc(var(--spacing) * 5);
  }
}
.\[\&_\[cmdk-input\]\]\:h-12 {
  & [cmdk-input] {
    height: calc(var(--spacing) * 12);
  }
}
.\[\&_\[cmdk-item\]\]\:px-2 {
  & [cmdk-item] {
    padding-inline: calc(var(--spacing) * 2);
  }
}
.\[\&_\[cmdk-item\]\]\:py-3 {
  & [cmdk-item] {
    padding-block: calc(var(--spacing) * 3);
  }
}
.\[\&_\[cmdk-item\]_svg\]\:h-5 {
  & [cmdk-item] svg {
    height: calc(var(--spacing) * 5);
  }
}
.\[\&_\[cmdk-item\]_svg\]\:w-5 {
  & [cmdk-item] svg {
    width: calc(var(--spacing) * 5);
  }
}
.\[\&_p\]\:leading-relaxed {
  & p {
    --tw-leading: var(--leading-relaxed);
    line-height: var(--leading-relaxed);
  }
}
.\[\&_svg\]\:pointer-events-none {
  & svg {
    pointer-events: none;
  }
}
.\[\&_svg\]\:shrink-0 {
  & svg {
    flex-shrink: 0;
  }
}
.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-4 {
  & svg:not([class*='size-']) {
    width: calc(var(--spacing) * 4);
    height: calc(var(--spacing) * 4);
  }
}
.\[\&_svg\:not\(\[class\*\=\'text-\'\]\)\]\:text-muted-foreground {
  & svg:not([class*='text-']) {
    color: var(--muted-foreground);
  }
}
.\[\&_tr\]\:border-b {
  & tr {
    border-bottom-style: var(--tw-border-style);
    border-bottom-width: 1px;
  }
}
.\[\&_tr\:last-child\]\:border-0 {
  & tr:last-child {
    border-style: var(--tw-border-style);
    border-width: 0px;
  }
}
.\[\&\:has\(\>\.day-range-end\)\]\:rounded-r-md {
  &:has(>.day-range-end) {
    border-top-right-radius: calc(var(--radius) - 2px);
    border-bottom-right-radius: calc(var(--radius) - 2px);
  }
}
.\[\&\:has\(\>\.day-range-start\)\]\:rounded-l-md {
  &:has(>.day-range-start) {
    border-top-left-radius: calc(var(--radius) - 2px);
    border-bottom-left-radius: calc(var(--radius) - 2px);
  }
}
.\[\&\:has\(\[aria-selected\]\)\]\:rounded-md {
  &:has([aria-selected]) {
    border-radius: calc(var(--radius) - 2px);
  }
}
.\[\&\:has\(\[aria-selected\]\)\]\:bg-accent {
  &:has([aria-selected]) {
    background-color: var(--accent);
  }
}
.first\:\[\&\:has\(\[aria-selected\]\)\]\:rounded-l-md {
  &:first-child {
    &:has([aria-selected]) {
      border-top-left-radius: calc(var(--radius) - 2px);
      border-bottom-left-radius: calc(var(--radius) - 2px);
    }
  }
}
.last\:\[\&\:has\(\[aria-selected\]\)\]\:rounded-r-md {
  &:last-child {
    &:has([aria-selected]) {
      border-top-right-radius: calc(var(--radius) - 2px);
      border-bottom-right-radius: calc(var(--radius) - 2px);
    }
  }
}
.\[\&\:has\(\[aria-selected\]\.day-range-end\)\]\:rounded-r-md {
  &:has([aria-selected].day-range-end) {
    border-top-right-radius: calc(var(--radius) - 2px);
    border-bottom-right-radius: calc(var(--radius) - 2px);
  }
}
.\[\&\:has\(\[role\=checkbox\]\)\]\:pr-0 {
  &:has([role=checkbox]) {
    padding-right: calc(var(--spacing) * 0);
  }
}
.\[\.border-b\]\:pb-6 {
  &:is(.border-b) {
    padding-bottom: calc(var(--spacing) * 6);
  }
}
.\[\.border-t\]\:pt-6 {
  &:is(.border-t) {
    padding-top: calc(var(--spacing) * 6);
  }
}
.\*\:\[span\]\:last\:flex {
  :is(& > *) {
    &:is(span) {
      &:last-child {
        display: flex;
      }
    }
  }
}
.\*\:\[span\]\:last\:items-center {
  :is(& > *) {
    &:is(span) {
      &:last-child {
        align-items: center;
      }
    }
  }
}
.\*\:\[span\]\:last\:gap-2 {
  :is(& > *) {
    &:is(span) {
      &:last-child {
        gap: calc(var(--spacing) * 2);
      }
    }
  }
}
.data-\[variant\=destructive\]\:\*\:\[svg\]\:\!text-destructive {
  &[data-variant="destructive"] {
    :is(& > *) {
      &:is(svg) {
        color: var(--destructive) !important;
      }
    }
  }
}
.\[\&\:last-child\]\:pb-6 {
  &:last-child {
    padding-bottom: calc(var(--spacing) * 6);
  }
}
.\[\&\>\[role\=checkbox\]\]\:translate-y-\[2px\] {
  &>[role=checkbox] {
    --tw-translate-y: 2px;
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
}
.\[\&\>button\]\:hidden {
  &>button {
    display: none;
  }
}
.\[\&\>span\:last-child\]\:truncate {
  &>span:last-child {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
}
.\[\&\>svg\]\:pointer-events-none {
  &>svg {
    pointer-events: none;
  }
}
.\[\&\>svg\]\:size-3 {
  &>svg {
    width: calc(var(--spacing) * 3);
    height: calc(var(--spacing) * 3);
  }
}
.\[\&\>svg\]\:size-3\.5 {
  &>svg {
    width: calc(var(--spacing) * 3.5);
    height: calc(var(--spacing) * 3.5);
  }
}
.\[\&\>svg\]\:size-4 {
  &>svg {
    width: calc(var(--spacing) * 4);
    height: calc(var(--spacing) * 4);
  }
}
.\[\&\>svg\]\:h-2\.5 {
  &>svg {
    height: calc(var(--spacing) * 2.5);
  }
}
.\[\&\>svg\]\:h-3 {
  &>svg {
    height: calc(var(--spacing) * 3);
  }
}
.\[\&\>svg\]\:w-2\.5 {
  &>svg {
    width: calc(var(--spacing) * 2.5);
  }
}
.\[\&\>svg\]\:w-3 {
  &>svg {
    width: calc(var(--spacing) * 3);
  }
}
.\[\&\>svg\]\:shrink-0 {
  &>svg {
    flex-shrink: 0;
  }
}
.\[\&\>svg\]\:translate-y-0\.5 {
  &>svg {
    --tw-translate-y: calc(var(--spacing) * 0.5);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
}
.\[\&\>svg\]\:text-current {
  &>svg {
    color: currentcolor;
  }
}
.\[\&\>svg\]\:text-muted-foreground {
  &>svg {
    color: var(--muted-foreground);
  }
}
.\[\&\>svg\]\:text-sidebar-accent-foreground {
  &>svg {
    color: var(--sidebar-accent-foreground);
  }
}
.\[\&\>tr\]\:last\:border-b-0 {
  &>tr {
    &:last-child {
      border-bottom-style: var(--tw-border-style);
      border-bottom-width: 0px;
    }
  }
}
.\[\&\[data-panel-group-direction\=vertical\]\>div\]\:rotate-90 {
  &[data-panel-group-direction=vertical]>div {
    rotate: 90deg;
  }
}
.\[\&\[data-state\=open\]\>svg\]\:rotate-180 {
  &[data-state=open]>svg {
    rotate: 180deg;
  }
}
.\[\[data-side\=left\]\[data-collapsible\=offcanvas\]_\&\]\:-right-2 {
  [data-side=left][data-collapsible=offcanvas] & {
    right: calc(var(--spacing) * -2);
  }
}
.\[\[data-side\=left\]\[data-state\=collapsed\]_\&\]\:cursor-e-resize {
  [data-side=left][data-state=collapsed] & {
    cursor: e-resize;
  }
}
.\[\[data-side\=right\]\[data-collapsible\=offcanvas\]_\&\]\:-left-2 {
  [data-side=right][data-collapsible=offcanvas] & {
    left: calc(var(--spacing) * -2);
  }
}
.\[\[data-side\=right\]\[data-state\=collapsed\]_\&\]\:cursor-w-resize {
  [data-side=right][data-state=collapsed] & {
    cursor: w-resize;
  }
}
.\[a\&\]\:hover\:bg-accent {
  a& {
    &:hover {
      @media (hover: hover) {
        background-color: var(--accent);
      }
    }
  }
}
.\[a\&\]\:hover\:bg-destructive\/90 {
  a& {
    &:hover {
      @media (hover: hover) {
        background-color: var(--destructive);
        @supports (color: color-mix(in lab, red, red)) {
          background-color: color-mix(in oklab, var(--destructive) 90%, transparent);
        }
      }
    }
  }
}
.\[a\&\]\:hover\:bg-primary\/90 {
  a& {
    &:hover {
      @media (hover: hover) {
        background-color: var(--primary);
        @supports (color: color-mix(in lab, red, red)) {
          background-color: color-mix(in oklab, var(--primary) 90%, transparent);
        }
      }
    }
  }
}
.\[a\&\]\:hover\:bg-secondary\/90 {
  a& {
    &:hover {
      @media (hover: hover) {
        background-color: var(--secondary);
        @supports (color: color-mix(in lab, red, red)) {
          background-color: color-mix(in oklab, var(--secondary) 90%, transparent);
        }
      }
    }
  }
}
.\[a\&\]\:hover\:text-accent-foreground {
  a& {
    &:hover {
      @media (hover: hover) {
        color: var(--accent-foreground);
      }
    }
  }
}
}

/* ----- Custom property definitions (@property) ----- */
@property --tw-animation-delay { syntax: "*"; inherits: false; initial-value: 0s; }
@property --tw-animation-direction { syntax: "*"; inherits: false; initial-value: normal; }
@property --tw-animation-duration { syntax: "*"; inherits: false; }
@property --tw-animation-fill-mode { syntax: "*"; inherits: false; initial-value: none; }
@property --tw-animation-iteration-count { syntax: "*"; inherits: false; initial-value: 1; }
@property --tw-enter-blur { syntax: "*"; inherits: false; initial-value: 0; }
@property --tw-enter-opacity { syntax: "*"; inherits: false; initial-value: 1; }
@property --tw-enter-rotate { syntax: "*"; inherits: false; initial-value: 0; }
@property --tw-enter-scale { syntax: "*"; inherits: false; initial-value: 1; }
@property --tw-enter-translate-x { syntax: "*"; inherits: false; initial-value: 0; }
@property --tw-enter-translate-y { syntax: "*"; inherits: false; initial-value: 0; }
@property --tw-exit-blur { syntax: "*"; inherits: false; initial-value: 0; }
@property --tw-exit-opacity { syntax: "*"; inherits: false; initial-value: 1; }
@property --tw-exit-rotate { syntax: "*"; inherits: false; initial-value: 0; }
@property --tw-exit-scale { syntax: "*"; inherits: false; initial-value: 1; }
@property --tw-exit-translate-x { syntax: "*"; inherits: false; initial-value: 0; }
@property --tw-exit-translate-y { syntax: "*"; inherits: false; initial-value: 0; }

/* ----- Theme variables (light) ----- */
:root {
  --font-size: 17px; --background: #ffffff; --foreground: oklch(0.145 0 0); --card: #ffffff; --card-foreground: oklch(0.145 0 0); --popover: oklch(1 0 0); --popover-foreground: oklch(0.145 0 0); --primary: #030213; --primary-foreground: oklch(1 0 0); --secondary: oklch(0.95 0.0058 264.53); --secondary-foreground: #030213; --muted: #ececf0; --muted-foreground: #717182; --accent: #e9ebef; --accent-foreground: #030213; --destructive: #d4183d; --destructive-foreground: #ffffff; --border: rgba(0, 0, 0, 0.1); --input: transparent; --input-background: #f3f3f5; --switch-background: #cbced4; --font-weight-medium: 500; --font-weight-normal: 400; --ring: oklch(0.708 0 0); --chart-1: oklch(0.646 0.222 41.116); --chart-2: oklch(0.6 0.118 184.704); --chart-3: oklch(0.398 0.07 227.392); --chart-4: oklch(0.828 0.189 84.429); --chart-5: oklch(0.769 0.188 70.08); --radius: 0.625rem; --sidebar: oklch(0.985 0 0); --sidebar-foreground: oklch(0.145 0 0); --sidebar-primary: #030213; --sidebar-primary-foreground: oklch(0.985 0 0); --sidebar-accent: oklch(0.97 0 0); --sidebar-accent-foreground: oklch(0.205 0 0); --sidebar-border: oklch(0.922 0 0); --sidebar-ring: oklch(0.708 0 0);
}

/* ----- Theme variables (dark) ----- */
.dark {
  --background: oklch(0.145 0 0); --foreground: oklch(0.985 0 0); --card: oklch(0.145 0 0); --card-foreground: oklch(0.985 0 0); --popover: oklch(0.145 0 0); --popover-foreground: oklch(0.985 0 0); --primary: oklch(0.985 0 0); --primary-foreground: oklch(0.205 0 0); --secondary: oklch(0.269 0 0); --secondary-foreground: oklch(0.985 0 0); --muted: oklch(0.269 0 0); --muted-foreground: oklch(0.708 0 0); --accent: oklch(0.269 0 0); --accent-foreground: oklch(0.985 0 0); --destructive: oklch(0.396 0.141 25.723); --destructive-foreground: oklch(0.637 0.237 25.331); --border: oklch(0.269 0 0); --input: oklch(0.269 0 0); --ring: oklch(0.439 0 0); --font-weight-medium: 500; --font-weight-normal: 400; --chart-1: oklch(0.488 0.243 264.376); --chart-2: oklch(0.696 0.17 162.48); --chart-3: oklch(0.769 0.188 70.08); --chart-4: oklch(0.627 0.265 303.9); --chart-5: oklch(0.645 0.246 16.439); --sidebar: oklch(0.205 0 0); --sidebar-foreground: oklch(0.985 0 0); --sidebar-primary: oklch(0.488 0.243 264.376); --sidebar-primary-foreground: oklch(0.985 0 0); --sidebar-accent: oklch(0.269 0 0); --sidebar-accent-foreground: oklch(0.985 0 0); --sidebar-border: oklch(0.269 0 0); --sidebar-ring: oklch(0.439 0 0);
}

/* ----- Base overrides (body, typography, form) ----- */
@layer base {
  * { border-color: var(--border); outline-color: var(--ring); @supports (color: color-mix(in lab, red, red)) { outline-color: color-mix(in oklab, var(--ring) 50%, transparent); } }
  body { background-color: var(--background); color: var(--foreground); }
  html { font-size: var(--font-size); }
  h1, h2, h3, h4, label, button, input { line-height: 1.5; }
  h1 { font-size: var(--text-2xl); font-weight: var(--font-weight-medium); }
  h2 { font-size: var(--text-xl); font-weight: var(--font-weight-medium); }
  h3 { font-size: var(--text-lg); font-weight: var(--font-weight-medium); }
  h4, label, button { font-size: var(--text-base); font-weight: var(--font-weight-medium); }
  input { font-size: var(--text-base); font-weight: var(--font-weight-normal); }
}
@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-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-gradient-position { syntax: "*"; inherits: false; }
@property --tw-gradient-from { syntax: "<color>"; inherits: false; initial-value: #0000; }
@property --tw-gradient-via { syntax: "<color>"; inherits: false; initial-value: #0000; }
@property --tw-gradient-to { syntax: "<color>"; 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: "<length-percentage>"; inherits: false; initial-value: 0%; }
@property --tw-gradient-via-position { syntax: "<length-percentage>"; inherits: false; initial-value: 50%; }
@property --tw-gradient-to-position { syntax: "<length-percentage>"; 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-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: "<percentage>"; 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: "<percentage>"; 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: "<length>"; inherits: false; initial-value: 0px; }
@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-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; }
@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-content { syntax: "*"; initial-value: ""; inherits: false; }

/* ----- Keyframes ----- */
@keyframes pulse { 50% { opacity: 0.5; } }
@keyframes enter { from { opacity: var(--tw-enter-opacity,1); transform: translate3d(var(--tw-enter-translate-x,0),var(--tw-enter-translate-y,0),0)scale3d(var(--tw-enter-scale,1),var(--tw-enter-scale,1),var(--tw-enter-scale,1))rotate(var(--tw-enter-rotate,0)); filter: blur(var(--tw-enter-blur,0)); } }
@keyframes exit { to { opacity: var(--tw-exit-opacity,1); transform: translate3d(var(--tw-exit-translate-x,0),var(--tw-exit-translate-y,0),0)scale3d(var(--tw-exit-scale,1),var(--tw-exit-scale,1),var(--tw-exit-scale,1))rotate(var(--tw-exit-rotate,0)); filter: blur(var(--tw-exit-blur,0)); } }
@keyframes accordion-down { from { height: 0; } to { height: var(--radix-accordion-content-height,var(--bits-accordion-content-height,var(--reka-accordion-content-height,var(--kb-accordion-content-height,var(--ngp-accordion-content-height,auto))))); } }
@keyframes accordion-up { from { height: var(--radix-accordion-content-height,var(--bits-accordion-content-height,var(--reka-accordion-content-height,var(--kb-accordion-content-height,var(--ngp-accordion-content-height,auto))))); } to { height: 0; } }
@keyframes caret-blink { 0%,70%,100% { opacity: 1; } 20%,50% { opacity: 0; } }
@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-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-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-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-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;
    --tw-scale-x: 1;
    --tw-scale-y: 1;
    --tw-scale-z: 1;
    --tw-content: "";
    --tw-animation-delay: 0s;
    --tw-animation-direction: normal;
    --tw-animation-duration: initial;
    --tw-animation-fill-mode: none;
    --tw-animation-iteration-count: 1;
    --tw-enter-blur: 0;
    --tw-enter-opacity: 1;
    --tw-enter-rotate: 0;
    --tw-enter-scale: 1;
    --tw-enter-translate-x: 0;
    --tw-enter-translate-y: 0;
    --tw-exit-blur: 0;
    --tw-exit-opacity: 1;
    --tw-exit-rotate: 0;
    --tw-exit-scale: 1;
    --tw-exit-translate-x: 0;
    --tw-exit-translate-y: 0;
  }
}
}

/* ----- Scrollbar utility ----- */
.scrollbar-hide { -ms-overflow-style: none; scrollbar-width: none; }
.scrollbar-hide::-webkit-scrollbar { display: none; }

/* ==========================================================================
   Page layout – index.html overrides
   ========================================================================== */
.sticky-header { position: sticky; top: 0; z-index: 50; background-color: white; }
.header-toggle span { font-size: 1.5rem; line-height: 1; }

/* Section anchor scroll offset */
#projects, #skills, #life { scroll-margin-top: 5rem; }

/* Key Skills: bullet list */
.skill-list { list-style: disc; padding-left: 1.25rem; min-height: 2.5rem; }
.skill-list li { margin-bottom: 0.25rem; }
.skill-list li:last-child { margin-bottom: 0; }

/* Let's Connect: push right on desktop */
.connect-section { padding-left: 0; }
@media (min-width: 768px) { .connect-section { padding-left: 10rem; } }

/* Biography title: one line on desktop, wrap on mobile */
@media (min-width: 768px) { .bio-heading { white-space: nowrap; } }

.life-caption { font-size: 0.875rem; }

/* Featured project card */
.project-card-cover { line-height: 0; font-size: 0; }
.project-card-cover img { width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; }
@media (min-width: 768px) {
  .project-card-cover { width: 26%; flex: 0 0 26%; align-self: stretch; }
  .project-card-cover img { min-width: 100%; min-height: 100%; }
  .project-card-content { padding: 1.25rem 1.5rem; }
}
.project-card-content { padding: 1rem 1.25rem; min-width: 0; }

.shadow-right { box-shadow: 4px 0 10px -2px rgba(0, 0, 0, 0.08), 0 1px 3px 0 rgba(0, 0, 0, 0.1); }

.whatido-card { flex: 1 1 0; min-width: 260px; display: flex; flex-direction: column; }
.whatido-card p { flex: 1; }

/* ==========================================================================
   Project page (project_steam.html)
   ========================================================================== */
.project-page { min-height: 100vh; background-color: #fff; color: #111827; }
.project-page ::selection { background-color: rgba(152, 193, 217, 0.3); color: #3d5a80; }

.project-header { background-color: rgba(255, 255, 255, 0.9); backdrop-filter: blur(8px); border-bottom: 1px solid #f3f4f6; }
.project-header .nav-inner { display: flex; align-items: center; justify-content: space-between; padding: 1rem; max-width: 64rem; margin: 0 auto; }
.project-header__top { display: flex; align-items: center; justify-content: space-between; width: 100%; gap: 1rem; }
.project-header .brand { font-size: 1.25rem; font-weight: 700; color: #111827; letter-spacing: -0.025em; }
.project-header .nav-links { display: none; gap: 1.5rem; font-size: 0.875rem; font-weight: 500; color: #4b5563; }
.project-header .nav-toggle { display: inline-flex; align-items: center; justify-content: center; padding: 0.5rem; border-radius: 0.375rem; color: #374151; }
.project-header .nav-toggle:hover { color: #ee6c4d; background-color: #f3f4f6; }
.project-header .mobile-menu { max-width: 64rem; margin: 0 auto; padding: 0 1rem 1rem; }
.project-header .mobile-menu a { display: block; padding: 0.25rem 0; font-size: 0.875rem; font-weight: 500; color: #374151; }
.project-header .nav-links a:hover,
.project-header .mobile-menu a:hover { color: #ee6c4d; }

@media (min-width: 768px) {
  .project-header__top { width: auto; }
  .project-header .nav-inner { padding-left: 2rem; padding-right: 2rem; }
  .project-header .nav-links { display: flex; }
  .project-header .nav-toggle { display: none; }
}

.project-footer { padding: 2rem 0; border-top: 1px solid #f3f4f6; background-color: #f9fafb; }
.project-footer .footer-inner { max-width: 64rem; margin: 0 auto; padding: 0 1rem; display: flex; flex-direction: column; justify-content: space-between; align-items: center; gap: 1rem; }
.project-footer .footer-brand { font-size: 1.25rem; font-weight: 700; color: #6b7280; }
.project-footer .footer-links { display: flex; gap: 1.5rem; font-size: 0.875rem; color: #6b7280; }
.project-footer .footer-links a:hover { color: #ee6c4d; }
.project-footer .footer-copy { color: #9ca3af; font-size: 0.75rem; }
@media (min-width: 768px) {
  .project-footer .footer-inner { flex-direction: row; padding-left: 2rem; padding-right: 2rem; }
}

/* Project article & highlight (shared box + spacing) */
.project-highlight { margin: 3rem 0; padding: 1.5rem; border-radius: 1rem; border: 1px solid #f3f4f6; background-color: rgba(249, 250, 251, 0.8); }
.project-highlight h2 { font-size: 1.125rem; font-weight: 700; color: #ee6c4d; margin-bottom: 0.75rem; }
.project-highlight p, .project-highlight li { color: #4b5563; line-height: 1.625; }
.project-highlight-list { list-style: disc; padding-left: 1.25rem; margin: 0; }
.project-highlight-list li { margin-bottom: 0.75rem; }
.project-highlight-list li:last-child { margin-bottom: 0; }
@media (min-width: 768px) { .project-highlight { padding: 2rem; } }

.project-article { padding: 2.5rem 1rem; max-width: 64rem; margin: 0 auto; }
.project-article__header { margin-bottom: 2rem; }
.project-meta { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 0.5rem; margin-bottom: 0.75rem; }
.project-tag { font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; color: #3d5a80; background-color: rgba(152, 193, 217, 0.2); padding: 0.25rem 0.5rem; border-radius: 0.375rem; }
.project-date { font-size: 0.75rem; color: #6b7280; }
.project-title { font-size: 1.875rem; font-weight: 800; color: #111827; line-height: 1.25; margin-bottom: 0.75rem; }
.project-hashtags { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.project-hashtag { font-size: 0.75rem; font-weight: 500; color: #9ca3af; }
.project-figure { margin-bottom: 2.5rem; max-width: 60rem; margin-left: auto; margin-right: auto; border-radius: 1rem; overflow: hidden; border: 1px solid #f3f4f6; box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1); background-color: #f3f4f6; }
.project-figure img { width: 100%; height: auto; object-fit: cover; max-height: 16rem; }
.project-subtitle { font-size: 1.125rem; font-weight: 700; color: #3d5a80; margin-bottom: 1rem; }

.project-prose, .project-extra { color: #4b5563; line-height: 1.625; max-width: 60rem; }
.project-prose p + p, .project-extra p + p { margin-top: 1.5rem; }
.project-prose p:first-child { margin-top: 0; }
.project-prose .project-subtitle { margin-top: 1.5rem; margin-bottom: 0.5rem; }
.project-prose .project-subtitle:first-child { margin-top: 0; }
.project-extra { margin-top: 2.5rem; }
.project-extra-label { font-weight: 600; color: #4b5563; margin-bottom: 0.5rem; }
.project-extra-list { margin: 0 0 0 1.25rem; padding-left: 0.25rem; color: #4b5563; line-height: 1.625; }
.project-extra-list li { margin-bottom: 0.5rem; }
.project-extra-list a { color: #3d5a80; text-decoration: underline; }
.project-extra-list a:hover { color: #ee6c4d; }

@media (min-width: 768px) {
  .project-article { padding-left: 2rem; padding-right: 2rem; }
  .project-title { font-size: 2.25rem; }
}
