/*
 * ARI Features — UI styles. Reuses the theme's design tokens (defined in the
 * theme's ari.css :root). The fallback :root below keeps the plugin usable if
 * it is ever loaded without the theme; values mirror the theme exactly.
 */
:root{
  --bg:#FDFBF8;--white:#FFFFFF;--pink:#FBE7EC;--peach:#FCEADF;--butter:#FBF1DA;
  --mint:#E7F2EC;--lilac:#F0EAF8;--sky:#E7EFF7;--rose-soft:#F6D2DC;--rose:#C0506A;
  --rose-dk:#A8425A;--text:#41302A;--ink:#33251F;--muted:#8E7E72;
  --r-lg:34px;--r-md:24px;--r-sm:16px;--r-pill:999px;
  --sh:0 14px 40px rgba(74,52,38,.07),0 4px 12px rgba(74,52,38,.04);
  --sh-h:0 26px 64px rgba(74,52,38,.14);--sh-sm:0 6px 18px rgba(74,52,38,.07);
}

/* ===== PDP variation swatches ===== */
.ari-select-hidden{position:absolute!important;width:1px;height:1px;opacity:0;pointer-events:none;clip:rect(0 0 0 0);overflow:hidden}
.ari-swatches{display:flex;flex-wrap:wrap;gap:10px;margin:6px 0 4px}
.ari-swatch{background:none;border:none;padding:0;margin:0;cursor:pointer;line-height:0;font-family:inherit}
.ari-swatch--color .sw{display:block;width:38px;height:38px;border-radius:50%;background:var(--sw,#ccc);border:2.5px solid #fff;box-shadow:0 0 0 1px rgba(0,0,0,.08),var(--sh-sm);transition:transform .2s,box-shadow .2s}
.ari-swatch--color:hover .sw{transform:scale(1.08)}
.ari-swatch--color.is-active .sw{box-shadow:0 0 0 2.5px var(--rose),var(--sh-sm)}
.ari-swatch--color:focus-visible .sw{outline:2.5px solid var(--rose);outline-offset:3px}
.ari-swatch--chip{line-height:1.2;padding:9px 16px;border-radius:var(--r-pill);background:var(--bg);font-size:.82rem;font-weight:600;color:var(--ink);border:1.5px solid transparent;transition:.2s}
.ari-swatch--chip:hover{border-color:var(--rose-soft)}
.ari-swatch--chip.is-active{border-color:var(--rose);background:var(--pink);color:var(--rose-dk)}

/* Wave + length chips: icon above a label, tactile card-ish chip */
.ari-swatch--wave,.ari-swatch--length{display:inline-flex;flex-direction:column;align-items:center;gap:6px;padding:10px 16px;border-radius:var(--r-md);min-width:74px}
.ari-swatch-l{line-height:1.1}
.ari-ic{display:flex;align-items:center;justify-content:center}
.ari-ic--wave{width:36px;height:16px}
.ari-ic--wave svg{width:36px;height:16px;overflow:visible}
.ari-ic--wave svg path{fill:none;stroke:var(--ink);stroke-width:2;stroke-linecap:round;opacity:.65;transition:stroke .2s,opacity .2s}
.ari-swatch--wave:hover .ari-ic--wave svg path{opacity:1}
.ari-swatch--wave.is-active .ari-ic--wave svg path{stroke:var(--rose-dk);opacity:1}
.ari-ic--len{width:22px;height:30px;align-items:flex-end;justify-content:center}
.ari-len-bar{display:block;width:6px;height:var(--h,70%);border-radius:var(--r-pill);background:linear-gradient(180deg,var(--rose-soft),var(--rose));opacity:.7;transition:opacity .2s,transform .2s;transform-origin:bottom}
.ari-swatch--length:hover .ari-len-bar{opacity:1}
.ari-swatch--length.is-active .ari-len-bar{opacity:1}

/* ===== Shade finder (colour comes from --sw) ===== */
.ari-finder .big{background:var(--sw,#9C7240)}
.ari-finder .chip .sw{background:var(--sw,var(--rose-soft))}
.ari-finder #ariFinderShop{margin-top:18px}

/* ===== Sample ring ===== */
.ari-sample-ring{display:flex;flex-wrap:wrap;gap:20px;align-items:center;justify-content:space-between;background:var(--white);border-radius:var(--r-lg);box-shadow:var(--sh-sm);padding:clamp(24px,3vw,40px)}
.ari-sample-ring .asr-info{max-width:48ch}
.ari-sample-ring h3{font-size:1.6rem;margin:8px 0 6px}
.ari-sample-ring p{color:#6c5d50;margin:0;font-size:.95rem}
.ari-sample-ring .asr-action{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.ari-sample-ring .price{font-weight:700;font-size:1.3rem;color:var(--ink)}
.ari-sample-ring .asr-soon{color:var(--muted);font-weight:600}

/* ===== Shared tool shell + segmented controls ===== */
.ari-tool{background:var(--white);border-radius:var(--r-lg);box-shadow:var(--sh-sm);padding:clamp(26px,3.5vw,46px)}
.ari-tool-head{margin-bottom:24px}
.ari-tool-title{font-size:clamp(1.6rem,3vw,2.4rem);margin-top:10px}
.ari-tool-title .fr{color:var(--rose)}
.ari-field{margin-bottom:20px}
.ari-field>label{display:block;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:10px}
.ari-segs{display:flex;flex-wrap:wrap;gap:8px}
.ari-segs--stack{flex-direction:column}
.ari-seg{font-family:inherit;font-size:.84rem;font-weight:600;color:var(--ink);background:var(--bg);border:1.5px solid transparent;border-radius:var(--r-pill);padding:10px 18px;cursor:pointer;transition:.2s}
.ari-seg:hover{border-color:var(--rose-soft)}
.ari-seg.is-active{background:var(--rose);color:#fff;border-color:var(--rose)}
.ari-segs--stack .ari-seg{text-align:left;border-radius:var(--r-md)}

/* ===== Strand helper (formerly gram helper) ===== */
.ari-strand-result{margin-top:8px;background:var(--butter);border-radius:var(--r-md);padding:24px;text-align:center}
.asr-count{font-size:2.4rem;font-weight:700;letter-spacing:-.02em;color:var(--ink)}
.asr-count .asr-unit{font-size:1rem;font-weight:600;color:var(--rose-dk);letter-spacing:0}
.asr-sub{font-weight:600;color:var(--rose-dk);margin-top:2px;font-size:.92rem}
.asr-note{color:#6c5d50;font-size:.9rem;margin:10px 0 0}
.ari-grams-input{display:flex;align-items:center;gap:10px}
.ari-grams-input input{width:120px;font-family:inherit;font-size:.95rem;text-align:center;color:var(--ink);background:var(--bg);border:1.5px solid rgba(58,42,33,.16);border-radius:var(--r-pill);padding:11px 14px}
.ari-grams-input input:focus{outline:none;border-color:var(--rose)}
.ari-grams-unit{font-size:.84rem;font-weight:600;color:var(--muted)}

/* ===== By-strand quantity + live total (PDP/cart) ===== */
.ari-strand-suffix{display:inline-block;margin-left:-2px;font-size:.82rem;font-weight:600;color:var(--muted);white-space:nowrap}

/* PDP: hide the native number field (still submits), hide duplicate var price */
.ari-qty-hidden{position:absolute!important;width:1px;height:1px;opacity:0;pointer-events:none;overflow:hidden;clip:rect(0 0 0 0);margin:0!important}
.ari-by-strand-pdp .woocommerce-variation-price{display:none}

/* Strand slider */
.ari-strand-slider{flex-basis:100%;width:100%;margin:2px 0 4px}
.ass-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:8px}
.ass-label{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:700}
.ass-readout{font-size:.92rem;font-weight:600;color:var(--text)}
.ass-readout .ass-val{font-size:1.15rem;font-weight:700;color:var(--ink)}
.ass-controls{display:flex;align-items:center;gap:12px}
.ass-step{flex:none;width:38px;height:38px;border-radius:50%;border:1.5px solid var(--rose-soft);background:var(--white);color:var(--rose-dk);font-size:1.2rem;font-weight:700;line-height:1;display:flex;align-items:center;justify-content:center;box-shadow:var(--sh-sm);transition:transform .2s,border-color .2s,background .2s}
.ass-step:hover{border-color:var(--rose);background:var(--pink);transform:translateY(-1px)}
.ass-step:active{transform:translateY(0)}
.ass-range{flex:1;-webkit-appearance:none;appearance:none;height:8px;border-radius:var(--r-pill);background:linear-gradient(90deg,var(--rose) 0,var(--rose) var(--fill,0%),var(--rose-soft) var(--fill,0%),var(--rose-soft) 100%);outline-offset:4px}
.ass-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:24px;height:24px;border-radius:50%;background:var(--white);border:3px solid var(--rose);box-shadow:var(--sh-sm);cursor:pointer;transition:transform .15s}
.ass-range::-webkit-slider-thumb:hover{transform:scale(1.12)}
.ass-range::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:var(--white);border:3px solid var(--rose);box-shadow:var(--sh-sm);cursor:pointer}
.ass-range:focus-visible{outline:2.5px solid var(--rose)}

.ari-strand-total{flex-basis:100%;width:100%;display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:8px 16px;margin:4px 0 12px;background:var(--butter);border-radius:var(--r-md);padding:14px 18px}
.ari-strand-total .ast-line{font-size:.9rem;font-weight:600;color:var(--text);display:inline-flex;gap:6px;align-items:baseline;flex-wrap:wrap}
.ari-strand-total .ast-x{color:var(--muted)}
.ari-strand-total .ast-total{display:inline-flex;gap:8px;align-items:baseline}
.ari-strand-total .ast-total-label{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:700}
.ari-strand-total .ast-total strong{font-size:1.5rem;font-weight:700;color:var(--ink);letter-spacing:-.02em}

/* ===== Before / after ===== */
.ari-ba{max-width:560px}
.ari-ba-stage{position:relative;aspect-ratio:4/5;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh);user-select:none;cursor:ew-resize;touch-action:pan-y}
.ari-ba-img{position:absolute;inset:0;background-size:cover;background-position:center}
.ari-ba-before{clip-path:inset(0 50% 0 0);-webkit-clip-path:inset(0 50% 0 0)}
.ari-ba-after.is-placeholder{background:radial-gradient(120% 100% at 70% 12%,#fdeaf0,#fbd9e3 52%,#f6cdd8)}
.ari-ba-before.is-placeholder{background:radial-gradient(120% 100% at 30% 10%,#fdeef2,#f6cdd9)}
.ari-ba-tag{position:absolute;top:14px;z-index:2;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;background:rgba(255,255,255,.85);color:var(--ink);padding:5px 11px;border-radius:var(--r-pill)}
.ari-ba-tag--before{left:14px}
.ari-ba-tag--after{right:14px}
.ari-ba-handle{position:absolute;top:0;bottom:0;left:50%;z-index:3;width:3px;background:#fff;transform:translateX(-50%);cursor:ew-resize;box-shadow:0 0 0 1px rgba(0,0,0,.06)}
.ari-ba-grip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:40px;height:40px;border-radius:50%;background:#fff;box-shadow:var(--sh);display:flex;align-items:center;justify-content:center;color:var(--rose);font-weight:700;letter-spacing:-1px}
.ari-ba-handle:focus-visible{outline:2.5px solid var(--rose);outline-offset:2px}

/* ===== Colour quiz ===== */
.ari-quiz-step{display:none}
.ari-quiz-step.is-active{display:block}
.ari-quiz-result{display:none}
.ari-quiz-result.is-active{display:block}
.ari-q{font-size:1.05rem;font-weight:600;color:var(--ink);margin:0 0 14px}
.ari-quiz .fin-card{max-width:360px;text-align:center}
.ari-quiz .fin-card .big{background:var(--sw,var(--rose-soft));width:120px;height:120px;border-radius:50%;margin:0 auto 16px;box-shadow:0 10px 30px rgba(0,0,0,.14)}
.ari-quiz-prog{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--rose);font-weight:700;text-align:center;margin-bottom:6px}
.ari-quiz-restart{display:block;margin:14px auto 0;background:none;border:none;color:var(--muted);font-weight:600;font-size:.82rem;text-decoration:underline;cursor:pointer}

/* ===== Length guide ===== */
.ari-length-grid{display:grid;grid-template-columns:210px 1fr;gap:clamp(24px,4vw,48px);align-items:center}
.ari-figure{position:relative;height:340px;background:linear-gradient(180deg,var(--lilac),var(--pink));border-radius:var(--r-lg);overflow:hidden}
.ari-body{position:absolute;left:50%;top:24px;bottom:0;transform:translateX(-50%);width:120px}
.ari-body-head{position:absolute;top:0;left:50%;transform:translateX(-50%);width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.72)}
.ari-body-torso{position:absolute;top:46px;left:50%;transform:translateX(-50%);width:96px;height:250px;background:rgba(255,255,255,.72);border-radius:48px 48px 34px 34px}
.ari-mark{position:absolute;left:0;right:0;height:1px;background:rgba(58,42,33,.16)}
.ari-mark-active{position:absolute;left:0;right:0;height:3px;background:var(--rose);box-shadow:0 0 0 4px rgba(192,80,106,.15);transition:top .35s cubic-bezier(.2,.7,.2,1)}
.ari-length-where{font-size:1.05rem;font-weight:600;color:var(--ink);margin:18px 0}

/* ===== Wishlist ===== */
.ari-plp .wp-block-woocommerce-product-image.ari-has-wish{position:relative}
.wish{z-index:2}
.wish.is-saved{background:var(--rose)}
.wish.is-saved svg{stroke:#fff;fill:#fff}
.ari-wishlist-page{padding-top:clamp(28px,5vw,52px);padding-bottom:clamp(40px,6vw,80px)}
.ari-wishlist-grid{margin-top:8px}
.ari-wishlist-grid .card .pname{display:block;font-weight:700;color:var(--ink);font-size:1.02rem;text-decoration:none}
.ari-wishlist-grid .card .pname:hover{color:var(--rose)}
.ari-wishlist-grid .add{display:inline-block;text-align:center;text-decoration:none}
.ari-wishlist-empty{text-align:center;padding:clamp(40px,6vw,90px) 0}
.ari-wishlist-empty h3{font-size:1.8rem;margin-bottom:10px}
.ari-wishlist-empty p{color:#6c5d50;margin-bottom:22px}

@media(max-width:680px){
  .ari-length-grid{grid-template-columns:1fr}
  .ari-figure{height:300px;max-width:240px;margin:0 auto}
  .ari-sample-ring{flex-direction:column;align-items:flex-start}
}
