html{
  height: 100%;
}
body{
  width: 95%;
  margin: 1em 1em 1em 1em;
  padding-bottom: 3em;
}
.link_frame{
  display: inline-block;
  margin: 0em 1em 0em 1em;  /* 上、右、下、左 */
  padding: 0px;
  background-color: #7FFF00;
}

/* バナー */

.banner{
  display: inline-block;
  margin: 2px;
  background-color: #FFFFE0;
}

/* タイトル */
h1 {
  color: #EEEEEE;
  padding: 5px;
  margin-bottom: 5px;
  background-color: #000080;
}

/* サブ・タイトル */
h2 {
  color: #FFFFFF;
  font-size: x-large;
  padding: 5px;
  margin-top: 10px;
  margin-bottom: 5px;
  background-color: #6699CC;
}

/* 章 */
h3 {
  color: #FFFFFF;
  font-size: large;
  margin-bottom: 5px;
  background-color: #6699CC;
  display: inline-block;
  padding: 0.15em 0.4em;
  //border-radius: 4px;
}

/* 節 */
h4 {
  font-size: large;
  display: inline-block;       /* テキスト幅に合わせる */
  position: relative;          /* 擬似要素配置の基準にする */
  z-index: 0;                  /* 下線を後ろに回すための基準 */
  margin-bottom: 5px;
}
h4::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -0.2em;              /* 文字の下に被らない位置 */
  width: 100%;
  height: 0.30em;              /* 下線の太さ */
  background-color: #6699CC;   /* 下線の色 */
  z-index: -1;                 /* テキストの下に配置 */
  //border-radius: 2px;          /* 丸みを付けたい場合 */
}

/*
 * 区切り線
 */
hr {
  border-style: dotted;
}

/*
 * コメント、ソースコード
 */
pre:has(> code) {
  display: inline-block;
  background-color: #E0FFFF;
  padding: 2px;
  margin: 0em 0em 0em 1em;  /* 上、右、下、左 */
  line-height: 1.5;
}

div.source, div.source2 {
  border: dashed 1px green;
  background-color: #C0FFF0;
  padding: 2px;
  margin-top: 10px;
  margin-bottom: 10px;
}

/*
 * 画像と文字の位置合わせ
 */
.image_insert {
  margin: 5px;
  vertical-align: middle;
}

/*
 * 画像の外枠
 */
img.border {
  border: 1px solid black;
}

/*
 * ブロックの位置合わせ。左にずらす。
 */
div.indent1 {
  margin-left: 2em;
  margin-bottom: 20px;
}

table {
  margin: 1em 0em 1em 2em;  /* 上、右、下、左 */
  border-collapse: collapse;
  width: 100%;
  overflow-x: auto;
  display: block;
  font-variant-numeric: lining-nums tabular-nums;
}
table caption {
  margin-bottom: 0.75em;
}
tbody {
  margin-top: 0.5em;
  border: 1px solid #1a1a1a;
}
th {
  border: 1px solid #1a1a1a;
  padding: 0.25em 0.5em 0.25em 0.5em;
  background-color: #47C403;
}
td {
  border: 1px solid #1a1a1a;
  padding: 0.125em 0.5em 0.25em 0.5em;
}

