/* ============================================================
   AMYZA — page-specific styles (shop / product / contact)
   Builds on style.css (vars, buttons, header, footer, cart).
   ============================================================ */

/* button alias used by shared cart drawer */
.btn-secondary { background: transparent; color: var(--plum); border-color: var(--plum); }
.btn-secondary:hover { background: var(--plum); color: var(--porcelain); transform: translateY(-2px); }

/* active nav state */
.nav-left a.active,
.mobile-menu a.active { color: var(--plum); }
.nav-left a.active::after { width: 100%; }

/* gradient product-card label (shop + related) */
.pc-label {
  position: absolute; left: 1rem; top: 1rem; z-index: 2;
  font-size: .62rem; letter-spacing: .18em; text-transform: uppercase;
  background: rgba(241,237,236,.9); color: var(--plum);
  padding: .35rem .7rem; border-radius: 999px; font-weight: 600;
}

/* toast */
.amyza-toast {
  position: fixed; left: 50%; bottom: 2rem; transform: translate(-50%, 140%);
  background: var(--plum-deep); color: var(--porcelain);
  padding: .85rem 1.5rem; border-radius: 999px; font-size: .85rem;
  letter-spacing: .02em; z-index: 600; box-shadow: 0 14px 40px rgba(78,10,58,.4);
  transition: transform .5s cubic-bezier(.16,1,.3,1); pointer-events: none; max-width: 90vw;
}
.amyza-toast.show { transform: translate(-50%, 0); }

body.drawer-lock { overflow: hidden; }

/* ============================================================
   COLLECTION (shop) HERO
   ============================================================ */
.collection-hero {
  background: linear-gradient(135deg, var(--plum) 0%, var(--plum-deep) 55%, #8C4C70 100%);
  color: var(--porcelain); padding: 9rem 6vw 3.5rem; text-align: center;
  position: relative; overflow: hidden;
}
.collection-hero .eyebrow { color: var(--blush); }
.collection-hero h1 { font-size: clamp(2.8rem, 7vw, 5.5rem); color: var(--porcelain); line-height: 1.02; }
.collection-hero h1 .serif-italic { color: var(--blush); }
.collection-hero .ch-sub {
  max-width: 560px; margin: 1.4rem auto 0; color: rgba(241,237,236,.82);
  font-size: 1.05rem; line-height: 1.6;
}
.ingredient-marquee {
  margin-top: 2.6rem; overflow: hidden; -webkit-mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
  mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
}
.ingredient-marquee .marquee-track {
  display: inline-flex; gap: 3rem; white-space: nowrap;
  animation: amyza-marquee 26s linear infinite;
}
.ingredient-marquee span {
  font-family: var(--serif); font-style: italic; font-size: 1.3rem;
  color: rgba(234,172,201,.8);
}
.ingredient-marquee span::after { content: '✦'; margin-left: 3rem; color: rgba(234,172,201,.4); font-style: normal; }
@keyframes amyza-marquee { to { transform: translateX(-50%); } }

/* shop toolbar / filters */
.shop-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 1rem; padding: 1.6rem 6vw; border-bottom: 1px solid rgba(115,17,87,.1);
  position: sticky; top: 0; background: rgba(247,244,243,.86); backdrop-filter: blur(12px); z-index: 50;
}
.filter-chips { display: flex; flex-wrap: wrap; gap: .55rem; }
.chip {
  border: 1px solid rgba(115,17,87,.25); background: transparent; color: var(--ink);
  padding: .5rem 1.05rem; border-radius: 999px; font-size: .78rem; letter-spacing: .04em;
  cursor: pointer; transition: .3s; text-transform: capitalize;
}
.chip:hover { border-color: var(--plum); color: var(--plum); }
.chip.active { background: var(--plum); border-color: var(--plum); color: var(--porcelain); }
.shop-count { font-size: .78rem; letter-spacing: .12em; text-transform: uppercase; color: #998; }

/* collection grid */
.collection-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem 1.6rem;
  padding: 3rem 6vw 4rem;
}
.collection-grid .product-card { position: relative; }
.collection-grid .product-image-wrap {
  position: relative; display: block; aspect-ratio: 4/5; border-radius: var(--radius-md, 14px);
  overflow: hidden; background: var(--plum);
}
.collection-grid .product-image-wrap .pc-bg {
  position: absolute; inset: 0; transition: transform .8s cubic-bezier(.16,1,.3,1);
}
.collection-grid .product-card:hover .pc-bg { transform: scale(1.06); }
.collection-grid .quick-add {
  position: absolute; left: 50%; bottom: 1rem; transform: translate(-50%, 160%);
  background: var(--porcelain); color: var(--plum); border: none; cursor: pointer;
  padding: .7rem 1.4rem; border-radius: 999px; font-size: .76rem; letter-spacing: .06em;
  font-weight: 600; transition: transform .45s cubic-bezier(.16,1,.3,1), background .3s; z-index: 3;
}
.collection-grid .product-card:hover .quick-add { transform: translate(-50%, 0); }
.collection-grid .quick-add:hover { background: var(--plum); color: var(--porcelain); }
.collection-grid .product-info { padding: 1rem .2rem 0; }
.collection-grid .pc-cat { font-size: .68rem; letter-spacing: .18em; text-transform: uppercase; color: #998; }
.collection-grid .pc-title { font-family: var(--serif); font-size: 1.35rem; margin: .25rem 0; color: var(--ink); }
.collection-grid .pc-foot { display: flex; align-items: center; justify-content: space-between; margin-top: .4rem; }
.collection-grid .pc-price { font-family: var(--serif); font-size: 1.15rem; color: var(--plum); }
.collection-grid .pc-rating { font-size: .8rem; color: var(--olive); }
.product-card[hidden] { display: none; }
.no-results { grid-column: 1/-1; text-align: center; padding: 3rem; color: #998; font-style: italic; }

/* shop editorial CTA */
.shop-editorial {
  margin: 1rem 6vw 4rem; padding: 4rem 2rem; border-radius: 20px; text-align: center;
  background: linear-gradient(135deg, var(--blush), #f3d6e3);
}
.shop-editorial h2 { font-size: clamp(2rem, 4vw, 3.2rem); color: var(--plum-deep); }
.shop-editorial p { max-width: 480px; margin: 1rem auto 1.6rem; color: var(--ink); }

/* ============================================================
   BREADCRUMB
   ============================================================ */
.breadcrumb { padding: 6.5rem 6vw 0; font-size: .76rem; letter-spacing: .08em; color: #998; }
.breadcrumb a { color: #998; transition: color .3s; }
.breadcrumb a:hover { color: var(--plum); }
.breadcrumb span { color: var(--plum); }

/* ============================================================
   PDP (product detail)
   ============================================================ */
.pdp { display: grid; grid-template-columns: 1.05fr 1fr; gap: 4rem; padding: 2rem 6vw 4rem; }
.pdp-gallery { position: sticky; top: 2rem; align-self: start; }
.pdp-main {
  aspect-ratio: 4/5; border-radius: 20px; overflow: hidden; position: relative;
  background: #efe7ea;
}
.pdp-main .ri-inner img,
.pdp-main img#pdpMain { width: 100%; height: 100%; object-fit: cover; display: block; transition: opacity .35s ease; }
.pdp-thumbs button img { width: 100%; height: 100%; object-fit: cover; display: block; }
.pdp-thumbs { display: flex; gap: .8rem; margin-top: 1rem; }
.pdp-thumbs button {
  width: 74px; height: 90px; border-radius: 12px; border: 2px solid transparent;
  cursor: pointer; overflow: hidden; padding: 0; transition: border-color .3s, transform .3s;
}
.pdp-thumbs button:hover { transform: translateY(-3px); }
.pdp-thumbs button.active { border-color: var(--plum); }

.pdp-info { padding-top: 1rem; }
.pdp-info .eyebrow { color: var(--plum); }
.pdp-title { font-size: clamp(2.4rem, 4.5vw, 3.6rem); line-height: 1.04; color: var(--ink); }
.pdp-tagline { font-family: var(--serif); font-style: italic; color: var(--plum); font-size: 1.25rem; margin-top: .4rem; }
.pdp-rating { margin: 1rem 0; color: var(--olive); font-size: .9rem; }
.pdp-rating em { color: #998; font-style: normal; }
.pdp-desc { color: #5a4350; line-height: 1.7; margin-bottom: 1.6rem; max-width: 46ch; }
.pdp-benefits { list-style: none; display: flex; flex-wrap: wrap; gap: .6rem; margin-bottom: 1.8rem; padding: 0; }
.pdp-benefits li {
  background: var(--porcelain-soft); border: 1px solid rgba(115,17,87,.12);
  padding: .5rem 1rem; border-radius: 999px; font-size: .76rem; letter-spacing: .04em; color: var(--plum);
}

.pdp-variants { margin-bottom: 1.6rem; }
.pdp-variants .var-label { font-size: .7rem; letter-spacing: .2em; text-transform: uppercase; color: #998; margin-bottom: .7rem; }
.variant-row { display: flex; gap: .7rem; flex-wrap: wrap; }
.variant-opt {
  border: 1px solid rgba(115,17,87,.25); background: transparent; cursor: pointer;
  padding: .8rem 1.1rem; border-radius: 12px; text-align: left; transition: .3s; min-width: 130px;
}
.variant-opt strong { display: block; font-size: .9rem; color: var(--ink); margin-bottom: .15rem; font-weight: 600; }
.variant-opt em { font-style: normal; font-size: .8rem; color: var(--plum); }
.variant-opt em s { color: #bba; margin-left: .3rem; }
.variant-opt:hover { border-color: var(--plum); }
.variant-opt.active { border-color: var(--plum); background: rgba(115,17,87,.06); }

.pdp-buy { display: flex; gap: 1rem; align-items: stretch; margin-bottom: 1rem; }
.qty-stepper {
  display: inline-flex; align-items: center; border: 1px solid rgba(115,17,87,.25);
  border-radius: 12px; overflow: hidden;
}
.qty-stepper button {
  background: none; border: none; cursor: pointer; font-size: 1.2rem; color: var(--plum);
  width: 44px; height: 100%; transition: background .25s;
}
.qty-stepper button:hover { background: rgba(115,17,87,.08); }
.qty-stepper span { min-width: 40px; text-align: center; font-size: .95rem; }
.pdp-add { flex: 1; }
.pdp-note { font-size: .76rem; color: #998; letter-spacing: .04em; margin-bottom: 1.8rem; }

/* accordion */
.pdp-accordion { border-top: 1px solid rgba(115,17,87,.14); }
.pdp-accordion details { border-bottom: 1px solid rgba(115,17,87,.14); }
.pdp-accordion summary {
  list-style: none; cursor: pointer; padding: 1.1rem 0; display: flex; justify-content: space-between;
  align-items: center; font-size: .95rem; color: var(--ink); font-weight: 500;
}
.pdp-accordion summary::-webkit-details-marker { display: none; }
.pdp-accordion summary::after { content: '+'; color: var(--plum); font-size: 1.3rem; transition: transform .3s; }
.pdp-accordion details[open] summary::after { transform: rotate(45deg); }
.pdp-accordion .acc-body { padding: 0 0 1.2rem; color: #5a4350; line-height: 1.7; font-size: .9rem; }

/* ============================================================
   INGREDIENT STORY (pinned bg swap)
   ============================================================ */
.ingredient-story {
  display: grid; grid-template-columns: 1fr 1fr; gap: 0;
  background: var(--plum-deep); color: var(--porcelain);
}
.ing-visual {
  position: sticky; top: 0; height: 100vh;
  background-color: var(--plum-deep);
  background-size: cover; background-position: center; background-repeat: no-repeat;
  transition: background-image .8s ease, opacity .8s ease;
}
.ing-step[data-bg] { /* bg used only as data source for JS swap */ }
.ing-steps { padding: 4rem 5vw; }
.ing-step { min-height: 80vh; display: flex; flex-direction: column; justify-content: center; opacity: .35; transition: opacity .6s ease; }
.ing-step.ing-on { opacity: 1; }
.ing-step .eyebrow { color: var(--blush); }
.ing-step h2 { font-size: clamp(2rem, 4vw, 3.2rem); color: var(--porcelain); }
.ing-step h2 .serif-italic { color: var(--blush); }
.ing-step p { color: rgba(241,237,236,.78); line-height: 1.7; margin-top: 1rem; max-width: 44ch; }

/* reviews + related */
.pdp-reviews { padding: 4rem 6vw; text-align: center; }
.pdp-reviews h2 { font-size: clamp(2rem, 4vw, 3rem); color: var(--plum); margin-bottom: 2.4rem; }
.reviews-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.6rem; }
.review-card {
  background: var(--porcelain-soft); border: 1px solid rgba(115,17,87,.1);
  border-radius: 16px; padding: 1.8rem; text-align: left;
}
.review-card .stars { color: var(--olive); margin-bottom: .8rem; }
.review-card p { color: #5a4350; line-height: 1.6; font-style: italic; margin-bottom: 1rem; }
.review-card .rv-name { font-size: .8rem; letter-spacing: .1em; text-transform: uppercase; color: var(--plum); }

.related { padding: 1rem 6vw 5rem; }
.related h2 { font-size: clamp(1.8rem, 3.5vw, 2.6rem); color: var(--plum); margin-bottom: 2rem; text-align: center; }
.related-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.6rem; }

/* sticky ATC */
.sticky-atc {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 300;
  background: rgba(241,237,236,.94); backdrop-filter: blur(14px);
  border-top: 1px solid rgba(115,17,87,.14); padding: .9rem 6vw;
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  transform: translateY(110%); transition: transform .55s cubic-bezier(.16,1,.3,1);
  box-shadow: 0 -10px 40px rgba(115,17,87,.12);
}
.sticky-atc.show { transform: translateY(0); }
.sticky-atc .sa-info { display: flex; flex-direction: column; }
.sticky-atc .sa-name { font-family: var(--serif); font-size: 1.15rem; color: var(--plum); }
.sticky-atc .sa-variant { font-size: .72rem; letter-spacing: .08em; color: #998; text-transform: uppercase; }
.sticky-atc .sa-right { display: flex; align-items: center; gap: 1.2rem; }
.sticky-atc .sa-price { font-family: var(--serif); font-size: 1.4rem; color: var(--plum); }

/* ============================================================
   CONTACT
   ============================================================ */
.contact-hero {
  background: linear-gradient(135deg, var(--blush) 0%, #f3d6e3 50%, var(--porcelain) 100%);
  padding: 9rem 6vw 4rem; text-align: center; position: relative; overflow: hidden;
}
.contact-hero h1 { font-size: clamp(2.8rem, 7vw, 5.5rem); color: var(--plum-deep); line-height: 1.02; }
.contact-hero h1 .serif-italic { color: var(--plum); }
.contact-hero p { max-width: 520px; margin: 1.3rem auto 0; color: #5a4350; font-size: 1.05rem; line-height: 1.6; }
.contact-orb { position: absolute; border-radius: 50%; filter: blur(8px); opacity: .55; pointer-events: none; }
.contact-orb.o1 { width: 200px; height: 200px; background: var(--plum); left: 6%; top: 20%; animation: float-orb 9s ease-in-out infinite; }
.contact-orb.o2 { width: 140px; height: 140px; background: var(--olive); right: 8%; bottom: 14%; animation: float-orb 11s ease-in-out infinite reverse; }
@keyframes float-orb { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-26px); } }

.contact-body { display: grid; grid-template-columns: 1.3fr 1fr; gap: 3rem; padding: 4rem 6vw; }
.contact-form { display: flex; flex-direction: column; gap: 1.2rem; }
.field { display: flex; flex-direction: column; gap: .45rem; }
.field label { font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--plum); }
.field input, .field textarea, .field select {
  font-family: var(--sans); font-size: .95rem; color: var(--ink);
  background: var(--porcelain-soft); border: 1px solid rgba(115,17,87,.18);
  border-radius: 12px; padding: .9rem 1rem; transition: border-color .3s, box-shadow .3s;
}
.field input:focus, .field textarea:focus, .field select:focus {
  outline: none; border-color: var(--plum); box-shadow: 0 0 0 3px rgba(115,17,87,.1);
}
.field textarea { resize: vertical; min-height: 130px; }
.contact-form .btn { align-self: flex-start; }
.form-status { font-size: .85rem; min-height: 1.2em; }
.form-status.ok { color: var(--emerald); }
.form-status.err { color: #b3306b; }

.contact-info { display: flex; flex-direction: column; gap: 1rem; }
.info-card {
  background: var(--porcelain-soft); border: 1px solid rgba(115,17,87,.1);
  border-radius: 16px; padding: 1.4rem 1.5rem; transition: transform .35s, box-shadow .35s;
}
.info-card:hover { transform: translateY(-4px); box-shadow: 0 14px 36px rgba(115,17,87,.1); }
.info-card h4 { font-family: var(--serif); font-size: 1.2rem; color: var(--plum); margin-bottom: .35rem; }
.info-card p, .info-card a { color: #5a4350; font-size: .9rem; line-height: 1.5; }
.info-card a { color: var(--plum); transition: opacity .3s; }
.info-card a:hover { opacity: .7; }
.info-card .socials { display: flex; gap: 1rem; margin-top: .3rem; }

.contact-faq { padding: 1rem 6vw 4rem; max-width: 820px; margin: 0 auto; }
.contact-faq h2 { font-size: clamp(2rem, 4vw, 3rem); color: var(--plum); text-align: center; margin-bottom: 2rem; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1100px) {
  .collection-grid, .reviews-grid, .related-grid { grid-template-columns: repeat(2, 1fr); }
  .pdp { gap: 2.5rem; }
}
@media (max-width: 980px) {
  .pdp { grid-template-columns: 1fr; }
  .pdp-gallery { position: static; }
  .ingredient-story { grid-template-columns: 1fr; }
  .ing-visual { height: 50vh; position: static; }
  .ing-step { min-height: auto; padding: 2rem 0; opacity: 1; }
  .contact-body { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .collection-grid, .reviews-grid, .related-grid { grid-template-columns: 1fr; }
  .collection-hero, .contact-hero { padding-top: 7rem; }
  .pdp-buy { flex-direction: column; }
  .qty-stepper { width: 100%; justify-content: space-between; }
  .sticky-atc { padding: .8rem 5vw; }
  .sticky-atc .sa-variant { display: none; }
  .shop-toolbar { position: static; }
}

/* ============================================================
   ABOUT PAGE
   ============================================================ */

/* 1) HERO */
.about-hero {
  position: relative;
  overflow: hidden;
  padding: clamp(9rem, 16vw, 14rem) 6vw clamp(5rem, 9vw, 8rem);
  background: radial-gradient(120% 120% at 50% -10%, var(--porcelain-soft) 0%, var(--porcelain) 55%, #efe3ea 100%);
  text-align: center;
}
.about-hero-inner { max-width: 900px; margin: 0 auto; position: relative; z-index: 2; }
.about-hero .eyebrow { color: var(--plum); }
.about-hero-title {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(2.6rem, 6.5vw, 5.4rem);
  line-height: 1.04;
  color: var(--ink);
  margin: 1rem auto 1.4rem;
  max-width: 14ch;
}
.about-hero-sub {
  font-size: clamp(1.02rem, 1.6vw, 1.2rem);
  line-height: 1.7;
  color: #5c4350;
  max-width: 60ch;
  margin: 0 auto 2rem;
}
.about-hero-meta {
  display: flex; flex-wrap: wrap; justify-content: center; gap: .9rem;
  font-size: .8rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--plum);
}
.about-orb {
  position: absolute; border-radius: 50%; filter: blur(48px); opacity: .55; z-index: 1;
  pointer-events: none;
}
.about-orb.a1 { width: 360px; height: 360px; background: var(--blush); top: -80px; left: -60px; }
.about-orb.a2 { width: 300px; height: 300px; background: #d9c7e0; bottom: -90px; right: -40px; }

/* 2) MARQUEE wrap */
.about-marquee-wrap {
  background: var(--plum-deep);
  padding: 1.6rem 0;
}
.about-marquee-wrap .amz-marquee .amz-track span { color: var(--blush); }
.about-marquee-wrap .amz-marquee .amz-track span::after { color: rgba(234,172,201,.4); }

/* 3) ORIGIN STORY */
.about-story { padding: clamp(5rem, 10vw, 9rem) 6vw; background: var(--porcelain); }
.about-story-grid {
  max-width: 1200px; margin: 0 auto;
  display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(2.5rem, 6vw, 6rem);
  align-items: center;
}
.about-story-media {
  position: relative; width: 100%; aspect-ratio: 4/5; border-radius: 8px;
}
.about-story-text .eyebrow { color: var(--plum); }
.about-story-text h2 {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(2rem, 4vw, 3.2rem); line-height: 1.1; color: var(--ink);
  margin: .8rem 0 1.4rem;
}
.about-story-text p { font-size: 1.04rem; line-height: 1.8; color: #5c4350; margin-bottom: 1.2rem; }
.about-story-text em { font-style: italic; color: var(--plum); }
.about-story-text .btn { margin-top: 1rem; }

/* 4) PINNED EXPAND BANNER */
.about-banner { padding: clamp(3rem, 6vw, 6rem) 6vw; background: var(--porcelain); display: flex; }
.about-banner .pe-media {
  position: relative; display: flex; align-items: center; justify-content: center;
  min-height: 62vh;
}
.about-banner-bg {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, var(--plum) 0%, var(--plum-deep) 60%, #2A0A20 100%);
}
.about-banner-overlay {
  position: absolute; inset: 0;
  background: radial-gradient(80% 80% at 30% 20%, rgba(234,172,201,.18), transparent 70%);
}
.about-banner-content { position: relative; z-index: 2; max-width: 820px; padding: 3rem; text-align: center; }
.about-banner-content p {
  font-family: var(--serif); font-style: italic; font-weight: 400;
  font-size: clamp(1.5rem, 3.4vw, 2.6rem); line-height: 1.4; color: var(--porcelain);
}

/* 5) VALUES */
.about-values { padding: clamp(5rem, 10vw, 9rem) 6vw; background: var(--porcelain-soft); }
.about-values .section-header { text-align: center; max-width: 640px; margin: 0 auto clamp(2.5rem, 5vw, 4rem); }
.about-values .section-header .eyebrow { color: var(--plum); }
.about-values .section-header h2 { font-family: var(--serif); font-weight: 400; font-size: clamp(2rem, 4.4vw, 3.4rem); color: var(--ink); margin: .6rem 0 .8rem; }
.about-values .section-header .section-sub { color: #7a6270; }
.about-values-grid {
  max-width: 1200px; margin: 0 auto;
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 1.4rem;
}
.value-card {
  background: var(--porcelain); border: 1px solid #ead9e4; border-radius: 8px;
  padding: 2rem 1.5rem; min-height: 240px;
  display: flex; flex-direction: column;
  transition: box-shadow .4s, transform .4s;
}
.value-card:hover { box-shadow: 0 24px 50px -28px rgba(78,10,58,.5); }
.value-num { font-family: var(--serif); font-style: italic; font-size: 1.6rem; color: var(--blush); margin-bottom: 1rem; }
.value-card h3 { font-family: var(--serif); font-weight: 400; font-size: 1.4rem; color: var(--plum); margin-bottom: .7rem; }
.value-card p { font-size: .92rem; line-height: 1.65; color: #6a5260; }

/* 6) PHILOSOPHY */
.about-philosophy { padding: clamp(5rem, 10vw, 9rem) 6vw; background: var(--plum-deep); }
.about-philo-grid {
  max-width: 1200px; margin: 0 auto;
  display: grid; grid-template-columns: 1.1fr 0.9fr; gap: clamp(2.5rem, 6vw, 6rem);
  align-items: center;
}
.about-philo-text .eyebrow { color: var(--blush); }
.about-philo-text h2 { font-family: var(--serif); font-weight: 400; font-size: clamp(2rem, 4vw, 3.2rem); color: var(--porcelain); margin: .8rem 0 1.4rem; line-height: 1.1; }
.about-philo-text > p { font-size: 1.04rem; line-height: 1.8; color: #e9d4e2; margin-bottom: 1.8rem; }
.philo-list { list-style: none; display: grid; gap: 1rem; }
.philo-list li {
  display: flex; flex-direction: column; gap: .15rem;
  padding-bottom: 1rem; border-bottom: 1px solid rgba(234,172,201,.22);
}
.philo-list strong { font-family: var(--serif); font-style: italic; font-size: 1.2rem; color: var(--blush); }
.philo-list span { font-size: .92rem; color: #d8bccf; }
.about-philo-media { position: relative; width: 100%; aspect-ratio: 4/5; border-radius: 8px; }

/* 7) FOUNDER */
.about-founder { padding: clamp(5rem, 10vw, 9rem) 6vw; background: var(--porcelain); }
.about-founder-inner {
  max-width: 1100px; margin: 0 auto;
  display: grid; grid-template-columns: 0.8fr 1.2fr; gap: clamp(2.5rem, 6vw, 5rem);
  align-items: center;
}
.about-founder-media { position: relative; width: 100%; aspect-ratio: 4/5; border-radius: 8px; }
.about-founder-text { position: relative; }
.founder-quote-mark {
  font-family: var(--serif); font-size: 6rem; line-height: .6; color: var(--blush);
  display: block; margin-bottom: .5rem;
}
.founder-note {
  font-size: clamp(1.4rem, 2.6vw, 2.1rem); line-height: 1.45; color: var(--ink);
  font-weight: 400; margin-bottom: 1.8rem;
}
.founder-sign strong { display: block; font-size: 1rem; color: var(--plum); letter-spacing: .04em; }
.founder-sign span { font-size: .85rem; color: #8a7280; }

/* 8) STATS */
.about-stats { background: var(--porcelain-soft); padding: clamp(3.5rem, 7vw, 6rem) 6vw; }
.about-stats-grid {
  max-width: 1100px; margin: 0 auto;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 2rem; text-align: center;
}
.stat-item strong { display: block; font-family: var(--serif); font-size: clamp(2.4rem, 5vw, 3.6rem); color: var(--plum); line-height: 1; }
.stat-item span { display: block; margin-top: .6rem; font-size: .82rem; letter-spacing: .12em; text-transform: uppercase; color: #7a6270; }

/* 9) CTA */
.about-cta {
  padding: clamp(5rem, 11vw, 10rem) 6vw; text-align: center;
  background: radial-gradient(120% 120% at 50% 0%, #efe3ea 0%, var(--porcelain) 60%);
}
.about-cta-inner { max-width: 720px; margin: 0 auto; }
.about-cta-inner h2 { font-family: var(--serif); font-weight: 400; font-size: clamp(2.4rem, 5.5vw, 4.4rem); color: var(--ink); margin-bottom: 1rem; line-height: 1.05; }
.about-cta-inner > p { font-size: 1.1rem; color: #5c4350; margin-bottom: 2rem; }
.about-cta-btns { display: flex; flex-wrap: wrap; gap: 1rem; justify-content: center; }

/* ABOUT RESPONSIVE */
@media (max-width: 1024px) {
  .about-values-grid { grid-template-columns: repeat(3, 1fr); }
  .about-stats-grid { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 860px) {
  .about-story-grid,
  .about-philo-grid,
  .about-founder-inner { grid-template-columns: 1fr; gap: 2.5rem; }
  .about-philo-media,
  .about-founder-media { order: -1; max-width: 480px; margin: 0 auto; }
  .about-values-grid { grid-template-columns: repeat(2, 1fr); }
  .about-stats-grid { grid-template-columns: repeat(2, 1fr); gap: 2.5rem 2rem; }
}
@media (max-width: 480px) {
  .about-values-grid { grid-template-columns: 1fr; }
  .about-hero-meta { font-size: .72rem; }
}

/* ============================================================
   WRITE-A-REVIEW FORM (product page)
   ============================================================ */
.reviews-summary {
  margin: -1.4rem auto 2.6rem; color: #5a4350; font-size: .98rem; letter-spacing: .01em;
}
.reviews-summary .rs-stars { color: var(--olive); letter-spacing: .12em; margin-right: .35rem; }
.reviews-summary strong { color: var(--plum); }

/* new review card pop-in */
.review-card.rv-new { opacity: 0; transform: translateY(16px) scale(.98); transition: opacity .5s ease, transform .5s cubic-bezier(.22,.61,.36,1); }
.review-card.rv-new.in { opacity: 1; transform: none; }

.review-form-wrap {
  max-width: 640px; margin: 3.4rem auto 0; text-align: center;
  background: var(--porcelain-soft);
  border: 1px solid rgba(115,17,87,.12);
  border-radius: 20px; padding: 2.6rem 2.4rem;
}
.review-form-wrap h3 {
  font-size: clamp(1.5rem, 3vw, 2rem); color: var(--plum); margin-bottom: .4rem; line-height: 1.1;
}
.review-form-wrap .rf-sub { color: #6a5360; font-size: .92rem; margin-bottom: 1.8rem; }

.review-form { text-align: left; }
.review-form .rf-field { margin-bottom: 1.1rem; }
.review-form .rf-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.review-form label {
  display: block; font-size: .72rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--plum); margin-bottom: .5rem; font-weight: 600;
}
.review-form label .opt { color: #9a8390; font-weight: 400; text-transform: none; letter-spacing: .02em; }
.review-form input,
.review-form textarea {
  width: 100%; font-family: var(--sans); font-size: .95rem; color: var(--ink);
  background: #fff; border: 1px solid rgba(115,17,87,.18);
  border-radius: var(--radius-md); padding: .8rem .95rem; transition: border-color .25s, box-shadow .25s;
}
.review-form textarea { min-height: 120px; resize: vertical; line-height: 1.6; }
.review-form input:focus,
.review-form textarea:focus {
  outline: none; border-color: var(--plum); box-shadow: 0 0 0 3px rgba(115,17,87,.12);
}
.review-form input::placeholder,
.review-form textarea::placeholder { color: #b3a3ac; }

/* star rating input */
.star-input { display: inline-flex; gap: .25rem; }
.star-input .star {
  background: none; border: none; cursor: pointer; padding: 0 .08rem;
  font-size: 2rem; line-height: 1; color: #d9cbd3; transition: color .15s ease, transform .15s ease;
}
.star-input .star:hover { transform: scale(1.12); }
.star-input .star.on { color: var(--olive); }
.star-input .star.sel { color: #c79a2f; }
.star-input .star:focus-visible { outline: 2px solid var(--plum); outline-offset: 2px; border-radius: 4px; }

.review-form .btn { margin-top: .4rem; }
.rf-status { margin-top: 1rem; font-size: .88rem; min-height: 1.2em; }
.rf-status.ok { color: var(--emerald); font-weight: 600; }
.rf-status.err { color: #b3325a; }

@media (max-width: 600px) {
  .review-form .rf-row { grid-template-columns: 1fr; }
  .review-form-wrap { padding: 2rem 1.4rem; }
}

/* ============================================================
   HOME SHOWCASE — reveal-img glue + trust strip
   ============================================================ */
.showcase-main-img[data-reveal-img] { aspect-ratio: 1/1; }
.showcase-main-img .showcase-badge { z-index: 4; }
.showcase-main-img .ri-inner img { width: 100%; height: 100%; object-fit: cover; display: block; transition: opacity .4s ease; }

.showcase-trust {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem;
  margin-top: 1.8rem; padding-top: 1.6rem; border-top: 1px solid rgba(115,17,87,.14);
}
.showcase-trust .st-item strong {
  display: block; font-family: var(--serif); font-size: 1.9rem; line-height: 1; color: var(--plum); margin-bottom: .35rem;
}
.showcase-trust .st-item span { display: block; font-size: .74rem; color: #6a5360; line-height: 1.45; }
@media (max-width: 600px) {
  .showcase-trust { grid-template-columns: 1fr; gap: .9rem; text-align: left; }
  .showcase-trust .st-item { display: flex; align-items: baseline; gap: .6rem; }
  .showcase-trust .st-item strong { margin-bottom: 0; font-size: 1.4rem; flex: 0 0 auto; }
}

/* ============================================================
   HOME PAGE — Maya-style cinematic additions
   (uses the shared [data-pin-expand] + [data-parallax] engine)
   ============================================================ */

/* Cinematic pinned-expand quote banner (mirrors About banner) */
.home-banner { padding: clamp(3rem, 6vw, 6rem) 6vw; background: var(--porcelain); display: flex; }
.home-banner .pe-media {
  position: relative; display: flex; align-items: center; justify-content: center;
  min-height: 62vh; overflow: hidden;
}
.home-banner-bg {
  position: absolute; inset: 0;
  background: url('amz_ritual.png') center/cover no-repeat, linear-gradient(135deg, var(--plum) 0%, var(--plum-deep) 60%, #2A0A20 100%);
  transform: scale(1.06);
}
.home-banner-overlay {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(42,10,32,.30) 0%, rgba(78,10,58,.55) 60%, rgba(42,10,32,.72) 100%),
    radial-gradient(80% 80% at 30% 20%, rgba(234,172,201,.22), transparent 70%);
}
.home-banner-content { position: relative; z-index: 2; max-width: 880px; padding: 3rem; text-align: center; }
.home-banner-content .eyebrow.light { color: var(--blush); margin-bottom: 1.2rem; }
.home-banner-quote {
  font-family: var(--serif); font-style: italic; font-weight: 400;
  font-size: clamp(1.5rem, 3.4vw, 2.7rem); line-height: 1.4; color: var(--porcelain);
  text-wrap: balance;
}

/* Parallax floating orbs in the heritage section (mirrors About orbs) */
.heritage { position: relative; overflow: hidden; }
.home-orb {
  position: absolute; border-radius: 50%; filter: blur(54px); opacity: .42; z-index: 0;
  pointer-events: none; will-change: transform;
}
.home-orb.h1 { width: 340px; height: 340px; background: var(--blush); top: -70px; right: -50px; }
.home-orb.h2 { width: 280px; height: 280px; background: #d9c7e0; bottom: -80px; left: -40px; }
.heritage-grid { position: relative; z-index: 1; }

@media(max-width:980px){
  .home-banner { padding: 2.5rem 1.2rem; }
  .home-banner .pe-media { min-height: 56vh; }
  .home-banner-content { padding: 1.6rem; }
  .home-orb.h1 { width: 200px; height: 200px; right: -60px; }
  .home-orb.h2 { width: 180px; height: 180px; left: -60px; }
}

/* ============================================================
   BOTANICALS PAGE
   ============================================================ */
.bot-hero{ position:relative; overflow:hidden; padding:clamp(3rem,7vw,6rem) 6vw clamp(2rem,5vw,4rem); display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,5vw,5rem); align-items:center; background:linear-gradient(180deg,var(--porcelain-soft),var(--porcelain)); }
.bot-orb{ position:absolute; border-radius:50%; filter:blur(60px); opacity:.4; z-index:0; pointer-events:none; will-change:transform; }
.bot-orb.b1{ width:360px; height:360px; background:var(--blush); top:-90px; left:-70px; }
.bot-orb.b2{ width:300px; height:300px; background:#d9c7e0; bottom:-110px; right:-60px; }
.bot-hero-inner{ position:relative; z-index:1; }
.bot-hero-title{ font-family:var(--serif); font-weight:400; font-size:clamp(2.6rem,6vw,4.6rem); line-height:1.02; color:var(--plum-deep); margin:.4rem 0 1.2rem; }
.bot-hero-lead{ font-size:clamp(1rem,1.4vw,1.18rem); color:var(--ink); max-width:46ch; opacity:.85; }
.bot-hero-meta{ display:flex; gap:2.4rem; margin-top:2.2rem; flex-wrap:wrap; }
.bhm-item{ display:flex; flex-direction:column; }
.bhm-item strong{ font-family:var(--serif); font-size:2.2rem; color:var(--plum); line-height:1; }
.bhm-item span{ font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink); opacity:.6; margin-top:.4rem; }
.bot-hero-media{ position:relative; z-index:1; border-radius:var(--radius-md); overflow:hidden; aspect-ratio:4/5; box-shadow:0 30px 70px -30px rgba(78,10,58,.45); }
.bot-hero-media .ri-inner img{ width:100%; height:100%; object-fit:cover; }

.bot-philosophy{ background:var(--plum-deep); color:var(--porcelain); padding:1.4rem 0; }
.bot-philosophy .amz-marquee span{ font-family:var(--serif); font-style:italic; font-size:clamp(1.4rem,3vw,2.2rem); color:var(--porcelain); padding:0 1.4rem; display:inline-flex; align-items:center; gap:1.4rem; }
.bot-philosophy .amz-marquee em{ color:var(--blush); font-style:normal; }

.bot-story{ padding:clamp(3rem,7vw,6.5rem) 6vw; display:flex; flex-direction:column; gap:clamp(3rem,7vw,6.5rem); }
.bot-row{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,5rem); align-items:center; }
.bot-row.reverse .bot-row-media{ order:2; }
.bot-row-media{ border-radius:var(--radius-md); overflow:hidden; aspect-ratio:4/3; box-shadow:0 24px 60px -30px rgba(78,10,58,.4); }
.bot-row-media .ri-inner img{ width:100%; height:100%; object-fit:cover; }
.bot-row-text h2{ font-family:var(--serif); font-weight:400; font-size:clamp(1.8rem,3.4vw,2.8rem); line-height:1.1; color:var(--plum-deep); margin:.4rem 0 1rem; }
.bot-row-text p{ color:var(--ink); opacity:.85; max-width:48ch; }
.bot-bullets{ list-style:none; margin:1.4rem 0 0; padding:0; display:flex; flex-direction:column; gap:.6rem; }
.bot-bullets li{ position:relative; padding-left:1.5rem; color:var(--ink); opacity:.82; font-size:.96rem; }
.bot-bullets li::before{ content:"✦"; position:absolute; left:0; color:var(--olive); font-size:.8rem; top:.15rem; }

.bot-catalogue{ padding:clamp(3rem,7vw,6rem) 6vw; background:var(--porcelain-soft); }
.bot-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem; margin-top:2.6rem; }
.bot-card{ background:#fff; border-radius:var(--radius-md); padding:1.4rem; border:1px solid rgba(115,17,87,.08); transition:transform .4s cubic-bezier(.2,.8,.2,1), box-shadow .4s; }
.bot-card:hover{ transform:translateY(-6px); box-shadow:0 24px 50px -28px rgba(78,10,58,.4); }
.bot-card-swatch{ height:120px; border-radius:var(--radius-sm); background:linear-gradient(135deg,var(--bc1),var(--bc2)); margin-bottom:1.1rem; }
.bot-card h3{ font-family:var(--serif); font-weight:400; font-size:1.5rem; color:var(--plum-deep); }
.bot-card p{ font-size:.9rem; color:var(--ink); opacity:.78; margin:.4rem 0 .9rem; line-height:1.5; }
.bot-card-tag{ display:inline-block; font-size:.68rem; letter-spacing:.1em; text-transform:uppercase; color:var(--plum); background:rgba(234,172,201,.22); padding:.34rem .7rem; border-radius:100px; }

.bot-promise{ padding:clamp(3rem,7vw,6rem) 6vw; background:var(--plum); color:var(--porcelain); }
.bot-promise .section-header h2{ color:var(--porcelain); }
.bot-steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; margin-top:2.4rem; }
.bot-step{ border-top:1px solid rgba(241,237,236,.25); padding-top:1.4rem; }
.bot-step-no{ font-family:var(--serif); font-size:2.4rem; color:var(--blush); display:block; line-height:1; }
.bot-step h3{ font-family:var(--serif); font-weight:400; font-size:1.4rem; margin:.6rem 0 .5rem; }
.bot-step p{ opacity:.82; font-size:.95rem; line-height:1.6; }

.bot-cta{ padding:clamp(2.5rem,5vw,5rem) 6vw; background:var(--porcelain); display:flex; }
.bot-cta .pe-media{ position:relative; min-height:56vh; width:100%; display:flex; align-items:center; justify-content:center; overflow:hidden; border-radius:var(--radius-md); }
.bot-cta-bg{ position:absolute; inset:0; background:url('bot_hero.png') center/cover no-repeat,linear-gradient(135deg,var(--plum),var(--plum-deep)); transform:scale(1.06); }
.bot-cta-overlay{ position:absolute; inset:0; background:linear-gradient(180deg,rgba(42,10,32,.45),rgba(78,10,58,.7)); }
.bot-cta-content{ position:relative; z-index:2; text-align:center; max-width:640px; padding:2.4rem; }
.bot-cta-content .eyebrow.light{ color:var(--blush); }
.bot-cta-title{ font-family:var(--serif); font-style:italic; font-size:clamp(1.8rem,4vw,3.2rem); color:var(--porcelain); margin:.8rem 0; }
.bot-cta-sub{ color:rgba(241,237,236,.9); margin-bottom:1.6rem; }
.bot-cta-actions{ display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* ============================================================
   GIFT PAGE
   ============================================================ */
.gift-hero{ position:relative; overflow:hidden; padding:clamp(3rem,7vw,6rem) 6vw; display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,5rem); align-items:center; background:linear-gradient(180deg,#fff,var(--porcelain)); }
.gift-orb{ position:absolute; border-radius:50%; filter:blur(64px); opacity:.42; z-index:0; pointer-events:none; will-change:transform; }
.gift-orb.g1{ width:360px; height:360px; background:var(--blush); top:-100px; right:-60px; }
.gift-orb.g2{ width:300px; height:300px; background:#e8cbe0; bottom:-120px; left:-70px; }
.gift-hero-text{ position:relative; z-index:1; }
.gift-hero-title{ font-family:var(--serif); font-weight:400; font-size:clamp(2.8rem,6.5vw,5rem); line-height:1; color:var(--plum-deep); margin:.4rem 0 1.2rem; }
.gift-hero-lead{ font-size:clamp(1rem,1.4vw,1.18rem); color:var(--ink); opacity:.85; max-width:46ch; }
.gift-hero-actions{ display:flex; gap:1rem; margin-top:2rem; flex-wrap:wrap; }
.gift-hero-media{ position:relative; z-index:1; border-radius:var(--radius-md); overflow:hidden; aspect-ratio:4/5; box-shadow:0 30px 70px -30px rgba(78,10,58,.45); }
.gift-hero-media .ri-inner img{ width:100%; height:100%; object-fit:cover; }

.gift-trust{ background:var(--plum-deep); color:var(--porcelain); padding:clamp(2rem,4vw,3.2rem) 6vw; }
.gift-trust-inner{ display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; max-width:1100px; margin:0 auto; }
.gt-item{ text-align:center; }
.gt-ico{ color:var(--blush); font-size:1.2rem; }
.gt-item h4{ font-family:var(--serif); font-weight:400; font-size:1.35rem; margin:.5rem 0 .4rem; }
.gt-item p{ opacity:.82; font-size:.92rem; line-height:1.55; max-width:30ch; margin:0 auto; }

.gift-sets{ padding:clamp(3rem,7vw,6rem) 6vw; }
.gift-set-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; margin-top:2.6rem; }
.gift-set-card{ background:#fff; border-radius:var(--radius-md); overflow:hidden; border:1px solid rgba(115,17,87,.08); display:flex; flex-direction:column; }
.gsc-media{ position:relative; aspect-ratio:4/3; overflow:hidden; background:linear-gradient(135deg,var(--plum),var(--plum-deep)); }
.gsc-media img{ width:100%; height:100%; object-fit:cover; transition:transform .6s cubic-bezier(.2,.8,.2,1); }
.gift-set-card:hover .gsc-media img{ transform:scale(1.05); }
.gsc-mist{ background:linear-gradient(135deg,var(--blush),var(--plum)); }
.gsc-cleanse{ background:linear-gradient(135deg,var(--olive),var(--emerald)); }
.gsc-badge{ position:absolute; top:1rem; left:1rem; background:var(--plum); color:var(--porcelain); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; padding:.4rem .8rem; border-radius:100px; z-index:2; }
.gsc-body{ padding:1.6rem; display:flex; flex-direction:column; flex:1; }
.gsc-body h3{ font-family:var(--serif); font-weight:400; font-size:1.7rem; color:var(--plum-deep); }
.gsc-body p{ font-size:.92rem; color:var(--ink); opacity:.8; margin:.5rem 0 1rem; line-height:1.55; flex:1; }
.gsc-price{ display:flex; align-items:baseline; gap:.7rem; margin-bottom:1.1rem; }
.gsc-price .now{ font-family:var(--serif); font-size:1.7rem; color:var(--plum); }
.gsc-price .was{ font-size:1rem; color:var(--ink); opacity:.45; text-decoration:line-through; }

/* Gift card builder */
.gift-card-sec{ padding:clamp(3rem,7vw,6rem) 6vw; background:var(--porcelain-soft); }
.gc-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(2rem,5vw,5rem); align-items:center; }
.gc-preview{ border-radius:var(--radius-md); overflow:hidden; }
.gc-card{ aspect-ratio:1.6/1; background:linear-gradient(135deg,var(--plum) 0%,var(--plum-deep) 55%,#2A0A20 100%); border-radius:var(--radius-md); padding:1.8rem; color:var(--porcelain); display:flex; flex-direction:column; justify-content:space-between; box-shadow:0 30px 70px -30px rgba(78,10,58,.6); position:relative; overflow:hidden; }
.gc-card::after{ content:""; position:absolute; width:260px; height:260px; border-radius:50%; background:radial-gradient(circle,rgba(234,172,201,.3),transparent 70%); top:-80px; right:-60px; }
.gc-card-top{ display:flex; align-items:center; gap:.6rem; z-index:1; }
.gc-mark{ width:30px; height:30px; }
.gc-brand{ font-family:var(--serif); font-size:1.2rem; letter-spacing:.18em; }
.gc-card-mid{ z-index:1; }
.gc-label{ font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--blush); }
.gc-amount{ font-family:var(--serif); font-size:clamp(2.4rem,5vw,3.4rem); line-height:1; margin-top:.2rem; }
.gc-card-bottom{ z-index:1; }
.gc-to{ font-family:var(--serif); font-style:italic; font-size:1.05rem; color:rgba(241,237,236,.92); }
.gc-form-wrap h2{ font-family:var(--serif); font-weight:400; font-size:clamp(1.8rem,3.4vw,2.8rem); color:var(--plum-deep); margin:.4rem 0 .8rem; }
.gc-intro{ color:var(--ink); opacity:.85; max-width:46ch; margin-bottom:1.6rem; }
.gc-form{ display:flex; flex-direction:column; gap:1.1rem; max-width:460px; }
.gc-field{ display:flex; flex-direction:column; gap:.45rem; }
.gc-field label{ font-size:.8rem; letter-spacing:.06em; text-transform:uppercase; color:var(--ink); opacity:.7; }
.gc-opt{ text-transform:none; letter-spacing:0; opacity:.6; }
.gc-amounts{ display:flex; gap:.6rem; flex-wrap:wrap; }
.gc-amt{ flex:1; min-width:70px; padding:.7rem .4rem; border:1px solid rgba(115,17,87,.25); background:#fff; border-radius:var(--radius-sm); font-family:var(--serif); font-size:1.05rem; color:var(--plum); cursor:pointer; transition:all .25s; }
.gc-amt:hover{ border-color:var(--plum); }
.gc-amt.is-active{ background:var(--plum); color:var(--porcelain); border-color:var(--plum); }
.gc-field input,.gc-field textarea{ font-family:var(--sans); font-size:.98rem; padding:.85rem 1rem; border:1px solid rgba(115,17,87,.2); border-radius:var(--radius-sm); background:#fff; color:var(--ink); resize:vertical; }
.gc-field input:focus,.gc-field textarea:focus{ outline:none; border-color:var(--plum); box-shadow:0 0 0 3px rgba(234,172,201,.3); }
.gc-status{ font-size:.9rem; min-height:1.2em; }
.gc-status.ok{ color:var(--emerald); }
.gc-status.err{ color:#b3325a; }

.gift-how{ padding:clamp(3rem,7vw,6rem) 6vw; background:var(--plum); color:var(--porcelain); }
.gift-how .section-header h2{ color:var(--porcelain); }
.gift-steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; margin-top:2.4rem; }
.gift-step{ border-top:1px solid rgba(241,237,236,.25); padding-top:1.4rem; }
.gift-step-no{ font-family:var(--serif); font-size:2.4rem; color:var(--blush); display:block; line-height:1; }
.gift-step h3{ font-family:var(--serif); font-weight:400; font-size:1.4rem; margin:.6rem 0 .5rem; }
.gift-step p{ opacity:.82; font-size:.95rem; line-height:1.6; }

.gift-cta{ padding:clamp(2.5rem,5vw,5rem) 6vw; background:var(--porcelain); display:flex; }
.gift-cta .pe-media{ position:relative; min-height:54vh; width:100%; display:flex; align-items:center; justify-content:center; overflow:hidden; border-radius:var(--radius-md); }
.gift-cta-bg{ position:absolute; inset:0; background:url('gift_hero.png') center/cover no-repeat,linear-gradient(135deg,var(--plum),var(--plum-deep)); transform:scale(1.06); }
.gift-cta-overlay{ position:absolute; inset:0; background:linear-gradient(180deg,rgba(42,10,32,.4),rgba(78,10,58,.72)); }
.gift-cta-content{ position:relative; z-index:2; text-align:center; max-width:680px; padding:2.4rem; }
.gift-cta-content .eyebrow.light{ color:var(--blush); }
.gift-cta-quote{ font-family:var(--serif); font-style:italic; font-size:clamp(1.6rem,3.6vw,2.8rem); line-height:1.35; color:var(--porcelain); margin:.8rem 0 1.6rem; text-wrap:balance; }
.gift-cta-actions{ display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* ============================================================
   BOTANICALS + GIFT — RESPONSIVE
   ============================================================ */
@media(max-width:980px){
  .bot-hero{ grid-template-columns:1fr; padding:2.4rem 1.2rem 2rem; gap:2rem; }
  .bot-hero-media{ aspect-ratio:4/3; order:-1; }
  .bot-hero-meta{ gap:1.6rem; }
  .bot-orb.b1,.bot-orb.b2{ width:200px; height:200px; }
  .bot-story{ padding:2.6rem 1.2rem; gap:2.6rem; }
  .bot-row,.bot-row.reverse{ grid-template-columns:1fr; gap:1.4rem; }
  .bot-row.reverse .bot-row-media{ order:0; }
  .bot-catalogue,.bot-promise{ padding:2.6rem 1.2rem; }
  .bot-grid{ grid-template-columns:repeat(2,1fr); gap:1rem; }
  .bot-steps{ grid-template-columns:1fr; gap:1.4rem; }
  .bot-cta,.gift-cta{ padding:2rem 1rem; }
  .bot-cta .pe-media,.gift-cta .pe-media{ min-height:52vh; }

  .gift-hero{ grid-template-columns:1fr; padding:2.4rem 1.2rem; gap:2rem; }
  .gift-hero-media{ aspect-ratio:4/3; order:-1; }
  .gift-orb.g1,.gift-orb.g2{ width:200px; height:200px; }
  .gift-trust-inner{ grid-template-columns:1fr; gap:1.6rem; }
  .gift-sets,.gift-card-sec,.gift-how{ padding:2.6rem 1.2rem; }
  .gift-set-grid{ grid-template-columns:1fr; gap:1.4rem; }
  .gc-grid{ grid-template-columns:1fr; gap:2rem; }
  .gc-preview{ max-width:420px; }
  .gift-steps{ grid-template-columns:1fr; gap:1.4rem; }
}
@media(max-width:480px){
  .bot-grid{ grid-template-columns:1fr; }
}
