/** Shopify CDN: Minification failed

Line 18:0 All "@import" rules must come first

**/
/* ============================================================
   RS Product Page — warm palette + soft type system
   Drop-in stylesheet for the redesigned product template.
   Replaces all of the inline custom-liquid styles you had.

   NOTE: Horizon's --font-heading--family / --font-body--family
   custom properties + tag-level h1/h2/h3 selectors beat our class
   selectors. We override both with scoped !important declarations
   inside .rs-section blocks below to win the cascade.
   ============================================================ */
   .view-product-title { display: none !important; }

@import url('https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=Nunito:wght@400;500;600;700;800&family=Caveat:wght@500;600;700&display=swap');

:root {
  --rs-paper:       #FAF7F2;
  --rs-paper-warm:  #F4EFE6;
  --rs-paper-cream: #EFE7D9;
  --rs-ink:         #1A1008;
  --rs-ink-soft:    #5C4F40;
  --rs-ink-quiet:   #8B7C6A;
  --rs-rule:        #D9CFBE;
  --rs-rule-soft:   #E8E0D0;
  --rs-blue:        #1d4fd8;
  --rs-blue-tint:   #e7eeff;
  --rs-blue-deep:   #15327a;
  --rs-red:         #c8202c;
  --rs-red-tint:    #fce8ea;
  --rs-red-deep:    #8a131c;
  --rs-serif: 'Instrument Serif', Georgia, serif;
  --rs-sans:  'Nunito', system-ui, sans-serif;
  --rs-hand:  'Caveat', cursive;
}

/* ============================================================
   Horizon font-variable override.
   Re-declaring Horizon's font custom properties inside our
   sections forces our fonts onto every heading/body element nested
   below. The !important on font-family wins against Horizon's
   tag-level h1/h2/h3 selectors.
   ============================================================ */
.rs-section,
.rs-breadcrumbs,
.rs-nonneg,
.rs-vibe,
.rs-addons,
.rs-sticky-buy {
  --font-heading--family:    'Instrument Serif', Georgia, serif;
  --font-body--family:       'Nunito', system-ui, sans-serif;
  --font-subheading--family: 'Nunito', system-ui, sans-serif;
  --font-accent--family:     'Caveat', cursive;
  --font-heading--weight:    400;
  --font-body--weight:       400;
  font-family: var(--rs-sans) !important;
}

.rs-nonneg p, .rs-nonneg span, .rs-nonneg li,
.rs-vibe p, .rs-vibe span, .rs-vibe li, .rs-vibe a, .rs-vibe button,
.rs-addons p, .rs-addons span, .rs-addons a,
.rs-sticky-buy span, .rs-sticky-buy button {
  font-family: var(--rs-sans) !important;
}

.rs-nonneg h1, .rs-nonneg h2, .rs-nonneg h3, .rs-nonneg h4,
.rs-vibe h1, .rs-vibe h2, .rs-vibe h3, .rs-vibe h4,
.rs-addons h1, .rs-addons h2, .rs-addons h3, .rs-addons h4,
.rs-sticky-buy .rs-sb-title {
  font-family: var(--rs-serif) !important;
  font-weight: 400 !important;
  letter-spacing: -0.02em;
}

/* Italic serif body lines */
.rs-nonneg-card p,
.rs-vibe-tagline,
.rs-vibe-footer,
.rs-addons-caption,
.rs-section-head p {
  font-family: var(--rs-serif) !important;
  font-style: italic !important;
  font-weight: 400 !important;
}

/* Handwritten accent */
.rs-hand,
.rs-section .rs-hand,
.rs-nonneg .rs-hand,
.rs-vibe .rs-hand,
.rs-addons .rs-hand {
  font-family: var(--rs-hand) !important;
  font-weight: 600 !important;
  font-style: normal !important;
  line-height: 0.95;
  display: inline-block;
}

/* Vibe list lines — handwritten font but flex layout for bullets */
.rs-vibe-list .v-line {
  font-family: var(--rs-hand) !important;
  font-weight: 600 !important;
  font-style: normal !important;
}

.rs-eyebrow, .rs-section .rs-eyebrow {
  font-family: var(--rs-sans) !important;
  font-weight: 800 !important;
  font-style: normal !important;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--rs-ink-quiet);
}

/* ===== Shared helpers (scoped to rs-* classes only) ===== */
.rs-wrap { max-width: 1320px; margin: 0 auto; padding: 0 32px; }
.rs-eyebrow { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--rs-ink-quiet); }
.rs-serif { font-family: var(--rs-serif); font-weight: 400; letter-spacing: -0.01em; }
.rs-hand { font-family: var(--rs-hand); font-weight: 600; line-height: 0.95; display: inline-block; }
.rs-section-head { text-align: center; margin-bottom: 48px; }
.rs-section-head .rs-eyebrow { display: block; margin-bottom: 14px; }
.rs-section-head h2 { font-family: var(--rs-serif); font-size: clamp(38px, 5vw, 64px); line-height: 1.02; margin: 0 0 12px; letter-spacing: -0.02em; }
.rs-section-head p { font-family: var(--rs-serif); font-style: italic; font-size: 18px; color: var(--rs-ink-soft); margin: 0; max-width: 560px; margin-left: auto; margin-right: auto; }
.rs-section-head h2 .rs-hand, .rs-section-head h2 .hand { font-size: 1.1em; transform: translateY(0.06em); }

/* ===== Breadcrumbs (snippet) ===== */
.rs-breadcrumbs { padding: 14px 0; font-size: 13px; color: var(--rs-ink-soft); }
.rs-breadcrumbs a { text-decoration: none; color: inherit; }
.rs-breadcrumbs a:hover { color: var(--rs-ink); }
.rs-breadcrumbs .sep { margin: 0 8px; color: var(--rs-ink-quiet); }

/* ===== Section 1: Non-Negotiables ===== */
.rs-nonneg { padding: 80px 0; background: var(--rs-paper-cream); border-top: 1px solid var(--rs-rule); }
.rs-nonneg-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
@media (max-width: 860px) { .rs-nonneg-grid { grid-template-columns: 1fr; } }
.rs-nonneg-card { display: flex; flex-direction: column; gap: 14px; text-align: center; align-items: center; }
.rs-nonneg-card .img-wrap { width: 100%; aspect-ratio: 1; border-radius: 12px; background: var(--rs-paper); overflow: hidden; display: flex; align-items: center; justify-content: center; border: 1px solid var(--rs-rule-soft); }
.rs-nonneg-card .img-wrap img { width: 80%; height: auto; mix-blend-mode: multiply; }
.rs-nonneg-card .label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--rs-ink-quiet); margin-top: 4px; }
.rs-nonneg-card h3 { font-family: var(--rs-serif); font-size: 28px; margin: 4px 0; letter-spacing: -0.01em; color: var(--rs-ink); }
.rs-nonneg-card p { font-family: var(--rs-serif); font-style: italic; color: var(--rs-ink-soft); margin: 0; font-size: 16px; line-height: 1.4; max-width: 280px; }

/* ===== Section 2: Choose Your Vibe ===== */
.rs-vibe { padding: 100px 0; border-top: 1px solid var(--rs-rule-soft); background: var(--rs-paper); }
.rs-vibe-panels { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
@media (max-width: 860px) { .rs-vibe-panels { grid-template-columns: 1fr; } }
.rs-vibe-panel { border-radius: 18px; padding: 36px 32px; display: flex; flex-direction: column; gap: 20px; border: 1.5px solid var(--rs-rule); position: relative; overflow: hidden; transition: all .25s ease; }
.rs-vibe-panel.sweet { background: var(--rs-blue-tint); border-color: var(--rs-blue); }
.rs-vibe-panel.snarky { background: var(--rs-red-tint); border-color: var(--rs-red); }
.rs-vibe-icon { width: 80px; height: 80px; border-radius: 999px; background: var(--rs-paper); display: flex; align-items: center; justify-content: center; overflow: hidden; }
.rs-vibe-icon img { width: 70%; height: auto; }
.rs-vibe-panel .label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; }
.rs-vibe-panel.sweet .label { color: var(--rs-blue-deep); }
.rs-vibe-panel.snarky .label { color: var(--rs-red-deep); }
.rs-vibe-name { font-family: var(--rs-serif); font-size: 64px; margin: -8px 0 -4px; letter-spacing: -0.02em; line-height: 1; color: var(--rs-ink); }
.rs-vibe-tagline { font-family: var(--rs-serif); font-style: italic; font-size: 22px; color: var(--rs-ink-soft); margin: 0 0 8px; }

/* Handwritten differentiated-items list (replaces the old mosaic) */
.rs-vibe-list { display: flex; flex-direction: column; gap: 14px; margin: 8px 0 4px; padding: 24px 28px; list-style: none; background: rgba(255,255,255,0.55); border-radius: 14px; border: 1px dashed currentColor; }
.rs-vibe-panel.sweet .rs-vibe-list { color: var(--rs-blue-deep); }
.rs-vibe-panel.snarky .rs-vibe-list { color: var(--rs-red-deep); }
.rs-vibe-list .v-line { font-family: var(--rs-hand); font-weight: 600; font-size: clamp(28px, 3vw, 36px); line-height: 1; color: var(--rs-ink); letter-spacing: 0; display: flex; align-items: baseline; gap: 14px; }
.rs-vibe-list .v-line::before { content: ''; width: 18px; height: 18px; flex-shrink: 0; border-radius: 999px; background: currentColor; opacity: 0.5; transform: translateY(-2px); }

/* Hybrid mosaic: 2-col photo grid with handwritten phrase per cell */
.rs-vibe-mosaic { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin: 8px 0 4px; padding: 24px 22px; background: rgba(255,255,255,0.55); border-radius: 14px; border: 1px dashed currentColor; }
.rs-vibe-panel.sweet  .rs-vibe-mosaic { color: var(--rs-blue-deep); }
.rs-vibe-panel.snarky .rs-vibe-mosaic { color: var(--rs-red-deep); }
.rs-vibe-mosaic-item { display: flex; flex-direction: column; align-items: center; gap: 8px; text-align: center; }
.vmi-img { width: 100%; aspect-ratio: 1 / 1; background: var(--rs-paper); border-radius: 12px; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.vmi-img img { width: 100%; height: 100%; object-fit: cover; }
.vmi-phrase { font-family: var(--rs-hand) !important; font-weight: 600 !important; font-size: clamp(20px, 2.2vw, 26px); line-height: 1.15; color: var(--rs-ink); max-width: 92%; }
@media (max-width: 520px) { .rs-vibe-mosaic { grid-template-columns: 1fr 1fr; gap: 12px; padding: 16px 14px; } .vmi-phrase { font-size: 18px; } }

.rs-vibe-cta { margin-top: 8px; padding: 14px 22px; border-radius: 999px; background: var(--rs-ink); color: var(--rs-paper); font-family: var(--rs-sans); font-weight: 800; font-size: 15px; text-align: center; align-self: flex-start; display: inline-flex; gap: 8px; align-items: center; text-decoration: none; border: 0; cursor: pointer; }
.rs-vibe-panel.sweet .rs-vibe-cta { background: var(--rs-blue); }
.rs-vibe-panel.snarky .rs-vibe-cta { background: var(--rs-red); }
.rs-vibe-footer { text-align: center; font-family: var(--rs-serif); font-style: italic; font-size: 20px; color: var(--rs-ink-soft); margin-top: 40px; }

/* ===== Section 3: Make It Personal (add-ons) ===== */
.rs-addons { padding: 80px 0; background: var(--rs-paper-warm); border-top: 1px solid var(--rs-rule); }
.rs-addons-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-bottom: 32px; }
@media (max-width: 860px) { .rs-addons-grid { grid-template-columns: 1fr; } }
.rs-addon-card { background: var(--rs-paper); border: 1.5px solid var(--rs-rule); border-radius: 14px; padding: 28px; display: flex; flex-direction: column; align-items: center; text-align: center; gap: 12px; cursor: pointer; transition: all .2s; color: var(--rs-ink); text-decoration: none; }
.rs-addon-card:hover { border-color: var(--rs-ink); transform: translateY(-3px); }
.rs-addon-card .icon-wrap { width: 100%; aspect-ratio: 1; background: var(--rs-paper-warm); border-radius: 12px; display: flex; align-items: center; justify-content: center; overflow: hidden; }
.rs-addon-card .icon-wrap img { width: 65%; height: auto; mix-blend-mode: multiply; }
.rs-addon-card .name { font-family: var(--rs-serif); font-size: 22px; margin: 8px 0 0; }
.rs-addon-card .price { font-family: var(--rs-serif); font-size: 28px; color: var(--rs-ink); }
.rs-addon-card .badge { font-size: 11px; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; color: var(--rs-ink-quiet); }
.rs-bundle-row { text-align: center; background: var(--rs-ink); color: var(--rs-paper); padding: 24px 32px; border-radius: 14px; display: flex; justify-content: center; gap: 20px; align-items: center; flex-wrap: wrap; }
.rs-bundle-row .b-main { font-family: var(--rs-serif); font-size: 28px; letter-spacing: -0.01em; }
.rs-bundle-row .b-save { font-family: var(--rs-hand); font-size: 28px; color: #F4C77C; }
.rs-addons-caption { text-align: center; margin-top: 16px; font-family: var(--rs-serif); font-style: italic; color: var(--rs-ink-soft); }

/* ===== Sticky Add-to-Cart Bar ===== */
body:has(.rs-sticky-buy) { padding-bottom: 88px; }
@media (max-width: 760px) {
  body:has(.rs-sticky-buy) { padding-bottom: 104px; }
}
.rs-sticky-buy {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 50;
  background: var(--rs-paper); border-top: 1px solid var(--rs-rule);
  box-shadow: 0 -10px 30px rgba(0,0,0,0.06);
  transform: translateY(100%); transition: transform .3s cubic-bezier(.4,0,.2,1);
}
.rs-sticky-buy.is-visible { transform: translateY(0); }
.rs-sticky-buy-inner {
  max-width: 1320px; margin: 0 auto; padding: 14px 32px;
  display: grid; grid-template-columns: auto 1fr auto auto; gap: 24px; align-items: center;
}
.rs-sb-product { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.rs-sb-collection { font-size: 11px; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; color: var(--rs-ink-quiet); }
.rs-sb-title { font-family: var(--rs-serif); font-size: 22px; letter-spacing: -0.01em; line-height: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: var(--rs-ink); }
.rs-sb-vibe { display: flex; align-items: center; gap: 10px; font-size: 13px; font-weight: 700; }
.rs-sb-vibe-dot { width: 10px; height: 10px; border-radius: 999px; flex-shrink: 0; background: var(--rs-blue); }
.rs-sb-vibe-dot.snarky { background: var(--rs-red); }
.rs-sb-vibe-label { color: var(--rs-ink-soft); font-weight: 600; }
.rs-sb-vibe-name { font-family: var(--rs-serif); font-weight: 400; font-size: 18px; letter-spacing: -0.01em; color: var(--rs-ink); }
.rs-sb-price { font-family: var(--rs-serif); font-size: 26px; letter-spacing: -0.01em; color: var(--rs-ink); }
.rs-sb-cta {
  padding: 13px 22px; border-radius: 999px; background: var(--rs-ink); color: var(--rs-paper);
  font-family: var(--rs-sans); font-weight: 800; font-size: 14px; border: 0; cursor: pointer;
  transition: transform .15s ease; text-decoration: none; display: inline-flex; align-items: center; gap: 6px;
}
.rs-sb-cta:hover { transform: translateY(-1px); }
@media (max-width: 760px) {
  .rs-sticky-buy-inner { grid-template-columns: 1fr auto; padding: 10px 16px; gap: 12px; row-gap: 0; }
  .rs-sb-product { grid-row: 1; grid-column: 1; }
  .rs-sb-vibe { grid-row: 2; grid-column: 1; font-size: 12px; }
  .rs-sb-vibe-name { font-size: 15px; }
  .rs-sb-price { display: none; }
  .rs-sb-cta { grid-row: 1 / span 2; grid-column: 2; padding: 14px 18px; font-size: 13px; }
}
