/* FranklinCyber v3.4 — Mobile + Self-hosted fonts */
@font-face {
  font-family: 'Inter';
  src: url('/assets/fonts/Inter-Regular.woff2') format('woff2');
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Inter';
  src: url('/assets/fonts/Inter-Bold.woff2') format('woff2');
  font-weight: 700; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Orbitron';
  src: url('/assets/fonts/Orbitron-Regular.woff2') format('woff2');
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Orbitron';
  src: url('/assets/fonts/Orbitron-Bold.woff2') format('woff2');
  font-weight: 700; font-style: normal; font-display: swap;
}

:root{
  --bg:#081225; --bg-alt:#0b1730; --card:#0c1d3a; --ink:#e9f2ff; --muted:#b7c8e6;
  --accent:#7fb8ff; --accent-2:#4db3ff; --btn:#112a52; --border:rgba(255,255,255,0.12);
  --focus:#9be7ff; --vault-band:#080f1f; --header-h:64px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol";
  color:var(--ink);
  background:
    radial-gradient(1300px 700px at 15% -10%, rgba(77,179,255,.20), transparent 60%),
    radial-gradient(1100px 600px at 85% 10%, rgba(127,184,255,.15), transparent 60%),
    linear-gradient(180deg,#050c1a 0%, #081225 45%, #0a1830 100%);
  line-height:1.55; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  -webkit-tap-highlight-color: transparent;
}

.anchor{scroll-margin-top: calc(var(--header-h) + 12px)}

h1,h2,h3,h4,.brand-text{
  font-family:"Orbitron", Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  letter-spacing:.3px;
}
h1{font-weight:700} h2,h3,h4{font-weight:700}

img{max-width:100%;height:auto}
.container{width:min(1100px, 92%); margin-inline:auto}

.skip-link{position:absolute; left:-10000px; top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:1rem;top:1rem;width:auto;height:auto;z-index:999;background:#000;color:#fff;padding:.5rem .75rem;border-radius:.5rem}

.site-header{position:sticky; top:0; z-index:50; backdrop-filter:saturate(180%) blur(10px);
  background:rgba(5,12,26,.55); border-bottom:1px solid var(--border); height:var(--header-h)}
.header-inner{display:flex; align-items:center; justify-content:space-between; padding:.5rem 0}
.brand{display:flex; align-items:center; gap:.6rem; font-weight:700; letter-spacing:.2px; min-width:0}
.logo{width:28px; height:28px; border-radius:50%; flex:0 0 auto}
.brand-text{font-size:1.05rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:60vw}
.brand-text .tm{font-size:.65rem; margin-left:.2rem; opacity:.85; vertical-align:super}
.accent{background:linear-gradient(90deg,var(--accent-2),var(--accent)); -webkit-background-clip:text; background-clip:text; color:transparent}

.site-nav .nav-toggle{
  background:transparent;color:var(--ink); border:1px solid var(--border);
  padding:.6rem .75rem; border-radius:.5rem; display:none; min-height:44px;
}

.nav-list{display:flex; gap:1rem; list-style:none; margin:0; padding:0}
.nav-list a{color:var(--ink); text-decoration:none; padding:.45rem .6rem; border-radius:.4rem}
.nav-list a:hover{background:rgba(255,255,255,.06)}

.hero{
  padding: clamp(3rem, 8vw, 6rem) 0 2.25rem;
  background:
    radial-gradient(1400px 700px at 10% -10%, rgba(77,179,255,.28), transparent 60%),
    radial-gradient(1200px 650px at 90% 0%, rgba(127,184,255,.24), transparent 60%);
}
.hero-inner{max-width:860px}
.hero h1{ font-size: clamp(1.9rem, 5.2vw, 3.2rem); line-height:1.16; margin:0 0 .6rem }
.period{background:linear-gradient(90deg,#7fb8ff,#4db3ff,#3be3d2); -webkit-background-clip:text; background-clip:text; color:transparent}
.lead{font-size: clamp(1rem, 2.6vw, 1.2rem); color:var(--muted); margin:0 0 1rem}

.cta-group{display:flex; gap:.6rem; flex-wrap:wrap}
.btn{
  display:inline-block; text-decoration:none; border-radius:.6rem; padding:.8rem 1rem; border:1px solid var(--border);
  transition:transform .12s ease, background .2s ease, border-color .2s ease, box-shadow .2s ease;
  box-shadow: 0 6px 20px rgba(77,179,255,.12); min-height:44px;
}
.btn:hover{transform:translateY(-1px); border-color:rgba(255,255,255,.22)}
.btn.primary{background:var(--btn); border-color:transparent}
.btn.ghost{background:transparent}

.section{position:relative}
.pad{padding: clamp(2rem, 6vw, 3.5rem) 0}
.alt{background:linear-gradient(180deg, var(--bg-alt), transparent)}

.two-col{ display:grid; gap:1.25rem; grid-template-columns: 1.1fr .9fr }
@media (max-width: 860px){
  .site-nav .nav-toggle{display:inline-block}
  .nav-list{display:none; position:absolute; right:1rem; top:calc(var(--header-h) - 4px); background:#061127; padding:.6rem; border:1px solid var(--border); border-radius:.6rem; flex-direction:column; gap:.2rem; width:max(200px, 45vw)}
  .nav-list.open{display:flex}
  .brand-text{max-width:50vw}
  .two-col{grid-template-columns:1fr}
  .contact-wide{max-width:100%}
  .logo{width:24px; height:24px}
}

.card{ background: var(--card); border:1px solid var(--border); border-radius:1rem; padding:1rem; box-shadow: 0 8px 24px rgba(0,0,0,.25) }
.callout .mini-brand{display:flex; align-items:center; gap:.8rem; margin-bottom:.5rem}
.mini-logo{width:20px; height:20px}
.mini-title{font-weight:700}
.mini-sub{color:var(--muted); font-size:.95rem}
.muted{color:var(--muted)} .small{font-size:.9rem}

.checklist{margin:.5rem 0 0 0; padding:0; list-style:none}
.checklist li{padding-left:1.4rem; position:relative; margin:.35rem 0}
.checklist li::before{ content:"✓"; position:absolute; left:0; top:0; color:var(--accent); font-weight:700 }

.steps{display:grid; grid-template-columns: repeat(3, 1fr); gap:1rem; margin-top:1rem}
@media (max-width: 860px){ .steps{grid-template-columns:1fr} }
.step{background:var(--card); border:1px solid var(--border); border-radius:1rem; padding:1rem}
.step-num{ width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#3be3d2,#4db3ff); color:#001025; font-weight:800; margin-bottom:.5rem }

.pillars{display:grid; grid-template-columns: repeat(3, 1fr); gap:1rem; margin-top:1.25rem}
@media (max-width: 860px){ .pillars{grid-template-columns:1fr} }
.pillar{border-left:3px solid var(--accent); padding: .75rem 1rem; background:rgba(255,255,255,.03); border-radius:.5rem}

.vault-band{background: linear-gradient(180deg, var(--vault-band), #0a152a 80%, transparent 100%)}
.vault-card{display:flex; flex-direction:column; align-items:center; justify-content:center; gap:.75rem; text-align:center}
.vault-img{width:140px; height:auto; max-width:50vw; filter: drop-shadow(0 12px 30px rgba(61,179,255,.18))}

.bullets{padding-left:1rem} .bullets li{margin:.4rem 0}
.shield-card{display:flex; align-items:center; gap:1rem}

.contact-card .contact-list{list-style:none; margin:0; padding:0}
.contact-card .contact-list li{display:flex; gap:.5rem; align-items:center; margin:.35rem 0; flex-wrap:wrap}
.contact-card .contact-list span{display:inline-block; width:64px; color:var(--muted)}
.contact-wide{max-width:720px; margin:0 auto}

.site-footer{ border-top:1px solid var(--border); background:#050c1a; color:var(--muted) }
.footer-inner{display:flex; align-items:center; justify-content:space-between; gap:.75rem; padding:1rem 0; flex-wrap:wrap}
.footer-links{display:flex; flex-wrap:wrap; gap:.5rem}
.footer-links a{color:var(--muted); text-decoration:none}
.footer-links a:hover{color:var(--ink)}
