:root{
  --ink:#07142d;
  --line:#e6ebf3;
  --blue:#2f80ed;
}

*{
  box-sizing:border-box;
}

html{
  min-height:100%;
}

body{
  margin:0;
  min-height:100vh;
  font-family:"Plus Jakarta Sans",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--ink);
  background:
    url("data:image/svg+xml,%3Csvg width='1800' height='1400' viewBox='0 0 1800 1400' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M160 760C315 610 455 670 590 500C710 350 850 230 1050 285C1220 332 1210 505 1355 590C1490 670 1600 735 1570 890C1545 1020 1690 1095 1770 1175' fill='none' stroke='%238fc5ff' stroke-opacity='.13' stroke-width='18' stroke-linecap='round'/%3E%3Cpath d='M-80 1220C110 1080 335 1160 515 940C680 740 810 660 990 740C1165 820 1150 1025 1330 1100C1495 1170 1610 1190 1790 1325' fill='none' stroke='%238fc5ff' stroke-opacity='.10' stroke-width='18' stroke-linecap='round'/%3E%3C/svg%3E") center top/1800px auto no-repeat,
    linear-gradient(180deg,#ffffff 0%,#fbfcff 44%,#f6f8fc 100%);
  letter-spacing:-.03em;
}

a{
  color:inherit;
  text-decoration:none;
}

.page-shell{
  width:min(1180px,calc(100% - 40px));
  min-height:100vh;
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:14px 0 34px;
}

.hero-card{
  width:100%;
  text-align:center;
  padding:8px 0 26px;
}

.brand-logo{
  display:block;
  width:auto;
  object-fit:contain;
}

.top-logo{
  height:87px;
  max-width:390px;
  margin:0 auto 24px;
}

h1{
  max-width:1040px;
  margin:0 auto 14px;
  font-size:clamp(44px,4.35vw,61px);
  line-height:1.04;
  font-weight:900;
  color:#34363b;
}

.subhead{
  max-width:980px;
  margin:0 auto 48px;
  font-size:clamp(14px,1.15vw,17px);
  line-height:1.35;
  color:#101828;
  letter-spacing:-.02em;
}

.content-grid{
  max-width:1080px;
  margin:0 auto 60px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:54px;
  text-align:left;
  align-items:start;
}

.info-block,
.video-block{
  min-width:0;
}

.feature-logo{
  display:block;
  width:168px;
  max-width:100%;
  height:auto;
  object-fit:contain;
  margin:0 auto 18px;
  border:1px solid #d7dde8;
  box-shadow:0 4px 12px rgba(9,27,65,.10);
  background:#fff;
}

.content-grid h2{
  margin:0 0 12px;
  font-size:22px;
  line-height:1.1;
  color:#05070b;
}

.content-grid p{
  margin:0;
  font-size:14px;
  line-height:1.42;
  color:#111827;
  letter-spacing:-.02em;
}

.feature-list{
  list-style:none;
  padding:0;
  margin:0;
  font-size:14px;
  line-height:1.32;
  color:#111827;
  letter-spacing:-.02em;
}

.feature-list li{
  margin:3px 0;
}

.feature-list li::before{
  content:"- ";
}

.video-embed{
  width:100%;
  max-width:360px;
  aspect-ratio:16/9;
  margin:0 0 18px;
  border:1px solid #d7dde8;
  box-shadow:0 4px 12px rgba(9,27,65,.10);
  overflow:hidden;
  background:#f7faff;
}

.video-embed iframe{
  width:100%;
  height:100%;
  border:0;
  display:block;
}

.links{
  display:flex;
  justify-content:center;
  gap:28px;
  flex-wrap:wrap;
  margin:0;
  padding-bottom:10px;
  color:#767676;
  font-size:15px;
  font-weight:500;
}

.links a:hover{
  color:var(--blue);
}

.legal-shell{
  width:min(920px,calc(100% - 36px));
  margin:0 auto;
  padding:56px 0 76px;
}

.legal-card{
  background:rgba(255,255,255,.92);
  border:1px solid var(--line);
  border-radius:30px;
  padding:48px;
  box-shadow:0 18px 60px rgba(9,27,65,.06);
  backdrop-filter:blur(12px);
}

.legal-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  margin-bottom:38px;
}

.legal-top .brand-logo{
  height:64px;
  max-width:260px;
  margin:0;
}

.not-found-logo{
  height:82px;
  max-width:320px;
}

.back-link{
  color:#667085;
  font-weight:800;
  font-size:14px;
}

.back-link:hover{
  color:var(--blue);
}

.legal-card h1{
  margin:0 0 24px;
  font-size:48px;
  line-height:1.05;
  color:var(--ink);
}

.legal-card h2{
  margin:42px 0 16px;
  font-size:28px;
  line-height:1.18;
  color:var(--ink);
}

.legal-card h3{
  margin:28px 0 10px;
  font-size:20px;
  line-height:1.25;
  color:var(--ink);
}

.legal-card p,
.legal-card li{
  color:#4b5565;
  line-height:1.75;
  font-size:16px;
  letter-spacing:-.02em;
}

.legal-card ul{
  margin:12px 0 24px;
  padding-left:24px;
}

.legal-card li{
  margin:7px 0;
}

.legal-card a{
  color:var(--blue);
  font-weight:800;
}

code{
  background:#f3f7fc;
  border:1px solid var(--line);
  border-radius:8px;
  padding:2px 6px;
  font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace;
  font-size:.92em;
  word-break:break-word;
}

@media(max-width:980px){
  .page-shell{
    padding:28px 0 42px;
    align-items:flex-start;
  }

  .top-logo{
    height:78px;
    margin-bottom:22px;
  }

  h1{
    max-width:760px;
    font-size:clamp(38px,8vw,54px);
  }

  .subhead{
    max-width:760px;
    margin-bottom:34px;
  }

  .content-grid{
    grid-template-columns:1fr;
    gap:34px;
    max-width:420px;
    margin-bottom:46px;
  }

  .feature-logo{
    width:168px;
  }

  .video-embed{
    width:100%;
    max-width:100%;
  }

  .legal-top{
    align-items:flex-start;
    flex-direction:column;
  }
}

@media(max-width:760px){
  .page-shell{
    width:min(100%,calc(100% - 24px));
    padding:22px 0 44px;
  }

  .hero-card{
    padding:0 0 24px;
  }

  .top-logo{
    height:72px;
  }

  h1{
    font-size:clamp(34px,10vw,44px);
  }

  .subhead{
    font-size:14px;
    line-height:1.45;
  }

  .content-grid h2{
    font-size:20px;
  }

  .feature-list,
  .content-grid p{
    font-size:14px;
  }

  .links{
    padding-bottom:18px;
  }

  .legal-card{
    padding:28px;
    border-radius:22px;
  }

  .legal-card h1{
    font-size:36px;
  }

  .legal-card h2{
    font-size:25px;
  }

  .legal-top .brand-logo{
    height:56px;
  }

  .not-found-logo{
    height:72px;
    max-width:280px;
  }
}