/* Virtual nail try-on — photo hand + SVG nail masks (Beyond Polish style) */



.vns-overlay {

  position: fixed;

  inset: 0;

  z-index: 2000;

  display: none;

  align-items: center;

  justify-content: center;

  padding: 1rem;

}



.vns-overlay.is-open {

  display: flex;

}



.vns-overlay[hidden] {

  display: none !important;

}



body.vns-open {

  overflow: hidden;

}



.vns-overlay-backdrop {

  position: absolute;

  inset: 0;

  background: rgba(42, 31, 35, 0.55);

  backdrop-filter: blur(4px);

}



.vns-overlay-dialog {

  position: relative;

  z-index: 1;

  width: min(1120px, 100%);

  max-height: min(94vh, 960px);

  overflow: auto;

  border-radius: 1.1rem;

  border: 1px solid rgba(199, 91, 111, 0.22);

  background: linear-gradient(180deg, #fffcfa 0%, #faf6f2 100%);

  box-shadow: 0 24px 64px rgba(58, 47, 50, 0.22);

  outline: none;

}



.vns-overlay-header {

  display: flex;

  align-items: flex-start;

  justify-content: space-between;

  gap: 1rem;

  padding: 1rem 1.25rem;

  border-bottom: 1px solid rgba(199, 91, 111, 0.12);

}



.vns-overlay-body {

  padding: 1rem 1.25rem 1.25rem;

}



.vns-layout {

  display: grid;

  grid-template-columns: 1fr min(300px, 32%);

  gap: 1.5rem;

  align-items: start;

}



@media (max-width: 767.98px) {

  .vns-layout {

    grid-template-columns: 1fr;

  }

}



.vns-stage {

  background: radial-gradient(ellipse 80% 70% at 50% 40%, rgba(255, 255, 255, 0.95), rgba(243, 236, 230, 0.6));

  border-radius: 1rem;

  padding: 1rem 0.5rem 0.75rem;

  min-height: 280px;

  display: flex;

  flex-direction: column;

  align-items: center;

}



.vns-hand-wrap {

  width: 100%;

  margin-inline: auto;

}



.vns-viewport {

  width: 100%;

  max-width: 560px;

  margin-inline: auto;

  aspect-ratio: 1380 / 752;

  overflow: hidden;

  border-radius: 0.85rem;

  box-shadow: 0 14px 36px rgba(58, 47, 50, 0.14);

  background: #f5ebe6;

  touch-action: none;

  cursor: default;

}



.vns-viewport.is-zoomed {

  cursor: grab;

}



.vns-viewport.is-hand-magnify:not(.is-zoomed):not(.is-panning) {

  cursor: crosshair;

}



.vns-hand-magnifier-lens {

  position: fixed;

  top: 0;

  left: 0;

  z-index: 2100;

  pointer-events: none;

  border-radius: 50%;

  border: 3px solid #fff;

  box-shadow: 0 14px 40px rgba(58, 47, 50, 0.32), inset 0 0 0 1px rgba(199, 91, 111, 0.28);

  overflow: hidden;

  opacity: 0;

  visibility: hidden;

  transition: opacity 0.12s ease, visibility 0.12s ease;

  background: #f5ebe6;

}



.vns-hand-magnifier-lens.is-visible {

  opacity: 1;

  visibility: visible;

}



.vns-hand-magnifier-mirror {

  position: absolute;

  top: 0;

  left: 0;

  transform-origin: 0 0;

  will-change: transform;

}



.vns-hand-magnifier-mirror .vns-zoom-layer {

  width: 100%;

  height: 100%;

}



.vns-zoom-layer {

  width: 100%;

  height: 100%;

  transform-origin: center center;

  will-change: transform;

}



.vns-zoom-layer.is-animating {

  transition: transform 0.2s ease;

}



.vns-viewport.is-hand-both {

  max-width: 800px;

}



.vns-viewport.is-hand-left,
.vns-viewport.is-hand-right {

  max-width: 560px;

}



.vns-photo-frame {

  position: relative;

  width: 100%;

  aspect-ratio: 1380 / 752;

  overflow: hidden;

  background: #f5ebe6;

}



.vns-hand-crop {

  position: relative;

  width: 100%;

  height: 100%;

  overflow: hidden;

}



.vns-hand-crop-inner {

  position: relative;

  width: 100%;

  height: 100%;

  transition: transform 0.28s ease, width 0.28s ease;

}



.vns-hand-wrap.is-hand-left .vns-hand-crop-inner,
.vns-hand-wrap.is-hand-right .vns-hand-crop-inner {

  width: 200%;

}



.vns-hand-wrap.is-hand-right .vns-hand-crop-inner {

  transform: translateX(-50%);

}



.vns-hand-wrap.is-hand-both .vns-hand-crop-inner {

  width: 100%;

  transform: translateX(0);

}



.vns-hand-wrap.is-hand-both .vns-hand-photo {

  object-position: center center;

}



.vns-zoom-label {

  align-self: center;

  min-width: 3rem;

  text-align: center;

  font-weight: 600;

}



.vns-zoom-btn {

  min-width: 2.5rem;

  font-size: 1rem;

  line-height: 1;

}



.vns-zoom-btn:disabled {

  opacity: 0.45;

  cursor: not-allowed;

}



.vns-polish-svg,

.vns-design-svg,

.vns-mask-debug-svg {

  position: absolute;

  inset: 0;

  width: 100%;

  height: 100%;

  pointer-events: none;

}



.vns-hand-photo {

  width: 100%;

  height: 100%;

  object-fit: cover;

  object-position: left center;

  display: block;

}



/* Opaque mask fill — matches color selector swatch (default) */

.vns-polish-svg {

  mix-blend-mode: normal;

}



.vns-polish-fill {

  opacity: 1;

  transition: fill 0.3s ease;

}



.vns-photo-frame.blend-multiply .vns-polish-svg {

  mix-blend-mode: multiply;

}



.vns-photo-frame.blend-overlay .vns-polish-svg {

  mix-blend-mode: overlay;

}



.vns-photo-frame.blend-hard-light .vns-polish-svg {

  mix-blend-mode: hard-light;

}



.vns-photo-frame.blend-normal .vns-polish-svg {

  mix-blend-mode: normal;

}



.vns-nail-mask-path {

  stroke: none;

}



.vns-photo-frame:not(.blend-normal).finish-shimmer .vns-polish-svg,

.vns-photo-frame:not(.blend-normal).finish-pearl .vns-polish-svg {

  mix-blend-mode: color;

  opacity: 0.92;

}



.vns-photo-frame:not(.blend-normal).finish-glitter .vns-polish-svg {

  mix-blend-mode: hard-light;

  opacity: 0.9;

}



.vns-photo-frame:not(.blend-normal).finish-matte .vns-polish-svg {

  mix-blend-mode: multiply;

}



.vns-photo-frame:not(.blend-normal).finish-neon .vns-polish-svg {

  mix-blend-mode: screen;

  opacity: 0.95;

}



.vns-mask-debug-path {

  fill: rgba(255, 255, 255, 0.45);

  stroke: rgba(199, 91, 111, 0.55);

  stroke-width: 1.5;

}



.vns-show-masks-label {

  display: inline-flex;

  align-items: center;

  cursor: pointer;

  color: var(--spa-text-muted, #6b5c60);

}



.vns-hand-tools {

  display: flex;

  flex-wrap: wrap;

  gap: 0.4rem;

  justify-content: center;

  margin-top: 0.75rem;

}



.vns-tool-btn {

  min-height: 40px;

  padding: 0.35rem 0.85rem;

  font-size: 0.8rem;

  font-weight: 600;

  border-radius: 999px;

  border: 1px solid rgba(199, 91, 111, 0.25);

  background: rgba(255, 255, 255, 0.9);

  color: var(--spa-text, #3a2f32);

}



.vns-tool-btn.active {

  background: var(--spa-brand-rose-soft, #fceef2);

  border-color: var(--spa-brand-rose, #c75b6f);

  color: var(--spa-brand-rose-deep, #a84458);

}



.vns-side {

  display: flex;

  flex-direction: column;

  gap: 1rem;

}



.vns-color-info {

  padding: 0.85rem 1rem;

  border-radius: 0.85rem;

  background: rgba(255, 255, 255, 0.85);

  border: 1px solid rgba(199, 91, 111, 0.14);

}



.vns-color-swatch-lg {

  width: 56px;

  height: 56px;

  border-radius: 50%;

  border: 3px solid #fff;

  box-shadow: 0 4px 14px rgba(58, 47, 50, 0.15);

  flex-shrink: 0;

}



.vns-color-swatch-magnify[data-magnify="color"] {

  cursor: crosshair;

}



@media (hover: hover) and (pointer: fine) {

  .vns-color-swatch-magnify[data-magnify="color"]:hover {

    box-shadow: 0 0 0 3px rgba(199, 91, 111, 0.35);

  }



  .vns-design-chip[data-magnify]:hover {

    box-shadow: 0 0 0 2px rgba(199, 91, 111, 0.35);

  }

}



.vns-design-chip[data-magnify="color"],

.vns-design-chip[data-magnify="image"] {

  cursor: crosshair;

}



.vns-skin-panel label {

  font-size: 0.7rem;

  font-weight: 600;

  text-transform: uppercase;

  letter-spacing: 0.1em;

  color: var(--spa-text-muted, #6b5c60);

  margin-bottom: 0.5rem;

  display: block;

}



.vns-skin-range {

  width: 100%;

  accent-color: var(--spa-brand-rose, #c75b6f);

  min-height: 44px;

}



.vns-skin-labels {

  display: flex;

  justify-content: space-between;

  font-size: 0.72rem;

  color: var(--spa-text-muted, #6b5c60);

  margin-top: 0.25rem;

}



.vns-skin-chips {

  display: flex;

  flex-wrap: wrap;

  gap: 0.35rem;

  margin-top: 0.5rem;

}



.vns-skin-chip {

  position: relative;

  width: 36px;

  height: 36px;

  border-radius: 50%;

  border: 2px solid transparent;

  cursor: pointer;

  padding: 0;

}



.vns-skin-chip.active {

  border-color: var(--spa-brand-rose, #c75b6f);

  box-shadow: 0 0 0 2px rgba(199, 91, 111, 0.25);

}



.vns-skin-chip span {

  position: absolute;

  width: 1px;

  height: 1px;

  overflow: hidden;

  clip: rect(0, 0, 0, 0);

}



.vns-note {

  font-size: 0.75rem;

  color: var(--spa-text-muted, #6b5c60);

  line-height: 1.45;

  margin: 0;

}



/* Homepage preview — SVG masks */

.home-color-selector-hand-preview .vns-home-photo-frame {

  position: relative;

  max-width: 280px;

  margin-inline: auto;

  aspect-ratio: 1380 / 752;

  border-radius: 0.85rem;

  overflow: hidden;

  box-shadow: 0 12px 28px rgba(58, 47, 50, 0.14);

}



.home-color-selector-hand-preview .vns-home-hand {

  width: 100%;

  height: 100%;

  object-fit: cover;

  display: block;

}



.home-color-selector-hand-preview .vns-home-polish-svg {

  position: absolute;

  inset: 0;

  width: 100%;

  height: 100%;

  pointer-events: none;

}



.home-color-selector-hand-preview .vns-home-polish-svg {

  mix-blend-mode: normal;

}



.home-color-selector-hand-preview .vns-home-polish-fill {

  opacity: 1;

}



.color-result-card.is-tryable {

  cursor: pointer;

}



.color-try-btn {

  min-height: 44px;

  border-radius: 999px;

  font-weight: 600;

  font-size: 0.9rem;

}



.color-result-card.is-tryable .color-try-hint {

  font-size: 0.75rem;

  color: var(--spa-brand-rose-deep, #a84458);

  font-weight: 600;

  margin-top: 0.35rem;

}



.color-result-swatch-btn {

  border: none;

  padding: 0;

  background: none;

  cursor: pointer;

  border-radius: 50%;

}



.color-result-swatch-btn[data-magnify="color"] {

  cursor: crosshair;

}



@media (hover: hover) and (pointer: fine) {

  .color-result-swatch-btn[data-magnify="color"]:hover {

    box-shadow: 0 0 0 3px rgba(199, 91, 111, 0.35);

  }

}



.color-result-swatch-btn:focus-visible {

  outline: 2px solid var(--spa-brand-rose, #c75b6f);

  outline-offset: 3px;

}



.vns-close-btn {

  width: 2.75rem;

  height: 2.75rem;

  padding: 0;

  flex-shrink: 0;

  opacity: 0.75;

}



.vns-mobile-close-bar {

  display: none;

}



@media (min-width: 768px) and (max-width: 991.98px) {

  .vns-overlay-dialog {

    width: min(960px, 100%);

  }



  .vns-viewport.is-hand-both {

    max-width: 680px;

  }



  .vns-viewport.is-hand-left,
  .vns-viewport.is-hand-right {

    max-width: 480px;

  }

}



@media (max-width: 767.98px) {

  .vns-overlay {

    align-items: flex-end;

    justify-content: center;

    padding: 0;

  }



  .vns-overlay-dialog {

    width: 100%;

    max-height: 92vh;

    border-radius: 1.25rem 1.25rem 0 0;

    display: flex;

    flex-direction: column;

    overflow: hidden;

  }



  .vns-overlay-body {

    flex: 1;

    overflow-y: auto;

    padding: 0.85rem 1rem 0.5rem;

    -webkit-overflow-scrolling: touch;

  }



  .vns-overlay-header {

    padding: 0.85rem 1rem;

    position: sticky;

    top: 0;

    z-index: 2;

    background: linear-gradient(180deg, #fffcfa 0%, #faf6f2 100%);

  }



  .vns-close-btn {

    width: 3rem;

    height: 3rem;

    opacity: 1;

    background-color: rgba(255, 255, 255, 0.9);

    border-radius: 50%;

    box-shadow: 0 2px 8px rgba(58, 47, 50, 0.12);

  }



  .vns-desktop-close {

    display: none;

  }



  .vns-mobile-close-bar {

    display: block;

    flex-shrink: 0;

    position: sticky;

    bottom: 0;

    z-index: 3;

    padding: 0.75rem 1rem calc(0.75rem + env(safe-area-inset-bottom, 0px));

    background: linear-gradient(180deg, rgba(250, 246, 242, 0.92) 0%, #faf6f2 100%);

    border-top: 1px solid rgba(199, 91, 111, 0.14);

    box-shadow: 0 -8px 24px rgba(58, 47, 50, 0.08);

  }



  .vns-mobile-close-btn {

    min-height: 52px;

    font-size: 1rem;

    font-weight: 700;

  }



  .vns-viewport.is-hand-both {

    max-width: 100%;

  }



  .vns-viewport.is-hand-left,
  .vns-viewport.is-hand-right {

    max-width: 100%;

  }



  .vns-layout,
  .vns-stage,
  .vns-side,
  .vns-viewport,
  .vns-overlay-body {

    min-width: 0;

    max-width: 100%;

  }



  .vns-hand-tools[aria-label="Paint nails"] {

    display: grid;

    grid-template-columns: repeat(3, minmax(0, 1fr));

    gap: 0.45rem;

  }



  .vns-hand-tools[aria-label="Paint hand"] {

    display: grid;

    grid-template-columns: repeat(2, minmax(0, 1fr));

    gap: 0.45rem;

  }



  .vns-hand-tools[aria-label="Zoom"] {

    display: grid;

    grid-template-columns: repeat(3, minmax(0, 1fr));

    gap: 0.45rem;

  }



  .vns-hand-tools[aria-label="Paint hand"] .vns-tool-btn:first-child {

    grid-column: 1 / -1;

  }



  .vns-hand-tools[aria-label="Polish blend"] {

    display: grid;

    grid-template-columns: repeat(2, minmax(0, 1fr));

    gap: 0.45rem;

  }



  .vns-hand-tools .vns-tool-btn,
  .vns-hand-tools .vns-zoom-btn {

    width: 100%;

    min-height: 44px;

    padding-inline: 0.45rem;

    font-size: 0.74rem;

  }



  .vns-hand-tools .vns-zoom-label {

    grid-column: 1 / -1;

    width: 100%;

  }



  .vns-design-scroll {

    display: grid;

    grid-template-columns: repeat(auto-fill, minmax(4.25rem, 1fr));

    gap: 0.5rem;

    overflow: visible;

    padding-bottom: 0;

    scroll-snap-type: none;

  }



  .vns-design-chip {

    flex: unset;

    width: auto;

    scroll-snap-align: unset;

  }

}



.vns-design-svg {

  position: absolute;

  inset: 0;

  width: 100%;

  height: 100%;

  pointer-events: none;

  mix-blend-mode: normal;

}



.vns-design-panel label.vns-design-panel-label {

  font-size: 0.7rem;

  font-weight: 600;

  text-transform: uppercase;

  letter-spacing: 0.1em;

  color: var(--spa-text-muted, #6b5c60);

  margin-bottom: 0.5rem;

  display: block;

}



.vns-design-scroll {

  display: flex;

  gap: 0.5rem;

  overflow-x: auto;

  padding-bottom: 0.35rem;

  scroll-snap-type: x proximity;

  -webkit-overflow-scrolling: touch;

}



.vns-design-chip {

  flex: 0 0 auto;

  scroll-snap-align: start;

  display: flex;

  flex-direction: column;

  align-items: center;

  gap: 0.25rem;

  width: 4.5rem;

  padding: 0.35rem;

  border-radius: 0.75rem;

  border: 2px solid rgba(199, 91, 111, 0.18);

  background: rgba(255, 255, 255, 0.92);

  cursor: pointer;

  position: relative;

}



.vns-design-chip.active {

  border-color: var(--spa-brand-rose, #c75b6f);

  box-shadow: 0 0 0 2px rgba(199, 91, 111, 0.2);

  background: var(--spa-brand-rose-soft, #fceef2);

}



.vns-design-chip--recommended {

  box-shadow: 0 0 0 2px rgba(212, 175, 55, 0.45);

}



.vns-design-chip--recommended:not(.active)::after {

  content: "★";

  position: absolute;

  top: 0.15rem;

  right: 0.2rem;

  font-size: 0.65rem;

  color: #b8860b;

  line-height: 1;

}



.vns-design-chip img {

  width: 2.5rem;

  height: 4rem;

  object-fit: contain;

  pointer-events: none;

}



.vns-design-chip-name {

  font-size: 0.62rem;

  line-height: 1.2;

  text-align: center;

  color: var(--spa-text-muted, #6b5c60);

  max-width: 100%;

  overflow: hidden;

  text-overflow: ellipsis;

  white-space: nowrap;

}



.vns-design-chip-none {

  display: flex;

  align-items: center;

  justify-content: center;

  width: 2.5rem;

  height: 4rem;

  font-size: 0.72rem;

  font-weight: 600;

  color: var(--spa-text-muted, #6b5c60);

}



.vns-compare-panel label.vns-compare-panel-label {

  font-size: 0.7rem;

  font-weight: 600;

  text-transform: uppercase;

  letter-spacing: 0.1em;

  color: var(--spa-text-muted, #6b5c60);

  margin-bottom: 0.5rem;

  display: block;

}



.vns-compare-scroll {

  display: flex;

  flex-direction: column;

  gap: 0.45rem;

  max-height: 220px;

  overflow-y: auto;

  padding-right: 0.15rem;

}



.vns-compare-chip {

  display: flex;

  align-items: center;

  gap: 0.65rem;

  width: 100%;

  padding: 0.45rem 0.55rem;

  border-radius: 0.75rem;

  border: 2px solid rgba(199, 91, 111, 0.18);

  background: rgba(255, 255, 255, 0.92);

  cursor: pointer;

  text-align: left;

}



.vns-compare-chip.active {

  border-color: var(--spa-brand-rose, #c75b6f);

  box-shadow: 0 0 0 2px rgba(199, 91, 111, 0.2);

  background: var(--spa-brand-rose-soft, #fceef2);

}



.vns-compare-swatch {

  width: 2rem;

  height: 2rem;

  border-radius: 50%;

  border: 2px solid #fff;

  box-shadow: 0 2px 8px rgba(58, 47, 50, 0.12);

  flex-shrink: 0;

}



.vns-compare-label {

  display: flex;

  flex-direction: column;

  min-width: 0;

}



.vns-compare-brand {

  font-size: 0.72rem;

  font-weight: 600;

  color: var(--spa-text, #3a2f32);

}



.vns-compare-name,
.vns-compare-code {

  font-size: 0.68rem;

  color: var(--spa-text-muted, #6b5c60);

  overflow: hidden;

  text-overflow: ellipsis;

  white-space: nowrap;

}



.vns-compare-active-row {

  display: flex;

  align-items: center;

  gap: 0.65rem;

  padding: 0.55rem 0.65rem;

  border-radius: 0.75rem;

  background: rgba(255, 255, 255, 0.85);

  border: 1px solid rgba(199, 91, 111, 0.14);

  margin-bottom: 0.65rem;

}



.vns-compare-active-swatch {

  width: 2.25rem;

  height: 2.25rem;

  border-radius: 50%;

  border: 2px solid #fff;

  box-shadow: 0 2px 8px rgba(58, 47, 50, 0.12);

  flex-shrink: 0;

}



.swatch-magnify-lens {

  position: fixed;

  top: 0;

  left: 0;

  z-index: 3000;

  pointer-events: none;

  border-radius: 50%;

  border: 3px solid #fff;

  box-shadow: 0 12px 36px rgba(58, 47, 50, 0.28), inset 0 0 0 1px rgba(199, 91, 111, 0.25);

  overflow: hidden;

  opacity: 0;

  visibility: hidden;

  transition: opacity 0.12s ease, visibility 0.12s ease;

  background: #faf6f2;

}



.swatch-magnify-lens.is-visible {

  opacity: 1;

  visibility: visible;

}



.swatch-magnify-lens-inner {

  width: 100%;

  height: 100%;

  overflow: hidden;

  border-radius: 50%;

  display: flex;

  align-items: center;

  justify-content: center;

  position: relative;

}



.swatch-magnify-lens-inner.is-composite .swatch-magnify-color {

  position: absolute;

  inset: 0;

  transform: none !important;

}



.swatch-magnify-lens-inner.is-composite .swatch-magnify-img {

  position: absolute;

  inset: 0;

  object-fit: contain;

  z-index: 1;

}



.swatch-magnify-color {

  width: 100%;

  height: 100%;

  transform-origin: center center;

}



.swatch-magnify-img {

  width: 100%;

  height: 100%;

  object-fit: cover;

  transform-origin: center center;

}


