:root {
    --bg: #edf3fb;
    --bg-soft: #f8fbff;
    --surface: #ffffff;
    --surface-2: #f2f7ff;
    --surface-3: #e7eefb;
    --line: #d6e1f2;
    --line-strong: #bfd0ea;
    --text: #17345b;
    --text-2: #49698d;
    --text-3: #7c93af;
    --blue: #3975f2;
    --blue-2: #7aa4ff;
    --navy: #17345b;
    --gold: #f0c35a;
    --green: #26b46d;
    --red: #db5f67;
    --shadow-1: 0 12px 36px rgba(33, 71, 131, .12);
    --shadow-2: 0 24px 60px rgba(33, 71, 131, .18);
    --radius-1: 14px;
    --radius-2: 20px;
    --radius-3: 28px;
    --space-1: 8px;
    --space-2: 12px;
    --space-3: 16px;
    --space-4: 24px;
    --space-5: 32px;
    --space-6: 48px;
    --space-7: 64px;
    --container: 1240px;
}
* { box-sizing: border-box; }
html, body { margin:0; padding:0; }
body {
    font-family: 'Inter', sans-serif;
    color: var(--text);
    background:
        radial-gradient(circle at top center, rgba(122,164,255,.18), transparent 42%),
        linear-gradient(180deg, #f7fbff 0%, #edf3fb 100%);
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button, input, select, textarea { font: inherit; }
.container { width:min(var(--container), calc(100% - 40px)); margin:0 auto; }
.page-shell { padding: 34px 0 72px; }
h1, h2, h3, h4 { margin:0; font-family:'Cinzel', serif; font-weight:700; color: var(--navy); line-height:1.05; }
h1 { font-size: clamp(42px, 5vw, 68px); }
h2 { font-size: clamp(28px, 3vw, 42px); }
h3 { font-size: clamp(22px, 2vw, 28px); }
p { margin:0; color: var(--text-2); line-height:1.7; }
ul { margin:0; padding-left: 18px; color: var(--text-2); }
.section { margin-top: var(--space-6); }
.eyebrow {
    display:inline-flex; align-items:center; gap:8px;
    padding:8px 14px; border-radius:999px;
    background: linear-gradient(180deg, #f8fbff, #edf4ff);
    border:1px solid var(--line);
    color: var(--blue);
    font-size: 12px; letter-spacing: .12em; font-weight: 800; text-transform: uppercase;
}
.hero-block {
    background:
        linear-gradient(135deg, rgba(255,255,255,.95), rgba(246,250,255,.88)),
        linear-gradient(180deg, rgba(80,132,255,.16), transparent 45%);
    border:1px solid rgba(191,208,234,.85);
    border-radius: 32px;
    box-shadow: var(--shadow-1);
    padding: clamp(28px, 4vw, 46px);
}
.hero-grid { display:grid; grid-template-columns: 1.2fr .8fr; gap: 24px; align-items: stretch; }
.hero-side {
    background: linear-gradient(180deg, rgba(255,255,255,.85), rgba(242,247,255,.92));
    border:1px solid var(--line);
    border-radius: 24px;
    padding: 20px;
    display:grid; gap:14px;
}
.stack { display:grid; gap:18px; }
.grid-2 { display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:24px; }
.grid-3 { display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:24px; }
.grid-4 { display:grid; grid-template-columns:repeat(4, minmax(0,1fr)); gap:20px; }
.card {
    background: linear-gradient(180deg, rgba(255,255,255,.94), rgba(245,249,255,.98));
    border:1px solid var(--line);
    border-radius: 24px;
    box-shadow: var(--shadow-1);
    padding: 22px;
}
.card-soft {
    background: linear-gradient(180deg, rgba(250,252,255,.92), rgba(239,245,255,.98));
}
.metric {
    display:grid; gap:8px; min-height: 138px;
}
.metric-label {
    font-size: 12px; letter-spacing: .08em; text-transform: uppercase; font-weight:800; color: var(--text-3);
}
.metric-value {
    font-size: clamp(28px, 4vw, 42px); font-weight:800; color: var(--navy); line-height: 1;
}
.metric-copy { font-size: 14px; color: var(--text-2); }
.split {
    display:grid; grid-template-columns: .9fr 1.1fr; gap: 24px;
}
.list-clean { list-style:none; padding:0; margin:0; display:grid; gap:14px; }
.table-shell {
    overflow:hidden; border:1px solid var(--line); border-radius:24px; background:var(--surface); box-shadow:var(--shadow-1);
}
.table-shell table { width:100%; border-collapse: collapse; }
.table-shell th, .table-shell td { padding:16px 18px; text-align:left; border-bottom:1px solid var(--line); font-size:14px; }
.table-shell th { background: var(--surface-2); color: var(--text-2); font-size:12px; letter-spacing:.08em; text-transform:uppercase; }
.pill-row { display:flex; flex-wrap:wrap; gap:10px; }
.pill {
    display:inline-flex; align-items:center; justify-content:center;
    padding:10px 14px; border-radius:999px; border:1px solid var(--line);
    background: rgba(255,255,255,.7); color:var(--text-2); font-weight:700; font-size:13px;
}
.search-panel {
    display:grid; grid-template-columns: 1fr auto auto; gap: 12px; align-items:end;
}
.field {
    display:grid; gap:8px;
}
.field label { font-size:12px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color: var(--text-3); }
.input, .select {
    width:100%; border:1px solid var(--line-strong); background:#fff; border-radius:16px; min-height:52px;
    padding:0 16px; color: var(--text); box-shadow: inset 0 1px 0 rgba(255,255,255,.65);
}
.kicker { max-width: 760px; margin-top: 14px; font-size:18px; }
.actions { display:flex; flex-wrap:wrap; gap:12px; margin-top: 24px; }
.empty-state {
    padding: 28px; border: 1px dashed var(--line-strong); border-radius: 20px; background: rgba(255,255,255,.6);
}
@media (max-width: 1060px) {
    .hero-grid, .split, .grid-4, .grid-3, .grid-2, .search-panel { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
    .page-shell { padding-top: 20px; }
    .container { width:min(var(--container), calc(100% - 24px)); }
    .hero-block { padding: 24px; border-radius: 24px; }
}
