﻿#projects.projects-page {
  --carousel-bg: var(--color-canvas);
  --carousel-text: var(--color-ink);
  --carousel-panel: var(--color-fog);
  --carousel-muted: rgba(26, 26, 26, .5);
  --carousel-soft: rgba(26, 26, 26, .1);
  --carousel-line: rgba(26, 26, 26, .14);
  --stack-1: var(--color-sky-tint);
  --stack-2: var(--color-mint);
  --carousel-ease: cubic-bezier(.19, 1, .22, 1);
  position: relative;
  width: 100%;
  height: 100svh;
  min-height: 720px;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 15%, rgba(190, 219, 255, .34), transparent 28%),
    linear-gradient(180deg, var(--carousel-bg), var(--carousel-panel)),
    var(--carousel-bg);
  color: var(--carousel-text);
  font-family: var(--font);
}

[data-theme="dark"] #projects.projects-page {
  --carousel-muted: rgba(230, 251, 255, .56);
  --carousel-soft: rgba(230, 251, 255, .12);
  --carousel-line: rgba(230, 251, 255, .16);
  --stack-1: var(--color-sky-tint);
  --stack-2: rgba(0, 215, 255, .32);
  background:
    radial-gradient(circle at 50% 16%, rgba(0, 215, 255, .08), transparent 34%),
    linear-gradient(180deg, #020b12 0%, #061925 100%);
}

#projects .grain {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  opacity: .05;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 160 160' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.75'/%3E%3C/svg%3E");
  mix-blend-mode: multiply;
}

[data-theme="dark"] #projects .grain {
  opacity: .025;
  mix-blend-mode: screen;
}

#projects .projects-heading {
  position: absolute;
  z-index: 24;
  top: clamp(104px, 12vh, 132px);
  left: clamp(20px, 4vw, 56px);
  max-width: min(420px, 88vw);
  pointer-events: none;
}

#projects .projects-heading__label {
  margin-bottom: 12px;
  color: var(--carousel-muted);
  font-family: var(--font);
  font-size: 14px;
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: -0.35px;
}

#projects .projects-heading h2 {
  margin: 0;
  color: var(--carousel-text);
  font-family: var(--font);
  font-size: clamp(36px, 5.5vw, 48px);
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -1.2px;
}

#projects .viewport {
  position: absolute;
  z-index: 4;
  inset: clamp(200px, 22vh, 232px) 0 20px;
  display: flex;
  align-items: flex-start;
  overflow: hidden;
  cursor: grab;
  touch-action: none;
}

#projects .viewport.is-grabbing {
  cursor: grabbing;
}

#projects .track {
  display: flex;
  gap: clamp(52px, 5.9vw, 92px);
  align-items: flex-start;
  padding-left: 27vw;
  padding-right: 34vw;
  transform: translate3d(0, 0, 0);
  will-change: transform;
}

#projects .project-card {
  position: relative;
  flex: 0 0 clamp(340px, 33vw, 520px);
  min-width: 0;
  opacity: .54;
  cursor: pointer;
  transform: translate3d(0, 0, 0) scale(.985);
  transition: opacity .28s var(--carousel-ease), filter .28s var(--carousel-ease);
  will-change: opacity, transform;
}

#projects .project-card.is-active,
#projects .project-card:hover {
  opacity: 1;
  transform: translate3d(0, -2px, 0) scale(1);
  filter: none;
}

#projects .project-card.is-hidden {
  display: none;
}

#projects .project-stack {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  transform-style: preserve-3d;
  perspective: 900px;
}

#projects .project-stack::before,
#projects .project-stack::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: var(--radius-images);
  pointer-events: none;
  opacity: 0;
  transform-origin: center right;
  transition: opacity .48s var(--carousel-ease), transform .7s var(--carousel-ease);
}

#projects .project-stack::before {
  z-index: 1;
  background: var(--stack-1);
  transform: translate3d(8px, 2px, -1px) rotateY(-1deg) scale(.995);
}

#projects .project-stack::after {
  z-index: 0;
  background: var(--stack-2);
  transform: translate3d(14px, 4px, -2px) rotateY(-1.5deg) scale(.99);
}

#projects .project-card.is-active .project-stack::before,
#projects .project-card:hover .project-stack::before {
  opacity: .68;
  transform: translate3d(9px, 1px, -1px) rotateY(-1.8deg) scale(.996);
}

#projects .project-card.is-active .project-stack::after,
#projects .project-card:hover .project-stack::after {
  opacity: .38;
  transform: translate3d(17px, 4px, -2px) rotateY(-2.5deg) scale(.991);
}

#projects .image-wrap {
  position: absolute;
  z-index: 2;
  inset: 0;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, .92), rgba(245, 248, 250, .72));
  border: 1px solid var(--carousel-soft);
  border-radius: var(--radius-images);
  box-shadow: 0 18px 42px rgba(26, 26, 26, .08);
}

[data-theme="dark"] #projects .image-wrap {
  background:
    linear-gradient(135deg, rgba(230, 251, 255, .1), rgba(2, 11, 18, .34));
  box-shadow: 0 18px 48px rgba(0, 0, 0, .28);
}

#projects .image-wrap img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
  object-position: center;
  transform: translate3d(var(--px, 0px), var(--py, 0px), 0) scale(.965);
  filter: saturate(.88) contrast(.98);
  transition: transform .9s var(--carousel-ease), filter .9s var(--carousel-ease);
  will-change: transform;
  user-select: none;
  pointer-events: none;
}

#projects .project-card:hover .image-wrap img,
#projects .project-card.is-active .image-wrap img {
  transform: translate3d(var(--px, 0px), var(--py, 0px), 0) scale(1);
  filter: saturate(1.04) contrast(1.04);
}

#projects .project-title {
  margin-top: 20px;
  pointer-events: none;
}

#projects .project-title h2 {
  margin: 0;
  font-family: var(--font);
  font-size: clamp(30px, 3.5vw, 48px);
  font-weight: 700;
  line-height: .96;
  text-transform: uppercase;
  letter-spacing: 0;
  color: var(--carousel-text);
}

#projects .project-title em {
  display: block;
  margin-top: 6px;
  font-family: var(--font);
  font-size: clamp(17px, 1.75vw, 23px);
  font-style: normal;
  font-weight: 500;
  line-height: 1.05;
  color: var(--carousel-muted);
  letter-spacing: 0;
  text-transform: lowercase;
}

#projects .project-info {
  width: min(360px, 90%);
  margin-top: 12px;
  opacity: 0;
  transform: translate3d(0, 12px, 0);
  transition: opacity .42s var(--carousel-ease), transform .42s var(--carousel-ease);
}

#projects .project-card.is-active .project-info,
#projects .project-card:hover .project-info {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

#projects .project-info .line {
  width: 34px;
  height: 1px;
  margin-bottom: 20px;
  background: var(--carousel-text);
  transform-origin: left;
  transform: scaleX(.35);
  transition: transform .5s var(--carousel-ease);
}

#projects .project-card.is-active .project-info .line,
#projects .project-card:hover .project-info .line {
  transform: scaleX(1);
}

#projects .project-info p {
  margin: 0 0 14px;
  color: var(--carousel-text);
  font-family: var(--font);
  font-size: 16px;
  font-weight: 500;
  line-height: 1.45;
  letter-spacing: 0;
}

#projects .project-info .small {
  display: flex;
  flex-direction: column;
  gap: 5px;
  color: var(--carousel-muted);
  font-family: var(--font);
  font-size: 12px;
  font-weight: 600;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0;
}

#projects .project-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 14px;
  min-height: 42px;
  padding: 0 18px;
  color: var(--carousel-bg);
  background: var(--carousel-text);
  border: 1px solid var(--carousel-text);
  border-radius: var(--radius-elements);
  font-family: var(--font);
  font-size: 14px;
  font-weight: 600;
  line-height: 1;
  text-decoration: none;
  text-transform: none;
  letter-spacing: 0;
  box-shadow: 0 10px 28px rgba(26, 26, 26, .12);
  transition: transform .2s ease, background .2s ease, border-color .2s ease, color .2s ease, box-shadow .2s ease;
  cursor: pointer;
}

#projects .project-link.project-glass {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  min-height: 38px;
  padding: 0 20px;
  color: var(--carousel-text);
  background: transparent;
  border: none;
  border-radius: 999px;
  box-shadow:
    0 4px 6px rgba(0, 0, 0, .14),
    0 0 16px rgba(0, 0, 0, .07);
  transition: all .4s cubic-bezier(.175, .885, .32, 2.2);
}

#projects .project-link.project-glass .liquidGlass-effect {
  position: absolute;
  z-index: 0;
  inset: 0;
  border-radius: inherit;
  backdrop-filter: blur(3px) saturate(135%);
  -webkit-backdrop-filter: blur(3px) saturate(135%);
  filter: url(#hero-glass-distortion);
  opacity: .72;
  overflow: hidden;
  pointer-events: none;
}

#projects .project-link.project-glass .liquidGlass-tint {
  position: absolute;
  z-index: 1;
  inset: 0;
  border-radius: inherit;
  background: rgba(255, 255, 255, .16);
  pointer-events: none;
}

#projects .project-link.project-glass .liquidGlass-shine {
  position: absolute;
  z-index: 2;
  inset: 0;
  border-radius: inherit;
  overflow: hidden;
  box-shadow:
    inset 2px 2px 1px 0 rgba(255, 255, 255, .72),
    inset -1px -1px 1px 1px rgba(255, 255, 255, .5),
    inset 0 0 0 1px rgba(255, 255, 255, .18);
  pointer-events: none;
}

#projects .project-link.project-glass .liquidGlass-shine::before,
#projects .project-link.project-glass .liquidGlass-shine::after {
  content: "";
  position: absolute;
  left: 10px;
  right: 10px;
  pointer-events: none;
}

#projects .project-link.project-glass .liquidGlass-shine::before {
  top: 0;
  height: 42%;
  border-radius: inherit;
  background: linear-gradient(180deg, rgba(255, 255, 255, .58), rgba(255, 255, 255, 0));
  opacity: .7;
}

#projects .project-link.project-glass .liquidGlass-shine::after {
  bottom: 0;
  height: 34%;
  border-radius: inherit;
  background: linear-gradient(0deg, rgba(0, 0, 0, .12), rgba(0, 0, 0, 0));
  opacity: .22;
}

#projects .project-link.project-glass .liquidGlass-text {
  position: relative;
  z-index: 3;
  color: var(--carousel-text);
  transition: transform .4s cubic-bezier(.175, .885, .32, 2.2);
}

#projects .project-link:hover {
  transform: translateY(-1px);
  color: var(--carousel-text);
  background: var(--carousel-panel);
  border-color: var(--carousel-line);
  box-shadow: 0 14px 34px rgba(26, 26, 26, .16);
}

#projects .project-link.project-glass:hover {
  padding-left: 24px;
  padding-right: 24px;
  background: transparent;
  border-color: transparent;
  box-shadow:
    0 4px 6px rgba(0, 0, 0, .14),
    0 0 16px rgba(0, 0, 0, .07);
}

#projects .project-link.project-glass:hover .liquidGlass-text {
  transform: scale(.95);
}

[data-theme="dark"] #projects .project-link {
  box-shadow: 0 14px 36px rgba(0, 215, 255, .14);
}

[data-theme="dark"] #projects .project-link:hover {
  box-shadow: 0 16px 40px rgba(0, 0, 0, .28);
}

[data-theme="dark"] #projects .project-link.project-glass,
[data-theme="dark"] #projects .project-link.project-glass:hover {
  box-shadow:
    0 4px 6px rgba(0, 0, 0, .14),
    0 0 16px rgba(0, 0, 0, .07);
}

#projects .filters {
  position: absolute;
  z-index: 25;
  top: clamp(128px, 14vh, 154px);
  right: clamp(20px, 4vw, 56px);
  display: flex;
  gap: 14px;
  align-items: center;
  transform: none;
  white-space: nowrap;
}

#projects .filter {
  appearance: none;
  border: 1px solid var(--carousel-line);
  border-radius: var(--radius-elements);
  background: var(--carousel-panel);
  padding: 8px 14px;
  color: var(--carousel-muted);
  font-family: var(--font);
  font-size: 14px;
  font-weight: 500;
  line-height: 1;
  text-transform: none;
  letter-spacing: 0;
  cursor: pointer;
  transition: background .28s ease, border-color .28s ease, color .28s ease, opacity .28s ease;
}

#projects .filter:hover,
#projects .filter.is-active {
  background: var(--carousel-text);
  border-color: var(--carousel-text);
  color: var(--carousel-bg);
}

#projects .filter sup {
  position: relative;
  top: -1px;
  margin-left: 4px;
  color: currentColor;
  opacity: .55;
  font-size: 9px;
  letter-spacing: 0;
}

#projects .counter {
  position: absolute;
  z-index: 25;
  right: 44px;
  bottom: 18px;
  color: var(--carousel-muted);
  font-family: var(--font);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0;
}

#projects .progress {
  position: absolute;
  z-index: 25;
  left: 44px;
  bottom: 22px;
  width: 150px;
  height: 1px;
  background: var(--carousel-line);
  overflow: hidden;
}

#projects .progress span {
  display: block;
  width: 0%;
  height: 100%;
  background: var(--carousel-text);
  transition: width .15s linear;
}

#projects .mobile-project-controls {
  display: none;
}

@keyframes projectMobileInNext {
  from {
    opacity: 0;
    transform: translate3d(34px, 0, 0) scale(.985);
    filter: blur(4px);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
    filter: blur(0);
  }
}

@keyframes projectMobileInPrev {
  from {
    opacity: 0;
    transform: translate3d(-34px, 0, 0) scale(.985);
    filter: blur(4px);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
    filter: blur(0);
  }
}

@keyframes projectMobileCopyIn {
  from {
    opacity: 0;
    transform: translate3d(0, 16px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@media (max-width: 900px) {
  #projects.projects-page {
    height: auto;
    min-height: 100svh;
    overflow: visible;
    padding: 72px 18px 90px;
  }

  #projects .projects-heading {
    position: static;
    max-width: none;
    margin-bottom: 22px;
    pointer-events: auto;
  }

  #projects .projects-heading__label {
    margin-bottom: 12px;
  }

  #projects .projects-heading h2 {
    font-size: clamp(36px, 5.5vw, 48px);
    line-height: 1.2;
  }

  #projects .viewport,
  #projects .filters,
  #projects .counter,
  #projects .progress {
    position: static;
  }

  #projects .viewport {
    display: block;
    overflow: hidden;
    cursor: grab;
    touch-action: pan-y;
    margin-top: 28px;
  }

  #projects .track {
    display: flex;
    gap: 18px;
    padding: 0;
    width: 100%;
    transform: translate3d(0, 0, 0);
    will-change: transform;
  }

  #projects .project-card {
    display: block;
    flex: 0 0 100%;
    width: 100%;
    opacity: .82 !important;
    transform: none !important;
    cursor: default;
    transition: opacity .34s var(--carousel-ease);
  }

  #projects .project-card.is-mobile-current {
    opacity: 1 !important;
  }

  #projects .project-card.is-mobile-current .project-stack {
    animation: none;
    will-change: transform, opacity, filter;
  }

  #projects.swipe-prev .project-card.is-mobile-current .project-stack {
    animation-name: projectMobileInPrev;
  }

  #projects.swipe-next .project-card.is-mobile-current .project-stack {
    animation-name: projectMobileInNext;
  }

  #projects .project-card.is-mobile-current .project-title {
    animation: none;
  }

  #projects .project-card.is-mobile-current .project-info {
    animation: none;
  }

  #projects .project-card.is-hidden {
    display: none !important;
  }

  #projects .project-info {
    opacity: 1;
    transform: none;
  }

  #projects .mobile-project-controls {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-top: 28px;
  }

  #projects .mobile-project-btn {
    width: 52px;
    height: 44px;
    border: 1px solid var(--carousel-line);
    border-radius: var(--radius-buttons);
    background: var(--carousel-panel);
    color: var(--carousel-text);
    font-family: var(--font);
    font-size: 20px;
    font-weight: 600;
    cursor: pointer;
    transition: background .2s ease, color .2s ease, opacity .2s ease;
  }

  #projects .mobile-project-btn:disabled {
    opacity: .35;
    cursor: default;
  }

  #projects .mobile-project-count {
    color: var(--carousel-muted);
    font-size: 15px;
    font-weight: 600;
  }

  #projects .filters {
    transform: none;
    justify-content: flex-start;
    flex-wrap: wrap;
    margin-top: 0;
  }

  #projects .counter,
  #projects .progress {
    display: none;
  }
}

@media (max-width: 560px) {
  #projects .project-title h2 {
    font-size: 32px;
  }

  #projects .project-title em {
    font-size: 22px;
  }

  #projects .filters {
    gap: 16px;
  }
}
