/*! tailwindcss v4.1.18 | MIT License | https://tailwindcss.com */
@layer properties;
@layer theme, base, components, utilities;
@layer theme {
  :root, :host {
    --font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono",
      "Courier New", monospace;
    --spacing: 0.25rem;
    --container-md: 28rem;
    --container-lg: 32rem;
    --container-2xl: 42rem;
    --container-6xl: 72rem;
    --container-7xl: 80rem;
    --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-4xl: 2.25rem;
    --text-4xl--line-height: calc(2.5 / 2.25);
    --text-5xl: 3rem;
    --text-5xl--line-height: 1;
    --text-6xl: 3.75rem;
    --text-6xl--line-height: 1;
    --text-7xl: 4.5rem;
    --text-7xl--line-height: 1;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --radius-lg: 0.5rem;
    --ease-out: cubic-bezier(0, 0, 0.2, 1);
    --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-bg-primary: #fafaf9;
    --color-bg-secondary: #ffffff;
    --color-text-primary: #1c1917;
    --color-text-secondary: #57534e;
    --color-accent-green: #059669;
    --color-muted: #94a3b8;
  }
}
@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;
    vertical-align: middle;
  }
  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;
  }
}
@layer utilities {
  .visible {
    visibility: visible;
  }
  .sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip-path: inset(50%);
    white-space: nowrap;
    border-width: 0;
  }
  .absolute {
    position: absolute;
  }
  .fixed {
    position: fixed;
  }
  .relative {
    position: relative;
  }
  .static {
    position: static;
  }
  .top-0 {
    top: calc(var(--spacing) * 0);
  }
  .right-4 {
    right: calc(var(--spacing) * 4);
  }
  .bottom-4 {
    bottom: calc(var(--spacing) * 4);
  }
  .left-0 {
    left: calc(var(--spacing) * 0);
  }
  .left-4 {
    left: calc(var(--spacing) * 4);
  }
  .z-50 {
    z-index: 50;
  }
  .order-1 {
    order: 1;
  }
  .order-2 {
    order: 2;
  }
  .order-3 {
    order: 3;
  }
  .container {
    width: 100%;
    @media (width >= 40rem) {
      max-width: 40rem;
    }
    @media (width >= 48rem) {
      max-width: 48rem;
    }
    @media (width >= 64rem) {
      max-width: 64rem;
    }
    @media (width >= 80rem) {
      max-width: 80rem;
    }
    @media (width >= 96rem) {
      max-width: 96rem;
    }
  }
  .mx-auto {
    margin-inline: auto;
  }
  .my-12 {
    margin-block: calc(var(--spacing) * 12);
  }
  .mt-2 {
    margin-top: calc(var(--spacing) * 2);
  }
  .mb-2 {
    margin-bottom: calc(var(--spacing) * 2);
  }
  .mb-4 {
    margin-bottom: calc(var(--spacing) * 4);
  }
  .mb-6 {
    margin-bottom: calc(var(--spacing) * 6);
  }
  .mb-8 {
    margin-bottom: calc(var(--spacing) * 8);
  }
  .mb-12 {
    margin-bottom: calc(var(--spacing) * 12);
  }
  .block {
    display: block;
  }
  .flex {
    display: flex;
  }
  .grid {
    display: grid;
  }
  .hidden {
    display: none;
  }
  .inline-flex {
    display: inline-flex;
  }
  .h-64 {
    height: calc(var(--spacing) * 64);
  }
  .h-\[80px\] {
    height: 80px;
  }
  .h-full {
    height: 100%;
  }
  .min-h-80 {
    min-height: calc(var(--spacing) * 80);
  }
  .min-h-screen {
    min-height: 100vh;
  }
  .w-\[60px\] {
    width: 60px;
  }
  .w-\[90\%\] {
    width: 90%;
  }
  .w-full {
    width: 100%;
  }
  .max-w-2xl {
    max-width: var(--container-2xl);
  }
  .max-w-6xl {
    max-width: var(--container-6xl);
  }
  .max-w-7xl {
    max-width: var(--container-7xl);
  }
  .max-w-lg {
    max-width: var(--container-lg);
  }
  .max-w-md {
    max-width: var(--container-md);
  }
  .flex-1 {
    flex: 1;
  }
  .flex-2 {
    flex: 2;
  }
  .shrink-0 {
    flex-shrink: 0;
  }
  .transform {
    transform: var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,);
  }
  .cursor-pointer {
    cursor: pointer;
  }
  .resize {
    resize: both;
  }
  .grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .flex-col {
    flex-direction: column;
  }
  .flex-wrap {
    flex-wrap: wrap;
  }
  .items-center {
    align-items: center;
  }
  .justify-between {
    justify-content: space-between;
  }
  .justify-center {
    justify-content: center;
  }
  .justify-evenly {
    justify-content: space-evenly;
  }
  .justify-start {
    justify-content: flex-start;
  }
  .gap-2 {
    gap: calc(var(--spacing) * 2);
  }
  .gap-4 {
    gap: calc(var(--spacing) * 4);
  }
  .gap-6 {
    gap: calc(var(--spacing) * 6);
  }
  .gap-12 {
    gap: calc(var(--spacing) * 12);
  }
  .space-y-2 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .overflow-hidden {
    overflow: hidden;
  }
  .overflow-x-auto {
    overflow-x: auto;
  }
  .rounded-\[20px\] {
    border-radius: 20px;
  }
  .rounded-lg {
    border-radius: var(--radius-lg);
  }
  .border {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }
  .border-2 {
    border-style: var(--tw-border-style);
    border-width: 2px;
  }
  .border-accent-green {
    border-color: var(--color-accent-green);
  }
  .border-text-secondary\/20 {
    border-color: color-mix(in srgb, #57534e 20%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      border-color: color-mix(in oklab, var(--color-text-secondary) 20%, transparent);
    }
  }
  .bg-accent-green {
    background-color: var(--color-accent-green);
  }
  .bg-bg-secondary {
    background-color: var(--color-bg-secondary);
  }
  .bg-muted {
    background-color: var(--color-muted);
  }
  .bg-transparent {
    background-color: transparent;
  }
  .p-4 {
    padding: calc(var(--spacing) * 4);
  }
  .px-4 {
    padding-inline: calc(var(--spacing) * 4);
  }
  .px-6 {
    padding-inline: calc(var(--spacing) * 6);
  }
  .py-2 {
    padding-block: calc(var(--spacing) * 2);
  }
  .py-3 {
    padding-block: calc(var(--spacing) * 3);
  }
  .py-6 {
    padding-block: calc(var(--spacing) * 6);
  }
  .py-16 {
    padding-block: calc(var(--spacing) * 16);
  }
  .pt-20 {
    padding-top: calc(var(--spacing) * 20);
  }
  .text-center {
    text-align: center;
  }
  .text-left {
    text-align: left;
  }
  .text-right {
    text-align: right;
  }
  .font-mono {
    font-family: var(--font-mono);
  }
  .text-2xl {
    font-size: var(--text-2xl);
    line-height: var(--tw-leading, var(--text-2xl--line-height));
  }
  .text-3xl {
    font-size: var(--text-3xl);
    line-height: var(--tw-leading, var(--text-3xl--line-height));
  }
  .text-4xl {
    font-size: var(--text-4xl);
    line-height: var(--tw-leading, var(--text-4xl--line-height));
  }
  .text-5xl {
    font-size: var(--text-5xl);
    line-height: var(--tw-leading, var(--text-5xl--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-\[10px\] {
    font-size: 10px;
  }
  .font-bold {
    --tw-font-weight: var(--font-weight-bold);
    font-weight: var(--font-weight-bold);
  }
  .font-medium {
    --tw-font-weight: var(--font-weight-medium);
    font-weight: var(--font-weight-medium);
  }
  .font-semibold {
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
  }
  .text-accent-green {
    color: var(--color-accent-green);
  }
  .text-bg-primary {
    color: var(--color-bg-primary);
  }
  .text-text-primary {
    color: var(--color-text-primary);
  }
  .text-text-primary\/90 {
    color: color-mix(in srgb, #1c1917 90%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-text-primary) 90%, transparent);
    }
  }
  .text-text-secondary {
    color: var(--color-text-secondary);
  }
  .filter {
    filter: var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,);
  }
  .transition {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to, opacity, box-shadow, transform, translate, scale, rotate, filter, -webkit-backdrop-filter, backdrop-filter, display, content-visibility, overlay, pointer-events;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-all {
    transition-property: all;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-opacity {
    transition-property: opacity;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .duration-200 {
    --tw-duration: 200ms;
    transition-duration: 200ms;
  }
  .ease-out {
    --tw-ease: var(--ease-out);
    transition-timing-function: var(--ease-out);
  }
  .hover\:border-accent-green {
    &:hover {
      @media (hover: hover) {
        border-color: var(--color-accent-green);
      }
    }
  }
  .hover\:opacity-90 {
    &:hover {
      @media (hover: hover) {
        opacity: 90%;
      }
    }
  }
  .sm\:text-4xl {
    @media (width >= 40rem) {
      font-size: var(--text-4xl);
      line-height: var(--tw-leading, var(--text-4xl--line-height));
    }
  }
  .sm\:text-6xl {
    @media (width >= 40rem) {
      font-size: var(--text-6xl);
      line-height: var(--tw-leading, var(--text-6xl--line-height));
    }
  }
  .md\:order-2 {
    @media (width >= 48rem) {
      order: 2;
    }
  }
  .md\:order-3 {
    @media (width >= 48rem) {
      order: 3;
    }
  }
  .md\:flex-row {
    @media (width >= 48rem) {
      flex-direction: row;
    }
  }
  .md\:flex-wrap {
    @media (width >= 48rem) {
      flex-wrap: wrap;
    }
  }
  .md\:justify-center {
    @media (width >= 48rem) {
      justify-content: center;
    }
  }
  .md\:gap-16 {
    @media (width >= 48rem) {
      gap: calc(var(--spacing) * 16);
    }
  }
  .md\:py-40 {
    @media (width >= 48rem) {
      padding-block: calc(var(--spacing) * 40);
    }
  }
  .md\:pt-60 {
    @media (width >= 48rem) {
      padding-top: calc(var(--spacing) * 60);
    }
  }
  .md\:text-5xl {
    @media (width >= 48rem) {
      font-size: var(--text-5xl);
      line-height: var(--tw-leading, var(--text-5xl--line-height));
    }
  }
  .md\:text-6xl {
    @media (width >= 48rem) {
      font-size: var(--text-6xl);
      line-height: var(--tw-leading, var(--text-6xl--line-height));
    }
  }
  .md\:text-sm {
    @media (width >= 48rem) {
      font-size: var(--text-sm);
      line-height: var(--tw-leading, var(--text-sm--line-height));
    }
  }
  .lg\:grid-cols-4 {
    @media (width >= 64rem) {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }
  .lg\:flex-row {
    @media (width >= 64rem) {
      flex-direction: row;
    }
  }
  .lg\:items-start {
    @media (width >= 64rem) {
      align-items: flex-start;
    }
  }
  .lg\:justify-between {
    @media (width >= 64rem) {
      justify-content: space-between;
    }
  }
  .lg\:gap-6 {
    @media (width >= 64rem) {
      gap: calc(var(--spacing) * 6);
    }
  }
  .lg\:gap-16 {
    @media (width >= 64rem) {
      gap: calc(var(--spacing) * 16);
    }
  }
  .lg\:gap-20 {
    @media (width >= 64rem) {
      gap: calc(var(--spacing) * 20);
    }
  }
  .lg\:text-left {
    @media (width >= 64rem) {
      text-align: left;
    }
  }
  .lg\:text-7xl {
    @media (width >= 64rem) {
      font-size: var(--text-7xl);
      line-height: var(--tw-leading, var(--text-7xl--line-height));
    }
  }
}
.dark, [data-theme="dark"] {
  --color-bg-primary: #18181b;
  --color-bg-secondary: #09090b;
  --color-text-primary: #f4f4f5;
  --color-text-secondary: #a1a1aa;
  --color-accent-green: #10b981;
  --color-muted: #94a3b8;
}
@layer base {
  *, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
  }
  html {
    scroll-behavior: smooth;
    scroll-padding-top: 4rem;
    background-color: var(--color-bg-primary);
    background-image: linear-gradient(to right, rgba(255, 255, 255, 0.05) 1px, transparent 1px), linear-gradient(to bottom, rgba(255, 255, 255, 0.05) 1px, transparent 1px);
    background-size: 20px 20px;
  }
  section {
    margin-bottom: 4rem;
  }
}
body {
  font-family: var(--font-sans);
  background-color: transparent;
  color: var(--color-text-primary);
  text-align: left;
}
[data-reveal] {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 1s ease-out, transform 1s ease-out;
}
[data-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
  [data-reveal] {
    opacity: 1;
    transform: none;
    transition: none;
  }
}
.theme-toggle-icon-light {
  display: block;
}
.theme-toggle-icon-dark {
  display: none;
}
.dark .theme-toggle-icon-light {
  display: none;
}
.dark .theme-toggle-icon-dark {
  display: block;
}
#rotating-logo {
  position: fixed;
  width: 80px;
  height: 80px;
  z-index: 60;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: visible;
}
#rotating-logo a {
  display: block;
  width: 100%;
  height: 100%;
  color: var(--color-text-primary);
  transition: color 0.2s ease;
  overflow: visible;
}
#rotating-logo a:hover {
  color: var(--color-accent-green);
}
#rotating-logo svg {
  width: 100%;
  height: 100%;
  display: block;
  overflow: visible;
}
#rotating-logo #logo-rotatable {
  transform-origin: 50px 50px;
}
@media (max-width: 1023px) {
  #rotating-logo {
    width: 70px;
    height: 70px;
  }
}
@media (max-width: 767px) {
  #rotating-logo {
    width: 60px;
    height: 60px;
  }
}
@media (prefers-reduced-motion: reduce) {
  #rotating-logo #logo-rotatable {
    transform: none !important;
  }
}
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 50;
  padding: 0.75rem 1rem;
  background-color: transparent;
  transition: background-color 0.2s ease;
}
.site-header__inner {
  max-width: 72rem;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.site-header__logo {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  color: var(--color-text-primary);
  transition: color 0.2s ease;
}
.site-header__logo:hover {
  color: var(--color-accent-green);
}
.site-header__logo .logo {
  width: 100%;
  height: 100%;
  display: block;
}
@media (max-width: 767px) {
  .site-header__logo {
    width: 2rem;
    height: 2rem;
  }
}
.site-header__brand {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--color-text-primary);
  text-decoration: none;
  border: 1px solid color-mix(in srgb, #57534e 35%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    border: 1px solid color-mix(in oklab, var(--color-text-secondary) 35%, transparent);
  }
  background-color: color-mix(in srgb, #ffffff 95%, #1c1917);
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in oklab, var(--color-bg-secondary) 95%, var(--color-text-primary));
  }
  transition: border-color 0.2s ease, color 0.2s ease;
}
.site-header__brand:hover {
  border-color: var(--color-accent-green);
  color: var(--color-accent-green);
}
.site-nav {
  position: relative;
}
.site-nav__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
  gap: 0;
  padding: 0.25rem 0.5rem;
  border: 1px solid color-mix(in srgb, #57534e 25%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    border: 1px solid color-mix(in oklab, var(--color-text-secondary) 25%, transparent);
  }
  border-radius: 0.25rem;
  background-color: color-mix(in srgb, #ffffff 98%, #1c1917);
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in oklab, var(--color-bg-secondary) 98%, var(--color-text-primary));
  }
  box-shadow: 0 1px 0 0 color-mix(in oklab, white 15%, transparent);
}
.dark .site-nav__list {
  box-shadow: 0 1px 0 0 color-mix(in srgb, #1c1917 8%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    box-shadow: 0 1px 0 0 color-mix(in oklab, var(--color-text-primary) 8%, transparent);
  }
}
.site-nav__list li {
  position: relative;
}
.site-nav__list li + li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 1px;
  height: 0.75rem;
  background-color: color-mix(in srgb, #57534e 30%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in oklab, var(--color-text-secondary) 30%, transparent);
  }
}
.site-nav__link {
  display: block;
  padding: 0.4rem 0.65rem;
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--color-text-secondary);
  text-decoration: none;
  transition: color 0.2s ease, background-color 0.15s ease;
  border-radius: 0.125rem;
}
.site-nav__link:hover {
  color: var(--color-text-primary);
}
.site-nav__link:hover, .site-nav__link:focus-visible {
  color: var(--color-accent-green);
}
.site-nav__link:focus-visible {
  outline: 2px solid var(--color-accent-green);
  outline-offset: 2px;
}
.site-nav__toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 2.25rem;
  height: 2.25rem;
  padding: 0.35rem;
  border: 1px solid color-mix(in srgb, #57534e 30%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    border: 1px solid color-mix(in oklab, var(--color-text-secondary) 30%, transparent);
  }
  border-radius: 0.25rem;
  background-color: color-mix(in srgb, #ffffff 98%, #1c1917);
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in oklab, var(--color-bg-secondary) 98%, var(--color-text-primary));
  }
  color: var(--color-text-primary);
  cursor: pointer;
  transition: border-color 0.2s ease, background-color 0.2s ease;
}
.site-nav__toggle:hover {
  border-color: var(--color-accent-green);
}
.site-nav__toggle[aria-expanded="true"] {
  border-color: var(--color-accent-green);
  background-color: color-mix(in srgb, #059669 12%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in oklab, var(--color-accent-green) 12%, transparent);
  }
}
.site-nav__toggle-bar {
  display: block;
  width: 100%;
  height: 2px;
  background-color: currentColor;
  border-radius: 1px;
  transition: transform 0.25s ease, opacity 0.25s ease;
}
.site-nav__toggle[aria-expanded="true"] .site-nav__toggle-bar:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
.site-nav__toggle[aria-expanded="true"] .site-nav__toggle-bar:nth-child(2) {
  opacity: 0;
}
.site-nav__toggle[aria-expanded="true"] .site-nav__toggle-bar:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}
@media (max-width: 767px) {
  .site-nav__toggle {
    display: flex;
  }
  .site-nav__list {
    position: absolute;
    top: calc(100% + 0.5rem);
    right: 0;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    min-width: 12rem;
    padding: 0.35rem;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-4px);
    transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s ease;
  }
  .site-nav__list[data-open="true"] {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
  }
  .site-nav__list li + li::before {
    display: none;
  }
  .site-nav__list li + li {
    border-top: 1px solid color-mix(in srgb, #57534e 20%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      border-top: 1px solid color-mix(in oklab, var(--color-text-secondary) 20%, transparent);
    }
  }
  .site-nav__link {
    padding: 0.6rem 0.75rem;
    border-radius: 0.125rem;
  }
}
.site-main {
  padding-top: 4rem;
}
#hero, #contact {
  background-color: var(--color-bg-primary);
  background-size: 40px 40px, 40px 40px, 100% 100%;
}
.card-stack {
  display: flex;
  justify-content: center;
  position: relative;
  width: 100%;
}
.card {
  display: flex;
  flex-direction: column;
  justify-content: space-evenly;
  align-items: center;
  width: 100%;
  height: 200px;
  position: absolute;
  border-radius: 20px;
  padding: 10px;
  font-size: 16px;
  font-weight: 500;
  text-align: center;
  cursor: pointer;
  transition: all 1s cubic-bezier(0.23, 1, 0.32, 1);
  box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.1);
}
@media (max-width: 425px) {
  .card {
    height: 260px;
  }
}
.card:hover {
  transform: scale(1.1);
  box-shadow: 0 20px 25px -5px rgba(0,0,0,0.1);
}
.dark .card.bg-muted {
  background-color: #3f3f46;
}
.dark .card.bg-muted, .dark .card.bg-muted dd {
  color: #f4f4f5;
}
.active {
  z-index: 30;
  transform: translate(0, 0) scale(1);
  box-shadow: 0 20px 25px -5px rgba(0,0,0,0.1);
}
.next {
  z-index: 20;
  transform: translate(0px, 20px) scale(0.95);
  opacity: 0.7;
  box-shadow: 0 10px 10px -5px rgba(0,0,0,0.04);
}
.hidden-card {
  z-index: 10;
  transform: translate(0px, 40px) scale(0.9);
  opacity: 0.5;
}
.card.shuffling {
  animation: shuffle-out 1s cubic-bezier(0.23, 1, 0.32, 1) forwards;
}
@keyframes shuffle-out {
  0% {
    transform: translate(0, 0) scale(1);
    z-index: 30;
  }
  50% {
    transform: translate(120%, 10px) rotate(5deg) scale(0.95);
    z-index: 30;
  }
  100% {
    transform: translate(0px, 40px) scale(0.9);
    z-index: 10;
  }
}
@keyframes marquee-pingpong {
  0%, 100% {
    transform: translateX(0);
  }
  50% {
    transform: translateX(var(--marquee-translate-end, 0));
  }
}
.skills-marquee-track {
  display: flex;
  width: 100%;
}
.skills-marquee-track > * {
  flex-shrink: 0;
}
.skills-marquee-track.is-active {
  width: max-content;
  animation: marquee-pingpong 24s ease-in-out infinite;
}
#about h3 {
  font-size: var(--text-4xl);
}
@media (width >= 768px) {
  .stat-number {
    font-size: calc(var(--text-7xl) * 1.5);
  }
}
.pillars-animation {
  color: var(--color-text-primary);
}
.pillars-track {
  position: relative;
  width: 100%;
  height: 48px;
}
@keyframes pillars-line-draw {
  to {
    stroke-dashoffset: 0;
  }
}
.pillar-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  opacity: 0;
  animation: pillars-icon-in 0.4s ease-out forwards;
}
.pillar-icon svg {
  width: 48px;
  height: 48px;
}
.pillar-code {
  left: 15%;
  animation-delay: 0s;
}
.pillar-gear {
  left: 50%;
  animation-delay: 1.25s;
}
.pillar-diy {
  left: 85%;
  animation-delay: 2.5s;
}
.pillar-problem-solving {
  left: 50%;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
@keyframes pillars-icon-in {
  to {
    opacity: 1;
  }
}
.pillars-phase-2 .pillar-code {
  animation: pillars-converge-code 2.5s ease-in-out forwards;
}
.pillars-phase-2 .pillar-gear {
  animation: pillars-converge-gear 2.5s ease-in-out forwards;
}
.pillars-phase-2 .pillar-diy {
  animation: pillars-converge-diy 2.5s ease-in-out forwards;
}
.pillars-phase-2 .pillar-problem-solving {
  visibility: visible;
  pointer-events: auto;
  animation: pillars-converge-problem-solving 3s ease-in-out forwards;
  transform-origin: center center;
}
@keyframes pillars-converge-code {
  0% {
    left: 15%;
    opacity: 1;
  }
  100% {
    left: 50%;
    opacity: 0;
  }
}
@keyframes pillars-converge-gear {
  0% {
    left: 50%;
    opacity: 0.75;
  }
  100% {
    left: 50%;
    opacity: 0;
  }
}
@keyframes pillars-converge-diy {
  0% {
    left: 85%;
    opacity: 1;
  }
  100% {
    left: 50%;
    opacity: 0;
  }
}
@keyframes pillars-converge-problem-solving {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%) scale(0);
  }
  100% {
    opacity: 1;
    transform: translate(-50%, -50%) scale(2);
  }
}
@media (prefers-reduced-motion: reduce) {
  .pillars-animation.pillars-reduced-motion .pillar-icon {
    animation-duration: 0.01s;
  }
  .pillars-animation.pillars-reduced-motion .pillar-code {
    animation-delay: 0s;
  }
  .pillars-animation.pillars-reduced-motion .pillar-gear {
    animation-delay: 0.02s;
  }
  .pillars-animation.pillars-reduced-motion .pillar-diy {
    animation-delay: 0.04s;
  }
  .pillars-animation.pillars-reduced-motion.pillars-phase-2 .pillar-code, .pillars-animation.pillars-reduced-motion.pillars-phase-2 .pillar-gear, .pillars-animation.pillars-reduced-motion.pillars-phase-2 .pillar-diy, .pillars-animation.pillars-reduced-motion.pillars-phase-2 .pillar-problem-solving {
    animation-duration: 0.15s;
  }
}
.timeline-hidden {
  display: none;
}
.timeline-toggle__btn {
  padding: 0.5rem 1rem;
  border-radius: var(--radius-lg, 0.5rem);
  border: 1px solid color-mix(in srgb, #57534e 30%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    border: 1px solid color-mix(in oklab, var(--color-text-secondary) 30%, transparent);
  }
  color: var(--color-text-primary);
  background-color: transparent;
  font: inherit;
  cursor: pointer;
  transition: border-color 0.15s ease, opacity 0.15s ease, background-color 0.15s ease, color 0.15s ease;
}
.timeline-toggle__btn:hover {
  border-color: var(--color-accent-green);
  opacity: 0.9;
}
.timeline-toggle__btn[aria-pressed="true"] {
  background-color: var(--color-accent-green);
  color: var(--color-bg-primary);
  border-color: var(--color-accent-green);
}
.timeline {
  position: relative;
  padding: 0 1rem;
}
@media (width >= 768px) {
  .timelines-wrapper .timeline {
    width: 100%;
    max-width: 22rem;
  }
}
.timeline__line {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 2px;
  background-color: var(--color-text-secondary);
  opacity: 0.5;
}
.timeline__title {
  position: relative;
  z-index: 1;
}
@media (width >= 768px) {
  .timeline__line {
    left: 50%;
    transform: translateX(-50%);
  }
  .timeline-item {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 1rem;
    align-items: center;
    min-height: 5rem;
    position: relative;
  }
  .timeline-item__node {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background-color: var(--color-accent-green);
    border: 3px solid var(--color-text-primary);
    flex-shrink: 0;
    z-index: 1;
  }
  .timeline-item__content {
    max-width: 280px;
  }
  .timeline-item--left .timeline-item__content {
    grid-column: 1;
    text-align: right;
  }
  .timeline-item--left .timeline-item__node {
    grid-column: 2;
  }
  .timeline-item--right .timeline-item__content {
    grid-column: 3;
    text-align: left;
  }
  .timeline-item--right .timeline-item__node {
    grid-column: 2;
  }
}
@media (max-width: 767px) {
  .timeline {
    padding-left: 2rem;
  }
  .timeline__line {
    left: 7px;
  }
  .timeline__items {
    display: flex;
    flex-direction: column;
    gap: 2rem;
  }
  .timeline-item {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    min-height: 4rem;
    position: relative;
  }
  .timeline-item__node {
    position: absolute;
    left: 0;
    top: 0.25rem;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background-color: var(--color-accent-green);
    border: 3px solid var(--color-text-primary);
    transform: translateX(-50%);
    flex-shrink: 0;
    z-index: 1;
  }
  .timeline-item__content {
    margin-left: 1rem;
    flex: 1;
  }
}
.timeline-item__date {
  display: block;
  margin-bottom: 0.25rem;
}
.timeline-item__desc {
  margin: 0;
}
@keyframes timeline-item-in {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.timeline__items .timeline-item {
  animation: none;
  opacity: 0;
}
[data-reveal].is-visible .timeline__items .timeline-item {
  animation: timeline-item-in 0.4s ease-out forwards;
}
[data-reveal].is-visible .timeline__items .timeline-item:nth-child(1) {
  animation-delay: 0.1s;
}
[data-reveal].is-visible .timeline__items .timeline-item:nth-child(2) {
  animation-delay: 0.2s;
}
[data-reveal].is-visible .timeline__items .timeline-item:nth-child(3) {
  animation-delay: 0.3s;
}
[data-reveal].is-visible .timeline__items .timeline-item:nth-child(4) {
  animation-delay: 0.4s;
}
[data-reveal].is-visible .timeline__items .timeline-item:nth-child(5) {
  animation-delay: 0.5s;
}
[data-reveal].is-visible .timeline__items .timeline-item:nth-child(6) {
  animation-delay: 0.6s;
}
[data-reveal].is-visible .timeline__items .timeline-item:nth-child(7) {
  animation-delay: 0.7s;
}
[data-reveal].is-visible .timeline__items .timeline-item:nth-child(8) {
  animation-delay: 0.8s;
}
[data-reveal].is-visible .timeline__items .timeline-item:nth-child(9) {
  animation-delay: 0.9s;
}
[data-reveal].is-visible .timeline__items .timeline-item:nth-child(10) {
  animation-delay: 1s;
}
[data-reveal].is-visible .timeline__items .timeline-item:nth-child(11) {
  animation-delay: 1.1s;
}
[data-reveal].is-visible .timeline__items .timeline-item:nth-child(12) {
  animation-delay: 1.2s;
}
[data-reveal].is-visible .timeline__items .timeline-item:nth-child(13) {
  animation-delay: 1.3s;
}
[data-reveal].is-visible .timeline__items .timeline-item:nth-child(14) {
  animation-delay: 1.4s;
}
[data-reveal].is-visible .timeline__items .timeline-item:nth-child(15) {
  animation-delay: 1.5s;
}
[data-reveal].is-visible .timeline__items .timeline-item:nth-child(16) {
  animation-delay: 1.6s;
}
[data-reveal].is-visible .timeline__items .timeline-item:nth-child(17) {
  animation-delay: 1.7s;
}
[data-reveal].is-visible .timeline__items .timeline-item:nth-child(18) {
  animation-delay: 1.8s;
}
[data-reveal].is-visible .timeline__items .timeline-item:nth-child(19) {
  animation-delay: 1.9s;
}
[data-reveal].is-visible .timeline__items .timeline-item:nth-child(20) {
  animation-delay: 2s;
}
[data-reveal].is-visible .timeline__items .timeline-item:nth-child(21) {
  animation-delay: 2.1s;
}
[data-reveal].is-visible .timeline__items .timeline-item:nth-child(22) {
  animation-delay: 2.2s;
}
[data-reveal].is-visible .timeline__items .timeline-item:nth-child(23) {
  animation-delay: 2.3s;
}
[data-reveal].is-visible .timeline__items .timeline-item:nth-child(24) {
  animation-delay: 2.4s;
}
[data-reveal].is-visible .timeline__items .timeline-item:nth-child(25) {
  animation-delay: 2.5s;
}
@media (prefers-reduced-motion: reduce) {
  .timeline__items .timeline-item, [data-reveal].is-visible .timeline__items .timeline-item {
    animation: none;
    opacity: 1;
  }
}
#skills {
  --bubble-min: 4rem;
  --bubble-max: 6rem;
  --score-min: 50;
  --score-max: 90;
}
@media (width >= 768px) {
  #skills {
    --bubble-min: 6rem;
    --bubble-max: 8rem;
  }
}
.skills-bubble {
  --radius: calc(
        var(--bubble-min) +
        (var(--score) - var(--score-min)) / (var(--score-max) - var(--score-min)) *
        (var(--bubble-max) - var(--bubble-min))
    );
  width: calc(var(--radius) * 2);
  height: calc(var(--radius) * 2);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: color-mix(in srgb, #059669 85%, #ffffff);
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in oklab, var(--color-accent-green) 85%, var(--color-bg-secondary));
  }
  color: #fff;
  font-weight: var(--font-weight-semibold);
  font-size: clamp(0.75rem, 2vw, var(--text-base));
  text-align: center;
  padding: 0.5rem;
  overflow: hidden;
  position: relative;
}
.skills-bubble:nth-of-type(1) {
  background-color: var(--color-accent-green);
}
.skills-bubble:nth-of-type(2) {
  background-color: color-mix(in srgb, #059669 70%, #1c1917);
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in oklab, var(--color-accent-green) 70%, var(--color-text-primary));
  }
}
.skills-bubble:nth-of-type(3) {
  background-color: var(--color-text-secondary);
}
.skills-bubble:nth-of-type(4) {
  background-color: color-mix(in srgb, #1c1917 85%, #059669);
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in oklab, var(--color-text-primary) 85%, var(--color-accent-green));
  }
}
.skills-bubble:nth-of-type(5) {
  background-color: color-mix(in srgb, #94a3b8 60%, #1c1917);
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in oklab, var(--color-muted) 60%, var(--color-text-primary));
  }
}
.dark #skills .skills-bubble {
  color: #fff;
}
.dark #skills .skills-bubble:nth-of-type(1) {
  background-color: var(--color-accent-green);
}
.dark #skills .skills-bubble:nth-of-type(2) {
  background-color: color-mix(in srgb, #059669 75%, #0c0c0e);
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in oklab, var(--color-accent-green) 75%, #0c0c0e);
  }
}
.dark #skills .skills-bubble:nth-of-type(3) {
  background-color: #52525b;
}
.dark #skills .skills-bubble:nth-of-type(4) {
  background-color: #3f3f46;
}
.dark #skills .skills-bubble:nth-of-type(5) {
  background-color: #27272a;
}
.dark #skills .skills-bubble:hover .skills-bubble__subskills, .dark #skills .skills-bubble:focus-within .skills-bubble__subskills {
  background-color: #1f1f23;
}
@keyframes curtain-lift {
  from {
    transform: translateY(0);
    opacity: 1;
  }
  to {
    transform: translateY(-100%);
    opacity: 1;
  }
}
@keyframes curtain-down {
  from {
    transform: translateY(-100%);
    opacity: 1;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}
@keyframes subskills-reveal {
  from {
    opacity: 0;
    transform: translateY(20%);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes subskills-hide {
  from {
    opacity: 1;
    transform: translateY(0);
  }
  to {
    opacity: 0;
    transform: translateY(20%);
  }
}
.skills-bubble__label {
  animation: curtain-down 0.6s ease-out both;
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.5rem;
  transition: opacity 0.2s ease;
}
.skills-bubble__subskills {
  animation: subskills-hide 0.6s ease-out both;
  gap: 1rem;
  flex-wrap: wrap;
  opacity: 0;
  pointer-events: none;
  font-size: 0.7em;
  padding: 1.5rem;
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.2s ease;
  align-content: center;
}
.skills-bubble__subskill {
  flex: 0 1 auto;
  padding: 0.25em 0.6em;
  border-radius: 9999px;
  background-color: rgba(255, 255, 255, 0.25);
  color: #fff;
  font-size: 1.2em;
  white-space: nowrap;
}
.skills-bubble:hover .skills-bubble__label, .skills-bubble:focus-within .skills-bubble__label {
  animation: curtain-lift 0.6s ease-out forwards;
}
.skills-bubble:hover .skills-bubble__subskills, .skills-bubble:focus-within .skills-bubble__subskills {
  pointer-events: auto;
  background-color: var(--color-muted);
  animation: subskills-reveal 0.35s ease-out 0.12s forwards;
}
@media (prefers-reduced-motion: reduce) {
  .skills-bubble__label, .skills-bubble__subskills {
    transition-duration: 0.01ms;
  }
}
@media (width >= 768px) {
  .skills-bubble__container--clustered {
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: flex-start;
  }
  .skills-bubble__container--clustered .skills-bubble {
    position: absolute;
  }
}
.projects-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}
@media (width >= 768px) {
  .projects-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (width >= 1024px) {
  .projects-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
.project-card {
  position: relative;
  aspect-ratio: 2 / 3;
  min-height: 280px;
  padding: 0;
  text-align: left;
  background-color: var(--color-bg-secondary);
  overflow: hidden;
}
.project-card__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  background-size: cover;
  background-position: center;
  transition: transform 0.4s ease;
}
.project-card:hover .project-card__bg {
  transform: scale(1.1);
}
.project-card__bg--gradient {
  background-image: linear-gradient(to bottom, transparent 25%, rgba(0, 0, 0, 0.75) 100%), linear-gradient( 135deg, color-mix(in srgb, #57534e 25%, #fafaf9) 0%, color-mix(in srgb, #059669 15%, #ffffff) 100% );
  @supports (color: color-mix(in lab, red, red)) {
    background-image: linear-gradient(to bottom, transparent 25%, rgba(0, 0, 0, 0.75) 100%), linear-gradient( 135deg, color-mix(in oklab, var(--color-text-secondary) 25%, var(--color-bg-primary)) 0%, color-mix(in oklab, var(--color-accent-green) 15%, var(--color-bg-secondary)) 100% );
  }
}
.project-card:hover {
  transform: scale(1.02);
  transition: transform 0.4s ease;
  border: 3px solid var(--color-accent-green);
  border-radius: 10px;
}
.project-card:hover::before, .project-card:hover::after {
  display: none;
}
.project-card::before, .project-card::after {
  content: "";
  position: absolute;
  width: 30px;
  height: 30px;
  border-color: var(--color-text-primary);
  border-style: solid;
  border-width: 0;
  opacity: 0.85;
  z-index: 1;
}
.project-card::before {
  top: 0;
  left: 0;
  border-top-width: 4px;
  border-left-width: 4px;
}
.project-card::after {
  bottom: 0;
  right: 0;
  border-bottom-width: 4px;
  border-right-width: 4px;
}
.project-card__content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 1;
  padding: 1.25rem 1.5rem;
}
.project-card__title {
  font-size: var(--text-xl, 1.25rem);
  font-weight: 700;
  margin-bottom: 0.35rem;
  color: #fff;
}
.project-card__description {
  margin-bottom: 0.6rem;
  line-height: 1.45;
  color: rgba(255, 255, 255, 0.92);
}
.project-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}
.project-card__tag {
  padding: 0.2em 0.5em;
  font-size: 0.75rem;
  background-color: rgba(255, 255, 255, 0.2);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.35);
}
.project-card__meta {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  padding: 1rem 1.5rem;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size: 0.7rem;
  color: rgba(255, 255, 255, 0.95);
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.75) 0%, transparent 50%);
  opacity: 0;
  transform: translateY(4px);
  pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.project-card:hover .project-card__meta, .project-card:focus-within .project-card__meta {
  opacity: 1;
  transform: translateY(0);
  pointer-events: none;
}
.project-card__meta-line {
  display: block;
  letter-spacing: 0.02em;
}
.project-card__meta-line + .project-card__meta-line {
  margin-top: 0.2rem;
}
@media (prefers-reduced-motion: reduce) {
  .project-card__meta {
    transition-duration: 0.01ms;
  }
}
.modal-open, .modal-open body {
  overflow: hidden;
}
.project-modal {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.25s ease, visibility 0.25s ease;
  min-height: 100dvh;
}
.project-modal.project-modal--open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.project-modal__backdrop {
  position: absolute;
  inset: 0;
  background: color-mix(in srgb, #1c1917 60%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in oklab, var(--color-text-primary) 60%, transparent);
  }
}
.project-modal__dialog {
  position: relative;
  z-index: 1;
  width: 100vw;
  height: calc(100dvh - 2rem);
  overflow: auto;
  padding: 2rem;
  margin: 1rem;
  background-color: var(--color-bg-secondary);
  border: 1px solid color-mix(in srgb, #57534e 25%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    border: 1px solid color-mix(in oklab, var(--color-text-secondary) 25%, transparent);
  }
  border-radius: 1rem;
  transform: scale(0.98);
  opacity: 0;
  transition: transform 0.5s ease, opacity 0.5s ease;
}
.project-modal--open .project-modal__dialog {
  transform: scale(1);
  opacity: 1;
}
.project-modal__close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  padding: 0.5rem 1rem;
  border: 1px solid color-mix(in srgb, #57534e 40%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    border: 1px solid color-mix(in oklab, var(--color-text-secondary) 40%, transparent);
  }
  background: transparent;
  color: var(--color-text-primary);
  font: inherit;
  cursor: pointer;
  border-radius: var(--radius-lg, 0.5rem);
  transition: border-color 0.15s ease, background-color 0.15s ease;
}
.project-modal__close:hover {
  border-color: var(--color-accent-green);
  background-color: color-mix(in srgb, #059669 15%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in oklab, var(--color-accent-green) 15%, transparent);
  }
}
.project-modal__close:focus-visible {
  outline: 2px solid var(--color-accent-green);
  outline-offset: 2px;
}
.project-modal__status-bar {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: center;
  gap: 1rem 1.5rem;
  padding: 0.625rem 0;
  margin-bottom: 1rem;
  font-size: 0.8125rem;
  letter-spacing: 0.03em;
  color: var(--color-text-secondary);
  border-bottom: 1px solid color-mix(in srgb, #57534e 20%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    border-bottom: 1px solid color-mix(in oklab, var(--color-text-secondary) 20%, transparent);
  }
}
.project-modal__status-bar[aria-hidden="true"] {
  display: none;
}
.project-modal__status-items {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem 1.5rem;
}
.project-modal__status-item {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
}
.project-modal__status-dot {
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  background-color: var(--color-accent-green);
  flex-shrink: 0;
  animation: availability-pulse 2s ease-in-out infinite;
}
.project-modal__live-link {
  flex-shrink: 0;
}
.project-modal__live-link[aria-hidden="true"] {
  display: none;
}
.project-modal__project-description-link {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--color-accent-green);
  text-decoration: none;
  transition: color 0.2s ease;
}
.project-modal__project-description-link:hover {
  color: var(--color-text-primary);
}
.project-modal__project-description-link:focus-visible {
  outline: 2px solid var(--color-accent-green);
  outline-offset: 2px;
}
.project-modal__project-description-arrow {
  flex-shrink: 0;
  transition: transform 0.2s ease;
}
.project-modal__project-description-link:hover .project-modal__project-description-arrow {
  transform: translateY(4px);
}
.project-modal__live-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-accent-green);
  border: 1px solid color-mix(in srgb, #059669 50%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    border: 1px solid color-mix(in oklab, var(--color-accent-green) 50%, transparent);
  }
  border-radius: var(--radius-lg, 0.5rem);
  background: transparent;
  text-decoration: none;
  transition: border-color 0.2s ease, background-color 0.2s ease;
}
.project-modal__live-btn:hover {
  background-color: color-mix(in srgb, #059669 15%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in oklab, var(--color-accent-green) 15%, transparent);
  }
  border-color: var(--color-accent-green);
}
.project-modal__live-btn:focus-visible {
  outline: 2px solid var(--color-accent-green);
  outline-offset: 2px;
}
.project-modal__title {
  font-size: var(--text-2xl, 1.5rem);
  font-weight: 700;
  margin-bottom: 1rem;
  padding-right: 5rem;
  text-align: center;
}
.project-modal__body {
  line-height: 1.6;
}
.project-modal__preview {
  display: flex;
  flex-direction: column;
  width: 100%;
  aspect-ratio: 16 / 9;
  min-height: 12rem;
  margin-bottom: 1.25rem;
  border-radius: 0.5rem;
  overflow: hidden;
}
.project-modal__preview[aria-hidden="true"] {
  display: none;
}
.project-modal__preview-banner {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  padding: 0.25rem 0.75rem;
  font-family: var(--font-mono, ui-monospace, monospace);
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-accent-green);
  background-color: color-mix(in srgb, #059669 12%, #ffffff);
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in oklab, var(--color-accent-green) 12%, var(--color-bg-secondary));
  }
  border-bottom: 1px solid color-mix(in srgb, #059669 35%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    border-bottom: 1px solid color-mix(in oklab, var(--color-accent-green) 35%, transparent);
  }
}
.project-modal__preview-iframe-wrap {
  flex: 1;
  min-height: 0;
  position: relative;
}
.project-modal__preview-iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}
.project-modal__preview-mobile {
  flex: 1;
  min-height: 0;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
.project-modal__preview-mobile-image {
  position: absolute;
  inset: 0;
  background-color: color-mix(in srgb, #57534e 15%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in oklab, var(--color-text-secondary) 15%, transparent);
  }
}
.project-modal__preview-mobile-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.project-modal__preview-mobile-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: color-mix(in srgb, #fafaf9 40%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in oklab, var(--color-bg-primary) 40%, transparent);
  }
}
.project-modal__preview-mobile-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-accent-green);
  border: 1px solid color-mix(in srgb, #059669 50%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    border: 1px solid color-mix(in oklab, var(--color-accent-green) 50%, transparent);
  }
  border-radius: var(--radius-lg, 0.5rem);
  background: var(--color-bg-secondary);
  text-decoration: none;
  transition: border-color 0.2s ease, background-color 0.2s ease;
}
.project-modal__preview-mobile-btn:hover {
  background-color: color-mix(in srgb, #059669 15%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in oklab, var(--color-accent-green) 15%, transparent);
  }
  border-color: var(--color-accent-green);
}
.project-modal__preview-mobile-btn:focus-visible {
  outline: 2px solid var(--color-accent-green);
  outline-offset: 2px;
}
@media (min-width: 768px) {
  .project-modal__preview-mobile {
    display: none;
  }
}
.project-modal__narrative {
  margin-bottom: 1.25rem;
}
.project-modal__specs {
  margin: 1rem 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
}
@media (max-width: 425px) {
  .project-modal__specs {
    gap: 0.5rem;
  }
}
.project-modal__specs dt {
  display: inline-block;
  padding: 0.4em 0.8em;
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 1.3;
  color: var(--color-accent-green);
  background-color: color-mix(in srgb, #059669 15%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in oklab, var(--color-accent-green) 15%, transparent);
  }
  border: 1px solid color-mix(in srgb, #059669 35%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    border: 1px solid color-mix(in oklab, var(--color-accent-green) 35%, transparent);
  }
  border-radius: 9999px;
  margin-top: 0.5rem;
}
.project-modal__specs dd {
  margin-left: 0;
  margin-top: 0.25rem;
}
.project-modal__problem-solving {
  margin-top: 1.25rem;
  padding-top: 1rem;
  border-top: 1px solid color-mix(in srgb, #57534e 20%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    border-top: 1px solid color-mix(in oklab, var(--color-text-secondary) 20%, transparent);
  }
}
@media (max-width: 767px) {
  .project-modal__dialog {
    padding: 1rem;
    margin: 0.5rem;
  }
  .project-modal__status-bar {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 0.75rem;
  }
  .project-modal__status-items {
    justify-content: center;
    margin-top: 2.5rem;
  }
  .project-modal__title {
    padding-right: 0;
  }
}
.contact-cards {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
@media (min-width: 768px) {
  .contact-cards {
    flex-direction: row;
    align-items: stretch;
    gap: 1.25rem;
  }
}
.contact-card {
  flex: 1;
  min-width: 0;
  background-color: var(--color-bg-secondary);
  border: 1px solid color-mix(in srgb, #57534e 18%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    border: 1px solid color-mix(in oklab, var(--color-text-secondary) 18%, transparent);
  }
  border-radius: 1rem;
  padding: 1.5rem;
  text-align: left;
  transition: border-color 0.25s ease, box-shadow 0.25s ease;
}
.contact-card:hover {
  border-color: color-mix(in srgb, #57534e 28%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    border-color: color-mix(in oklab, var(--color-text-secondary) 28%, transparent);
  }
  box-shadow: 0 4px 20px -4px rgba(0, 0, 0, 0.08);
}
.dark .contact-card:hover {
  box-shadow: 0 4px 20px -4px rgba(0, 0, 0, 0.25);
}
.contact-card__title {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--color-text-primary);
  margin-bottom: 1rem;
}
.contact-card__title--inline {
  margin-bottom: 0;
}
.contact-info-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.contact-info-item {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
}
.contact-info-icon {
  flex-shrink: 0;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0.5rem;
  background-color: var(--color-accent-green);
  color: var(--color-bg-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.25s cubic-bezier(0.23, 1, 0.32, 1);
}
.contact-info-item:hover .contact-info-icon {
  transform: scale(1.05);
}
.contact-info-item > div {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
  min-width: 0;
}
.contact-info-label {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-text-secondary);
}
.contact-info-value {
  font-size: 0.9375rem;
  color: var(--color-text-primary);
  text-decoration: none;
}
a.contact-info-value:hover {
  color: var(--color-accent-green);
  text-decoration: underline;
}
.contact-card-availability {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.availability-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}
.availability-dot {
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  background-color: var(--color-accent-green);
  flex-shrink: 0;
  animation: availability-pulse 2s ease-in-out infinite;
}
@keyframes availability-pulse {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0.5;
  }
}
.availability-text {
  font-size: 0.9375rem;
  color: var(--color-text-secondary);
  margin: 0;
  line-height: 1.5;
}
.contact-card .contact-buttons {
  justify-content: center;
}
.contact-buttons {
  --contact-btn-ease: cubic-bezier(0.23, 1, 0.32, 1);
}
.contact-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.875rem 1.5rem;
  border-radius: 0.75rem;
  font-weight: 600;
  font-size: 1rem;
  text-decoration: none;
  border: 2px solid transparent;
  position: relative;
  overflow: hidden;
  transition: transform 0.35s var(--contact-btn-ease), box-shadow 0.35s var(--contact-btn-ease), border-color 0.25s ease, color 0.25s ease, background-color 0.25s ease;
}
.contact-btn::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.15) 0%, transparent 50%);
  opacity: 0;
  transition: opacity 0.35s var(--contact-btn-ease);
}
.contact-btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 24px -8px rgba(0, 0, 0, 0.2);
}
.contact-btn:focus-visible {
  outline: 2px solid var(--color-accent-green);
  outline-offset: 2px;
}
.contact-btn__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.35s var(--contact-btn-ease);
}
.contact-btn:hover .contact-btn__icon {
  transform: scale(1.1);
}
.contact-btn__label {
  position: relative;
  z-index: 1;
}
.contact-btn-email {
  background-color: var(--color-accent-green);
  color: var(--color-bg-primary);
}
.contact-btn-email:hover {
  background-color: color-mix(in srgb, #059669 85%, black);
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in oklab, var(--color-accent-green) 85%, black);
  }
  box-shadow: 0 12px 24px -8px color-mix(in srgb, #059669 40%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    box-shadow: 0 12px 24px -8px color-mix(in oklab, var(--color-accent-green) 40%, transparent);
  }
}
.contact-btn-email:hover::before {
  opacity: 1;
}
.contact-btn-linkedin {
  background-color: transparent;
  color: var(--color-text-primary);
  border-color: color-mix(in srgb, #57534e 50%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    border-color: color-mix(in oklab, var(--color-text-secondary) 50%, transparent);
  }
}
.contact-btn-linkedin:hover {
  border-color: #0a66c2;
  color: #0a66c2;
  box-shadow: 0 12px 24px -8px rgba(10, 102, 194, 0.25);
}
.contact-btn-linkedin:hover .contact-btn__icon {
  color: #0a66c2;
}
.contact-btn-github {
  background-color: transparent;
  color: var(--color-text-primary);
  border-color: color-mix(in srgb, #57534e 50%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    border-color: color-mix(in oklab, var(--color-text-secondary) 50%, transparent);
  }
}
.contact-btn-github:hover {
  border-color: var(--color-text-primary);
  background-color: color-mix(in srgb, #1c1917 8%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in oklab, var(--color-text-primary) 8%, transparent);
  }
  box-shadow: 0 12px 24px -8px rgba(0, 0, 0, 0.15);
}
.dark .contact-btn-github:hover {
  box-shadow: 0 12px 24px -8px rgba(255, 255, 255, 0.08);
}
@media (prefers-reduced-motion: reduce) {
  .project-modal, .project-modal__dialog {
    transition-duration: 0.01ms;
  }
  .contact-btn, .contact-btn::before, .contact-btn__icon {
    transition-duration: 0.01ms;
  }
  .contact-btn:hover {
    transform: none;
  }
  .contact-btn:hover .contact-btn__icon {
    transform: none;
  }
  .availability-dot {
    animation: none;
  }
  .contact-info-item:hover .contact-info-icon {
    transform: none;
  }
  .site-nav__list {
    transition-duration: 0.01ms;
  }
  .site-nav__toggle-bar {
    transition-duration: 0.01ms;
  }
}
@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-border-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}
@property --tw-font-weight {
  syntax: "*";
  inherits: false;
}
@property --tw-blur {
  syntax: "*";
  inherits: false;
}
@property --tw-brightness {
  syntax: "*";
  inherits: false;
}
@property --tw-contrast {
  syntax: "*";
  inherits: false;
}
@property --tw-grayscale {
  syntax: "*";
  inherits: false;
}
@property --tw-hue-rotate {
  syntax: "*";
  inherits: false;
}
@property --tw-invert {
  syntax: "*";
  inherits: false;
}
@property --tw-opacity {
  syntax: "*";
  inherits: false;
}
@property --tw-saturate {
  syntax: "*";
  inherits: false;
}
@property --tw-sepia {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-drop-shadow-size {
  syntax: "*";
  inherits: false;
}
@property --tw-duration {
  syntax: "*";
  inherits: false;
}
@property --tw-ease {
  syntax: "*";
  inherits: false;
}
@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-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-border-style: solid;
      --tw-font-weight: initial;
      --tw-blur: initial;
      --tw-brightness: initial;
      --tw-contrast: initial;
      --tw-grayscale: initial;
      --tw-hue-rotate: initial;
      --tw-invert: initial;
      --tw-opacity: initial;
      --tw-saturate: initial;
      --tw-sepia: initial;
      --tw-drop-shadow: initial;
      --tw-drop-shadow-color: initial;
      --tw-drop-shadow-alpha: 100%;
      --tw-drop-shadow-size: initial;
      --tw-duration: initial;
      --tw-ease: initial;
    }
  }
}
