.site-footer { background: #0a0f1b; border-top: 1px solid rgba(255,255,255,0.06); padding: 56px 0 22px; position: relative; }
.site-footer::before { content: ""; position: absolute; inset: 0; background: radial-gradient(800px 300px at 20% 0%, rgba(173,97,202,0.10), transparent 60%), radial-gradient(700px 280px at 80% 0%, rgba(149,73,218,0.10), transparent 60%); pointer-events: none; }
.footer-grid { display: grid; grid-template-columns: 1.3fr 1fr 1fr 1.2fr; gap: 32px; align-items: start; }
.footer-col { color: #e6edf6; position: relative; }
.footer-col:not(:first-child)::before { content: ""; position: absolute; left: -16px; top: 6px; bottom: 6px; width: 1px; background: linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.02)); }
.footer-brand-row { display: flex; align-items: center; gap: 8px; font-weight: 800; font-size: 22px; letter-spacing: 0.2px; }
.footer-logo { width: 28px; height: 28px; display: inline-flex; align-items: center; justify-content: center; background: linear-gradient(135deg, #ad61ca, #9549da); color: #fff; border-radius: 8px; box-shadow: 0 6px 16px rgba(0,0,0,0.22); }
.footer-logo-img { width: 40px; height: 40px; object-fit: contain; filter: brightness(1.08) saturate(1.05) contrast(1.05); }
.footer-brand-name { color: #dbe7ff; }
.footer-desc { color: #9fb3c8; margin: 10px 0 16px; max-width: 420px; }
.footer-title { margin: 0 0 12px; color: #eaf2ff; font-size: 15px; text-transform: uppercase; letter-spacing: 0.6px; }
.footer-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.footer-list a { color: #9fb3c8; display: inline-flex; align-items: center; gap: 8px; transition: color 0.2s ease, transform 0.2s ease; }
.footer-list a::before { content: '›'; opacity: 0.48; transition: transform 0.2s ease, opacity 0.2s ease; }
.footer-list a:hover { color: #ffffff; transform: translateX(1px); }
.footer-list a:hover::before { opacity: 0.9; transform: translateX(2px); }
.contact-list .ci { display: inline-block; width: 20px; }
.footer-social { display: flex; gap: 10px; }
.social-btn { width: 38px; height: 38px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; background: rgba(255,255,255,0.10); border: 1px solid rgba(255,255,255,0.18); backdrop-filter: blur(6px); transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease; }
.social-btn img { width: 18px; height: 18px; filter: brightness(1.6); }
.footer-social .social-btn img { width: 20px; height: 20px; object-fit: contain; filter: grayscale(1) brightness(0) invert(1) contrast(1.05); }
.social-btn:hover { background: rgba(255,255,255,0.20); border-color: rgba(255,255,255,0.28); transform: translateY(-1px); }
.newsletter { display: grid; grid-template-columns: 1fr auto; gap: 10px; }
.newsletter-input { height: 44px; border-radius: 12px; border: 1px solid rgba(255,255,255,0.14); background: rgba(255,255,255,0.06); color: #fff; padding: 0 12px; outline: none; transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease; }
.newsletter-input::placeholder { color: #b6c3d6; }
.newsletter-input:focus { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(149,73,218,0.25); background: rgba(255,255,255,0.09); }
.newsletter-btn { height: 44px; border-radius: 12px; padding: 0 18px; }
.footer-map-wrap { position: relative; border: 1px solid rgba(255,255,255,0.12); border-radius: 12px; overflow: hidden; box-shadow: 0 8px 20px rgba(0,0,0,0.18); }
.footer-map { width: 100%; height: 180px; border: 0; display: block; }
.map-link { display: inline-block; margin-top: 8px; color: #bcd1ff; text-decoration: underline; text-underline-offset: 3px; }
.footer-bottom { margin-top: 28px; padding-top: 18px; border-top: 1px solid rgba(255,255,255,0.06); display: flex; align-items: center; justify-content: space-between; color: #9fb3c8; font-size: 14px; }
.footer-legal { display: flex; gap: 16px; }
.footer-legal a { color: #9fb3c8; }
.footer-legal a:hover { color: #fff; }

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



