/** Shopify CDN: Minification failed

Line 259:10 Expected identifier but found whitespace
Line 259:15 Unexpected ";"

**/
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: 'Outfit', sans-serif;
  font-weight: 400;
  background: #FAFAF8;
  color: #0F0D0A;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
:root {
  --ink: #0F0D0A;
  --ink-70: rgba(15,13,10,.7);
  --ink-40: rgba(15,13,10,.4);
  --ink-15: rgba(15,13,10,.15);
  --ink-06: rgba(15,13,10,.06);
  --paper: #FAFAF8;
  --linen: #F4F1EC;
  --warm-border: #E5E0D8;
  --terracotta: #B5593A;
  --terracotta-light: #D4795C;
  --terracotta-bg: #F9EDE8;
  --sage: #3A5447;
  --sage-light: #BCCFC8;
  --sage-bg: #EBF0EE;
  --gold: #C8952A;
  --gold-light: #F0D898;
  --r: 6px;
  --r-lg: 14px;
  --r-xl: 22px;
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; font-size: 16px; }

body {
  font-family: 'Outfit', sans-serif;
  font-weight: 400;
  background: var(--paper);
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

/* ── ANNOUNCEMENT ── */
.top-bar {
  background: var(--sage);
  color: rgba(255,255,255,.9);
  text-align: center;
  padding: 9px 16px;
  font-size: 12.5px;
  letter-spacing: .045em;
  font-weight: 400;
}
.top-bar strong { color: var(--gold-light); font-weight: 500; }
.top-bar a { color: inherit; text-decoration: underline; }

/* ── NAV ── */
nav {
  background: rgba(250,250,248,.96);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--warm-border);
  padding: 0 6%;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: sticky;
  top: 0;
  z-index: 200;
}
.logo {
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px;
  font-weight: 500;
  color: var(--ink);
  letter-spacing: .01em;
  text-decoration: none;
}
.logo sup {
  font-size: 11px;
  font-weight: 400;
  color: var(--ink-40);
  vertical-align: super;
  font-family: 'Outfit', sans-serif;
  letter-spacing: .04em;
}
.nav-links { display: flex; gap: 32px; list-style: none; }
.nav-links a { text-decoration: none; color: var(--ink-70); font-size: 13.5px; font-weight: 400; letter-spacing: .01em; transition: color .2s; }
.nav-links a:hover { color: var(--ink); }
.nav-actions { display: flex; gap: 12px; align-items: center; }
.nav-cart-count {
  background: var(--terracotta);
  color: #fff;
  border: none;
  width: 36px; height: 36px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  font-size: 15px;
  transition: background .2s;
  position: relative;
}
.nav-cart-count:hover { background: #8B3E24; }
.cart-badge {
  position: absolute;
  top: -4px; right: -4px;
  background: var(--gold);
  color: #fff;
  width: 16px; height: 16px;
  border-radius: 50%;
  font-size: 9px;
  font-weight: 600;
  display: none;
  align-items: center;
  justify-content: center;
}
.nav-cta {
  background: var(--ink);
  color: #fff;
  border: none;
  padding: 9px 22px;
  border-radius: 100px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  font-family: 'Outfit', sans-serif;
  letter-spacing: .02em;
  transition: background .2s, transform .15s;
}
.nav-cta:hover { background: var(--sage); transform: translateY(-1px); }

/* ── BREADCRUMB ── */
.breadcrumb {
  padding: 14px 6%;
  font-size: 12px;
  color: var(--ink-40);
  display: flex;
  gap: 6px;
  align-items: center;
  border-bottom: 1px solid var(--warm-border);
}
.breadcrumb a { text-decoration: none; color: var(--ink-40); transition: color .2s; }
.breadcrumb a:hover { color: var(--ink); }
.breadcrumb-sep { font-size: 10px; opacity: .5; }

/* ── HERO / PRODUCT ── */
.product-section {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: 0;
  align-items: start;
}
.product-gallery {
  background: var(--linen);
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: 0;
  align-self: stretch;
}
.gallery-main {
  display: flex;
  align-items: stretch;
  justify-content: center;
  position: relative;
  padding: 0;
  background: var(--linen);
  overflow: hidden;
}
.product-3d {
  width: 100%;
  position: relative;
}
.product-3d img#pawrestMainImage {
  width: 100% !important;
  height: 100% !important;
  max-height: 100vh !important;
  object-fit: cover !important;
  object-position: center center !important;
  border-radius: 0 !important;
  display: block !important;
}
/* Refined CSS bed illustration */
.bed-wrap {
  position: relative;
  width: 100%;
  padding-bottom: 55%;
}
.bed-shadow {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 80%;
  height: 18px;
  background: radial-gradient(ellipse, rgba(15,13,10,.18) 0%, transparent 70%);
  border-radius: 50%;
}
.bed-body {
  position: absolute;
  bottom: 12px;
  left: 5%;
  right: 5%;
  height: 42%;
  background: linear-gradient(160deg, #C4956A 0%, #A67448 60%, #8B5C38 100%);
  border-radius: 40% 40% 28% 28% / 35% 35% 18% 18%;
}
.bed-bolster-back {
  position: absolute;
  bottom: 44%;
  left: 8%;
  right: 8%;
  height: 30%;
  background: linear-gradient(170deg, #D4A574 0%, #BC8050 50%, #9E6438 100%);
  border-radius: 100px 100px 0 0;
}
.bed-bolster-front {
  position: absolute;
  bottom: 40%;
  left: 6%;
  right: 6%;
  height: 12%;
  background: linear-gradient(180deg, #C8905E 0%, #A87040 100%);
  border-radius: 0 0 100px 100px;
}
.bed-pillow {
  position: absolute;
  bottom: 28%;
  left: 18%;
  right: 18%;
  height: 26%;
  background: linear-gradient(140deg, #E8C08A 0%, #C8985A 100%);
  border-radius: 50%;
}
.bed-texture {
  position: absolute;
  bottom: 14px;
  left: 5%;
  right: 5%;
  height: 3px;
  background: rgba(255,255,255,.12);
  border-radius: 100px;
}
.gallery-urgency {
  padding: 16px 28px 28px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  background: var(--linen);
}
  display: flex;
  gap: 8px;
  padding: 20px 28px;
  flex-wrap: wrap;
}
.g-badge {
  background: rgba(255,255,255,.85);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.6);
  border-radius: var(--r);
  padding: 6px 12px;
  font-size: 11.5px;
  color: var(--sage);
  font-weight: 500;
  letter-spacing: .02em;
  display: flex;
  align-items: center;
  gap: 5px;
}
.g-badge-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--sage);
  flex-shrink: 0;
}
.gallery-thumbnails {
  display: flex;
  gap: 8px;
  padding: 0 28px 24px;
}
.thumb {
  width: 56px; height: 56px;
  border-radius: var(--r);
  border: 1.5px solid var(--warm-border);
  cursor: pointer;
  overflow: hidden;
  background: #E0D4C4;
  transition: border-color .2s;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  color: var(--ink-40);
  font-weight: 500;
}
.thumb:hover, .thumb.active { border-color: var(--terracotta); }
.thumb.active { border-width: 2px; }

/* PRODUCT INFO */
.product-info {
  padding: 48px 7% 48px 6%;
  display: flex;
  flex-direction: column;
  gap: 28px;
  border-left: 1px solid var(--warm-border);
}
.product-rating {
  display: flex;
  align-items: center;
  gap: 10px;
}
.stars-row { display: flex; gap: 2px; }
.star {
  width: 14px; height: 14px;
  clip-path: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%);
  background: var(--gold);
}
.star.half { background: linear-gradient(90deg, var(--gold) 50%, #D5CEBF 50%); }
.rating-text { font-size: 13px; color: var(--ink-40); }
.rating-text a { color: var(--ink-40); text-decoration: underline; text-underline-offset: 2px; }
.rating-text a:hover { color: var(--terracotta); }
.product-badges {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.p-badge {
  padding: 4px 10px;
  border-radius: 100px;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .04em;
}
.p-badge-sage { background: var(--sage-bg); color: var(--sage); }
.p-badge-terra { background: var(--terracotta-bg); color: var(--terracotta); }
.p-badge-gold { background: #FEF6E4; color: #8B6010; }

h1.product-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(28px, 3vw, 40px);
  font-weight: 400;
  line-height: 1.15;
  letter-spacing: -.02em;
  color: var(--ink);
}
h1 em { font-style: italic; color: var(--terracotta); }

.product-desc {
  font-size: 14px;
  color: var(--ink-70);
  line-height: 1.75;
}
.product-desc p { margin-bottom: 10px; }
.product-desc strong { color: var(--ink); font-weight: 500; }
.product-desc ul { padding-left: 18px; display: flex; flex-direction: column; gap: 4px; margin: 8px 0; }
.product-desc li { font-size: 14px; }

/* SIZE SELECTOR */
.variant-group { display: flex; flex-direction: column; gap: 0; margin-bottom: 12px; }
.variant-label {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--ink-40);
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 5px;
  padding-left: 1px;
}
.variant-label a { color: var(--terracotta); text-decoration: none; font-size: 10px; letter-spacing: .04em; text-transform: none; font-weight: 500; }
.size-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
.size-opt {
  border: 1px solid var(--warm-border);
  background: transparent;
  padding: 11px 8px;
  border-radius: var(--r);
  text-align: center;
  cursor: pointer;
  font-family: 'Outfit', sans-serif;
  transition: all .2s;
}
.size-opt:hover { border-color: var(--ink-40); }
.size-opt.active { background: var(--ink); color: #fff; border-color: var(--ink); }
.size-opt-name { font-size: 14px; font-weight: 500; display: block; color: inherit; }
.size-opt-dim { font-size: 11px; color: var(--ink-40); display: block; margin-top: 2px; }
.size-opt.active .size-opt-dim { color: rgba(255,255,255,.65); }

/* PRICE */
.price-block { display: flex; flex-direction: column; gap: 6px; }
.price-row { display: flex; align-items: baseline; gap: 14px; }
.price-current {
  font-family: 'Cormorant Garamond', serif;
  font-size: 40px;
  font-weight: 400;
  color: var(--ink);
  line-height: 1;
}
.price-original {
  font-size: 18px;
  color: var(--ink-40);
  text-decoration: line-through;
}
.price-discount {
  font-size: 12px;
  font-weight: 600;
  background: var(--terracotta);
  color: #fff;
  padding: 3px 9px;
  border-radius: 100px;
  letter-spacing: .04em;
}
.price-note { font-size: 12px; color: var(--ink-40); }

/* CTA BUTTONS */
.cta-stack { display: flex; flex-direction: column; gap: 10px; }
.btn-atc {
  background: #C49A1A;
  color: #fff;
  border: none;
  padding: 16px;
  border-radius: var(--r-lg);
  font-size: 15px;
  font-weight: 600;
  font-family: 'Outfit', sans-serif;
  cursor: pointer;
  letter-spacing: .02em;
  transition: all .25s;
  width: 100%;
}
.btn-atc:hover { background: #A07D10; transform: translateY(-1px); box-shadow: 0 6px 20px rgba(196,154,26,.35); }
.btn-buy {
  background: var(--terracotta-bg);
  color: var(--terracotta);
  border: 1px solid rgba(181,89,58,.25);
  padding: 15px;
  border-radius: var(--r-lg);
  font-size: 15px;
  font-weight: 500;
  font-family: 'Outfit', sans-serif;
  cursor: pointer;
  transition: all .2s;
  width: 100%;
}
.btn-buy:hover { background: #EEDDD6; }

/* TRUST ROW */
.trust-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  padding-top: 4px;
}
.trust-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  text-align: center;
  padding: 14px 10px;
  background: var(--linen);
  border-radius: var(--r);
  border: 1px solid var(--warm-border);
}
.trust-icon {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--sage);
  display: flex;
  align-items: center;
  justify-content: center;
}
.trust-icon svg { width: 14px; height: 14px; stroke: #fff; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.trust-label { font-size: 11px; color: var(--ink-70); font-weight: 500; line-height: 1.3; }

/* ── SOCIAL PROOF BAR ── */
.proof-bar {
  background: var(--linen);
  border-top: 1px solid var(--warm-border);
  border-bottom: 1px solid var(--warm-border);
  padding: 18px 6%;
  display: flex;
  align-items: center;
  justify-content: space-evenly;
  gap: 40px;
  flex-wrap: wrap;
}
.proof-item { text-align: center; }
.proof-num {
  font-family: 'Cormorant Garamond', serif;
  font-size: 30px;
  font-weight: 400;
  color: var(--ink);
  line-height: 1;
  display: block;
}
.proof-label { font-size: 12px; color: var(--ink-40); letter-spacing: .03em; }
.proof-divider { width: 1px; height: 36px; background: var(--warm-border); }

/* ── SECTIONS SHARED ── */
.section { padding: 90px 6%; }
.section-inner { max-width: 1200px; margin: 0 auto; }
.section-eyebrow {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--terracotta);
  margin-bottom: 14px;
}
.section-heading {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(28px, 3.5vw, 46px);
  font-weight: 400;
  line-height: 1.12;
  letter-spacing: -.025em;
  color: var(--ink);
  margin-bottom: 0;
}
.section-heading em { font-style: italic; color: var(--terracotta); }

/* ── FEATURES ── */
.features { background: var(--paper); }
.features-layout {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 80px;
  align-items: center;
}
.features-visual {
  background: var(--linen);
  border-radius: var(--r-xl);
  height: 480px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}
.features-visual-label {
  position: absolute;
  bottom: 24px;
  left: 24px;
  right: 24px;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(12px);
  border-radius: var(--r-lg);
  padding: 16px 20px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.fv-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--sage); flex-shrink: 0; }
.fv-text { font-size: 13px; color: var(--ink-70); line-height: 1.5; }
.fv-text strong { color: var(--ink); font-weight: 500; }
.features-list { display: flex; flex-direction: column; gap: 0; }
.feature-item {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 16px;
  padding: 22px 0;
  border-bottom: 1px solid var(--warm-border);
  align-items: flex-start;
}
.feature-item:first-child { padding-top: 0; }
.feature-num {
  font-family: 'Cormorant Garamond', serif;
  font-size: 32px;
  font-weight: 300;
  color: var(--ink-15);
  line-height: 1;
  padding-top: 2px;
}
.feature-title { font-size: 15px; font-weight: 500; color: var(--ink); margin-bottom: 5px; }
.feature-desc { font-size: 13.5px; color: var(--ink-70); line-height: 1.65; }

/* ── WHY ── */
.why { background: var(--linen); }
.why-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 52px;
}
.why-card {
  background: var(--paper);
  border: 1px solid var(--warm-border);
  border-radius: var(--r-xl);
  padding: 32px 28px;
  transition: transform .3s ease, box-shadow .3s ease;
  cursor: default;
}
.why-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 48px rgba(15,13,10,.08);
}
.why-icon-wrap {
  width: 48px; height: 48px;
  border-radius: var(--r-lg);
  background: var(--sage-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 18px;
}
.why-icon-wrap svg { width: 22px; height: 22px; stroke: var(--sage); fill: none; stroke-width: 1.5; stroke-linecap: round; stroke-linejoin: round; }
.why-title { font-size: 16px; font-weight: 500; color: var(--ink); margin-bottom: 8px; }
.why-desc { font-size: 13.5px; color: var(--ink-70); line-height: 1.7; }

/* ── TESTIMONIALS ── */
.testimonials { background: var(--paper); }
.testimonials-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 52px; flex-wrap: wrap; gap: 24px; }
.rating-summary { display: flex; align-items: center; gap: 18px; }
.rating-big-num {
  font-family: 'Cormorant Garamond', serif;
  font-size: 64px;
  font-weight: 300;
  color: var(--ink);
  line-height: 1;
}
.rating-breakdown { display: flex; flex-direction: column; gap: 3px; }
.rb-row { display: flex; align-items: center; gap: 6px; font-size: 11px; color: var(--ink-40); }
.rb-bar { width: 80px; height: 3px; background: var(--warm-border); border-radius: 100px; overflow: hidden; }
.rb-fill { height: 100%; background: var(--gold); border-radius: 100px; }

.testi-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.testi-card {
  background: var(--linen);
  border: 1px solid var(--warm-border);
  border-radius: var(--r-xl);
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: box-shadow .3s;
}
.testi-card:hover { box-shadow: 0 8px 32px rgba(15,13,10,.07); }
.testi-card.featured-review {
  background: var(--sage);
  border-color: var(--sage);
  grid-column: span 1;
}
.testi-top { display: flex; align-items: center; gap: 12px; }
.reviewer-init {
  width: 40px; height: 40px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 600;
  flex-shrink: 0;
}
.reviewer-meta { flex: 1; min-width: 0; }
.r-name { font-size: 14px; font-weight: 500; }
.r-sub { font-size: 12px; color: var(--ink-40); margin-top: 1px; }
.r-stars-row { display: flex; gap: 1px; }
.r-star { width: 12px; height: 12px; background: var(--gold); clip-path: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%); }
.r-star.grey { background: #D5CEBF; }
.testi-text { font-size: 14px; line-height: 1.75; color: var(--ink-70); font-style: italic; }
.featured-review .r-name { color: #fff; }
.featured-review .r-sub { color: rgba(255,255,255,.55); }
.featured-review .testi-text { color: rgba(255,255,255,.82); }
.verified-tag { font-size: 11px; color: var(--sage); font-weight: 500; letter-spacing: .03em; display: flex; align-items: center; gap: 5px; }
.verified-tag::before { content: ''; display: inline-block; width: 12px; height: 12px; background: var(--sage); border-radius: 50%; }
.featured-review .verified-tag { color: rgba(255,255,255,.6); }
.featured-review .verified-tag::before { background: rgba(255,255,255,.4); }

/* ── SPECS ── */
.specs-section { background: var(--linen); }
.specs-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: start; margin-top: 52px; }
.spec-table { border: 1px solid var(--warm-border); border-radius: var(--r-xl); overflow: hidden; }
.spec-row { display: grid; grid-template-columns: 1.1fr 1fr; }
.spec-row + .spec-row { border-top: 1px solid var(--warm-border); }
.spec-key { padding: 13px 20px; background: var(--paper); font-size: 13px; color: var(--ink-40); font-weight: 500; }
.spec-val { padding: 13px 20px; font-size: 13px; color: var(--ink); font-weight: 400; }
.includes-list { display: flex; flex-direction: column; gap: 16px; }
.inc-item { display: flex; align-items: flex-start; gap: 14px; }
.inc-check {
  width: 20px; height: 20px; border-radius: 50%;
  background: var(--sage);
  flex-shrink: 0; margin-top: 2px;
  display: flex; align-items: center; justify-content: center;
}
.inc-check svg { width: 10px; height: 10px; stroke: #fff; fill: none; stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round; }
.inc-text { font-size: 14px; color: var(--ink-70); line-height: 1.55; }
.inc-text strong { color: var(--ink); font-weight: 500; }
.vet-box {
  margin-top: 28px;
  background: var(--paper);
  border: 1px solid var(--warm-border);
  border-radius: var(--r-lg);
  padding: 22px 24px;
  display: grid;
  grid-template-columns: 48px 1fr;
  gap: 14px;
  align-items: center;
}
.vet-icon {
  width: 48px; height: 48px; border-radius: var(--r);
  background: var(--terracotta-bg);
  display: flex; align-items: center; justify-content: center;
}
.vet-icon svg { width: 22px; height: 22px; stroke: var(--terracotta); fill: none; stroke-width: 1.5; stroke-linecap: round; stroke-linejoin: round; }
.vet-title { font-size: 14px; font-weight: 500; color: var(--ink); margin-bottom: 4px; }
.vet-desc { font-size: 13px; color: var(--ink-70); line-height: 1.5; }
.vet-link { color: var(--terracotta); text-decoration: none; font-weight: 500; }

/* ── FAQ ── */
.faq-section { background: var(--paper); }
.faq-layout { display: grid; grid-template-columns: 1fr 1.6fr; gap: 80px; align-items: start; margin-top: 52px; }
.faq-intro .section-heading { font-size: clamp(24px, 2.5vw, 36px); }
.faq-intro p { font-size: 15px; color: var(--ink-70); margin-top: 18px; line-height: 1.75; }
.faq-list { display: flex; flex-direction: column; gap: 0; }
.faq-item { border-bottom: 1px solid var(--warm-border); }
.faq-item:first-child { border-top: 1px solid var(--warm-border); }
.faq-q {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 0;
  width: 100%;
  background: transparent;
  border: none;
  text-align: left;
  font-family: 'Outfit', sans-serif;
  font-size: 15px;
  font-weight: 400;
  color: var(--ink);
  cursor: pointer;
  transition: color .2s;
  gap: 16px;
}
.faq-q:hover { color: var(--terracotta); }
.faq-q.open { color: var(--terracotta); font-weight: 500; }
.faq-icon {
  width: 26px; height: 26px; border-radius: 50%;
  border: 1px solid var(--warm-border);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: all .25s;
}
.faq-icon svg { width: 12px; height: 12px; stroke: var(--ink-40); fill: none; stroke-width: 2; transition: transform .25s; }
.faq-q.open .faq-icon { background: var(--terracotta); border-color: var(--terracotta); }
.faq-q.open .faq-icon svg { stroke: #fff; transform: rotate(45deg); }
.faq-a {
  font-size: 14px;
  color: var(--ink-70);
  line-height: 1.75;
  max-height: 0;
  overflow: hidden;
  transition: max-height .35s ease, padding .35s ease;
  padding: 0;
}
.faq-a.open { max-height: 200px; padding-bottom: 20px; }

/* ── CTA SECTION ── */
.cta-section {
  background: var(--ink);
  padding: 100px 6%;
  position: relative;
  overflow: hidden;
}
.cta-section::before {
  content: '';
  position: absolute;
  top: -200px; right: -200px;
  width: 600px; height: 600px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(181,89,58,.18) 0%, transparent 60%);
}
.cta-inner { max-width: 720px; margin: 0 auto; text-align: center; position: relative; z-index: 1; }
.cta-eyebrow { color: var(--terracotta-light); font-size: 11px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; margin-bottom: 20px; }
.cta-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(34px, 4vw, 56px);
  font-weight: 300;
  color: #fff;
  line-height: 1.12;
  letter-spacing: -.025em;
  margin-bottom: 18px;
}
.cta-title em { font-style: italic; color: var(--terracotta-light); font-weight: 400; }
.cta-subtitle { font-size: 16px; color: rgba(255,255,255,.6); margin-bottom: 40px; line-height: 1.7; }
.cta-btns { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.cta-btn-primary {
  background: #fff;
  color: var(--ink);
  border: none;
  padding: 16px 40px;
  border-radius: 100px;
  font-size: 15px;
  font-weight: 500;
  font-family: 'Outfit', sans-serif;
  cursor: pointer;
  transition: all .25s;
}
.cta-btn-primary:hover { background: var(--gold-light); transform: translateY(-2px); box-shadow: 0 10px 30px rgba(0,0,0,.35); }
.cta-btn-secondary {
  background: transparent;
  color: rgba(255,255,255,.7);
  border: 1px solid rgba(255,255,255,.2);
  padding: 15px 32px;
  border-radius: 100px;
  font-size: 15px;
  font-weight: 400;
  font-family: 'Outfit', sans-serif;
  cursor: pointer;
  transition: all .2s;
}
.cta-btn-secondary:hover { border-color: rgba(255,255,255,.6); color: #fff; }
.cta-trust { margin-top: 24px; font-size: 12px; color: rgba(255,255,255,.35); }

/* ── FOOTER ── */
footer {
  background: #0D0B09;
  padding: 60px 6% 30px;
}
.footer-top { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; margin-bottom: 48px; }
.footer-logo-wrap { display: flex; flex-direction: column; gap: 16px; }
.f-logo { font-family: 'Cormorant Garamond', serif; font-size: 22px; font-weight: 500; color: #fff; }
.f-logo sup { font-family: 'Outfit', sans-serif; font-size: 10px; color: rgba(255,255,255,.4); }
.f-desc { font-size: 13px; color: rgba(255,255,255,.45); line-height: 1.7; }
.f-social { display: flex; gap: 12px; }
.f-soc-link {
  width: 32px; height: 32px; border-radius: 50%;
  border: 1px solid rgba(255,255,255,.1);
  display: flex; align-items: center; justify-content: center;
  text-decoration: none; color: rgba(255,255,255,.5);
  font-size: 12px; font-weight: 500;
  transition: all .2s;
}
.f-soc-link:hover { border-color: rgba(255,255,255,.35); color: #fff; }
.f-col-title { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .1em; color: rgba(255,255,255,.5); margin-bottom: 18px; }
.f-links { list-style: none; display: flex; flex-direction: column; gap: 11px; }
.f-links a { text-decoration: none; color: rgba(255,255,255,.45); font-size: 13.5px; transition: color .2s; }
.f-links a:hover { color: rgba(255,255,255,.85); }
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.08);
  padding-top: 28px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
}
.f-copy { font-size: 12px; color: rgba(255,255,255,.3); }
.f-pay { display: flex; gap: 8px; }
.pay-chip {
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 4px;
  padding: 4px 10px;
  font-size: 10px;
  color: rgba(255,255,255,.45);
  font-weight: 500;
  letter-spacing: .04em;
}

/* ── STICKY BAR ── */
.sticky-bar {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  background: rgba(250,250,248,.97);
  backdrop-filter: blur(16px);
  border-top: 1px solid var(--warm-border);
  padding: 14px 5%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  z-index: 150;
  transform: translateY(100%);
  transition: transform .45s cubic-bezier(.16,1,.3,1);
  box-shadow: 0 -8px 40px rgba(15,13,10,.08);
}
.sticky-bar.visible { transform: translateY(0); }
.sticky-info { display: flex; align-items: center; gap: 16px; flex: 1; }
.sticky-name { font-size: 14px; font-weight: 500; color: var(--ink); }
.sticky-variant { font-size: 12px; color: var(--ink-40); }
.sticky-rating { display: flex; align-items: center; gap: 5px; }
.sticky-stars { display: flex; gap: 1px; }
.sticky-star { width: 10px; height: 10px; background: var(--gold); clip-path: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%); }
.sticky-count { font-size: 11px; color: var(--ink-40); }
.sticky-price { font-family: 'Cormorant Garamond', serif; font-size: 28px; font-weight: 400; color: var(--ink); }
.sticky-atc {
  background: #C49A1A;
  color: #fff;
  border: none;
  padding: 13px 32px;
  border-radius: var(--r-lg);
  font-size: 14px;
  font-weight: 600;
  font-family: 'Outfit', sans-serif;
  cursor: pointer;
  transition: background .2s;
  white-space: nowrap;
}
.sticky-atc:hover { background: #A07D10; }

/* ── ANIMATIONS ── */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .65s ease, transform .65s ease;
}
.reveal.in { opacity: 1; transform: translateY(0); }

/* ── URGENCY ── */

/* Stock bar */
.stock-block {
  background: var(--linen);
  border: 1px solid var(--warm-border);
  border-radius: var(--r);
  padding: 12px 16px;
  display: flex;
  flex-direction: column;
  gap: 7px;
}
.stock-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 13px;
}
.stock-label { color: var(--ink-70); font-weight: 400; }
.stock-count { font-weight: 600; color: var(--terracotta); font-size: 13px; }
.stock-bar-bg {
  height: 5px;
  background: var(--warm-border);
  border-radius: 100px;
  overflow: hidden;
}
.stock-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--terracotta), #E8835A);
  border-radius: 100px;
  width: 23%;
  animation: stock-pulse 2.5s ease-in-out infinite;
}
@keyframes stock-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: .75; }
}
.stock-sold { font-size: 11.5px; color: var(--ink-40); }

/* Countdown */
.countdown-block {
  background: #FEF6E4;
  border: 1px solid #F0D898;
  border-radius: var(--r);
  padding: 12px 16px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.countdown-label {
  font-size: 12.5px;
  color: #6B4A0A;
  flex: 1;
  line-height: 1.4;
}
.countdown-label strong { font-weight: 600; }
.countdown-timer {
  display: flex;
  gap: 4px;
  align-items: center;
  flex-shrink: 0;
}
.cd-unit {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
}
.cd-num {
  background: #8B6010;
  color: #fff;
  font-size: 16px;
  font-weight: 600;
  font-family: 'Outfit', sans-serif;
  min-width: 30px;
  text-align: center;
  border-radius: 4px;
  padding: 3px 4px;
  line-height: 1.2;
  letter-spacing: .04em;
}
.cd-label-s {
  font-size: 9px;
  color: #8B6010;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.cd-sep { font-size: 15px; font-weight: 700; color: #8B6010; margin-bottom: 10px; }

/* Social activity */
.activity-bar {
  display: flex;
  flex-direction: column;
  gap: 0;
  overflow: hidden;
  max-height: calc(3 * 44px);
}
.activity-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12.5px;
  color: var(--ink-70);
  padding: 7px 0;
  border-bottom: 1px solid var(--warm-border);
  animation: fade-slide-in .4s ease;
}
.activity-item:last-child { border-bottom: none; }
@keyframes fade-slide-in {
  from { opacity: 0; transform: translateY(-6px); }
  to { opacity: 1; transform: translateY(0); }
}
.activity-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--sage);
  flex-shrink: 0;
  animation: dot-blink 1.8s ease-in-out infinite;
}
@keyframes dot-blink {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: .5; transform: scale(.85); }
}
.activity-dot.red { background: var(--terracotta); }
.activity-time { color: var(--ink-40); font-size: 11.5px; margin-left: auto; }

/* Viewing now badge */
.viewing-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: rgba(58,84,71,.08);
  border: 1px solid rgba(58,84,71,.18);
  border-radius: 100px;
  padding: 6px 14px;
  font-size: 12.5px;
  color: var(--sage);
  font-weight: 500;
}
.viewing-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--sage);
  animation: dot-blink 1.2s ease-in-out infinite;
}

/* Shipping deadline */
.ship-deadline {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--ink-70);
  padding: 10px 0 0;
}
.ship-icon {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--sage-bg);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.ship-icon svg { width: 13px; height: 13px; stroke: var(--sage); fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.ship-text strong { color: var(--sage); font-weight: 600; }

/* Toast notification */
.toast {
  position: fixed;
  bottom: 90px;
  left: 20px;
  background: var(--paper);
  border: 1px solid var(--warm-border);
  border-radius: var(--r-lg);
  padding: 12px 16px;
  display: flex;
  align-items: center;
  gap: 10px;
  box-shadow: 0 8px 30px rgba(15,13,10,.12);
  z-index: 300;
  max-width: 280px;
  transform: translateX(-110%);
  transition: transform .5s cubic-bezier(.16,1,.3,1);
  pointer-events: none;
}
.toast.show { transform: translateX(0); }
.toast-avatar {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--linen);
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 600; color: var(--terracotta);
  flex-shrink: 0; border: 1px solid var(--warm-border);
}
.toast-content { flex: 1; min-width: 0; }
.toast-name { font-size: 13px; font-weight: 500; color: var(--ink); }
.toast-action { font-size: 12px; color: var(--ink-70); margin-top: 1px; line-height: 1.35; }
.toast-time { font-size: 11px; color: var(--ink-40); }

/* ── VARIANT DROPDOWNS ── */
.pawrest-select-wrap {
  position: relative;
  display: block;
  width: 100%;
}
.pawrest-select {
  width: 100%;
  appearance: none;
  -webkit-appearance: none;
  background: var(--paper);
  border: 1px solid var(--warm-border);
  border-radius: var(--r);
  padding: 11px 40px 11px 14px;
  font-size: 14px;
  font-weight: 400;
  font-family: 'Outfit', sans-serif;
  color: var(--ink);
  cursor: pointer;
  transition: border-color .2s, box-shadow .2s;
  outline: none;
  line-height: 1.4;
}
.pawrest-select:hover {
  border-color: var(--ink-40);
}
.pawrest-select:focus {
  border-color: var(--terracotta);
  box-shadow: 0 0 0 3px rgba(181,89,58,.12);
}
.pawrest-select option:disabled {
  color: var(--ink-40);
  font-style: italic;
}
.pawrest-select-arrow {
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  color: var(--ink-40);
  display: flex;
  align-items: center;
}


@media (max-width: 960px) {
  .product-section { grid-template-columns: 1fr; }
  .product-info {
    border-left: none;
    border-top: none;
    padding: 20px 5% 36px;
    display: flex;
    flex-direction: column;
    gap: 16px;
  }

  /* ── Reorder mobile : prix + variantes + CTA en premier ── */
  .product-rating    { order: 5; }
  .product-badges    { order: 6; }
  h1.product-title   { order: 7; }
  .price-block       { order: 1; padding-top: 4px; }
  .pawrest-form-variants { order: 2; }
  .cta-stack         { order: 3; }
  .trust-row         { order: 4; grid-template-columns: repeat(3, 1fr); }
  .product-desc      { order: 8; }
  .urgency-group     { order: 9; }

  /* Réduit les espaces urgence sur mobile */
  .viewing-badge, .ship-deadline { font-size: 12px; }
  .stock-block { padding: 10px 14px; }
  .countdown-block { padding: 10px 14px; }

  .features-layout { grid-template-columns: 1fr; gap: 40px; }
  .features-visual { height: 280px; }
  .why-grid { grid-template-columns: 1fr 1fr; }
  .testi-grid { grid-template-columns: 1fr; }
  .specs-layout { grid-template-columns: 1fr; gap: 40px; }
  .faq-layout { grid-template-columns: 1fr; gap: 40px; }
  .footer-top { grid-template-columns: 1fr 1fr; gap: 32px; }
  .nav-links { display: none; }
  .proof-divider { display: none; }
}
@media (max-width: 600px) {
  .section { padding: 60px 5%; }
  .why-grid { grid-template-columns: 1fr; }
  .size-grid { grid-template-columns: repeat(2, 1fr); }
  .trust-row { grid-template-columns: 1fr; }
  .footer-top { grid-template-columns: 1fr; }
  .sticky-bar { flex-wrap: wrap; }
  .sticky-info { flex-direction: column; align-items: flex-start; gap: 4px; }
  /* Prix bien visible sur mobile */
  .price-current { font-size: 36px; }
  /* Bouton ATC pleine largeur et plus grand */
  .btn-atc { padding: 18px; font-size: 16px; border-radius: 12px; }
  /* Variantes côte à côte */
  .pawrest-form-variants { display: flex; flex-direction: column; gap: 12px; }
}