html,
body,
div,
h1,
h2,
p,
footer,
header {
    margin: 0;
    padding: 0;
    background: transparent;
    font-size: 100%;
    vertical-align: baseline;
}

body {
    background: #fff;
    color: #222;
    font: 14px/1.4 Helvetica, Arial, "�ҥ饮�γѥ� ProN W3", "Hiragino Kaku Gothic ProN", "�ᥤ�ꥪ", Meiryo, "�⥴���å�", YuGothic, sans-serif;
    -moz-font-feature-settings: "pkna";
    -webkit-font-feature-settings: "pkna";
    font-feature-settings: "pkna";
    letter-spacing: .01em;
    word-wrap: break-word;
    -webkit-text-size-adjust: 100%;
}

#wrapper {
    /* width: 780px; */
    /* height: 577px; */
    margin: 0 auto;
    /* background: url(default_page.png?date=210428); */
}

#header {
    padding: 22px 0;
}

/* #container {
    margin-bottom: 20px;
    height: 332px;
    padding-top: 140px;
    text-align: center;
} */

h1 a {
    width: 205px;
    height: 60px;
    display: block;
    margin: 0 auto;
    text-indent: -4000px;
}

h2 {
    margin-bottom: 20px;
    text-align: center;
    font-size: 28px;
    color: #113d6b;
    line-height: 1.6;
}

p {
    font-size: 14px;
    padding-bottom: 22px;
    line-height: 1.4;
}

a {
    font-size: 11px;
    color: #333;
}

a:hover {
    -webkit-opacity: 0.7;
    -moz-opacity: 0.7;
    -ms-opacity: 0.7;
    -o-opacity: 0.7;
    opacity: 0.7;
}

.boxlink {
    width: 356px;
    height: 60px;
    display: block;
    margin: 0 auto 45px;
    color: #113d6b;
    font-size: 15px;
    line-height: 60px;
    text-decoration: none;
    text-align: center;
}

.boxlink:hover {
    color: #113d6b;
}

address {
    font-style: normal;
    font-size: 13px;
    text-align: center;
    color: #333;
}

dl {
    display: flex;
    flex-wrap: wrap;
    width: 30%;
}

dt {
    height: 50%;
    width: 30%;
    padding-bottom: 20px;
    margin-bottom: 10px;
    background-color: #DADADA;
}

dd {
    width: 50%;
    padding-bottom: 20px;
    background-color: #F3F3F3;
    margin-bottom: 10px;
}

dt img {
    object-fit: contain;
}

.sitelist {
    width: 40%;
    display: flex;
    align-items: flex-start;
}

.sitelist table {
    width: 10;
}

.sitelist table td {
    width: 10em;
}

.sitelist table img {
    object-fit: contain;
}


.test-grid-container {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    /* テーブル間のスペース */
    padding: 20px;
}

.test-grid-table {
    border-collapse: collapse;
    width: 100%;
    /* グリッド内で自動的に調整 */
}

.test-grid-table caption {
    caption-side: top;
    font-weight: bold;
    margin-bottom: 10px;
}

.test-grid-table th,
.test-grid-table td {
    border: 1px solid #000;
    padding: 8px;
    text-align: left;
}


.container:after {
    clear: both;
    content: '';
    display: block;
}

.item {
    border: 1px solid #999;
    float: left;
    width: 250px;
    height: 250px;
    /* margin-bottom: 1em; */
    margin: 2em;
}

/* .blue {
    background-color: royalblue;
}

.purple {
    background-color: blueviolet;
} */

.item img {
    width: 100%;
    height: 100%;

}