/* =====================================================
 * Raj Collection Sequel — BOUTIQUE SOUL LAYER
 * The aesthetic layer that turns "well-built" into "I want to tell my sister."
 * Loaded after everything else.
 * ===================================================== */

/* =====================================================
 * 1. COLOR — add dusk-blue 4th accent (#1F2D4D)
 * Used for: review stars, sale countdowns, "From Last Friday's Live" labels
 * ===================================================== */
:root {
    --rcs-dusk:        #1F2D4D;
    --rcs-dusk-soft:   #E5EAF2;
    --rcs-paper:       #F7F2E8; /* warm cream paper */
}

/* Review stars + countdowns + special accents */
.star-rating,
.rcs-pdp__rating,
.rcs-countdown,
.rcs-fb-live__countdown,
.rcs-fridays-label {
    color: var(--rcs-dusk) !important;
}
.rcs-fridays-strip {
    background: var(--rcs-dusk-soft);
}

/* =====================================================
 * 2. TYPOGRAPHY — Fraunces optical-size axis on hero headlines
 * ===================================================== */
.rcs-hero__title,
.rcs-thankyou__title,
.rcs-section__title,
h1.product_title,
.rcs-pdp__title,
.rcs-h1,
.rcs-display {
    font-variation-settings: 'opsz' 144, 'wght' 600;
    letter-spacing: -0.02em;
}
.rcs-h2,
.rcs-shop-header h1,
.rcs-cart-header h1 {
    font-variation-settings: 'opsz' 96, 'wght' 600;
    letter-spacing: -0.012em;
}

/* =====================================================
 * 3. DROP CAP on founder quote + first paragraph of PDP product story
 * ===================================================== */
.rcs-founder__quote::first-letter,
.rcs-founder blockquote::first-letter,
.rcs-pdp__sections details:first-of-type > div p:first-child::first-letter {
    float: left;
    font-family: var(--rcs-font-display);
    font-size: 3.4em;
    line-height: 0.85;
    font-weight: 600;
    color: var(--rcs-primary);
    padding: 0.1em 0.12em 0 0;
    margin: 0.05em 0.05em 0 0;
    font-feature-settings: "swsh" 1, "calt" 1;
    font-variation-settings: 'opsz' 144;
}

/* =====================================================
 * 4. GRAIN TEXTURE — subtle 4% noise on cream surfaces
 * ===================================================== */
.rcs-surface,
.rcs-card,
.rcs-product-card,
.rcs-footer,
.rcs-signin__card,
.rcs-account__hero,
.rcs-thankyou__card,
.rcs-thankyou__next,
.rcs-cart-totals,
body {
    position: relative;
}
.rcs-surface::before,
.rcs-card::before,
.rcs-product-card::before,
.rcs-footer::before,
.rcs-thankyou__card::before,
.rcs-thankyou__next::before {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.3, 0 0 0 0 0.2, 0 0 0 0 0.1, 0 0 0 0.04 0'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
    background-size: 200px 200px;
    opacity: 1;
    mix-blend-mode: multiply;
    border-radius: inherit;
}
.rcs-surface > *,
.rcs-card > *,
.rcs-product-card > *,
.rcs-footer > * {
    position: relative;
    z-index: 1;
}

/* =====================================================
 * 5. SECTION DIVIDERS — hand-drawn flourishes (4 variants cycled)
 * ===================================================== */
main > section:not(:first-child)::before,
main > .rcs-section:not(:first-child)::before {
    content: '';
    display: block;
    width: 100px;
    height: 18px;
    margin: 28px auto 0;
    opacity: 0.45;
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
}
main > section:nth-child(4n+1)::before {
    /* Flourish 1 — gold thread loop */
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 18' fill='none' stroke='%23C9A961' stroke-width='1.2' stroke-linecap='round'><path d='M2 9 Q20 9 38 9'/><path d='M62 9 Q80 9 98 9'/><circle cx='50' cy='9' r='4.5'/><circle cx='50' cy='9' r='1.5' fill='%23C9A961'/></svg>");
}
main > section:nth-child(4n+2)::before {
    /* Flourish 2 — gold sprigs */
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 18' fill='none' stroke='%23C9A961' stroke-width='1.2' stroke-linecap='round'><path d='M2 9 Q26 9 42 9'/><path d='M58 9 Q74 9 98 9'/><path d='M50 4 L50 14 M45 7 L50 4 L55 7 M45 11 L50 14 L55 11'/></svg>");
}
main > section:nth-child(4n+3)::before {
    /* Flourish 3 — paisley curl */
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 18' fill='none' stroke='%23C9A961' stroke-width='1.2' stroke-linecap='round'><path d='M2 9 Q22 9 38 9'/><path d='M62 9 Q78 9 98 9'/><path d='M40 9 Q46 1 50 9 Q54 17 60 9' stroke-width='1.4'/></svg>");
}
main > section:nth-child(4n)::before {
    /* Flourish 4 — three dots */
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 18' fill='none' stroke='%23C9A961' stroke-width='1.2' stroke-linecap='round'><path d='M2 9 Q26 9 38 9'/><path d='M62 9 Q74 9 98 9'/><circle cx='44' cy='9' r='1.6' fill='%23C9A961'/><circle cx='50' cy='9' r='2.2' fill='%23C9A961'/><circle cx='56' cy='9' r='1.6' fill='%23C9A961'/></svg>");
}

/* =====================================================
 * 6. BOUTIQUE CURSOR (desktop only, hero + PDP only)
 * ===================================================== */
@media (hover: hover) and (pointer: fine) and (min-width: 1024px) {
    body.home,
    body.single-product {
        cursor: none;
    }
    body.home a,
    body.home button,
    body.home [role="button"],
    body.single-product a,
    body.single-product button,
    body.single-product [role="button"] {
        cursor: none;
    }
    .rcs-cursor {
        position: fixed;
        top: 0;
        left: 0;
        width: 8px;
        height: 8px;
        margin: -4px 0 0 -4px;
        background: var(--rcs-primary);
        border-radius: 50%;
        pointer-events: none;
        z-index: 99999;
        mix-blend-mode: multiply;
        transition: transform 80ms linear;
    }
    .rcs-cursor__ring {
        position: fixed;
        top: 0;
        left: 0;
        width: 32px;
        height: 32px;
        margin: -16px 0 0 -16px;
        border: 1px solid var(--rcs-accent);
        border-radius: 50%;
        pointer-events: none;
        z-index: 99998;
        transition: transform 320ms cubic-bezier(0.16, 1, 0.3, 1), width 220ms, height 220ms, margin 220ms;
        opacity: 0.85;
    }
    .rcs-cursor.is-hovering + .rcs-cursor__ring,
    .rcs-cursor__ring.is-hovering {
        width: 52px;
        height: 52px;
        margin: -26px 0 0 -26px;
        opacity: 1;
        border-color: var(--rcs-primary);
    }
}
@media (hover: none), (max-width: 1023px) {
    .rcs-cursor, .rcs-cursor__ring { display: none !important; }
}

/* =====================================================
 * 7. GHOST-WRITE — "Why we love it" line on product card hover
 * ===================================================== */
@media (hover: hover) and (prefers-reduced-motion: no-preference) {
    .rcs-product-card {
        position: relative;
        overflow: hidden;
    }
    .rcs-product-card__media {
        position: relative;
        overflow: hidden;
    }
    .rcs-product-card__media::after {
        content: attr(data-ghost);
        position: absolute;
        bottom: 0;
        left: 0;
        right: 0;
        padding: 14px 14px 12px;
        background: linear-gradient(180deg, transparent, rgba(28,26,25,0.85));
        color: rgba(255,255,255,0.95);
        font-family: var(--rcs-font-display);
        font-style: italic;
        font-size: 12px;
        line-height: 1.35;
        transform: translateY(110%);
        transition: transform 480ms cubic-bezier(0.16, 1, 0.3, 1);
        pointer-events: none;
    }
    .rcs-product-card:hover .rcs-product-card__media::after {
        transform: translateY(0);
    }
}

/* =====================================================
 * 8. PROVENANCE LINE on PDP — calm gold tagline
 * ===================================================== */
.rcs-pdp__provenance {
    margin: 4px 0 14px;
    padding: 8px 12px;
    background: rgba(201,169,97,0.08);
    border-left: 2px solid var(--rcs-accent);
    border-radius: 4px;
    font-size: 12px;
    color: var(--rcs-bronze);
    font-family: var(--rcs-font-ui);
    font-style: italic;
    line-height: 1.5;
    display: flex;
    align-items: center;
    gap: 6px;
}
.rcs-pdp__provenance i {
    color: var(--rcs-accent);
    font-size: 14px;
}

/* =====================================================
 * 9. SOUND TOGGLE in header
 * ===================================================== */
.rcs-sound-toggle {
    width: 36px;
    height: 36px;
    display: grid;
    place-items: center;
    border-radius: 50%;
    transition: background 200ms var(--rcs-ease-out);
}
.rcs-sound-toggle:hover {
    background: rgba(107,26,46,0.08);
}
.rcs-sound-toggle i {
    font-size: 18px;
    color: var(--rcs-text);
}

/* =====================================================
 * 10. BOUTIQUE-OPEN INDICATOR
 * ===================================================== */
.rcs-boutique-status {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    font-family: var(--rcs-font-ui);
    letter-spacing: 0.04em;
    text-transform: uppercase;
}
.rcs-boutique-status--open {
    background: rgba(46,125,50,0.08);
    color: var(--rcs-success);
}
.rcs-boutique-status--closed {
    background: rgba(183,121,31,0.10);
    color: var(--rcs-warning);
}
.rcs-boutique-status__dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: currentColor;
    animation: rcs-pulse-dot 1.8s ease-in-out infinite;
}

/* =====================================================
 * 11. PINCODE RIBBON under PDP price
 * ===================================================== */
.rcs-pdp__pin-ribbon {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    background: var(--rcs-section-tint);
    border-radius: 8px;
    margin: 8px 0 14px;
    font-size: 13px;
}
.rcs-pdp__pin-ribbon i {
    color: var(--rcs-primary);
    font-size: 18px;
    flex-shrink: 0;
}
.rcs-pdp__pin-ribbon__msg {
    flex: 1;
    color: var(--rcs-text);
    font-weight: 500;
}
.rcs-pdp__pin-ribbon button {
    background: none;
    border: 0;
    color: var(--rcs-primary);
    font-weight: 700;
    cursor: pointer;
    font-size: 12px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: 6px 10px;
    border-radius: 6px;
}
.rcs-pdp__pin-ribbon button:hover {
    background: rgba(107,26,46,0.06);
}

/* =====================================================
 * 12. FB LIVE COUNTDOWN
 * ===================================================== */
.rcs-fb-live__countdown {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: var(--rcs-dusk-soft);
    color: var(--rcs-dusk);
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
    margin: 10px 0;
}

/* =====================================================
 * 13. WHATSAPP CART RECOVERY TOAST
 * ===================================================== */
.rcs-wa-recovery {
    position: fixed;
    bottom: calc(80px + var(--rcs-safe-bottom));
    left: 16px;
    right: 16px;
    background: var(--rcs-surface);
    border: 1px solid var(--rcs-accent);
    border-radius: 14px;
    padding: 14px 16px;
    box-shadow: 0 24px 48px -16px rgba(28,26,25,0.18);
    display: flex;
    gap: 12px;
    align-items: center;
    z-index: 9999;
    transform: translateY(140%);
    transition: transform 540ms cubic-bezier(0.16, 1, 0.3, 1);
}
.rcs-wa-recovery.is-visible {
    transform: translateY(0);
}
.rcs-wa-recovery__icon {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--rcs-whatsapp);
    color: #fff;
    display: grid;
    place-items: center;
    flex-shrink: 0;
}
.rcs-wa-recovery__icon i {
    font-size: 20px;
}
.rcs-wa-recovery__body {
    flex: 1;
    font-size: 13px;
    line-height: 1.4;
    color: var(--rcs-text);
}
.rcs-wa-recovery__body strong {
    font-family: var(--rcs-font-display);
    color: var(--rcs-primary);
    display: block;
    margin-bottom: 2px;
}
.rcs-wa-recovery__close {
    background: none;
    border: 0;
    color: var(--rcs-text-muted);
    cursor: pointer;
    padding: 4px;
    font-size: 18px;
}
.rcs-wa-recovery__cta {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: var(--rcs-whatsapp);
    font-weight: 700;
    text-decoration: none;
    font-size: 12px;
    letter-spacing: 0.04em;
}

/* =====================================================
 * 14. DRAPE GUIDE MODAL trigger
 * ===================================================== */
.rcs-pdp__drape-trigger {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: none;
    border: 1px dashed var(--rcs-outline);
    color: var(--rcs-bronze);
    padding: 10px 14px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
    margin: 12px 0;
    cursor: pointer;
    width: 100%;
    justify-content: center;
}
.rcs-pdp__drape-trigger i {
    color: var(--rcs-accent);
    font-size: 16px;
}
.rcs-pdp__drape-trigger:hover {
    border-color: var(--rcs-accent);
    color: var(--rcs-primary);
}

/* =====================================================
 * 15. VOICE-NOTE play button
 * ===================================================== */
.rcs-pdp__voice {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--rcs-canvas);
    border: 1px solid var(--rcs-outline);
    border-radius: 999px;
    padding: 6px 14px 6px 6px;
    font-size: 12px;
    font-weight: 600;
    color: var(--rcs-text);
    cursor: pointer;
    margin: 4px 0;
}
.rcs-pdp__voice-play {
    width: 26px;
    height: 26px;
    border-radius: 50%;
    background: var(--rcs-primary);
    color: var(--rcs-text-inverse);
    display: grid;
    place-items: center;
    flex-shrink: 0;
}

/* =====================================================
 * 16. ONE-TAP REORDER button on past orders
 * ===================================================== */
.rcs-reorder-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--rcs-primary);
    color: var(--rcs-text-inverse);
    padding: 8px 16px;
    border-radius: 999px;
    text-decoration: none;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    border: 0;
    cursor: pointer;
}
.rcs-reorder-btn:hover {
    background: var(--rcs-primary-soft);
}
.rcs-reorder-btn i {
    font-size: 14px;
}

/* =====================================================
 * 17. SAREE DNA card link on PDP
 * ===================================================== */
.rcs-pdp__dna-card {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--rcs-bronze);
    text-decoration: none;
    font-size: 11px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    font-weight: 600;
    margin: 4px 0;
}
.rcs-pdp__dna-card:hover {
    color: var(--rcs-primary);
}

/* =====================================================
 * 18. OUTFIT BUILDER section
 * ===================================================== */
.rcs-outfit-builder {
    margin: 24px 0;
    padding: 20px 16px;
    background: var(--rcs-paper);
    border-radius: 14px;
    border: 1px dashed var(--rcs-accent);
}
.rcs-outfit-builder h3 {
    font-family: var(--rcs-font-display);
    font-size: 18px;
    color: var(--rcs-primary);
    margin: 0 0 12px;
}
.rcs-outfit-builder__items {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    padding-bottom: 8px;
}
.rcs-outfit-builder__items::-webkit-scrollbar { display: none; }
.rcs-outfit-builder__item {
    flex: 0 0 120px;
    border-radius: 8px;
    overflow: hidden;
    background: var(--rcs-surface);
}
.rcs-outfit-builder__item img {
    width: 100%;
    height: 120px;
    object-fit: cover;
    display: block;
}
.rcs-outfit-builder__bundle-cta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--rcs-outline);
}
.rcs-outfit-builder__price {
    font-family: var(--rcs-font-display);
    font-weight: 700;
    color: var(--rcs-primary);
    font-size: 18px;
}
.rcs-outfit-builder__price del {
    color: var(--rcs-text-subtle);
    font-weight: 400;
    font-size: 13px;
    margin-right: 6px;
}

/* =====================================================
   19. Boutique cursor (desktop only)
   ===================================================== */
@media (hover: hover) and (pointer: fine) and (min-width: 992px) {
  body { cursor: none; }
  a, button, [role="button"], input, textarea, select, .rcs-card { cursor: none; }
  .rcs-cursor__dot,
  .rcs-cursor__ring {
    position: fixed; top: 0; left: 0; pointer-events: none; z-index: 99999;
    will-change: transform;
    transition: opacity .25s ease, background-color .2s ease, width .2s ease, height .2s ease;
  }
  .rcs-cursor__dot {
    width: 6px; height: 6px; margin: -3px 0 0 -3px;
    border-radius: 50%; background: var(--rcs-gold, #b89559);
    mix-blend-mode: difference;
  }
  .rcs-cursor__ring {
    width: 28px; height: 28px; margin: -14px 0 0 -14px;
    border-radius: 50%; border: 1px solid rgba(184, 149, 89, .55);
  }
  .rcs-cursor__ring.is-hover {
    width: 48px; height: 48px; margin: -24px 0 0 -24px;
    border-color: rgba(184, 149, 89, .9);
    background: rgba(184, 149, 89, .06);
  }
}

/* =====================================================
   20. Ghost-write under product titles
   ===================================================== */
.rcs-card .rcs-ghost,
li.product .rcs-ghost {
  display: block;
  margin-top: 4px;
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-weight: 400;
  font-size: .78rem;
  letter-spacing: .01em;
  color: rgba(60, 50, 40, .55);
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  transition: opacity .35s ease, max-height .35s ease, margin-top .35s ease;
}
.rcs-card:hover .rcs-ghost,
li.product:hover .rcs-ghost,
.rcs-card:focus-within .rcs-ghost {
  opacity: .9;
  max-height: 3rem;
  margin-top: 6px;
}
@media (hover: none) {
  .rcs-card .rcs-ghost { opacity: .75; max-height: 3rem; margin-top: 6px; }
}

/* =====================================================
   21. Pincode ribbon (PDP, beneath price)
   ===================================================== */
.rcs-pincode-ribbon {
  display: flex; flex-wrap: wrap; align-items: center; gap: 8px;
  margin: 12px 0 16px;
  padding: 10px 12px;
  background: linear-gradient(180deg, #fdf8ef 0%, #faf1e1 100%);
  border: 1px solid rgba(184, 149, 89, .22);
  border-radius: 12px;
  font-size: .86rem;
}
.rcs-pincode-ribbon i { color: var(--rcs-gold, #b89559); font-size: 1.1rem; }
.rcs-pincode-ribbon__lede { font-family: 'Fraunces', serif; font-style: italic; color: #4a3f33; }
.rcs-pincode-ribbon__input {
  flex: 0 1 110px; min-width: 100px;
  padding: 6px 10px;
  border: 1px solid rgba(184, 149, 89, .35);
  border-radius: 8px; background: #fff;
  font: inherit; letter-spacing: .04em;
}
.rcs-pincode-ribbon__btn {
  padding: 6px 14px;
  background: #1b1b1b; color: #fff;
  border: none; border-radius: 8px;
  font-size: .82rem; letter-spacing: .04em;
  cursor: pointer; transition: background .2s ease;
}
.rcs-pincode-ribbon__btn:hover { background: var(--rcs-gold, #b89559); }
.rcs-pincode-ribbon__msg { flex: 1 0 100%; font-size: .8rem; color: #4a3f33; }
.rcs-pincode-ribbon__msg.is-ok { color: #2e6b3a; }
.rcs-pincode-ribbon__msg.is-warn { color: #a8541a; }

/* =====================================================
   22. Drape guide modal
   ===================================================== */
.rcs-drape-modal {
  position: fixed; inset: 0;
  background: rgba(20, 16, 12, .55);
  display: flex; align-items: center; justify-content: center;
  z-index: 9999;
  opacity: 0;
  transition: opacity .24s ease;
  padding: 16px;
}
.rcs-drape-modal.is-open { opacity: 1; }
.rcs-drape-modal__box {
  max-width: 480px; width: 100%;
  background: var(--rcs-cream, #faf3e7);
  border-radius: 16px; padding: 28px 24px;
  position: relative;
  transform: translateY(8px) scale(.98);
  transition: transform .28s cubic-bezier(.2,.7,.3,1.1);
  box-shadow: 0 30px 80px rgba(0,0,0,.25);
}
.rcs-drape-modal.is-open .rcs-drape-modal__box { transform: translateY(0) scale(1); }
.rcs-drape-modal__close {
  position: absolute; top: 8px; right: 12px;
  background: none; border: none;
  font-size: 1.8rem; line-height: 1;
  color: #4a3f33; cursor: pointer;
}
.rcs-drape-modal__h {
  font-family: 'Fraunces', serif;
  font-size: 1.4rem; margin: 0 0 12px;
}
.rcs-drape-modal__list { padding-left: 18px; }
.rcs-drape-modal__list li {
  margin-bottom: 8px;
  font-size: .92rem; line-height: 1.5;
  color: #3a2f24;
}
.rcs-drape-modal__list strong {
  font-family: 'Fraunces', serif;
  font-style: italic;
  color: var(--rcs-gold, #b89559);
  margin-right: 4px;
}
.rcs-drape-modal__note {
  margin-top: 14px; padding-top: 12px;
  border-top: 1px solid rgba(184, 149, 89, .25);
  font-size: .82rem; font-style: italic;
  color: #5a4a3a;
}

/* =====================================================
   23. WhatsApp cart-recovery toast
   ===================================================== */
.rcs-recovery-toast {
  position: fixed; left: 16px; right: 16px; bottom: 80px;
  max-width: 380px; margin: 0 auto;
  background: #fff; border: 1px solid rgba(184, 149, 89, .25);
  border-radius: 14px; padding: 14px 14px 14px 52px;
  box-shadow: 0 16px 40px rgba(0,0,0,.18);
  z-index: 9000;
  transform: translateY(20px);
  opacity: 0;
  transition: transform .35s cubic-bezier(.2,.7,.3,1), opacity .35s ease;
}
.rcs-recovery-toast.is-in { transform: translateY(0); opacity: 1; }
.rcs-recovery-toast > i {
  position: absolute; left: 14px; top: 14px;
  width: 28px; height: 28px;
  display: grid; place-items: center;
  background: #25d366; color: #fff;
  border-radius: 50%; font-size: 1rem;
}
.rcs-recovery-toast strong {
  display: block;
  font-family: 'Fraunces', serif;
  font-size: .98rem; color: #1b1b1b;
}
.rcs-recovery-toast p {
  margin: 4px 0 8px; font-size: .82rem;
  color: #4a3f33; line-height: 1.45;
}
.rcs-recovery-toast .rcs-btn {
  display: inline-block; padding: 8px 16px;
  background: #25d366; color: #fff;
  border-radius: 8px; text-decoration: none;
  font-size: .82rem; letter-spacing: .03em;
}
.rcs-recovery-toast__close {
  position: absolute; top: 6px; right: 8px;
  background: none; border: none;
  font-size: 1.4rem; line-height: 1;
  color: #888; cursor: pointer;
}

/* =====================================================
   24. Friday FB Live countdown badge
   ===================================================== */
.rcs-fblive-countdown {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 12px;
  background: #1b1b1b; color: #fff;
  border-radius: 999px;
  font-size: .76rem; letter-spacing: .04em;
  font-feature-settings: "tnum" 1;
}
.rcs-fblive-countdown i {
  color: #e84a3a;
  animation: rcsLivePulse 1.4s ease-in-out infinite;
}
@keyframes rcsLivePulse {
  0%, 100% { opacity: 1; }
  50% { opacity: .4; }
}

/* =====================================================
   25. PDP image gentle pan (CSS hook for JS-applied transform)
   ===================================================== */
.rcs-pan-img {
  transition: transform .35s cubic-bezier(.2,.7,.3,1);
  will-change: transform;
}

/* =====================================================
   26. WhatsApp FAB (lazy-mounted)
   ===================================================== */
.rcs-fab.rcs-fab--whatsapp {
  position: fixed; right: 16px;
  bottom: calc(82px + env(safe-area-inset-bottom, 0px));
  width: 52px; height: 52px;
  background: #25d366; color: #fff;
  border-radius: 50%; text-decoration: none;
  display: grid; place-items: center;
  font-size: 1.6rem;
  box-shadow: 0 12px 28px rgba(37, 211, 102, .35);
  z-index: 800;
  transform: scale(.6); opacity: 0;
  animation: rcsFabIn .4s .15s cubic-bezier(.2,.7,.3,1.1) forwards;
}
@keyframes rcsFabIn { to { transform: scale(1); opacity: 1; } }
.rcs-fab.rcs-fab--whatsapp:hover { background: #1ebe5b; }

/* =====================================================
   27. Voice-note play button on PDP
   ===================================================== */
.rcs-voice-note {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 14px;
  background: var(--rcs-cream, #faf3e7);
  border: 1px solid rgba(184, 149, 89, .3);
  border-radius: 999px;
  font-family: 'Fraunces', serif; font-style: italic;
  font-size: .88rem; color: #3a2f24;
  cursor: pointer; transition: background .25s ease;
}
.rcs-voice-note:hover { background: #f6ebd6; }
.rcs-voice-note.is-playing { background: var(--rcs-gold, #b89559); color: #fff; }
.rcs-voice-note::before {
  content: ''; width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--rcs-gold, #b89559);
  box-shadow: 0 0 0 2px #fff inset;
}
.rcs-voice-note.is-playing::before {
  animation: rcsVoiceWave 1.4s ease-in-out infinite;
}
@keyframes rcsVoiceWave {
  0%, 100% { box-shadow: 0 0 0 2px #fff inset, 0 0 0 0 rgba(255,255,255,.6); }
  50%      { box-shadow: 0 0 0 2px #fff inset, 0 0 0 10px rgba(255,255,255,0); }
}

/* =====================================================
   28. One-tap reorder button
   ===================================================== */
.rcs-reorder-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px;
  background: #1b1b1b; color: #fff;
  border: none; border-radius: 8px;
  font-size: .82rem; letter-spacing: .04em;
  cursor: pointer; text-decoration: none;
  transition: background .2s ease;
}
.rcs-reorder-btn:hover { background: var(--rcs-gold, #b89559); }
.rcs-reorder-btn.is-loading { opacity: .7; pointer-events: none; }
.rcs-reorder-btn::before {
  content: '↻'; font-size: 1rem; line-height: 1;
}

/* =====================================================
   29. Saree DNA card link
   ===================================================== */
.rcs-saree-dna {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 14px;
  background: linear-gradient(180deg, #fefaf2 0%, #f8efdc 100%);
  border: 1px solid rgba(184, 149, 89, .25);
  border-radius: 12px;
  text-decoration: none; color: #3a2f24;
  font-size: .86rem;
  margin: 14px 0;
}
.rcs-saree-dna i { font-size: 1.4rem; color: var(--rcs-gold, #b89559); }
.rcs-saree-dna strong { display: block; font-family: 'Fraunces', serif; font-size: .98rem; }

/* =====================================================
   30. Outfit builder strip
   ===================================================== */
.rcs-outfit-builder {
  margin: 24px 0;
  padding: 18px;
  background: #fdfaf3;
  border-radius: 14px;
}
.rcs-outfit-builder__h {
  font-family: 'Fraunces', serif; font-style: italic;
  font-size: 1.1rem; margin: 0 0 10px;
}
.rcs-outfit-builder__grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.rcs-outfit-builder__item {
  background: #fff;
  border: 1px dashed rgba(184, 149, 89, .35);
  border-radius: 10px;
  aspect-ratio: 1;
  display: grid; place-items: center;
  font-size: .7rem; color: #5a4a3a;
  text-align: center;
  padding: 6px;
}

/* =====================================================
   31. PDP boutique row (voice + drape + video call)
   ===================================================== */
.rcs-pdp__boutique-row {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin: 14px 0 10px;
}
.rcs-pdp__boutique-row .rcs-btn--ghost {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px;
  background: #fff; color: #1b1b1b;
  border: 1px solid rgba(184, 149, 89, .3);
  border-radius: 999px;
  font-size: .82rem; letter-spacing: .03em;
  text-decoration: none; cursor: pointer;
  transition: background .2s ease, border-color .2s ease;
}
.rcs-pdp__boutique-row .rcs-btn--ghost:hover {
  background: var(--rcs-cream, #faf3e7);
  border-color: var(--rcs-gold, #b89559);
}

/* =====================================================
   32. Hero loop video (boutique 6s)
   ===================================================== */
.rcs-hero__video {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 1.4s ease;
  z-index: 0;
}
.rcs-hero__video.is-loaded { opacity: .55; }
.rcs-hero > * { position: relative; z-index: 1; }
