@import "../../../../template/css/site.css?v=20260514125000";

/* === HOME SCROLL HERO === */
.home-scroll-hero {
  position: relative;
  height: 300vh;
  background: #0d0d0d;
  color: #fff;
  isolation: isolate;
}
.home-scroll-sticky {
  position: sticky;
  top: 0;
  height: 100vh;
  min-height: 720px;
  overflow: hidden;
  display: grid;
  place-items: stretch;
}
.home-scroll-video-stage {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  background:
    radial-gradient(circle at 76% 24%, rgba(229,201,136,.18), transparent 28%),
    radial-gradient(circle at 18% 72%, rgba(134,124,102,.16), transparent 32%),
    linear-gradient(124deg, #17130d 0%, #090909 54%, #020202 100%);
}
.home-scroll-video,
.home-scroll-video-fallback,
.home-scroll-shade {
  position: absolute;
  inset: 0;
}
.home-scroll-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transform: scale(1.04);
  transition: opacity .55s ease, transform 1.2s ease;
}
.home-scroll-video.is-active {
  opacity: 1;
  transform: scale(1);
}
.home-scroll-video-fallback {
  background:
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(rgba(255,255,255,.028) 1px, transparent 1px);
  background-size: 86px 86px;
  opacity: .08;
  mask-image: radial-gradient(ellipse at 52% 56%, black 0%, rgba(0,0,0,.74) 42%, transparent 78%);
  -webkit-mask-image: radial-gradient(ellipse at 52% 56%, black 0%, rgba(0,0,0,.74) 42%, transparent 78%);
}
.home-scroll-shade {
  background:
    linear-gradient(180deg, rgba(0,0,0,.42), rgba(0,0,0,.08) 34%, rgba(0,0,0,.6)),
    linear-gradient(90deg, rgba(0,0,0,.52), rgba(0,0,0,.06) 42%, rgba(0,0,0,.28));
}
.home-scroll-window {
  position: relative;
  z-index: 2;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.home-scroll-track {
  position: relative;
  width: 100%;
  height: 100%;
}
.home-scroll-panel {
  position: absolute;
  inset: 0;
  width: 100%;
  min-width: 0;
  height: 100%;
  display: grid;
  place-items: center;
  padding: 6.8rem clamp(1.25rem, 6vw, 7rem) 6.8rem;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translate3d(5vw, 0, 0) scale(.985);
  transition: opacity .55s ease, transform .75s cubic-bezier(.22,1,.36,1), visibility .55s ease;
  will-change: opacity, transform;
}
.home-scroll-panel.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translate3d(0, 0, 0) scale(1);
}
.home-scroll-panel:nth-child(2) {
  transform: translate3d(-5vw, 0, 0) scale(.985);
}
.home-scroll-panel:nth-child(2).is-active {
  transform: translate3d(0, 0, 0) scale(1);
}
.home-scroll-copy {
  width: min(100%, 760px);
  margin-inline: auto;
  text-align: center;
  transform: translateY(clamp(7.25rem, 16vh, 10.25rem));
}
.home-scroll-index {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  margin-bottom: 1.15rem;
  padding: .42rem .78rem;
  border: 1px solid rgba(229,201,136,.34);
  border-radius: 999px;
  color: rgba(244,226,168,.94);
  background: rgba(8,8,8,.32);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 14px 42px rgba(0,0,0,.2);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  font-size: .7rem;
  font-weight: 800;
  letter-spacing: .2em;
  text-transform: uppercase;
}
.home-scroll-copy h1,
.home-scroll-copy h2 {
  margin: 0 auto .92rem;
  color: #f8f5ed;
  background: linear-gradient(180deg, #fffefa 0%, #f2e7c7 46%, #d7b863 78%, #a8893e 100%);
  -webkit-background-clip: text;
  background-clip: text;
  font-family: Georgia, 'Times New Roman', serif;
  font-size: clamp(5.25rem, 7.2vw, 7.4rem);
  font-weight: 500;
  line-height: .88;
  letter-spacing: 0;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 22px 80px rgba(0,0,0,.48);
}
.home-scroll-copy p {
  max-width: 36rem;
  margin-inline: auto;
  color: rgba(255,250,238,.88);
  font-size: clamp(1.06rem, 1.18vw, 1.2rem);
  font-weight: 360;
  line-height: 1.84;
  letter-spacing: .01em;
  text-wrap: balance;
  text-shadow: 0 14px 42px rgba(0,0,0,.74);
}
.home-scroll-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  margin-top: 1.55rem;
  padding: .82rem 1.22rem;
  border: 1px solid rgba(229,201,136,.3);
  border-radius: 999px;
  color: rgba(248,245,237,.9);
  background: linear-gradient(180deg, rgba(28,26,21,.58), rgba(8,8,8,.46));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 20px 56px rgba(0,0,0,.24);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  font-size: .86rem;
  font-weight: 760;
  letter-spacing: .01em;
  transition: transform .25s ease, border-color .25s ease, background .25s ease, color .25s ease;
}
.home-scroll-link:hover {
  transform: translateY(-1px);
  border-color: rgba(229,201,136,.56);
  background: rgba(229,201,136,.13);
  color: var(--gold-light);
}
.home-scroll-nav {
  position: absolute;
  z-index: 4;
  left: 50%;
  bottom: clamp(1.1rem, 3vh, 2rem);
  display: flex;
  gap: .24rem;
  padding: .24rem;
  border: 1px solid rgba(229,201,136,.22);
  border-radius: 999px;
  background: rgba(8,8,8,.5);
  box-shadow: 0 18px 50px rgba(0,0,0,.24), inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  transform: translateX(-50%);
}
.home-scroll-nav button {
  min-height: 30px;
  padding: .42rem .68rem;
  border-radius: 999px;
  color: rgba(255,255,255,.62);
  font-size: .68rem;
  font-weight: 760;
  white-space: nowrap;
  transition: background .25s ease, color .25s ease;
}
.home-scroll-nav button.is-active {
  color: #16130d;
  background: linear-gradient(135deg, #fff8df 0%, #d6b767 100%);
}
.home-scroll-meter {
  position: absolute;
  z-index: 4;
  right: clamp(1.25rem, 4vw, 4.5rem);
  top: 50%;
  width: 2px;
  height: min(34vh, 240px);
  overflow: hidden;
  border-radius: 999px;
  background: rgba(255,255,255,.16);
  transform: translateY(-50%);
}
.home-scroll-meter span {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(180deg, var(--gold-light), #fff);
  transform: scaleY(.02);
  transform-origin: top;
}
.home-scroll-cue {
  position: absolute;
  z-index: 4;
  left: clamp(1.25rem, 4vw, 4.5rem);
  bottom: clamp(1.35rem, 4vh, 2.5rem);
  display: inline-flex;
  align-items: center;
  gap: .75rem;
  color: rgba(255,255,255,.56);
  font-size: .74rem;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.home-scroll-cue i {
  width: 58px;
  height: 1px;
  overflow: hidden;
  background: rgba(255,255,255,.18);
}
.home-scroll-cue i::after {
  content: '';
  display: block;
  width: 42%;
  height: 100%;
  background: var(--gold-light);
  animation: homeScrollCue 1.65s ease-in-out infinite;
}
@keyframes homeScrollCue {
  0% { transform: translateX(-110%); }
  100% { transform: translateX(250%); }
}

/* === ABOUT US === */
.home-about {
  position: relative;
  overflow: hidden;
  min-height: auto;
  padding: clamp(6.25rem, 8vw, 8.75rem) clamp(1.25rem, 5vw, 5rem);
  color: #f8f5ed;
  background:
    radial-gradient(circle at 14% 24%, rgba(229,201,136,.1), transparent 29%),
    radial-gradient(circle at 88% 68%, rgba(255,255,255,.055), transparent 30%),
    linear-gradient(135deg, #070706 0%, #11100c 50%, #030303 100%);
}
.home-about-bg,
.home-about-bg span {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.home-about-bg span:first-child {
  background:
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(rgba(255,255,255,.026) 1px, transparent 1px);
  background-size: 72px 72px;
  opacity: .2;
  mask-image: radial-gradient(ellipse at 48% 52%, black 0%, transparent 72%);
  -webkit-mask-image: radial-gradient(ellipse at 48% 52%, black 0%, transparent 72%);
}
.home-about-bg span:last-child {
  background: linear-gradient(180deg, rgba(0,0,0,.3), rgba(0,0,0,0) 28%, rgba(0,0,0,.36));
}
.home-about-inner {
  position: relative;
  z-index: 1;
  width: min(100%, 1360px);
  margin-inline: auto;
  display: grid;
  grid-template-columns: minmax(380px, .92fr) minmax(520px, 1.08fr);
  align-items: center;
  gap: clamp(3rem, 5vw, 5.8rem);
}
.home-about-copy {
  min-width: 0;
  max-width: 700px;
  padding: clamp(1.45rem, 2.4vw, 2.35rem) 0;
  transform-origin: center center;
  will-change: transform;
}
.about-reveal {
  opacity: 0;
  filter: none;
  transform: translate3d(0, 34px, 0);
  transform-origin: center center;
  will-change: opacity, filter, transform;
}
.home-about.is-visible .about-reveal {
  opacity: 1;
  filter: none;
  transform: translate3d(0, 0, 0);
  transition: opacity .9s ease, transform .9s cubic-bezier(.22,1,.36,1);
}
.home-about.is-visible .about-reveal:nth-child(2) {
  transition-delay: .1s;
}
.home-about.is-visible .about-reveal:nth-child(3) {
  transition-delay: .22s;
}
.home-about.is-visible .about-reveal:nth-child(4) {
  transition-delay: .34s;
}
.home-about-eyebrow {
  display: flex;
  align-items: center;
  gap: .55rem;
  width: fit-content;
  margin: 0 0 .85rem;
  color: rgba(244,226,168,.94);
  font-size: .72rem;
  font-weight: 820;
  letter-spacing: .2em;
  text-transform: uppercase;
}
.home-about-eyebrow::before {
  content: '';
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: var(--gold-light);
  box-shadow: 0 0 18px rgba(229,201,136,.7);
}
.home-about h2 {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  width: min(100%, 700px);
  max-width: none;
  margin: 0 0 1.35rem;
  padding: 0 0 .34em;
  color: #f8f5ed;
  background: linear-gradient(180deg, #fffdf7 0%, #f4e7c4 46%, #c9a961 100%);
  -webkit-background-clip: text;
  background-clip: text;
  font-family: Georgia, 'Times New Roman', serif;
  font-size: clamp(3.45rem, 4.15vw, 5.2rem);
  font-weight: 520;
  line-height: .92;
  letter-spacing: 0;
  -webkit-text-fill-color: transparent;
  white-space: normal;
  overflow: visible;
  overflow-wrap: normal;
  word-break: normal;
  text-shadow:
    0 28px 78px rgba(0,0,0,.44),
    0 0 34px rgba(229,201,136,.08);
}
.home-about h2::after {
  content: '';
  display: block;
  width: min(320px, 64%);
  height: 1px;
  margin-top: .32em;
  background: linear-gradient(90deg, rgba(229,201,136,.82), rgba(255,255,255,.42), transparent);
  box-shadow: 0 0 24px rgba(229,201,136,.22);
}
.home-about-title span,
.home-about-title em {
  display: block;
  max-width: 100%;
}
.home-about-title span {
  display: block;
  white-space: nowrap;
  text-wrap: balance;
  overflow: visible;
}
.home-about-title em {
  width: fit-content;
  align-self: flex-start;
  margin-top: .04em;
  margin-left: clamp(2.6rem, 6vw, 5rem);
  padding: 0 .04em .02em;
  font-style: italic;
  font-size: .58em;
  font-weight: 430;
  letter-spacing: 0;
  line-height: 1;
  background: linear-gradient(110deg, #ffffff 0%, #ead18a 38%, #9f8339 72%, #fff7dc 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.home-about p {
  position: relative;
  max-width: 50ch;
  margin: 0;
  padding: 1.2rem 0 0;
  border-top: 1px solid rgba(229,201,136,.32);
  border-left: 0;
  color: rgba(248,245,237,.8);
  font-size: clamp(1rem, 1.02vw, 1.1rem);
  font-weight: 340;
  letter-spacing: .006em;
  line-height: 1.82;
  text-wrap: pretty;
  text-shadow: 0 14px 34px rgba(0,0,0,.24);
}
.home-about-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .8rem;
  margin-top: 2rem;
}
.home-about-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: .78rem 1.08rem;
  border: 1px solid rgba(229,201,136,.34);
  border-radius: 999px;
  color: #15120d;
  background: linear-gradient(135deg, #fff8df 0%, #d1b15e 100%);
  box-shadow: 0 18px 48px rgba(0,0,0,.28);
  font-size: .84rem;
  font-weight: 760;
  transition: transform .25s ease, border-color .25s ease, background .25s ease, color .25s ease;
}
.home-about-link:hover {
  transform: translateY(-1px);
}
.home-about-link--ghost {
  color: rgba(248,245,237,.88);
  background: rgba(255,255,255,.06);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}
.home-about-gallery {
  position: relative;
  height: clamp(520px, 66vh, 660px);
  min-height: 520px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(.85rem, 1.8vw, 1.2rem);
  overflow: hidden;
  border-radius: 8px;
  box-shadow: 0 36px 110px rgba(0,0,0,.36);
}
.home-about-gallery::before,
.home-about-gallery::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  z-index: 2;
  height: 18%;
  pointer-events: none;
}
.home-about-gallery::before {
  top: 0;
  background: linear-gradient(180deg, #0c0a07, transparent);
}
.home-about-gallery::after {
  bottom: 0;
  background: linear-gradient(0deg, #0c0a07, transparent);
}
.home-about-lane {
  overflow: hidden;
}
.home-about-track {
  display: grid;
  gap: clamp(.85rem, 1.8vw, 1.2rem);
  animation: aboutVerticalScroll 32s linear infinite;
  will-change: transform;
}
.home-about-lane--reverse .home-about-track {
  animation-name: aboutVerticalScrollReverse;
  animation-duration: 36s;
}
.home-about-photo {
  width: 100%;
  aspect-ratio: 16 / 11;
  overflow: hidden;
  display: block;
  border: 1px solid rgba(229,201,136,.14);
  border-radius: 8px;
  box-shadow: 0 22px 70px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.08);
  background: rgba(255,255,255,.035);
}
.home-about-photo img,
.home-about-track img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  filter: saturate(.92) contrast(1.03);
}
.home-about-gallery:hover .home-about-track {
  animation-play-state: paused;
}
@keyframes aboutVerticalScroll {
  0% { transform: translateY(0); }
  100% { transform: translateY(calc(-50% - .6rem)); }
}
@keyframes aboutVerticalScrollReverse {
  0% { transform: translateY(calc(-50% - .6rem)); }
  100% { transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
  .about-reveal {
    opacity: 1;
    filter: none;
    transform: none;
  }
  .home-about-copy {
    transform: none;
  }
}

@media (max-width: 1280px) {
  .home-scroll-copy h1,
  .home-scroll-copy h2 {
    font-size: clamp(4.85rem, 7.2vw, 6.1rem);
  }
  .home-about-inner {
    width: min(100%, 1160px);
    grid-template-columns: minmax(330px, .9fr) minmax(430px, 1.1fr);
    gap: clamp(2rem, 4vw, 4rem);
  }
  .home-about h2 {
    font-size: clamp(3.05rem, 4vw, 4.45rem);
  }
}

@media (max-width: 1100px) {
  .home-about {
    padding-block: clamp(4.8rem, 7vw, 6.25rem);
  }
  .home-about-inner {
    width: min(100%, 1000px);
    grid-template-columns: minmax(0, .9fr) minmax(360px, 1fr);
    gap: clamp(1.8rem, 4vw, 3.2rem);
  }
  .home-about-copy {
    max-width: 520px;
    text-align: left;
  }
  .home-about h2 {
    width: min(100%, 520px);
    max-width: none;
    margin-left: 0;
    margin-right: 0;
    text-align: left;
    font-size: clamp(2.9rem, 5.2vw, 4rem);
    line-height: .94;
    align-items: flex-start;
  }
  .home-about-title span {
    white-space: nowrap;
  }
  .home-about-title em {
    align-self: flex-start;
    margin: .08em 0 0 2.2rem;
    padding-inline: .04em;
    font-size: .6em;
  }
  .home-about h2::after {
    margin-inline: 0;
    background: linear-gradient(90deg, rgba(229,201,136,.82), rgba(255,255,255,.44), transparent);
  }
  .home-about p {
    max-width: 46ch;
    margin-inline: 0;
    padding: 1rem 0 0;
    border-top: 1px solid rgba(229,201,136,.32);
    border-left: 0;
    font-size: clamp(.96rem, 1.5vw, 1.04rem);
    line-height: 1.82;
  }
  .home-about-eyebrow,
  .home-about-actions {
    justify-content: flex-start;
  }
  .home-about-gallery {
    width: 100%;
    height: clamp(440px, 58vh, 560px);
    min-height: 440px;
  }
}

@media (max-width: 968px) {
  .home-scroll-sticky {
    min-height: 660px;
  }
  .home-scroll-panel {
    padding: 7.6rem 1.15rem 6.4rem;
  }
  .home-scroll-copy {
    transform: translateY(clamp(5.25rem, 13vh, 7.5rem));
  }
  .home-scroll-copy h1,
  .home-scroll-copy h2 {
    font-size: clamp(3.75rem, 9vw, 4.65rem);
    line-height: .9;
  }
  .home-scroll-copy p {
    font-size: 1.02rem;
    line-height: 1.72;
  }
  .home-scroll-meter {
    display: none;
  }
  .home-scroll-cue {
    display: none;
  }
  .home-about {
    padding-block: clamp(4.6rem, 8vw, 5.8rem);
  }
  .home-about-inner {
    grid-template-columns: 1fr;
    gap: clamp(2.2rem, 6vw, 3.5rem);
  }
  .home-about-copy {
    max-width: min(100%, 680px);
    text-align: center;
    margin-inline: auto;
    padding-block: 0;
  }
  .home-about h2 {
    display: flex;
    margin-inline: auto;
    text-align: center;
    max-width: min(100%, 620px);
    font-size: clamp(2.8rem, 7.4vw, 4.2rem);
    white-space: normal;
    align-items: center;
  }
  .home-about-title span {
    white-space: nowrap;
  }
  .home-about-title em {
    align-self: center;
    margin-inline: auto;
    padding-left: .04em;
  }
  .home-about h2::after {
    margin-inline: auto;
    background: linear-gradient(90deg, transparent, rgba(229,201,136,.82), rgba(255,255,255,.44), transparent);
  }
  .home-about p {
    max-width: 54ch;
    margin-inline: auto;
    padding: 1rem 0 0;
    border-top: 1px solid rgba(229,201,136,.28);
    border-left: 0;
    line-height: 1.78;
  }
  .home-about-eyebrow,
  .home-about-actions {
    justify-content: center;
  }
  .home-about-eyebrow {
    width: fit-content;
    margin-inline: auto;
    margin-bottom: .8rem;
  }
  .home-about-gallery {
    width: min(100%, 760px);
    height: clamp(440px, 58vh, 540px);
    min-height: 420px;
    margin-inline: auto;
  }
}

@media (max-width: 640px) {
  .home-scroll-panel {
    padding: 7rem 1rem 5.8rem;
  }
  .home-scroll-copy {
    transform: translateY(clamp(4rem, 10vh, 5.6rem));
  }
  .home-scroll-nav {
    width: auto;
    max-width: calc(100% - 1.5rem);
  }
  .home-scroll-nav button {
    flex: 1;
    min-width: 0;
    padding-inline: .42rem;
    font-size: .58rem;
  }
  .home-scroll-copy h1,
  .home-scroll-copy h2 {
    font-size: clamp(2.85rem, 13vw, 3.55rem);
    line-height: .92;
  }
  .home-scroll-index {
    min-height: 31px;
    font-size: .62rem;
  }
  .home-scroll-copy p {
    max-width: 20rem;
  }
  .home-about {
    padding: 4.5rem 1rem;
  }
  .home-about-inner {
    gap: 2rem;
  }
  .home-about h2 {
    max-width: min(100%, 22rem);
    font-size: clamp(2.35rem, 10vw, 3.05rem);
    line-height: .98;
    white-space: normal;
  }
  .home-about-title span {
    white-space: normal;
    text-wrap: balance;
  }
  .home-about-title em {
    align-self: center;
    margin: .1em auto 0;
    font-size: .76em;
  }
  .home-about p {
    max-width: 33rem;
    font-size: .96rem;
    line-height: 1.68;
    padding-top: .9rem;
  }
  .home-about-actions {
    flex-direction: column;
    width: min(100%, 19rem);
    margin-inline: auto;
    margin-top: 1.55rem;
  }
  .home-about-link {
    width: 100%;
  }
  .home-about-gallery {
    height: clamp(430px, 62vh, 540px);
    min-height: 430px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .65rem;
    overflow: hidden;
    border-radius: 8px;
  }
  .home-about-gallery::before,
  .home-about-gallery::after {
    display: block;
  }
  .home-about-lane {
    overflow: hidden;
  }
  .home-about-lane--reverse {
    display: block;
  }
  .home-about-track {
    grid-template-columns: 1fr;
    gap: .65rem;
    animation: aboutVerticalScroll 30s linear infinite;
  }
  .home-about-lane--reverse .home-about-track {
    animation-name: aboutVerticalScrollReverse;
    animation-duration: 34s;
  }
  .home-about-photo {
    aspect-ratio: 16 / 11;
  }
}

/* === HOME SERVICE SHOWCASES === */
.service-showcase {
  --service-card-w: clamp(370px, 32vw, 455px);
  --service-fade: clamp(2.25rem, 5vw, 4.25rem);
  position: relative;
  isolation: isolate;
  overflow: hidden;
  padding: clamp(6.8rem, 11vw, 9.5rem) 0 clamp(5.6rem, 8vw, 7rem);
  color: #fff;
  background:
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,0) 22%, rgba(229,201,136,.055) 100%),
    linear-gradient(135deg, #111112 0%, #1b1915 48%, #09090a 100%);
}
.service-showcase--injectables {
  color: var(--dark);
  background:
    radial-gradient(circle at 14% 16%, rgba(229,201,136,.22), transparent 30%),
    radial-gradient(circle at 86% 24%, rgba(132,190,184,.13), transparent 28%),
    linear-gradient(180deg, #ffffff 0%, #faf8f2 44%, #f1eadf 100%);
}
.service-showcase--injectables .service-showcase-grid {
  background:
    linear-gradient(rgba(26,26,26,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(26,26,26,.03) 1px, transparent 1px);
  opacity: .44;
}
.service-showcase--injectables .service-showcase-beam {
  background: linear-gradient(90deg, transparent, rgba(201,169,97,.36), rgba(26,26,26,.08), transparent);
}
.service-showcase--injectables .service-showcase-ring {
  border-color: rgba(201,169,97,.16);
  box-shadow: inset 0 0 72px rgba(201,169,97,.06), 0 0 58px rgba(201,169,97,.06);
}
.service-showcase--injectables .service-showcase-eyebrow {
  border-color: rgba(201,169,97,.26);
  background: rgba(255,255,255,.66);
  color: rgba(26,26,26,.66);
  box-shadow: 0 16px 40px rgba(26,26,26,.08), inset 0 1px 0 rgba(255,255,255,.82);
}
.service-showcase--injectables .service-showcase-title {
  text-shadow: 0 24px 72px rgba(26,26,26,.08);
}
.service-showcase--injectables .service-showcase-title-main {
  color: var(--dark);
}
.service-showcase--injectables .service-showcase-title-line {
  background: linear-gradient(110deg, #17130d 0%, #8b7530 40%, #c9a961 72%, #17130d 100%);
  -webkit-background-clip: text;
  background-clip: text;
}
.service-showcase--injectables .service-showcase-lead {
  color: rgba(26,26,26,.64);
}
.service-showcase-bg,
.service-showcase-grid,
.service-showcase-beam,
.service-showcase-ring {
  position: absolute;
  pointer-events: none;
}
.service-showcase-bg {
  inset: 0;
  z-index: 0;
  overflow: hidden;
}
.service-showcase-grid {
  inset: 0;
  background:
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size: 82px 82px;
  opacity: .48;
  mask-image: linear-gradient(180deg, transparent, black 16%, black 82%, transparent);
  -webkit-mask-image: linear-gradient(180deg, transparent, black 16%, black 82%, transparent);
}
.service-showcase-beam {
  width: min(780px, 74vw);
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(229,201,136,.46), rgba(255,255,255,.24), transparent);
  opacity: .5;
  filter: blur(.4px);
  animation: serviceBeamDrift 18s ease-in-out infinite alternate;
}
.service-showcase-beam-1 {
  left: -10%;
  top: 24%;
  transform: rotate(-13deg);
}
.service-showcase-beam-2 {
  right: -18%;
  bottom: 20%;
  transform: rotate(10deg);
  animation-duration: 22s;
  animation-direction: alternate-reverse;
}
.service-showcase-ring {
  left: 50%;
  top: 48%;
  width: min(92vw, 1120px);
  aspect-ratio: 1 / .34;
  border: 1px solid rgba(229,201,136,.13);
  border-radius: 50%;
  box-shadow: inset 0 0 72px rgba(229,201,136,.055), 0 0 58px rgba(229,201,136,.055);
  opacity: .46;
  transform: translate(-50%, -50%) rotate(-7deg);
  animation: serviceRingFloat 22s ease-in-out infinite alternate;
}
.service-showcase-head {
  position: relative;
  z-index: 2;
  display: grid;
  justify-items: center;
  margin-bottom: clamp(2.2rem, 4.8vw, 3.7rem);
  overflow: visible;
  text-align: center;
}
.service-showcase-eyebrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  margin-bottom: clamp(1.05rem, 2.2vw, 1.45rem);
  padding: .48rem .95rem;
  border: 1px solid rgba(229,201,136,.25);
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  box-shadow: 0 18px 46px rgba(0,0,0,.2), inset 0 1px 0 rgba(255,255,255,.12);
  color: rgba(255,255,255,.72);
  font-size: .76rem;
  line-height: 1.25;
  backdrop-filter: blur(14px) saturate(150%);
  -webkit-backdrop-filter: blur(14px) saturate(150%);
}
.service-showcase-eyebrow .dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--gold);
  box-shadow: 0 0 14px rgba(229,201,136,.8);
}
.service-showcase-title {
  display: grid;
  justify-items: center;
  gap: .32rem;
  width: 100%;
  max-width: min(100%, 1120px);
  margin: 0 0 clamp(1.1rem, 2.2vw, 1.55rem);
  line-height: 1;
  text-shadow: 0 24px 72px rgba(0,0,0,.34);
}
.service-showcase-title-main {
  display: block;
  max-width: 100%;
  color: #fff;
  font-size: clamp(3.8rem, 10.2vw, 9.4rem);
  font-weight: 840;
  letter-spacing: -.046em;
  line-height: .9;
  overflow-wrap: normal;
  word-break: normal;
}
.service-showcase-title-line {
  display: inline-block;
  padding: .02em .06em .18em;
  background: linear-gradient(135deg, #fff 0%, var(--gold-light) 42%, var(--gold) 72%, #fff 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-family: Georgia, 'Times New Roman', serif;
  font-size: clamp(2.1rem, 5.6vw, 4.9rem);
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1.05;
}
.service-showcase-lead {
  max-width: 700px;
  margin: 0 auto;
  color: rgba(255,255,255,.68);
  font-size: clamp(.98rem, 1.25vw, 1.12rem);
  font-weight: 300;
  line-height: 1.72;
}
.service-showcase-eyebrow,
.service-showcase-title,
.service-showcase-lead,
.service-head-actions,
.biohack-eyebrow,
.biohack-title,
.biohack-lead,
.biohack-head-actions {
  transform-origin: center center;
  backface-visibility: hidden;
  will-change: transform, opacity, filter;
}
.service-showcase-title,
.biohack-title {
  max-width: min(100%, 1120px);
  padding-inline: clamp(.2rem, 1.8vw, 1rem);
  overflow: visible;
  transform-box: border-box;
  contain: layout;
}
.biohack-title-main {
  max-width: 100%;
  font-size: clamp(3.8rem, 10.2vw, 9.4rem);
  letter-spacing: -.046em;
  overflow-wrap: normal;
  word-break: normal;
}
.biohack-title-line {
  font-size: clamp(2.1rem, 5.6vw, 4.9rem);
}
.service-rail-wrap {
  position: relative;
  z-index: 2;
  max-width: 1480px;
  margin: 0 auto;
}
.service-rail {
  display: flex;
  gap: clamp(1rem, 2vw, 1.35rem);
  overflow-x: auto;
  overflow-y: hidden;
  padding: 2.4rem max(var(--service-fade), calc((100% - var(--service-card-w)) / 2)) 5.4rem;
  scroll-behavior: smooth;
  scroll-padding: max(var(--service-fade), calc((100% - var(--service-card-w)) / 2));
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  -ms-overflow-style: none;
  cursor: grab;
  user-select: none;
  touch-action: pan-y;
  overscroll-behavior-x: contain;
  -webkit-overflow-scrolling: touch;
}
.service-rail::-webkit-scrollbar {
  display: none;
}
.service-rail.is-dragging {
  cursor: grabbing;
  scroll-behavior: auto;
  scroll-snap-type: none;
}
.service-rail.is-dragging .service-card {
  pointer-events: none;
}
.service-card {
  --service-rail-scale: 1;
  --service-rail-y: 8px;
  --service-rail-focus: .6;
  flex: 0 0 var(--service-card-w);
  scroll-snap-align: center;
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 382px;
  padding: clamp(1.35rem, 2.2vw, 1.75rem);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 8px;
  overflow: hidden;
  background:
    linear-gradient(145deg, rgba(255,255,255,.96), rgba(247,245,240,.9) 68%, rgba(229,201,136,.1)),
    #fff;
  color: var(--dark);
  box-shadow:
    0 18px 44px rgba(0,0,0,.13),
    inset 0 1px 0 rgba(255,255,255,.82);
  opacity: calc(.86 + (var(--service-rail-focus) * .14));
  transform: translate3d(0, var(--service-rail-y), 0) scale(var(--service-rail-scale));
  transition: transform .36s cubic-bezier(.22,.72,.22,1), border-color .3s ease, box-shadow .36s ease, opacity .3s ease, background .3s ease;
}
.service-card::before {
  content: '';
  position: absolute;
  inset: -1px;
  background:
    radial-gradient(circle at 18% 8%, rgba(255,255,255,.78), transparent 20%),
    linear-gradient(180deg, rgba(255,255,255,.28), transparent 48%);
  opacity: .56;
  transition: opacity .28s ease;
  pointer-events: none;
}
.service-card::after {
  content: '';
  position: absolute;
  inset: auto 1.2rem 1.2rem;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(201,169,97,.46), transparent);
  opacity: .42;
  pointer-events: none;
}
.service-card > * {
  position: relative;
  z-index: 1;
}
.service-card:hover {
  border-color: rgba(229,201,136,.34);
  box-shadow:
    0 20px 50px rgba(0,0,0,.16),
    inset 0 1px 0 rgba(255,255,255,.86);
  transform: translate3d(0, calc(var(--service-rail-y) - 3px), 0) scale(var(--service-rail-scale));
}
.service-card.is-rail-active {
  z-index: 2;
  border-color: rgba(229,201,136,.3);
  box-shadow:
    0 22px 54px rgba(0,0,0,.16),
    inset 0 1px 0 rgba(255,255,255,.88);
}
.service-rail.is-scrolling .service-card::before {
  opacity: .58;
}
.service-card-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: clamp(1.6rem, 3vw, 2.35rem);
}
.service-icon {
  width: 46px;
  height: 46px;
  flex: 0 0 46px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(26,26,26,.1);
  border-radius: 8px;
  background:
    linear-gradient(145deg, rgba(255,255,255,.92), rgba(229,201,136,.12)),
    rgba(255,255,255,.74);
  color: var(--dark);
  box-shadow: 0 14px 36px rgba(26,26,26,.08), inset 0 1px 0 rgba(255,255,255,.9);
  transition: transform .35s ease, background .35s ease, color .35s ease, border-color .35s ease;
}
.service-card:hover .service-icon,
.service-card.is-rail-active .service-icon {
  transform: translateY(-1px);
  background: rgba(255,255,255,.94);
  color: var(--gold-deep);
  border-color: rgba(201,169,97,.3);
}
.service-cat {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 28px;
  padding: .36rem .68rem;
  border: 1px solid rgba(201,169,97,.24);
  border-radius: 999px;
  background: rgba(255,255,255,.62);
  color: var(--gold-deep);
  font-size: .62rem;
  font-weight: 800;
  letter-spacing: .18em;
  line-height: 1;
  text-transform: uppercase;
}
.service-card h3 {
  margin: 0 0 .85rem;
  color: var(--dark);
  font-size: clamp(1.55rem, 2.1vw, 2.1rem);
  font-weight: 720;
  letter-spacing: -.035em;
  line-height: 1.04;
}
.service-card p {
  flex: 1;
  color: rgba(26,26,26,.62);
  font-size: clamp(.95rem, 1vw, 1.02rem);
  line-height: 1.68;
}
.service-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin: 1.3rem 0 1.2rem;
}
.service-card-meta span {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: .34rem .62rem;
  border: 1px solid rgba(26,26,26,.08);
  border-radius: 999px;
  background: rgba(255,255,255,.58);
  color: rgba(26,26,26,.56);
  font-size: .68rem;
  font-weight: 700;
}
.service-link-static {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  width: fit-content;
  margin-top: auto;
  color: var(--dark);
  font-size: .78rem;
  font-weight: 780;
  letter-spacing: .13em;
  line-height: 1;
  text-transform: uppercase;
  transition: color .28s ease, gap .28s ease;
}
.service-link-static::before {
  content: '';
  width: 22px;
  height: 1px;
  background: currentColor;
  transition: width .28s ease;
}
.service-link-static:hover {
  gap: .8rem;
  color: var(--gold-deep);
}
.service-link-static:hover::before {
  width: 32px;
}
.service-rail-nav {
  position: absolute;
  top: 48%;
  z-index: 5;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 50%;
  color: #fff;
  background: rgba(255,255,255,.12);
  box-shadow: 0 16px 40px rgba(0,0,0,.24), inset 0 1px 0 rgba(255,255,255,.12);
  cursor: pointer;
  backdrop-filter: blur(14px) saturate(150%);
  -webkit-backdrop-filter: blur(14px) saturate(150%);
  transition: transform .3s ease, background .3s ease, color .3s ease, opacity .3s ease, border-color .3s ease;
}
.service-rail-prev {
  left: .9rem;
  transform: translateY(-50%);
}
.service-rail-next {
  right: .9rem;
  transform: translateY(-50%);
}
.service-rail-nav:hover {
  color: var(--dark);
  background: var(--gold);
  border-color: var(--gold);
}
.service-rail-prev:hover {
  transform: translateY(-50%) translateX(-2px);
}
.service-rail-next:hover {
  transform: translateY(-50%) translateX(2px);
}
.service-rail-nav:disabled {
  opacity: 0;
  pointer-events: none;
}
.service-rail-progress {
  position: relative;
  z-index: 4;
  width: min(260px, calc(100% - 3rem));
  height: 3px;
  margin: -2rem auto 0;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
}
.service-rail-progress-bar {
  width: 20%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--gold-light), var(--gold), #fff);
  transform-origin: left;
  transition: width .3s ease, transform .3s ease;
}
@keyframes serviceBeamDrift {
  0% { opacity: .24; translate: -3% 0; }
  48% { opacity: .62; }
  100% { opacity: .34; translate: 6% 18px; }
}
@keyframes serviceRingFloat {
  0% { transform: translate(-50%, -50%) rotate(-7deg) scale(1); opacity: .32; }
  100% { transform: translate(-50%, calc(-50% - 15px)) rotate(5deg) scale(1.05); opacity: .54; }
}

@media (max-width: 968px) {
  .service-showcase {
    --service-card-w: min(82vw, 390px);
    padding-block: 6rem 5.2rem;
  }
  .service-showcase-title-main,
  .biohack-title-main {
    font-size: clamp(3.7rem, 16vw, 7.6rem);
  }
  .service-showcase-title-line,
  .biohack-title-line {
    font-size: clamp(2.1rem, 8.5vw, 4.4rem);
  }
  .service-rail-nav {
    display: none;
  }
  .service-card {
    min-height: 370px;
    padding: 1.45rem;
  }
}

@media (max-width: 640px) {
  .service-showcase {
    --service-card-w: min(86vw, 350px);
    padding-block: 5.3rem 4.9rem;
  }
  .service-showcase-title,
  .biohack-title {
    max-width: min(100%, 24rem);
    padding-inline: .25rem;
  }
  .service-showcase-title-main,
  .biohack-title-main {
    font-size: clamp(2.85rem, 14vw, 5.1rem);
    letter-spacing: -.04em;
  }
  .service-showcase-title-line,
  .biohack-title-line {
    font-size: clamp(1.85rem, 8vw, 3.05rem);
  }
  .service-showcase-lead,
  .biohack-lead {
    font-size: .96rem;
    line-height: 1.66;
  }
  .service-rail {
    padding-top: 1.65rem;
    padding-bottom: 4.8rem;
  }
  .service-card {
    min-height: 392px;
    padding: 1.25rem;
  }
  .service-card h3 {
    font-size: 1.45rem;
  }
  .service-card p {
    font-size: .92rem;
    line-height: 1.6;
  }
}

/* Match the visible Biohack card treatment */
.service-rail {
  gap: clamp(1rem, 2vw, 1.45rem);
  padding-top: 2rem;
}
.service-card {
  min-height: 410px;
  border-color: rgba(255,255,255,.13);
  border-radius: 24px;
  background:
    linear-gradient(145deg, rgba(255,255,255,.105), rgba(255,255,255,.035)),
    rgba(255,255,255,.035);
  color: #fff;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.13),
    0 30px 74px rgba(0,0,0,.34);
  opacity: calc(.88 + (var(--service-rail-focus) * .12));
  transition: transform .28s cubic-bezier(.22,.72,.22,1), border-color .24s ease, box-shadow .28s ease, opacity .24s ease;
}
.service-card::before {
  background:
    radial-gradient(circle at 18% 16%, rgba(229,201,136,.2), transparent 30%),
    radial-gradient(circle at 86% 0%, rgba(132,190,184,.12), transparent 30%);
  opacity: .82;
}
.service-card::after {
  background: linear-gradient(90deg, transparent, rgba(229,201,136,.4), transparent);
  opacity: .35;
}
.service-card:hover,
.service-card.is-rail-active {
  border-color: rgba(229,201,136,.32);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.16),
    0 32px 78px rgba(0,0,0,.42);
}
.service-icon {
  border-color: rgba(255,255,255,.12);
  background:
    linear-gradient(145deg, rgba(255,255,255,.12), rgba(255,255,255,.045)),
    rgba(0,0,0,.18);
  color: rgba(255,245,218,.95);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.12);
}
.service-card:hover .service-icon,
.service-card.is-rail-active .service-icon {
  background:
    linear-gradient(145deg, rgba(229,201,136,.2), rgba(255,255,255,.065)),
    rgba(0,0,0,.16);
  color: var(--gold-light);
  border-color: rgba(229,201,136,.28);
}
.service-cat {
  border-color: rgba(229,201,136,.28);
  background: rgba(229,201,136,.1);
  color: rgba(255,238,194,.9);
}
.service-card h3 {
  color: #fff;
  line-height: 1.1;
}
.service-card p {
  color: rgba(255,255,255,.66);
}
.service-card-meta span {
  border-color: rgba(255,255,255,.1);
  background: rgba(255,255,255,.055);
  color: rgba(255,255,255,.68);
}
.service-link-static {
  color: rgba(255,245,218,.96);
}
.service-link-static:hover {
  color: var(--gold-light);
}
.service-rail-nav {
  background: rgba(255,255,255,.1);
  border-color: rgba(255,255,255,.16);
}
.service-rail-progress {
  width: min(220px, calc(100% - 3rem));
  height: 2px;
  background: rgba(255,255,255,.13);
}
.service-rail-progress-bar {
  background: linear-gradient(90deg, rgba(245,225,168,.92), rgba(201,169,97,.88));
  transition: width .24s ease, transform .24s ease;
}
.service-showcase--injectables .service-card {
  border-color: rgba(18,18,18,.14);
  background:
    radial-gradient(circle at 18% 16%, rgba(229,201,136,.18), transparent 31%),
    radial-gradient(circle at 88% 0%, rgba(132,190,184,.1), transparent 34%),
    linear-gradient(145deg, rgba(30,29,27,.98), rgba(13,13,13,.98) 68%, rgba(6,6,6,.98));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.13),
    0 28px 68px rgba(26,26,26,.2),
    0 10px 28px rgba(26,26,26,.12);
}
.service-showcase--injectables .service-card::before {
  background:
    radial-gradient(circle at 18% 16%, rgba(229,201,136,.22), transparent 31%),
    linear-gradient(180deg, rgba(255,255,255,.09), transparent 48%);
  opacity: .78;
}
.service-showcase--injectables .service-card:hover,
.service-showcase--injectables .service-card.is-rail-active {
  border-color: rgba(201,169,97,.38);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.16),
    0 32px 72px rgba(26,26,26,.26),
    0 12px 32px rgba(201,169,97,.1);
}
.service-showcase--injectables .service-rail-nav {
  color: #fff;
  background: rgba(14,14,14,.82);
  border-color: rgba(201,169,97,.22);
  box-shadow: 0 16px 40px rgba(26,26,26,.16), inset 0 1px 0 rgba(255,255,255,.12);
}
.service-showcase--injectables .service-rail-nav:hover {
  color: var(--dark);
  background: var(--gold);
  border-color: var(--gold);
}
.service-showcase--injectables .service-rail-progress {
  background: rgba(26,26,26,.12);
}
.service-showcase--injectables .service-rail-progress-bar {
  background: linear-gradient(90deg, rgba(139,117,48,.9), rgba(201,169,97,.94));
}

/* Keep the Google rating card readable while the review title animates. */
.reviews-rating {
  opacity: 1 !important;
  transform: none !important;
  filter: none !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.88)),
    rgba(255,255,255,.9) !important;
  border-color: rgba(201,169,97,.28) !important;
  box-shadow:
    0 24px 60px rgba(26,26,26,.09),
    inset 0 1px 0 rgba(255,255,255,.78) !important;
}
.reviews-rating .rating-num,
.reviews-rating .stars,
.reviews-rating .rating-meta,
.reviews-rating .rating-tags {
  opacity: 1;
}

/* === HOME BIOHACK MENU TOGGLE === */
.service-head-actions,
.biohack-head-actions {
  display: flex;
  justify-content: center;
  margin-top: 1.35rem;
}
.biohack-menu-toggle {
  min-height: 44px;
  padding: .78rem 1.18rem;
  border: 1px solid rgba(229,201,136,.36);
  border-radius: 999px;
  color: #15120d;
  background: linear-gradient(135deg, #fff8df 0%, #d4b45f 100%);
  box-shadow: 0 18px 48px rgba(0,0,0,.24), inset 0 1px 0 rgba(255,255,255,.36);
  font-size: .84rem;
  font-weight: 780;
  transition: transform .25s ease, box-shadow .25s ease;
}
.biohack-menu-toggle:hover {
  transform: translateY(-1px);
  box-shadow: 0 22px 58px rgba(0,0,0,.3), inset 0 1px 0 rgba(255,255,255,.42);
}

@media (max-width: 640px) {
  .service-head-actions,
  .biohack-head-actions {
    margin-top: 1.1rem;
  }
  .biohack-menu-toggle {
    min-height: 40px;
    padding: .7rem 1rem;
    font-size: .78rem;
  }
}

