@font-face{font-family:'HelveticaNeueCustom';src:url('/assets/HelveticaNeue-Roman.otf') format('opentype');font-weight:400;font-style:normal;font-display:swap;}
:root{
  --brand:#2a368f;--brand-dark:#1f275f;--brand-mid:#4455c6;
  --line:rgba(42,54,143,.16);--text:#132033;--muted:#5e6a7d;
  --bg1:#eef3ff;--bg2:#dfe7ff;--shadow:0 18px 45px rgba(25,35,95,.15);
  --soft:0 10px 24px rgba(25,35,95,.10);--radius:20px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'HelveticaNeueCustom',Arial,sans-serif;color:var(--text);
  background:radial-gradient(circle at top left,rgba(68,85,198,.18),transparent 32%),
    radial-gradient(circle at bottom right,rgba(42,54,143,.14),transparent 28%),
    linear-gradient(180deg,var(--bg1),#f8fbff 48%,#eef4ff 100%);
  min-height:100vh;display:flex;flex-direction:column;
}
a{color:var(--brand)}
.topbar{
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  max-width:1200px;margin:18px auto 0;width:calc(100% - 36px);padding:14px 22px;
  background:linear-gradient(135deg,rgba(31,39,95,.96),rgba(42,54,143,.93),rgba(68,85,198,.88));
  color:#fff;border-radius:20px;box-shadow:0 20px 40px rgba(18,25,65,.22);
}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:#fff}
.logo{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;
  background:linear-gradient(135deg,#fff,#dbe5ff);color:var(--brand-dark);font-weight:800;font-size:20px}
.brandtext{display:flex;flex-direction:column;line-height:1.1}
.brandtext strong{font-size:22px}
.brandtext em{font-style:normal;font-size:12px;color:rgba(255,255,255,.8)}
.topnav{display:flex;gap:8px;flex-wrap:wrap}
.topnav a{color:#fff;text-decoration:none;font-weight:700;padding:9px 14px;border-radius:12px;
  background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.14)}
.topnav a:hover{background:rgba(255,255,255,.2)}
.page{flex:1;max-width:1200px;margin:0 auto;width:calc(100% - 36px);padding:26px 0}
.card{background:rgba(255,255,255,.9);border:1px solid var(--line);box-shadow:var(--shadow);
  border-radius:24px;padding:28px;margin-bottom:24px;backdrop-filter:blur(8px)}
.hero{display:grid;grid-template-columns:1.05fr .95fr;gap:26px;align-items:center}
.hero h1{margin:0 0 14px;font:700 44px/1.05 Georgia,'Times New Roman',serif;color:var(--brand-dark)}
.lead{font-size:18px;line-height:1.6;color:#344154;margin:0 0 22px}
.btnrow{display:flex;gap:12px;flex-wrap:wrap}
.btn{display:inline-block;padding:14px 20px;border-radius:14px;text-decoration:none;font-weight:800}
.btn.primary{background:linear-gradient(135deg,#2a368f,#4455c6);color:#fff;box-shadow:var(--soft)}
.btn.secondary{background:#fff;color:var(--brand-dark);border:1px solid var(--line)}
.heroshot img{width:100%;border-radius:18px;border:1px solid rgba(42,54,143,.1);box-shadow:0 12px 28px rgba(24,33,88,.12)}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:8px}
.feature{background:#fff;border:1px solid var(--line);border-radius:18px;padding:20px}
.feature h3{margin:0 0 8px;color:var(--brand-dark);font-size:18px}
.feature p{margin:0;color:var(--muted);font-size:14px;line-height:1.55}
h2{font:700 30px Georgia,serif;color:var(--brand-dark);margin:0 0 18px}
.legal-page{max-width:880px;margin:0 auto;line-height:1.6}
.legal-page h1{color:var(--brand-dark)}
.legal-page h2{font-size:22px;margin-top:1.6rem}
form.contact{display:grid;gap:14px;max-width:560px}
form.contact label{font-weight:700;color:var(--brand-dark);font-size:14px}
form.contact input,form.contact textarea{width:100%;padding:12px 14px;border:1px solid var(--line);
  border-radius:12px;font:inherit;font-size:15px}
form.contact textarea{min-height:130px;resize:vertical}
.notice{padding:14px 16px;border-radius:12px;margin-bottom:18px;font-weight:700}
.notice.ok{background:#e6f7ec;color:#176a37;border:1px solid #9fd9b4}
.notice.err{background:#fdecec;color:#a01f1f;border:1px solid #f0b3b3}
.sitefooter{background:linear-gradient(135deg,#1f275f,#2a368f);color:#fff;margin-top:30px}
.footinner{max-width:1200px;margin:0 auto;width:calc(100% - 36px);padding:30px 0;
  display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:22px}
.footbrand strong{display:block;font-size:20px;margin-bottom:6px}
.footbrand span{color:rgba(255,255,255,.78);font-size:14px}
.footlinks{display:flex;flex-direction:column;gap:8px}
.footlinks a,.footcontact a{color:rgba(255,255,255,.9);text-decoration:none}
.footlinks a:hover,.footcontact a:hover{text-decoration:underline}
.footcontact{display:flex;flex-direction:column;gap:8px}
.copyline{border-top:1px solid rgba(255,255,255,.16);text-align:center;padding:16px;
  font-size:13px;color:rgba(255,255,255,.8)}
.copyline a{color:rgba(255,255,255,.9)}
@media (max-width:1000px){.hero,.grid3,.footinner{grid-template-columns:1fr}.topbar{flex-direction:column;align-items:flex-start}}
@media (max-width:600px){.hero h1{font-size:34px}h2{font-size:24px}}
