/* ==========================================================================
   GiveLocally — Design tokens
   ========================================================================== */
:root{
  /* Color system — aligned to the GiveLocally logo (green + navy) */
  --color-bg:              #F7F9F8;
  --color-bg-alt:          #FFFFFF;
  --color-navy:            #222B38;
  --color-navy-soft:       #303B4A;
  --color-primary:         #4D9F3C;
  --color-primary-deep:    #3C7E2E;
  --color-primary-light:   #E3F3DC;
  --color-ink:             #1C2430;
  --color-ink-soft:        #5C6670;
  --color-line:            #E2E6E3;
  --color-success-bg:      #E6F4EC;
  --color-success-text:    #1F7A4D;
  --color-accent-red:      #C0392B;

  --font-display: 'Poppins', sans-serif;
  --font-body: 'Inter', sans-serif;

  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-lg: 22px;
  --radius-full: 999px;

  --shadow-sm: 0 2px 8px rgba(28,36,48,0.06);
  --shadow-md: 0 8px 24px rgba(28,36,48,0.10);
  --shadow-lg: 0 20px 50px rgba(28,36,48,0.16);

  --container-w: 1180px;
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  font-family: var(--font-body);
  color: var(--color-ink);
  background: var(--color-bg);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
img{ max-width:100%; display:block; }
a{ text-decoration:none; color:inherit; }
ul,ol{ list-style:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; }

.container{
  max-width: var(--container-w);
  margin: 0 auto;
  padding: 0 24px;
}

/* ==========================================================================
   Buttons — ONE consistent system across the whole site (critique fix)
   ========================================================================== */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  font-family: var(--font-display);
  font-weight:700;
  border-radius: var(--radius-full);
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
  white-space:nowrap;
}
.btn--sm{ padding:10px 20px; font-size:0.875rem; }
.btn--lg{ padding:16px 30px; font-size:1rem; }

.btn--primary{
  background: var(--color-primary);
  color:#fff;
  box-shadow: var(--shadow-sm);
}
.btn--primary:hover{ background: var(--color-primary-deep); transform: translateY(-2px); box-shadow: var(--shadow-md); }

.btn--ghost{
  background: transparent;
  color: var(--color-navy);
  border: 1.5px solid var(--color-line);
}
.btn--ghost:hover{ border-color: var(--color-navy); transform: translateY(-2px); }

.btn--light{
  background:#fff;
  color: var(--color-primary);
}
.btn--light:hover{ transform: translateY(-2px); box-shadow: var(--shadow-md); }

.btn--ghost-light{
  background: transparent;
  color:#fff;
  border: 1.5px solid rgba(255,255,255,0.5);
}
.btn--ghost-light:hover{ border-color:#fff; transform: translateY(-2px); }

.btn--dark{
  background: var(--color-navy);
  color:#fff;
  box-shadow: var(--shadow-sm);
}
.btn--dark:hover{ transform: translateY(-2px); box-shadow: var(--shadow-md); }

/* ==========================================================================
   Top utility bar + Header
   ========================================================================== */
.topbar{
  background: var(--color-navy);
  color: rgba(255,255,255,0.7);
  font-size: 0.8rem;
}
.topbar__inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding: 8px 24px;
}
.topbar__left{ display:flex; gap:24px; }
.topbar a:hover{ color:#fff; }

.header{
  position: sticky;
  top:0;
  z-index: 100;
  background: rgba(247,249,248,0.9);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--color-line);
}
.header__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 14px 24px;
  gap: 24px;
}
.logo{ display:flex; align-items:center; gap:10px; }
.logo__img{
  height: 44px;
  width: auto;
  display:block;
}
.logo__chip{
  display:inline-flex;
  align-items:center;
  background:#fff;
  border-radius: var(--radius-sm);
  padding: 6px 12px;
}
.nav{
  display:flex;
  gap: 32px;
  margin-left:auto;
  font-weight:600;
  font-size:0.92rem;
  color: var(--color-ink-soft);
}
.nav a:hover{ color: var(--color-primary); }
.nav-toggle{
  display:none;
  flex-direction:column;
  gap:5px;
  width: 28px;
}
.nav-toggle span{
  height:2px; width:100%;
  background: var(--color-ink);
  border-radius:2px;
}

/* ==========================================================================
   Hero
   ========================================================================== */
.hero{
  position: relative;
  color: var(--color-navy);
  background: #fcf1e0;
  overflow: hidden;
  min-height: 88vh;
  display:flex;
  align-items:center;
  padding: 110px 0 64px;
}
.hero__bg{
  position:absolute; inset:0;
  background: url('assets/hero-banner.png') 80px center / cover no-repeat;
}
.hero__inner{
  position:relative;
  width:100%;
}
.hero__content{
  max-width: 520px;
}
.pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 8px 16px;
  border-radius: var(--radius-full);
  font-size:0.8rem;
  font-weight:600;
  margin-bottom: 22px;
}
.pill--accent{
  background: rgba(255,255,255,0.7);
  color: var(--color-primary-deep);
  border: 1px solid rgba(77,159,60,0.3);
}
.pill__dot{
  width:7px; height:7px;
  border-radius:50%;
  background: var(--color-primary);
  box-shadow: 0 0 0 0 rgba(77,159,60,0.6);
  animation: pulse 2s infinite;
}
@keyframes pulse{
  0%{ box-shadow: 0 0 0 0 rgba(77,159,60,0.5); }
  70%{ box-shadow: 0 0 0 6px rgba(77,159,60,0); }
  100%{ box-shadow: 0 0 0 0 rgba(77,159,60,0); }
}
.pill--success{
  background: var(--color-success-bg);
  color: var(--color-success-text);
  margin-top: 14px;
}
.hero__title{
  font-family: var(--font-display);
  font-size: clamp(2.1rem, 4.2vw, 3rem);
  line-height: 1.15;
  font-weight: 600;
  margin-bottom: 22px;
  letter-spacing: -0.01em;
  color: var(--color-navy);
}
.hero__title em{
  font-style: italic;
  color: var(--color-primary-deep);
}
.hero__underline{
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 4px;
}
.hero__subtitle{
  font-size: 1.05rem;
  color: var(--color-ink-soft);
  max-width: 460px;
  margin-bottom: 28px;
}
.hero__perks{
  display:flex;
  align-items:center;
  gap: 16px;
  margin-bottom: 32px;
  font-weight:700;
  font-size: 1rem;
  color: var(--color-primary-deep);
}
.hero__perk{
  display:flex;
  align-items:center;
  gap: 8px;
}
.hero__perk-icon{ font-size: 1.1rem; }
.hero__perk-divider{
  width: 1px;
  height: 22px;
  background: var(--color-line);
}
.hero__ctas{
  display:flex;
  gap: 14px;
  flex-wrap: wrap;
}
.hero__ctas--center{ justify-content:center; }
.btn--store{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  background: var(--color-navy);
  color:#fff;
  border-radius: var(--radius-md);
  padding: 10px 20px;
  transition: transform .2s ease, box-shadow .2s ease;
}
.btn--store:hover{ transform: translateY(-2px); box-shadow: var(--shadow-md); }
.btn--store small{ display:block; font-size: 0.62rem; letter-spacing: 0.04em; opacity: 0.7; }
.btn--store strong{ display:block; font-size: 0.95rem; font-family: var(--font-display); }
.btn--store-outline{
  background: transparent;
  border: 1.5px solid var(--color-navy);
  color: var(--color-navy);
}
.hero__note{
  margin-top:22px;
  font-size: 0.85rem;
  color: var(--color-ink-soft);
  display:flex;
  align-items:center;
  gap:8px;
}
.hero__note-icon{
  color: var(--color-primary);
  font-weight:800;
}


/* ==========================================================================
   Section generic
   ========================================================================== */
.section{ padding: 100px 0; }
.section-head{ max-width: 640px; margin: 0 auto 56px; text-align:center; }
.section-head--light{ color:#fff; }
.eyebrow{
  display:block;
  font-size:0.78rem;
  font-weight:800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-primary);
  margin-bottom: 14px;
}
.eyebrow--light{ color:#8FCF7E; }
.h2{
  font-family: var(--font-display);
  font-size: clamp(1.7rem, 3vw, 2.3rem);
  font-weight: 600;
  line-height:1.25;
  color: var(--color-ink);
  letter-spacing: -0.01em;
}
.h2--light{ color:#fff; }
.section-head__sub{
  margin-top: 14px;
  color: var(--color-ink-soft);
  font-size: 1.02rem;
}
.body-text{ color: var(--color-ink-soft); font-size: 1rem; margin-bottom: 22px; }

/* Problem section */
.problem{ background: var(--color-bg-alt); }
.problem__inner{
  display:grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: 72px;
  align-items:center;
}
.problem__phone-img{
  max-width: 320px;
  margin: 0 auto;
  filter: drop-shadow(0 30px 40px rgba(28,36,48,0.18));
}
.problem__lede{
  font-size: 1.15rem;
  font-weight:600;
  color: var(--color-primary);
  margin: 14px 0 18px;
}
.trust-chip{
  display:flex;
  align-items:center;
  gap: 14px;
  background: var(--color-bg);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-md);
  padding: 14px 18px;
}
.trust-chip__icon{ font-size: 1.4rem; }
.trust-chip strong{ display:block; font-size:0.92rem; }
.trust-chip span{ font-size: 0.82rem; color: var(--color-ink-soft); }

/* How it works */
.how-it-works{ background: var(--color-bg); }
.how-it-works__grid{
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 32px;
  align-items: center;
}
.how-col{
  background: var(--color-bg-alt);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  padding: 36px 32px;
  box-shadow: var(--shadow-sm);
  transition: transform .25s ease, box-shadow .25s ease;
}
.how-col:hover{ transform: translateY(-3px); box-shadow: var(--shadow-md); }
.how-col__title{
  display:flex;
  align-items:center;
  gap:10px;
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight:600;
  margin-bottom: 30px;
}
.how-col__icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:34px; height:34px;
  border-radius:50%;
  font-size:0.95rem;
}
.how-col__title--give .how-col__icon{ background: #E4E8EC; color: var(--color-navy); }
.how-col__title--receive .how-col__icon{ background: var(--color-primary-light); color: var(--color-primary-deep); }
.steps{
  display:flex;
  flex-direction:column;
  gap: 28px;
  position: relative;
}
.steps::before{
  content:'';
  position:absolute;
  left: 18px;
  top: 24px;
  bottom: 24px;
  width: 0;
  border-left: 2px dotted var(--color-ink-soft);
  opacity: 0.35;
  z-index:0;
}
.step{
  display:flex;
  gap: 18px;
  position: relative;
  z-index:1;
}
.step strong{ display:block; font-size:1rem; margin-bottom:4px; }
.step p{ font-size: 0.92rem; color: var(--color-ink-soft); }
.step__num{
  flex: 0 0 36px;
  width:36px; height:36px;
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-weight:800;
  font-family: var(--font-display);
  color:#fff;
  box-shadow: 0 0 0 4px var(--color-bg-alt);
}
.step__num--give{ background: var(--color-navy); }
.step__num--receive{ background: var(--color-primary); }
.how-divider{
  display:flex;
  align-items:center;
  justify-content:center;
}
.how-divider__node{
  width: 56px; height:56px;
  border-radius:50%;
  background: var(--color-navy);
  color:#fff;
  box-shadow: var(--shadow-md);
  animation: spin-subtle 6s linear infinite;
  display:flex; align-items:center; justify-content:center;
  font-size: 1.3rem;
}
@keyframes spin-subtle{
  0%, 40%{ transform: rotate(0deg); }
  60%, 100%{ transform: rotate(360deg); }
}

/* Categories — light surface to match approved reference */
.categories{ background: var(--color-bg); }
.category-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-bottom: 36px;
}
.cat-card{
  position:relative;
  background: var(--color-bg-alt);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  padding: 26px;
  color: var(--color-ink);
  transition: transform .25s ease, box-shadow .25s ease;
}
.cat-card:hover{ transform: translateY(-4px); box-shadow: var(--shadow-md); }
.cat-card__icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width: 48px; height:48px;
  border-radius: var(--radius-sm);
  font-size: 1.4rem;
  margin-bottom: 16px;
}
.cat-card h3{ font-family: var(--font-display); font-size:1.1rem; margin-bottom:8px; }
.cat-card p{ font-size: 0.88rem; color: var(--color-ink-soft); }
.cat-card__badge{
  position:absolute;
  top:22px; right:22px;
  background: var(--color-success-text);
  color:#fff;
  font-size: 0.68rem;
  font-weight:700;
  padding: 4px 10px;
  border-radius: var(--radius-full);
}
.cat-card__badge--urgent{ background: #6A4FB0; }
.cat-card__tags{ display:flex; gap:8px; margin-top:12px; flex-wrap:wrap; }
.cat-card__tags span{
  font-size: 0.72rem;
  color: var(--color-ink-soft);
  background: var(--color-bg);
  border: 1px solid var(--color-line);
  padding: 3px 9px;
  border-radius: var(--radius-full);
}

.banner-card{
  display:flex;
  align-items:center;
  gap: 20px;
  background: var(--color-accent-red);
  border-radius: var(--radius-lg);
  padding: 24px 28px;
  transition: transform .2s ease;
}
.banner-card:hover{ transform: translateY(-2px); }
.banner-card__icon{
  font-size: 1.8rem;
  background: rgba(255,255,255,0.15);
  width: 56px; height:56px;
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
}
.banner-card__copy{ flex:1; color:#fff; }
.banner-card__copy strong{ display:block; font-size:1.05rem; margin-bottom:4px; }
.banner-card__copy p{ font-size: 0.88rem; color: rgba(255,255,255,0.78); }

/* Trust */
.trust{ background: var(--color-bg-alt); }
.trust-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.trust-card{
  background: var(--color-bg);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  padding: 26px;
  position:relative;
  transition: transform .25s ease, box-shadow .25s ease;
}
.trust-card:hover{ transform: translateY(-4px); box-shadow: var(--shadow-md); }
.trust-card__num{
  position:absolute;
  top:20px; right:22px;
  font-family: var(--font-display);
  font-weight:800;
  font-size: 0.85rem;
  color: var(--color-line);
}
.trust-card__icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width: 44px; height:44px;
  border-radius:50%;
  background:#fff;
  border: 1px solid var(--color-line);
  font-size: 1.2rem;
  font-weight:800;
  margin-bottom: 18px;
}
.trust-card h3{ font-family: var(--font-display); font-size: 1.02rem; margin-bottom: 8px; }
.trust-card p{ font-size: 0.86rem; color: var(--color-ink-soft); margin-bottom: 14px; }
.trust-card__tag{
  display:inline-block;
  font-size: 0.74rem;
  font-weight:700;
  color: var(--color-primary-deep);
  background: rgba(77,159,60,0.08);
  padding: 5px 12px;
  border-radius: var(--radius-full);
}

/* Community — navy, echoes the logo's dark heart shape */
.community{ background: linear-gradient(135deg, #283545, #1B232E); }
.community__inner{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items:center;
}
.community__sub{
  color: rgba(255,255,255,0.7);
  margin: 18px 0 28px;
  font-size: 1.02rem;
  max-width: 460px;
}
.community__event-types{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 28px;
}
.community__event-types span{
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.15);
  color: rgba(255,255,255,0.85);
  font-size: 0.82rem;
  font-family: var(--font-body);
  padding: 6px 14px;
  border-radius: 100px;
}
.community__footnote{
  margin-top: 14px;
  color: rgba(255,255,255,0.4);
  font-size: 0.82rem;
}

.community__visual{ display:flex; justify-content:center; }
.event-card{
  width: 100%;
  max-width: 380px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius-lg);
  padding: 26px;
  box-shadow: var(--shadow-lg);
}
.event-card__head{
  display:flex;
  align-items:center;
  gap: 12px;
  margin-bottom: 20px;
}
.event-card__icon{
  width: 42px; height:42px;
  border-radius: var(--radius-sm);
  background: rgba(77,159,60,0.22);
  display:flex; align-items:center; justify-content:center;
  font-size: 1.2rem;
  flex-shrink:0;
}
.event-card__head strong{ display:block; color:#fff; font-size:0.92rem; }
.event-card__head span:not(.event-card__live){ font-size: 0.78rem; color: rgba(255,255,255,0.55); }
.event-card__live{
  margin-left:auto;
  font-size: 0.72rem;
  font-weight:700;
  color: #6FD89B;
  background: rgba(111,216,155,0.12);
  padding: 4px 10px;
  border-radius: var(--radius-full);
  white-space:nowrap;
}
.event-card__avatars{
  display:flex;
  margin-bottom: 22px;
}
.avatar{
  width: 36px; height:36px;
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size: 0.68rem;
  font-weight:700;
  color:#fff;
  border: 2px solid #283545;
  margin-left:-10px;
}
.avatar:first-child{ margin-left:0; }
.avatar--1{ background: var(--color-primary); }
.avatar--2{ background: #2E7D5B; }
.avatar--3{ background: #B8860B; }
.avatar--4{ background: #6A4FB0; }
.avatar--more{ background: rgba(255,255,255,0.15); font-size:0.62rem; }
.event-card__stats{
  display:grid;
  grid-template-columns: repeat(3,1fr);
  gap: 10px;
  padding: 18px 0;
  border-top: 1px solid rgba(255,255,255,0.08);
  border-bottom: 1px solid rgba(255,255,255,0.08);
  margin-bottom: 18px;
}
.event-stat{ text-align:center; }
.event-stat strong{
  display:block;
  font-family: var(--font-display);
  font-size: 1.3rem;
  color:#fff;
}
.event-stat span{
  font-size: 0.7rem;
  color: rgba(255,255,255,0.5);
}
.event-card__progress-bar{
  height: 8px;
  border-radius: var(--radius-full);
  background: rgba(255,255,255,0.1);
  overflow:hidden;
  margin-bottom: 8px;
}
.event-card__progress-bar span{
  display:block;
  height:100%;
  border-radius: var(--radius-full);
  background: linear-gradient(90deg, var(--color-primary), #9FD98C);
}
.event-card__progress-label{
  font-size: 0.78rem;
  color: rgba(255,255,255,0.55);
}

/* Final CTA — brick accent, the 3rd allowed tone */
.final-cta{
  position:relative;
  background: var(--color-primary);
  text-align:center;
  overflow:hidden;
}
.final-cta__rings{ position:absolute; inset:0; pointer-events:none; }
.final-cta__rings span{
  position:absolute;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius:50%;
}
.final-cta__rings span:nth-child(1){ width:500px; height:500px; left:-150px; top:-150px; }
.final-cta__rings span:nth-child(2){ width:700px; height:700px; right:-250px; bottom:-300px; }
.final-cta__rings span:nth-child(3){ width:300px; height:300px; right:10%; top:10%; }
.final-cta__inner{ position:relative; max-width: 640px; margin:0 auto; }
.final-cta__sub{
  color: rgba(255,255,255,0.82);
  margin: 16px 0 32px;
  font-size: 1.02rem;
}

/* ==========================================================================
   Footer
   ========================================================================== */
.footer{ background: var(--color-ink); color: rgba(255,255,255,0.65); }
.footer__inner{
  display:grid;
  grid-template-columns: 1.6fr 2.2fr auto;
  gap: 40px;
  padding: 64px 24px 40px;
}
.footer__cols{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
}
.footer__brand p{ margin: 14px 0 16px; font-size:0.88rem; max-width:240px; }
.footer__social{ display:flex; gap:12px; }
.footer__social a{
  width:42px; height:42px;
  border-radius:50%;
  background: rgba(255,255,255,0.08);
  display:flex; align-items:center; justify-content:center;
  font-size: 1.1rem;
  transition: background .2s ease;
}
.footer__social a:hover{ background: rgba(255,255,255,0.18); }
.footer__col h4{
  color:#fff;
  font-size: 0.85rem;
  margin-bottom: 16px;
  font-family: var(--font-display);
}
.footer__col a{ display:block; font-size: 0.88rem; margin-bottom: 10px; }
.footer__col a:hover{ color:#fff; }
.footer__stores{
  display:flex;
  flex-direction:column;
  gap: 12px;
  height: fit-content;
}
.footer__store{
  display:flex;
  align-items:center;
  gap:10px;
  background: rgba(255,255,255,0.08);
  border-radius: var(--radius-md);
  padding: 12px 16px;
  font-size: 0.75rem;
  transition: background .2s ease;
}
.footer__store:hover{ background: rgba(255,255,255,0.14); }
.footer__store strong{ color:#fff; font-size:0.85rem; }
.footer__store-icon{ font-size: 1.1rem; }
.footer__store--soon{
  opacity: 0.6;
  cursor: default;
}
.footer__store--soon:hover{ background: rgba(255,255,255,0.08); }
.footer__bottom{
  border-top: 1px solid rgba(255,255,255,0.08);
  padding: 20px 24px;
  font-size: 0.8rem;
  text-align:center;
}

/* ==========================================================================
   Scroll reveal base state (animated via GSAP in script.js)
   ========================================================================== */
[data-reveal]{ opacity: 0; }
h1[data-reveal], h2[data-reveal], h3[data-reveal], h4[data-reveal],
p[data-reveal], .eyebrow[data-reveal], .hero__perks[data-reveal],
.hero__note[data-reveal], .hero__ctas[data-reveal], .section-sub[data-reveal]{
  opacity: 1;
  will-change: transform;
}

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width: 1024px){
  .problem__inner{ grid-template-columns: 1fr; text-align:center; }
  .trust-grid{ grid-template-columns: repeat(2,1fr); }
  .category-grid{ grid-template-columns: repeat(2,1fr); }
  .footer__inner{ grid-template-columns: 1fr; }
  .footer__cols{ max-width: 480px; }
  .community__inner{ grid-template-columns: 1fr; text-align:center; gap: 44px; }
  .community__sub{ margin-left:auto; margin-right:auto; }
}

.header.is-scrolled{ box-shadow: var(--shadow-sm); }

@media (max-width: 760px){
  .hero__content{
    background: rgba(247,249,248,0.88);
    backdrop-filter: blur(4px);
    border-radius: var(--radius-lg);
    padding: 20px;
    margin: 0 -8px;
  }
  .topbar__left a:nth-child(2){ display:none; }
  .nav{
    display:none;
    position:absolute;
    top:100%; left:0; right:0;
    background: var(--color-bg);
    flex-direction:column;
    gap:0;
    padding: 8px 24px 16px;
    border-bottom: 1px solid var(--color-line);
  }
  .nav.is-open{ display:flex; }
  .nav a{ padding: 12px 0; border-bottom: 1px solid var(--color-line); }
  .nav a:last-child{ border-bottom:none; }
  .nav-toggle{ display:flex; }
  .header__inner .btn--sm{ display:none; }
  .how-it-works__grid{ grid-template-columns: 1fr; }
  .how-divider{ display:none; }
  .category-grid{ grid-template-columns: 1fr; }
  .trust-grid{ grid-template-columns: 1fr; }
  .banner-card{ flex-direction:column; text-align:center; }
  .footer__inner{ grid-template-columns: 1fr; text-align:center; }
  .footer__brand{ display:flex; flex-direction:column; align-items:center; }
  .footer__brand p{ margin-left:auto; margin-right:auto; }
  .footer__social{ justify-content:center; }
  .footer__cols{
    grid-template-columns: repeat(2, 1fr);
    max-width: 100%;
    gap: 32px 20px;
    text-align:left;
  }
  .footer__col:last-child{ grid-column: 1 / -1; }
  .footer__stores{ align-items:center; }
  .footer__store{ width: 100%; max-width: 280px; }
  .hero__ctas{ flex-direction:column; }
  .hero__ctas .btn{ width:100%; }
  .section{ padding: 64px 0; }
}
