* { margin: 0; padding: 0; box-sizing: border-box; }
body {
    font-family: "Inter", sans-serif;
    background-color: #ffffff;
    color: #1a1f36;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
}
.container {
    max-width: 1024px;
    margin: 0 auto;
    padding: 0 32px;
}
body::before {
    content: ""; position: fixed; top: 0; left: 0; width: 100%; height: 100%;
    background-image: radial-gradient(circle at 20% 30%, rgba(0, 153, 255, 0.02) 0%, transparent 30%),
    radial-gradient(circle at 80% 70%, rgba(0, 255, 200, 0.02) 0%, transparent 30%);
    pointer-events: none; z-index: -1;
}

a {
    color: #2563eb;
    text-decoration: underline;
}

.navbar {
    display: flex; justify-content: space-between; align-items: center;
    padding: 20px 0;
    border-bottom: 1px solid #eef2f6; margin-bottom: 40px;
}
.logo {
    display: flex;
    align-items: center;
    font-weight: 600; font-size: 1.5rem; letter-spacing: -0.02em;
    color: #13294b;
}
.logo img {
    height: 32px;
    width: auto;
    margin-right: 10px;
    vertical-align: middle;
}
.navbar select {
    background-color: white;
    border: 1px solid #cddfff;
    border-radius: 40px;
    padding: 8px 28px 8px 18px;
    font-family: "Inter", sans-serif;
    font-size: 0.95rem;
    font-weight: 500;
    color: #1e3a8a;
    cursor: pointer;
    outline: none;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%232563eb' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 16px;
    transition: all 0.2s;
}
.navbar select:hover {
    border-color: #2563eb;
    background-color: #f0f7ff;
}
.navbar select:focus {
    border-color: #2563eb;
    box-shadow: 0 0 0 3px rgba(37,99,235,0.2);
}
.navbar select:-moz-focusring {
    color: transparent;
    text-shadow: 0 0 0 #000;
}

.article-header {
    margin-bottom: 48px;
}
.article-header h1 {
    font-size: clamp(2.2rem, 6vw, 3.4rem);
    font-weight: 700; letter-spacing: -0.02em; line-height: 1.2;
    color: #0b1e42; margin-bottom: 20px;
}
.article-header .subhead {
    font-size: 1.5rem; font-weight: 300; color: #2d3c5e;
    border-left: 4px solid #2563eb; padding-left: 24px; margin: 24px 0 20px;
}
.byline {
    display: flex; gap: 32px; color: #4b5b7c; font-weight: 300;
    border-top: 1px solid #e2eaf5; padding-top: 24px; flex-wrap: wrap;
}
.byline i { color: #2563eb; width: 20px; }

h2 {
    font-size: 2rem; font-weight: 600; letter-spacing: -0.01em;
    color: #0b1e42; margin: 56px 0 24px;
}
p {
    font-size: 1.1rem; color: #232b47; margin-bottom: 24px;
    font-weight: 300;
}
p strong { color: #0b1e42; font-weight: 600; }

.graphic-block {
    background: #f6faff;
    border-radius: 36px;
    padding: 44px 36px;
    margin: 56px 0;
    border: 1px solid rgba(0,102,255,0.1);
    box-shadow: 0 20px 35px -10px rgba(0,51,102,0.08);
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 36px;
    position: relative;
    overflow: hidden;
}
.graphic-block::after {
    content: "";
    position: absolute;
    top: -20%; right: -10%;
    width: 300px; height: 300px;
    background: radial-gradient(circle, rgba(37,99,235,0.02) 0%, transparent 70%);
    border-radius: 50%;
    z-index: 0;
}
.graphic-block > * { position: relative; z-index: 2; }

.graphic-block i {
    color: #2563eb;
}

@media (min-width: 700px) {
    .graphic-block {
        flex-wrap: nowrap;
    }
}

.stat-badge {
    background: white; border-radius: 60px; padding: 14px 34px;
    box-shadow: 0 8px 18px rgba(0,51,102,0.05);
    border: 1px solid #dbe9ff;
    font-weight: 600; color: #0047ab; display: inline-flex; align-items: center; gap: 12px;
    font-size: 1.1rem;
}
.icon-strip {
    display: flex; gap: 36px; flex-wrap: wrap; justify-content: center;
    font-size: 2.8rem; color: #2563eb;
}
.icon-strip i { opacity: 0.75; transition: 0.2s; }
.icon-strip i:hover { opacity: 1; transform: scale(1.03); }

ul {
    list-style: none;
    margin: 32px 0;
}
ul li {
    margin-bottom: 36px;
}
.li-title {
    display: flex;
    align-items: flex-start;
    gap: 18px;
    margin-bottom: 8px;
}
.li-title i {
    color: #2563eb;
    font-size: 1.8rem;
    min-width: 44px;
    text-align: center;
    margin-top: 2px;
}
.li-title strong {
    font-size: 1.2rem;
    font-weight: 600;
    color: #0b1e42;
    line-height: 1.4;
}
.li-desc {
    margin-left: 62px;
    color: #232b47;
    font-weight: 300;
    font-size: 1.1rem;
}

.custody-block {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    font-weight: 600;
    font-size: 1.2rem;
    gap: 8px;
}
.custody-block i {
    font-size: 3.2rem;
}

.pull-quote {
    background: #ffffff; border-radius: 48px; padding: 36px 48px;
    border: 1px solid #cddfff; box-shadow: 0 10px 30px -10px #d4e2ff;
    margin: 56px 0; font-size: 1.25rem; font-style: italic;
    color: #10325c; font-weight: 350;
}
.pull-quote i { color: #2563eb; margin-right: 16px; font-size: 1.6rem; }

footer {
    border-top: 1px solid #e4ecfc; padding: 40px 0; margin-top: 80px;
    display: flex; justify-content: space-between; color: #546a8a;
    font-weight: 300; flex-wrap: wrap;
}
hr {
    border: none; height: 1px; background: linear-gradient(to right, #ffffff, #a0c4ff, #ffffff);
    margin: 64px 0;
}

@media (max-width: 700px) {
    .container { padding: 0 20px; }
    h2 { font-size: 1.8rem; }
    .graphic-block { padding: 30px 20px; }
    .li-desc { margin-left: 0; }
    .navbar {
        flex-wrap: wrap;
        gap: 15px;
    }
    .navbar select {
        width: 100%;
    }
}