/* Virtual nail try-on — salon-branded hand preview + SVG nail masks */



.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;

  pointer-events: auto;

  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;

  border-radius: 0.95rem;

  background: linear-gradient(165deg, #fceef2 0%, #f8f4ec 52%, #fffdf8 100%);

  border: 1px solid rgba(201, 162, 44, 0.28);

  box-shadow:

    0 18px 42px rgba(168, 68, 88, 0.14),

    inset 0 1px 0 rgba(255, 255, 255, 0.75);

}



.vns-photo-frame.is-model-flatlay::after {

  content: "";

  position: absolute;

  inset: 0;

  z-index: 3;

  pointer-events: none;

  border-radius: inherit;

  background:

    radial-gradient(ellipse 88% 72% at 50% 42%, transparent 42%, rgba(168, 68, 88, 0.1) 100%),

    linear-gradient(180deg, rgba(252, 238, 242, 0.08), rgba(199, 91, 111, 0.12));

  mix-blend-mode: multiply;

}



.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-backdrop-gradient:

    radial-gradient(ellipse 120% 85% at 50% 18%, rgba(255, 253, 250, 0.96), transparent 58%),

    linear-gradient(165deg, #fceef2 0%, #f5ebe6 42%, #fffdf8 100%);

  --vns-backdrop-image: none;

}



.vns-scene-backdrop {

  position: absolute;

  inset: 0;

  z-index: 0;

  pointer-events: none;

  background: var(--vns-backdrop-gradient), #fceef2;

}



.vns-hand-photo,

.vns-polish-svg,

.vns-design-svg,

.vns-mask-debug-svg {

  position: relative;

  z-index: 1;

}



.vns-photo-frame[data-vns-backdrop="salon"] .vns-scene-backdrop,
.vns-photo-frame.is-model-flatlay .vns-scene-backdrop {

  --vns-backdrop-gradient:

    radial-gradient(ellipse 120% 85% at 50% 18%, rgba(255, 253, 250, 0.96), transparent 58%),

    linear-gradient(165deg, #fceef2 0%, #f5ebe6 42%, #fffdf8 100%);

  --vns-backdrop-image: none;

}



.vns-photo-frame[data-vns-backdrop="gradient"] .vns-scene-backdrop {

  --vns-backdrop-image: none;

  --vns-backdrop-gradient: radial-gradient(ellipse 85% 75% at 50% 42%, rgba(255, 252, 248, 0.92), rgba(237, 226, 216, 0.88));

}



.vns-photo-frame[data-vns-backdrop="marble"] .vns-scene-backdrop {

  --vns-backdrop-gradient: linear-gradient(180deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.04));

  --vns-backdrop-image: url("../images/virtual-hands/backdrops/studio-marble.jpg");

}



.vns-photo-frame.is-model-flatlay .vns-hand-photo {

  filter: saturate(1.08) contrast(1.05) hue-rotate(-8deg) brightness(1.02);

}



.vns-photo-frame.is-model-flatlay .vns-hand-wrap.is-hand-both .vns-hand-crop-inner {

  transform: scale(1.38);

  transform-origin: 50% 44%;

}



.vns-photo-frame.is-model-flatlay .vns-hand-wrap.is-hand-left .vns-hand-crop-inner {

  transform: scale(1.38);

  transform-origin: 50% 44%;

}



.vns-photo-frame.is-model-flatlay .vns-hand-wrap.is-hand-right .vns-hand-crop-inner {

  transform: translateX(-50%) scale(1.38);

  transform-origin: 50% 44%;

}



.vns-home-photo-frame {

  --vns-backdrop-gradient:

    radial-gradient(ellipse 120% 85% at 50% 18%, rgba(255, 253, 250, 0.96), transparent 58%),

    linear-gradient(165deg, #fceef2 0%, #f5ebe6 42%, #fffdf8 100%);

  --vns-backdrop-image: none;

  position: relative;

  border: 1px solid rgba(201, 162, 44, 0.22);

}



.vns-home-photo-frame::after {

  content: "";

  position: absolute;

  inset: 0;

  z-index: 2;

  pointer-events: none;

  border-radius: inherit;

  background: linear-gradient(180deg, rgba(252, 238, 242, 0.1), rgba(199, 91, 111, 0.1));

  mix-blend-mode: multiply;

}



.vns-home-photo-frame .vns-scene-backdrop {

  position: absolute;

  inset: 0;

  z-index: 0;

  pointer-events: none;

  border-radius: inherit;

  background: var(--vns-backdrop-gradient), #fceef2;

}



.vns-home-photo-frame .vns-home-hand,

.vns-home-photo-frame .vns-home-polish-svg {

  position: relative;

  z-index: 1;

}



.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: center center;

  display: block;

}



.vns-processed-preview {

  position: absolute;

  inset: 0;

  width: 100%;

  height: 100%;

  object-fit: cover;

  object-position: left center;

  display: block;

  pointer-events: none;

  z-index: 1;

  opacity: 0;

  transition: opacity 0.2s ease;

}



.vns-processed-preview.is-active {

  opacity: 0.42;

}



/* Opaque mask fill — matches color selector swatch (default) */

.vns-polish-svg {

  mix-blend-mode: normal;

}



.vns-photo-frame.is-vns-masks-pending .vns-polish-svg,
.vns-photo-frame.is-vns-masks-pending .vns-design-svg {

  opacity: 0;

  pointer-events: none;

}



.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: color;

  opacity: 0.98;

  filter: saturate(1.35);

}



.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;

  position: relative;

  z-index: 2;

}



.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-hand-photo-panel {
  margin-top: 1.25rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(58, 47, 50, 0.08);
}

.vns-hand-photo-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.35rem;
  display: block;
}

.vns-hand-photo-actions .btn {
  font-size: 0.72rem;
}

.vns-hand-align-panel,
.vns-detect-panel {
  margin-top: 0.75rem;
  padding-top: 0.75rem;
  border-top: 1px dashed rgba(58, 47, 50, 0.12);
}

.vns-detect-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.35rem;
  display: block;
}

.vns-detect-panel .btn-primary {
  font-size: 0.72rem;
}

.vns-detect-status {
  line-height: 1.35;
}

.vns-detect-fix-panel .btn {
  font-size: 0.72rem;
}

.vns-hand-align-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.35rem;
  display: block;
}

.vns-align-range-label {
  font-size: 0.72rem !important;
  font-weight: 600 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  display: flex !important;
  justify-content: space-between;
  align-items: center;
}

.vns-align-range {
  width: 100%;
  accent-color: var(--spa-brand-rose, #c75b6f);
  min-height: 36px;
}

.vns-hand-crop.is-custom-hand-mode {
  cursor: default;
}

.vns-hand-photo.is-custom-active {
  position: relative;
  z-index: 0;
  pointer-events: auto;
  cursor: grab;
  touch-action: none;
}

.vns-hand-crop.is-custom-hand-mode {
  overflow: hidden;
  isolation: isolate;
}

.vns-hand-photo.is-custom-active.is-dragging {
  cursor: grabbing;
}

.vns-style-panel {
  margin-top: 1.25rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(58, 47, 50, 0.08);
}

.vns-style-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.35rem;
  display: block;
}

.vns-variant-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

.vns-variant-chip {
  font-size: 0.72rem;
  line-height: 1.2;
  padding: 0.35rem 0.65rem;
  border-radius: 999px;
  border: 1px solid rgba(58, 47, 50, 0.14);
  background: rgba(255, 255, 255, 0.85);
  color: var(--spa-text, #3a2f32);
  cursor: pointer;
  transition: border-color 0.15s ease, background-color 0.15s ease, box-shadow 0.15s ease;
}

.vns-variant-chip:hover {
  border-color: rgba(199, 91, 111, 0.45);
}

.vns-variant-chip.active {
  border-color: var(--spa-brand-rose, #c75b6f);
  background: rgba(199, 91, 111, 0.1);
  box-shadow: 0 0 0 2px rgba(199, 91, 111, 0.15);
}



.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;

  filter: saturate(1.08) contrast(1.05) hue-rotate(-8deg) brightness(1.02);

  transform: scale(1.38);

  transform-origin: 50% 44%;

}



.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,
.vns-save-panel label.vns-save-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;

}


