body {font-family: Arial, sans-serif; margin: 0 auto; max-width: 1024px; padding: 0;  background-color: rgb(0, 0, 0);}
html { scroll-padding-top: 60px;}
p{ font-family: "Kosugi Maru", "Hiragino Sans", "Meiryo", sans-serif; letter-spacing: 0.05em; line-height: 1.6; text-align: center;
}
h2{ font-family: Impact, Haettenschweiler, 'Arial Narrow Bold', sans-serif; margin: 10px auto 0 auto;}
h3{ margin-bottom: 5px; text-align: center;}
a { color: white; text-decoration: none; }
a:visited { color: white;}
button { border: none; cursor: pointer; padding: 10px;}
li { color: white; font-family: "Kosugi Maru", "Hiragino Sans", "Meiryo", sans-serif;letter-spacing: 0.05em; line-height: 1.7;}
/* ヘッダー*/
.header {
    background-color: #111; display: flex;
    position: fixed; top: 0; left: 0;
    width: 100%; height: 60px; align-items: center; z-index: 1000;              
}
.logo {
    font-family: Impact, Haettenschweiler, 'Arial Narrow Bold', sans-serif; font-weight: 600; font-size: 1.4rem;
    color: white; padding-left: 20px;
}
.instagram {
    height: 40px; width: 40px; margin: auto; margin-right: 0;
}
.instagram img{
    height: 100%; width: 100%;
}
.menu {
    background: #000000; position: fixed;
    top: 0px; right: -250px; width: 250px;
    height: 100%; z-index: 4; color: white;
    transition: 0.3s; padding-top: 20px; z-index: 3;
}
.menu-label {
  display: block; text-align: center; font-size: 0.9em; margin-top: 4px; color: white;
}
.menu a {
    display: flex; align-items: center; padding: 12px 16px; margin-bottom: 13px; font-size: 16px; min-height: 48px; color: white; text-decoration: none; user-select: none;     
}
.menu a:hover {
    background: rgb(242, 238, 10);
    color: #000000;
}
.header-btn {
    background-color: transparent; color: white;
    font-size: 2rem;
}
.overlay {
    display: none; position: fixed; top: 0;
    left: 0; width: 100%; height: 100%;background: transparent; z-index: 1;
}
.admission {
    width: 60px; height: 60px; text-align: center; background-color: rgb(232, 0, 0);
}
.admission img{
    width: 30px; height: 30px; margin-top: 5px;
}
.admission p{
    margin-top: -5px; font-size: 0.7rem;
}

/* コンテンツ */
.contents {
    margin: 50px 10px; padding: 5px;background-color: white;
}
.contents p{
    color: black; text-align: left;
}
.contents h1{
    color: black; font-size: 1.5rem; padding: 10px;
}
.contents h2 {
    padding: 0.5em; color: white; background: black; font-size: 1.4rem;
}
.contents h3{
    color: black; text-align: left;
}
.contents ol{
    text-align: left; list-style-type: decimal; width: 200px;margin: auto; border: 1px solid rgb(150, 150, 150);
}
.contents ul{
    padding-left: 15px;
}
.contents li{
    color: black;
}
.contents a{
    color: #000000;
    text-decoration: underline;
}
.contents img {
    width: 300px; height: 200px; object-fit: cover; display: block; margin: auto;
}
.line {
    border-top: 1px solid white; width: 100%;  margin: 20px 0; 
}
.table-of-contents{
    text-align: center !important;
}
/* コンテナ */
.container {
    width: 100%;
    margin:auto ;
    display: flex;    
    flex-wrap: wrap;  
    gap: 16px; 
    justify-content: center;
}
.description {
    width: 100%;
    max-width: 400px;
}
.card{
    width: 160px;
}
.card img{
    width: 100%;
}
.service
/* 表 */
table {
    width: 100%; max-width: 800px; margin: 24px auto; border-collapse: collapse; 
}
th, td {
    padding: 12px 10px; text-align: left;border: none; color: black;
}
tr:not(:last-child) td {
    border-bottom: 1px solid #ddd; 
}
thead th {
    font-weight: 600;
}
/* フッター */
.INFORMATION {
    width: 100%; max-width: 1920px; margin: 20px auto 0 auto; color: white; min-height: 800px; background-color: #111;
}
.INFORMATION h2,
.INFORMATION h3 {
    color: white; padding: 0 20px;
}
.INFORMATION p {
    font-size: 0.8rem; line-height: 1.5; padding-top: 10px; color: white;
}
.INFORMATION iframe {
  width: 100%; height: 400px; max-width: 1920px;
  margin: 0 auto; display: block;background-color: white; 
}
.footer {    
    width: 100%; height: 190px; color: white;
    display: flex; justify-content: space-between; margin-top: -20px;
}
.footer ul{
    list-style: none;
}
.footer li{
    min-width: 80px; font-size: 0.7rem;
    min-height: 36px; margin-bottom: 8px;
}
