/* =============================================================================
   SCRAPEY DESIGN SYSTEM
   Doorstep scrap pickup service · Ahmedabad, India
   WCAG 2.1 AA compliant · Mobile-first · No Bootstrap dependency
   ============================================================================= */


/* ============================================================================
   1. CSS CUSTOM PROPERTIES (Design Tokens)
   ============================================================================ */

:root {
  /* Brand colours */
  --color-green:        #16A34A;   /* Scrapey Green */
  --color-forest:       #064E3B;   /* Deep Forest */
  --color-yellow:       #FACC15;   /* Cash Yellow */
  --color-bone:         #FAFAF7;   /* Bone White */
  --color-charcoal:     #1F2937;   /* Charcoal */
  --color-mint:         #DCFCE7;   /* Mint Wash */
  --color-sand:         #FEF3C7;   /* Sand */
  --color-soft-grey:    #E5E7EB;   /* Soft Grey */
  --color-stone:        #6B7280;   /* Stone Grey */
  --color-coral:        #FB7185;   /* Alert Coral */

  /* Semantic aliases */
  --color-bg:           var(--color-bone);
  --color-text:         var(--color-charcoal);
  --color-text-muted:   var(--color-stone);
  --color-border:       var(--color-soft-grey);
  --color-success:      var(--color-green);
  --color-error:        var(--color-coral);

  /* Typography */
  --font-display:       'Clash Display', 'Inter', sans-serif;
  --font-body:          'Inter', system-ui, sans-serif;
  --font-number:        'Space Grotesk', 'Inter', sans-serif;

  /* Type scale */
  --text-xs:   0.75rem;    /* 12px */
  --text-sm:   0.875rem;   /* 14px */
  --text-base: 1rem;       /* 16px */
  --text-lg:   1.125rem;   /* 18px */
  --text-xl:   1.25rem;    /* 20px */
  --text-2xl:  1.5rem;     /* 24px */
  --text-3xl:  1.875rem;   /* 30px */
  --text-4xl:  2.25rem;    /* 36px */
  --text-5xl:  3rem;       /* 48px */
  --text-6xl:  3.75rem;    /* 60px */

  /* Spacing */
  --space-1:  0.25rem;
  --space-2:  0.5rem;
  --space-3:  0.75rem;
  --space-4:  1rem;
  --space-5:  1.25rem;
  --space-6:  1.5rem;
  --space-8:  2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-14: 3.5rem;
  --space-16: 4rem;
  --space-20: 5rem;
  --space-24: 6rem;

  /* Radii */
  --radius-sm:   6px;
  --radius-md:   12px;
  --radius-lg:   16px;
  --radius-xl:   24px;
  --radius-2xl:  32px;
  --radius-full: 9999px;

  /* Shadows */
  --shadow-sm:   0 1px 3px rgba(31,41,55,0.08), 0 1px 2px rgba(31,41,55,0.06);
  --shadow-md:   0 4px 16px rgba(31,41,55,0.10), 0 2px 6px rgba(31,41,55,0.06);
  --shadow-lg:   0 10px 32px rgba(31,41,55,0.12), 0 4px 12px rgba(31,41,55,0.08);
  --shadow-xl:   0 20px 56px rgba(31,41,55,0.16);
  --shadow-green: 0 4px 20px rgba(22,163,74,0.28);
  --shadow-card-hover: 0 16px 48px rgba(6,78,59,0.14);

  /* Transitions */
  --transition-fast:   0.15s ease;
  --transition-base:   0.25s ease;
  --transition-slow:   0.4s ease;

  /* Z-index layers */
  --z-header:   100;
  --z-mobile:   99;
  --z-float:    200;
  --z-overlay:  300;

  /* Layout */
  --max-width:  1200px;
  --header-h:   100px;
  --section-py-desktop: 52px;
  --section-py-mobile:  36px;
}


/* ============================================================================
   2. BASE STYLES
   ============================================================================ */

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  tab-size: 4;
  overflow-x: hidden;
}

body {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.65;
  color: var(--color-text);
  background-color: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

/* Prevent scroll when mobile menu open */
body.scrapey-menu-open {
  overflow: hidden;
  position: fixed;
  width: 100%;
}

img, svg {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  color: inherit;
  text-decoration: none;
}

a:focus-visible {
  outline: 3px solid var(--color-green);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
}

button {
  cursor: pointer;
  border: none;
  background: none;
  font-family: inherit;
}

button:focus-visible {
  outline: 3px solid var(--color-green);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
}

ul, ol {
  list-style: none;
}

p + p {
  margin-top: var(--space-4);
}

/* Skip link for keyboard users */
.skip-link {
  position: absolute;
  top: -100%;
  left: var(--space-4);
  padding: var(--space-3) var(--space-6);
  background: var(--color-green);
  color: #fff;
  font-weight: 600;
  border-radius: var(--radius-md);
  z-index: 9999;
  transition: top var(--transition-fast);
}
.skip-link:focus {
  top: var(--space-4);
}


/* ============================================================================
   3. TYPOGRAPHY
   ============================================================================ */

.display-xl {
  font-family: var(--font-display);
  font-size: clamp(var(--text-4xl), 6vw, var(--text-6xl));
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--color-forest);
}

.display-l {
  font-family: var(--font-display);
  font-size: clamp(var(--text-3xl), 4.5vw, var(--text-5xl));
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--color-forest);
}

.heading-1 {
  font-family: var(--font-display);
  font-size: clamp(var(--text-2xl), 3.5vw, var(--text-4xl));
  font-weight: 700;
  line-height: 1.2;
  color: var(--color-charcoal);
}

.heading-2 {
  font-family: var(--font-display);
  font-size: clamp(var(--text-xl), 2.5vw, var(--text-3xl));
  font-weight: 600;
  line-height: 1.25;
  color: var(--color-charcoal);
}

.heading-3 {
  font-family: var(--font-display);
  font-size: clamp(var(--text-lg), 2vw, var(--text-2xl));
  font-weight: 600;
  line-height: 1.3;
  color: var(--color-charcoal);
}

.body-large {
  font-size: var(--text-lg);
  line-height: 1.7;
  color: var(--color-charcoal);
}

.body {
  font-size: var(--text-base);
  line-height: 1.65;
  color: var(--color-charcoal);
}

.small {
  font-size: var(--text-sm);
  line-height: 1.5;
  color: var(--color-stone);
}

.price-display {
  font-family: var(--font-number);
  font-weight: 700;
  line-height: 1;
  color: var(--color-forest);
}

.price-inline {
  font-family: var(--font-number);
  font-weight: 600;
  color: var(--color-charcoal);
}


/* ============================================================================
   4. HEADER
   ============================================================================ */

.scrapey-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: var(--z-header);
  background: var(--color-bone);
  border-bottom: 1px solid transparent;
  transition:
    background var(--transition-base),
    border-color var(--transition-base),
    box-shadow var(--transition-base);
}

.scrapey-header--scrolled {
  background: var(--color-forest);
  border-color: rgba(255,255,255,0.08);
  box-shadow: 0 2px 20px rgba(6,78,59,0.35);
}

.scrapey-header__inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-6);
  height: var(--header-h);
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

/* Logo */
.scrapey-header__logo {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

/* WordPress outputs: <a class="custom-logo-link"><img class="custom-logo"></a> */
.scrapey-header__logo a,
.scrapey-header__logo .custom-logo-link {
  display: flex !important;
  align-items: center !important;
  text-decoration: none !important;
  transition: opacity var(--transition-fast);
}
.scrapey-header__logo a:hover,
.scrapey-header__logo .custom-logo-link:hover { opacity: 0.85; }

/* Target WordPress custom-logo img directly — use !important to override theme */
.scrapey-header__logo img,
.scrapey-header__logo .custom-logo,
img.custom-logo {
  height: 90px !important;
  width: auto !important;
  max-width: 240px !important;
  max-height: none !important;
  display: block !important;
  object-fit: contain !important;
}

@media (max-width: 767px) {
  .scrapey-header__logo img,
  .scrapey-header__logo .custom-logo,
  img.custom-logo {
    height: 44px !important;
    max-width: 140px !important;
  }
}

/* On scrolled dark header */
.scrapey-header--scrolled .scrapey-header__logo img,
.scrapey-header--scrolled .custom-logo {
  filter: brightness(0) invert(1);
}

/* Fallback text logo */
.scrapey-header__logo-fallback {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--color-green);
  letter-spacing: -0.03em;
  text-decoration: none;
  transition: color var(--transition-base);
}
.scrapey-header--scrolled .scrapey-header__logo-fallback {
  color: var(--color-yellow);
}

/* Desktop nav */
.scrapey-header__nav {
  flex: 1;
  display: none;
}

.scrapey-header__nav-list {
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

.scrapey-header__nav-link {
  display: flex;
  align-items: center;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-charcoal);
  border-radius: var(--radius-sm);
  transition: color var(--transition-fast), background var(--transition-fast);
  min-height: 44px;
  white-space: nowrap;
}

.scrapey-header__nav-link:hover {
  color: var(--color-green);
  background: var(--color-mint);
}

.scrapey-header--scrolled .scrapey-header__nav-link {
  color: rgba(255,255,255,0.85);
}

.scrapey-header--scrolled .scrapey-header__nav-link:hover {
  color: var(--color-yellow);
  background: rgba(255,255,255,0.08);
}

/* Desktop actions */
.scrapey-header__actions {
  display: none;
  align-items: center;
  gap: var(--space-3);
  flex-shrink: 0;
}

/* WhatsApp ghost button in header */
.scrapey-header__whatsapp {
  gap: var(--space-2);
}

/* ── Language chip (shared across header + footer) ────────────────────────── */
.scrapey-lang-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 5px 12px;
  border-radius: 999px;
  border: 1.5px solid rgba(255,255,255,0.25);
  background: transparent;
  color: rgba(255,255,255,0.65);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  cursor: pointer;
  transition: background 0.18s, color 0.18s, border-color 0.18s;
  line-height: 1;
  white-space: nowrap;
}
.scrapey-lang-chip:hover {
  border-color: rgba(255,255,255,0.5);
  color: #fff;
}
.scrapey-lang-chip.is-active {
  background: var(--color-forest);
  border-color: var(--color-forest);
  color: #fff;
}

/* Header language group */
.scrapey-header__lang {
  display: none;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}
@media (min-width: 1024px) {
  .scrapey-header__lang { display: flex; }
}

/* On light bone header (default) — use dark chip colors */
.scrapey-header__lang .scrapey-lang-chip {
  border-color: rgba(6,78,59,0.3);
  color: var(--color-forest);
}
.scrapey-header__lang .scrapey-lang-chip:hover {
  border-color: #064E3B;
  color: #064E3B;
  background: rgba(6,78,59,0.06);
}
.scrapey-header__lang .scrapey-lang-chip.is-active {
  background: #064E3B !important;
  border-color: #064E3B !important;
  color: #fff !important;
}

/* On scrolled dark header — revert to light chip colors */
.scrapey-header--scrolled .scrapey-header__lang .scrapey-lang-chip {
  border-color: rgba(255,255,255,0.3);
  color: rgba(255,255,255,0.7);
}
.scrapey-header--scrolled .scrapey-header__lang .scrapey-lang-chip:hover {
  border-color: rgba(255,255,255,0.6);
  color: #fff;
  background: rgba(255,255,255,0.08);
}
.scrapey-header--scrolled .scrapey-header__lang .scrapey-lang-chip.is-active {
  background: #064E3B !important;
  border-color: #064E3B !important;
  color: #fff !important;
}

/* Mobile menu language group */
.scrapey-header__mobile-lang {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 0 4px;
  border-top: 1px solid rgba(255,255,255,0.1);
  margin-top: 4px;
}

/* Mobile hamburger */
.scrapey-header__hamburger {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 44px;
  height: 44px;
  padding: var(--space-2);
  margin-left: auto;
  border-radius: var(--radius-sm);
  transition: background var(--transition-fast);
}

.scrapey-header__hamburger:hover {
  background: var(--color-mint);
}

.scrapey-header--scrolled .scrapey-header__hamburger:hover {
  background: rgba(255,255,255,0.1);
}

.scrapey-header__hamburger-bar {
  display: block;
  width: 100%;
  height: 2px;
  background: var(--color-charcoal);
  border-radius: 2px;
  transition: transform var(--transition-base), opacity var(--transition-base), background var(--transition-base);
  transform-origin: center;
}

.scrapey-header--scrolled .scrapey-header__hamburger-bar {
  background: #fff;
}

.scrapey-header__hamburger.is-active .scrapey-header__hamburger-bar:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
.scrapey-header__hamburger.is-active .scrapey-header__hamburger-bar:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}
.scrapey-header__hamburger.is-active .scrapey-header__hamburger-bar:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* Mobile menu panel */
.scrapey-header__mobile {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--color-forest);
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.35s cubic-bezier(0.4,0,0.2,1);
  z-index: var(--z-mobile);
}

.scrapey-header__mobile.is-open {
  max-height: 520px;
}

.scrapey-header__mobile-list {
  padding: var(--space-4) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.scrapey-header__mobile-link {
  display: block;
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-lg);
  font-weight: 500;
  color: rgba(255,255,255,0.9);
  border-radius: var(--radius-sm);
  min-height: 52px;
  display: flex;
  align-items: center;
  transition: color var(--transition-fast), background var(--transition-fast);
}

.scrapey-header__mobile-link:hover {
  color: var(--color-yellow);
  background: rgba(255,255,255,0.06);
}

.scrapey-header__mobile-actions {
  padding: var(--space-4) var(--space-6) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

@media (min-width: 1024px) {
  .scrapey-header__hamburger { display: none; }
  .scrapey-header__nav { display: flex; }
  .scrapey-header__actions { display: flex; }
  .scrapey-header__mobile { display: none; }
}


/* ============================================================================
   5. BUTTONS
   ============================================================================ */

.scrapey-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 0.625rem var(--space-6);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 600;
  line-height: 1.25;
  min-height: 44px;
  border-radius: var(--radius-full);
  border: 2px solid transparent;
  text-decoration: none;
  cursor: pointer;
  transition:
    background var(--transition-base),
    color var(--transition-base),
    border-color var(--transition-base),
    box-shadow var(--transition-base),
    transform var(--transition-fast);
  white-space: nowrap;
  user-select: none;
}

.scrapey-btn:focus-visible {
  outline: 3px solid var(--color-green);
  outline-offset: 3px;
}

.scrapey-btn:active {
  transform: scale(0.97);
}

/* Primary — Scrapey Green */
.scrapey-btn--primary {
  background: var(--color-green);
  color: #fff;
  border-color: var(--color-green);
  box-shadow: var(--shadow-green);
}
.scrapey-btn--primary:hover {
  background: #15803D;
  border-color: #15803D;
  box-shadow: 0 6px 24px rgba(22,163,74,0.38);
  color: #fff;
}
.scrapey-btn--primary:focus-visible {
  outline-color: var(--color-forest);
}

/* Ghost — transparent with green border */
.scrapey-btn--ghost {
  background: transparent;
  color: var(--color-green);
  border-color: var(--color-green);
}
.scrapey-btn--ghost:hover {
  background: var(--color-mint);
  color: var(--color-forest);
}

/* On dark backgrounds */
.scrapey-header--scrolled .scrapey-btn--ghost {
  color: rgba(255,255,255,0.9);
  border-color: rgba(255,255,255,0.4);
}
.scrapey-header--scrolled .scrapey-btn--ghost:hover {
  background: rgba(255,255,255,0.1);
  color: #fff;
}

/* Outline — white, for dark backgrounds */
.scrapey-btn--outline {
  background: transparent;
  color: #fff;
  border-color: rgba(255,255,255,0.6);
}
.scrapey-btn--outline:hover {
  background: rgba(255,255,255,0.12);
  border-color: #fff;
  color: #fff;
}

/* WhatsApp button */
.scrapey-btn--whatsapp {
  background: #25D366;
  color: #fff;
  border-color: #25D366;
}
.scrapey-btn--whatsapp:hover {
  background: #1ebe58;
  border-color: #1ebe58;
  box-shadow: 0 4px 20px rgba(37,211,102,0.35);
  color: #fff;
}

/* Sizes */
.scrapey-btn--lg {
  padding: 0.875rem var(--space-8);
  font-size: var(--text-base);
  min-height: 52px;
}

/* Full width */
.scrapey-btn--full {
  width: 100%;
}

/* Disabled */
.scrapey-btn:disabled,
.scrapey-btn[aria-disabled="true"] {
  opacity: 0.5;
  pointer-events: none;
  cursor: not-allowed;
}


/* ============================================================================
   6. RATE PILLS
   ============================================================================ */

.rate-pill {
  display: inline-flex;
  align-items: baseline;
  gap: var(--space-1);
  background: var(--color-yellow);
  color: var(--color-charcoal);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-full);
  line-height: 1;
}

.rate-pill__price {
  font-family: var(--font-number);
  font-weight: 700;
  font-size: var(--text-xl);
  color: var(--color-charcoal);
}

.rate-pill__unit {
  font-family: var(--font-number);
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--color-stone);
}

.rate-pill--range .rate-pill__price {
  font-size: var(--text-base);
}


/* ============================================================================
   7. CARDS
   ============================================================================ */

.scrapey-card {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  padding: var(--space-8);
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.scrapey-card:hover {
  box-shadow: var(--shadow-card-hover);
  transform: translateY(-4px);
}


/* ============================================================================
   8. SECTION CONTAINERS
   ============================================================================ */

.scrapey-section {
  padding: var(--section-py-mobile) 0;
  position: relative;
}

.scrapey-container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-6);
  width: 100%;
}

.scrapey-section-header {
  text-align: center;
  margin-bottom: var(--space-8);
}

.scrapey-section-sub {
  margin-top: var(--space-4);
  color: var(--color-stone);
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
}

@media (min-width: 1024px) {
  .scrapey-section {
    padding: var(--section-py-desktop) 0;
  }
  .scrapey-container {
    padding: 0 var(--space-8);
  }
}


/* ============================================================================
   9. HERO SECTION
   ============================================================================ */

.hero-section {
  min-height: 100vh;
  display: flex;
  align-items: center;
  /* Only clear the fixed header — flexbox centering handles the rest */
  padding-top:    var(--header-h);
  padding-bottom: 36px;
  background: var(--color-bone);
  overflow: visible;
  position: relative;
}

/* Mint blob */
.hero-blob {
  position: absolute;
  top: -10%;
  right: -15%;
  width: 680px;
  height: 680px;
  background: radial-gradient(ellipse at center, var(--color-mint) 0%, transparent 70%);
  border-radius: 40% 60% 55% 45% / 45% 40% 60% 55%;
  pointer-events: none;
  z-index: 0;
  animation: blob-drift 14s ease-in-out infinite alternate;
}

@keyframes blob-drift {
  0%   { transform: translate(0, 0) scale(1); }
  100% { transform: translate(-30px, 20px) scale(1.06); }
}

.hero-container {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
  align-items: center;
  position: relative;
  z-index: 1;
}

/* Hero copy */
.hero-copy {
  max-width: 600px;
}

/* Trust strip */
.hero-trust-strip {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  background: var(--color-mint);
  color: var(--color-forest);
  font-size: var(--text-sm);
  font-weight: 600;
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-full);
  margin-bottom: var(--space-6);
  border: 1px solid rgba(22,163,74,0.18);
}

.hero-trust-star {
  color: var(--color-yellow);
  font-size: var(--text-base);
}

.hero-trust-divider {
  color: var(--color-stone);
}

/* Hero heading */
.hero-heading {
  margin-bottom: var(--space-6);
}

.hero-heading-accent {
  color: var(--color-green);
  position: relative;
}

.hero-heading-accent::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--color-yellow);
  border-radius: 2px;
}

/* Hero subhead */
.hero-subhead {
  margin-bottom: var(--space-8);
  color: var(--color-stone);
}

/* Hero CTA row */
.hero-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-4);
}

.hero-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-weight: 600;
  font-size: var(--text-base);
  color: var(--color-green);
  transition: gap var(--transition-fast), color var(--transition-fast);
}

.hero-link:hover {
  color: var(--color-forest);
  gap: var(--space-3);
}

/* Hero visual */
.hero-visual {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 3;
}

/* Phone mockup */
.upi-phone {
  width: 240px;
  background: #1a1a2e;
  border-radius: 32px;
  padding: 16px;
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.08),
    var(--shadow-xl),
    0 0 60px rgba(22,163,74,0.15);
  position: relative;
}

.upi-phone__screen {
  background: #0f1628;
  border-radius: 22px;
  padding: var(--space-5) var(--space-4) var(--space-4);
  min-height: 360px;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

/* UPI notification card */
.upi-card {
  background: #fff;
  border-radius: var(--radius-md);
  padding: var(--space-4);
  box-shadow: var(--shadow-lg);
  animation: slide-in-card 0.6s 0.3s cubic-bezier(0.34,1.56,0.64,1) both;
}

@keyframes slide-in-card {
  from { transform: translateY(20px); opacity: 0; }
  to   { transform: translateY(0);    opacity: 1; }
}

.upi-card__header {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}

.upi-card__app-icon {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: linear-gradient(135deg, #16A34A, #064E3B);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: var(--text-base);
  flex-shrink: 0;
}

.upi-card__app-meta {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.upi-card__app-name {
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--color-charcoal);
  line-height: 1;
}

.upi-card__time {
  font-size: 10px;
  color: var(--color-stone);
  line-height: 1;
}

.upi-card__badge {
  width: 20px;
  height: 20px;
  background: var(--color-green);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
  flex-shrink: 0;
}

.upi-card__amount {
  font-family: var(--font-number);
  font-size: var(--text-4xl);
  font-weight: 700;
  color: var(--color-green);
  line-height: 1;
  margin-bottom: var(--space-1);
}

.upi-card__label {
  font-size: var(--text-sm);
  color: var(--color-stone);
  margin-bottom: var(--space-3);
}

.upi-card__ref {
  font-size: 10px;
  color: var(--color-stone);
  background: var(--color-soft-grey);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  line-height: 1.4;
}

/* Payment app logos strip */
.upi-card__payment-apps {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-soft-grey);
}

.upi-card__payment-apps-label {
  font-size: 9px;
  color: var(--color-stone);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  flex-shrink: 0;
}

.upi-card__app-logos {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.pay-app {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 22px;
  padding: 0 6px;
  border-radius: 4px;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1;
  white-space: nowrap;
}

.pay-app--gpay {
  background: #fff;
  border: 1px solid #e5e7eb;
  color: #1a73e8;
  font-family: 'Google Sans', sans-serif;
}

.pay-app--gpay em {
  font-style: normal;
  color: #ea4335;
  margin-left: 1px;
}

.pay-app--phonepe {
  background: #5f259f;
  color: #fff;
  font-size: 10px;
  font-weight: 900;
}

.pay-app--paytm {
  background: #00b9f5;
  color: #fff;
  font-size: 8px;
  font-weight: 700;
  letter-spacing: 0;
}

.pay-app--upi {
  background: #fff;
  border: 1px solid #e5e7eb;
  padding: 0 4px;
  height: 22px;
  display: inline-flex;
  align-items: center;
}

/* Balance and weight rows */
.upi-balance {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-3) var(--space-3);
  background: rgba(255,255,255,0.05);
  border-radius: var(--radius-sm);
}

.upi-balance__label {
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.5);
}

.upi-balance__value {
  font-family: var(--font-number);
  font-size: var(--text-sm);
  font-weight: 600;
  color: #fff;
}

.upi-weight {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-xs);
  color: var(--color-yellow);
  padding: var(--space-2) var(--space-3);
  background: rgba(250,204,21,0.08);
  border-radius: var(--radius-sm);
}

/* Floating badges */
.hero-badge {
  position: absolute;
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: 600;
  white-space: nowrap;
  box-shadow: var(--shadow-lg);
  animation: badge-float 3s ease-in-out infinite alternate;
  z-index: 10;
}

@keyframes badge-float {
  0%   { transform: translateY(0); }
  100% { transform: translateY(-6px); }
}

.hero-badge--pickup {
  top: -8%;
  right: -8%;
  background: #fff;
  color: var(--color-green);
  animation-delay: 0s;
}

.hero-badge--eco {
  bottom: 20%;
  left: -10%;
  background: var(--color-forest);
  color: var(--color-yellow);
  animation-delay: 1.5s;
}

@media (min-width: 768px) {
  .hero-badge--pickup { right: -16%; }
  .hero-badge--eco    { left: -18%; }
}

@media (min-width: 1024px) {
  .hero-section {
    padding-top: var(--header-h);
    padding-bottom: 44px;
  }
  .hero-container {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-16);
  }
  .hero-visual {
    justify-content: flex-end;
  }
  .upi-phone {
    width: 280px;
  }
  .hero-badge--pickup { right: -5%; }
  .hero-badge--eco    { left: -8%; }
}


/* ============================================================================
   10. RATES SECTION
   ============================================================================ */

.rates-section {
  background: var(--color-bone);
}

/* Filter chips */
.rates-filters {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  justify-content: center;
  margin-bottom: var(--space-10);
}

.rates-chip {
  padding: var(--space-2) var(--space-5) !important;
  border-radius: var(--radius-full) !important;
  border: 2px solid var(--color-border) !important;
  font-size: var(--text-sm) !important;
  font-weight: 600 !important;
  color: var(--color-stone) !important;
  background: #fff !important;
  background-color: #fff !important;
  min-height: 44px !important;
  cursor: pointer !important;
  transition:
    background var(--transition-fast),
    border-color var(--transition-fast),
    color var(--transition-fast);
  text-decoration: none !important;
}

.rates-chip:hover,
.rates-chip:focus {
  border-color: var(--color-green) !important;
  color: var(--color-green) !important;
  background: #fff !important;
  background-color: #fff !important;
  text-decoration: none !important;
}

.rates-chip.is-active,
.rates-chip.is-active:hover,
.rates-chip.is-active:focus {
  background: var(--color-green) !important;
  background-color: var(--color-green) !important;
  border-color: var(--color-green) !important;
  color: #fff !important;
}

/* Rate cards grid */
.rates-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}

.rate-card {
  background: #fff;
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  align-items: flex-start;
  transition: box-shadow var(--transition-base), transform var(--transition-base);
  position: relative;
  overflow: hidden;
}

.rate-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--color-green);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--transition-base);
}

.rate-card:hover {
  box-shadow: var(--shadow-card-hover);
  transform: translateY(-4px);
}

.rate-card:hover::before {
  transform: scaleX(1);
}

.rate-card__icon {
  width: 48px;
  height: 48px;
  background: var(--color-mint);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  color: var(--color-forest);
  flex-shrink: 0;
}

.rate-card__name {
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-charcoal);
  line-height: 1.3;
}

.rate-card__tag {
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--color-stone);
  background: var(--color-soft-grey);
  padding: 2px var(--space-3);
  border-radius: var(--radius-full);
  margin-top: auto;
  align-self: flex-start;
}

/* Rates footer link */
.rates-footer {
  text-align: center;
  margin-top: var(--space-10);
}

.rates-all-link {
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-green);
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  transition: gap var(--transition-fast), color var(--transition-fast);
}

.rates-all-link:hover {
  color: var(--color-forest);
  gap: var(--space-3);
}

@media (min-width: 768px) {
  .rates-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (min-width: 1024px) {
  .rates-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-6);
  }
  .rate-card {
    padding: var(--space-8);
  }
}


/* ============================================================================
   11. HOW IT WORKS (STEPS)
   ============================================================================ */

.steps-section {
  background: var(--color-mint);
}

.steps-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

.step-card {
  background: #fff;
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  box-shadow: var(--shadow-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.step-card:hover {
  box-shadow: var(--shadow-card-hover);
  transform: translateY(-6px);
}

/* Step number — large Cash Yellow circle */
.step-card__number {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--color-yellow);
  color: var(--color-charcoal);
  font-family: var(--font-number);
  font-size: var(--text-2xl);
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(250,204,21,0.4);
}

/* Step illustrations */
.step-card__illustration {
  width: 100%;
  height: 140px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-bone);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

/* Book illustration */
.step-illus--book {
  display: flex;
  align-items: center;
  justify-content: center;
}

.step-illus__phone {
  width: 80px;
  background: var(--color-charcoal);
  border-radius: 14px;
  padding: 8px 6px;
  box-shadow: var(--shadow-md);
}

.step-illus__screen {
  background: #0f1628;
  border-radius: 8px;
  padding: 8px 6px;
  min-height: 100px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  justify-content: flex-end;
}

.step-illus__bubble {
  padding: 5px 8px;
  border-radius: 10px;
  font-size: 7px;
  font-weight: 500;
  line-height: 1.3;
  color: #fff;
  max-width: 90%;
}

.step-illus__bubble--in {
  background: rgba(255,255,255,0.12);
  align-self: flex-start;
  border-bottom-left-radius: 3px;
}

.step-illus__bubble--out {
  background: var(--color-green);
  align-self: flex-end;
  border-bottom-right-radius: 3px;
}

/* Weigh illustration */
.step-illus--weigh {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.step-illus__scale {
  position: relative;
  width: 100px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
}

.step-illus__scale-base {
  width: 60px;
  height: 8px;
  background: var(--color-charcoal);
  border-radius: 4px;
}

.step-illus__scale-post {
  width: 6px;
  height: 30px;
  background: var(--color-forest);
  border-radius: 3px;
}

.step-illus__scale-beam {
  width: 80px;
  height: 6px;
  background: var(--color-green);
  border-radius: 3px;
}

.step-illus__scale-pan {
  width: 28px;
  height: 6px;
  background: var(--color-yellow);
  border-radius: 3px;
  position: absolute;
  top: 24px;
}

.step-illus__scale-pan--l { left: 2px; }
.step-illus__scale-pan--r { right: 2px; }

.step-illus__scale-display {
  background: var(--color-charcoal);
  color: var(--color-yellow);
  font-family: var(--font-number);
  font-size: 11px;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: var(--radius-sm);
  margin-top: var(--space-2);
  letter-spacing: 0.03em;
}

/* Pay illustration */
.step-illus--pay {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
  position: relative;
}

.step-illus__upi-badge {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  background: #fff;
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  box-shadow: var(--shadow-md);
}

.step-illus__upi-icon {
  width: 40px;
  height: 40px;
  background: var(--color-green);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-xl);
  font-weight: 700;
  flex-shrink: 0;
}

.step-illus__upi-amount {
  font-family: var(--font-number);
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--color-green);
  display: block;
  line-height: 1;
}

.step-illus__upi-label {
  font-size: var(--text-xs);
  color: var(--color-stone);
  font-weight: 500;
  display: block;
}

.step-illus__checkmark {
  width: 36px;
  height: 36px;
  background: var(--color-green);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-xl);
  font-weight: 700;
  flex-shrink: 0;
  box-shadow: var(--shadow-green);
  position: absolute;
  top: -8px;
  right: -8px;
}

.step-card__title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--color-forest);
  line-height: 1.2;
}

.step-card__desc {
  font-size: var(--text-base);
  color: var(--color-stone);
  line-height: 1.65;
}

@media (min-width: 768px) {
  .steps-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-6);
  }
}

@media (min-width: 1024px) {
  .steps-grid {
    gap: var(--space-8);
  }
}


/* ============================================================================
   12. COMPARISON TABLE
   ============================================================================ */

.compare-section {
  background: var(--color-bone);
}

.compare-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
}

.compare-table {
  width: 100%;
  min-width: 560px;
  border-collapse: separate;
  border-spacing: 0;
  background: #fff;
  border-radius: var(--radius-xl);
  overflow: hidden;
}

.compare-table thead tr {
  background: var(--color-soft-grey);
}

.compare-table__feature-col {
  width: 30%;
}

.compare-table__kabadi-col,
.compare-table__scrapey-col {
  width: 35%;
}

.compare-table th {
  padding: var(--space-5) var(--space-6);
  font-weight: 700;
  font-size: var(--text-sm);
  text-align: left;
  vertical-align: middle;
}

.compare-table__col-label {
  display: block;
  font-size: var(--text-base);
  font-family: var(--font-display);
  font-weight: 700;
}

.compare-table__col-label--kabadi {
  color: var(--color-stone);
}

.compare-table__col-label--scrapey {
  color: var(--color-green);
  font-size: var(--text-lg);
}

.compare-table td {
  padding: var(--space-4) var(--space-6);
  border-top: 1px solid var(--color-soft-grey);
  font-size: var(--text-sm);
  vertical-align: middle;
}

.compare-table tbody tr:hover {
  background: var(--color-bone);
}

.compare-table__feature {
  font-weight: 600;
  color: var(--color-charcoal);
  font-size: var(--text-sm);
}

.compare-table__kabadi {
  color: var(--color-stone);
}

.compare-table__scrapey {
  background: rgba(220,252,231,0.4);
  color: var(--color-charcoal);
}

.compare-no,
.compare-yes {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  font-size: 12px;
  font-weight: 700;
  flex-shrink: 0;
  margin-right: var(--space-2);
  vertical-align: middle;
}

.compare-no {
  background: rgba(251,113,133,0.15);
  color: var(--color-coral);
}

.compare-yes {
  background: var(--color-mint);
  color: var(--color-green);
}

.compare-desc {
  font-size: var(--text-sm);
  vertical-align: middle;
}


/* ============================================================================
   13. TESTIMONIALS
   ============================================================================ */

.testimonials-section {
  background: var(--color-sand);
}

.testimonials-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

.testimonial-card {
  background: #fff;
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  box-shadow: var(--shadow-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.testimonial-card:hover {
  box-shadow: var(--shadow-card-hover);
  transform: translateY(-4px);
}

.testimonial-card__stars {
  display: flex;
  gap: 3px;
  color: var(--color-yellow);
  font-size: var(--text-lg);
}

.testimonial-card__quote {
  font-size: var(--text-base);
  line-height: 1.75;
  color: var(--color-charcoal);
  font-style: italic;
  flex: 1;
  position: relative;
}

.testimonial-card__quote::before {
  content: '\201C';
  font-size: 4rem;
  line-height: 0;
  vertical-align: -1rem;
  color: var(--color-mint);
  font-family: Georgia, serif;
  margin-right: var(--space-1);
}

.testimonial-card__footer {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-soft-grey);
  flex-wrap: wrap;
}

.testimonial-card__avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--color-green);
  color: #fff;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-xl);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.testimonial-card__meta {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.testimonial-card__name {
  font-style: normal;
  font-weight: 700;
  font-size: var(--text-sm);
  color: var(--color-charcoal);
}

.testimonial-card__suburb {
  font-size: var(--text-xs);
  color: var(--color-stone);
}

.testimonial-card__earned {
  flex-shrink: 0;
}

@media (min-width: 768px) {
  .testimonials-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}


/* ============================================================================
   14. FOR BUSINESS
   ============================================================================ */

.business-section {
  background: var(--color-forest);
  color: #fff;
}

.business-section .display-l,
.business-section .scrapey-section-header .display-l {
  color: #fff;
}

.business-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
  align-items: center;
}

.business-heading {
  color: #fff;
  margin-bottom: var(--space-5);
}

.business-body {
  color: rgba(255,255,255,0.75);
  margin-bottom: var(--space-8);
}

.business-pillars {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-bottom: var(--space-8);
}

.business-pillar {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.12);
  padding: var(--space-3) var(--space-5);
  border-radius: var(--radius-full);
  font-size: var(--text-sm);
  font-weight: 600;
  color: rgba(255,255,255,0.9);
  transition: background var(--transition-base);
}

.business-pillar:hover {
  background: rgba(255,255,255,0.14);
}

.business-pillar i {
  color: var(--color-yellow);
  font-size: var(--text-lg);
}

.business-stats-card {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.business-stats-item {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.business-stats-item i {
  width: 48px;
  height: 48px;
  background: rgba(250,204,21,0.12);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-2xl);
  color: var(--color-yellow);
  flex-shrink: 0;
}

.business-stats-item strong {
  display: block;
  font-family: var(--font-number);
  font-size: var(--text-xl);
  font-weight: 700;
  color: #fff;
  line-height: 1;
  margin-bottom: 2px;
}

.business-stats-item span {
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.55);
}

@media (min-width: 1024px) {
  .business-inner {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-16);
  }
}


/* ============================================================================
   15. IMPACT STATS
   ============================================================================ */

.impact-section {
  background: var(--color-mint);
}

.impact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}

.impact-card {
  background: #fff;
  border-radius: var(--radius-xl);
  padding: var(--space-8) var(--space-6);
  box-shadow: var(--shadow-md);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.impact-card:hover {
  box-shadow: var(--shadow-card-hover);
  transform: translateY(-4px);
}

.impact-card__icon {
  width: 56px;
  height: 56px;
  background: var(--color-mint);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-2xl);
  color: var(--color-forest);
  flex-shrink: 0;
}

.impact-card__number {
  font-size: clamp(var(--text-3xl), 5vw, var(--text-5xl));
  font-weight: 700;
  color: var(--color-forest);
  line-height: 1;
}

.impact-card__label {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-stone);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

@media (min-width: 768px) {
  .impact-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-6);
  }
}

@media (min-width: 1024px) {
  .impact-card {
    padding: var(--space-10) var(--space-8);
  }
}


/* ============================================================================
   16. FAQ ACCORDION
   ============================================================================ */

.faq-section {
  background: var(--color-bone);
}

.faq-list {
  max-width: 800px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.faq-item {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  border: 1px solid var(--color-border);
  transition: box-shadow var(--transition-base);
}

.faq-item.is-open {
  box-shadow: var(--shadow-md);
  border-color: var(--color-green);
}

.faq-item__trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-6);
  text-align: left;
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-charcoal);
  background: transparent;
  cursor: pointer;
  min-height: 64px;
  transition: color var(--transition-fast), background var(--transition-fast);
}

.faq-item__trigger:hover {
  color: var(--color-green);
  background: var(--color-bone);
}

.faq-item.is-open .faq-item__trigger {
  color: var(--color-green);
}

.faq-item__icon {
  font-size: var(--text-xl);
  color: var(--color-green);
  flex-shrink: 0;
  transition: transform var(--transition-base);
}

.faq-item.is-open .faq-item__icon {
  transform: rotate(45deg);
}

.faq-item__body {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.35s cubic-bezier(0.4,0,0.2,1);
}

.faq-item__body:not([hidden]) {
  /* JS sets max-height inline */
}

.faq-item__body p {
  padding: 0 var(--space-6) var(--space-5);
  font-size: var(--text-base);
  line-height: 1.75;
  color: var(--color-stone);
}


/* ============================================================================
   17. CTA BAND
   ============================================================================ */

.cta-section {
  background: var(--color-green);
  padding: var(--section-py-mobile) 0;
}

.cta-section .scrapey-section-header .display-l {
  color: #fff;
}

.cta-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
  align-items: start;
}

.cta-heading {
  color: #fff;
  margin-bottom: var(--space-5);
}

.cta-body {
  color: rgba(255,255,255,0.85);
  margin-bottom: var(--space-8);
}

.cta-whatsapp {
  margin-bottom: var(--space-5);
}

.cta-hours {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.65);
}

.cta-hours i {
  color: var(--color-yellow);
}

@media (min-width: 1024px) {
  .cta-section {
    padding: var(--section-py-desktop) 0;
  }
  .cta-inner {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-16);
    align-items: center;
  }
}


/* ============================================================================
   18. CONTACT / BOOKING FORM (CF7)
   ============================================================================ */

.cta-form-card {
  background: #fff;
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  box-shadow: var(--shadow-xl);
}

.cta-form-card__title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--color-forest);
  margin-bottom: var(--space-6);
}

/* CF7 base overrides */
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.failed .wpcf7-response-output {
  border: 1px solid var(--color-coral);
  background: rgba(251,113,133,0.06);
  color: var(--color-coral);
  border-radius: var(--radius-sm);
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm);
  margin-top: var(--space-4);
}

.wpcf7 form.sent .wpcf7-response-output {
  border: 1px solid var(--color-green);
  background: var(--color-mint);
  color: var(--color-forest);
  border-radius: var(--radius-sm);
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm);
  margin-top: var(--space-4);
}

.wpcf7 p {
  margin-bottom: var(--space-4);
}

.wpcf7 label {
  display: block;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-charcoal);
  margin-bottom: var(--space-2);
}

.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 textarea,
.wpcf7 select {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-charcoal);
  background: var(--color-bone);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  min-height: 48px;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  appearance: none;
  outline: none;
}

.wpcf7 input[type="text"]:focus,
.wpcf7 input[type="email"]:focus,
.wpcf7 input[type="tel"]:focus,
.wpcf7 textarea:focus,
.wpcf7 select:focus {
  border-color: var(--color-green);
  box-shadow: 0 0 0 3px rgba(22,163,74,0.15);
}

.wpcf7 textarea {
  min-height: 100px;
  resize: vertical;
}

.wpcf7 input[type="submit"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.875rem var(--space-8);
  background: var(--color-green);
  color: #fff;
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: 600;
  border: none;
  border-radius: var(--radius-full);
  min-height: 52px;
  cursor: pointer;
  width: 100%;
  transition: background var(--transition-base), box-shadow var(--transition-base), transform var(--transition-fast);
  box-shadow: var(--shadow-green);
}

.wpcf7 input[type="submit"]:hover {
  background: #15803D;
  box-shadow: 0 6px 24px rgba(22,163,74,0.38);
}

.wpcf7 input[type="submit"]:active {
  transform: scale(0.97);
}

.wpcf7-not-valid-tip {
  color: var(--color-coral);
  font-size: var(--text-xs);
  margin-top: var(--space-1);
  display: block;
}

.wpcf7-spinner {
  display: none;
}


/* ============================================================================
   19. FOOTER
   ============================================================================ */

.scrapey-footer {
  background: var(--color-forest);
  color: rgba(255,255,255,0.75);
}

.scrapey-footer__container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-6);
  width: 100%;
}

.scrapey-footer__top {
  padding: var(--space-16) 0 var(--space-12);
}

.scrapey-footer__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-10);
}

/* Col 1: Brand */
.scrapey-footer__brand { }

.scrapey-footer__logo-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
}

.scrapey-footer__logo-wordmark {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--color-yellow);
  letter-spacing: -0.03em;
}

.scrapey-footer__tagline {
  font-size: var(--text-lg);
  font-weight: 600;
  color: #fff;
  margin-bottom: var(--space-3);
  line-height: 1.4;
}

.scrapey-footer__desc {
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.55);
  line-height: 1.7;
  margin-bottom: var(--space-6);
}

.scrapey-footer__social {
  display: flex;
  gap: var(--space-3);
}

.scrapey-footer__social-link {
  width: 44px;
  height: 44px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-xl);
  color: rgba(255,255,255,0.7);
  transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
}

.scrapey-footer__social-link:hover {
  background: var(--color-green);
  border-color: var(--color-green);
  color: #fff;
}

/* Col titles */
.scrapey-footer__col-title {
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: 700;
  color: #fff;
  margin-bottom: var(--space-5);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

/* Footer links */
.scrapey-footer__links {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.scrapey-footer__links a {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.6);
  transition: color var(--transition-fast), gap var(--transition-fast);
  min-height: 32px;
}

.scrapey-footer__links a i {
  font-size: var(--text-base);
  color: var(--color-green);
  flex-shrink: 0;
  transition: transform var(--transition-fast);
}

.scrapey-footer__links a:hover {
  color: var(--color-yellow);
  gap: var(--space-3);
}

.scrapey-footer__links a:hover i {
  transform: translateX(2px);
}

/* Contact list */
.scrapey-footer__contact-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.scrapey-footer__contact-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.6);
  line-height: 1.6;
}

.scrapey-footer__contact-item a {
  color: rgba(255,255,255,0.6);
  transition: color var(--transition-fast);
}

.scrapey-footer__contact-item a:hover {
  color: var(--color-yellow);
}

.scrapey-footer__contact-icon {
  width: 32px;
  height: 32px;
  background: rgba(22,163,74,0.15);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-base);
  color: var(--color-green);
  flex-shrink: 0;
  margin-top: 1px;
}

/* Bottom bar */
.scrapey-footer__bottom {
  border-top: 1px solid rgba(255,255,255,0.08);
  padding: var(--space-5) 0;
}

.scrapey-footer__bottom-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-4);
  justify-content: space-between;
}

.scrapey-footer__copy {
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.45);
}

.scrapey-footer__copy strong {
  color: rgba(255,255,255,0.7);
}

.scrapey-footer__bottom-links {
  display: flex;
  gap: var(--space-5);
}

.scrapey-footer__bottom-links a {
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.45);
  transition: color var(--transition-fast);
}

.scrapey-footer__bottom-links a:hover {
  color: rgba(255,255,255,0.8);
}

/* Language chips */
.scrapey-footer__lang {
  display: flex;
  gap: var(--space-2);
}

.scrapey-footer__lang-chip {
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  border: 1px solid rgba(255,255,255,0.2);
  font-size: var(--text-xs);
  font-weight: 600;
  color: rgba(255,255,255,0.55);
  background: transparent;
  cursor: pointer;
  min-height: 32px;
  transition:
    background var(--transition-fast),
    color var(--transition-fast),
    border-color var(--transition-fast);
}

.scrapey-footer__lang-chip:hover {
  border-color: var(--color-yellow);
  color: var(--color-yellow);
}

.scrapey-footer__lang-chip.is-active {
  background: #064E3B !important;
  border-color: #064E3B !important;
  color: #fff !important;
}

/* ── Footer: mobile (< 600px) ────────────────────────────────────────────── */
@media (max-width: 599px) {

  /* Compact top/bottom padding */
  .scrapey-footer__top {
    padding: 32px 0 24px !important;
  }
  .scrapey-footer__container {
    padding: 0 20px !important;
  }

  /* Single-column, tight gap */
  .scrapey-footer__grid {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
    text-align: left;
  }

  /* Logo: constrain image height */
  .scrapey-footer__logo-link {
    justify-content: flex-start;
    margin-bottom: 12px !important;
  }
  .scrapey-footer__logo-link img {
    max-height: 52px !important;
    width: auto !important;
  }
  .scrapey-footer__logo-wordmark {
    font-size: 1.4rem !important;
  }

  /* Tagline & desc smaller */
  .scrapey-footer__tagline {
    font-size: 1rem !important;
    margin-bottom: 8px !important;
  }
  .scrapey-footer__desc {
    font-size: 0.82rem !important;
    margin-bottom: 16px !important;
    line-height: 1.6 !important;
  }

  /* Social icons left-aligned */
  .scrapey-footer__social {
    justify-content: flex-start;
    gap: 10px !important;
  }
  .scrapey-footer__social-link {
    width: 40px !important;
    height: 40px !important;
    font-size: 1rem !important;
  }

  /* Column titles */
  .scrapey-footer__col-title {
    font-size: 0.75rem !important;
    margin-bottom: 12px !important;
    letter-spacing: 0.06em !important;
    text-align: left !important;
  }

  /* Links: tighter rows, left-aligned */
  .scrapey-footer__links {
    gap: 4px !important;
    align-items: flex-start !important;
  }
  .scrapey-footer__links a {
    display: flex !important;
    width: 100% !important;
    font-size: 0.85rem !important;
    min-height: 36px !important;
    justify-content: flex-start !important;
    text-align: left !important;
  }

  /* Contact list: left-aligned */
  .scrapey-footer__contact-list {
    gap: 12px !important;
    align-items: flex-start !important;
    text-align: left !important;
  }
  .scrapey-footer__contact-item {
    font-size: 0.82rem !important;
    gap: 10px !important;
    justify-content: flex-start !important;
    text-align: left !important;
  }
  .scrapey-footer__contact-icon {
    width: 28px !important;
    height: 28px !important;
    font-size: 0.85rem !important;
    flex-shrink: 0 !important;
  }

  /* Bottom bar: stack vertically */
  .scrapey-footer__bottom {
    padding: 16px 0 !important;
  }
  .scrapey-footer__bottom-inner {
    flex-direction: column !important;
    align-items: center !important;
    gap: 12px !important;
    text-align: center;
  }
  .scrapey-footer__copy {
    font-size: 0.75rem !important;
    order: 3;
  }
  .scrapey-footer__bottom-links {
    gap: 16px !important;
    order: 2;
  }
  .scrapey-footer__bottom-links a {
    font-size: 0.78rem !important;
  }
  .scrapey-footer__lang {
    order: 1;
    gap: 8px !important;
  }
  .scrapey-footer__lang-chip {
    padding: 5px 14px !important;
    font-size: 0.78rem !important;
    min-height: 34px !important;
  }
}

/* ── Footer: tablet (600px – 1023px) ─────────────────────────────────────── */
@media (min-width: 600px) and (max-width: 1023px) {
  .scrapey-footer__grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 32px !important;
  }
  .scrapey-footer__top {
    padding: 48px 0 36px !important;
  }
  .scrapey-footer__container {
    padding: 0 24px !important;
  }
  .scrapey-footer__logo-link img {
    max-height: 56px !important;
    width: auto !important;
  }
  .scrapey-footer__tagline {
    font-size: 1rem !important;
  }
  .scrapey-footer__bottom-inner {
    flex-wrap: wrap !important;
    gap: 12px !important;
  }
}

/* ── Footer: desktop (≥ 1024px) ─────────────────────────────────────────── */
@media (min-width: 1024px) {
  .scrapey-footer__grid {
    grid-template-columns: 2fr 1fr 1fr 1.5fr;
    gap: var(--space-12);
  }
  .scrapey-footer__container {
    padding: 0 var(--space-8);
  }
}


/* ============================================================================
   20. FLOATING WHATSAPP BUTTON
   ============================================================================ */

.scrapey-whatsapp-float {
  position: fixed;
  bottom: var(--space-6);
  right: var(--space-6);
  z-index: var(--z-float);
  width: 60px;
  height: 60px;
  background: #25D366;
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  box-shadow: 0 4px 20px rgba(37,211,102,0.45);
  transition:
    transform var(--transition-base),
    box-shadow var(--transition-base),
    background var(--transition-base);
  text-decoration: none;
}

.scrapey-whatsapp-float:hover {
  transform: scale(1.1) translateY(-3px);
  box-shadow: 0 8px 32px rgba(37,211,102,0.55);
  background: #1ebe58;
}

.scrapey-whatsapp-float:focus-visible {
  outline: 3px solid var(--color-yellow);
  outline-offset: 4px;
}

/* Tooltip */
.scrapey-whatsapp-float__tooltip {
  position: absolute;
  right: calc(100% + var(--space-3));
  top: 50%;
  transform: translateY(-50%);
  background: var(--color-charcoal);
  color: #fff;
  font-size: var(--text-xs);
  font-weight: 600;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition-fast);
}

.scrapey-whatsapp-float__tooltip::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 100%;
  transform: translateY(-50%);
  border: 5px solid transparent;
  border-left-color: var(--color-charcoal);
}

.scrapey-whatsapp-float:hover .scrapey-whatsapp-float__tooltip {
  opacity: 1;
}

/* Pulse animation ring */
.scrapey-whatsapp-float::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: #25D366;
  animation: wa-pulse 2.5s ease-out infinite;
  z-index: -1;
}

@keyframes wa-pulse {
  0%   { transform: scale(1);   opacity: 0.6; }
  100% { transform: scale(1.7); opacity: 0; }
}


/* ============================================================================
   21. RESPONSIVE — mobile-first, breakpoints at 768px and 1024px
   ============================================================================ */

/* --- 768px --- */
@media (min-width: 768px) {

  :root {
    --section-py-mobile: 44px;
  }

  /* Header already handled above */

  /* Rates */
  .rates-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  /* Steps */
  .steps-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  /* Testimonials */
  .testimonials-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  /* Impact */
  .impact-grid {
    grid-template-columns: repeat(4, 1fr);
  }

  /* Footer */
  .scrapey-footer__grid {
    grid-template-columns: 1fr 1fr;
  }

  /* CTA inner on tablet */
  .cta-inner {
    grid-template-columns: 1fr;
    max-width: 600px;
    margin: 0 auto;
  }
}

/* --- 1024px --- */
@media (min-width: 1024px) {

  :root {
    --section-py-mobile: var(--section-py-desktop);
  }

  /* Hero two-col */
  .hero-container {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-16);
  }

  /* Business two-col */
  .business-inner {
    grid-template-columns: 1fr 1fr;
  }

  /* CTA two-col */
  .cta-inner {
    grid-template-columns: 1fr 1fr;
    max-width: none;
    gap: var(--space-16);
  }

  /* Footer four-col */
  .scrapey-footer__grid {
    grid-template-columns: 2fr 1fr 1fr 1.5fr;
  }
}


/* ============================================================================
   22. AOS ANIMATION SUPPORT
   ============================================================================ */

/* AOS default overrides for performance */
[data-aos] {
  will-change: transform, opacity;
}

/* Ensure AOS doesn't break stacking */
[data-aos="fade-up"] {
  transform: translateY(24px);
}

[data-aos="fade-right"] {
  transform: translateX(-24px);
}

[data-aos="fade-left"] {
  transform: translateX(24px);
}


/* ============================================================================
   23. REDUCED MOTION
   ============================================================================ */

@media (prefers-reduced-motion: reduce) {

  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }

  .hero-blob {
    animation: none;
  }

  .hero-badge {
    animation: none;
  }

  .scrapey-whatsapp-float::before {
    animation: none;
  }

  [data-aos] {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}


/* ============================================================================
   24. VISUAL ENHANCEMENTS — More Attractive UI
   ============================================================================ */

/* ── WordPress admin bar offset ─────────────────────────────────────────── */
/* When logged in, WP admin bar is 32px tall (46px on small screens).      */
/* The fixed header must sit below it.                                       */
body.admin-bar .scrapey-header {
  top: 32px;
}
/* Hero: just add admin-bar height on top of the header clear */
body.admin-bar .hero-section {
  padding-top: calc(var(--header-h) + 32px);
}
@media screen and (max-width: 782px) {
  body.admin-bar .scrapey-header { top: 46px; }
  body.admin-bar .hero-section   { padding-top: calc(var(--header-h) + 46px); }
}
@media (min-width: 1024px) {
  body.admin-bar .hero-section {
    padding-top: calc(var(--header-h) + 32px);
  }
}

/* ── Section eyebrow labels ─────────────────────────────────────────────── */
.section-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: var(--color-mint);
  color: var(--color-forest);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-full);
  border: 1px solid rgba(22,163,74,0.20);
  margin-bottom: var(--space-5);
}
.section-eyebrow--dark {
  background: rgba(255,255,255,0.10);
  color: var(--color-yellow);
  border-color: rgba(255,255,255,0.15);
}
.section-eyebrow i { font-size: 14px; }

/* ── Hero: rich mesh gradient + particles ───────────────────────────────── */
.hero-section {
  background:
    radial-gradient(ellipse 900px 700px at 80% 20%, rgba(220,252,231,0.55) 0%, transparent 60%),
    radial-gradient(ellipse 600px 500px at 10% 80%, rgba(254,243,199,0.35) 0%, transparent 55%),
    radial-gradient(ellipse 400px 350px at 50% 50%, rgba(22,163,74,0.04) 0%, transparent 70%),
    var(--color-bone);
}

/* Gradient text on hero accent */
.hero-heading-accent {
  background: linear-gradient(135deg, var(--color-green) 0%, #059669 50%, var(--color-forest) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  position: relative;
}
.hero-heading-accent::after {
  content: '';
  position: absolute;
  bottom: -6px;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--color-yellow) 0%, #f59e0b 100%);
  border-radius: 3px;
}

/* Hero floating particles */
.hero-particles {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 0;
}
.hero-dot {
  position: absolute;
  border-radius: 50%;
  animation: dot-float linear infinite;
  opacity: 0;
}
.hero-dot--1  { width: 8px;  height: 8px;  background: var(--color-green);  top: 20%; left: 15%; animation-duration: 12s; animation-delay: 0s; }
.hero-dot--2  { width: 5px;  height: 5px;  background: var(--color-yellow); top: 60%; left: 8%;  animation-duration: 16s; animation-delay: 3s; }
.hero-dot--3  { width: 12px; height: 12px; background: var(--color-mint);   top: 35%; left: 40%; animation-duration: 10s; animation-delay: 1s; }
.hero-dot--4  { width: 6px;  height: 6px;  background: var(--color-green);  top: 75%; left: 55%; animation-duration: 14s; animation-delay: 5s; }
.hero-dot--5  { width: 9px;  height: 9px;  background: var(--color-yellow); top: 15%; left: 70%; animation-duration: 11s; animation-delay: 2s; }
.hero-dot--6  { width: 4px;  height: 4px;  background: var(--color-forest); top: 85%; left: 30%; animation-duration: 18s; animation-delay: 7s; }

@keyframes dot-float {
  0%   { transform: translateY(0) rotate(0);   opacity: 0; }
  10%  { opacity: 0.4; }
  90%  { opacity: 0.4; }
  100% { transform: translateY(-80px) rotate(360deg); opacity: 0; }
}

/* Hero phone: deeper glow */
.upi-phone {
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.1),
    0 40px 80px rgba(6,78,59,0.25),
    0 0 80px rgba(22,163,74,0.20),
    inset 0 0 0 1px rgba(255,255,255,0.04);
}

/* Hero section decorative ring */
.hero-deco-ring {
  position: absolute;
  width: 500px;
  height: 500px;
  border-radius: 50%;
  border: 1.5px solid rgba(22,163,74,0.10);
  top: 50%;
  right: -10%;
  transform: translateY(-50%);
  pointer-events: none;
  z-index: 0;
}
.hero-deco-ring::after {
  content: '';
  position: absolute;
  inset: 40px;
  border-radius: 50%;
  border: 1px solid rgba(250,204,21,0.12);
}

/* ── Rates: gradient border + category colors ───────────────────────────── */
.rates-section {
  background:
    radial-gradient(ellipse 700px 400px at 0% 100%, rgba(220,252,231,0.4) 0%, transparent 60%),
    var(--color-bone);
}

.rate-card {
  background: #fff;
  border: 1.5px solid var(--color-soft-grey);
  transition:
    box-shadow 0.3s ease,
    transform 0.3s ease,
    border-color 0.3s ease;
  position: relative;
}

.rate-card::before {
  content: '';
  position: absolute;
  inset: -1.5px;
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, var(--color-green), var(--color-yellow), var(--color-green));
  z-index: -1;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.rate-card:hover {
  border-color: transparent;
  box-shadow: 0 20px 56px rgba(6,78,59,0.16);
  transform: translateY(-6px);
}
.rate-card:hover::before { opacity: 1; }

/* Category icon colors */
.rate-card[data-category="paper"]   .rate-card__icon { background: #FEF3C7; color: #92400E; }
.rate-card[data-category="plastic"] .rate-card__icon { background: #E0F2FE; color: #0369A1; }
.rate-card[data-category="metal"]   .rate-card__icon { background: #FEE2E2; color: #B91C1C; }
.rate-card[data-category="ewaste"]  .rate-card__icon { background: #F3E8FF; color: #7E22CE; }

/* Rate pill upgrade */
.rate-pill {
  background: linear-gradient(135deg, var(--color-yellow) 0%, #f59e0b 100%);
  box-shadow: 0 2px 8px rgba(250,204,21,0.35);
}

/* ── Steps: connecting gradient line + richer cards ─────────────────────── */
.steps-section {
  background:
    radial-gradient(ellipse 800px 500px at 100% 0%, rgba(254,243,199,0.4) 0%, transparent 60%),
    var(--color-mint);
  position: relative;
}

.steps-grid {
  position: relative;
}

/* Connecting line between steps (desktop only) */
@media (min-width: 768px) {
  .steps-grid::after {
    content: '';
    position: absolute;
    top: 56px; /* align with step number center */
    left: calc(100% / 6);
    right: calc(100% / 6);
    height: 3px;
    background: linear-gradient(90deg, var(--color-yellow), var(--color-green), var(--color-yellow));
    z-index: 0;
    border-radius: 2px;
    opacity: 0.5;
  }
  .step-card { position: relative; z-index: 1; }
}

.step-card {
  border: 1px solid rgba(22,163,74,0.12);
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(8px);
}
.step-card:hover {
  border-color: rgba(22,163,74,0.30);
}

/* Step number gradient shadow */
.step-card__number {
  background: linear-gradient(135deg, var(--color-yellow) 0%, #fbbf24 100%);
  box-shadow:
    0 6px 20px rgba(250,204,21,0.45),
    0 2px 6px rgba(250,204,21,0.30);
  width: 64px;
  height: 64px;
  font-size: var(--text-3xl);
}

/* Step illustration area */
.step-card__illustration {
  background: linear-gradient(135deg, var(--color-bone) 0%, rgba(220,252,231,0.5) 100%);
  border: 1px solid rgba(22,163,74,0.08);
}

/* ── Compare table: card with glow + icon rows ──────────────────────────── */
.compare-section {
  background:
    radial-gradient(ellipse 600px 400px at 50% 100%, rgba(220,252,231,0.35) 0%, transparent 60%),
    var(--color-bone);
  padding-bottom: 60px !important;
}

/* Heading gradient fails on bone bg — force solid dark color */
.compare-section .display-l {
  background-image: none !important;
  -webkit-text-fill-color: var(--color-charcoal) !important;
  color: var(--color-charcoal) !important;
  animation: none !important;
}

.compare-table-wrap {
  border-radius: var(--radius-2xl);
  overflow: hidden;
  box-shadow: var(--shadow-xl);
  border: 1px solid var(--color-soft-grey);
}

.compare-table thead th {
  padding: var(--space-5) var(--space-6);
  font-size: var(--text-base);
}
.compare-table__col-label--scrapey {
  background: linear-gradient(135deg, var(--color-green), #059669);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-size: var(--text-lg);
}

/* Alternate row subtle colors */
.compare-table tbody tr:nth-child(odd) {
  background: rgba(250,250,247,1);
}
.compare-table tbody tr:nth-child(even) {
  background: rgba(220,252,231,0.25);
}
.compare-table tbody tr:hover {
  background: rgba(220,252,231,0.45);
}

/* ── Testimonials: large quote mark + gradient top ──────────────────────── */
.testimonials-section {
  background:
    radial-gradient(ellipse 700px 500px at 30% 50%, rgba(254,243,199,0.3) 0%, transparent 60%),
    var(--color-bone);
}

.testimonial-card {
  position: relative;
  overflow: visible;
  border-top: 4px solid transparent;
  background-clip: padding-box;
}
.testimonial-card::before {
  content: '';
  position: absolute;
  top: -4px;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--color-green), var(--color-yellow));
  border-radius: 4px 4px 0 0;
}

/* Giant quote mark */
.testimonial-card__quote-mark {
  font-family: Georgia, serif;
  font-size: 72px;
  line-height: 0.7;
  color: var(--color-mint);
  display: block;
  margin-bottom: var(--space-2);
  font-weight: 900;
  user-select: none;
  pointer-events: none;
}

/* Avatar gradient circles */
.testimonial-card__avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--color-green) 0%, var(--color-forest) 100%);
  color: #fff;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(22,163,74,0.35);
}
.testimonial-card:nth-child(2) .testimonial-card__avatar {
  background: linear-gradient(135deg, #7C3AED 0%, #4C1D95 100%);
  box-shadow: 0 4px 12px rgba(124,58,237,0.35);
}
.testimonial-card:nth-child(3) .testimonial-card__avatar {
  background: linear-gradient(135deg, #0369A1 0%, #1e3a5f 100%);
  box-shadow: 0 4px 12px rgba(3,105,161,0.35);
}

/* Star icons: gold */
.testimonial-card__stars i {
  color: #FBBF24;
}

/* ── Business section: richer Dark background ───────────────────────────── */
.business-section {
  background:
    radial-gradient(ellipse 800px 600px at 100% 50%, rgba(22,163,74,0.15) 0%, transparent 60%),
    radial-gradient(ellipse 500px 400px at 0% 80%, rgba(250,204,21,0.08) 0%, transparent 55%),
    var(--color-forest);
  position: relative;
  overflow: hidden;
}

/* Decorative grid dots pattern */
.business-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(255,255,255,0.06) 1px, transparent 1px);
  background-size: 28px 28px;
  pointer-events: none;
}

.business-section::after {
  content: '';
  position: absolute;
  bottom: -80px;
  right: -80px;
  width: 360px;
  height: 360px;
  border-radius: 50%;
  border: 60px solid rgba(250,204,21,0.06);
  pointer-events: none;
}

.business-stats-card {
  background: rgba(255,255,255,0.07);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  box-shadow: 0 8px 32px rgba(0,0,0,0.25);
}

.business-stats-item i {
  font-size: 28px;
  color: var(--color-yellow);
  background: rgba(250,204,21,0.12);
  padding: var(--space-3);
  border-radius: var(--radius-md);
}

.business-pillar {
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.12);
  backdrop-filter: blur(8px);
}
.business-pillar:hover {
  background: rgba(255,255,255,0.14);
  border-color: rgba(250,204,21,0.3);
}
.business-pillar i { color: var(--color-yellow); }

/* ── Impact stats: gradient numbers + icon glow ─────────────────────────── */
.impact-section {
  background:
    radial-gradient(ellipse 900px 600px at 50% 50%, rgba(220,252,231,0.45) 0%, transparent 65%),
    var(--color-bone);
}

.impact-card {
  border: 1px solid rgba(22,163,74,0.12);
  transition: box-shadow 0.3s ease, transform 0.3s ease, border-color 0.3s ease;
}
.impact-card:hover {
  border-color: rgba(22,163,74,0.30);
  box-shadow: 0 20px 56px rgba(6,78,59,0.16);
  transform: translateY(-6px);
}

.impact-card__icon {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--color-mint) 0%, rgba(22,163,74,0.15) 100%);
  border: 2px solid rgba(22,163,74,0.20);
  box-shadow: 0 4px 20px rgba(22,163,74,0.15);
  margin: 0 auto var(--space-4);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 32px;
  color: var(--color-forest);
}

.impact-card__number {
  font-size: clamp(2rem, 4vw, 3rem);
  background: linear-gradient(135deg, var(--color-forest) 0%, var(--color-green) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── FAQ: gradient left accent ──────────────────────────────────────────── */
.faq-section {
  background:
    radial-gradient(ellipse 600px 400px at 100% 0%, rgba(254,243,199,0.3) 0%, transparent 55%),
    var(--color-bone);
}

.faq-item {
  border: 1.5px solid var(--color-soft-grey);
  transition: border-color 0.25s ease, box-shadow 0.25s ease;
}
.faq-item.is-open {
  border-color: var(--color-green);
  box-shadow: 0 4px 24px rgba(22,163,74,0.10);
}

/* Open state: left accent bar */
.faq-item.is-open .faq-item__trigger {
  background: linear-gradient(90deg, rgba(220,252,231,0.6) 0%, rgba(220,252,231,0.1) 100%);
}

.faq-item__trigger:hover {
  background: rgba(220,252,231,0.4);
}

.faq-item__icon {
  color: var(--color-green);
  font-size: 20px;
  transition: transform 0.25s ease, color 0.25s ease;
}
.faq-item.is-open .faq-item__icon {
  transform: rotate(45deg);
  color: var(--color-forest);
}

/* ── CTA section: dramatic Green gradient + noise texture ────────────────── */
.cta-section {
  background:
    radial-gradient(ellipse 800px 600px at 20% 50%, rgba(5,150,105,0.8) 0%, transparent 60%),
    radial-gradient(ellipse 600px 400px at 80% 100%, rgba(250,204,21,0.15) 0%, transparent 50%),
    var(--color-green);
  position: relative;
  overflow: hidden;
}
.cta-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(255,255,255,0.05) 1px, transparent 1px);
  background-size: 24px 24px;
  pointer-events: none;
}

/* Decorative circle in CTA */
.cta-section::after {
  content: '';
  position: absolute;
  top: -100px;
  right: -100px;
  width: 400px;
  height: 400px;
  border-radius: 50%;
  border: 80px solid rgba(255,255,255,0.05);
  pointer-events: none;
}

.cta-heading {
  color: #fff !important;
}
.cta-body {
  color: rgba(255,255,255,0.8) !important;
}
.cta-hours {
  color: rgba(255,255,255,0.65) !important;
}

.cta-form-card {
  background: rgba(255,255,255,0.97);
  border: 1px solid rgba(255,255,255,0.5);
  box-shadow:
    0 32px 80px rgba(6,78,59,0.30),
    0 0 0 1px rgba(255,255,255,0.12) inset;
}

/* ── Header: glass effect when scrolled ─────────────────────────────────── */
.scrapey-header--scrolled {
  background: rgba(6,78,59,0.95);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

/* Header logo: subtle lift on hover */
.scrapey-header__logo a:hover img {
  filter: drop-shadow(0 2px 8px rgba(22,163,74,0.3));
}

/* ── Footer logo ─────────────────────────────────────────────────────────── */
.scrapey-footer__logo-wrap {
  display: flex;
  align-items: center;
  margin-bottom: var(--space-4);
}
.scrapey-footer__logo-wrap a {
  display: flex;
  align-items: center;
  text-decoration: none;
  transition: opacity var(--transition-fast);
}
.scrapey-footer__logo-wrap a:hover { opacity: 0.80; }
.scrapey-footer__logo-wrap img,
.scrapey-footer__logo-wrap .custom-logo {
  height: 90px !important;
  width: auto !important;
  max-width: 240px !important;
  max-height: none !important;
  display: block !important;
  object-fit: contain !important;
  /* Invert to white so logo shows on the dark Deep Forest background */
  filter: brightness(0) invert(1) !important;
}
/* Fallback text on dark bg */
.scrapey-footer__logo-wrap .scrapey-footer__logo-wordmark {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--color-yellow);
  letter-spacing: -0.03em;
  text-decoration: none;
}

/* ── Footer: subtle gradient ─────────────────────────────────────────────── */
.scrapey-footer {
  background:
    radial-gradient(ellipse 700px 500px at 100% 0%, rgba(22,163,74,0.08) 0%, transparent 50%),
    var(--color-forest);
}

/* Footer social icons hover */
.scrapey-footer__social-link:hover {
  background: var(--color-yellow);
  color: var(--color-forest);
  transform: translateY(-3px);
  box-shadow: 0 6px 16px rgba(250,204,21,0.4);
}

/* ── WhatsApp float: bigger glow ─────────────────────────────────────────── */
.scrapey-whatsapp-float {
  box-shadow:
    0 8px 32px rgba(37,211,102,0.50),
    0 2px 8px rgba(37,211,102,0.30);
}

/* ── Reduced motion: disable new animations ──────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .hero-dot { animation: none !important; opacity: 0.2; }
  .hero-deco-ring { display: none; }
}

/* ============================================================================
   25. ADVANCED ANIMATIONS & INTERACTIONS
   ============================================================================ */

/* ── Scroll progress bar ────────────────────────────────────────────────── */
#scrapey-progress-bar {
  position: fixed;
  top: 0;
  left: 0;
  height: 3px;
  width: 0%;
  background: linear-gradient(90deg, #16A34A 0%, #FACC15 50%, #16A34A 100%);
  background-size: 200% 100%;
  z-index: 9999;
  transition: width 0.1s linear;
  animation: progress-shimmer 2s linear infinite;
}
@keyframes progress-shimmer {
  0%   { background-position: 200% center; }
  100% { background-position: -200% center; }
}

/* ── Animated gradient hero background ─────────────────────────────────── */
.hero-section {
  background-size: 400% 400% !important;
  animation: hero-gradient-shift 12s ease infinite;
}
@keyframes hero-gradient-shift {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

/* ── Typewriter cursor ──────────────────────────────────────────────────── */
.typewriter-cursor {
  display: inline-block;
  width: 3px;
  height: 0.85em;
  background: #16A34A;
  margin-left: 4px;
  vertical-align: middle;
  border-radius: 2px;
  animation: cursor-blink 0.9s step-end infinite;
}
@keyframes cursor-blink {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0; }
}

/* ── Rate ticker / marquee ──────────────────────────────────────────────── */
.rate-ticker {
  background: #064E3B;
  padding: 14px 0;
  overflow: hidden;
  position: relative;
  z-index: 1;
}
.rate-ticker::before,
.rate-ticker::after {
  content: '';
  position: absolute;
  top: 0; bottom: 0;
  width: 80px;
  z-index: 2;
  pointer-events: none;
}
.rate-ticker::before { left: 0;  background: linear-gradient(90deg, #064E3B, transparent); }
.rate-ticker::after  { right: 0; background: linear-gradient(-90deg, #064E3B, transparent); }

.rate-ticker__track {
  display: flex;
  gap: 0;
  width: max-content;
  animation: ticker-scroll 28s linear infinite;
}
.rate-ticker__track:hover { animation-play-state: paused; }
@keyframes ticker-scroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.rate-ticker__item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 0 32px;
  font-size: 14px;
  font-weight: 600;
  color: rgba(255,255,255,0.85);
  white-space: nowrap;
  border-right: 1px solid rgba(255,255,255,0.10);
  font-family: 'Inter', sans-serif;
}
.rate-ticker__item-price {
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700;
  color: #FACC15;
  font-size: 15px;
}
.rate-ticker__item-emoji { font-size: 16px; }

/* ── Wave SVG dividers ──────────────────────────────────────────────────── */
.wave-divider {
  display: block;
  width: 100%;
  overflow: hidden;
  line-height: 0;
  margin: 0;
  padding: 0;
}
.wave-divider svg {
  display: block;
  width: 100%;
  height: auto;
}

/* ── Card shimmer sweep on hover ────────────────────────────────────────── */
.rate-card,
.step-card,
.testimonial-card,
.impact-card {
  position: relative;
  overflow: hidden;
}
.rate-card::after,
.step-card::after,
.testimonial-card::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 60%;
  height: 100%;
  background: linear-gradient(
    105deg,
    transparent 20%,
    rgba(255,255,255,0.35) 50%,
    transparent 80%
  );
  transform: skewX(-15deg);
  transition: left 0.6s ease;
  pointer-events: none;
  z-index: 2;
}
.rate-card:hover::after,
.step-card:hover::after,
.testimonial-card:hover::after {
  left: 140%;
}

/* ── Glow pulse on primary CTA ──────────────────────────────────────────── */
.scrapey-btn--primary {
  position: relative;
  overflow: hidden;
}
.scrapey-btn--primary::before {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: inherit;
  background: linear-gradient(135deg, #16A34A, #FACC15, #16A34A);
  background-size: 300% 300%;
  z-index: -1;
  opacity: 0;
  transition: opacity 0.3s ease;
  animation: btn-glow-rotate 3s linear infinite;
}
.scrapey-btn--primary:hover::before { opacity: 1; }
@keyframes btn-glow-rotate {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

/* Ripple on click */
.btn-ripple {
  position: absolute;
  border-radius: 50%;
  background: rgba(255,255,255,0.35);
  transform: scale(0);
  animation: ripple-out 0.55s ease-out forwards;
  pointer-events: none;
}
@keyframes ripple-out {
  to { transform: scale(4); opacity: 0; }
}

/* ── Stagger animation delays for grids ─────────────────────────────────── */
.rate-card:nth-child(1) { animation-delay: 0.05s; }
.rate-card:nth-child(2) { animation-delay: 0.10s; }
.rate-card:nth-child(3) { animation-delay: 0.15s; }
.rate-card:nth-child(4) { animation-delay: 0.20s; }
.rate-card:nth-child(5) { animation-delay: 0.25s; }
.rate-card:nth-child(6) { animation-delay: 0.30s; }
.rate-card:nth-child(7) { animation-delay: 0.35s; }
.rate-card:nth-child(8) { animation-delay: 0.40s; }

/* ── Card 3D tilt (applied via JS, CSS supports it) ────────────────────── */
.tilt-card {
  transform-style: preserve-3d;
  transform: perspective(1000px) rotateX(0deg) rotateY(0deg);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
  will-change: transform;
}
.tilt-card:hover {
  box-shadow: 0 24px 60px rgba(6,78,59,0.20) !important;
}
.tilt-card__shine {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(
    circle at var(--shine-x, 50%) var(--shine-y, 50%),
    rgba(255,255,255,0.18) 0%,
    transparent 65%
  );
  pointer-events: none;
  z-index: 3;
  opacity: 0;
  transition: opacity 0.3s ease;
}
.tilt-card:hover .tilt-card__shine { opacity: 1; }

/* ── Animated entrance for sections ─────────────────────────────────────── */
.reveal-on-scroll {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity 0.65s cubic-bezier(0.22,1,0.36,1),
              transform 0.65s cubic-bezier(0.22,1,0.36,1);
}
.reveal-on-scroll.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ── Impact ring animation ──────────────────────────────────────────────── */
.impact-card__icon {
  position: relative;
}
.impact-card__icon::before {
  content: '';
  position: absolute;
  inset: -6px;
  border-radius: 50%;
  border: 2px solid rgba(22,163,74,0.25);
  animation: ring-pulse 2.5s ease-out infinite;
}
@keyframes ring-pulse {
  0%   { transform: scale(0.85); opacity: 0.7; }
  70%  { transform: scale(1.15); opacity: 0; }
  100% { transform: scale(1.15); opacity: 0; }
}

/* ── Floating hero visual ────────────────────────────────────────────────── */
.hero-visual {
  animation: hero-float 5s ease-in-out infinite;
  z-index: 3;
}
@keyframes hero-float {
  0%, 100% { transform: translateY(0px); }
  50%       { transform: translateY(-16px); }
}

/* ── Animated badge entries ──────────────────────────────────────────────── */
.hero-badge--pickup {
  animation: badge-entrance-right 0.7s 1s cubic-bezier(0.34,1.56,0.64,1) both,
             badge-float 3.5s 1.7s ease-in-out infinite alternate;
}
.hero-badge--eco {
  animation: badge-entrance-left 0.7s 1.4s cubic-bezier(0.34,1.56,0.64,1) both,
             badge-float 4s 2.1s ease-in-out infinite alternate-reverse;
}
@keyframes badge-entrance-right {
  from { opacity: 0; transform: translateX(30px) scale(0.8); }
  to   { opacity: 1; transform: translateX(0) scale(1); }
}
@keyframes badge-entrance-left {
  from { opacity: 0; transform: translateX(-30px) scale(0.8); }
  to   { opacity: 1; transform: translateX(0) scale(1); }
}
@keyframes badge-float {
  from { transform: translateY(0); }
  to   { transform: translateY(-8px); }
}

/* ── Animated mesh gradient blobs ────────────────────────────────────────── */
.hero-blob {
  animation: blob-morph 18s ease-in-out infinite;
}
@keyframes blob-morph {
  0%   { border-radius: 40% 60% 55% 45% / 45% 40% 60% 55%; transform: translate(0,0) scale(1); }
  25%  { border-radius: 60% 40% 45% 55% / 55% 60% 40% 45%; transform: translate(-20px,15px) scale(1.04); }
  50%  { border-radius: 45% 55% 60% 40% / 40% 55% 45% 60%; transform: translate(10px,-20px) scale(0.97); }
  75%  { border-radius: 55% 45% 40% 60% / 60% 40% 55% 45%; transform: translate(-15px,5px) scale(1.06); }
  100% { border-radius: 40% 60% 55% 45% / 45% 40% 60% 55%; transform: translate(0,0) scale(1); }
}

/* ── Step card connector animated line ──────────────────────────────────── */
@media (min-width: 768px) {
  .steps-grid::after {
    background: linear-gradient(90deg, #FACC15 0%, #16A34A 50%, #FACC15 100%);
    background-size: 200% 100%;
    animation: line-flow 3s linear infinite;
  }
}
@keyframes line-flow {
  0%   { background-position: 200% center; }
  100% { background-position: -200% center; }
}

/* ── Scroll-to-top button ────────────────────────────────────────────────── */
#scroll-top-btn {
  position: fixed;
  bottom: 100px;
  right: 24px;
  width: 48px;
  height: 48px;
  background: #064E3B;
  color: #fff;
  border-radius: 50%;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  z-index: 190;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.3s ease, transform 0.3s ease, background 0.2s ease;
  box-shadow: 0 4px 20px rgba(6,78,59,0.35);
}
#scroll-top-btn.is-visible {
  opacity: 1;
  transform: translateY(0);
}
#scroll-top-btn:hover {
  background: #16A34A;
  box-shadow: 0 6px 28px rgba(22,163,74,0.45);
  transform: translateY(-3px);
}

/* ── Confetti canvas ─────────────────────────────────────────────────────── */
#confetti-canvas {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9998;
}

/* ── Magnetic button wrapper ─────────────────────────────────────────────── */
.magnetic-btn-wrap {
  display: inline-block;
  position: relative;
}

/* ── Animated compare table rows ─────────────────────────────────────────── */
.compare-table tbody tr {
  transition: background 0.2s ease, transform 0.2s ease;
}
.compare-table tbody tr:hover {
  transform: scale(1.01);
  z-index: 1;
  position: relative;
}

/* ── Testimonial card stagger ────────────────────────────────────────────── */
.testimonial-card:nth-child(1) { transition-delay: 0s; }
.testimonial-card:nth-child(2) { transition-delay: 0.1s; }
.testimonial-card:nth-child(3) { transition-delay: 0.2s; }

/* ── UPI card animation enhanced ─────────────────────────────────────────── */
.upi-card {
  animation: upi-slide-in 0.7s 0.4s cubic-bezier(0.34,1.56,0.64,1) both;
}
@keyframes upi-slide-in {
  from { transform: translateY(30px) scale(0.9); opacity: 0; }
  to   { transform: translateY(0) scale(1); opacity: 1; }
}
.upi-card__amount {
  animation: amount-pop 0.5s 1.1s cubic-bezier(0.34,1.56,0.64,1) both;
}
@keyframes amount-pop {
  from { transform: scale(0.6); opacity: 0; }
  to   { transform: scale(1); opacity: 1; }
}

/* ── Section heading gradient animation ──────────────────────────────────── */
.display-xl,
.display-l {
  background-image: linear-gradient(135deg, #064E3B 0%, #16A34A 50%, #064E3B 100%);
  background-size: 200% auto;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: heading-gradient 6s linear infinite;
}
/* Only for non-accent headings: dark backgrounds need white */
.business-section .display-l,
.cta-section .display-l,
.cta-heading {
  background-image: none !important;
  -webkit-text-fill-color: #fff !important;
  animation: none !important;
}
@keyframes heading-gradient {
  0%   { background-position: 0% center; }
  100% { background-position: 200% center; }
}
/* Hero heading special: keep the accent green */
.hero-heading-accent {
  background-image: linear-gradient(135deg, #16A34A 0%, #059669 40%, #FACC15 100%);
  background-size: 300% auto;
  animation: hero-accent-gradient 4s ease infinite alternate;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
@keyframes hero-accent-gradient {
  0%   { background-position: 0% center; }
  100% { background-position: 100% center; }
}

/* ── Reduced motion: disable all new animations ──────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .hero-section { animation: none !important; }
  .rate-ticker__track { animation: none !important; }
  .hero-visual { animation: none !important; }
  .hero-badge--pickup,
  .hero-badge--eco { animation: none !important; opacity: 1; }
  .hero-blob { animation: none !important; }
  .display-xl, .display-l { animation: none !important; }
  .hero-heading-accent { animation: none !important; }
  .steps-grid::after { animation: none !important; }
  .impact-card__icon::before { animation: none !important; }
  #scrapey-progress-bar { transition: none !important; }
}

/* ============================================================================
   IMAGE ENHANCEMENTS
   Hero photo badge, step photos, gallery, avatar photos
   ============================================================================ */

/* ── Hero photo badge ───────────────────────────────────────────────────── */
.hero-photo-badge {
  position: absolute;
  bottom: -20px;
  left: -60px;
  width: 200px;
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-xl);
  border: 3px solid #fff;
  animation: float-badge 4s ease-in-out infinite alternate;
  z-index: 1;
}

@keyframes float-badge {
  from { transform: translateY(0) rotate(-2deg); }
  to   { transform: translateY(-10px) rotate(1deg); }
}

.hero-photo-badge__img {
  width: 100%;
  height: 130px;
  object-fit: cover;
  display: block;
}

.hero-photo-badge__overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: linear-gradient(transparent, rgba(6,78,59,0.85));
  color: #fff;
  padding: var(--space-2) var(--space-3);
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-xs);
  font-weight: 600;
}

.hero-photo-badge__overlay i {
  font-size: 1rem;
  color: var(--color-yellow);
}

/* ── Step photo images ──────────────────────────────────────────────────── */
.step-card__photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--radius-lg);
  transition: transform var(--transition-slow);
}

.step-card:hover .step-card__photo {
  transform: scale(1.04);
}

.step-card__icon-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.step-card__icon-placeholder i {
  font-size: 5rem;
  color: rgba(255,255,255,.25);
}

/* ── Testimonial avatar photos ──────────────────────────────────────────── */
.testimonial-card__avatar--photo {
  object-fit: cover;
  border: 2px solid var(--color-mint);
}

/* ── Gallery section ────────────────────────────────────────────────────── */
.gallery-section {
  background: var(--color-bone);
}

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: auto auto;
  gap: var(--space-4);
}

.gallery-item--wide {
  grid-column: 1 / -1;
}

.gallery-item {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  background: var(--color-charcoal);
  aspect-ratio: 4 / 3;
}

.gallery-item--wide {
  aspect-ratio: 16 / 7;
}

.gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--transition-slow);
}

.gallery-item:hover img {
  transform: scale(1.06);
}

.gallery-item__label {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: linear-gradient(transparent, rgba(6,78,59,0.9));
  color: #fff;
  padding: var(--space-4) var(--space-4) var(--space-3);
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  font-weight: 600;
  opacity: 0;
  transform: translateY(8px);
  transition:
    opacity var(--transition-base),
    transform var(--transition-base);
}

.gallery-item:hover .gallery-item__label {
  opacity: 1;
  transform: translateY(0);
}

.gallery-item__label i {
  font-size: 1.1rem;
  color: var(--color-yellow);
  flex-shrink: 0;
}

/* Responsive gallery */
@media (max-width: 768px) {
  .gallery-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .gallery-item--wide {
    grid-column: 1 / -1;
    aspect-ratio: 16 / 9;
  }
  .gallery-item__label {
    opacity: 1;
    transform: translateY(0);
  }
  .hero-photo-badge {
    display: none;
  }
}

@media (max-width: 480px) {
  .gallery-grid {
    grid-template-columns: 1fr;
  }
}

/* ============================================================================
   VISUAL REDESIGN ENHANCEMENTS
   Comprehensive upgrade: hero, steps, gallery, rates, testimonials,
   comparison, impact section — all sections elevated.
   ============================================================================ */


/* ==========================================================================
   HERO SECTION — Full-bleed photo background, diagonal split, glow
   ========================================================================== */

/* Override base hero to use full-bleed photo + dark overlay */
.hero-section {
  min-height: 90vh !important;
  align-items: flex-start;
  background:
    linear-gradient(
      105deg,
      rgba(6,78,59,0.92)  0%,
      rgba(6,78,59,0.82)  38%,
      rgba(6,78,59,0.35)  65%,
      rgba(6,78,59,0.10) 100%
    ),
    url('/wp-content/uploads/scrapey-gallery/scrap-yard.jpg') center center / cover no-repeat !important;
  position: relative;
  overflow: visible !important;
}

/* Hide the CSS blob — photo background replaces it */
.hero-section .hero-blob {
  display: none;
}

/* Diagonal decorative split line */
.hero-section::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    108deg,
    transparent 0%,
    transparent 52%,
    rgba(220,252,231,0.03) 52%,
    rgba(220,252,231,0.06) 100%
  );
  pointer-events: none;
  z-index: 0;
}

/* Particles stay on top */
.hero-particles { z-index: 2; }
.hero-container  { z-index: 2; }
.hero-deco-ring  { z-index: 1; }

/* Hero text needs white on the dark left panel */
.hero-copy .display-xl,
.hero-copy .hero-heading {
  background-image: none !important;
  -webkit-text-fill-color: #fff !important;
  animation: none !important;
  color: #fff !important;
}

.hero-copy .hero-heading-accent {
  -webkit-text-fill-color: transparent !important;
  background-image: linear-gradient(135deg, #FACC15 0%, #16A34A 60%) !important;
  background-clip: text !important;
  -webkit-background-clip: text !important;
  animation: hero-accent-gradient 4s ease infinite alternate !important;
}

.hero-copy .hero-subhead {
  color: rgba(255,255,255,0.82) !important;
}

.hero-trust-strip {
  background: rgba(255,255,255,0.12) !important;
  border-color: rgba(255,255,255,0.22) !important;
  color: #fff !important;
}
.hero-trust-divider { color: rgba(255,255,255,0.45) !important; }

.hero-link {
  color: var(--color-yellow) !important;
}
.hero-link:hover {
  color: #fff !important;
}

/* Pulsing green glow behind the phone mockup */
.hero-visual::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 320px;
  height: 320px;
  background: radial-gradient(ellipse, rgba(22,163,74,0.38) 0%, transparent 70%);
  border-radius: 50%;
  animation: phone-glow-pulse 3s ease-in-out infinite;
  pointer-events: none;
  z-index: 0;
}

@keyframes phone-glow-pulse {
  0%, 100% { opacity: 0.6; transform: translate(-50%,-50%) scale(1);   }
  50%       { opacity: 1;   transform: translate(-50%,-50%) scale(1.15); }
}

/* Floating badges — larger, more prominent */
.hero-badge {
  font-size: var(--text-sm) !important;
  padding: var(--space-3) var(--space-5) !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.22) !important;
  z-index: 10;
}
.hero-badge i { font-size: 1.1rem; }

.hero-badge--pickup {
  background: #fff !important;
  color: var(--color-forest) !important;
}
.hero-badge--eco {
  background: var(--color-forest) !important;
  color: var(--color-yellow) !important;
  border: 1px solid rgba(250,204,21,0.3);
}

/* Photo badge — keep visible but lift it */
.hero-photo-badge {
  border: 3px solid rgba(255,255,255,0.85) !important;
  box-shadow: 0 12px 40px rgba(0,0,0,0.3) !important;
}


/* ==========================================================================
   HOW IT WORKS — Photo-background tall cards with gradient overlay
   ========================================================================== */

.steps-section {
  background: var(--color-mint);
}

.steps-grid {
  gap: var(--space-6) !important;
}

/* Taller cards with photo as full background */
.step-card {
  position: relative !important;
  min-height: 380px !important;
  padding: 0 !important;
  overflow: hidden !important;
  border-radius: var(--radius-xl) !important;
  background: var(--color-charcoal) !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-end !important;
  box-shadow: 0 12px 40px rgba(6,78,59,0.18), var(--shadow-lg) !important;
  gap: 0 !important;
  transition: box-shadow 0.35s ease, transform 0.35s ease !important;
}

.step-card:hover {
  box-shadow: 0 20px 60px rgba(6,78,59,0.28) !important;
  transform: translateY(-8px) !important;
}

/* The photo fills the full card */
.step-card__illustration {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  background: none !important;
  border-radius: 0 !important;
  z-index: 0;
}

.step-card__photo {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  border-radius: 0 !important;
  transition: transform 0.6s ease !important;
  display: block !important;
}

.step-card:hover .step-card__photo {
  transform: scale(1.08) !important;
}

/* Gradient overlay at bottom for readability */
.step-card__illustration::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(6,78,59,0.05) 0%,
    rgba(6,78,59,0.25) 35%,
    rgba(6,78,59,0.85) 70%,
    rgba(4,50,30,0.97) 100%
  );
  z-index: 1;
}

/* Text content sits above overlay */
.step-card__number {
  position: absolute !important;
  top: var(--space-5) !important;
  left: var(--space-5) !important;
  width: 64px !important;
  height: 64px !important;
  font-size: var(--text-3xl) !important;
  background: var(--color-yellow) !important;
  color: var(--color-charcoal) !important;
  box-shadow: 0 4px 16px rgba(250,204,21,0.5) !important;
  z-index: 10;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.step-card__title {
  position: relative;
  z-index: 10;
  color: #fff !important;
  font-size: var(--text-2xl) !important;
  padding: 0 var(--space-6);
  margin-bottom: var(--space-2);
  text-shadow: 0 2px 8px rgba(0,0,0,0.3);
}

.step-card__desc {
  position: relative;
  z-index: 10;
  color: rgba(255,255,255,0.82) !important;
  padding: 0 var(--space-6) var(--space-6) !important;
  font-size: var(--text-sm) !important;
  line-height: 1.6 !important;
}

/* Large decorative step number watermark */
.step-card::before {
  content: attr(data-step);
  position: absolute;
  bottom: -10px;
  right: 12px;
  font-family: var(--font-number);
  font-size: 9rem;
  font-weight: 900;
  color: rgba(255,255,255,0.04);
  line-height: 1;
  pointer-events: none;
  z-index: 5;
  letter-spacing: -0.05em;
}

@media (min-width: 768px) {
  .steps-grid {
    grid-template-columns: repeat(3, 1fr) !important;
  }
  .step-card {
    min-height: 400px !important;
  }
}

@media (min-width: 1024px) {
  .step-card {
    min-height: 440px !important;
  }
}


/* ==========================================================================
   GALLERY — Masonry-inspired, hover overlays, "View all" CTA
   ========================================================================== */

.gallery-section {
  background: var(--color-bone);
}

/* Enhanced gallery grid — masonry-inspired 3-col layout */
.gallery-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  grid-template-rows: auto auto !important;
  gap: var(--space-4) !important;
}

/* Wide top image spans all 3 columns */
.gallery-item--wide {
  grid-column: 1 / -1 !important;
  aspect-ratio: 21 / 8 !important;
}

/* Individual items */
.gallery-item {
  border-radius: var(--radius-2xl) !important;
  overflow: hidden !important;
  box-shadow: 0 6px 24px rgba(31,41,55,0.12), 0 2px 6px rgba(31,41,55,0.06) !important;
  transition: box-shadow 0.35s ease, transform 0.35s ease !important;
  aspect-ratio: 4 / 3 !important;
}

.gallery-item:hover {
  box-shadow: 0 16px 48px rgba(6,78,59,0.2) !important;
  transform: translateY(-4px) scale(1.01) !important;
}

/* Image zoom on hover */
.gallery-item img {
  transition: transform 0.6s cubic-bezier(0.25,0.46,0.45,0.94) !important;
}

.gallery-item:hover img {
  transform: scale(1.08) !important;
}

/* Label slides up from bottom on hover */
.gallery-item__label {
  background: linear-gradient(transparent, rgba(4,50,30,0.95)) !important;
  padding: var(--space-8) var(--space-5) var(--space-4) !important;
  font-size: var(--text-base) !important;
  opacity: 0;
  transform: translateY(100%) !important;
  transition: opacity 0.3s ease, transform 0.35s cubic-bezier(0.25,0.46,0.45,0.94) !important;
}

.gallery-item:hover .gallery-item__label {
  opacity: 1 !important;
  transform: translateY(0) !important;
}

/* Always show label on touch devices */
@media (hover: none) {
  .gallery-item__label {
    opacity: 1 !important;
    transform: translateY(0) !important;
  }
}

/* Gallery "View all" CTA */
.gallery-cta-row {
  text-align: center;
  margin-top: var(--space-10);
  margin-bottom: var(--space-4);
}

.gallery-view-all {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-10);
  background: transparent;
  border: 2px solid var(--color-green);
  color: var(--color-green);
  font-weight: 600;
  font-size: var(--text-base);
  border-radius: var(--radius-full);
  letter-spacing: 0.02em;
  transition: background 0.25s ease, color 0.25s ease, box-shadow 0.25s ease, gap 0.15s ease;
}

.gallery-view-all:hover {
  background: var(--color-green);
  color: #fff;
  box-shadow: var(--shadow-green);
  gap: var(--space-3);
}

.gallery-view-all i {
  font-size: 1rem;
  transition: transform 0.2s ease;
}

.gallery-view-all:hover i {
  transform: translateX(3px);
}

@media (max-width: 768px) {
  .gallery-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  .gallery-item--wide {
    grid-column: 1 / -1 !important;
    aspect-ratio: 16 / 7 !important;
  }
  .gallery-item__label {
    opacity: 1 !important;
    transform: translateY(0) !important;
  }
}

@media (max-width: 480px) {
  .gallery-grid {
    grid-template-columns: 1fr !important;
  }
}


/* ==========================================================================
   RATES SECTION — Gradient-border cards, bigger price numbers
   ========================================================================== */

.rates-section {
  background: var(--color-bone);
  position: relative;
}

/* Subtle dot-grid texture background */
.rates-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(22,163,74,0.07) 1px, transparent 1px);
  background-size: 28px 28px;
  pointer-events: none;
  z-index: 0;
}

.rates-section .scrapey-container {
  position: relative;
  z-index: 1;
}

/* Rate card — gradient border via pseudo-element */
.rate-card {
  background: #fff !important;
  border-radius: var(--radius-xl) !important;
  box-shadow: 0 4px 20px rgba(31,41,55,0.08), 0 1px 4px rgba(31,41,55,0.05) !important;
  transition: box-shadow 0.3s ease, transform 0.3s ease !important;
  padding: var(--space-7) var(--space-6) !important;
  position: relative !important;
  isolation: isolate;
}

/* Gradient border using ::before (override existing top-bar) */
.rate-card::before {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  border-radius: var(--radius-xl) !important;
  padding: 2px !important;
  background: linear-gradient(135deg, var(--color-green), var(--color-yellow)) !important;
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0) !important;
  -webkit-mask-composite: xor !important;
  mask-composite: exclude !important;
  opacity: 0 !important;
  transition: opacity 0.3s ease !important;
  transform: none !important;
  height: auto !important;
}

.rate-card:hover::before {
  opacity: 1 !important;
  transform: none !important;
}

.rate-card:hover {
  box-shadow: 0 12px 40px rgba(6,78,59,0.16), 0 4px 12px rgba(22,163,74,0.12) !important;
  transform: translateY(-6px) !important;
}

/* Bigger price number */
.rate-card .rate-pill__price {
  font-size: var(--text-3xl) !important;
  font-weight: 800 !important;
  letter-spacing: -0.03em;
  color: var(--color-forest) !important;
}

.rate-card .rate-pill {
  background: linear-gradient(135deg, rgba(250,204,21,0.25), rgba(250,204,21,0.12)) !important;
  border: 1.5px solid rgba(250,204,21,0.5) !important;
  padding: var(--space-2) var(--space-5) !important;
}

.rate-card .rate-pill__unit {
  color: var(--color-stone) !important;
  font-size: var(--text-sm) !important;
}

/* Slightly larger icon */
.rate-card .rate-card__icon {
  width: 56px !important;
  height: 56px !important;
  font-size: 28px !important;
  background: linear-gradient(135deg, var(--color-mint), rgba(220,252,231,0.5)) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: 0 2px 8px rgba(22,163,74,0.15) !important;
}

.rate-card .rate-card__name {
  font-size: var(--text-lg) !important;
  font-weight: 700 !important;
}


/* ==========================================================================
   TESTIMONIALS — Light-green BG, decorative quotes, horizontal card layout
   ========================================================================== */

.testimonials-section {
  background: linear-gradient(180deg, var(--color-mint) 0%, rgba(220,252,231,0.4) 100%) !important;
}

.testimonials-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

.testimonial-card {
  background: #fff !important;
  border-radius: var(--radius-2xl) !important;
  padding: var(--space-8) var(--space-8) var(--space-7) !important;
  box-shadow: 0 6px 28px rgba(6,78,59,0.10) !important;
  border: 1px solid rgba(22,163,74,0.1);
  position: relative;
  overflow: hidden;
  transition: box-shadow 0.3s ease, transform 0.3s ease, border-color 0.3s ease !important;
}

.testimonial-card:hover {
  box-shadow: 0 16px 52px rgba(6,78,59,0.18) !important;
  transform: translateY(-5px) !important;
  border-color: rgba(22,163,74,0.25);
}

/* Large decorative opening quote */
.testimonial-card__quote-mark {
  position: absolute !important;
  top: 12px !important;
  left: 20px !important;
  font-size: 6rem !important;
  line-height: 1 !important;
  color: var(--color-mint) !important;
  font-family: Georgia, 'Times New Roman', serif !important;
  pointer-events: none;
  z-index: 0;
  display: block !important;
}

/* Inline quote mark in blockquote — hide since we have the absolute one */
.testimonial-card__quote::before {
  display: none !important;
}

.testimonial-card__quote {
  font-size: var(--text-base) !important;
  line-height: 1.8 !important;
  color: var(--color-charcoal) !important;
  font-style: italic !important;
  position: relative;
  z-index: 1;
  padding-top: var(--space-8);
}

.testimonial-card__stars {
  color: var(--color-yellow) !important;
  font-size: var(--text-xl) !important;
  gap: 2px !important;
  position: relative;
  z-index: 1;
}

.testimonial-card__footer {
  background: var(--color-bone);
  border-radius: var(--radius-lg);
  padding: var(--space-4) !important;
  border: none !important;
  margin-top: var(--space-2);
}

.testimonial-card__avatar--photo {
  width: 52px !important;
  height: 52px !important;
  border: 3px solid var(--color-mint) !important;
  box-shadow: 0 3px 12px rgba(22,163,74,0.2) !important;
}

.testimonial-card__name {
  font-size: var(--text-base) !important;
  font-weight: 700 !important;
}

/* Desktop: horizontal layout */
@media (min-width: 768px) {
  .testimonials-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-6);
  }
}


/* ==========================================================================
   COMPARISON TABLE — Green gradient header, pill badges, row highlight
   ========================================================================== */

.compare-section {
  background: var(--color-bone);
}

.compare-table-wrap {
  border-radius: var(--radius-2xl) !important;
  box-shadow: 0 10px 40px rgba(31,41,55,0.12) !important;
  overflow: hidden;
}

.compare-table {
  border-radius: var(--radius-2xl) !important;
}

/* Header row */
.compare-table thead tr {
  background: transparent !important;
}

.compare-table th {
  padding: var(--space-6) var(--space-6) !important;
}

/* Kabadiwala column header — muted */
.compare-table__kabadi-col th,
.compare-table th:nth-child(2) {
  background: var(--color-soft-grey);
}

/* Scrapey column header — green gradient */
.compare-table__scrapey-col,
.compare-table th:nth-child(3) {
  background: linear-gradient(135deg, var(--color-forest) 0%, var(--color-green) 100%) !important;
}

.compare-table__col-label--scrapey {
  color: #fff !important;
  font-size: var(--text-xl) !important;
  text-shadow: 0 2px 8px rgba(0,0,0,0.2);
}

/* Feature column header */
.compare-table th:first-child {
  background: #fff;
}

/* Row hover highlight */
.compare-table tbody tr {
  transition: background 0.2s ease !important;
}

.compare-table tbody tr:hover {
  background: rgba(220,252,231,0.55) !important;
  transform: none !important;
}

.compare-table__feature {
  font-weight: 700 !important;
  font-size: var(--text-base) !important;
}

/* Yes badge — green pill */
.compare-yes {
  width: auto !important;
  height: auto !important;
  border-radius: var(--radius-full) !important;
  padding: 2px var(--space-3) !important;
  background: var(--color-green) !important;
  color: #fff !important;
  font-size: var(--text-xs) !important;
  font-weight: 700 !important;
  display: inline-flex !important;
  align-items: center !important;
  box-shadow: 0 2px 8px rgba(22,163,74,0.3) !important;
}

/* No badge — red pill */
.compare-no {
  width: auto !important;
  height: auto !important;
  border-radius: var(--radius-full) !important;
  padding: 2px var(--space-3) !important;
  background: rgba(251,113,133,0.15) !important;
  color: #e11d48 !important;
  border: 1px solid rgba(225,29,72,0.25) !important;
  font-size: var(--text-xs) !important;
  font-weight: 700 !important;
  display: inline-flex !important;
  align-items: center !important;
}

.compare-table td {
  vertical-align: middle !important;
  padding: var(--space-4) var(--space-6) !important;
}

/* Scrapey column cells slightly tinted */
.compare-table__scrapey {
  background: rgba(220,252,231,0.35) !important;
}


/* ==========================================================================
   IMPACT SECTION — Dark forest green, large numbers, yellow icons
   ========================================================================== */

.impact-section {
  background: var(--color-forest) !important;
  position: relative;
  overflow: hidden;
}

/* Subtle noise texture overlay */
.impact-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(ellipse at 20% 50%, rgba(22,163,74,0.15) 0%, transparent 60%),
    radial-gradient(ellipse at 80% 20%, rgba(250,204,21,0.08) 0%, transparent 50%);
  pointer-events: none;
  z-index: 0;
}

.impact-section .scrapey-container {
  position: relative;
  z-index: 1;
}

/* Section header on dark bg */
.impact-section .scrapey-section-header .display-l {
  background-image: none !important;
  -webkit-text-fill-color: #fff !important;
  animation: none !important;
  color: #fff !important;
}

.impact-section .section-eyebrow {
  color: var(--color-yellow) !important;
  background: rgba(250,204,21,0.12) !important;
  border-color: rgba(250,204,21,0.3) !important;
}

/* Impact grid — no gap, dividers between cells */
.impact-grid {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 0 !important;
}

@media (max-width: 599px) {
  .impact-grid {
    grid-template-columns: 1fr !important;
    gap: 0 !important;
  }
  .impact-section .impact-card,
  .impact-grid .impact-card {
    padding: 16px 20px !important;
    gap: 14px !important;
  }
  .impact-card__icon {
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    font-size: 1.1rem !important;
  }
  .impact-num {
    font-size: clamp(1.4rem, 6vw, 1.8rem) !important;
  }
  .impact-card + .impact-card::before {
    left: 0 !important;
    top: 0 !important;
    height: 1px !important;
    width: 100% !important;
  }
}

@media (min-width: 600px) and (max-width: 767px) {
  .impact-section .impact-card,
  .impact-grid .impact-card {
    padding: 16px 12px !important;
    gap: 10px !important;
  }
  .impact-card__icon {
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    font-size: 1.1rem !important;
  }
  .impact-num {
    font-size: clamp(1.3rem, 4vw, 1.7rem) !important;
  }
}

@media (min-width: 768px) {
  .impact-grid {
    grid-template-columns: repeat(4, 1fr) !important;
  }
}

/* Stat cell — no card box, content directly on bg */
/* Impact card — flat stat layout, no box */
.impact-section .impact-card,
.impact-grid .impact-card {
  background: transparent !important;
  background-color: transparent !important;
  border: none !important;
  outline: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
  padding: 20px 24px !important;
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 16px !important;
  position: relative !important;
  transform: none !important;
  transition: background 0.2s ease !important;
}

/* Vertical divider between cells */
.impact-card + .impact-card::before {
  content: '' !important;
  position: absolute !important;
  left: 0 !important;
  top: 20% !important;
  height: 60% !important;
  width: 1px !important;
  background: rgba(255,255,255,0.15) !important;
}

.impact-card:hover {
  background: rgba(255,255,255,0.04) !important;
  border-color: transparent !important;
  transform: none !important;
  box-shadow: none !important;
}

/* Icon — smaller, left side */
.impact-card__icon {
  width: 48px !important;
  height: 48px !important;
  min-width: 48px !important;
  background: rgba(250,204,21,0.15) !important;
  border: 1.5px solid rgba(250,204,21,0.3) !important;
  border-radius: 50% !important;
  font-size: 1.3rem !important;
  color: var(--color-yellow) !important;
  box-shadow: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Right side: number + label stacked */
.impact-card__body {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

/* Number row */
.impact-card__number {
  display: flex !important;
  align-items: baseline !important;
  gap: 5px !important;
  flex-wrap: nowrap !important;
  line-height: 1 !important;
  margin: 0 !important;
}

.impact-num {
  font-size: clamp(1.6rem, 2.8vw, 2.2rem) !important;
  font-weight: 800 !important;
  color: #fff !important;
  background: none !important;
  -webkit-text-fill-color: #fff !important;
  letter-spacing: -0.02em !important;
  line-height: 1 !important;
}

.impact-unit {
  font-size: 0.95rem !important;
  font-weight: 600 !important;
  color: var(--color-yellow) !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}

/* Label */
.impact-card__label {
  color: rgba(255,255,255,0.55) !important;
  font-size: 0.72rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  font-weight: 600 !important;
  margin-top: 2px !important;
}


/* ==========================================================================
   SECTION BACKGROUND ALTERNATION
   bone → mint → bone → dark → bone pattern
   ========================================================================== */

/* Rates: bone (already set) */
.rates-section { background: var(--color-bone); }

/* Steps: mint (already set via .steps-section) */

/* Compare: bone */
.compare-section { background: var(--color-bone); }

/* Business: forest (already set) */

/* FAQ: bone */
.faq-section { background: var(--color-bone); }

/* FAQ — enhanced */
.faq-list {
  gap: var(--space-2) !important;
}

.faq-item {
  border-radius: var(--radius-lg) !important;
  box-shadow: 0 1px 6px rgba(31,41,55,0.06) !important;
  border: 1px solid rgba(31,41,55,0.09) !important;
  transition: box-shadow 0.25s ease, border-color 0.25s ease !important;
  overflow: hidden !important;
}

.faq-item.is-open {
  box-shadow: 0 4px 20px rgba(22,163,74,0.12) !important;
  border-color: var(--color-green) !important;
}

/* Override reset.css pink button defaults completely */
.faq-item__trigger,
.faq-item__trigger:link,
.faq-item__trigger:visited {
  font-size: var(--text-base) !important;
  font-weight: 600 !important;
  padding: var(--space-5) var(--space-6) !important;
  background-color: transparent !important;
  background: transparent !important;
  border: none !important;
  color: var(--color-charcoal) !important;
  box-shadow: none !important;
}

.faq-item__trigger:hover,
.faq-item__trigger:focus {
  background-color: rgba(220,252,231,0.4) !important;
  background: rgba(220,252,231,0.4) !important;
  color: var(--color-green) !important;
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
}

.faq-item.is-open .faq-item__trigger {
  background: linear-gradient(90deg, rgba(220,252,231,0.6) 0%, rgba(220,252,231,0.1) 100%) !important;
  color: var(--color-green) !important;
  border: none !important;
}

.faq-item__body p {
  padding: 0 var(--space-6) var(--space-5) !important;
  font-size: var(--text-sm) !important;
  color: var(--color-stone) !important;
  line-height: 1.75 !important;
  margin: 0 !important;
}


/* ==========================================================================
   GLOBAL CARD DEPTH + HOVER TRANSITIONS
   Applies across all section cards
   ========================================================================== */

/* Universal card depth rule */
.scrapey-card,
.rate-card,
.step-card,
.testimonial-card,
.impact-card,
.business-stats-card,
.cta-form-card {
  transition: box-shadow 0.3s ease, transform 0.3s ease !important;
}

/* Section header eyebrow pill — consistent style */
.section-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: var(--color-mint);
  color: var(--color-forest);
  font-size: var(--text-sm);
  font-weight: 700;
  padding: var(--space-2) var(--space-5);
  border-radius: var(--radius-full);
  margin-bottom: var(--space-4);
  border: 1.5px solid rgba(22,163,74,0.2);
  letter-spacing: 0.03em;
}

.section-eyebrow--dark {
  background: rgba(255,255,255,0.12) !important;
  color: rgba(255,255,255,0.85) !important;
  border-color: rgba(255,255,255,0.18) !important;
}


/* ==========================================================================
   BUSINESS SECTION — Enhanced dark section with grain overlay
   ========================================================================== */

.business-section {
  position: relative;
  overflow: hidden;
}

.business-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(ellipse at 85% 15%, rgba(22,163,74,0.18) 0%, transparent 55%),
    radial-gradient(ellipse at 10% 80%, rgba(250,204,21,0.06) 0%, transparent 50%);
  pointer-events: none;
  z-index: 0;
}

.business-inner {
  position: relative;
  z-index: 1;
}

.business-stats-card {
  background: rgba(255,255,255,0.07) !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  border-radius: var(--radius-2xl) !important;
  backdrop-filter: blur(4px);
}

.business-stats-item i {
  width: 56px !important;
  height: 56px !important;
  font-size: var(--text-2xl) !important;
  background: rgba(250,204,21,0.14) !important;
  border-radius: var(--radius-lg) !important;
  border: 1px solid rgba(250,204,21,0.25) !important;
}


/* ==========================================================================
   WAVE DIVIDERS — Smooth color transitions
   ========================================================================== */

.wave-divider {
  line-height: 0;
  overflow: hidden;
}

.wave-divider svg {
  display: block;
  width: 100%;
  height: 60px;
}


/* ==========================================================================
   RATE TICKER — Enhanced styling
   ========================================================================== */

.rate-ticker {
  background: linear-gradient(90deg, var(--color-forest) 0%, #0a6647 50%, var(--color-forest) 100%);
}

.rate-ticker__item-price {
  color: var(--color-yellow);
  font-weight: 700;
}

.rate-ticker__item {
  font-weight: 500;
}


/* ==========================================================================
   CTA SECTION — Enhanced gradient background
   ========================================================================== */

.cta-section {
  background: linear-gradient(135deg, var(--color-forest) 0%, var(--color-green) 60%, #15803d 100%) !important;
  position: relative;
  overflow: hidden;
}

.cta-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(ellipse at 90% 10%, rgba(250,204,21,0.1) 0%, transparent 50%);
  pointer-events: none;
}

.cta-form-card {
  border-radius: var(--radius-2xl) !important;
  box-shadow: 0 20px 64px rgba(0,0,0,0.2) !important;
  border: 1px solid rgba(255,255,255,0.08);
}


/* ==========================================================================
   REDUCED MOTION — Override all new animations
   ========================================================================== */

@media (prefers-reduced-motion: reduce) {
  .step-card__photo,
  .gallery-item img,
  .gallery-item__label,
  .hero-visual::before,
  .impact-card,
  .rate-card:hover,
  .testimonial-card:hover { transition: none !important; animation: none !important; }
}

/* ============================================================================
   TARGETED FIXES — Rate card images · Impact numbers · Icon fallbacks
   ============================================================================ */

/* ── Rate card — full-bleed photo with overlay ──────────────────────────── */
.rate-card {
  padding: 0 !important;
  overflow: hidden !important;
  border-radius: var(--radius-xl) !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
  position: relative !important;
  min-height: 220px !important;
  cursor: pointer;
  background: #111 !important;
}

/* Full-bleed photo */
.rate-card__thumb {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  border-radius: 0 !important;
}

.rate-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.55s ease;
  filter: brightness(1.0);
}

.rate-card:hover .rate-card__thumb img {
  transform: scale(1.08);
  filter: brightness(0.9);
}

/* Light gradient overlay — only darkens bottom third for text legibility */
.rate-card__thumb::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,0.0)  0%,
    rgba(0,0,0,0.0)  45%,
    rgba(0,0,0,0.55) 75%,
    rgba(0,0,0,0.75) 100%
  );
}

/* Icon — top-right glass circle */
.rate-card__icon,
.rate-card[data-category="paper"]   .rate-card__icon,
.rate-card[data-category="plastic"] .rate-card__icon,
.rate-card[data-category="metal"]   .rate-card__icon,
.rate-card[data-category="ewaste"]  .rate-card__icon {
  position: absolute !important;
  top: var(--space-4) !important;
  right: var(--space-4) !important;
  left: auto !important;
  width: 44px !important;
  height: 44px !important;
  font-size: 1.3rem !important;
  margin: 0 !important;
  z-index: 4 !important;
  background: rgba(255,255,255,0.22) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
  border: 1.5px solid rgba(255,255,255,0.45) !important;
  box-shadow: 0 2px 12px rgba(0,0,0,0.2) !important;
  color: #fff !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Content stacked at bottom over gradient */
.rate-card__name {
  position: absolute !important;
  bottom: 68px !important;
  left: var(--space-5) !important;
  right: var(--space-5) !important;
  margin: 0 !important;
  font-size: var(--text-base) !important;
  font-weight: 700 !important;
  color: #fff !important;
  z-index: 3;
  text-shadow: 0 1px 6px rgba(0,0,0,0.5);
  line-height: 1.2;
}

.rate-card .rate-pill {
  position: absolute !important;
  bottom: var(--space-5) !important;
  left: var(--space-5) !important;
  margin: 0 !important;
  z-index: 3;
  background: rgba(255,255,255,0.15) !important;
  backdrop-filter: blur(6px) !important;
  -webkit-backdrop-filter: blur(6px) !important;
  border: 1px solid rgba(255,255,255,0.3) !important;
  border-radius: 999px !important;
  padding: 4px 14px !important;
  display: inline-flex !important;
  align-items: baseline !important;
  gap: 3px !important;
}

.rate-card .rate-pill__price {
  color: #fff !important;
  font-weight: 800 !important;
  font-size: 1.15rem !important;
  -webkit-text-fill-color: #fff !important;
  background: none !important;
  text-shadow: none !important;
}

.rate-card .rate-pill__unit {
  color: rgba(255,255,255,0.8) !important;
  font-size: 0.8rem !important;
}

.rate-card__tag {
  position: absolute !important;
  top: var(--space-4) !important;
  left: var(--space-4) !important;
  margin: 0 !important;
  z-index: 3;
  background: rgba(255,255,255,0.18) !important;
  backdrop-filter: blur(8px) !important;
  -webkit-backdrop-filter: blur(8px) !important;
  border: 1px solid rgba(255,255,255,0.3) !important;
  color: #fff !important;
  font-size: 0.72rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  padding: 3px 10px !important;
  border-radius: 999px !important;
}

/* Category accent colours on tag */
.rate-card[data-category="paper"]   .rate-card__tag { background: rgba(254,243,199,0.25) !important; border-color: rgba(252,211,77,0.5) !important; color: #FDE68A !important; }
.rate-card[data-category="plastic"] .rate-card__tag { background: rgba(224,242,254,0.2) !important; border-color: rgba(56,189,248,0.4) !important; color: #BAE6FD !important; }
.rate-card[data-category="metal"]   .rate-card__tag { background: rgba(254,226,226,0.2) !important; border-color: rgba(252,165,165,0.4) !important; color: #FCA5A5 !important; }
.rate-card[data-category="ewaste"]  .rate-card__tag { background: rgba(243,232,255,0.2) !important; border-color: rgba(216,180,254,0.4) !important; color: #DDD6FE !important; }

/* ── Impact section — force white numbers (override gradient clip) ────── */
.impact-section .impact-card__number,
.impact-section .impact-num,
.impact-section .price-display {
  background: none !important;
  background-image: none !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
  -webkit-text-fill-color: #fff !important;
  color: #fff !important;
  text-shadow: 0 2px 20px rgba(22,163,74,0.35);
}

/* Also force the label white */
.impact-section .impact-card__label {
  color: rgba(255,255,255,0.65) !important;
}

/* ── Testimonial card — improve avatar display ───────────────────────── */
.testimonial-card__avatar--photo {
  width: 52px !important;
  height: 52px !important;
  border-radius: 50% !important;
  object-fit: cover !important;
  border: 3px solid var(--color-green) !important;
  flex-shrink: 0;
}

.rate-card .tilt-card__shine {
  z-index: 5;
  pointer-events: none;
  border-radius: var(--radius-xl);
  border-radius: inherit;
}

/* Consistent card height across all breakpoints */
.rates-grid {
  grid-auto-rows: 230px !important;
}

@media (min-width: 768px) {
  .rates-grid {
    grid-auto-rows: 240px !important;
  }
}

/* Remove the old padding override on desktop that would break full-bleed */
@media (min-width: 1024px) {
  .rate-card {
    padding: 0 !important;
  }
}

/* Filter hidden state — must use !important to override display:flex !important */
.rate-card--hidden {
  display: none !important;
}

/* ============================================================================
   FIX: Testimonial footer wrapping + Gallery redesign
   ============================================================================ */

/* ── Testimonial footer layout ───────────────────────────────────────── */
.testimonial-card__footer {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: var(--space-3) !important;
}

.testimonial-card__avatar--photo {
  width: 52px !important;
  height: 52px !important;
  flex-shrink: 0 !important;
}

.testimonial-card__meta {
  flex: 1 !important;
  min-width: 120px !important;
}

.testimonial-card__name {
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: unset !important;
  font-weight: 700 !important;
  font-size: var(--text-sm) !important;
  display: block !important;
  color: var(--color-charcoal) !important;
}

.testimonial-card__suburb {
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: unset !important;
  font-size: var(--text-xs) !important;
  display: block !important;
  color: var(--color-stone) !important;
}

.testimonial-card__earned {
  flex-shrink: 0 !important;
  margin-left: auto !important;
}

/* ── Gallery section — full redesign ──────────────────────────────────── */

/* Remove the wide banner image from the layout — use a 2x3 equal grid */
.gallery-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  grid-template-rows: repeat(2, 220px) !important;
  gap: var(--space-4) !important;
}

/* No more span — all items equal */
.gallery-item--wide {
  grid-column: auto !important;
  aspect-ratio: unset !important;
}

.gallery-item {
  border-radius: var(--radius-xl) !important;
  aspect-ratio: unset !important;
  height: 100% !important;
  position: relative !important;
  overflow: hidden !important;
  box-shadow: var(--shadow-lg) !important;
  transition: transform 0.35s ease, box-shadow 0.35s ease !important;
  background: var(--color-charcoal) !important;
}

.gallery-item:hover {
  transform: translateY(-6px) !important;
  box-shadow: 0 20px 50px rgba(6,78,59,0.22) !important;
}

.gallery-item img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  transition: transform 0.6s ease !important;
}

.gallery-item:hover img {
  transform: scale(1.08) !important;
}

/* Label always visible with bottom gradient */
.gallery-item__label {
  position: absolute !important;
  bottom: 0 !important;
  left: 0 !important;
  right: 0 !important;
  padding: var(--space-6) var(--space-4) var(--space-3) !important;
  background: linear-gradient(transparent, rgba(4,40,25,0.88)) !important;
  color: #fff !important;
  display: flex !important;
  align-items: center !important;
  gap: var(--space-2) !important;
  font-size: var(--text-sm) !important;
  font-weight: 600 !important;
  opacity: 1 !important;
  transform: none !important;
  transition: none !important;
}

.gallery-item__label i {
  color: var(--color-yellow) !important;
  font-size: 1.1rem !important;
}

/* Responsive: 2 columns on tablet */
@media (max-width: 900px) {
  .gallery-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    grid-template-rows: repeat(3, 200px) !important;
  }
}

@media (max-width: 540px) {
  .gallery-grid {
    grid-template-columns: 1fr !important;
    grid-template-rows: unset !important;
  }
  .gallery-item {
    height: 200px !important;
  }
}

/* ── Testimonial card inner spacing ─────────────────────────────────── */
.testimonial-card {
  padding: var(--space-10) !important;
}

.testimonial-card__quote {
  margin-bottom: var(--space-8) !important;
  line-height: 1.75 !important;
}

.testimonial-card__footer {
  padding-top: var(--space-5) !important;
  border-top: 1px solid var(--color-soft-grey) !important;
  background: none !important;
  border-radius: 0 !important;
  margin-top: 0 !important;
}

/* ── Compare section — OLD two-card layout (superseded) ─────────────── */
.compare-cards {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: var(--space-6);
  align-items: center;
  max-width: 900px;
  margin: 0 auto;
}

/* VS badge */
.compare-vs {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: var(--color-charcoal);
  color: #fff;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--text-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: var(--shadow-md);
  letter-spacing: 0.02em;
}

/* Base card */
.compare-card {
  border-radius: var(--radius-2xl);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
}

/* Old (Kabadiwala) card — warm grey */
.compare-card--old {
  background: #F9FAFB;
  border: 1.5px solid #E5E7EB;
}

/* Scrapey card — rich green */
.compare-card--scrapey {
  background: var(--color-forest);
  border: 1.5px solid rgba(255,255,255,0.1);
}

/* Card header */
.compare-card__header {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-6) var(--space-7);
  border-bottom: 1px solid rgba(0,0,0,0.07);
}

.compare-card--scrapey .compare-card__header {
  border-bottom-color: rgba(255,255,255,0.1);
  background: rgba(255,255,255,0.04);
}

.compare-card__emoji {
  font-size: 2rem;
  line-height: 1;
}

.compare-card__title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-lg);
  color: var(--color-charcoal);
}

.compare-card--scrapey .compare-card__title {
  color: #fff;
}

.compare-card__subtitle {
  font-size: var(--text-xs);
  color: var(--color-stone);
  margin-top: 2px;
}

.compare-card--scrapey .compare-card__subtitle {
  color: rgba(255,255,255,0.55);
}

/* Feature list */
.compare-card__list {
  list-style: none;
  padding: var(--space-4) 0;
  margin: 0;
}

.compare-card__item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
  padding: var(--space-4) var(--space-7);
  border-bottom: 1px solid rgba(0,0,0,0.05);
  transition: background var(--transition-fast);
}

.compare-card--scrapey .compare-card__item {
  border-bottom-color: rgba(255,255,255,0.06);
}

.compare-card__item:last-child {
  border-bottom: none;
}

.compare-card__item--no:hover { background: rgba(239,68,68,0.04); }
.compare-card__item--yes:hover { background: rgba(255,255,255,0.05); }

/* Icons — styled as pill badges */
.compare-icon {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  font-weight: 800;
  line-height: 1;
  margin-top: 2px;
}

.compare-icon--no {
  background: #FEE2E2;
  color: #DC2626;
  border: 1.5px solid #FECACA;
}

.compare-icon--yes {
  background: rgba(74,222,128,0.2);
  color: #4ADE80;
  border: 1.5px solid rgba(74,222,128,0.4);
}

/* Item text */
.compare-card__item strong {
  display: block;
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--color-charcoal);
  margin-bottom: 2px;
}

.compare-card--scrapey .compare-card__item strong {
  color: #fff;
}

.compare-card__item span {
  font-size: var(--text-xs);
  color: var(--color-stone);
  line-height: 1.5;
}

.compare-card--scrapey .compare-card__item span {
  color: rgba(255,255,255,0.65);
}

/* Responsive — stack on mobile */
@media (max-width: 700px) {
  .compare-cards {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }
  .compare-vs {
    margin: 0 auto;
  }
}

/* ── Compare panel — unified 3-column aligned layout ────────────────── */
.compare-panel {
  background: #fff;
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-xl);
  overflow: hidden;
  border: 1px solid var(--color-soft-grey);
}

/* Header */
.compare-panel__head {
  display: grid;
  grid-template-columns: 1fr 160px 1fr;
  background: var(--color-charcoal);
}

.compare-panel__head-kabadi,
.compare-panel__head-feature,
.compare-panel__head-scrapey {
  padding: var(--space-5) var(--space-6);
  display: flex;
  align-items: center;
  justify-content: center;
}

.compare-panel__head-feature {
  background: rgba(255,255,255,0.06);
}

.compare-panel__badge {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-base);
  color: #fff;
  letter-spacing: -0.01em;
}

.compare-panel__badge--scrapey {
  color: #4ADE80;
}

/* Data rows */
.compare-panel__row {
  display: grid;
  grid-template-columns: 1fr 160px 1fr;
  border-top: 1px solid var(--color-soft-grey);
  transition: background var(--transition-fast);
}

.compare-panel__row:hover {
  background: #F9FAFB;
}

/* Feature (middle) cell */
.compare-panel__cell--feature {
  background: var(--color-bone);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-5) var(--space-4);
  text-align: center;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-sm);
  color: var(--color-forest);
  border-left: 1px solid var(--color-soft-grey);
  border-right: 1px solid var(--color-soft-grey);
  line-height: 1.3;
}

.compare-panel__cell--feature i {
  font-size: 1.3rem;
  color: var(--color-green);
}

/* Kabadi & Scrapey cells */
.compare-panel__cell--kabadi,
.compare-panel__cell--scrapey {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-5) var(--space-6);
  font-size: var(--text-sm);
  color: var(--color-stone);
  line-height: 1.4;
}

.compare-panel__cell--scrapey {
  background: rgba(220,252,231,0.3);
  color: var(--color-forest);
  font-weight: 500;
}

/* ✗ / ✓ pill badges */
.cpill {
  flex-shrink: 0;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.7rem;
  font-weight: 900;
  line-height: 1;
}

.cpill--no {
  background: #FEE2E2;
  color: #DC2626;
  border: 1.5px solid #FECACA;
}

.cpill--yes {
  background: #DCFCE7;
  color: #16A34A;
  border: 1.5px solid #BBF7D0;
}

/* Responsive — stack on mobile */
@media (max-width: 640px) {
  .compare-panel__head,
  .compare-panel__row {
    grid-template-columns: 1fr;
  }
  .compare-panel__cell--feature {
    flex-direction: row;
    justify-content: flex-start;
    background: var(--color-charcoal);
    color: #fff;
    border: none;
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: var(--space-3) var(--space-5);
  }
  .compare-panel__cell--feature i { color: var(--color-yellow); }
  .compare-panel__head-feature { display: none; }
  .compare-panel__head-kabadi,
  .compare-panel__head-scrapey { justify-content: flex-start; }
}

/* ============================================================================
   GLOBAL BUTTON RESET — kill reset.css pink (#c36) on ALL buttons
   ============================================================================ */

button:not(.scrapey-btn):not(.faq-item__trigger):not(.rates-chip):hover,
button:not(.scrapey-btn):not(.faq-item__trigger):not(.rates-chip):focus,
[type="button"]:not(.scrapey-btn):not(.rates-chip):hover,
[type="button"]:not(.scrapey-btn):not(.rates-chip):focus,
[type="submit"]:not(.scrapey-btn):not(.rates-chip):hover {
  background-color: transparent !important;
  color: inherit !important;
  border-color: inherit !important;
}

/* Active chip — always green regardless of hover/focus */
.rates-chip.is-active,
.rates-chip.is-active:hover,
.rates-chip.is-active:focus,
.rates-chip.is-active:active {
  background: var(--color-green) !important;
  background-color: var(--color-green) !important;
  border-color: var(--color-green) !important;
  color: #fff !important;
}

/* ============================================================================
   GLOBAL SECTION SPACING — compact vertical rhythm
   ============================================================================ */

/* Force compact padding on every section — all breakpoints */
.scrapey-section:not(.hero-section),
section.scrapey-section:not(.hero-section) {
  padding-top:    20px !important;
  padding-bottom: 20px !important;
}

@media (min-width: 768px) {
  .scrapey-section:not(.hero-section),
  section.scrapey-section:not(.hero-section) {
    padding-top:    24px !important;
    padding-bottom: 24px !important;
  }
}

@media (min-width: 1024px) {
  .scrapey-section:not(.hero-section),
  section.scrapey-section:not(.hero-section) {
    padding-top:    28px !important;
    padding-bottom: 28px !important;
  }
}

/* Hero: just clear the fixed nav, no extra padding */
.hero-section {
  padding-top:    calc(var(--header-h) + 20px) !important;
  padding-bottom: 24px !important;
}

/* Section header: very tight stack */
.scrapey-section-header {
  margin-bottom: 20px !important;
}

.section-eyebrow {
  margin-bottom: 8px !important;
  padding: 4px 12px !important;
  font-size: 0.7rem !important;
}

.scrapey-section-header .display-l,
.scrapey-section-header .display-xl {
  margin-top: 0 !important;
  margin-bottom: 6px !important;
  line-height: 1.1 !important;
}

.scrapey-section-sub {
  margin-top: 6px !important;
  font-size: var(--text-base) !important;
}

/* Tighten inner section element gaps */
.rates-filters       { margin-bottom: 16px !important; }
.rates-footer        { margin-top: 16px !important; }
.steps-grid          { gap: var(--space-4) !important; }
.impact-grid         { gap: var(--space-4) !important; }
.testimonials-grid   { gap: var(--space-4) !important; }
.gallery-grid        { gap: var(--space-2) !important; }
.faq-list            { gap: 6px !important; }
.compare-section .scrapey-container > * + * { margin-top: 16px !important; }
.business-grid       { gap: var(--space-4) !important; }

/* ============================================================================
   NEW ANIMATIONS — Spotlight · Cursor Trail · Word Reveal · Scramble
   ============================================================================ */

/* ── Typewriter word in hero heading ────────────────────────────────────── */
.hero-type-wrap {
  display: inline-flex;
  align-items: baseline;
  gap: 2px;
  color: var(--color-green);
}

.hero-type-word {
  color: var(--color-green);
  min-width: 4ch;
  display: inline-block;
  -webkit-text-fill-color: var(--color-green);
}

.hero-type-cursor {
  display: inline-block;
  color: var(--color-green);
  font-weight: 300;
  animation: cursor-blink 0.75s step-end infinite;
  margin-left: 1px;
  -webkit-text-fill-color: var(--color-green);
}

/* ── Live payment feed ──────────────────────────────────────────────────── */
.live-feed {
  position: absolute;
  bottom: 24px;
  left: -20px;
  z-index: 10;
  display: flex;
  flex-direction: column;
  gap: 8px;
  pointer-events: none;
}

.live-feed__toast {
  display: flex;
  align-items: center;
  gap: 10px;
  background: #fff;
  border-radius: var(--radius-xl);
  padding: 10px 14px;
  box-shadow: 0 8px 28px rgba(0,0,0,0.14);
  border-left: 3px solid var(--color-green);
  min-width: 220px;
  max-width: 260px;
  opacity: 0;
  transform: translateX(-24px) scale(0.95);
  transition: opacity 0.4s ease, transform 0.4s cubic-bezier(0.34,1.56,0.64,1);
}

.live-feed__toast--in {
  opacity: 1;
  transform: translateX(0) scale(1);
}

.live-feed__toast--out {
  opacity: 0;
  transform: translateX(-16px) scale(0.97);
  transition: opacity 0.4s ease, transform 0.35s ease;
}

.live-feed__icon {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--color-mint);
  color: var(--color-forest);
  font-size: 1rem;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.live-feed__text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  font-size: 0.82rem;
  color: var(--color-charcoal);
  font-weight: 500;
}

.live-feed__text-main {
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.live-feed__text strong {
  color: var(--color-green);
  font-weight: 800;
}

.live-feed__sub {
  display: block;
  font-size: 0.72rem;
  color: var(--color-stone);
  font-weight: 400;
}

/* ── Scrollspy active nav link ──────────────────────────────────────────── */
.scrapey-header__nav a.nav-active {
  color: var(--color-green) !important;
  font-weight: 700;
}

.scrapey-header__nav a.nav-active::after {
  width: 100% !important;
  opacity: 1 !important;
}

/* ── Hero cursor spotlight overlay ─────────────────────────────────────── */
#hero-spotlight {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.4s ease;
  border-radius: inherit;
}

/* ── Cursor particle trail dots ─────────────────────────────────────────── */
.cursor-trail-dot {
  position: fixed;
  border-radius: 50%;
  pointer-events: none;
  z-index: 99999;
  will-change: transform, opacity, left, top;
  transition: none;
}

/* ── Word-reveal on section headings ────────────────────────────────────── */
.word-reveal-wrap {
  display: inline-block;
  overflow: hidden;
  vertical-align: bottom;
  line-height: inherit;
}

.word-reveal {
  display: inline-block;
  transform: translateY(0);
  opacity: 1;
  transition: transform 0.55s cubic-bezier(0.22, 1, 0.36, 1),
              opacity 0.45s ease;
  will-change: transform, opacity;
}

/* JS adds word-reveal--in; keep for scroll-triggered animation when JS works */
.word-reveal--in {
  transform: translateY(0) !important;
  opacity: 1 !important;
}

/* ── Text scramble accent pulse ─────────────────────────────────────────── */
.hero-heading-accent {
  display: inline-block;
}

/* ── Floating scrap icon decorators (extra hero depth) ──────────────────── */
@keyframes floatSpin {
  0%   { transform: translateY(0)    rotate(0deg)   scale(1); }
  33%  { transform: translateY(-18px) rotate(120deg) scale(1.08); }
  66%  { transform: translateY(-8px)  rotate(240deg) scale(0.94); }
  100% { transform: translateY(0)    rotate(360deg) scale(1); }
}

/* ── Rate ticker pulse on item hover ────────────────────────────────────── */
.rate-ticker__item {
  transition: color 0.25s ease, transform 0.25s ease;
  cursor: default;
}

.rate-ticker__item:hover {
  color: var(--color-yellow);
  transform: scale(1.08);
}

/* ── Glow ring pulse on hero CTA button ────────────────────────────────── */
@keyframes ctaGlowRing {
  0%   { box-shadow: 0 0 0 0   rgba(22,163,74,0.55); }
  70%  { box-shadow: 0 0 0 16px rgba(22,163,74,0); }
  100% { box-shadow: 0 0 0 0   rgba(22,163,74,0); }
}

.scrapey-btn--primary {
  animation: ctaGlowRing 2.2s ease-out infinite;
}

.scrapey-btn--primary:hover {
  animation: none;
}

/* ── Section heading gradient shimmer ──────────────────────────────────── */
@keyframes headingShimmer {
  0%   { background-position: -200% center; }
  100% { background-position: 200% center; }
}

/* ── Staggered impact card pop-in ──────────────────────────────────────── */
@keyframes cardPopIn {
  0%   { opacity: 0; transform: scale(0.88) translateY(24px); }
  60%  { opacity: 1; transform: scale(1.03) translateY(-4px); }
  100% { opacity: 1; transform: scale(1)    translateY(0); }
}

.impact-card.aos-animate {
  animation: cardPopIn 0.6s cubic-bezier(0.34,1.56,0.64,1) both;
}

.impact-card:nth-child(1) { animation-delay: 0.05s; }
.impact-card:nth-child(2) { animation-delay: 0.15s; }
.impact-card:nth-child(3) { animation-delay: 0.25s; }
.impact-card:nth-child(4) { animation-delay: 0.35s; }

/* ── Morphing hero blob ─────────────────────────────────────────────────── */
@keyframes morphBlob {
  0%   { border-radius: 60% 40% 30% 70% / 60% 30% 70% 40%; }
  25%  { border-radius: 30% 60% 70% 40% / 50% 60% 30% 60%; }
  50%  { border-radius: 50% 60% 40% 60% / 40% 50% 60% 50%; }
  75%  { border-radius: 40% 50% 60% 30% / 60% 40% 50% 70%; }
  100% { border-radius: 60% 40% 30% 70% / 60% 30% 70% 40%; }
}

.hero-blob {
  animation: morphBlob 12s ease-in-out infinite !important;
}

/* ============================================================================
   HERO IMAGE SLIDER
   ============================================================================ */

.hero-slider {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;
  border-radius: var(--radius-2xl);
  overflow: hidden;
  box-shadow: 0 24px 60px rgba(6,78,59,0.25);
}

/* Each slide */
.hero-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 0.75s cubic-bezier(0.4, 0, 0.2, 1);
  pointer-events: none;
}

.hero-slide--active {
  opacity: 1;
  pointer-events: auto;
}

.hero-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Dark gradient at bottom for caption readability */
.hero-slide__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,0.0) 30%,
    rgba(0,0,0,0.55) 100%
  );
}

/* Caption */
.hero-slide__caption {
  position: absolute;
  bottom: 52px;
  left: 20px;
  right: 20px;
  display: flex;
  align-items: center;
  gap: 8px;
  color: #fff;
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-shadow: 0 1px 6px rgba(0,0,0,0.4);
}

.hero-slide__caption i {
  font-size: 1.1rem;
  color: var(--color-yellow);
  flex-shrink: 0;
}

/* Dot indicators */
.hero-slider__dots {
  position: absolute;
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  z-index: 4;
}

.hero-slider__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255,255,255,0.45) !important;
  border: none !important;
  padding: 0 !important;
  cursor: pointer !important;
  transition: background 0.3s ease, transform 0.3s ease !important;
  min-height: unset !important;
}

.hero-slider__dot--active {
  background: #fff !important;
  transform: scale(1.35) !important;
}

.hero-slider__dot:hover {
  background: rgba(255,255,255,0.8) !important;
  color: transparent !important;
}

/* Arrow buttons */
.hero-slider__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 4;
  width: 36px !important;
  height: 36px !important;
  min-height: unset !important;
  border-radius: 50% !important;
  background: rgba(255,255,255,0.18) !important;
  backdrop-filter: blur(8px) !important;
  border: 1px solid rgba(255,255,255,0.3) !important;
  color: #fff !important;
  font-size: 1rem !important;
  padding: 0 !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background 0.25s ease !important;
}

.hero-slider__arrow:hover {
  background: rgba(255,255,255,0.32) !important;
  color: #fff !important;
}

.hero-slider__arrow--prev { left: 12px; }
.hero-slider__arrow--next { right: 12px; }

/* ============================================================================
   VS COMPARE LAYOUT — Two-card versus design
   ============================================================================ */

.vs-wrap {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 0;
  align-items: stretch;
  max-width: 860px;
  margin: 0 auto;
}

/* ── Cards ─────────────────────────────────────────────────────────────── */
.vs-card {
  border-radius: var(--radius-2xl);
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.vs-card--bad {
  background: var(--color-charcoal);
  border-radius: var(--radius-2xl) 0 0 var(--radius-2xl);
}

.vs-card--good {
  background: linear-gradient(145deg, #064E3B 0%, #065f46 50%, #16A34A 100%);
  border-radius: 0 var(--radius-2xl) var(--radius-2xl) 0;
  box-shadow: 0 8px 32px rgba(22,163,74,0.25);
}

/* ── Card header ───────────────────────────────────────────────────────── */
.vs-card__header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(255,255,255,0.12);
}

.vs-card__emoji {
  font-size: 1.4rem;
  line-height: 1;
}

.vs-card__emoji--check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  background: rgba(255,255,255,0.2);
  border-radius: 50%;
  font-size: 1rem;
  color: #fff;
  flex-shrink: 0;
}

.vs-card__title {
  font-size: 1rem;
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.01em;
}

.vs-card--bad .vs-card__title { color: rgba(255,255,255,0.75); }

/* ── Item list ─────────────────────────────────────────────────────────── */
.vs-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.vs-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

/* ── Pill icons ────────────────────────────────────────────────────────── */
.vs-pill {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  font-weight: 700;
  margin-top: 2px;
}

.vs-pill--no  { background: rgba(239,68,68,0.2);  color: #fca5a5; border: 1px solid rgba(239,68,68,0.3); }
.vs-pill--yes { background: rgba(255,255,255,0.2); color: #fff;    border: 1px solid rgba(255,255,255,0.35); }

/* ── Item text ─────────────────────────────────────────────────────────── */
.vs-item__text {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.vs-item__feature {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: rgba(255,255,255,0.45);
  display: flex;
  align-items: center;
  gap: 4px;
}

.vs-item__feature i { font-size: 0.8rem; }

.vs-item--yes .vs-item__feature { color: rgba(255,255,255,0.55); }

.vs-item__desc {
  font-size: 0.9rem;
  font-weight: 500;
  line-height: 1.35;
  color: rgba(255,255,255,0.55);
}

.vs-item--yes .vs-item__desc { color: #fff; }

/* ── VS divider ────────────────────────────────────────────────────────── */
.vs-divider {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  position: relative;
  z-index: 2;
}

.vs-badge {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: var(--color-yellow);
  color: var(--color-forest);
  font-size: 0.75rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(250,204,21,0.5);
  flex-shrink: 0;
}

/* ── Mobile: stack vertically ──────────────────────────────────────────── */
@media (max-width: 640px) {
  .vs-wrap {
    grid-template-columns: 1fr;
  }

  .vs-card--bad  { border-radius: var(--radius-2xl) var(--radius-2xl) 0 0; }
  .vs-card--good { border-radius: 0 0 var(--radius-2xl) var(--radius-2xl); }

  .vs-divider {
    width: 100%;
    height: 44px;
    background: linear-gradient(to right, var(--color-charcoal) 50%, #064E3B 50%);
  }
}

/* ============================================================================
   CTA FORM CARD — Attractive redesign
   ============================================================================ */

/* Card shell */
#pickup .cta-form-card {
  background: #fff !important;
  border-radius: 20px !important;
  box-shadow: 0 32px 80px rgba(6,78,59,0.28), 0 0 0 1px rgba(22,163,74,0.08) !important;
  border: none !important;
  overflow: hidden !important;
  padding: 0 !important;
}

/* ── Hide ALL CF7 default text: title label, headings, office-hours paras ─── */
/* Targets the title p before the form tag */
#pickup .cta-form-card .wpcf7 > p,
#pickup .cta-form-card .wpcf7-response-output + p,
/* All headings inside the CF7 form body */
#pickup .cta-form-card .wpcf7-form h1,
#pickup .cta-form-card .wpcf7-form h2,
#pickup .cta-form-card .wpcf7-form h3,
#pickup .cta-form-card .wpcf7-form h4,
/* Paragraphs with no CF7 form controls (text-only paragraphs — modern browsers) */
#pickup .cta-form-card .wpcf7-form p:not(:has(.wpcf7-form-control)) {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
}

/* ── Green header banner ──────────────────────────────────────────────────── */
#pickup .cta-form-card .cta-card-header,
.cta-card-header {
  background: linear-gradient(135deg, #064E3B 0%, #16A34A 100%) !important;
  padding: 20px 24px !important;
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  visibility: visible !important;
  opacity: 1 !important;
  height: auto !important;
  overflow: visible !important;
}

.cta-card-header__icon {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(255,255,255,0.18);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  color: #fff;
  flex-shrink: 0;
  border: 1.5px solid rgba(255,255,255,0.3);
}

.cta-card-header__text {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.cta-card-header__title {
  font-size: 1rem;
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.01em;
}

.cta-card-header__sub {
  font-size: 0.75rem;
  color: rgba(255,255,255,0.7);
  font-weight: 500;
}

.cta-card-header__badge {
  background: var(--color-yellow);
  color: var(--color-forest);
  font-size: 0.72rem;
  font-weight: 800;
  padding: 4px 10px;
  border-radius: 999px;
  display: flex;
  align-items: center;
  gap: 4px;
  letter-spacing: 0.03em;
  flex-shrink: 0;
}

/* ── Form body padding ────────────────────────────────────────────────────── */
.cta-card-body {
  padding: 20px 24px 8px;
}

/* ── CF7 form field overrides ─────────────────────────────────────────────── */
#pickup .cta-form-card .wpcf7-form p,
#pickup .cta-form-card .wpcf7-form div {
  margin-bottom: 0 !important;
}

/* Hide the default CF7 form title / heading */
#pickup .cta-form-card h2,
#pickup .cta-form-card .wpcf7-form > p:first-child > label:only-child {
  display: none !important;
}

/* All text inputs, email, tel */
#pickup .cta-form-card input[type="text"],
#pickup .cta-form-card input[type="email"],
#pickup .cta-form-card input[type="tel"],
#pickup .cta-form-card input[type="number"],
#pickup .cta-form-card select,
#pickup .cta-form-card textarea {
  width: 100% !important;
  border: 1.5px solid #E5E7EB !important;
  border-radius: 10px !important;
  padding: 11px 14px !important;
  font-size: 0.9rem !important;
  color: var(--color-charcoal) !important;
  background: #FAFAFA !important;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease !important;
  outline: none !important;
  box-shadow: none !important;
  margin-bottom: 10px !important;
}

#pickup .cta-form-card input[type="text"]:focus,
#pickup .cta-form-card input[type="email"]:focus,
#pickup .cta-form-card input[type="tel"]:focus,
#pickup .cta-form-card textarea:focus {
  border-color: var(--color-green) !important;
  background: #fff !important;
  box-shadow: 0 0 0 3px rgba(22,163,74,0.1) !important;
}

#pickup .cta-form-card input::placeholder,
#pickup .cta-form-card textarea::placeholder {
  color: #9CA3AF !important;
}

#pickup .cta-form-card textarea {
  min-height: 100px !important;
  resize: vertical !important;
}

/* Labels */
#pickup .cta-form-card label {
  font-size: 0.8rem !important;
  font-weight: 600 !important;
  color: var(--color-charcoal) !important;
  display: block !important;
  margin-bottom: 4px !important;
}

/* Submit button */
#pickup .cta-form-card input[type="submit"],
#pickup .cta-form-card .wpcf7-submit {
  width: 100% !important;
  background: linear-gradient(135deg, #064E3B 0%, #16A34A 100%) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 12px !important;
  padding: 14px 28px !important;
  font-size: 0.95rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: opacity 0.25s ease, transform 0.2s ease, box-shadow 0.25s ease !important;
  box-shadow: 0 6px 24px rgba(22,163,74,0.35) !important;
  margin-top: 4px !important;
}

#pickup .cta-form-card input[type="submit"]:hover,
#pickup .cta-form-card .wpcf7-submit:hover {
  opacity: 0.92 !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 10px 32px rgba(22,163,74,0.45) !important;
}

/* ── Trust strip ──────────────────────────────────────────────────────────── */
.cta-trust-strip {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  padding: 12px 24px 16px;
  border-top: 1px solid #F3F4F6;
  flex-wrap: wrap;
}

.cta-trust-strip span {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--color-stone);
  letter-spacing: 0.02em;
}

.cta-trust-strip i {
  color: var(--color-green);
  font-size: 0.85rem;
}

/* ── Remove old title override ────────────────────────────────────────────── */
.cta-form-card__title { display: none !important; }

/* ============================================================================
   IMPACT SECTION — FINAL OVERRIDE (must be last)
   ============================================================================ */

#impact .impact-card,
.impact-section .impact-grid .impact-card {
  background:       transparent !important;
  background-color: transparent !important;
  border:           none !important;
  border-radius:    0 !important;
  box-shadow:       none !important;
  overflow:         visible !important;
  padding:          20px 24px !important;
  display:          flex !important;
  flex-direction:   row !important;
  align-items:      center !important;
  text-align:       left !important;
  gap:              16px !important;
  transform:        none !important;
}

#impact .impact-card:hover {
  background:    rgba(255,255,255,0.05) !important;
  box-shadow:    none !important;
  transform:     none !important;
  border:        none !important;
}

#impact .impact-card + .impact-card {
  border-left: 1px solid rgba(255,255,255,0.15) !important;
}

#impact .impact-card__icon {
  width:         48px !important;
  height:        48px !important;
  min-width:     48px !important;
  flex-shrink:   0 !important;
  margin:        0 !important;
  background:    rgba(250,204,21,0.15) !important;
  border:        1.5px solid rgba(250,204,21,0.3) !important;
  border-radius: 50% !important;
  font-size:     1.3rem !important;
  color:         var(--color-yellow) !important;
  box-shadow:    none !important;
  display:       flex !important;
  align-items:   center !important;
  justify-content: center !important;
}

#impact .impact-card__body {
  display:        flex !important;
  flex-direction: column !important;
  gap:            3px !important;
  text-align:     left !important;
}

#impact .impact-card__number {
  display:     flex !important;
  align-items: baseline !important;
  gap:         5px !important;
  flex-wrap:   nowrap !important;
  margin:      0 !important;
  line-height: 1 !important;
}

#impact .impact-num {
  font-size:            clamp(1.6rem, 2.8vw, 2.2rem) !important;
  font-weight:          800 !important;
  color:                #fff !important;
  -webkit-text-fill-color: #fff !important;
  background:           none !important;
  letter-spacing:       -0.02em !important;
  line-height:          1 !important;
}

#impact .impact-unit {
  font-size:   0.95rem !important;
  font-weight: 600 !important;
  color:       var(--color-yellow) !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}

#impact .impact-card__label {
  color:          rgba(255,255,255,0.55) !important;
  font-size:      0.72rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  font-weight:    600 !important;
  margin-top:     2px !important;
}

/* Mobile: 2 cols, remove left border on first col */
@media (max-width: 767px) {
  #impact .impact-card:nth-child(odd) {
    border-left: none !important;
  }
  #impact .impact-card:nth-child(3),
  #impact .impact-card:nth-child(4) {
    border-top: 1px solid rgba(255,255,255,0.12) !important;
  }
}

/* ============================================================================
   PHONE MOCKUP — LABEL VISUAL ENHANCEMENTS
   ============================================================================ */

/* ── UPI Card: app icon glow ────────────────────────────────────────────── */
.upi-card__app-icon {
  width: 36px !important;
  height: 36px !important;
  border-radius: 10px !important;
  background: linear-gradient(135deg, #16A34A 0%, #064E3B 100%) !important;
  box-shadow: 0 4px 12px rgba(22,163,74,0.45) !important;
}

/* ── UPI Card: app name — bolder & charcoal ─────────────────────────────── */
.upi-card__app-name {
  font-size: 0.8rem !important;
  font-weight: 800 !important;
  color: #1a2e1a !important;
  letter-spacing: 0.01em !important;
}

/* ── UPI Card: "just now" — live dot ────────────────────────────────────── */
.upi-card__time {
  font-size: 10px !important;
  color: #16A34A !important;
  font-weight: 600 !important;
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
}
.upi-card__time::before {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #16A34A;
  animation: live-pulse 1.4s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes live-pulse {
  0%, 100% { opacity: 1;   transform: scale(1);    }
  50%       { opacity: 0.4; transform: scale(0.7);  }
}

/* ── UPI Card: ✓ badge — larger & glowing ───────────────────────────────── */
.upi-card__badge {
  width: 24px !important;
  height: 24px !important;
  font-size: 13px !important;
  background: linear-gradient(135deg, #16A34A, #064E3B) !important;
  box-shadow: 0 3px 10px rgba(22,163,74,0.5) !important;
}

/* ── UPI Card: amount — gradient shimmer ────────────────────────────────── */
.upi-card__amount {
  font-size: clamp(1.8rem, 5vw, 2.2rem) !important;
  background: linear-gradient(135deg, #16A34A 0%, #059669 50%, #064E3B 100%);
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  line-height: 1.1 !important;
}

/* ── UPI Card: "received from Scrapey" — two-tone ──────────────────────── */
.upi-card__label {
  font-size: 0.78rem !important;
  color: #6b7280 !important;
  font-weight: 500 !important;
  letter-spacing: 0.01em !important;
}

/* ── UPI Card: ref box — green accent border + better bg ────────────────── */
.upi-card__ref {
  background: linear-gradient(135deg, rgba(220,252,231,0.8) 0%, rgba(240,253,244,0.6) 100%) !important;
  border-left: 3px solid #16A34A !important;
  border-radius: 6px !important;
  padding: 8px 10px !important;
  font-size: 0.72rem !important;
  font-weight: 600 !important;
  color: #064E3B !important;
  line-height: 1.5 !important;
  letter-spacing: 0.01em !important;
}

/* ── Balance row — glassmorphism tile ───────────────────────────────────── */
.upi-balance {
  background: linear-gradient(135deg, rgba(255,255,255,0.1) 0%, rgba(255,255,255,0.04) 100%) !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  border-radius: 10px !important;
  padding: 10px 12px !important;
  backdrop-filter: blur(4px) !important;
}

.upi-balance__label {
  font-size: 0.68rem !important;
  color: rgba(255,255,255,0.6) !important;
  font-weight: 500 !important;
  letter-spacing: 0.02em !important;
  text-transform: none !important;
}

.upi-balance__value {
  font-size: 1rem !important;
  font-weight: 800 !important;
  color: #fff !important;
  text-shadow: 0 0 20px rgba(22,163,74,0.4) !important;
  letter-spacing: -0.02em !important;
}

/* ── Weight / verified row — bright pill ────────────────────────────────── */
.upi-weight {
  background: linear-gradient(135deg, rgba(250,204,21,0.18) 0%, rgba(250,204,21,0.08) 100%) !important;
  border: 1px solid rgba(250,204,21,0.3) !important;
  border-radius: 10px !important;
  padding: 10px 12px !important;
  font-size: 0.78rem !important;
  font-weight: 700 !important;
  color: #FACC15 !important;
  letter-spacing: 0.02em !important;
  text-shadow: 0 0 12px rgba(250,204,21,0.4) !important;
}
.upi-weight i {
  font-size: 1rem !important;
  color: #FACC15 !important;
  filter: drop-shadow(0 0 4px rgba(250,204,21,0.6)) !important;
}

/* ── Floating badge — pickup: white glass card ──────────────────────────── */
.hero-badge--pickup {
  background: rgba(255,255,255,0.95) !important;
  backdrop-filter: blur(12px) !important;
  border: 1px solid rgba(22,163,74,0.2) !important;
  color: #064E3B !important;
  font-weight: 700 !important;
  font-size: 0.78rem !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.18), 0 2px 8px rgba(22,163,74,0.15) !important;
  padding: 8px 14px !important;
  gap: 6px !important;
}
.hero-badge--pickup i {
  color: #16A34A !important;
  font-size: 1rem !important;
  filter: drop-shadow(0 0 4px rgba(22,163,74,0.5)) !important;
}

/* ── Floating badge — eco: dark forest pill ─────────────────────────────── */
.hero-badge--eco {
  background: linear-gradient(135deg, #064E3B 0%, #065f46 100%) !important;
  border: 1px solid rgba(250,204,21,0.35) !important;
  color: #FACC15 !important;
  font-weight: 700 !important;
  font-size: 0.78rem !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.25), 0 2px 8px rgba(6,78,59,0.4) !important;
  padding: 8px 14px !important;
  gap: 6px !important;
}
.hero-badge--eco i {
  color: #FACC15 !important;
  font-size: 1rem !important;
  filter: drop-shadow(0 0 4px rgba(250,204,21,0.5)) !important;
}

/* ── Live-feed toast — richer card ─────────────────────────────────────── */
.live-feed__toast {
  background: rgba(255,255,255,0.97) !important;
  backdrop-filter: blur(12px) !important;
  border-left: 4px solid #16A34A !important;
  box-shadow: 0 12px 40px rgba(0,0,0,0.18), 0 2px 8px rgba(22,163,74,0.12) !important;
  border-radius: 14px !important;
}
.live-feed__icon {
  background: linear-gradient(135deg, #16A34A, #064E3B) !important;
  color: #fff !important;
  box-shadow: 0 4px 10px rgba(22,163,74,0.4) !important;
}
.live-feed__text strong {
  font-size: 0.9rem !important;
  font-weight: 800 !important;
}

/* ============================================================================
   FULL RESPONSIVE OVERHAUL — all breakpoints
   ============================================================================ */

/* ─────────────────────────────────────────────────────────────────────────────
   MOBILE FIRST  ≤ 480 px
───────────────────────────────────────────────────────────────────────────── */
@media (max-width: 480px) {

  /* Typography scale down */
  .display-xl { font-size: clamp(1.7rem, 8vw, 2.2rem) !important; }
  .display-l  { font-size: clamp(1.4rem, 6.5vw, 1.8rem) !important; }

  /* Container */
  .scrapey-container { padding-left: 16px !important; padding-right: 16px !important; }

  /* Header */
  .scrapey-header { padding: 0 16px !important; }
  .scrapey-header__logo img { height: 36px !important; }

  /* ── HERO ───────────────────────────────────────────────────────────────── */
  .hero-section {
    min-height: auto !important;
    padding-top: calc(var(--header-h) + 8px) !important;
    padding-bottom: 40px !important;
    overflow: hidden !important;
  }
  .hero-container { gap: 20px !important; }

  /* Hero copy centred */
  .hero-copy { text-align: center; }
  .hero-actions {
    justify-content: center !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 12px !important;
  }
  .hero-trust-strip {
    font-size: 0.65rem !important;
    padding: 6px 10px !important;
    justify-content: center;
    flex-wrap: wrap;
  }
  .scrapey-btn--lg { padding: 12px 28px !important; font-size: 0.9rem !important; }
  .hero-link { font-size: 0.85rem !important; }

  /* ── PHONE MOCKUP ───────────────────────────────────────────────────────── */
  .hero-visual {
    width: 100% !important;
    display: flex !important;
    justify-content: center !important;
    padding: 40px 16px 20px !important; /* top room for pickup badge */
    overflow: visible !important;
    position: relative !important;
  }
  .upi-phone {
    width: min(220px, 60vw) !important;
    flex-shrink: 0 !important;
  }
  .upi-phone__screen { min-height: 260px !important; }

  /* Card content — prevent text from overflowing the card */
  .upi-card { padding: 12px !important; }
  .upi-card__amount { font-size: 1.7rem !important; }
  .upi-card__label  { font-size: 0.72rem !important; white-space: normal !important; }
  .upi-card__ref    { font-size: 0.68rem !important; white-space: normal !important; }
  .upi-card__app-name { font-size: 0.72rem !important; }

  /* Balance / weight rows */
  .upi-balance {
    padding: 8px 10px !important;
    flex-direction: row !important;
    gap: 6px !important;
  }
  .upi-balance__label {
    font-size: 0.6rem !important;
    text-transform: none !important;   /* remove uppercase that squishes label */
    letter-spacing: 0 !important;
    white-space: nowrap !important;
  }
  .upi-balance__value { font-size: 0.82rem !important; }
  .upi-weight { padding: 8px 10px !important; font-size: 0.7rem !important; }

  /* ── FLOATING BADGES ────────────────────────────────────────────────────── */
  .hero-badge {
    font-size: 0.68rem !important;
    padding: 6px 10px !important;
    gap: 4px !important;
  }
  /* Pickup badge: above phone, centred horizontally */
  .hero-badge--pickup {
    top: 8px !important;
    right: auto !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    white-space: nowrap !important;
  }
  /* Eco badge: below phone on the right — doesn't clash with live feed */
  .hero-badge--eco {
    bottom: -10px !important;
    left: auto !important;
    right: 8px !important;
  }

  /* ── LIVE FEED TOAST ────────────────────────────────────────────────────── */
  .live-feed {
    bottom: 0px !important;
    left: 0px !important;
  }
  .live-feed__toast {
    min-width: 160px !important;
    max-width: 190px !important;
    padding: 8px 10px !important;
    font-size: 0.7rem !important;
    border-radius: 10px !important;
  }
  .live-feed__icon {
    width: 26px !important;
    height: 26px !important;
    font-size: 0.8rem !important;
  }
  .live-feed__text strong { font-size: 0.78rem !important; }

  /* Rates */
  .rates-grid { grid-template-columns: 1fr 1fr !important; gap: 10px !important; }
  .rates-filters { gap: 6px !important; }
  .rates-chip { font-size: 0.72rem !important; padding: 6px 12px !important; }
  .rate-card { padding: 12px !important; }
  .rate-pill__price { font-size: 1.1rem !important; }

  /* Steps */
  .steps-grid { grid-template-columns: 1fr !important; gap: 16px !important; }
  .step-card { min-height: 260px !important; }

  /* Compare */
  .vs-wrap { flex-direction: column !important; gap: 0 !important; }
  .vs-card  { border-radius: 16px !important; }
  .vs-card--bad  { border-radius: 16px 16px 0 0 !important; }
  .vs-card--good { border-radius: 0 0 16px 16px !important; }
  .vs-divider { padding: 8px 0 !important; }
  .vs-badge { width: 40px !important; height: 40px !important; font-size: 0.8rem !important; }
  .compare-section .display-l { font-size: 1.3rem !important; }

  /* Testimonials */
  .testimonials-grid { grid-template-columns: 1fr !important; gap: 16px !important; }
  .testimonial-card { padding: 20px !important; }

  /* Gallery */
  .gallery-grid { grid-template-columns: 1fr 1fr !important; gap: 6px !important; }
  .gallery-view-all { padding: 10px 24px !important; font-size: 0.85rem !important; }

  /* Impact — single column on small mobile */
  .impact-grid { grid-template-columns: 1fr !important; gap: 0 !important; }
  .impact-section .impact-card,
  .impact-grid .impact-card { padding: 16px 20px !important; gap: 14px !important; }
  .impact-card + .impact-card::before { left: 0 !important; top: 0 !important; height: 1px !important; width: 100% !important; }
  .impact-card__number .impact-num { font-size: 1.8rem !important; }

  /* Business */
  .business-inner { flex-direction: column !important; gap: 24px !important; }
  .business-pillars { flex-wrap: wrap !important; gap: 12px !important; }
  .business-pillar { font-size: 0.8rem !important; }

  /* FAQ */
  .faq-list { max-width: 100% !important; }
  .faq-item__trigger { font-size: 0.9rem !important; padding: 14px 16px !important; }

  /* CTA */
  .cta-inner { grid-template-columns: 1fr !important; gap: 24px !important; }
  .cta-heading { font-size: 1.5rem !important; }
  .cta-form-card { padding: 20px !important; }

  /* Footer */
  .scrapey-footer__grid { grid-template-columns: 1fr !important; gap: 24px !important; text-align: left; }
  .scrapey-footer__nav { flex-direction: column !important; gap: 8px !important; align-items: flex-start; }

  /* Scroll-to-top */
  #scroll-top-btn { bottom: 80px !important; right: 16px !important; }
}

/* ─────────────────────────────────────────────────────────────────────────────
   SMALL MOBILE  481 px – 640 px
───────────────────────────────────────────────────────────────────────────── */
@media (min-width: 481px) and (max-width: 640px) {

  .scrapey-container { padding-left: 20px !important; padding-right: 20px !important; }

  .display-xl { font-size: clamp(1.9rem, 7vw, 2.4rem) !important; }
  .display-l  { font-size: clamp(1.6rem, 5.5vw, 2rem) !important; }

  /* Hero */
  .hero-copy { text-align: center; }
  .hero-actions { justify-content: center !important; flex-wrap: wrap !important; }
  .upi-phone { width: 220px !important; }
  .hero-badge--pickup { right: -2% !important; }
  .hero-badge--eco    { left: -2% !important; }

  /* Rates */
  .rates-grid { grid-template-columns: repeat(2, 1fr) !important; }

  /* Steps */
  .steps-grid { grid-template-columns: 1fr !important; }

  /* Compare */
  .vs-wrap { flex-direction: column !important; gap: 0 !important; }
  .vs-card--bad  { border-radius: 16px 16px 0 0 !important; }
  .vs-card--good { border-radius: 0 0 16px 16px !important; }

  /* Testimonials */
  .testimonials-grid { grid-template-columns: 1fr !important; }

  /* Gallery */
  .gallery-grid { grid-template-columns: 1fr 1fr !important; }

  /* Impact */
  .impact-grid { grid-template-columns: 1fr 1fr !important; gap: 0 !important; }
  .impact-section .impact-card,
  .impact-grid .impact-card { padding: 14px 10px !important; gap: 10px !important; }
  .impact-card__icon { width: 38px !important; height: 38px !important; min-width: 38px !important; font-size: 1rem !important; }
  .impact-card__number .impact-num { font-size: clamp(1.2rem, 4.5vw, 1.6rem) !important; }

  /* CTA */
  .cta-inner { grid-template-columns: 1fr !important; }
}

/* ─────────────────────────────────────────────────────────────────────────────
   TABLET  641 px – 1023 px
───────────────────────────────────────────────────────────────────────────── */
@media (min-width: 641px) and (max-width: 1023px) {

  .scrapey-container { padding-left: 28px !important; padding-right: 28px !important; }

  /* Hero layout handled by section 3b / 4b rules below — no overrides here */

  /* Rates */
  .rates-grid { grid-template-columns: repeat(3, 1fr) !important; }

  /* Steps */
  .steps-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 20px !important; }

  /* Compare — stack vertically */
  .vs-wrap { flex-direction: column !important; max-width: 540px; margin-inline: auto !important; gap: 0 !important; }
  .vs-card--bad  { border-radius: 16px 16px 0 0 !important; }
  .vs-card--good { border-radius: 0 0 16px 16px !important; }
  .vs-divider { padding: 10px 0 !important; }

  /* Testimonials */
  .testimonials-grid { grid-template-columns: repeat(2, 1fr) !important; }

  /* Gallery */
  .gallery-grid { grid-template-columns: repeat(3, 1fr) !important; }

  /* Impact */
  .impact-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 16px !important; }

  /* Business */
  .business-inner { flex-direction: column !important; gap: 32px !important; text-align: center; }
  .business-pillars { justify-content: center; }

  /* CTA */
  .cta-inner { grid-template-columns: 1fr !important; max-width: 640px; margin-inline: auto; }

  /* Footer */
  .scrapey-footer__grid { grid-template-columns: 1fr 1fr !important; }
}

/* ─────────────────────────────────────────────────────────────────────────────
   LARGE DESKTOP  ≥ 1280 px
───────────────────────────────────────────────────────────────────────────── */
@media (min-width: 1280px) {

  .scrapey-container { padding-left: 40px !important; padding-right: 40px !important; }

  .hero-container { gap: 80px !important; }

  .rates-grid { grid-template-columns: repeat(4, 1fr) !important; }

  .testimonials-grid { grid-template-columns: repeat(3, 1fr) !important; }

  .impact-grid { grid-template-columns: repeat(4, 1fr) !important; }

  .upi-phone { width: 300px !important; }
  .upi-phone__screen { min-height: 400px !important; }
}

/* ─────────────────────────────────────────────────────────────────────────────
   EXTRA LARGE  ≥ 1440 px
───────────────────────────────────────────────────────────────────────────── */
@media (min-width: 1440px) {

  :root { --max-width: 1360px; }

  .display-xl { font-size: 4rem !important; }
  .display-l  { font-size: 3rem !important; }

  .hero-badge--pickup { right: -10% !important; }
  .hero-badge--eco    { left: -12% !important; }
}

/* ─────────────────────────────────────────────────────────────────────────────
   UNIVERSAL TOUCH / MOBILE HELPERS
───────────────────────────────────────────────────────────────────────────── */

/* Prevent any element from overflowing the viewport horizontally */
@media (max-width: 1023px) {

  /* Remove animation complexity on low-power mobile */
  .hero-visual { animation: none !important; }
  .hero-blob   { display: none !important; }
  .hero-deco-ring { display: none !important; }

  /* Rate ticker readable on small screens */
  .rate-ticker__item { font-size: 0.8rem !important; padding: 0 16px !important; }

  /* Nav CTA button smaller */
  .scrapey-header__cta { padding: 8px 16px !important; font-size: 0.8rem !important; }

  /* Wave dividers simpler height */
  .wave-divider svg { height: 36px !important; }

  /* Comparison table horizontal scroll on small screens */
  .compare-section .vs-wrap { width: 100% !important; }

  /* Gallery item label text */
  .gallery-item__label { font-size: 0.72rem !important; padding: 6px 10px !important; }

  /* WhatsApp float button smaller */
  .scrapey-whatsapp-float { width: 52px !important; height: 52px !important; bottom: 20px !important; right: 16px !important; }

  /* Scroll progress bar always visible */
  #scrapey-progress-bar { height: 3px !important; }

  /* Steps connector line hidden on mobile */
  .steps-grid::after { display: none !important; }

  /* FAQ max-width full on mobile */
  .faq-list { max-width: 100% !important; }

  /* CTA form card padding */
  .cta-form-card { padding: 24px 20px !important; }

  /* Trust strip in CTA */
  .cta-trust-strip { flex-wrap: wrap !important; gap: 8px !important; font-size: 0.72rem !important; }

  /* Rates section footnote */
  .rates-footer { text-align: center !important; }
}

/* ─────────────────────────────────────────────────────────────────────────────
   PRINT / ACCESSIBILITY SAFE FALLBACK
───────────────────────────────────────────────────────────────────────────── */
@media (max-width: 1023px) {
  /* Ensure all section headings always visible (no gradient-clip failure) */
  .scrapey-section-header .display-l,
  .scrapey-section-header .display-xl {
    background-image: none !important;
    -webkit-text-fill-color: var(--color-charcoal) !important;
    color: var(--color-charcoal) !important;
    animation: none !important;
  }

  /* Dark section overrides */
  .business-section .scrapey-section-header .display-l,
  .impact-section  .scrapey-section-header .display-l {
    -webkit-text-fill-color: #fff !important;
    color: #fff !important;
  }
}

/* ============================================================================
   RESPONSIVE COMPLETE OVERHAUL v2 — All Screen Sizes
   Covers: 320px · 360px · 480px · 640px · 768px · 1024px · 1280px · 1440px
   ============================================================================ */

/* ── 1. Responsive header height ─────────────────────────────────────────── */
/* Reduce fixed header height on mobile/tablet so hero content isn't pushed too far */
@media (max-width: 1023px) {
  :root {
    --header-h: 64px;
  }
  .scrapey-header__inner {
    height: 64px !important;
    padding: 0 20px !important;
  }
  .scrapey-header__logo img,
  .scrapey-header__logo .custom-logo,
  img.custom-logo {
    height: 48px !important;
    max-width: 180px !important;
  }
}

/* ── 2. Hero section — min-height fix for all non-desktop sizes ──────────── */
@media (max-width: 1023px) {
  .hero-section {
    min-height: auto !important;
    padding-bottom: 40px !important;
  }
}
@media (max-width: 767px) {
  .hero-section {
    padding-top: calc(var(--header-h) + 20px) !important;
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .hero-section {
    padding-top: calc(var(--header-h) + 32px) !important;
    min-height: 75vh !important;
    display: flex !important;
    align-items: center !important;
  }
}

/* ── 3. Hero container — single column on small mobile only ──────────────── */
@media (max-width: 767px) {
  .hero-container {
    grid-template-columns: 1fr !important;
    justify-items: center !important;
    text-align: center !important;
    gap: 24px !important;
  }
  .hero-copy {
    text-align: center !important;
    width: 100% !important;
    max-width: 100% !important;
  }
  .hero-actions {
    justify-content: center !important;
    flex-direction: column !important;
    align-items: center !important;
  }
  .hero-trust-strip {
    justify-content: center !important;
  }
}

/* ── 3b. Hero container — two column on tablet (768–1023px) ──────────────── */
@media (min-width: 768px) and (max-width: 1023px) {
  .hero-section {
    overflow: hidden !important;
  }
  .hero-container {
    grid-template-columns: minmax(0, 58fr) minmax(0, 42fr) !important;
    gap: 20px !important;
    align-items: center !important;
  }
  .hero-copy {
    text-align: left !important;
    min-width: 0 !important;
  }
  .hero-actions {
    justify-content: flex-start !important;
  }
  .hero-trust-strip {
    justify-content: flex-start !important;
  }
  .hero-visual {
    justify-content: center !important;
    min-width: 0 !important;
  }
}

/* ── 4. Hero visual — mobile (single column) ────────────────────────────── */
@media (max-width: 767px) {
  .hero-visual {
    width: 100% !important;
    display: flex !important;
    justify-content: center !important;
    padding: 12px 20px 20px !important;
    position: relative !important;
    overflow: visible !important;
  }

  /* Phone size — fits comfortably in single-column layout */
  .upi-phone {
    width: min(230px, 60vw) !important;
    flex-shrink: 0 !important;
    position: relative !important;
    z-index: 1 !important;
  }

  /* Phone screen — tighten so content doesn't get cut off */
  .upi-phone__screen {
    min-height: 240px !important;
    padding: 12px 10px 10px !important;
    gap: 8px !important;
  }

  /* UPI card — reduce internal spacing */
  .upi-card {
    padding: 10px 12px !important;
  }
  .upi-card__amount {
    font-size: 1.8rem !important;
  }
  .upi-card__label {
    font-size: 0.72rem !important;
    margin-bottom: 6px !important;
    white-space: normal !important;
  }
  .upi-card__ref {
    font-size: 0.65rem !important;
    white-space: normal !important;
    line-height: 1.4 !important;
  }

  /* Balance row */
  .upi-balance {
    padding: 7px 10px !important;
  }
  .upi-balance__label {
    font-size: 0.58rem !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
    white-space: nowrap !important;
  }
  .upi-balance__value {
    font-size: 0.82rem !important;
  }

  /* Weight row */
  .upi-weight {
    padding: 6px 10px !important;
    font-size: 0.65rem !important;
  }

  /* ── Hide floating badges on mobile — they overlap the phone ── */
  .hero-badge {
    display: none !important;
  }

  /* ── Live feed — position BELOW the phone, inline (not absolute) ── */
  .live-feed {
    position: static !important;
    display: flex !important;
    justify-content: center !important;
    margin-top: 10px !important;
    left: auto !important;
    bottom: auto !important;
    width: 100% !important;
    padding: 0 16px !important;
    overflow: visible !important;
  }
  .live-feed__toast {
    min-width: 0 !important;
    max-width: 100% !important;
    width: 100% !important;
    font-size: 0.72rem !important;
    padding: 8px 12px !important;
    border-radius: 10px !important;
    /* Slide up instead of left — avoids left-clip from overflow:hidden on hero-visual */
    transform: translateY(12px) scale(0.96) !important;
  }
  .live-feed__toast.live-feed__toast--in {
    transform: translateY(0) scale(1) !important;
  }
  .live-feed__toast.live-feed__toast--out {
    transform: translateY(-8px) scale(0.97) !important;
  }
  .live-feed__icon {
    width: 28px !important;
    height: 28px !important;
    font-size: 0.85rem !important;
    flex-shrink: 0 !important;
  }
  .live-feed__text strong { font-size: 0.8rem !important; }
  .live-feed__sub { font-size: 0.65rem !important; }
}

/* ── 4b. Hero visual — tablet ────────────────────────────────────────────── */
@media (min-width: 768px) and (max-width: 1023px) {
  .hero-visual {
    overflow: hidden !important;
    padding: 16px 0 16px !important;
    align-items: center !important;
    justify-content: center !important;
  }
  .upi-phone {
    width: min(200px, 26vw) !important;
    flex-shrink: 0 !important;
    margin: 0 auto !important;
  }
  .upi-phone__screen {
    min-height: 260px !important;
  }
  /* Hide floating badges at tablet — too cramped in 45% column */
  .hero-badge {
    display: none !important;
  }
  /* Live feed: show inside the column, below the phone */
  .live-feed {
    position: absolute !important;
    bottom: 12px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    right: auto !important;
    top: auto !important;
  }
  .live-feed__toast {
    min-width: 160px !important;
    max-width: 200px !important;
    font-size: 0.7rem !important;
    padding: 8px 10px !important;
  }
  .live-feed__icon {
    width: 26px !important;
    height: 26px !important;
    font-size: 0.8rem !important;
    flex-shrink: 0 !important;
  }
}

/* ── 5. Rate cards — mobile layout ──────────────────────────────────────── */
@media (max-width: 767px) {
  .rates-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    grid-auto-rows: 160px !important;
    gap: 10px !important;
  }
  .rate-card {
    min-height: 160px !important;
    padding: 0 !important;
  }
  /* Keep the full-bleed photo visible */
  .rate-card__thumb {
    display: block !important;
  }
  .rate-card__thumb img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
  }
  /* Tighten text positions for smaller card height */
  .rate-card__name {
    font-size: 0.78rem !important;
    bottom: 48px !important;
    left: 10px !important;
    right: 10px !important;
  }
  .rate-card .rate-pill {
    bottom: 10px !important;
    left: 10px !important;
  }
  .rate-card .rate-pill .rate-pill__price {
    font-size: 0.85rem !important;
  }
  .rate-card .rate-pill .rate-pill__unit {
    font-size: 0.65rem !important;
  }
  .rate-card__icon {
    width: 36px !important;
    height: 36px !important;
    font-size: 1.1rem !important;
    top: 8px !important;
    right: 8px !important;
    background: rgba(255,255,255,0.92) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    color: var(--color-forest) !important;
    border: none !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.25) !important;
  }
  .rate-card[data-category="paper"]   .rate-card__icon { background: #FEF3C7 !important; color: #92400E !important; }
  .rate-card[data-category="plastic"] .rate-card__icon { background: #E0F2FE !important; color: #0369A1 !important; }
  .rate-card[data-category="metal"]   .rate-card__icon { background: #FEE2E2 !important; color: #B91C1C !important; }
  .rate-card[data-category="ewaste"]  .rate-card__icon { background: #F3E8FF !important; color: #7E22CE !important; }
  .rate-card__tag {
    display: none !important;
  }
  .rate-card__cta {
    display: none !important;
  }
}

/* ── 6. Steps grid — 1-col on mobile, 3-col on tablet ───────────────────── */
@media (max-width: 640px) {
  .steps-grid {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }
  .step-card {
    /* Enough height so the number circle (top:20px, 64px tall) doesn't overlap content */
    min-height: 240px !important;
    padding: 0 !important;
  }
  /* Reduce the giant decorative background number on narrow screens */
  .step-card::before {
    font-size: 6rem !important;
    right: 8px !important;
  }
  /* Shrink the number circle slightly */
  .step-card__number {
    width: 52px !important;
    height: 52px !important;
    font-size: var(--text-2xl) !important;
    top: 16px !important;
    left: 16px !important;
  }
  /* Keep title/desc at bottom, tighten padding */
  .step-card__title {
    font-size: var(--text-xl) !important;
    padding: 0 var(--space-4) !important;
    margin-bottom: var(--space-1) !important;
  }
  .step-card__desc {
    font-size: 0.84rem !important;
    padding: 0 var(--space-4) var(--space-4) !important;
    line-height: 1.5 !important;
  }
  /* Illustration fills full card height */
  .step-card__illustration {
    position: absolute !important;
    inset: 0 !important;
    height: 100% !important;
  }
  /* Icon placeholder — smaller on mobile */
  .step-card__icon-placeholder i {
    font-size: 3.5rem !important;
  }
}

@media (min-width: 641px) and (max-width: 1023px) {
  .steps-grid {
    grid-template-columns: repeat(3, 1fr) !important;
  }
  .step-card {
    min-height: 340px !important;
  }
}

/* ── 7. Compare (VS) section ─────────────────────────────────────────────── */
@media (max-width: 767px) {
  .vs-wrap {
    grid-template-columns: 1fr !important;
    max-width: 100% !important;
  }
  .vs-card--bad  { border-radius: var(--radius-2xl) var(--radius-2xl) 0 0 !important; }
  .vs-card--good { border-radius: 0 0 var(--radius-2xl) var(--radius-2xl) !important; }
  .vs-divider {
    width: 100% !important;
    height: 44px !important;
    background: linear-gradient(to right, var(--color-charcoal) 50%, #064E3B 50%) !important;
  }
}

/* ── 8. Testimonials ─────────────────────────────────────────────────────── */
@media (max-width: 640px) {
  .testimonials-grid {
    grid-template-columns: 1fr !important;
  }
  .testimonial-card {
    padding: var(--space-6) !important;
  }
  .testimonial-card__quote {
    font-size: var(--text-sm) !important;
  }
}

@media (min-width: 641px) and (max-width: 1023px) {
  .testimonials-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* ── 9. Gallery grid ─────────────────────────────────────────────────────── */
@media (max-width: 480px) {
  .gallery-grid {
    grid-template-columns: 1fr !important;
    grid-template-rows: unset !important;
  }
  .gallery-item { height: 180px !important; }
}

@media (min-width: 481px) and (max-width: 767px) {
  .gallery-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    grid-template-rows: repeat(3, 180px) !important;
  }
}

/* ── 10. Business section ────────────────────────────────────────────────── */
@media (max-width: 1023px) {
  .business-inner {
    grid-template-columns: 1fr !important;
    gap: var(--space-8) !important;
    text-align: center !important;
  }
  .business-pillars {
    justify-content: center !important;
    flex-wrap: wrap !important;
  }
  .business-stats-card {
    max-width: 480px !important;
    margin: 0 auto !important;
  }
  /* Stat items: center the icon+text pair but keep text left-aligned */
  .business-stats-item {
    justify-content: flex-start !important;
    text-align: left !important;
  }
  .business-stats-item > div {
    text-align: left !important;
  }
  .business-stats-item strong,
  .business-stats-item span {
    text-align: left !important;
  }
}

/* ── 11. Impact grid ─────────────────────────────────────────────────────── */
@media (max-width: 480px) {
  #impact .impact-grid,
  .impact-grid {
    grid-template-columns: 1fr !important;
  }
  #impact .impact-card + .impact-card {
    border-left: none !important;
    border-top: 1px solid rgba(255,255,255,0.12) !important;
  }
}

@media (min-width: 481px) and (max-width: 767px) {
  #impact .impact-grid,
  .impact-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  #impact .impact-card:nth-child(odd) {
    border-left: none !important;
  }
  #impact .impact-card:nth-child(3),
  #impact .impact-card:nth-child(4) {
    border-top: 1px solid rgba(255,255,255,0.12) !important;
  }
}

/* ── 12. CTA section ─────────────────────────────────────────────────────── */
@media (max-width: 1023px) {
  .cta-section {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .cta-inner {
    grid-template-columns: 1fr !important;
    gap: var(--space-8) !important;
    max-width: 640px !important;
    margin: 0 auto !important;
  }
  .cta-copy {
    text-align: center !important;
  }
  .cta-whatsapp {
    margin-left: auto !important;
    margin-right: auto !important;
    display: inline-flex !important;
  }
  .cta-hours {
    justify-content: center !important;
  }
}

@media (max-width: 480px) {
  .cta-inner {
    max-width: 100% !important;
    gap: var(--space-6) !important;
  }
  .cta-heading {
    font-size: clamp(1.4rem, 6vw, 1.8rem) !important;
  }
  .cta-card-body {
    padding: 16px 16px 8px !important;
  }
  .cta-card-header {
    padding: 16px !important;
  }
}

/* ── 13. Footer ──────────────────────────────────────────────────────────── */
@media (max-width: 640px) {
  .scrapey-footer__grid {
    grid-template-columns: 1fr !important;
    gap: var(--space-8) !important;
    text-align: left !important;
  }
  .scrapey-footer__social {
    justify-content: flex-start !important;
  }
  .scrapey-footer__bottom-inner {
    flex-direction: column !important;
    align-items: flex-start !important;
    text-align: left !important;
  }
  .scrapey-footer__bottom-links {
    justify-content: flex-start !important;
    flex-wrap: wrap !important;
    gap: var(--space-3) !important;
  }
  .scrapey-footer__top {
    padding: var(--space-10) 0 var(--space-8) !important;
  }
  /* Column headings — left aligned */
  .scrapey-footer__col-title {
    text-align: left !important;
  }
  /* Link list items — left aligned */
  .scrapey-footer__links li,
  .scrapey-footer__links a {
    justify-content: flex-start !important;
    text-align: left !important;
  }
  /* Brand tagline and desc — left aligned */
  .scrapey-footer__tagline,
  .scrapey-footer__desc {
    text-align: left !important;
  }
}

@media (min-width: 641px) and (max-width: 1023px) {
  .scrapey-footer__grid {
    grid-template-columns: 1fr 1fr !important;
    gap: var(--space-8) !important;
  }
}

/* ── 14. Typography scale — tablet ──────────────────────────────────────── */
@media (min-width: 768px) and (max-width: 1023px) {
  /* In 2-col hero, display-xl sits beside the phone — keep it readable */
  .display-xl { font-size: clamp(1.8rem, 3.5vw, 2.6rem) !important; }
  .display-l  { font-size: clamp(1.6rem, 3vw, 2rem) !important; }
}

@media (min-width: 641px) and (max-width: 767px) {
  .display-xl { font-size: clamp(1.9rem, 5vw, 2.4rem) !important; }
  .display-l  { font-size: clamp(1.6rem, 4vw, 2rem) !important; }
}

/* ── 15. Very small screens (320 – 360 px) ───────────────────────────────── */
@media (max-width: 360px) {
  :root { --header-h: 58px; }

  .scrapey-header__inner {
    height: 58px !important;
    padding: 0 12px !important;
  }
  .scrapey-header__logo img,
  .scrapey-header__logo .custom-logo,
  img.custom-logo {
    height: 40px !important;
    max-width: 130px !important;
  }

  .display-xl { font-size: clamp(1.5rem, 7.5vw, 1.9rem) !important; }
  .display-l  { font-size: clamp(1.3rem, 6vw, 1.6rem) !important; }

  .scrapey-container { padding-left: 12px !important; padding-right: 12px !important; }

  .hero-section {
    padding-top: calc(var(--header-h) + 16px) !important;
  }
  .upi-phone {
    width: min(200px, 56vw) !important;
  }
  .hero-trust-strip {
    font-size: 0.6rem !important;
    padding: 5px 8px !important;
    gap: 4px !important;
  }
  .scrapey-btn--lg {
    padding: 10px 20px !important;
    font-size: 0.85rem !important;
  }

  .rates-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    grid-auto-rows: 140px !important;
    gap: 8px !important;
  }
  .rate-card {
    min-height: 140px !important;
    padding: 0 !important;
  }
  .rate-card__name {
    font-size: 0.7rem !important;
    bottom: 42px !important;
  }
  .rate-card__icon {
    width: 32px !important;
    height: 32px !important;
    font-size: 1rem !important;
    background: rgba(255,255,255,0.92) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    color: var(--color-forest) !important;
    border: none !important;
    box-shadow: 0 2px 6px rgba(0,0,0,0.2) !important;
  }
  .rate-card[data-category="paper"]   .rate-card__icon { background: #FEF3C7 !important; color: #92400E !important; }
  .rate-card[data-category="plastic"] .rate-card__icon { background: #E0F2FE !important; color: #0369A1 !important; }
  .rate-card[data-category="metal"]   .rate-card__icon { background: #FEE2E2 !important; color: #B91C1C !important; }
  .rate-card[data-category="ewaste"]  .rate-card__icon { background: #F3E8FF !important; color: #7E22CE !important; }

  .testimonial-card { padding: var(--space-4) !important; }
  .testimonial-card__quote { font-size: 0.82rem !important; }

  .faq-item__trigger {
    font-size: 0.85rem !important;
    padding: 12px 14px !important;
    min-height: 52px !important;
  }

  .cta-heading { font-size: 1.3rem !important; }
  #pickup .cta-form-card { border-radius: 12px !important; }

  .business-pillar { font-size: 0.75rem !important; padding: var(--space-2) var(--space-3) !important; }

  .scrapey-whatsapp-float {
    width: 48px !important;
    height: 48px !important;
    font-size: 1.3rem !important;
    bottom: 16px !important;
    right: 12px !important;
  }
}

/* ── 16. Landscape mobile (max-height 480px) ─────────────────────────────── */
@media (max-height: 480px) and (orientation: landscape) {
  .hero-section {
    min-height: auto !important;
    padding-top: calc(var(--header-h) + 16px) !important;
    padding-bottom: 24px !important;
  }
  .hero-container {
    grid-template-columns: 1fr 1fr !important;
    gap: 20px !important;
  }
  .hero-copy { text-align: left !important; }
  .hero-actions { justify-content: flex-start !important; }
  .upi-phone { width: min(180px, 35vw) !important; }
  .upi-phone__screen { min-height: 220px !important; }
  .hero-badge { display: none !important; }
}

/* ── 17. Overflow safety — no horizontal scroll on any device ────────────── */
body {
  overflow-x: hidden !important;
}

/* Prevent badges/live-feed from causing horizontal overflow on mobile */
@media (max-width: 1023px) {
  .hero-section {
    overflow-x: hidden !important;
  }
}

/* ── 18. Rate ticker on very small screens ───────────────────────────────── */
@media (max-width: 360px) {
  .rate-ticker__item {
    font-size: 0.7rem !important;
    padding: 0 10px !important;
  }
}

/* ── 19. Nav mobile menu improvements ───────────────────────────────────── */
@media (max-width: 767px) {
  .scrapey-header__mobile-list {
    padding: var(--space-3) var(--space-4) !important;
  }
  .scrapey-header__mobile-link {
    font-size: var(--text-base) !important;
    min-height: 48px !important;
  }
  .scrapey-header__mobile-actions {
    padding: var(--space-3) var(--space-4) var(--space-5) !important;
  }
}

/* ── 20. Scroll-to-top button ────────────────────────────────────────────── */
@media (max-width: 480px) {
  #scroll-top-btn {
    bottom: 76px !important;
    right: 12px !important;
    width: 40px !important;
    height: 40px !important;
  }
}

/* ── 21. Hero visual — column layout on mobile (live feed below phone) ───── */
@media (max-width: 767px) {
  .hero-visual {
    flex-direction: column !important;
    align-items: center !important;
  }
}

/* ── 22. Admin-bar hero clearance — override general !important rule ─────── */
/* WordPress admin bar is 46px on mobile (≤782px) and 32px on desktop.       */
/* Our general rule uses !important so we need a later !important to win.    */
@media screen and (max-width: 782px) {
  body.admin-bar .hero-section {
    padding-top: calc(var(--header-h) + 56px) !important;
  }
}
@media screen and (min-width: 783px) {
  body.admin-bar .hero-section {
    padding-top: calc(var(--header-h) + 40px) !important;
  }
}

/* ============================================================================
   END OF SCRAPEY DESIGN SYSTEM
   ============================================================================ */
