/* =============================================
   PETDOGCENTRAL D2C HOMEPAGE — BELOW-FOLD STYLES
   Note: Critical above-fold CSS (reset, fonts, typography, hero,
   marquee, as-seen-in, coupon, layout, buttons) is inlined in
   index.html <style> block. This file contains only below-fold
   component styles loaded deferred via media="print" onload trick.
   ============================================= */

/* =============================================
   SHARED SECTION STYLES
   ============================================= */
.gs-section-label {
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #E8654A;
  margin-bottom: 16px;
}
.gs-section-heading {
  font-size: 40px;
  margin-bottom: 24px;
  letter-spacing: -0.3px;
}
.gs-body-text {
  font-size: 18px;
  color: #4A5568;
  line-height: 1.75;
  max-width: 600px;
}
.gs-body-text p { margin-bottom: 18px; }

/* =============================================
   PRODUCT REVEAL
   ============================================= */
.gs-reveal { background: #FDF8F0; }
.gs-reveal-intro {
  max-width: 720px;
  margin: 0 auto 56px;
  text-align: center;
}
.gs-reveal-intro .gs-body-text {
  margin: 0 auto;
  text-align: center;
}
.gs-steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  margin-bottom: 56px;
}
.gs-step-card {
  background: #FFFFFF;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 2px 12px rgba(27,42,74,0.06);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.gs-step-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 30px rgba(27,42,74,0.12);
}
.gs-step-media {
  position: relative;
  width: 100%;
  aspect-ratio: 3/4;
  overflow: hidden;
  background: #F0EDE8;
  border-radius: 12px 12px 0 0;
}
.gs-step-media img,
.gs-step-media video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.gs-step-number {
  position: absolute;
  top: 16px;
  left: 16px;
  width: 36px;
  height: 36px;
  background: #E8654A;
  color: #FFFFFF;
  font-weight: 700;
  font-size: 16px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.gs-step-body {
  padding: 24px;
}
.gs-step-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 22px;
  font-weight: 700;
  margin-bottom: 8px;
  color: #1B2A4A;
}
.gs-step-desc {
  font-size: 18px;
  color: #4A5568;
  line-height: 1.6;
}
.gs-before-after {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  max-width: 720px;
  margin: 0 auto 16px;
}
.gs-ba-card {
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(27,42,74,0.1);
}
.gs-ba-card img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
}
.gs-ba-label {
  position: absolute;
  bottom: 12px;
  left: 12px;
  background: rgba(27,42,74,0.8);
  color: #FFFFFF;
  font-size: 13px;
  font-weight: 700;
  padding: 6px 14px;
  border-radius: 8px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}
.gs-ba-caption {
  text-align: center;
  font-size: 16px;
  color: #6B7A8D;
  margin-bottom: 40px;
}
.gs-reveal-cta {
  text-align: center;
  margin-top: 48px;
}

/* =============================================
   TIMELINE
   ============================================= */
.gs-timeline-img {
  max-width: 800px;
  margin: 0 auto;
}
.gs-timeline-img img {
  width: 100%;
  border-radius: 16px;
  box-shadow: 0 12px 40px rgba(27,42,74,0.1);
}

/* =============================================
   INGREDIENTS
   ============================================= */
.gs-ingredients { background: #FFFFFF; }
.gs-ingredients-intro {
  text-align: center;
  max-width: 600px;
  margin: 0 auto 48px;
}
.gs-ingredient-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-auto-rows: 1fr;
  gap: 24px;
}
.gs-ingredient-card {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 0;
  background: #FDF8F0;
  border-radius: 16px;
  overflow: hidden;
  transition: box-shadow 0.25s ease;
}
.gs-ingredient-card:hover {
  box-shadow: 0 4px 20px rgba(27,42,74,0.08);
}
.gs-ingredient-img {
  width: 100%;
  height: 100%;
  min-height: 240px;
  overflow: hidden;
  background: #FFFFFF;
}
.gs-ingredient-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.gs-ingredient-text {
  padding: 28px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.gs-ingredient-text h3 {
  font-size: 22px;
  margin-bottom: 10px;
}
.gs-ingredient-text p {
  font-size: 18px;
  color: #4A5568;
  line-height: 1.65;
}
.gs-ingredient-payoff {
  display: inline-block;
  margin-top: 10px;
  font-size: 16px;
  font-weight: 700;
  color: #5B9A7D;
  background: rgba(91,154,125,0.1);
  padding: 4px 12px;
  border-radius: 6px;
}

/* =============================================
   COMPARISON TABLE
   ============================================= */
.gs-comparison { background: #FDF8F0; }
.gs-comparison-intro {
  text-align: center;
  max-width: 600px;
  margin: 0 auto 48px;
}
.gs-comparison-sub {
  font-size: 17px;
  color: #6B7A8D;
  margin-top: 8px;
}
.gs-table-wrap {
  overflow-x: auto;
  border-radius: 16px;
  box-shadow: 0 2px 12px rgba(27,42,74,0.06);
}
.gs-table {
  width: 100%;
  border-collapse: collapse;
  background: #FFFFFF;
  border-radius: 16px;
  overflow: hidden;
  min-width: 600px;
}
.gs-table thead th {
  background: #1B2A4A;
  color: #FFFFFF;
  font-size: 16px;
  font-weight: 700;
  padding: 16px 20px;
  text-align: center;
  letter-spacing: 0.3px;
}
.gs-table thead th:first-child {
  text-align: left;
}
.gs-table tbody td {
  padding: 16px 20px;
  font-size: 16px;
  text-align: center;
  border-bottom: 1px solid #F0EDE8;
  color: #4A5568;
}
.gs-table tbody td:first-child {
  text-align: left;
  font-weight: 600;
  color: #1B2A4A;
}
.gs-table tbody tr:last-child td { border-bottom: none; }
.gs-table-highlight {
  background: #FFF8F5 !important;
}
.gs-table-highlight td {
  color: #1B2A4A !important;
  font-weight: 600;
}
.gs-check { color: #5B9A7D; font-size: 18px; font-weight: 700; }
.gs-cross { color: #D05438; font-size: 18px; font-weight: 700; }
.gs-partial { color: #D4A843; font-size: 15px; font-weight: 600; }

/* Mobile comparison cards */
.gs-compare-cards { display: none; }
.gs-compare-card {
  background: #FFFFFF;
  border-radius: 16px;
  padding: 24px;
  margin-bottom: 16px;
  box-shadow: 0 2px 12px rgba(27,42,74,0.06);
}
.gs-compare-card-highlight {
  border: 2px solid #E8654A;
}
.gs-compare-card h4 {
  font-size: 20px;
  margin-bottom: 16px;
}
.gs-compare-row {
  display: flex;
  justify-content: space-between;
  padding: 10px 0;
  border-bottom: 1px solid #F0EDE8;
  font-size: 16px;
}
.gs-compare-row:last-child { border-bottom: none; }
.gs-compare-feature { color: #6B7A8D; }
.gs-compare-value { font-weight: 700; color: #1B2A4A; }

/* =============================================
   SOCIAL PROOF / TESTIMONIALS
   ============================================= */
.gs-testimonials { background: #1B2A4A; }
.gs-testimonials-intro {
  text-align: center;
  max-width: 600px;
  margin: 0 auto 40px;
}
.gs-testimonials-intro p {
  color: rgba(255,255,255,0.7);
}
.gs-testimonials-header {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-bottom: 12px;
}
.gs-testimonials-header-stars {
  color: #E8654A;
  font-size: 22px;
  letter-spacing: 2px;
  line-height: 1;
}
.gs-testimonials-header-count {
  font-size: 16px;
  font-weight: 600;
  color: rgba(255,255,255,0.8);
}
/* --- Owner feedback cards --- */
.gs-care-testimonials { padding: 60px 0; text-align: center; }
.gs-care-testimonials .gs-section-heading { margin-bottom: 40px; }
.gs-care-testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.gs-care-slider-wrap { position: relative; }
.gs-care-arr { display: none; }
.gs-compare-slider-wrap { position: relative; }
.gs-compare-arr { display: none; }
.gs-steps-slider-wrap { position: relative; }
.gs-steps-arr { display: none; }
.gs-care-card {
  background: #fff;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0,0,0,0.08);
  border: 2px solid #e8f4f2;
  text-align: left;
}
.gs-care-avatar img {
  width: 100%;
  height: auto;
  display: block;
}
.gs-care-body {
  padding: 20px;
  position: relative;
}
.gs-care-badge {
  position: absolute;
  top: -14px;
  right: 20px;
  background: linear-gradient(135deg, #1a7a6c 0%, #2d9d8f 100%);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  padding: 6px 12px;
  border-radius: 20px;
  letter-spacing: 0.5px;
}
.gs-care-name {
  font-size: 20px;
  font-weight: 700;
  color: #1a3c34;
  margin-bottom: 4px;
}
.gs-care-title {
  font-size: 15px;
  color: #1a7a6c;
  font-weight: 600;
  margin-bottom: 12px;
}
.gs-care-quote {
  font-size: 18px;
  line-height: 1.6;
  color: #4a5568;
  font-style: italic;
  margin: 0;
}

/* --- Why It Works (4-block grid) --- */
.gs-why-works .gs-section-heading { margin-bottom: 8px; }
.gs-why-subtitle {
  text-align: center;
  font-size: 17px;
  color: #6b7a8d;
  font-style: italic;
  margin-bottom: 40px;
}
.gs-why-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}
.gs-why-card {
  background: #FFFFFF;
  border-radius: 16px;
  padding: 32px 24px;
  text-align: center;
  box-shadow: 0 2px 12px rgba(27,42,74,0.06);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.gs-why-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 30px rgba(27,42,74,0.12);
}
.gs-why-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 20px;
  font-weight: 700;
  color: #1B2A4A;
  margin-bottom: 12px;
}
.gs-why-text {
  font-size: 18px;
  line-height: 1.65;
  color: #1B2A4A;
  margin: 0;
}

/* --- Masonry Reviews Grid (Loox-style) --- */
.gs-reviews-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.gs-testimonial-card {
  background: #FFFFFF;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 2px 12px rgba(0,0,0,0.08);
}
.gs-testimonial-avatar {
  aspect-ratio: 1 / 1;
  overflow: hidden;
}
.gs-testimonial-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.gs-testimonial-body {
  padding: 12px 14px 16px;
}
.gs-testimonial-name {
  font-weight: 700;
  font-size: 17px;
  color: #111;
  display: flex;
  align-items: center;
  gap: 5px;
}
.gs-testimonial-date {
  font-size: 15px;
  color: #999;
  margin-top: 2px;
}
.gs-testimonial-stars {
  color: #E8654A;
  font-size: 15px;
  letter-spacing: 2px;
  margin: 6px 0;
}
.gs-testimonial-quote {
  font-size: 17px;
  color: #333;
  line-height: 1.55;
  margin: 0;
}

/* =============================================
   BUNDLES
   ============================================= */
.gs-bundles { background: #FFFFFF; }
.gs-bundles-intro {
  text-align: center;
  max-width: 600px;
  margin: 0 auto 48px;
}
.gs-bundle-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  align-items: start;
}
.gs-bundle-card[data-bundle="1"] { order: 0; }
.gs-bundle-card[data-bundle="3"] { order: 1; }
.gs-bundle-card[data-bundle="2"] { order: 2; }
.gs-bundle-card {
  background: #FFFFFF;
  border: 2px solid #F0EDE8;
  border-radius: 20px;
  overflow: hidden;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  position: relative;
}
.gs-bundle-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(27,42,74,0.1);
}
.gs-bundle-popular {
  border-color: #E8654A;
  box-shadow: 0 4px 24px rgba(232,101,74,0.15);
  transform: scale(1.03);
}
.gs-bundle-popular:hover {
  transform: scale(1.03) translateY(-4px);
  box-shadow: 0 12px 40px rgba(232,101,74,0.2);
}
.gs-bundle-badge {
  position: absolute;
  top: -1px;
  left: 50%;
  transform: translateX(-50%);
  background: #E8654A;
  color: #FFFFFF;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 6px 20px;
  border-radius: 0 0 10px 10px;
  white-space: nowrap;
}
.gs-bundle-badge-value {
  background: #5B9A7D;
}
.gs-bundle-img {
  padding: 0;
  text-align: center;
  overflow: hidden;
  border-radius: 16px 16px 0 0;
}
.gs-bundle-popular .gs-bundle-img {
  padding: 0;
}
.gs-bundle-img img {
  width: 100%;
  height: 220px;
  object-fit: cover;
}
.gs-bundle-body {
  padding: 24px;
  text-align: center;
}
.gs-bundle-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 22px;
  font-weight: 700;
  color: #1B2A4A;
  margin-bottom: 4px;
}
.gs-bundle-subtitle {
  font-size: 16px;
  color: #6B7A8D;
  margin-bottom: 16px;
}
.gs-bundle-price {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 40px;
  font-weight: 800;
  color: #1B2A4A;
  line-height: 1;
  margin-bottom: 4px;
}
.gs-bundle-savings {
  display: inline-block;
  font-size: 16px;
  font-weight: 700;
  color: #5B9A7D;
  background: rgba(91,154,125,0.1);
  padding: 4px 12px;
  border-radius: 6px;
  margin-bottom: 16px;
}
.gs-bundle-cta {
  display: block;
  width: 100%;
  background: #E8654A;
  color: #FFFFFF;
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  font-size: 18px;
  font-weight: 700;
  padding: 14px 24px;
  border-radius: 12px;
  border: none;
  cursor: pointer;
  transition: all 0.25s ease;
  margin-bottom: 16px;
}
.gs-bundle-cta:hover {
  background: #D05438;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(232,101,74,0.3);
}
.gs-bundle-ship-note {
  font-size: 16px;
  color: #5B9A7D;
  text-align: center;
  margin-top: 8px;
  font-weight: 600;
}
.gs-bundle-guarantee {
  text-align: center;
  margin-top: 40px;
  padding: 24px;
  background: #FDF8F0;
  border-radius: 16px;
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
}
.gs-bundle-guarantee p {
  font-size: 17px;
  color: #4A5568;
  line-height: 1.65;
}
.gs-bundle-guarantee strong {
  color: #1B2A4A;
}
.gs-bundle-price-rows {
  width: 100%;
  padding: 0 16px;
  margin: 8px 0;
}
.gs-bundle-price-row {
  display: flex;
  justify-content: space-between;
  font-size: 16px;
  color: #4A5568;
  padding: 4px 0;
  border-bottom: 1px solid rgba(27,42,74,0.06);
}
.gs-bundle-price-row:last-child { border-bottom: none; }
.gs-bundle-price-row s { color: #6B7A8D; }
.gs-bundle-price-row strong { color: #1B2A4A; }
.gs-bundle-details-list {
  list-style: none;
  padding: 0 16px;
  margin: 12px 0;
  text-align: left;
}
.gs-bundle-details-list li {
  font-size: 17px;
  color: #4A5568;
  padding: 4px 0;
  padding-left: 20px;
  position: relative;
}
.gs-bundle-details-list li::before {
  content: '\2713';
  position: absolute;
  left: 0;
  color: #5B9A7D;
  font-weight: 700;
}
.gs-bundle-payment {
  margin: 8px auto;
  display: block;
}
.gs-bundle-guarantee-line {
  font-size: 16px;
  color: #6B7A8D;
  text-align: center;
  margin-top: 8px;
}

/* =============================================
   FAQ
   ============================================= */
.gs-faq { background: #FDF8F0; }
.gs-faq-intro {
  text-align: center;
  margin-bottom: 48px;
}
.gs-faq-list {
  max-width: 760px;
  margin: 0 auto;
}
.gs-faq-item {
  background: #FFFFFF;
  border-radius: 14px;
  margin-bottom: 12px;
  overflow: hidden;
  box-shadow: 0 1px 4px rgba(27,42,74,0.04);
}
.gs-faq-question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  cursor: pointer;
  gap: 16px;
  user-select: none;
  -webkit-user-select: none;
}
.gs-faq-question h4 {
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  font-size: 19px;
  font-weight: 600;
  color: #1B2A4A;
  flex: 1;
}
.gs-faq-icon {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: #FDF8F0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.3s ease;
}
.gs-faq-icon svg {
  width: 14px;
  height: 14px;
  transition: transform 0.3s ease;
}
.gs-faq-item.active .gs-faq-icon svg {
  transform: rotate(180deg);
}
.gs-faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.35s ease;
}
.gs-faq-answer-inner {
  padding: 0 24px 20px;
  font-size: 18px;
  color: #4A5568;
  line-height: 1.7;
}

/* =============================================
   FINAL CTA
   ============================================= */
.gs-final-cta { background: #1B2A4A; }
.gs-final-cta-inner {
  text-align: center;
  max-width: 700px;
  margin: 0 auto;
}
.gs-final-cta-inner h2 {
  color: #FFFFFF;
  font-size: 36px;
  margin-bottom: 20px;
  line-height: 1.2;
}
.gs-final-cta-inner p {
  color: rgba(255,255,255,0.75);
  font-size: 18px;
  line-height: 1.7;
  margin-bottom: 32px;
}
.gs-final-social-proof {
  font-size: 18px;
  color: #94A3B8;
  text-align: center;
  margin-bottom: 8px;
}
.gs-final-social-proof span {
  color: #fff;
  font-weight: 700;
}
.gs-final-ctas {
  display: flex;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 24px;
}
.gs-final-badges {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 32px;
  margin-top: 24px;
  flex-wrap: wrap;
}
.gs-final-badge {
  display: flex;
  align-items: center;
  gap: 8px;
}
.gs-final-badge span {
  font-size: 15px;
  color: rgba(255,255,255,0.7);
  font-weight: 600;
}

/* =============================================
   FOOTER
   ============================================= */
.gs-footer {
  background: #141E33;
  padding: 48px 24px 32px;
}
.gs-footer-inner {
  max-width: 1100px;
  margin: 0 auto;
}
.gs-footer-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 48px;
  margin-bottom: 32px;
  flex-wrap: wrap;
}
.gs-footer-brand {
  max-width: 300px;
}
.gs-footer-logo {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 22px;
  font-weight: 800;
  color: #FFFFFF;
  margin-bottom: 12px;
}
.gs-footer-logo span { color: #E8654A; }
.gs-footer-brand p {
  font-size: 15px;
  color: rgba(255,255,255,0.5);
  line-height: 1.6;
}
.gs-footer-links {
  display: flex;
  gap: 48px;
}
.gs-footer-col h5 {
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  font-size: 15px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: rgba(255,255,255,0.4);
  margin-bottom: 16px;
}
.gs-footer-col a {
  display: block;
  font-size: 15px;
  color: rgba(255,255,255,0.65);
  margin-bottom: 10px;
  transition: color 0.2s;
}
.gs-footer-col a:hover { color: #FFFFFF; }
.gs-footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.08);
  padding-top: 24px;
}
.gs-footer-disclaimer {
  font-size: 12px;
  color: rgba(255,255,255,0.3);
  line-height: 1.65;
  margin-bottom: 16px;
}
.gs-footer-company-details {
  font-size: 11px;
  color: rgba(255,255,255,0.42);
  line-height: 1.5;
  margin: 0 0 14px;
}
.gs-footer-company-note {
  margin: 0 0 6px;
}
.gs-footer-company-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 18px;
  align-items: center;
}
.gs-footer-company-list span {
  display: inline-flex;
  gap: 4px;
  align-items: baseline;
}
.gs-footer-company-details strong {
  color: rgba(255,255,255,0.68);
  font-weight: 700;
}
.gs-footer-company-details a {
  color: rgba(255,255,255,0.68);
}
.gs-footer-copy {
  font-size: 12px;
  color: rgba(255,255,255,0.4);
}

/* =============================================
   STICKY BAR
   ============================================= */
body { padding-bottom: 70px; }
.gs-sticky-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 99;
  background: #FFFFFF;
  box-shadow: 0 -2px 20px rgba(27,42,74,0.1);
  padding: 12px 24px;
  transform: translateY(100%);
  transition: transform 0.35s ease;
}
.gs-sticky-bar.visible {
  transform: translateY(0);
}
.gs-sticky-inner {
  max-width: 1100px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.gs-sticky-text h4 {
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: #1B2A4A;
}
.gs-sticky-text span {
  font-size: 16px;
  color: #6B7A8D;
}
.gs-sticky-btn {
  display: inline-block;
  background: #E8654A;
  color: #FFFFFF;
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  font-size: 16px;
  font-weight: 700;
  padding: 12px 24px;
  border-radius: 10px;
  white-space: nowrap;
  transition: all 0.25s ease;
}
.gs-sticky-btn:hover {
  background: #D05438;
  transform: translateY(-1px);
}

/* =============================================
   RESPONSIVE — TABLET (768px)
   ============================================= */
@media (max-width: 1024px) {
  .gs-hero { padding: 24px 16px 24px; }
  .gs-hero-inner { gap: 20px; }
  .gs-hero-right { gap: 16px; }

  .gs-marquee-item { font-size: 12px; }
  .gs-section-label { font-size: 12px; }
}

@media (max-width: 768px) {
  .gs-section { padding: 56px 20px; }

  /* Hero */
  .gs-hero { padding: 0 20px 32px; }
  .gs-hero-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 24px;
    text-align: center;
  }
  .gs-hero-text {
    display: contents;
  }
  .gs-hero-right {
    display: contents;
  }
  .gs-hero-h1-desktop { display: none; }
  .gs-hero-img { order: 1; width: 100%; margin-left: -20px; margin-right: -20px; width: calc(100% + 40px); }
  .gs-hero-img img { width: 100%; border-radius: 0; }
  .gs-hero-badge-row { order: 2; width: 100%; text-align: center; }
  .gs-hero-h1-mobile { display: block; font-size: 26px; order: 3; }
  .gs-hero-stars-row { order: 4; width: 100%; text-align: center; }
  .gs-hero-sub { display: none; }
  .gs-hero-benefits { display: none; }
  .gs-hero-benefits-mobile {
    display: block;
    order: 7;
    width: 100%;
    list-style: none;
    padding: 0;
    margin: 8px 0 0;
    text-align: left;
  }
  .gs-hero-benefits-mobile li {
    position: relative;
    padding-left: 28px;
    margin-bottom: 12px;
    font-size: 18px;
    line-height: 1.5;
    font-weight: 700;
    color: #4A5568;
  }
  .gs-hero-benefits-mobile li::before {
    content: '\2713';
    position: absolute;
    left: 0;
    color: #2B6B4F;
    font-weight: 700;
    font-size: 20px;
  }
  .gs-hero-offer { order: 5; width: 100%; position: static; padding: 16px; margin-bottom: 0; border: 2px solid #E2D8CC; background: #fff; border-radius: 14px; }
  .gs-hero-ship-row { display: flex; flex-direction: column; align-items: center; gap: 2px; }
  .gs-hero-ship-sep { display: none; }
  .gs-care-endorsement { order: 9; width: 100%; max-width: 100%; }
  .gs-hero-inner { gap: 8px; }

  /* Section headings */
  .gs-section-heading { font-size: 30px; }

  /* Steps — horizontal slider on mobile */
  .gs-steps-slider-wrap {
    position: relative;
  }
  .gs-steps {
    display: flex;
    gap: 16px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding: 8px 0 16px;
    margin-bottom: 40px;
  }
  .gs-steps::-webkit-scrollbar { display: none; }
  .gs-steps .gs-step-card {
    flex: 0 0 85%;
    max-width: 340px;
    scroll-snap-align: center;
  }
  .gs-steps-arr {
    display: flex;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    background: #fff;
    border: 1px solid #E5E7EB;
    border-radius: 50%;
    cursor: pointer;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
    z-index: 10;
  }
  .gs-steps-arr svg { width: 20px; height: 20px; fill: #374151; }
  .gs-steps-arr.prev { left: 8px; }
  .gs-steps-arr.next { right: 8px; }

  /* Before/After */
  .gs-before-after { gap: 12px; }

  /* Ingredients — stack on mobile */
  .gs-ingredient-list {
    grid-template-columns: 1fr;
  }
  .gs-ingredient-card { grid-template-columns: 1fr; }
  .gs-ingredient-img { min-height: 200px; }

  /* Comparison — horizontal slider on mobile */
  .gs-table-wrap { display: none; }
  .gs-compare-slider-wrap {
    position: relative;
  }
  .gs-compare-cards {
    display: flex;
    gap: 16px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding: 8px 0 16px;
  }
  .gs-compare-cards::-webkit-scrollbar { display: none; }
  .gs-compare-cards .gs-compare-card {
    flex: 0 0 85%;
    max-width: 300px;
    scroll-snap-align: center;
    margin-bottom: 0;
  }
  .gs-compare-arr {
    display: flex;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    background: #fff;
    border: 1px solid #E5E7EB;
    border-radius: 50%;
    cursor: pointer;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
    z-index: 10;
  }
  .gs-compare-arr svg { width: 20px; height: 20px; fill: #374151; }
  .gs-compare-arr.prev { left: 8px; }
  .gs-compare-arr.next { right: 8px; }

  /* Owner feedback cards on tablet/mobile */
  .gs-care-testimonials-grid {
    display: flex;
    gap: 16px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding: 8px 0 16px;
    margin: 0 -16px;
    padding-left: 16px;
    padding-right: 16px;
  }
  .gs-care-testimonials-grid::-webkit-scrollbar { display: none; }
  .gs-care-testimonials-grid .gs-care-card {
    flex: 0 0 85%;
    max-width: 340px;
    scroll-snap-align: center;
  }
  .gs-care-slider-wrap {
    position: relative;
  }
  .gs-care-arr {
    display: flex;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    background: #fff;
    border: 1px solid #E5E7EB;
    border-radius: 50%;
    cursor: pointer;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
    z-index: 10;
  }
  .gs-care-arr svg { width: 20px; height: 20px; fill: #374151; }
  .gs-care-arr.prev { left: 8px; }
  .gs-care-arr.next { right: 8px; }

  /* Why It Works — stack on tablet/mobile */
  .gs-why-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .gs-why-card {
    padding: 24px 20px;
  }

  /* Testimonials — horizontal slider on tablet/mobile */
  .gs-reviews-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
  }

  /* Bundles */
  .gs-bundle-grid {
    grid-template-columns: 1fr;
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
  }
  .gs-bundle-card[data-bundle="3"] { order: -1; }
  .gs-bundle-card[data-bundle="2"] { order: 0; }
  .gs-bundle-card[data-bundle="1"] { order: 1; }
  .gs-bundle-popular { transform: none; order: -1; }
  .gs-bundle-popular:hover { transform: translateY(-4px); }

  /* Final CTA */
  .gs-final-cta-inner h2 { font-size: 28px; }
  .gs-final-ctas { flex-direction: column; align-items: center; }
  .gs-final-ctas a { width: 100%; max-width: 320px; }

  /* Footer */
  .gs-footer-top { flex-direction: column; gap: 32px; }
  .gs-footer-links { gap: 32px; }

  /* Sticky bar */
  .gs-sticky-text span { display: block; }
}

/* =============================================
   RESPONSIVE — SMALL MOBILE (480px)
   ============================================= */
@media (max-width: 480px) {
  .gs-section { padding: 48px 16px; }
  .gs-hero { padding: 0 16px 24px; }
  .gs-hero-text h1 { font-size: 28px; }
  .gs-hero-badges {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    gap: 12px;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 4px;
  }
  .gs-hero-badges::-webkit-scrollbar { display: none; }
  .gs-hero-badge { white-space: nowrap; flex-shrink: 0; font-size: 12px; }
  .gs-hero-img { margin: 0 -16px; width: calc(100% + 32px); }
  .gs-hero-img img { width: 100%; max-width: none; border-radius: 0; }

  .gs-section-heading { font-size: 26px; }

  .gs-before-after { grid-template-columns: 1fr; }

  .gs-ingredient-card {
    flex-direction: column;
    text-align: center;
    align-items: center;
  }

  /* Owner feedback cards on small mobile */
  .gs-care-testimonials-grid .gs-care-card {
    flex: 0 0 calc(100% - 32px);
    max-width: none;
  }
  /* Reviews grid — single column on small mobile */
  .gs-reviews-grid {
    grid-template-columns: 1fr;
  }

  .gs-bundle-price { font-size: 34px; }

  .gs-footer-links { flex-direction: column; gap: 24px; }

  .gs-marquee-item { font-size: 12px; }
  .gs-section-label { font-size: 12px; }
}

/* As Seen In */
.gs-as-seen {
  text-align: center;
  padding: 24px 40px;
  background: #f5f0e8;
  border-top: 1px solid #E2D8CC;
  border-bottom: 1px solid #E2D8CC;
}
.gs-as-seen-label {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: #6B7A8D;
  margin-bottom: 12px;
  font-weight: 600;
}
.gs-as-seen-logos {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 32px;
  flex-wrap: nowrap;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  max-width: 100%;
  margin: 0 auto;
  padding: 0 16px;
}
.gs-as-seen-logos::-webkit-scrollbar { display: none; }
.gs-as-seen-dupe { display: none; }
@media (max-width: 768px) {
  .gs-as-seen-dupe { display: none; }
}
.gs-as-seen-logo {
  color: #1B2A4A;
  opacity: 0.7;
  white-space: nowrap;
  font-size: 18px;
  font-weight: 700;
  line-height: 1;
}
.gs-asl-petmd { font-family: 'Georgia', serif; font-size: 22px; font-weight: 800; letter-spacing: -0.5px; }
.gs-asl-akc { font-family: 'Times New Roman', serif; font-size: 26px; font-weight: 900; letter-spacing: 3px; text-transform: uppercase; }
.gs-asl-vpn { font-family: 'Arial Narrow', Arial, sans-serif; font-size: 16px; font-weight: 700; letter-spacing: 0.5px; text-transform: uppercase; }
.gs-asl-wdj { font-family: 'Georgia', serif; font-size: 17px; font-weight: 700; font-style: italic; }
.gs-asl-aw { font-family: Arial, sans-serif; font-size: 17px; font-weight: 300; letter-spacing: 2px; text-transform: uppercase; }
@media (min-width: 481px) {
  .gs-asl-petmd { font-size: 28px; }
  .gs-asl-akc { font-size: 32px; }
  .gs-asl-vpn { font-size: 20px; }
  .gs-asl-wdj { font-size: 22px; }
  .gs-asl-aw { font-size: 22px; }
}
@media (max-width: 768px) {
  .gs-as-seen { padding: 16px 16px; }
  .gs-as-seen-logos {
    flex-wrap: wrap;
    gap: 8px 20px;
    justify-content: center;
    overflow-x: visible;
    overflow: visible;
  }
  .gs-as-seen-dupe { display: none !important; }
  .gs-asl-petmd { font-size: 16px; }
  .gs-asl-akc { font-size: 18px; }
  .gs-asl-vpn { font-size: 12px; }
  .gs-asl-wdj { font-size: 13px; }
  .gs-asl-aw { font-size: 13px; }
}

/* Badge bounce animation */
@keyframes badgeBounce {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}

/* =============================================
   COUPON BANNER
   ============================================= */
.gs-coupon-banner {
  position: relative;
  background: #FFF8F2;
  border: 2px dashed #E8654A;
  border-radius: 14px;
  margin: 0 auto 24px;
  max-width: 600px;
  overflow: visible;
}
.gs-coupon-notch {
  position: absolute;
  top: 50%;
  width: 18px;
  height: 18px;
  background: #FFFFFF;
  border-radius: 50%;
  transform: translateY(-50%);
  border: 2px dashed #E8654A;
  z-index: 2;
}
.gs-coupon-notch-left { left: -10px; border-right-color: transparent; }
.gs-coupon-notch-right { right: -10px; border-left-color: transparent; }
.gs-coupon-inner {
  display: flex;
  align-items: center;
  padding: 16px 24px;
  gap: 16px;
}
.gs-coupon-scissors {
  font-size: 18px;
  opacity: 0.4;
  flex-shrink: 0;
}
.gs-coupon-main { flex: 1; }
.gs-coupon-badge {
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 1.2px;
  color: #E8654A;
  text-transform: uppercase;
  margin-bottom: 4px;
}
.gs-coupon-code-row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.gs-coupon-code-box {
  font-family: 'Courier New', monospace;
  font-size: 22px;
  font-weight: 800;
  letter-spacing: 2px;
  color: #1B2A4A;
  background: rgba(232,101,74,0.08);
  padding: 4px 14px;
  border-radius: 6px;
  border: 1px solid rgba(232,101,74,0.2);
}
.gs-coupon-applied {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 16px;
  font-weight: 700;
  color: #5B9A7D;
}
@media (max-width: 480px) {
  .gs-coupon-inner { padding: 14px 18px; gap: 12px; }
  .gs-coupon-code-box { font-size: 18px; padding: 3px 10px; }
  .gs-coupon-notch { width: 14px; height: 14px; }
  .gs-coupon-notch-left { left: -8px; }
  .gs-coupon-notch-right { right: -8px; }
}

/* Hero offer card — bundle option alignment fixes (mirrors live shop-styles.css) */
.gs-hero-bundle-option { width: 100%; box-sizing: border-box; }
.gs-hero-bundle-option > div:first-of-type { text-align: left; }
.gs-hero-bundle-badge { top: -16px; }

.gs-hero-bundle-save { display: inline-block; background: #E8F5EF; color: #2B6B4F; font-size: 12px; font-weight: 800; padding: 2px 8px; border-radius: 4px; margin-top: 4px; }

/* Hero offer card — gift strip inside each option */
@media (max-width: 480px) {
  .gs-hero-bundle-option {
    display: grid !important;
    grid-template-columns: 1fr auto;
    gap: 4px 8px;
    align-items: start;
  }
  .gs-hero-bundle-option > div:first-of-type { grid-column: 1; grid-row: 1; }
  .gs-hero-bundle-option > div:nth-of-type(2) { grid-column: 2; grid-row: 1; text-align: right; }
  .gs-hero-bundle-option > .gs-hero-bundle-gifts {
    grid-column: 1 / -1;
    grid-row: 2;
    width: calc(100% + 28px);
    margin: 6px -14px -12px -14px;
  }
}
.gs-hero-bundle-option { flex-wrap: wrap; }
.gs-hero-bundle-gifts { flex: 0 0 calc(100% + 28px); width: calc(100% + 28px); box-sizing: border-box; margin: 6px -14px -12px -14px; background: #FFF4EA; border-top: 1px solid rgba(232, 101, 74, 0.22); border-radius: 0 0 6px 6px; padding: 4px 14px; text-align: left; }
.gs-hero-bundle-gift { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; font-size: 12px; font-weight: 700; color: #1B2A4A; line-height: 1.3; padding: 1px 0; }
@media (max-width: 480px) { .gs-hero-bundle-gift { font-size: 11px; } }
.gs-hero-bundle-gift + .gs-hero-bundle-gift { border-top: 1px dashed rgba(232, 101, 74, 0.22); margin-top: 0; padding-top: 3px; }
.gs-hero-bundle-gift-label { flex: 1 1 auto; min-width: 0; }
.gs-hero-bundle-gift-price { flex-shrink: 0; color: #E8654A; font-weight: 800; white-space: nowrap; }
.gs-hero-bundle-gift-price s { text-decoration: line-through; text-decoration-thickness: 1.5px; }

/* Bundle grid: bonus total pill under gift-stack bullets */
.gs-bundle-bonus-total { background: #E8F5EF; border: 1px solid #5B9A7D; border-radius: 8px; padding: 10px 14px; margin: 8px 0 16px; font-weight: 800; color: #2B6B4F; text-align: center; font-size: 16px; line-height: 1.35; }

/* Bundle grid: gift rows with strikethrough value chip on the right */
.gs-bundle-gift-item { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; font-weight: 700; color: #1B2A4A; padding: 6px 0 6px 20px; }
.gs-bundle-gift-item + .gs-bundle-gift-item { border-top: 1px dashed rgba(232, 101, 74, 0.22); }
.gs-bundle-gift-label { flex: 1 1 auto; min-width: 0; }
.gs-bundle-gift-price { flex-shrink: 0; color: #E8654A; font-weight: 800; font-size: 15px; white-space: nowrap; }
.gs-bundle-gift-price s { text-decoration: line-through; text-decoration-thickness: 2px; }
