:root{
      --navy:#0b2341; --blue:#15487f; --blue2:#2c74c9; --pale:#f4f8fc;
      --text:#0f2e55; --muted:#5c6f86; --line:#dfe9f5;
    }
    *{box-sizing:border-box}
    html{scroll-behavior:smooth}
    body{margin:0;font-family:Inter,Arial,Helvetica,sans-serif;background:var(--pale);color:#14263d;line-height:1.55}
    .market-ribbon{
      background:#07192d;
      color:white;
      border-bottom:1px solid rgba(255,255,255,.08);
    }
    .market-ribbon-note{
      max-width:1200px;
      margin:0 auto;
      padding:8px 24px 0;
      font-size:11px;
      color:rgba(255,255,255,.6);
      letter-spacing:.02em;
    }
    a{text-decoration:none;color:inherit}
    .wrap{max-width:1200px;margin:0 auto;padding:0 24px}
    .hero{
      color:white;overflow:hidden;position:relative;
      background:
        linear-gradient(rgba(8,24,48,.58), rgba(8,24,48,.58)),
        radial-gradient(circle at top left, rgba(91,140,255,.18), transparent 34%),
        url("assets/hero-background.png");
      background-size: cover, auto, cover;
      background-position: center, top left, center;
      background-repeat: no-repeat;
    }
    .hero::before,.hero::after{content:"";position:absolute;border:1px solid rgba(255,255,255,.15);border-radius:999px;pointer-events:none}
    .hero::before{width:320px;height:320px;left:-120px;top:-120px}
    .hero::after{width:220px;height:220px;right:40px;top:90px}
    .topbar{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:28px 0 14px;position:relative;z-index:1}
    .brand small{display:block;text-transform:uppercase;letter-spacing:.24em;color:rgba(255,255,255,.72);font-size:12px;margin-bottom:6px}
    .pill{border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.1);padding:10px 16px;border-radius:999px;font-size:12px;backdrop-filter: blur(8px)}
    .sfl-link{display:inline-flex;align-items:center;gap:12px;padding:10px 14px 10px 10px;border-radius:18px}
    .sfl-link:hover{background:rgba(255,255,255,.16)}
    .sfl-logo-wrap{
      width:54px;height:54px;border-radius:14px;background:white;
      display:inline-flex;align-items:center;justify-content:center;
      padding:4px;flex:0 0 auto;box-shadow: inset 0 0 0 1px rgba(21,72,127,.08);
    }
    .sfl-logo-img{max-width:100%;max-height:100%;object-fit:contain;display:block}
    .sfl-logo-text{display:flex;flex-direction:column;line-height:1.08}
    .sfl-logo-text strong{font-size:12px;color:#fff;font-weight:700}
    .sfl-logo-text small{font-size:11px;color:#ffffff;margin-top:5px;text-decoration:underline;text-underline-offset:2px}
    .hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:center;padding:28px 0 64px;position:relative;z-index:1}
    .eyebrow{text-transform:uppercase;letter-spacing:.28em;font-size:12px;color:rgba(219,234,254,.96);margin-bottom:18px;text-shadow:0 2px 10px rgba(0,0,0,.28)}
    h1{margin:0;font-size:58px;line-height:1.04;letter-spacing:-.03em;max-width:760px;text-shadow:0 4px 18px rgba(0,0,0,.28)}
    .lead{font-size:20px;color:rgba(255,255,255,.92);max-width:720px;margin:22px 0 0;text-shadow:0 2px 12px rgba(0,0,0,.25)}
    .actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
    .btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:0 22px;border-radius:999px;font-weight:600;transition:.2s ease;border:1px solid transparent;cursor:pointer}
    .btn.primary{background:white;color:var(--blue)}
    .btn.primary:hover{background:#eef5ff}
    .btn.ghost{border-color:rgba(255,255,255,.35);color:white;background:transparent}
    .btn.ghost:hover{background:rgba(255,255,255,.1)}
    .hero-card{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);padding:16px;border-radius:34px;backdrop-filter: blur(12px);box-shadow:0 24px 60px rgba(0,0,0,.24)}
    .hero-card-inner{background:rgba(255,255,255,.96);border-radius:28px;overflow:hidden;color:var(--text)}
    .portrait{width:100%;aspect-ratio:4 / 5;object-fit:cover;object-position:center 18%;display:block;background:#eef4ff}
    .hero-info{padding:24px 24px 22px}
    .hero-info h2{margin:0;font-size:32px;line-height:1.1;color:var(--text)}
    .subtitle{margin:10px 0 0;color:var(--muted);font-size:15px}
    .mini-pill{display:inline-block;margin-top:14px;background:#e8f0fc;color:#1c5ea8;padding:8px 12px;border-radius:999px;font-size:12px;font-weight:600}
    .feature-list{display:grid;gap:12px;margin-top:20px}
    .feature{border:1px solid var(--line);background:#f8fbff;border-radius:18px;padding:14px 16px}
    .feature strong{display:block;color:#6a7d94;font-size:13px;margin-bottom:4px}
    .feature span{font-weight:700;color:var(--text)}
    .gpjl-feature{display:grid;grid-template-columns:88px 1fr;gap:14px;align-items:center}
    .gpjl-logo{
      width:88px;height:88px;object-fit:contain;background:white;border-radius:14px;
      border:1px solid #e6e6e6;padding:6px;
    }
    .gpjl-text span{display:block;line-height:1.35}

    section{padding:78px 0}
    .section-title{color:#1c5ea8;text-transform:uppercase;letter-spacing:.25em;font-size:12px;font-weight:700;margin:0 0 14px}
    .two-col{display:grid;grid-template-columns:.9fr 1.1fr;gap:42px;align-items:start}
    h3{margin:0;font-size:40px;line-height:1.1;color:var(--text);letter-spacing:-.02em}
    .body-lg{font-size:20px;color:#485c74}
    .services{background:white;border-top:1px solid #eef3f8;border-bottom:1px solid #eef3f8}
    .cards{margin-top:34px;display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
    .card{background:#f8fbff;border:1px solid var(--line);border-radius:24px;padding:24px;box-shadow:0 8px 24px rgba(8,35,65,.04)}
    .icon{width:48px;height:48px;border-radius:16px;background:#dce9fb;display:flex;align-items:center;justify-content:center;color:#1c5ea8;font-weight:800;font-size:22px;margin-bottom:16px}
    .card h4{margin:0 0 10px;color:var(--text);font-size:22px}
    .card p{margin:0;color:#5d7087}
    .steps{display:grid;gap:14px}
    .step{display:flex;gap:16px;align-items:flex-start;background:white;border:1px solid var(--line);border-radius:24px;padding:18px 20px;box-shadow:0 8px 24px rgba(8,35,65,.04)}
    .step-num{width:38px;height:38px;border-radius:999px;background:#1c5ea8;color:white;display:flex;align-items:center;justify-content:center;font-weight:700;flex:0 0 auto}
    .cta{color:white;background:linear-gradient(135deg,#0c2748 0%, #15487f 55%, #2c74c9 100%)}
    .cta-box{display:grid;grid-template-columns:1fr auto;gap:26px;align-items:center;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:32px;padding:34px}
    footer{background:#0a1f37;color:white}
    .footer-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px}
    .contact-list{display:grid;gap:14px}
    .legal{border-top:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.64);font-size:14px;margin-top:34px;padding-top:22px}
    @media (max-width: 980px){
      .hero-grid,.two-col,.cards,.cta-box,.footer-grid{grid-template-columns:1fr}
      h1{font-size:42px} h3{font-size:32px} .lead,.body-lg{font-size:18px} .portrait{aspect-ratio:1 / 1.1}
    }