@import url('https://fonts.googleapis.com/css2?family=DM+Mono:wght@400;500&family=Fraunces:opsz,wght@9..144,500;9..144,600;9..144,700&family=Manrope:wght@400;500;600;700;800&display=swap');

:root{
  --ink:#12304f;
  --muted:#617f95;
  --paper:#f6fbff;
  --line:#c5dbe9;
  --gold:#d89500;
  --gold-soft:#fff0bd;
  --lilac:#e8dcff;
  --blue:#006ca7;
  --container:min(900px,calc(100% - 44px));
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--ink);
  background:
    radial-gradient(circle at 12% 7%,rgba(216,149,0,.10),transparent 25%),
    radial-gradient(circle at 91% 17%,rgba(0,108,167,.10),transparent 28%),
    linear-gradient(180deg,#f7fbff 0%,#ebf6ff 52%,#f9fcff 100%);
  font-family:Manrope,Arial,sans-serif;
  overflow-x:hidden;
}
body:before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-2;
  pointer-events:none;
  opacity:.6;
  background:
    linear-gradient(rgba(18,48,79,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(18,48,79,.04) 1px,transparent 1px);
  background-size:34px 34px;
}
a{color:var(--blue);font-weight:800;text-decoration:none}
a:hover{color:var(--gold)}
.bookmark{
  position:fixed;
  top:0;left:0;bottom:0;
  z-index:12;
  width:58px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:space-between;
  padding:18px 0;
  background:rgba(248,252,255,.88);
  border-right:1px solid rgba(18,48,79,.12);
  backdrop-filter:blur(15px);
}
.bookmark span{
  writing-mode:vertical-rl;
  transform:rotate(180deg);
  color:#7090a7;
  font:500 9px "DM Mono",monospace;
  letter-spacing:.15em;
}
.bookmark b{
  display:grid;
  place-items:center;
  width:34px;height:34px;
  border-radius:50%;
  background:var(--ink);
  color:#fff;
  font:500 10px "DM Mono",monospace;
}
.topline{
  margin-left:58px;
  border-bottom:1px solid rgba(18,48,79,.12);
}
.topline-inner{
  width:min(1120px,calc(100% - 42px));
  min-height:82px;
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}
.brand{display:flex;align-items:center;gap:11px;color:var(--ink)}
.brand img{
  width:47px;height:47px;
  border-radius:16px;
  box-shadow:0 11px 23px rgba(216,149,0,.16);
}
.brand strong{display:block;font-size:15px;letter-spacing:-.03em}
.brand span{display:block;margin-top:3px;color:#7794a9;font-size:11px}
.edition{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
  font:500 10px "DM Mono",monospace;
}
.edition span,.edition b{
  padding:9px 11px;
  border-radius:999px;
  border:1px solid var(--line);
  background:#fff;
  color:#6c899f;
  font-weight:500;
}
.edition b{background:var(--ink);border-color:var(--ink);color:#fff}
main{margin-left:58px}
.cover{
  position:relative;
  overflow:hidden;
  width:var(--container);
  min-height:465px;
  margin:34px auto 0;
  padding:clamp(30px,5vw,58px);
  background:#f9fdff;
  border:1px solid #bcd5e7;
  box-shadow:0 23px 65px rgba(25,74,113,.14);
}
.paper-grid{
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    repeating-linear-gradient(0deg,transparent 0 31px,rgba(18,48,79,.045) 31px 32px),
    linear-gradient(90deg,rgba(216,149,0,.23) 0 2px,transparent 2px 100%);
  background-position:0 0,74px 0;
}
.cover:after{
  content:"";
  position:absolute;
  right:-105px;top:-112px;
  width:390px;height:390px;
  border:1px solid rgba(216,149,0,.28);
  border-radius:50%;
  box-shadow:0 0 0 38px rgba(216,149,0,.035),0 0 0 76px rgba(216,149,0,.025);
}
.cover-content{position:relative;z-index:2;max-width:690px}
.issue{margin:0;color:var(--blue);font:500 10px "DM Mono",monospace;letter-spacing:.14em}
.issue:before{content:"";display:inline-block;width:34px;height:2px;background:var(--gold);vertical-align:middle;margin-right:10px}
h1{
  margin:18px 0;
  font:600 clamp(52px,7vw,96px)/.87 Fraunces,Georgia,serif;
  letter-spacing:-.09em;
}
.lead{
  max-width:620px;
  color:#56738a;
  font-size:17px;
  line-height:1.76;
}
.stamp-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:28px}
.stamp-row span{
  padding:9px 10px;
  border:1px solid var(--line);
  background:#fff;
  color:#7895a9;
  font:500 10px "DM Mono",monospace;
}
.stamp-row b{color:var(--ink)}
.paper-tag{
  position:absolute;
  right:33px;bottom:31px;
  z-index:2;
  width:260px;
  padding:15px;
  display:flex;
  align-items:center;
  gap:12px;
  background:var(--lilac);
  border:1px solid #d7c8ff;
  transform:rotate(-2deg);
  box-shadow:0 11px 25px rgba(65,42,105,.12);
}
.paper-tag:before{
  content:"";
  position:absolute;
  top:-9px;left:43%;
  width:50px;height:18px;
  background:rgba(216,149,0,.42);
  transform:rotate(4deg);
}
.paper-tag img{width:42px;height:42px;border-radius:13px}
.paper-tag span{font-size:12px;line-height:1.45;color:#566f89;font-weight:700}
.article{
  width:var(--container);
  max-width:780px;
  margin:0 auto;
  padding:44px 0 80px;
  color:#45647c;
  font-size:16px;
  line-height:1.82;
}
.article p{margin:0 0 21px}
.article strong{color:var(--ink)}
.article h2{
  margin:47px 0 14px;
  color:var(--ink);
  font:600 clamp(25px,3vw,34px)/1 Fraunces,Georgia,serif;
  letter-spacing:-.055em;
}
.article h2:before{
  content:"";
  display:block;
  width:44px;height:3px;
  margin-bottom:14px;
  background:linear-gradient(90deg,var(--gold),var(--blue));
  border-radius:99px;
}
.effective{
  margin-top:50px!important;
  padding-top:19px;
  border-top:1px solid var(--line);
  color:#708da1;
  font:500 11px "DM Mono",monospace;
}
footer{
  margin-left:58px;
  width:min(1120px,calc(100% - 42px));
  margin-right:auto;
  padding:30px 0 44px;
  border-top:1px solid var(--line);
  display:flex;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
}
footer strong,footer span,footer a{display:block}
footer strong{font-size:13px}
footer span,footer a{margin-top:4px;color:#6d8aa0;font-size:12px}
footer a{color:var(--blue)}
@media(max-width:720px){
  .bookmark{display:none}
  .topline,main,footer{margin-left:0}
  .topline-inner{width:min(100% - 24px,1120px);min-height:auto;padding:13px 0;align-items:flex-start;flex-direction:column}
  .edition{justify-content:flex-start}
  .cover,.article{width:min(100% - 24px,900px)}
  .cover{margin-top:20px;min-height:auto;padding:28px 22px 155px}
  h1{font-size:56px}
  .paper-tag{left:22px;right:auto;bottom:24px;width:calc(100% - 44px)}
  footer{width:min(100% - 24px,1120px)}
}
