.site-footer {
  background: var(--c-ink);
  color: #C9C7C2;
  padding: var(--sp-20) 0 var(--sp-8);
  margin-top: var(--sp-24);
  font-size: var(--fs-sm);
}
.site-footer a { color: #C9C7C2; }
.site-footer a:hover { color: #fff; }

.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: var(--sp-12);
  margin-bottom: var(--sp-16);
}
.footer-col h4 {
  color: #fff;
  font-size: var(--fs-xs);
  letter-spacing: var(--ls-extra);
  text-transform: uppercase;
  font-weight: var(--fw-semibold);
  margin-bottom: var(--sp-5);
}
.footer-col ul { display: flex; flex-direction: column; gap: var(--sp-3); }

.footer-brand .brand { color: #fff; font-size: var(--fs-xl); }
.footer-tag { color: #8E8C87; max-width: 320px; line-height: 1.6; margin-top: var(--sp-3); }

.footer-bottom {
  border-top: 1px solid #2A2A2A;
  padding-top: var(--sp-6);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--sp-4);
  color: #6E6C67;
  font-size: var(--fs-xs);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
}
.footer-pay { display: flex; gap: var(--sp-3); align-items: center; }
.pay-chip {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  padding: 6px 10px; border: 1px solid #2A2A2A; border-radius: var(--radius-sm);
  color: #C9C7C2; font-size: 11px;
}

@media (max-width: 880px) {
  .footer-grid { grid-template-columns: 1fr 1fr; gap: var(--sp-8); }
  .footer-brand { grid-column: 1 / -1; }
  .footer-bottom { flex-direction: column; align-items: flex-start; }
}

/* Trust strip (above footer) */
.trust-strip {
  border-top: 1px solid var(--c-line);
  border-bottom: 1px solid var(--c-line);
  padding: var(--sp-10) 0;
}
.trust-strip__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-6);
}
.trust-item {
  display: flex; gap: var(--sp-4); align-items: flex-start;
}
.trust-item__icon {
  width: 40px; height: 40px; flex: 0 0 40px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 50%;
  background: var(--c-bg-cream);
  color: var(--c-ink);
}
.trust-item__icon svg { width: 20px; height: 20px; }
.trust-item__title { font-size: var(--fs-sm); font-weight: var(--fw-semibold); margin-bottom: 2px; }
.trust-item__desc { font-size: var(--fs-xs); color: var(--c-muted); line-height: 1.5; }

@media (max-width: 880px) {
  .trust-strip { padding: var(--sp-8) 0; }
  .trust-strip__grid { grid-template-columns: 1fr 1fr; gap: var(--sp-5) var(--sp-3); }
  .trust-item { gap: var(--sp-3); }
  .trust-item__icon { width: 36px; height: 36px; flex-basis: 36px; }
  .trust-item__title { font-size: 12px; }
  .trust-item__desc { font-size: 11px; }
}

/* Cookie banner */
.cookie-banner {
  position: fixed;
  left: var(--sp-4); right: var(--sp-4); bottom: var(--sp-4);
  z-index: var(--z-modal);
  background: var(--c-ink);
  color: var(--c-bg);
  padding: var(--sp-5) var(--sp-6);
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
  max-width: 720px;
  margin: 0 auto;
  animation: cookie-in 360ms cubic-bezier(.4,0,.2,1);
}
.cookie-banner.is-leaving { animation: cookie-out 320ms cubic-bezier(.4,0,.2,1) forwards; }
@keyframes cookie-in { from { transform: translateY(110%); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
@keyframes cookie-out { to { transform: translateY(110%); opacity: 0; } }

.cookie-banner__inner {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--sp-5);
  align-items: center;
}
.cookie-banner__text { font-size: var(--fs-sm); line-height: 1.55; }
.cookie-banner__text strong { display: block; margin-bottom: 4px; font-size: var(--fs-base); }
.cookie-banner__text a { text-decoration: underline; color: var(--c-accent); }
.cookie-banner__actions { display: flex; gap: var(--sp-2); }
.cookie-banner .btn {
  font-size: var(--fs-xs); padding: 10px 16px;
  background: var(--c-bg); color: var(--c-ink); border-color: var(--c-bg);
}
.cookie-banner .btn:hover { background: var(--c-accent); border-color: var(--c-accent); color: #fff; }
.cookie-banner .btn--ghost { background: transparent; color: var(--c-bg); border-color: rgba(255,255,255,0.4); }
.cookie-banner .btn--ghost:hover { background: rgba(255,255,255,0.08); color: var(--c-bg); border-color: var(--c-bg); }

@media (max-width: 600px) {
  .cookie-banner__inner { grid-template-columns: 1fr; }
  .cookie-banner__actions { justify-content: stretch; }
  .cookie-banner__actions .btn { flex: 1; }
}
