.site-footer { background-color: #0a0a0a; padding: 56px 0 0; position: relative; }
.site-footer::before { content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 2px; background: linear-gradient(90deg, rgba(0, 0, 0, 0), #c8102e, #d4af37, #c8102e, rgba(0, 0, 0, 0)); }
.site-footer .footer-grid { display: grid; grid-template-columns: 1fr; gap: 32px; padding-bottom: 40px; border-bottom: 1px solid rgba(255, 255, 255, 0.04); max-width: 1200px; margin: 0 auto; padding-left: 20px; padding-right: 20px; }
.site-footer .footer-grid .footer-about .footer-logo { font-size: 18px; font-weight: 800; color: #ffffff; margin-bottom: 4px; letter-spacing: -0.3px; }
.site-footer .footer-grid .footer-about .footer-established { font-size: 12px; font-weight: 600; color: #d4af37; margin-bottom: 12px; letter-spacing: 0.5px; }
.site-footer .footer-grid .footer-about .footer-description { font-size: 14px; line-height: 24px; color: rgba(255, 255, 255, 0.35); margin-bottom: 14px; max-width: 280px; }
.site-footer .footer-grid .footer-about .footer-about-link { font-size: 14px; font-weight: 600; color: #d4af37; display: inline-flex; align-items: center; gap: 4px; }
.site-footer .footer-grid .footer-about .footer-about-link:hover { color: #e8c84a; }
.site-footer .footer-grid .footer-about .footer-about-link .link-arrow { width: 14px; height: 14px; }
.site-footer .footer-grid .footer-col .col-title { font-size: 11px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase; color: #d4af37; margin-bottom: 14px; }
.site-footer .footer-grid .footer-col .col-list { display: flex; flex-direction: column; gap: 8px; }
.site-footer .footer-grid .footer-col .col-list .col-link { font-size: 14px; color: rgba(255, 255, 255, 0.4); transition: color 0.2s ease; }
.site-footer .footer-grid .footer-col .col-list .col-link:hover { color: #ffffff; }
.site-footer .footer-grid .footer-rg .rg-message { margin-top: 16px; }
.site-footer .footer-grid .footer-rg .rg-message .rg-message-text { font-size: 13px; line-height: 21px; color: rgba(255, 255, 255, 0.78); margin: 0; }
.site-footer .footer-grid .footer-rg .rg-message .rg-message-text strong { color: #ffffff; font-weight: 700; }
.site-footer .footer-grid .footer-rg .rg-message .rg-message-text .rg-phone-link { color: #d4af37; font-weight: 700; text-decoration: none; border-bottom: 1px solid rgba(212, 175, 55, 0.4); }
.site-footer .footer-grid .footer-rg .rg-message .rg-message-text .rg-phone-link:hover { color: #e8c84a; border-color: rgba(212, 175, 55, 0.7); }
.site-footer .footer-grid .rg-logos { display: flex; align-items: center; gap: 12px; margin-top: 16px; flex-wrap: wrap; }
.site-footer .footer-grid .rg-logos .rg-age-logo { width: 44px; height: 44px; flex-shrink: 0; display: block; }
.site-footer .footer-grid .rg-logos .rg-sga-link { display: inline-flex; max-width: 100%; transition: opacity 0.2s ease; }
.site-footer .footer-grid .rg-logos .rg-sga-link:hover { opacity: 0.85; }
.site-footer .footer-grid .rg-logos .rg-sga-logo { height: 36px; width: auto; max-width: 100%; display: block; }
.site-footer .footer-grid .footer-rg .rg-links { display: flex; flex-direction: column; gap: 8px; }
.site-footer .footer-grid .footer-rg .rg-links .rg-link { font-size: 14px; color: rgba(255, 255, 255, 0.4); transition: color 0.2s ease; }
.site-footer .footer-grid .footer-rg .rg-links .rg-link:hover { color: #ffffff; }
.site-footer .footer-grid .footer-contact .contact-email { display: flex; align-items: center; gap: 8px; font-size: 14px; color: rgba(255, 255, 255, 0.4); margin-bottom: 12px; }
.site-footer .footer-grid .footer-contact .contact-email .email-icon { width: 16px; height: 16px; color: rgba(255, 255, 255, 0.25); flex-shrink: 0; }
.site-footer .footer-grid .footer-contact .contact-links { display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }
.site-footer .footer-grid .footer-contact .contact-links .contact-link { font-size: 14px; color: rgba(255, 255, 255, 0.4); transition: color 0.2s ease; }
.site-footer .footer-grid .footer-contact .contact-links .contact-link:hover { color: #ffffff; }
.site-footer .footer-grid .footer-contact .social-links { display: flex; gap: 10px; }
.site-footer .footer-grid .footer-contact .social-links .social-link { width: 36px; height: 36px; border-radius: 6px; background-color: rgba(255, 255, 255, 0.04); display: flex; align-items: center; justify-content: center; transition: background-color 0.2s ease; }
.site-footer .footer-grid .footer-contact .social-links .social-link:hover { background-color: rgba(200, 16, 46, 0.15); }
.site-footer .footer-grid .footer-contact .social-links .social-link .social-icon { width: 18px; height: 18px; color: rgba(255, 255, 255, 0.4); }
.site-footer .footer-bottom { padding: 24px 20px; max-width: 1200px; margin: 0 auto; }
.site-footer .footer-bottom .footer-policies { display: flex; flex-wrap: wrap; align-items: center; row-gap: 8px; margin-bottom: 18px; padding-bottom: 18px; border-bottom: 1px solid rgba(255, 255, 255, 0.04); }
.site-footer .footer-bottom .footer-policies a { position: relative; font-size: 13px; color: rgba(255, 255, 255, 0.35); padding: 0 14px; transition: color 0.2s ease; }
.site-footer .footer-bottom .footer-policies a:first-child { padding-left: 0; }
.site-footer .footer-bottom .footer-policies a:not(:last-child)::after { content: ""; position: absolute; right: 0; top: 50%; transform: translateY(-50%); width: 1px; height: 11px; background: rgba(255, 255, 255, 0.12); }
.site-footer .footer-bottom .footer-policies a:hover { color: #ffffff; }
.site-footer .footer-bottom .footer-disclaimer { font-size: 13px; line-height: 22px; color: rgba(255, 255, 255, 0.2); margin-bottom: 16px; }
.site-footer .footer-bottom .footer-bottom-row { display: flex; flex-direction: column; gap: 8px; }
.site-footer .footer-bottom .footer-bottom-row .footer-copyright { font-size: 12px; color: rgba(255, 255, 255, 0.15); }
.site-footer .footer-bottom .footer-bottom-row .footer-network { font-size: 12px; color: rgba(255, 255, 255, 0.15); }
.site-footer .footer-bottom .footer-bottom-row .footer-network .network-link { color: #d4af37; }
.site-footer .footer-bottom .footer-bottom-row .footer-updated { font-size: 12px; color: rgba(255, 255, 255, 0.15); }
@media (min-width: 768px) {
  .site-footer .footer-grid { grid-template-columns: repeat(2, 1fr); gap: 28px; padding-left: 40px; padding-right: 40px; }
  .site-footer .footer-bottom { padding: 24px 40px; }
  .site-footer .footer-bottom .footer-bottom-row { flex-direction: row; justify-content: space-between; align-items: center; }
}
@media (min-width: 1024px) {
  .site-footer .footer-grid { grid-template-columns: 1.5fr 1fr 1fr 1fr 1fr; gap: 24px; }
}
