body{
    font-family: メイリオ;
    color: #FFFFFF;
}
.section-white{
    color: black;
}
.section-black{
    background-color: black;
    color: white;
}
.font3em{
    font-size: 3em;
    margin-bottom: -3px;
}
nav{
    margin-top: 6px;
}
  
.noto-sans-jp {
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-weight: 300;
    font-style: normal;
  }
.noto-sans-jp-500 {
font-family: "Noto Sans JP", sans-serif;
font-optical-sizing: auto;
font-weight: 500;
font-style: normal;
}
.rubik{
font-family: "Rubik", sans-serif;
font-optical-sizing: auto;
font-weight:500;
font-style: normal;
}
.bg-nav{
    background-image: linear-gradient(180deg, rgba(255, 255, 255, 0), rgba(172, 172, 172, 0.03));
}
.noto-sans {
    font-family: "Noto Sans", sans-serif;
    font-optical-sizing: auto;
    font-weight: 600;
    font-style: normal;
}
th{
    vertical-align:middle
}
.nav-text{
    text-shadow: 1px 1px 2px rgb(0, 0, 0);
}
.roboto-black {
    font-family: "Roboto", sans-serif;
    font-weight: 500;
    font-style: normal;
  }
.mt6px{
    margin-top: 6px;
}
.ml2px{
    margin-left: 2px;
}
.mb7px{
    margin-bottom: 7px;
}
.logosizing{
    width: 10rem;
}

.roboto-black-main{
    font-size:6rem;
    margin-bottom: 0;
    margin-left: -4px;
    letter-spacing: 9px;
    margin-bottom: -1.4rem;
}
.noto-sans-main{
    letter-spacing: 10px;
}
.lead {
    font-size: 0.9rem;
}
.bg-img {
    background-image: url(../images/top_front.webp);
    background-size: cover;
    background-position: center 66.6%;
    height: 87vh;
  }
.toptext{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -65%);
}
table, th, td {
    border:1px solid #333;
  }
.tablelist{
    max-width: 85%;
    margin: auto;
    padding-left: 11px;
    padding-right: 11px;
}

table{

    margin: auto;
    table-layout: fixed;
}
  
.accordion-flush.accordion {
--bs-accordion-btn-bg: #ffffff;
--bs-accordion-active-bg: rgb(255, 255, 255);
--bs-accordion-active-color: #000000;
--bs-accordion-bg: rgb(255, 255, 255);
--bs-accordion-color: #000000;
--bs-accordion-btn-focus-box-shadow: none;
--bs-accordion-btn-focus-border-color: unset;
}

.accordion-flush .accordion-button {
border-top: 1px solid #000000;
}

.accordion-flush .accordion-item:last-child .accordion-button.collapsed,
.accordion-flush .accordion-item:last-child .accordion-body {
border-bottom: 1px solid #000000;
}

.accordion-button::after {
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='currentColor' class='bi bi-plus' viewBox='0 0 16 16'%3E%3Cpath d='M8 4a.5.5 0 0 1 .5.5v3h3a.5.5 0 0 1 0 1h-3v3a.5.5 0 0 1-1 0v-3h-3a.5.5 0 0 1 0-1h3v-3A.5.5 0 0 1 8 4z'/%3E%3C/svg%3E");
transition: all 0.5s;
}
.accordion-button:not(.collapsed)::after {
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='currentColor' class='bi bi-dash' viewBox='0 0 16 16'%3E%3Cpath d='M4 8a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7A.5.5 0 0 1 4 8z'/%3E%3C/svg%3E");
}

.hp_top{
    width: 42%;
    margin-top: 15vh;
}
/* Google Mapを囲う要素 */
.map {
    position: relative;
    width: 100%;
    height: 0;
    padding-top: 75%; /* 比率を4:3に固定 */
  }
   
  /* Google Mapのiframe */
  .map iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }
  th{
    font-weight: 400;
  }
 a{
    color: white;
    text-decoration: none;
 } 

@media (max-width: 768px){

    .hp_top{
        width: 100%;
        margin-top: 24vh;
    }
    .roboto-black-main{
        font-size:6rem;
        margin-bottom: 0;
        letter-spacing: 9px;
        margin-bottom: -1.4rem;
    }
    .noto-sans-main{
        letter-spacing: 20px;
        margin-left: 11px;
    }
    .lead {
        font-size: 0.9rem;
        margin-left: 13px;
    }
}