/* ═══════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════ */
.site-footer{background:var(--dark);color:rgba(255,255,255,.72)}
.footer-top{padding:60px 20px 40px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-grid{max-width:1220px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:40px}
.footer-brand{}
.footer-logo{display:flex;align-items:center;gap:10px;margin-bottom:18px;text-decoration:none}
.footer-logo-mark{width:40px;height:40px;background:var(--blue);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--fhead);font-size:1.1rem;font-weight:800;flex-shrink:0}
.footer-logo-text strong{font-family:var(--fhead);font-size:1.05rem;font-weight:800;color:#fff;text-transform:uppercase;letter-spacing:.3px;display:block}
.footer-logo-text span{font-size:.6rem;color:rgba(255,255,255,.4);letter-spacing:1.2px;text-transform:uppercase}
.footer-desc{font-size:.82rem;line-height:1.75;color:rgba(255,255,255,.55);margin-bottom:22px}
.footer-contact a{display:flex;align-items:flex-start;gap:9px;color:rgba(255,255,255,.65);font-size:.8rem;margin-bottom:10px;transition:color .2s;text-decoration:none}
.footer-contact a:hover{color:#fff}
.footer-contact .fc-icon{width:28px;height:28px;background:rgba(255,255,255,.07);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.8rem;flex-shrink:0;margin-top:1px}
.footer-social{display:flex;gap:8px;margin-top:20px}
.social-btn{width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;font-size:.9rem;color:rgba(255,255,255,.6);transition:all .2s;border:1px solid rgba(255,255,255,.08);text-decoration:none}
.social-btn:hover{background:var(--blue);color:#fff;border-color:var(--blue)}
.footer-col h4{font-family:var(--fhead);font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:#fff;margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-col ul li{margin-bottom:9px}
.footer-col ul li a{font-size:.8rem;color:rgba(255,255,255,.55);transition:color .2s;text-decoration:none;display:flex;align-items:center;gap:5px}
.footer-col ul li a:hover{color:#fff}
.footer-col ul li a::before{content:'›';color:var(--blue);font-weight:700;flex-shrink:0}

/* Footer regions */
.footer-mid{background:rgba(0,0,0,.2);padding:24px 20px;border-bottom:1px solid rgba(255,255,255,.06)}
.footer-mid-inner{max-width:1220px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.footer-mid-label{font-size:.72rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.4)}
.footer-regions{display:flex;gap:10px;flex-wrap:wrap}
.region-pill{display:inline-flex;align-items:center;gap:6px;background:rgba(224,144,23);border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.7);padding:6px 14px;border-radius:20px;font-size:.75rem;font-weight:600;transition:all .2s}
.region-pill:hover{background:var(--blue);border-color:var(--blue);color:#fff}

/* Footer brands strip */
.footer-brands{background:rgba(0,0,0,.15);padding:18px 20px;border-bottom:1px solid rgba(255,255,255,.06)}
.footer-brands-inner{max-width:1220px;margin:0 auto;display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.footer-brands-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,.35);white-space:nowrap}
.footer-brands-list{display:flex;gap:20px;flex-wrap:wrap;align-items:center}
.footer-brand-link{font-family:var(--fhead);font-size:.82rem;font-weight:700;color:rgba(255,255,255,.4);letter-spacing:.5px;text-decoration:none;transition:color .2s;white-space:nowrap;text-transform:uppercase}
.footer-brand-link:hover{color:#fff}

/* Footer bottom */
.footer-bottom{padding:18px 20px;background:rgba(0,0,0,.3)}
.footer-bottom-inner{max-width:1220px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.footer-copy{font-size:.75rem;color:rgba(255,255,255,.4)}
.footer-copy a{color:rgba(255,255,255,.5);transition:color .2s}
.footer-copy a:hover{color:#fff}
.footer-legal{display:flex;gap:16px;flex-wrap:wrap}
.footer-legal a{font-size:.72rem;color:rgba(255,255,255,.4);transition:color .2s;text-decoration:none}
.footer-legal a:hover{color:#fff}


/* ═══════════════════════════════════════════
   RESPONSIVE — TABLET  (≤1100px) — Footer
   ═══════════════════════════════════════════ */
@media(max-width:1100px){
.footer-grid{grid-template-columns:1fr 1fr 1fr;gap:28px}
.footer-brand{grid-column:1/-1}
.footer-desc{max-width:600px}
}

/* ═══════════════════════════════════════════
   RESPONSIVE — MOBILE  (≤900px) — Footer
   ═══════════════════════════════════════════ */
@media(max-width:900px){
.footer-grid{grid-template-columns:1fr 1fr;gap:24px}
.footer-brand{grid-column:1/-1}
.footer-mid-inner{flex-direction:column;align-items:flex-start;gap:16px}
.footer-brands-inner{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;padding-bottom:6px;scrollbar-width:none}
.footer-brands-inner::-webkit-scrollbar{display:none}
.footer-brands-label{flex-shrink:0}
.footer-brands-list{flex-wrap:nowrap}

/* ── Footer col accordion on mobile ── */
.footer-col{border-bottom:1px solid rgba(255,255,255,.08)}
.footer-col h4{cursor:pointer;display:flex;justify-content:space-between;align-items:center;padding-bottom:14px;margin-bottom:0;user-select:none;-webkit-tap-highlight-color:transparent}
.footer-col h4::after{content:'＋';font-size:.9rem;font-weight:400;color:rgba(255,255,255,.4);transition:transform .25s}
.footer-col.open h4::after{content:'－'}
.footer-col ul{display:none;margin-top:8px;padding-bottom:16px}
.footer-col.open ul{display:block}
}

/* ═══════════════════════════════════════════
   RESPONSIVE — SMALL MOBILE  (≤600px) — Footer
   ═══════════════════════════════════════════ */
@media(max-width:600px){
.footer-top{padding:36px 14px 28px}
.footer-grid{grid-template-columns:1fr;gap:0}
.footer-brand{padding-bottom:28px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:4px}
.footer-mid{padding:18px 14px}
.footer-mid-inner{gap:14px}
.footer-regions{gap:6px}
.region-pill{font-size:.7rem;padding:5px 10px}
.footer-bottom{padding:16px 14px}
.footer-bottom-inner{flex-direction:column;align-items:flex-start;gap:10px}
.footer-legal{gap:10px;flex-wrap:wrap}
.footer-legal a{font-size:.7rem}
.footer-copy{font-size:.72rem;line-height:1.55}
.footer-social{flex-wrap:wrap}
}
