/* ==========================================
   PUMPKIN DUKE — FOOTER
   Loads globally after master.css.
   ========================================== */

.site-footer {
  background-color: var(--color-surface-1);
  border-top: 1px solid var(--color-border);
}

/* ==========================================
   TOP FOOTER
   ========================================== */
.footer-top {
  padding-block: var(--space-9);
}
.footer-top-inner {
  display: grid;
  grid-template-columns: 1.2fr 2fr;
  gap: var(--space-8);
}

/* ---------- Brand ---------- */
.footer-brand {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  max-width: 340px;
}
.footer-logo {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.footer-logo img {
  width: 56px;
  height: 56px;
  object-fit: contain;
}
.footer-wordmark {
  font-family: var(--font-display);
  font-size: var(--text-h5);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-white);
}
.footer-motto {
  font-size: var(--text-small);
  font-style: italic;
  color: var(--color-primary);
  margin: 0;
}
.footer-contact {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.footer-contact li {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-small);
  color: var(--color-gray);
}
.footer-contact .pd-icon {
  width: 17px;
  height: 17px;
  color: var(--color-gray-dark);
  flex-shrink: 0;
}
.footer-contact a {
  color: var(--color-gray);
}
.footer-contact a:hover {
  color: var(--color-primary);
}
.footer-social {
  display: flex;
  gap: var(--space-4);
  margin-top: var(--space-2);
}
.footer-social a {
  color: var(--color-gray);
}
.footer-social a:hover {
  color: var(--color-primary);
}
.footer-social .pd-icon {
  width: 20px;
  height: 20px;
}

/* ---------- Link columns ---------- */
.footer-cols {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-6);
}
.footer-col-title {
  font-family: var(--font-display);
  font-size: var(--text-small);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-white);
  margin-bottom: var(--space-4);
}
.footer-col ul {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.footer-col a {
  font-size: var(--text-small);
  color: var(--color-gray);
  transition: color var(--t-base);
}
.footer-col a:hover {
  color: var(--color-primary);
}

/* ==========================================
   MID FOOTER BANDS
   ========================================== */
.footer-mid {
  border-top: 1px solid var(--color-border-soft);
}
.footer-mid-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  padding-block: var(--space-6);
}
.footer-mid-title {
  font-family: var(--font-display);
  font-size: var(--text-h5);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-white);
  margin-bottom: var(--space-1);
}
.footer-mid-text p {
  font-size: var(--text-small);
  color: var(--color-gray);
  margin: 0;
  max-width: 60ch;
}
.footer-mid .btn {
  flex-shrink: 0;
}
.footer-mid .btn .pd-icon {
  width: 18px;
  height: 18px;
}

/* ==========================================
   BOTTOM FOOTER
   ========================================== */
.footer-bottom {
  border-top: 1px solid var(--color-border);
}
.footer-bottom-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding-block: var(--space-5);
  font-size: var(--text-micro);
  letter-spacing: 0.04em;
}
.footer-copy {
  color: var(--color-gray-dark);
}
.footer-built {
  color: var(--color-gray-dark);
}
.footer-watch {
  color: var(--color-primary);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

/* ==========================================
   RESPONSIVE
   ========================================== */
@media (max-width: 999px) {
  .footer-top-inner {
    grid-template-columns: 1fr;
    gap: var(--space-7);
  }
  .footer-brand {
    max-width: none;
  }
}

@media (max-width: 640px) {
  .footer-cols {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-6) var(--space-4);
  }
  .footer-mid-inner {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-4);
  }
  .footer-bottom-inner {
    flex-direction: column;
    text-align: center;
    gap: var(--space-2);
  }
}
