
:root{
 --bg:#ffffff;--ink:#13171E;--muted:#5A6373;--line:#E6E9EF;--soft:#F5F7FA;
 --navy:#12305B;--navy2:#1C4585;--sans:'Inter',system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);line-height:1.55;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}
/* header */
.util{border-bottom:1px solid var(--line);font-size:12.5px;color:var(--muted)}
.util .wrap{display:flex;justify-content:space-between;align-items:center;height:38px}
.util b{color:var(--navy);font-weight:600}
.masthead{border-bottom:2px solid var(--ink);padding:20px 0 16px}
.masthead .wrap{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap}
.wordmark{font-weight:900;font-size:33px;letter-spacing:-.03em;line-height:1}
.wordmark b{color:var(--navy)}
.tag{font-size:12.5px;color:var(--muted);margin-top:5px}
.nav{display:flex;gap:23px;font-weight:600;font-size:14.5px}
.nav a:hover,.nav a.on{color:var(--navy)}
.kicker{color:var(--navy);font-weight:800;font-size:11.5px;text-transform:uppercase;letter-spacing:.13em}
/* homepage hero */
.hero{display:grid;grid-template-columns:1.55fr 1fr;gap:40px;padding:32px 0;border-bottom:1px solid var(--line)}
.lead .ph{height:300px;border-radius:8px;margin:13px 0 15px;background:linear-gradient(135deg,#12305B,#2C5FA0 70%,#3E78C4) center/cover no-repeat}
.lead{min-width:0}
.lead h1{font-size:37px;line-height:1.1;letter-spacing:-.025em;font-weight:800;overflow-wrap:break-word}
.lead:hover h1{color:var(--navy)}
.lead p{color:var(--muted);font-size:17px;margin-top:11px;max-width:46ch;overflow-wrap:break-word}
.rail h3{font-size:12px;text-transform:uppercase;letter-spacing:.13em;padding-bottom:11px;border-bottom:2px solid var(--ink);margin-bottom:4px}
.rank{display:flex;gap:14px;padding:13px 0;border-bottom:1px solid var(--line)}
.rank .n{font-weight:900;font-size:22px;color:var(--navy);line-height:1;min-width:22px;flex:0 0 22px}
.rank a{font-weight:600;font-size:15px;line-height:1.3;min-width:0;overflow-wrap:break-word}
.rank a:hover{color:var(--navy)}
/* sections */
.sec{padding:28px 0;border-bottom:1px solid var(--line)}
.sec-h{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.sec-h .bar{width:8px;height:22px;background:var(--navy);border-radius:2px}
.sec-h h2{font-size:20px;font-weight:800;letter-spacing:-.01em}
.sec-h a{margin-left:auto;font-size:13px;font-weight:600;color:var(--navy)}
.row4{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.lc{min-width:0}
.lc .ph{height:150px;border-radius:7px;background:var(--soft) center/cover no-repeat;border:1px solid var(--line);margin-bottom:10px}
.lc .ph.g{background:linear-gradient(135deg,#E9EEF5,#D6E0EE)}
.lc h3{font-size:15.5px;font-weight:700;line-height:1.3;margin-top:5px;overflow-wrap:break-word}
.lc:hover h3{color:var(--navy)}
.lc p{font-size:13px;color:var(--muted);margin-top:6px;overflow-wrap:break-word}
/* persons band */
.persons{background:var(--soft);border-radius:10px;padding:24px 26px;margin:28px 0}
.persons h2{font-size:18px;font-weight:800;display:flex;align-items:center;gap:10px}
.persons h2 .bar{width:8px;height:20px;background:var(--navy);border-radius:2px}
.persons .sub{color:var(--muted);font-size:13.5px;margin:5px 0 18px}
.prow{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.pcard{display:flex;gap:12px;align-items:center;min-width:0}
.pcard .av{width:52px;height:52px;border-radius:50%;flex:0 0 52px;background:linear-gradient(135deg,#12305B,#3E78C4) center/cover no-repeat}
.pcard b{font-size:14.5px;font-weight:700;line-height:1.25;min-width:0;overflow-wrap:break-word}
.pcard:hover b{color:var(--navy)}
/* article */
.crumb{font-size:12.5px;color:var(--muted);padding:20px 0 0}
.crumb a:hover{color:var(--navy)}
.art{max-width:740px;margin:0 auto;padding:0 28px}
.art-head{padding:12px 0 6px}
.art-head h1{font-size:37px;line-height:1.12;letter-spacing:-.025em;font-weight:800;margin:9px 0 12px}
.art-head .by{font-size:13px;color:var(--muted);border-bottom:1px solid var(--line);padding-bottom:15px}
.art-hero{margin:18px 0 4px;border-radius:8px;overflow:hidden;background:var(--soft)}
.art-hero img{width:100%;aspect-ratio:16/9;object-fit:cover}
.prose{font-size:17px;line-height:1.75;color:#1d222b;padding:14px 0 8px}
.prose p{margin:0 0 1.1em}
.prose h2{font-size:23px;font-weight:800;line-height:1.2;margin:1.5em 0 .5em;letter-spacing:-.01em}
.prose h3{font-size:18.5px;font-weight:700;margin:1.3em 0 .4em}
.prose ul,.prose ol{margin:0 0 1.1em 1.2em}.prose li{margin:.3em 0}
.prose img{border-radius:7px;margin:1.2em 0}
.prose a{color:var(--navy);border-bottom:1px solid var(--navy2)}
.art-foot{border-top:1px solid var(--line);margin-top:22px;padding:16px 0 0;font-size:13px}
.art-foot a{color:var(--navy);font-weight:600}
/* category */
.ch{padding:30px 0 14px;border-bottom:2px solid var(--ink);margin-bottom:26px}
.ch h1{font-size:32px;letter-spacing:-.02em;font-weight:800;margin-top:6px}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.pag{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin:40px 0 8px;font-size:14px}
.pag a,.pag .cur{padding:8px 13px;border:1px solid var(--line);border-radius:6px}
.pag a:hover{border-color:var(--navy);color:var(--navy)}
.pag .cur{background:var(--navy);color:#fff;border-color:var(--navy)}
.pag .dots{padding:8px 4px;color:var(--muted)}
/* footer */
footer{margin-top:10px;border-top:2px solid var(--ink);background:#fff}
footer .wrap{padding:28px 0 50px}
footer .fm{font-weight:900;font-size:23px;letter-spacing:-.02em}
footer .fm b{color:var(--navy)}
footer .cols{display:flex;gap:26px;font-size:13.5px;color:var(--muted);flex-wrap:wrap;margin-top:14px}
footer .cols a:hover{color:var(--navy)}
footer .note{color:var(--muted);font-size:13.5px;margin-top:16px;max-width:60ch}
@media(max-width:880px){.hero{grid-template-columns:1fr;gap:26px}.row4,.grid,.cards,.prow{grid-template-columns:1fr 1fr}.lead h1{font-size:32px}.lead .ph{height:240px}}
@media(max-width:560px){.row4,.grid,.cards,.prow{grid-template-columns:1fr}.nav{display:none}.tag{display:none}.lead h1{font-size:28px}.art-head h1{font-size:27px}.wordmark{font-size:27px}}
