/* Use the same font vars you set earlier */
:root{
  --font-site: "Bitter", Georgia, "Times New Roman", serif;
  --font-tagline: "Allura", "Segoe Script", "Lucida Handwriting", cursive;
  --font-nav: Tahoma, Geneva, Verdana, sans-serif;
}

/* Footer brand heading scales like header’s site-name */
.site-footer .footer-brand h3{
  font-family: var(--font-site);
  font-weight: 900;
  font-size: clamp(1.25rem, 1.05rem + 1vw, 1.6rem);
  letter-spacing: .2px;
  margin: 0 0 6px;
  color: #fff;
}

/* Keep the blurb readable (don’t use the script here); make it fluid */
.site-footer .brand-text{
  font-size: clamp(.95rem, .9rem + .25vw, 1.05rem);
  line-height: 1.55;
  color: var(--footer-muted);
  margin: 0;
}

/* Footer nav can use your nav stack for consistency */
.site-footer .footer-links a,
.site-footer .footer-col h3,
.site-footer .legal-inner{
  font-family: var(--font-nav);
}


.site-footer{
  --footer-bg: #0B1220;
  --footer-text: #e6e7eb;
  --footer-muted: #a7adbb;
  --footer-border: rgba(255,255,255,.08);

  background-color: var(--footer-bg); /* solid color, no gradient */
  color: var(--footer-text);
  margin-top: 0;
  border-top: 1px solid var(--footer-border);
  position: relative;
  isolation: isolate;
}

.site-footer::before{
  content: none;
}

.footer-inner{
    max-width: 1100px; margin: 0 auto; padding: 28px 16px;
    display: grid; gap: 18px;
    grid-template-columns: 1.2fr 1fr 1fr;
}
@media (max-width: 900px){ .footer-inner{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px){ .footer-inner{ grid-template-columns: 1fr; } }

/* Brand blurb */
.footer-brand { display:flex; gap:12px; align-items:flex-start; }
.logo-circle{
    width:40px; height:40px; border-radius:50%;
    background: rgba(255,255,255,.08);
    display:flex; align-items:center; justify-content:center;
    font-weight:700; letter-spacing:.5px;
    border: 1px solid var(--footer-border);
}
.brand-text{ color: var(--footer-muted); margin:0; }

/* Columns/links */
.footer-col h3{
    margin:0 0 10px; font-size:.95rem; letter-spacing:.2px; color:#fff; font-weight:700;
}
.footer-links{ display:flex; flex-direction:column; gap:8px; }
.footer-links a{
    color: var(--footer-text); text-decoration:none; opacity:.9;
    display:inline-flex; align-items:center; gap:8px;
    text-underline-offset: 3px;
}
.footer-links a:hover{ opacity:1; text-decoration: underline; }
.footer-links .muted{ color: var(--footer-muted); opacity:.95; }
.footer-links .muted:hover{ color: #fff; text-decoration: underline; }

/* Legal strip */
.footer-legal{ border-top:1px solid var(--footer-border); margin-top: 8px; }
.legal-inner{
    max-width:1100px; margin:0 auto; padding: 14px 16px;
    display:flex; gap:10px; align-items:center; justify-content:space-between; flex-wrap:wrap;
    color: var(--footer-muted); font-size:.9rem;
}
.back-to-top{
    color: var(--footer-text); text-decoration:none; opacity:.9; border:1px solid var(--footer-border);
    padding:6px 10px; border-radius:10px; background: rgba(255,255,255,.05);
    transition: background .15s ease, transform .15s ease, opacity .15s ease;
}
.back-to-top:hover{ opacity:1; background: rgba(255,255,255,.12); transform: translateY(-1px); }
.back-to-top:focus-visible{ outline:2px solid rgba(96,165,250,.45); outline-offset:3px; }

/* Tighten/relax spacing responsively */
.footer-inner{
  max-width: 1100px;
  margin: 0 auto;
  padding: 28px 16px;
  display: grid;
  gap: 18px;
  grid-template-columns: 1.2fr 1fr 1fr;
}

@media (max-width: 900px){
  .footer-inner{
    grid-template-columns: 1fr 1fr;
    gap: 16px 18px;
  }
}

@media (max-width: 600px){
  .footer-inner{
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .footer-brand{
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
}

/* Link spacing a touch larger for touch devices */
.footer-links{ gap: 10px; }
@media (max-width: 600px){
  .footer-links{ gap: 12px; }
}
