.tl-site-footer{
  --tl-footer-navy:#0f2347;
  --tl-footer-navy-soft:#1b3468;
  --tl-footer-cyan:#00BCD4;
  --tl-footer-gold:#F5C518;
  --tl-footer-line:rgba(255,255,255,.12);
  --tl-footer-panel:rgba(255,255,255,.07);
  --tl-footer-panel-strong:rgba(255,255,255,.11);
  margin-top:52px;
  position:relative;
  overflow:hidden;
  color:#fff;
  background:
    radial-gradient(circle at 14% 18%, rgba(245,197,24,.14), transparent 26%),
    radial-gradient(circle at 88% 14%, rgba(0,188,212,.14), transparent 24%),
    linear-gradient(135deg, var(--tl-footer-navy) 0%, var(--tl-footer-navy-soft) 64%, #173d78 100%);
}

.tl-site-footer::before,
.tl-site-footer::after{
  content:"";
  position:absolute;
  border-radius:999px;
  pointer-events:none;
}

.tl-site-footer::before{
  inset:auto auto -120px -72px;
  width:280px;
  height:280px;
  background:rgba(255,255,255,.05);
  filter:blur(4px);
}

.tl-site-footer::after{
  inset:-140px -90px auto auto;
  width:320px;
  height:320px;
  background:rgba(0,188,212,.08);
  filter:blur(8px);
}

.tl-site-footer__shell{
  position:relative;
  z-index:1;
  max-width:1320px;
  margin:0 auto;
  padding:18px 14px 16px;
}

.tl-site-footer__hero{
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(360px,.9fr);
  gap:22px;
  padding:28px;
  border-radius:34px;
  border:1px solid var(--tl-footer-line);
  background:
    linear-gradient(180deg, rgba(255,255,255,.09) 0%, rgba(255,255,255,.05) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.08),
    0 26px 70px rgba(2,6,23,.24);
  backdrop-filter:blur(14px);
}

.tl-site-footer__heroCopy,
.tl-site-footer__heroAside{
  min-width:0;
}

.tl-site-footer__heroCopy{
  display:grid;
  gap:16px;
  align-content:start;
}

.tl-site-footer__eyebrow{
  display:inline-flex;
  align-items:center;
  width:max-content;
  max-width:100%;
  min-height:36px;
  padding:8px 14px;
  border-radius:999px;
  background:rgba(245,197,24,.14);
  border:1px solid rgba(245,197,24,.24);
  color:#fff1bd;
  font-size:12px;
  font-weight:950;
  line-height:1.4;
}

.tl-site-footer__brandLine{
  display:flex;
  align-items:center;
  gap:14px;
  min-width:0;
}

.tl-site-footer__logo{
  width:72px;
  height:72px;
  border-radius:24px;
  flex:0 0 auto;
  background:rgba(255,255,255,.96);
  padding:8px;
  object-fit:contain;
  box-shadow:0 18px 40px rgba(2,6,23,.22);
}

.tl-site-footer__name{
  font-size:28px;
  font-weight:950;
  line-height:1.08;
  color:#fff;
}

.tl-site-footer__tagline{
  margin-top:6px;
  max-width:44ch;
  font-size:13px;
  line-height:1.9;
  color:rgba(255,255,255,.76);
}

.tl-site-footer__about{
  margin:0;
  max-width:64ch;
  font-size:15px;
  line-height:2;
  color:rgba(255,255,255,.88);
}

.tl-site-footer__heroAside{
  display:grid;
  gap:16px;
  align-content:space-between;
}

.tl-site-footer__quickPanel{
  padding:20px;
  border-radius:28px;
  border:1px solid rgba(255,255,255,.11);
  background:rgba(6,16,38,.18);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}

.tl-site-footer__quickTitle{
  margin:0 0 12px;
  font-size:13px;
  font-weight:950;
  color:#fff;
}

.tl-site-footer__quickLinks{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.tl-site-footer__quickLink{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:0 16px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.07);
  color:rgba(255,255,255,.92);
  font-size:13px;
  font-weight:900;
  text-decoration:none;
  transition:transform .18s ease, background-color .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.tl-site-footer__quickLink:hover{
  transform:translateY(-1px);
  background:rgba(255,255,255,.13);
  border-color:rgba(255,255,255,.2);
  box-shadow:0 10px 24px rgba(2,6,23,.16);
}

.tl-site-footer__actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:flex-start;
}

.tl-site-footer__btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:48px;
  padding:0 18px;
  border-radius:18px;
  border:1px solid transparent;
  font-size:13px;
  font-weight:950;
  text-decoration:none;
  transition:transform .18s ease, background-color .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.tl-site-footer__btn:hover{
  transform:translateY(-1px);
}

.tl-site-footer__btn--gold{
  background:linear-gradient(135deg, var(--tl-footer-gold), #e9b40e);
  color:#0f2347;
  box-shadow:0 16px 30px rgba(245,197,24,.24);
}

.tl-site-footer__btn--soft{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.14);
  color:#fff;
}

.tl-site-footer__linksWrap{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
  margin-top:14px;
}

.tl-site-footer__col{
  min-width:0;
  padding:18px;
  border-radius:28px;
  background:var(--tl-footer-panel);
  border:1px solid rgba(255,255,255,.1);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}

.tl-site-footer__colTitle{
  font-size:13px;
  font-weight:950;
  color:#fff;
}

.tl-site-footer__list{
  display:flex;
  flex-direction:column;
  gap:9px;
  margin:12px 0 0;
  padding:0;
  list-style:none;
}

.tl-site-footer__list li{
  margin:0;
  padding:0;
  list-style:none;
}

.tl-site-footer__list a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  min-height:42px;
  padding:11px 14px;
  border-radius:16px;
  background:var(--tl-footer-panel-strong);
  border:1px solid rgba(255,255,255,.08);
  color:rgba(255,255,255,.9);
  font-size:13px;
  font-weight:850;
  text-decoration:none;
  transition:transform .18s ease, background-color .18s ease, color .18s ease, border-color .18s ease;
}

.tl-site-footer__list a::after{
  content:"←";
  font-size:14px;
  flex:0 0 auto;
  color:rgba(255,255,255,.68);
}

.tl-site-footer__list a:hover{
  transform:translateY(-1px);
  background:rgba(255,255,255,.16);
  border-color:rgba(255,255,255,.16);
  color:#fff;
}

.tl-site-footer__list a:hover::after{
  color:#fff;
}

.tl-site-footer__bottom{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-top:14px;
  padding:16px 4px 0;
  border-top:1px solid rgba(255,255,255,.1);
  font-size:11.5px;
  color:rgba(255,255,255,.7);
}

.tl-site-footer__bottom a{
  color:#fff;
  text-decoration:underline;
}

@media (max-width: 1199px){
  .tl-site-footer__hero{
    grid-template-columns:1fr;
  }
}

@media (max-width: 1023px), ((hover: none) and (pointer: coarse) and (max-width: 1366px)){
  .tl-site-footer{
    margin-top:36px;
  }

  .tl-site-footer__shell{
    padding:14px 12px 12px;
  }

  .tl-site-footer__hero{
    padding:20px;
    border-radius:26px;
  }

  .tl-site-footer__logo{
    width:60px;
    height:60px;
    border-radius:20px;
  }

  .tl-site-footer__name{
    font-size:23px;
  }

  .tl-site-footer__about{
    font-size:14px;
  }

  .tl-site-footer__linksWrap{
    grid-template-columns:1fr;
  }

  .tl-site-footer__bottom{
    flex-direction:column;
    align-items:flex-start;
  }
}

@media (max-width: 767px), ((hover: none) and (pointer: coarse) and (max-width: 1366px)){
  .tl-site-footer__shell{
    padding:12px 10px 10px;
  }

  .tl-site-footer__hero{
    padding:18px 16px;
    gap:14px;
  }

  .tl-site-footer__eyebrow,
  .tl-site-footer__quickLink,
  .tl-site-footer__list a,
  .tl-site-footer__btn{
    min-height:40px;
  }

  .tl-site-footer__quickPanel,
  .tl-site-footer__col{
    padding:16px;
    border-radius:22px;
  }

  .tl-site-footer__name{
    font-size:21px;
  }

  .tl-site-footer__tagline,
  .tl-site-footer__about{
    font-size:13px;
  }
}
