/* Asesor de Revestimiento Plugin Styles */

#ar-plugin-container {
  --bg-base: #F4F4F4;
  --accent: #296DD1;
  --accent-light: #3a7ee2;
  --accent-pale: #ebf2fc;
  --accent-glow: rgba(41, 109, 209, 0.18);
  --text-dark: #1C1C1C;
  --text-mid: rgba(28, 28, 28, 0.6);
  --text-light: #888888;
  --border: #E0E0E0;
  --white: #ffffff;
  --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.05);
  --shadow-md: 0 8px 30px rgba(0, 0, 0, 0.08);
  --radius: 18px;
  --radius-sm: 10px;
  --transition: 0.35s cubic-bezier(0.4, 0, 0.2, 1);

  position: relative;
  font-family: 'Outfit', sans-serif;
  color: var(--text-dark);
  line-height: 1.6;
  overflow-x: hidden;
  /* Dynamic offset for WordPress headers */
  padding-top: var(--wp-header-height, 0px);
  scroll-margin-top: var(--wp-header-height, 0px);
}

#ar-plugin-container * {
  box-sizing: border-box;
}

/* ── Background ──────────────────────────────── */
#ar-plugin-container .bg-layer {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background: var(--bg-base);
}

#ar-plugin-container .bg-noise {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  opacity: 0.02;
  background-image: url("data:image/svg+xml,%3Csvg width='200' height='200' viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");
}

/* ── Wrapper ─────────────────────────────────── */
#ar-plugin-container .configurator {
  position: relative;
  z-index: 1;
  width: 100%;
  margin: 0 auto;
}

/* ── Header ──────────────────────────────────── */
#ar-plugin-container .hdr {
  text-align: center;
  margin-bottom: 44px;
  padding-bottom: 36px;
  border-bottom: 1px solid var(--border);
}

#ar-plugin-container .eyebrow {
  font-size: 10.5px;
  letter-spacing: 0.26em;
  font-weight: 600;
  color: var(--accent);
  text-transform: uppercase;
  margin-bottom: 16px;
  display: block;
}

#ar-plugin-container .hdr h1 {
  font-family: 'Outfit', sans-serif;
  font-size: clamp(26px, 5vw, 42px);
  font-weight: 600;
  line-height: 1.15;
  color: var(--text-dark);
  margin-bottom: 14px;
}

#ar-plugin-container .hdr h1 em {
  font-style: italic;
  color: var(--accent);
}

#ar-plugin-container .hdr p {
  font-size: 15px;
  color: var(--text-mid);
  max-width: 440px;
  margin: 0 auto;
  line-height: 1;
}

/* ── Progress ────────────────────────────────── */
#ar-plugin-container .progress-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  margin-bottom: 44px;
}

#ar-plugin-container .progress-label {
  font-size: 13px;
  color: var(--text-mid);
  font-weight: 600;
  letter-spacing: 0.04em;
  margin-top: 4px;
}

#ar-plugin-container .progress-dashes {
  display: flex;
  gap: 12px;
  width: 100%;
  max-width: fit-content;
  justify-content: center;
  margin: 0 auto;
}

#ar-plugin-container .dash {
  width: 70px;
  height: 50px;
  border-radius: 12px;
  background: #DCDCDC;
  color: #FFFFFF;
  font-family: 'Outfit', sans-serif;
  font-size: 24px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s ease;
  user-select: none;
}

#ar-plugin-container .dash.done,
#ar-plugin-container .dash.active {
  background: var(--accent);
  color: #FFFFFF;
}

#ar-plugin-container .dash.active {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px var(--accent-glow);
}

/* ── Step Panel ─────────────────────────────── */
#ar-plugin-container .step-panel {
  animation: arFadeUp 0.65s cubic-bezier(0.22, 1, 0.36, 1) both;
}

@keyframes arFadeUp {
  from {
    opacity: 0;
    transform: translateY(40px) scale(0.97);
    filter: blur(10px);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0);
  }
}

@keyframes arSkeleton {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}

#ar-plugin-container .skeleton {
  background: linear-gradient(90deg, #f0f0f0 25%, #f8f8f8 50%, #f0f0f0 75%);
  background-size: 200% 100%;
  animation: arSkeleton 1.5s infinite linear;
}

#ar-plugin-container .step-q {
  margin-bottom: 32px;
}

#ar-plugin-container .step-q h2 {
  font-family: 'Outfit', sans-serif;
  font-size: clamp(21px, 4vw, 30px);
  font-weight: 600;
  color: var(--text-dark);
  margin-bottom: 7px;
  line-height: 1.25;
}

#ar-plugin-container .step-q p {
  font-size: 14px;
  color: var(--text-mid);
}

/* ── Grid layouts ───────────────────────────── */
#ar-plugin-container .grid {
  display: grid;
  gap: 10px;
  margin-bottom: 36px;
}

#ar-plugin-container .grid-2x2 {
  grid-template-columns: repeat(2, 1fr);
}

#ar-plugin-container .grid-3 {
  grid-template-columns: repeat(3, 1fr);
}

#ar-plugin-container .grid-4 {
  grid-template-columns: repeat(4, 1fr);
}

#ar-plugin-container .grid-5 {
  grid-template-columns: repeat(5, 1fr);
}

#ar-plugin-container .grid-tones {
  grid-template-columns: repeat(3, 1fr);
}

#ar-plugin-container .flex-wrap-center {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 16px;
  margin-bottom: 36px;
}

/* Tone grid: auto-fills the row on desktop */
#ar-plugin-container .grid-tones-auto {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: 16px;
  margin-bottom: 36px;
}

/* ── Card base ──────────────────────────────── */
#ar-plugin-container .card {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius);
  border: none;
  cursor: pointer;
  background: var(--white);
  box-shadow: var(--shadow-sm);
  user-select: none;
  -webkit-tap-highlight-color: transparent;
  transition: box-shadow var(--transition), transform var(--transition);
}

#ar-plugin-container .card:hover {
  box-shadow: var(--shadow-md);
}

#ar-plugin-container .card.selected {
  outline: 1.5px solid var(--accent);
  outline-offset: -1.5px;
  box-shadow: 0 0 26px var(--accent-glow), var(--shadow-md);
}

#ar-plugin-container .chk {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 6;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
  border: 2px solid var(--white);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transform: scale(0.5) rotate(-20deg);
  transition: opacity 0.22s, transform 0.32s cubic-bezier(0.34, 1.56, 0.64, 1);
  pointer-events: none;
}

#ar-plugin-container .card.selected .chk {
  opacity: 1;
  transform: scale(1) rotate(0deg);
}

#ar-plugin-container .chk svg {
  width: 12px;
  height: 12px;
  fill: none;
  stroke: white;
  stroke-width: 2.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* visual card */
#ar-plugin-container .card-img {
  width: 100%;
  aspect-ratio: 4/3;
  display: flex;
  align-items: flex-end;
  padding: 16px;
  position: relative;
  background-color: #eee;
  /* Skeleton while loading */
  background-image: linear-gradient(90deg, #f0f0f0 25%, #f8f8f8 50%, #f0f0f0 75%);
  background-size: 200% 100%;
  animation: arSkeleton 1.5s infinite linear;
}

#ar-plugin-container .card-img > * {
  z-index: 2;
}

#ar-plugin-container .card-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 0;
  pointer-events: none;
}

#ar-plugin-container .card-img::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(5, 12, 8, 0.72) 0%, rgba(5, 12, 8, 0.08) 55%, transparent 100%);
  z-index: 1;
}

#ar-plugin-container .card-txt {
  position: relative;
  z-index: 2;
}

#ar-plugin-container .card-name {
  font-family: 'Outfit', sans-serif;
  font-size: 18px;
  font-weight: 600;
  color: white;
  line-height: 1.2;
  margin-bottom: 4px;
}

#ar-plugin-container .card-desc {
  font-size: 13px;
  color: rgba(255, 255, 255, 0.76);
  line-height: 1.5;
}

#ar-plugin-container .card-img.r32 {
  aspect-ratio: 3/2;
}

/* tone card */
#ar-plugin-container .card-tone {
  flex-direction: column;
  width: 100%;
}

#ar-plugin-container .card-tone .card-img {
  aspect-ratio: 1;
}

/* water card */
#ar-plugin-container .card-water {
  flex-direction: column;
}

#ar-plugin-container .card-water .w-vis {
  width: 100%;
  aspect-ratio: 3/2;
  flex-shrink: 0;
  position: relative;
  overflow: hidden;
  background-color: #eee;
  background-image: linear-gradient(90deg, #f0f0f0 25%, #f8f8f8 50%, #f0f0f0 75%);
  background-size: 200% 100%;
  animation: arSkeleton 1.5s infinite linear;
}

#ar-plugin-container .card-water .w-body {
  padding: 13px 15px 15px;
  background: var(--white);
}

#ar-plugin-container .card-water .w-name {
  font-family: 'Outfit', sans-serif;
  font-size: 16px;
  font-weight: 600;
  color: var(--text-dark);
  margin-bottom: 3px;
}

#ar-plugin-container .card-water .w-desc {
  font-size: 13.5px;
  color: var(--text-mid);
  line-height: 1.45;
}

/* Step 1 Colors (with real images) */
#ar-plugin-container .bg-bali {
  background: url('../img/bali.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-boho {
  background: url('../img/boho.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-clasico {
  background: url('../img/clasico.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-ibiza {
  background: url('../img/ibiza.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-industrial {
  background: url('../img/industrial.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-japandi {
  background: url('../img/japandi.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-lujo {
  background: url('../img/lujo.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-med {
  background: url('../img/mediterraneo.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-moderno {
  background: url('../img/moderno.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-mykonos {
  background: url('../img/mykonos.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-natural {
  background: url('../img/natural-lagoon.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-provenzal {
  background: url('../img/provenzal.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-rustico {
  background: url('../img/rustic-amb.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-spa {
  background: url('../img/spa-wellness.webp') center/cover no-repeat;
}

/* Step 2 & 3 Colors */
#ar-plugin-container .bg-gresite {
  background: url('../img/poster-gresite.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-porcel {
  background: url('../img/poster-porcelanico.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-piedra {
  background: url('../img/poster-bali.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-colores {
  background: url('../img/colores.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-marmol {
  background: url('../img/bali_gresite.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-nacar {
  background: url('../img/nacarados.webp') center/cover no-repeat;
}

/* Porcelanico Finishes */
#ar-plugin-container .bg-p-marmol {
  background: url('../img/p_marmol.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-p-cemento {
  background: url('../img/p_cemento.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-p-piedra {
  background: url('../img/p_piedra.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-p-bali {
  background: url('../img/p_bali.webp') center/cover no-repeat;
}

/* Tone Backgrounds */
#ar-plugin-container .bg-t-azul {
  background: url('../img/t_azul.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-t-verde {
  background: url('../img/t_verde.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-t-blanco {
  background: url('../img/t_blanco.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-t-gris {
  background: url('../img/t_gris.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-t-beige {
  background: url('../img/t_beige.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-t-negro {
  background: url('../img/t_negro.webp') center/cover no-repeat;
}

/* Bali Tone Backgrounds (Gresite > Bali) */
#ar-plugin-container .bg-bt-verde {
  background: url('../img/bt_verde.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-bt-azul {
  background: url('../img/bt_azul.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-bt-beige {
  background: url('../img/bt_beige.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-bt-gris {
  background: url('../img/bt_gris.webp') center/cover no-repeat;
}

/* Nacarados Tone Backgrounds (Gresite > Nacarados) */
#ar-plugin-container .bg-nt-azul {
  background: url('../img/nt_azul.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-nt-verde {
  background: url('../img/nt_verde.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-nt-blanco {
  background: url('../img/nt_blanco.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-nt-beige {
  background: url('../img/nt_beige.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-nt-negro {
  background: url('../img/nt_negro.webp') center/cover no-repeat;
}

/* Porcelánico > Mármol Tone Backgrounds */
#ar-plugin-container .bg-pt-marmol-calacatta {
  background: url('../img/marmol-calacatta.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-pt-marmol-crema-marfil {
  background: url('../img/marmol-crema-marfil.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-pt-marmol-travertino {
  background: url('../img/marmol-travertino.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-pt-marmol-negro {
  background: url('../img/marmol-negro.webp') center/cover no-repeat;
}

/* Porcelánico > Cemento Tone Backgrounds */
#ar-plugin-container .bg-pt-cemento-blanco {
  background: url('../img/cemento-blanco.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-pt-cemento-beige {
  background: url('../img/cemento-beige.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-pt-cemento-gris {
  background: url('../img/cemento-gris.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-pt-cemento-antracita {
  background: url('../img/cemento-antracita.webp') center/cover no-repeat;
}

/* Porcelánico > Piedra Tone Backgrounds */
#ar-plugin-container .bg-pt-piedra-blanco {
  background: url('../img/piedra-blanco.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-pt-piedra-beige {
  background: url('../img/piedra-beige.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-pt-piedra-gris {
  background: url('../img/piedra-gris.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-pt-piedra-negro {
  background: url('../img/piedra-negro.webp') center/cover no-repeat;
}

/* Bali Stone Tone Backgrounds */
#ar-plugin-container .bg-sb-verde {
  background: url('../img/piedra-bali-verde.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-sb-negro {
  background: url('../img/piedra-bali-negro.webp') center/cover no-repeat;
}

/* Porcelánico > Bali Tone Backgrounds */
#ar-plugin-container .bg-pt-bali-verde {
  background: url('../img/p-bali-verde.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-pt-bali-azul {
  background: url('../img/p-bali-azul.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-pt-bali-gris {
  background: url('../img/p-bali-gris.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-pt-bali-beige {
  background: url('../img/p-bali-beige.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-pt-bali-negro {
  background: url('../img/p-bali-negro.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-w508 {
  background: url('../img/Water 508.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-wRoyal {
  background: url('../img/Water Royal.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-wSalt {
  background: url('../img/Water Sea Salt.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-wJungl {
  background: url('../img/Water Jungle.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-wFusn {
  background: url('../img/Water Fusion White.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-wAir {
  background: url('../img/Water Air Force.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-w762 {
  background: url('../img/Water 762.webp') center/cover no-repeat;
}

#ar-plugin-container .bg-w710 {
  background: url('../img/Water 710.webp') center/cover no-repeat;
  animation: none; /* Stop skeleton when image loaded */
}

/* Ensure background images stop skeleton once loaded - using a hack for CSS-only detection or just simple override */
#ar-plugin-container [class^="bg-"] {
  animation: none !important;
}

/* Keep pool areas visible by anchoring image crops lower in the frame */
#ar-plugin-container .card-img[class*="bg-"],
#ar-plugin-container .card-water .w-vis[class*="bg-"],
#ar-plugin-container .sum-thumb {
  background-position: bottom !important;
  background-repeat: no-repeat;
  background-size: cover;
}

/* ── Ripple ─────────────────────────────────── */
#ar-plugin-container .ripple {
  position: absolute;
  border-radius: 50%;
  width: 8px;
  height: 8px;
  background: rgba(61, 122, 95, 0.28);
  transform: scale(0);
  pointer-events: none;
  animation: arRippleAnim 0.55s ease-out forwards;
}

@keyframes arRippleAnim {
  to {
    transform: scale(50);
    opacity: 0;
  }
}

/* ── Navigation ─────────────────────────────── */
#ar-plugin-container .nav-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-top: 4px;
}

#ar-plugin-container .btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 30px;
  border-radius: 999px;
  font-family: 'Outfit', sans-serif;
  font-size: 13.5px;
  font-weight: 600;
  cursor: pointer;
  border: none;
  outline: none;
  line-height: 1;
  letter-spacing: 0.01em;
  transition: 0.3s;
}

#ar-plugin-container .btn-back {
  background: transparent;
  border: 2px solid var(--border);
  color: var(--text-mid);
}

#ar-plugin-container .btn-back:hover {
  border-color: var(--accent);
  color: var(--accent);
  background: var(--accent-pale);
}

#ar-plugin-container .btn-back.invisible {
  visibility: hidden;
  pointer-events: none;
}

#ar-plugin-container .btn-next {
  background: var(--accent);
  color: white;
  box-shadow: 0 4px 20px rgba(41, 109, 209, 0.35);
}

#ar-plugin-container .btn-next:hover:not(:disabled) {
  background: var(--accent-light);
  box-shadow: 0 6px 28px rgba(41, 109, 209, 0.45);
  transform: translateY(-2px);
}

#ar-plugin-container .btn-next:disabled {
  background: var(--cream-dark);
  color: var(--text-light);
  box-shadow: none;
  cursor: not-allowed;
}

#ar-plugin-container .btn svg {
  flex-shrink: 0;
  width: 15px;
  height: 15px;
}

/* ── Lead Step ──────────────────────────────── */
#ar-plugin-container .lead-eyebrow {
  font-size: 10.5px;
  letter-spacing: 0.26em;
  font-weight: 700;
  color: var(--accent);
  text-transform: uppercase;
  margin-bottom: 10px;
  display: block;
}

#ar-plugin-container .lead-h {
  font-family: 'Outfit', sans-serif;
  font-size: clamp(20px, 3.5vw, 28px);
  font-weight: 600;
  color: var(--text-dark);
  line-height: 1.3;
  margin-bottom: 8px;
}

#ar-plugin-container .lead-sub {
  font-size: 14px;
  color: var(--text-mid);
  margin-bottom: 28px;
}

#ar-plugin-container .summary-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px 22px;
  margin-bottom: 28px;
}

#ar-plugin-container .sum-title {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.16em;
  color: var(--text-light);
  text-transform: uppercase;
  margin-bottom: 14px;
}

#ar-plugin-container .sum-items {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px;
}

#ar-plugin-container .sum-item {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--accent-pale);
  padding: 10px;
  border-radius: var(--radius-sm);
  transition: transform 0.3s ease;
}

#ar-plugin-container .sum-item:hover {
  transform: translateY(-2px);
}

#ar-plugin-container .sum-thumb {
  width: 48px;
  height: 48px;
  border-radius: 8px;
  background-size: cover;
  flex-shrink: 0;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  border: 1px solid var(--white);
  position: relative;
  overflow: hidden;
}

#ar-plugin-container .sum-vid {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 1;
}

#ar-plugin-container .sum-details {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

#ar-plugin-container .sum-lbl {
  font-size: 9px;
  color: var(--text-light);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

#ar-plugin-container .sum-val {
  font-size: 13px;
  font-weight: 600;
  color: var(--accent);
}

#ar-plugin-container .f-row {
  display: flex;
  flex-wrap: wrap;
  align-items: end;
  gap: 14px;
  margin-bottom: 20px;
}

#ar-plugin-container .f-grp {
  flex: 1 1 240px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

#ar-plugin-container .submit-actions {
  display: flex;
  gap: 12px;
  margin-bottom: 24px;
}

#ar-plugin-container .btn-submit {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 16px 20px;
  border-radius: var(--radius-sm);
  font-family: 'Outfit', sans-serif;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  border: none;
  transition: 0.3s;
  color: white;
}

#ar-plugin-container .btn-wa {
  background: #25D366;
  box-shadow: 0 4px 14px rgba(37, 211, 102, 0.3);
}

#ar-plugin-container .btn-wa:hover:not(:disabled) {
  background: #20BA5A;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(37, 211, 102, 0.4);
}

#ar-plugin-container .btn-mail {
  background: var(--accent);
  box-shadow: 0 4px 14px rgba(41, 109, 209, 0.3);
}

#ar-plugin-container .btn-mail:hover {
  background: var(--accent-light);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(41, 109, 209, 0.45);
}

#ar-plugin-container .btn-submit svg {
  width: 18px;
  height: 18px;
}

#ar-plugin-container .f-lbl {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.11em;
  line-height: 1;
  color: var(--text-mid);
  text-transform: uppercase;
}

#ar-plugin-container .f-inp {
  padding: 13px 16px;
  border-radius: var(--radius-sm);
  border: 2px solid var(--border);
  background: var(--white);
  font-family: 'Outfit', sans-serif;
  font-size: 14px;
  transition: 0.25s;
  outline: none;
}

#ar-plugin-container .f-inp:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 4px var(--accent-glow);
}

#ar-plugin-container .ty {
  text-align: center;
  padding: 64px 16px;
  animation: arFadeUp 0.5s ease both;
}

#ar-plugin-container .ty-icon {
  width: 76px;
  height: 76px;
  border-radius: 50%;
  background: var(--accent-pale);
  border: 2.5px solid var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 26px;
  font-size: 32px;
}

#ar-plugin-container .ty h2 {
  font-family: 'Outfit', sans-serif;
  font-size: 28px;
  font-weight: 600;
  margin-bottom: 12px;
  color: var(--text-dark);
}

#ar-plugin-container .ty-badge {
  display: inline-block;
  background: var(--accent-pale);
  border: 1px solid rgba(61, 122, 95, 0.3);
  border-radius: 999px;
  padding: 9px 22px;
  font-size: 11.5px;
  font-weight: 700;
  color: var(--accent);
  letter-spacing: 0.09em;
  text-transform: uppercase;
}

/* ── Breadcrumb Trail ───────────────────────────────────── */
#ar-plugin-container .breadcrumb-trail {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  margin-bottom: 24px;
  padding: 10px 16px;
  background: var(--accent-pale);
  border: 1px solid rgba(41, 109, 209, 0.15);
  border-radius: var(--radius-sm);
}

#ar-plugin-container .bc-item {
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
}

#ar-plugin-container .bc-lbl {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-light);
}

#ar-plugin-container .bc-val {
  font-size: 13px;
  font-weight: 600;
  color: var(--accent);
}

#ar-plugin-container .bc-sep {
  font-size: 15px;
  color: var(--border);
  font-weight: 400;
  line-height: 1;
  flex-shrink: 0;
}

/* ── Photo Upload Option ────────────────────────────────── */
#ar-plugin-container .photo-opt {
  margin-bottom: 24px;
  background: var(--white);
  padding: 16px;
  border-radius: var(--radius);
  border: 1px dashed var(--border);
  transition: border-color 0.3s;
}

#ar-plugin-container .photo-opt:hover {
  border-color: var(--accent);
}

#ar-plugin-container .f-chk-label {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  cursor: pointer;
}

#ar-plugin-container .f-chk-text {
  font-size: 14px;
  color: var(--text-dark);
  line-height: 1.45;
  font-weight: 500;
}

#ar-plugin-container input[type="checkbox"] {
  width: 18px;
  height: 18px;
  margin-top: 2px;
  accent-color: var(--accent);
  cursor: pointer;
}
/* ── Photo Opt: example text & before/after grid ────────── */
#ar-plugin-container .photo-example-txt {
  font-size: 13px;
  color: var(--text-mid);
  line-height: 1.5;
  margin: 12px 0 16px;
  font-style: italic;
}

#ar-plugin-container .client-ba-grid {
  display: grid;
  grid-template-columns: repeat(2, 300px);
  gap: 12px;
  margin-top: 16px;
}

#ar-plugin-container .client-ba-item {
  position: relative;
  border-radius: var(--radius-sm);
  overflow: hidden;
  box-shadow: 0 3px 12px rgba(0, 0, 0, 0.12);
  width: 300px;
  height: 300px;
}

#ar-plugin-container .client-ba-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}

#ar-plugin-container .client-ba-item:hover .client-ba-img {
  transform: scale(1.04);
}

#ar-plugin-container .client-ba-tag {
  position: absolute;
  top: 10px;
  left: 10px;
  background: rgba(0, 0, 0, 0.55);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 999px;
  backdrop-filter: blur(4px);
}

#ar-plugin-container .client-ba-tag--after {
  background: var(--accent);
}

@media (max-width: 480px) {
  #ar-plugin-container .client-ba-grid {
    grid-template-columns: 1fr;
    grid-template-columns: 1fr !important;
  }

  #ar-plugin-container .client-ba-img {
    height: 180px;
  }

  #ar-plugin-container .client-ba-item {
     width: 100%;
     height: 180px;
  }
}


#ar-plugin-container .hidden {
  display: none !important;
}


@media (max-width: 768px) {
  #ar-plugin-container .configurator {
    padding: 24px 16px 80px;
  }

  #ar-plugin-container .hdr {
    margin-bottom: 30px;
    padding-bottom: 24px;
  }

  #ar-plugin-container .grid-3,
  #ar-plugin-container .grid-4 {
    grid-template-columns: repeat(2, 1fr);
  }

  #ar-plugin-container .submit-actions {
    flex-direction: column;
  }

  #ar-plugin-container .progress-dashes {
    gap: 8px;
  }
  #ar-plugin-container .dash {
    width: 55px;
    height: 40px;
    font-size: 18px;
    border-radius: 10px;
  }
}

@media (max-width: 480px) {
  #ar-plugin-container .hdr h1 {
    font-size: 24px;
  }

  #ar-plugin-container .grid {
    grid-template-columns: 1fr !important;
  }

  #ar-plugin-container .f-grp {
    flex: 1 1 100%;
  }

  /* Tone grid collapses to 2 per row on mobile */
  #ar-plugin-container .grid-tones-auto {
    grid-template-columns: repeat(2, 1fr);
  }

  #ar-plugin-container .progress-dashes {
    gap: 6px;
  }

  #ar-plugin-container .dash {
    width: 45px;
    height: 35px;
    font-size: 16px;
    border-radius: 8px;
  }
}
