/* TG3 mega-footer styles. Relies on tokens.css for variables. */
.ff *{box-sizing:border-box}
.ff a{text-decoration:none}

.ff{position:relative;background:var(--navy-deep);color:#fff;font-family:var(--font-body);overflow:hidden}
.ff .hero{position:relative;background:var(--grad-brand);padding:64px 56px 60px;overflow:hidden}
.ff .hero::after{content:"";position:absolute;inset:0;background:radial-gradient(780px 320px at 82% 130%,rgba(8,24,46,.6),transparent 60%);pointer-events:none}
.ff .hero::before{content:"";position:absolute;top:-40%;right:-6%;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.16),transparent 60%);pointer-events:none}
.ff .hero .row{position:relative;display:grid;grid-template-columns:1.5fr 1fr;gap:48px;align-items:end}
.ff .ey{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.9);display:flex;align-items:center;gap:9px;margin-bottom:18px}
.ff .ey .dot{width:7px;height:7px;border-radius:50%;background:#7CF2BE;box-shadow:0 0 0 4px rgba(124,242,190,.22)}
.ff .hero h2{font-family:var(--font-display);font-weight:800;font-size:clamp(34px,4.2vw,58px);line-height:1.0;letter-spacing:-.03em;margin:0;max-width:15ch}
.ff .hero .sub{color:rgba(255,255,255,.86);font-size:16px;line-height:1.6;margin:18px 0 0;max-width:46ch}
.ff .btns{display:flex;flex-direction:column;gap:12px}
.ff .btn{display:inline-flex;align-items:center;justify-content:space-between;gap:14px;font-family:var(--font-display);font-weight:700;font-size:16px;padding:18px 24px;border-radius:12px;transition:transform .16s,box-shadow .16s,background .16s}
.ff .btn.pri{background:#fff;color:var(--cobalt-deep);box-shadow:0 18px 40px -14px rgba(8,24,46,.55)}
.ff .btn.pri:hover{transform:translateY(-2px)}
.ff .btn.sec{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.45)}
.ff .btn.sec:hover{background:rgba(255,255,255,.2)}
.ff .inner{position:relative;padding:0 56px}
.ff .news{display:flex;align-items:center;justify-content:space-between;gap:30px;padding:28px 0;border-bottom:1px solid rgba(255,255,255,.08);flex-wrap:wrap}
.ff .news .nt{font-family:var(--font-display);font-weight:700;font-size:18px}
.ff .news .ns{color:rgba(255,255,255,.55);font-size:13.5px;margin-top:3px}
.ff .news form{display:flex;gap:10px;flex:none}
.ff .news input{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);color:#fff;border-radius:10px;padding:13px 16px;font-size:14px;width:290px;font-family:var(--font-body)}
.ff .news input::placeholder{color:rgba(255,255,255,.45)}
.ff .news button{background:var(--cobalt);color:#fff;border:none;border-radius:10px;padding:0 22px;font-family:var(--font-display);font-weight:700;font-size:14px;cursor:pointer;transition:background .15s}
.ff .news button:hover{background:var(--cobalt-deep)}
.ff .mega{display:grid;grid-template-columns:1.1fr repeat(5,1fr);gap:30px 24px;padding:46px 0 38px}
.ff h4{font-family:var(--font-mono);font-size:10.5px;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--cobalt-bright);margin:0 0 15px}
.ff ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.ff .mega a{color:rgba(255,255,255,.74);font-size:13.5px;transition:color .15s}
.ff .mega a:hover{color:#fff}
.ff .brandcol .mark{font-family:var(--font-display);font-weight:800;font-size:28px;letter-spacing:-.02em}
.ff .brandcol .mark b{color:var(--cobalt-bright)}
.ff .brandcol p{color:rgba(255,255,255,.55);font-size:13px;line-height:1.6;margin:12px 0 0}
.ff .row2{display:grid;grid-template-columns:2fr 2fr 1.1fr;gap:24px;border-top:1px solid rgba(255,255,255,.08);padding:36px 0 40px}
.ff .row2 ul.two{display:grid;grid-template-columns:1fr 1fr;gap:10px 24px}
.ff .row2 a{color:rgba(255,255,255,.74);font-size:13.5px;transition:color .15s}
.ff .row2 a:hover{color:#fff}
.ff .stats{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08)}
.ff .stat{padding:24px 0;border-right:1px solid rgba(255,255,255,.06)}
.ff .stat:last-child{border-right:none}
.ff .stat .n{font-family:var(--font-display);font-weight:800;font-size:30px;letter-spacing:-.02em}
.ff .stat .n b{color:var(--cobalt-bright)}
.ff .stat .l{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-top:6px}
.ff .base{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:24px 0 26px;flex-wrap:wrap}
.ff .base .legal{font-family:var(--font-mono);font-size:11px;letter-spacing:.05em;color:rgba(255,255,255,.45);display:flex;gap:18px;flex-wrap:wrap;align-items:center}
.ff .base .legal a{color:rgba(255,255,255,.55)}
.ff .base .legal a:hover{color:#fff}
.ff .base .right{display:flex;align-items:center;gap:14px}
.ff .base .sister{font-size:13px;color:rgba(255,255,255,.55)}
.ff .base .sister a{color:var(--cobalt-bright)}
.ff .base .region{font-family:var(--font-mono);font-size:11px;color:rgba(255,255,255,.5);border:1px solid rgba(255,255,255,.16);padding:8px 11px;border-radius:8px}
.soc{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:9px;border:1px solid rgba(255,255,255,.16);color:rgba(255,255,255,.75);transition:.15s}
.soc:hover{color:#fff;border-color:var(--cobalt-bright);background:rgba(74,147,240,.12)}
.soc svg{width:16px;height:16px}
.ff .socs{display:flex;gap:9px}
.ff .bigword{text-align:center;font-family:var(--font-display);font-weight:800;font-size:clamp(80px,15vw,210px);line-height:.8;letter-spacing:-.04em;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.07);padding:6px 0 20px;pointer-events:none;user-select:none}
@media(max-width:900px){
    .ff .hero{padding:42px 24px}
    .ff .hero .row{grid-template-columns:1fr;gap:28px}
    .ff .inner{padding:0 24px}
    .ff .mega{grid-template-columns:1fr 1fr;gap:26px}
    .ff .row2{grid-template-columns:1fr}
    .ff .news{flex-direction:column;align-items:flex-start}.ff .news input{width:100%}
    .ff .stats{grid-template-columns:1fr 1fr}
  }

/* newsletter mailto button (interim, swap to endpoint later) */
.ff .news .memo-form{display:flex;gap:10px;flex:none}
.ff .news .memo-btn{background:var(--cobalt);color:#fff;border:none;border-radius:10px;padding:13px 22px;font-family:var(--font-display);font-weight:700;font-size:14px;cursor:pointer;display:inline-flex;align-items:center;text-decoration:none;transition:background .15s}
.ff .news .memo-btn:hover{background:var(--cobalt-deep)}
