body {
    font-family: "Hiragino Sans","Meiryo",sans-serif;
    background-image:none;
}
.page-wrapper {
    max-width: unset;
    background-color: var(--color--gray-100);
    /* background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='50' height='84' viewBox='0 0 50 84'%3e  %3cpath opacity='0.05' fill='%230e6ba6' d='M25,61.7C25,68.5,19.4,74,12.5,74S0,68.5,0,61.7c0-5.7,3.9-9.6,7.4-12.9c2.3-2.2,4.5-4.4,5.1-6.8c0.7,2.4,2.8,4.6,5.1,6.8C21.1,52.2,25,56,25,61.7z M42.6,6.8c-2.3-2.2-4.5-4.4-5.1-6.8c-0.7,2.4-2.9,4.6-5.1,6.8C28.9,10.2,25,14,25,19.7C25,26.5,30.6,32,37.5,32S50,26.5,50,19.7C50,14,46.1,10.2,42.6,6.8z'/%3e%3c/svg%3e");
*/
    }
.layout-main-wrapper {
    max-width: var(--max-bg-color);
    background-color: #fff;
}
.text-content{
    font-family: "Hiragino Sans","Meiryo",sans-serif;
}
.site-main a {
    text-decoration: none;
    box-shadow: none;
}
a:focus {
  outline: none;
}
.main-content__container {
    padding-block-start: 0;
}
.container {
    max-width: none;
}

.region--content{
    margin-block-start: var(--sp0-25);
}

.region > *:where(:not([data-big-pipe-placeholder-id])) {
    margin-block-end: 0;
}

.site-header .text-content{
        font-size: 0.9rem;
        /* margin-right: 10px;
        min-width: 120px;*/
}
.text-content p {
        margin-block-start: var(--sp1-5);
        margin-block-end: var(--sp1-5);
}

@media (min-width: 75rem) {
    .site-branding {
	min-height: var(--sp6);
    }
    .site-header {
        min-height: var(--sp6);
    }
    .site-branding__inner {
        padding-block-end: 0;
    }
}

@media (min-width: 43.75rem) {
    h1 {
        font-size: 2.0rem;
    }
    h2 {
        font-size: 1.5rem;
        line-height: var(--sp2-5);
    }
  .layout--content-medium, .layout--pass--content-medium > * {
        grid-column: 1 / 17;
  }
  .sidebar-grid > .site-main {
        grid-column: 1 / 17;
	padding-top:10px;
  }
    h1, h2, h3, h4, h5, h6 {
        margin-block: var(--sp1-5) var(--sp1);
    }
    h1 + h2{
	margin-block: 0 var(--sp1);    
    }
}

@media (min-width: 62.5rem) {
    .main-content .container {
        padding-inline: 0;
	/* padding-inline-start: var(--container-padding);*/
	padding-inline-start: 24px;
        padding-inline-end:0;
     }
    .layout--content-medium, .layout--pass--content-medium > * {
        grid-column: 2 / 17;
    }
    .sidebar-grid > .site-main {
        /* grid-column: 1 / 11; */
        grid-column: 5 / 17;
	padding-top: 10px;
        padding-inline-end: var(--container-padding);
    }
    .sidebar-grid .region--sidebar {
        /* grid-column: 11 / 15; */
        grid-column: 1 / 5;
	padding-top:10px;
	/* padding-inline-start: var(--container-padding); */
	padding-inline-start:0;
    }
    .sidebar-grid .region--sidebar .views-element-container{
        padding-inline-start: 0;
    }
    .sidebar-grid .region--sidebar .container-inline{
        padding-inline-start: 0;
        padding-bottom: 6px;    
    }
    .layout--content-medium, .layout--pass--content-medium > * {
        grid-column: 1 / 17;
    }
   .site-header .text-content{
     margin: 0;
     position: absolute;
     bottom: 0;
     right: 10px;
     width: 360px;
     text-align: right;
   }
   .mobile-buttons{
        display:none;
   }
   #header .header-nav {
        display:none;
   }
   #site-header__inner .container p {
    margin-right: 20px !important;
   }
}

@media (max-width: 62.49rem) {
    .sidebar-grid .region--sidebar {
	    display:none;
    }
    .site-header .text-content{
	    margin-top: 8px;
	    margin-bottom:8px;
	    line-height:1.2em;
    }
}

@media (max-width: 43.75rem) {
  .site-header .text-content{
        font-size: 0.8rem;
        margin-right: 0px;
        max-width: 100px;  
        margin-left: 8px;
  }
}
.messages-list {
    margin-block: 0;
}
.messages {
    margin-top: 10px;
}

/* ------------------ page-top button ------------------ */

#block-cfca-olivero-pagetoplink{
  width:0;
}

@media screen and (max-width: 460px) {
 #page_top{
  width: 40px;
  height: 40px;
  position: fixed;
  right: 3px;
  bottom: 3px;
  background: #ccc;
  opacity: 0.6;
  z-index: 999;
  border-radius: 50%;
 }
 #page_top a{
  position: relative;
  display: block;
  width: 40px;
  height: 40px;
  text-decoration: none;
  box-shadow: none;
 }
 #page_top a::after {
    content: '\025b2';
    font-size: 14px;
    font-weight: bold;
    color: #fff;
    position: absolute;
    top: 10px;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    text-align: center;
 }
#page_top a:hover {
  color: none;
}

#page_top a:focus {
  outline: none;
  outline-offset: 0;
}
}
@media (min-width: 43.75rem) {
    .text-content p, .cke_editable p {
        margin-block-start: var(--sp0-75);
        margin-block-end: var(--sp0-75);
        font-size: 1rem;
        line-height: var(--line-height-base);
    }
    .text-content, .cke_editable {
	font-size: 1rem;
    }
}

/* Content Above */	
h2.block__title {
    font-size: var(--font-size-l);
}
.region--content-above h2.block__title{
    margin-inline-start: 10px;
}

.trouble{
  padding: 10px 20px;
  margin: 0;
  /* background: var(--color--gray-95); */
  background: var(--color--primary-80);
  border: 2px solid var(--color--primary-40);
}
.text-formatted .trouble ul {
    margin: 0.4em 0;
}
.information{
  padding: 10px 20px;
  margin: var(--sp1-5) 0;
  background-color: #fff;
  border: 2px solid var(--color--gray-70);
}
.information h2, .trouble h2{
  margin: 0;
  letter-spacing:2px;
  padding: 0;
  border: none;
}
.information > ul, .trouble > ul{
  margin: 0 !important;
  padding:0 !important;
  list-style: none;
}
.information > ul > li > ul, .trouble > ul > li > ul{
  margin: 0.5em 3em !important;
}
.information > ul > li, .trouble > ul > li{
  margin: 0;
  padding: 7px 0px;
  border-bottom: solid 1px var(--color--gray-70);
  line-height: 1.6em;
}
.information > ul > li:first-of-type, .trouble > ul > li:first-of-type{
	padding: 0;
}
.trouble > ul > li:last-of-type{
  border-bottom: none;
}
.information p.center_p{
	text-align:center
}
.information .svg-inline--fa {
	margin-right: 5px;
}

li p.date{
    display: block;
    margin:0 5px;
    float: left;
    width: 140px;
}
li p.body{
    overflow: hidden;
    margin-left: 140px;
    margin: 0px 20px;
}
.information .info_link{
	margin-top:5px;
}

/* Search button */
/*.button{
    background: var(--color--primary-40) url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='26' height='27.2' viewBox='0 0 26 27.2'%3e  %3cpath fill='%23fff' d='M25.8,25.5l-5.3-5.3c2.1-2.1,3.4-5.1,3.4-8.3C23.9,5.3,18.5,0,11.9,0C5.3,0,0,5.3,0,11.9c0,6.6,5.3,11.9,11.9,11.9c2.6,0,5.1-0.9,7-2.3l5.4,5.4c0.4,0.4,1,0.4,1.4,0C26.1,26.6,26.1,25.9,25.8,25.5z M11.9,21.9c-5.5,0-9.9-4.4-9.9-9.9S6.4,2,11.9,2c5.5,0,9.9,4.4,9.9,9.9S17.4,21.9,11.9,21.9z'/%3e%3c/svg%3e") no-repeat center;
    text-indent: -9999px;
}
*/
.block-search .button {
        padding-block: 0;
        background: var(--color--primary-40) url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='26' height='27.2' viewBox='0 0 26 27.2'%3e  %3cpath fill='%23fff' d='M25.8,25.5l-5.3-5.3c2.1-2.1,3.4-5.1,3.4-8.3C23.9,5.3,18.5,0,11.9,0C5.3,0,0,5.3,0,11.9c0,6.6,5.3,11.9,11.9,11.9c2.6,0,5.1-0.9,7-2.3l5.4,5.4c0.4,0.4,1,0.4,1.4,0C26.1,26.6,26.1,25.9,25.8,25.5z M11.9,21.9c-5.5,0-9.9-4.4-9.9-9.9S6.4,2,11.9,2c5.5,0,9.9,4.4,9.9,9.9S17.4,21.9,11.9,21.9z'/%3e%3c/svg%3e") no-repeat center;
        text-indent: -9999px;
	height: var(--sp2);
	margin-block: var(--sp0-25);
	padding-inline: var(--sp1);
	margin-inline-end: 0;
}
[type="search"] {
      padding: 0 var(--sp0-25);
      min-height: var(--sp2);
      margin-block: var(--sp0-25);
      font-size:0.9em;
}
@media (min-width: 75rem) {
 [type="search"]{
      width: 200px !important;
 }
}
@media (min-width: 62.5rem) and (max-width: 75rem) {
 [type="search"]{
      width: 160px;
 }	 
}
[type="search"]::placeholder{
      color: transparent;
}

/* news & maintenance date */
.region--sidebar .view-header h2{
  font-size: var(--font-size-l);
  margin-block: 0;
  line-height: var(--sp2);
}
.region--sidebar .view-content .item-list ul{
    margin-block-start: 0;
    margin-block-end: 1em;
    margin-inline-start:0;
    padding-inline-start: 0;
    padding-inline-end: 3em;
    list-style-type: none;
}

/* sidebar menu*/
[id^="disclosure-menu"].vertical .menu__item-container {
    width: 100%;
    gap:0;
    padding-inline-start: 0.4em;
}
[id^="disclosure-menu"].vertical .menu__submenu--disclosure {
    margin-left: 1.2em;
}
[id^="disclosure-menu"] .menu__submenu-toggle {
    padding: 0.5em 1em 0.5em 1em;
    position:relative;
    height: auto;
}
[id^="disclosure-menu"] a.menu__item-link + .menu__submenu-toggle:after {
  display: block;
  content: '';
  position: absolute;
  width: 50px;
  height: 30px;
  top: 0px;
  left: -40px;
  /* background: rgba(255, 0, 0, 0.2); */
}
[id^="disclosure-menu"] :not(a.menu__item-link) + .menu__submenu-toggle:after {
  display: block;
  content: '';
  position: absolute;
  width: 240px;
  height: 30px;
  top: 0px;
  left: -200px;
}
ul.menu[id^="disclosure-menu"].vertical {
    margin-bottom: 26px;
    /* margin-top: 10px;*/
    font-weight: 600;
    gap: 0.6em;
}
ul.menu[id^="disclosure-menu"].vertical li.menu__item--level-1{
    /* border-bottom: 1px solid var(--color--gray-90); */
    margin-right: 50px;
    /* padding-bottom: 10px; */
}
ul.menu[id^="disclosure-menu"].vertical li.menu__item--level-1:first-child {
    /* border-top: 3px solid var(--color--gray-90); */
    padding-top: 10px;
}
.mobile-nav-button__label{
   display:none;
}
.menu--sidebar .menu__link {
        font-family: "Hiragino Sans", "Meiryo", sans-serif;
	font-size: 100%;
        padding-block: var(--sp0-5);
}
.region--sidebar .menu--main{
	padding-bottom:10px;
}
.region--sidebar ul.menu--sidebar{
        margin-inline-end: 1.0em;
}

.region--sidebar #block-cfca-olivero-yusarokuin{
    margin: var(--sp1-5) var(--sp1);
    line-height: var(--line-height-s);
}
.region--sidebar #block-cfca-olivero-yusarokuin .form-item {
    margin-block: var(--sp0);
}
.region--sidebar #block-cfca-olivero-yusarokuin [type="text"], .region--sidebar #block-cfca-olivero-yusarokuin [type="password"]{
    min-height: var(--sp2);
}
.region--sidebar #block-cfca-olivero-yusarokuin .button{
    height: var(--sp2);
}
.region--sidebar #block-cfca-olivero-yusarokuin .form-item__description{
    display:none;
}

/* mobile nav button */
@media (max-width: 31.25rem) {
    .mobile-buttons {
        margin-block-start: var(--sp2-5);
    }
    .header-nav {
       border-block-start: solid var(--color--white) calc(var(--sp4-5) + var(--drupal-displace-offset-top, 0px));
    }
}

/* show current page */
ul.menu > li.menu__item--level-1 > .menu__item-container > a.is-active {
    color: #000;
    font-weight:bold;
}

ul.menu__submenu > li.menu__item--level-2 > .menu__item-container > a.is-active {
    color: #000;
    font-weight:bold;
}



/* calender */
#block-cfca-olivero-content-field-baoshouricheng-on-calendar-block-1 .view{
    width: 80%;
    gap: 0;
}

/* social sidebar */
.social-bar a.feed-icon{
	box-shadow: none;
        color: var(--color-text-neutral-soft);
        transform: rotate(90deg);
        margin: 0 5px;
}
.social-bar a.feed-icon .x_icon{
        color: #282828;
}
.social-bar a.feed-icon .feed-icon__icon{
    /* background-color:#ff8c00;*/
    background-color:#282828;
    margin-inline-start: 0;
    width: 27px;
    height: 27px;
}
.social-bar a.feed-icon .youtube_icon{
    width: 30px;
    height: 30px;
}
.social-bar a.feed-icon .github_icon{
    color: #282828;
    line-height: 0;
}
.social-bar a.feed-icon .github_icon svg{
    width: var(--sp1-5);
    height: var(--sp1-5);
}
.social-bar a.feed-icon .x_icon svg{
    width: 26px;
    height: 26px;
}

.social-bar a.feed-icon .x_icon{
    margin-inline-start: 0;
    display: flex;
    justify-content: center;
    align-items: center;
}
.social-bar a.feed-icon .slack_icon img{
    width: 27px;
    height: 27px;
    max-width: unset;
}

.social-bar .social-sharing-buttons a{
    margin-inline-end: var(--sp1);
}

.text-content a.feed-icon:where(:not(.button)):hover {
    color: var(--color--primary-50);
    box-shadow: none;
    text-decoration-color: none;
}
@media screen and (min-width: 75rem) {
    .social-bar .block__content p.sns_label{
	    transform: rotate(90deg);
    }
}

/* Better Social Sharing Buttons */
.social-bar h2{
    letter-spacing: 0.08em;
    font-size: var(--font-size-xxs);
    font-weight: 600;
    margin: 10px;
}
.social-sharing-buttons svg{
    margin: 2em 0;
    align-items: center;
    justify-content: center;
    width: 27px;
    height: 27px;
    margin-inline-start: var(--sp0-5);
    color: var(--color--white);
    border-radius: 2px;
    /* background-color: var(--color--primary-50); */
    background-color:#282828;
    fill: #fff;
    transform: rotate(90deg);
}

.feed-icon__icon svg{
    width: 16px;
    height: 16px;
}


.social-sharing-buttons a.share-facebook svg{
    display: none;
}
.social-sharing-buttons a.share-facebook{
    background-image: url("http://www.cfca.nao.ac.jp/files/Facebook_Logo_Primary.png"); 
    /* background-image: url("http://mmm.cfca.nao.ac.jp/files/Facebook_Logo_Secondary.png");*/
    /* background-color: #282828;*/ 
    background-repeat: no-repeat;
    background-size: 27px 27px;
    background-position: center;
    width: 27px;
    height: 27px;
    transform: rotate(90deg);
    margin-left:20px;
}
.feed-icon__label {
    display: none;
}
@media (min-width: 75rem) {
    .rotate > *:not(:first-child) {
        margin-inline-end: var(--sp1);
    }
}
@media  screen and (max-width: 75rem) {
    
    .rotate{
        display:flex;
        width:240px;
	margin:auto;
    }
    .rotate:has(> :nth-child(5):last-child){
	width:200px;
    }
    .social-sharing-buttons {
        margin: 0;
    }
    .block-better-social-sharing-buttons{
	margin-left:60px;

    }
    .social-sharing-buttons svg, .social-sharing-buttons a.share-facebook{
	   transform: rotate(0);
    }
    .social-bar a.feed-icon{
        margin-inline-end: var(--sp1); 
        transform: rotate(0);
    }
    /* .social-bar a.feed-icon .slack_icon{
	position:relative;
    }
    .social-bar a.feed-icon .slack_icon img{
	position:absolute;
        top: -5px;
        right: -10px;
    }*/
    .social-bar h2 {
	display:none;
    }
}

/*scroll maintenance calender*/
@media screen and (max-width: 43.74rem) {
	/* .scroll-table table { */
	table {
  		display: block;
  		overflow-x: scroll;
	}
        pre{
          overflow: auto !important;
          word-wrap: normal;
        }
}

/* ------------------ page-title ------------------ */
.page-title {
    display: inline-block;
    /* margin-block-start: var(--sp1-5);
    margin-block-end: var(--sp1);*/
    margin-block-start: var(--sp1);
    margin-block-end: var(--sp0-5);
}

/* ------------------ toppage icons ------------------ */

.block__content .icons{
  line-height: var(--sp1);
}
.block__content .icons ul{
  list-style:none;
  margin: 20px 0 0 0;
  padding: 0;
}
.block__content .icons ul li{
  display: inline-block;
  float: left;
  width: 30%;
  margin-right: 5%;
  margin-top: 0;
  margin-bottom:0;
  text-align:center;
}

.block__content .icons ul li:last-child{
  margin-right: 0;
}
.block__content .about{
  margin-left: 0px;
  margin-right:0px;
  margin-top: 5px;
  margin-bottom: 0px;
}
.block__content .icons .box{
  position: relative;
}
.block__content .icons .box .on_image{
  position: absolute;
  color: white;
  font-weight: bold;
  /*font-size: 2vw;*/
  font-size: clamp(14px, 2vw, 24px);
  top: 40%;
  left: 50%;
  -ms-transform: translate(-50%,-50%);
  -webkit-transform: translate(-50%,-50%);
  transform: translate(-50%,-50%);
  margin:0;
  padding:0;
  white-space:nowrap;
  text-shadow: 1px 1px 1px var(--color--gray-20);
  line-height: 1.8vw;
}

.block__content .icons .box .small{
  /* font-size: clamp(12px, 1.1vw, 16px); */
    /* background-color: rgb(0, 0, 0);*/
    color: rgb(255, 255, 255);
    width: 96%;
    text-align: center;
    line-height: 150%;
    padding: 10px 0;
    position: absolute;
    top: 50%;
    font-weight: 600;
    filter: drop-shadow(0px 0px 0px var(--color--gray-45));
}

@media screen and (min-width: 100rem) {
  .block__content .icons .box .small{
    font-size: 14px;
    /* font-size: clamp(14px, 1.1vw, 16px);*/
    top: 62%;
  }
}
@media (min-width: 75rem) and (max-width: 100rem) {
  .block__content .icons .box .small{
	  font-size: 12px;
	  top: 62%;
	  /* font-size: clamp(11px, 1.1vw, 14px); */
  }	
}

@media (min-width: 62.5rem) and (max-width: 75rem) {
  .block__content .icons .box .small{
          font-size: 11px;
          /* font-size: clamp(12px, 1.1vw, 14px);*/
	  top:57%;
  }
}

@media (min-width: 75rem) and (max-width: 80rem) {
   .block__content ul.top_icon .icon_add {
        letter-spacing: -0.5px;
    }
}
@media (min-width: 65rem) and (max-width: 70rem) {
   .block__content ul.top_icon .icon_add {
        letter-spacing: -0.5px;
    }
}

.block__content .icons .box img {
  width: 100%;
  /* filter: drop-shadow(2px 2px 2px var(--color--gray-20)); */
}
.block__content .icons .box:hover{
  opacity: 0.8;
  transition-duration: 0.3s;
}
@media (min-width: 43.75rem) and (max-width: 62.5rem) {
  .block__content .icons .box .small{
      top: 50%;
      font-size: 11px;
      /* font-size: clamp(11px, 1.1vw, 14px);*/
  }
}
@media screen and (max-width: 43.75rem) {
  .block__content .icons ul{
    margin: 10px;
  }
  .block__content .icons ul li{
    float: none;
    width: 100%;
    margin-right: 0;
    margin-top: 10px;
    margin-bottom:0;
  }
  .block__content .icons .box .on_image{
    font-size: 18px;
    line-height: 16px;
    margin: 0 !important;
  }
  .block__content .icons .box .small{
    font-size: 14px;
    /* font-size: clamp(14px, 1.1vw, 16px);*/
    top: 68%;
  }
}
.trouble{
  clear: left;
}
.box p:last-child {
    margin-block-start: 0;
    margin-block-end: 0;
}

.block__content ul.top_icon{
        background-color: var(--color--gray-10);
        border-radius: 5px;
        box-shadow: 2px 2px 2px 0 var(--color--gray-60);
        display: grid;
        grid-template-columns: 1fr 2fr;
        gap: 0;
        margin-inline-start:0;
        margin-bottom: var(--sp1-5);
　　    margin-block-start: var(--sp1);
    　  margin-block-end: var(--sp1);
}
.block__content ul.top_icon li{
        list-style: none;
}
.block__content ul.top_icon li:first-child{
        list-style: none;
        overflow:hidden;
        position:relative;
        padding: 14px 8px 14px 16px;
}
.block__content ul.top_icon li:nth-child(2){
        padding: 16px 12px 12px 10px;
        line-height: 1.3em;
	align-self: center;
        justify-self: end;
}
.block__content ul.top_icon li img{
  width: 100%;
  height: 90px;
  object-fit: cover;
  transition: transform .6s ease;
}
.block__content ul.top_icon li a:hover img{
  opacity: 0.8;
  transition-duration: 0.3s;
  transform: scale(1.05);
}
.block__content ul.top_icon a{
       color:#fff;
}
.block__content ul.top_icon a > br{
       display: none;
}
.block__content ul.top_icon a:hover{
       box-shadow: none;
       text-decoration: none;
}
.block__content ul.top_icon a:hover .icon_small{
       /* text-decoration: underline; */
       color: var(--color--primary-80);
}
.block__content ul.top_icon .icon_title{
    font-size: 24px;
    font-weight: 600;
    position: absolute;
    top: 26%;
    left: 0;
    right: 0;
    text-align: center;
}
.block__content ul.top_icon .icon_add{
    font-size: var(--font-size-xxs);
    font-weight: 600;
    position: absolute;
    top: 60%;
    left: 5%;
    right: 0;
    text-align: center;
    line-height: 1.4em;
}
.block__content ul.top_icon .icon_small{
    font-size: 16px;
    color:#fff;
    margin-block-start: 0 !important;
    margin-block-end: 0 !important;
}
/* @media screen and (max-width: 43.75rem) { */
@media screen and (max-width: 65rem) {
    .block__content ul.top_icon{
          grid-template-columns: 1fr;
          gap: 0;
    }
    .block__content ul.top_icon .icon_small{
        padding-top: 0;
    }
    .block__content ul.top_icon li:first-child{
        padding: 14px;
    }
    .block__content ul.top_icon li:nth-child(2) {
    padding: 0 12px 12px 10px;
    }
}

/*table*/

/**
 * @file
 * Styles for Bartik's tables.
 */

table {
  width: 100%;
  margin: 10px 0;
  border-spacing: 0;
  border: 0;
  border-collapse: collapse;
  font-family: "Lucida Grande", "Lucida Sans Unicode", Verdana, sans-serif;
  font-size: 0.857em;
}
table {
  font-size: 1em;
}
tr {
  padding: 0.1em 0.6em;
  border-bottom: 1px solid #ccc;
  background: #efefef;
  background: rgba(0, 0, 0, 0.063);
}
thead > tr {
  border-bottom: 1px solid #000;
}
tr.odd {
  background: #e4e4e4;
  background: rgba(0, 0, 0, 0.105);
}
table tr th {
  border-bottom-style: none;
  background: #757575;
  background: rgba(0, 0, 0, 0.51);
}
table tr th,
table tr th a,
table tr th a:hover,
table tr th a:focus {
  /* color: #fff; */
  font-weight: bold;
}
table tbody tr th {
  vertical-align: top;
}
tr td,tr th {
  padding: 4px 9px;
  text-align: left; /* LTR */
  border: 1px solid #fff;
}
.tabledrag-handle:hover,
.tabledrag-handle {
  border: none;
}
[dir="rtl"] tr td,
[dir="rtl"] tr th {
  text-align: right;
}

/**
 * Responsive tables.
 */
@media screen and (max-width: 37.5em) { /* 600px */
  th.priority-low,
  td.priority-low,
  th.priority-medium,
  td.priority-medium {
    display: none;
  }
}

@media screen and (max-width: 60em) { /* 920px */
  th.priority-low,
  td.priority-low {
    display: none;
  }
}


/*画像テーブル*/
.block__content table.img_table{
	width:100%;
	font-size:1.071em;
	line-height: 1.6;
}
.block__content table.img_table tr{
    padding: 0;
    border-bottom: none;
    background: #ffffff;
}
.block__content table.img_table tr td{
	width:50%;
	padding:0;
}
.block__content table.img_table tr td:first-child {
    padding-right: 12px;
}
.block__content table.img_table tr td:nth-child(2) {
    padding-left: 12px;
}
.block__content table.img_table a:hover{
        border-bottom-style:none;
}
.block__content table.img_table img{
        width:100%;
}
@media screen and (max-width: 43.75rem) {
  .block__content table.img_table tr td p{
        padding-top:20px;
  }
 .block__content table.img_table tr td img{
        margin-top: 0 !important;
  }
}


/* table_L */
.block__content table.table_L tr th {
        background-color: rgb(179, 204, 230);
        color:#000000;
	border: 1px solid #666;
}
.block__content table.table_L tr{
        background:#ffffff;
}
.block__content table.table_L tr td{
        border: 1px solid #666;
	min-width: 70px;
}
/* border table */
.block__content table.border tr td{
        border: 1px solid #666;
}
/* num column */
.block__content table tr td.num{
	text-align: right;
}
@media only screen and (max-width: 460px){
	.block__content table.img_table{
		border-collapse: unset;
	}
	.block__content table.img_table tr td{
        	width:100%;
		display:block;
		padding-left:0 !important;
		padding-right:0 !important;
	}
}
/*ユーザー表*/
table tr.striped:nth-of-type(even) {
  background-color: #edf5fa;
}
table tr.striped:nth-of-type(odd) {
  background-color: #fff;
}
/*アカウント作成ページ*/
.account_notice{
   border-collapse: collapse !important;
}
.account_notice td.bold{
    font-weight: bold;
}
.account_notice th, .account_notice td {
	border: 1px solid #999999 !important;
}
.account_notice tr:nth-of-type(4n+1), .account_notice tr:nth-of-type(4n+4)
{
	background: #e3feff !important;
        color: #000 !important;
}
.account_notice tr:nth-of-type(4n+1) th, .account_notice tr:nth-of-type(4n+4) th
{
	background: #e3feff !important;
        color: #000 !important;
}
.account_notice tr:nth-of-type(4n+2),.account_notice tr:nth-of-type(4n+3)
{
	background: #fff !important;
        color: #000 !important;
}
.account_notice tr:nth-of-type(4n+2) th,.account_notice tr:nth-of-type(4n+3) th
{
	background: #fff !important;
        color: #000 !important;
}
.account_notice tr:first-of-type{
	background: #b3cce6 !important;
}
.even{
  padding: 20px 0;
  background: #ffffff;/*背景色*/
}
.odd{
  padding: 20px 0;
  background: #efefef;/*背景色*/
}
/*メンテナンス表*/
.block__content table.maintenance td,.block__content table.maintenance_calendar td{
        border: 2px solid #fff;
	padding: 8px 12px 6px;
	font-weight:600;
}

.block__content table.maintenance tr:nth-of-type(odd),.block__content table.maintenance_calendar tr:nth-of-type(odd) {
        background-color: var(--color--primary-80);
}
.block__content table.maintenance tr:nth-of-type(even),.block__content table.maintenance_calendar tr:nth-of-type(even) {
        background-color: var(--color--gray-100);
}
/* calendar */
.block__content .calendar-calendar {
  width:90%;
  font-size: 0.8em;
}
.block__content .calendar-calendar table.mini tr td {
  padding: 4px;
}

/* footer */
.site-footer{
  text-align: center;
  font-weight: bold;
}

/* カテゴリ別メニュー移動実験中 */
/* .main-content{
  padding-top:14px;
} */

.region--content-above .block-menu {
    padding: 10px;
    background-color: #fff;
    border: 2px solid var(--color--gray-70);
    margin: var(--sp0-5) 0;
    font-size: 1em;
    line-height: var(--sp1-5);
}
.region--content-above > .block-menu > .menu{
	column-count: 2;
}
@media (max-width: 43.75rem) {
  .region--content-above > .block-menu > .menu{
        column-count: 1;
  }
}
@media (min-width: 43.75rem) and (max-width: 62.5rem) {
  .region--content-above > .block-menu > .menu{
        column-count: 2;
  }
}
.region--content-above ul.menu li {
    list-style-image: url(https://www.cfca.nao.ac.jp/files/menu-leaf.gif);
    margin-top: 5px;
    margin-bottom:5px;
}
.region--content-above p{
  margin-top:14px !important;
  margin-bottom: 8px !important;
}
.region--content-above .block__title {
    margin-block: var(--sp0-5);
    }
.grid-full {
    grid-column-gap: 0;
    }

@media (min-width: 43.75rem) {
    :root {
        --grid-col-count: 16;
    }
}

/* ヘッダの背景を横幅いっぱい塗りつぶす */
.site-branding {
    background-image: none;
    padding-inline-start: var(--sp1);
}
@media (max-width: 43.75rem) {
  .site-branding {
    margin-inline: calc(-1* var(--container-padding)) var(--sp0-25);
    padding-inline-start: var(--sp0-5);
    padding-inline-end: var(--sp0-5);
  }
}
#site-header__inner .container {
    /* background-image: linear-gradient(160deg, var(--color--primary-50) 0%, var(--color--primary-40) 78.66%); */
    background-image: url(http://www.cfca.nao.ac.jp/files/iii-aterui-007-t3.png);
    background-size: cover;
    background-repeat: no-repeat;
    background-color: #000000;
}

#site-header__inner .container p{
    color: white;
    margin-right: 0;
    text-shadow: 0.5px 0.5px 0 #000, -0.5px 0.5px 0 #000, -0.5px -0.5px 0 #000, 0.5px -0.5px 0 #000;
}
#site-header__inner .container p a{
    color: white;
    box-shadow: none;
}
#site-header__inner .container svg.ext path{
      stroke: #fff;
}

.mobile-nav-button__icon {
    border-top: solid 3px white;
}

.mobile-nav-button__icon::before, .mobile-nav-button__icon::after {
    border-top: solid 3px white;
}

.mobile-nav-button[aria-expanded="true"] .mobile-nav-button__icon::before {
  border-top: solid 3px var(--color--primary-50);
}

.mobile-nav-button[aria-expanded="true"] .mobile-nav-button__icon::after {
  border-top: solid 3px var(--color--primary-50);
}
.mobile-nav-button:focus {
  outline: none;
}

/* フッタの色を変える */
.site-footer {
    color: var(--color--white);
    background:var(--color--primary-40);
    svg.ext path, svg.mailto path, svg.tel path{
      stroke: #fff;
    }
}
.site-footer a{
    box-shadow: none;
}

/* table */
.block__content content table{
	font-size: 1em;
	width:98%;
	margin-left: 1%;
}
.block__content table tr {
	border-bottom:none;
	background: none;
}
.block__content table tr th {
	background: #efefef;
	border: none;
	color: #000;
	padding: 4px 9px;
	font-size: 1em;
}
.block__content table tr td {
        border: none;
	padding: 4px 9px;
	font-size: 1em;
}
.scroll-table table tr td:nth-child(1), .scroll-table table tr td:nth-child(2){
	white-space: nowrap;
}

@media all and (min-width: 43.75rem) and (max-width: 62.5rem) {
	.scroll-table table {
        	display: block;
        	overflow-x: scroll;
	}
}
@media screen and (max-width: 43.75rem) {
	.scroll-table table {
  		display: block;
  		overflow-x: scroll;
	}
	.content table{
        	width:99%;
        	margin-left: 0;
	}
	.content .block__content p {
    		margin: 10px 0 !important;
	}
}

/* newsletter table*/

@media (min-width: 43.75rem) {
    .view, .view-content {
        gap: 0;
    }
    .view-newsletter table tr td:last-child{
        white-space: nowrap;
   }
}
.view, .view-content {
        gap: 0;
}
.view-newsletter {
    display:block;
}

/* caption */
:is(.forum table, .text-content table, .views-table, .draggable-table) caption {
    text-align: center;
    font-family: initial;
    font-size: 1em;
    font-style: normal;
}

/* blockquote */
.text-content blockquote::before,
.cke_editable blockquote::before {
  content: none;
}

.text-content blockquote::after,
.cke_editable blockquote::after {
  content: none;
}

.text-content blockquote,
.cke_editable blockquote {
  font-size: 1rem;
  padding-inline-start: var(--sp);
}
@media (min-width: 43.75rem) {
  .text-content blockquote,
  .cke_editable blockquote {
    font-size: 1.3125rem;
    line-height: var(--sp2);
  }
}
@media (min-width: 62.5rem) {
  .text-content blockquote,
  .cke_editable blockquote {
    font-size: 1.3125rem;
    line-height: var(--sp2);
  }
}

/* faq */
.faq-qa > .item-list .faq-ul-questions-top{
  margin-bottom: 40px;
}
.faq-category-group .faq-question{
  border-top: 1px solid gray;
  padding-top:20px;
}
/* .faq-content{
    font-size: 1.0em;
}*/
.faq-content .node__content{
    font-size: 1.0em !important;
}
.faq-content hr{
        margin-top: 20px;
}
.faq-category-group .faq-question a:before {
  content:"Q. ";
  font-weight: bold;
  color:#00AA00;
}
.node--type-faq .field--name-body > p:nth-child(1):before {
  content:"A. ";
  font-weight: bold;
  color:#AA0000;
}

.faq-answer h2.node__title{
  margin:0;
}

.faq-category-group + .faq-category-indent .faq-category-menu h3 {
  border-top: 2px solid gray;
  padding-top: 60px
}

/* new icon area */

.block__content .facilities{
  position: relative;
}
.block__content .facilities h2{
  margin: 10px 0 10px 20px;
  letter-spacing:2px;
  padding: 0;
  border: none;
}
.block__content .facilities p.facilities_notice{
  position:absolute;
  top: -20px;
  right:10px;
}
.block__content .facilities ul {
    margin-inline-start: 0;
    margin-block-start: 0;
    /* margin-block-end: 3em;*/
}

.block__content .facilities ul li {
    display: inline-block;
    float: left;
    width: 18%;
    height: 230px;
    margin-right: 2%;
    margin-top: 0;
    margin-bottom: 20px;
    border: solid 2px var(--color--gray-60);
    /* box-shadow: 2px 2px 2px var(--color--gray-70); */
}
.block__content .facilities ul li:last-child {
    margin-right: 0;
}
.block__content .facilities ul li:last-child p.facilities_text {
    letter-spacing: -1px;
}
.block__content .facilities ul li:nth-child(3) {
    width: 20%;
}
.block__content .facilities ul li:nth-child(3) p.facilities_text {
    letter-spacing: -2px;
}
.block__content .facilities ul li img{
  width: 100%;
  height: 70px;
  object-fit: cover;
  margin:auto;
}
.block__content .facilities ul li img:hover{
  opacity: 0.8;
  transition-duration: 0.3s;
  /* filter: drop-shadow(2px 2px 2px var(--color--gray-20)); */
}
.block__content .facilities p.facilities_text{
  text-align: center;
  margin-block-start: 0;
  margin-block-end: 0;
}
.text-content .facilities p.facilities_small{
        color: var(--color--gray-45);
	font-size:0.8em;
	font-weight:500;
	line-height:1.1em;
	margin-block-start: 0;
        margin-block-end: 0;
	padding:0 10px;
}
.block__content .facilities ul li br{
       display:none;
}
@media screen and (max-width: 65rem) {
  .block__content .facilities ul li {
    width: 32%;
    height: 200px;
    margin-right: 2%;
 }
 .block__content .facilities ul li:last-child {
    width: 32%;
    height: 200px;
    margin-right: 0;
 }
 .block__content .facilities ul li:nth-child(3) {
    width: 32%;
    margin-right: 0;
}
}
@media screen and (max-width: 43.75rem) {
  .block__content .facilities ul li {
    float: none;
    width: 100%;
    height: 160px;
 }
 .block__content .facilities ul li:nth-child(3) {
    float: none;
    width: 100%;
    height: 160px;
  }
 .block__content .facilities ul li:last-child {
     float: none;
    width: 100%;
    height: 160px;
 }
 .block__content .facilities p.facilities_notice{
     position: static;
        margin-left: 20px;
 }
} 



.block__content ul.gfacilities_list{
	display: grid;
        grid-template-columns: repeat(5, [col-start] 1fr);
        gap: 18px;
	margin-inline-start:0;
	margin-bottom: var(--sp2-5);
}
@media screen and (max-width: 65rem) {
        .block__content ul.gfacilities_list{
	    grid-template-columns: repeat(3, [col-start] 1fr);
        }
    }
@media screen and (max-width: 43.75rem) {
      .block__content ul.gfacilities_list{
	grid-template-columns: 1fr;
      }
     .block__content .gfacilities p.gfacilities_notice{
        position: static !important;
        margin-left: 20px;
     }
     .block__content .gfacilities h2 {
        margin: 20px 0 10px 10px;
    }
}
.block__content ul.gfacilities_list li{
        list-style: none;
	border: 2px solid var(--color--gray-45);
        box-shadow: 5px 5px 5px 0 var(--color--primary-80);
}
.block__content .gfacilities ul li img{
  width: 100%;
  height: 80px;
  object-fit: cover;
  margin:auto;
}
.block__content .gfacilities ul li img:hover{
  opacity: 0.8;
  transition-duration: 0.3s;
}
.block__content .gfacilities p.gfacilities_text{
  text-align: center;
  margin-block-start: 0;
  margin-block-end: 0;
}
.text-content .gfacilities p.gfacilities_small{
        color: var(--color--gray-45);
        font-size:0.75em;
        font-weight:500;
        line-height:1.2em;
        margin-block-start: 0;
        margin-block-end: 0;
        padding:0 10px 10px 10px;
}
.block__content .gfacilities ul li br{
       display:none;
}
.block__content .gfacilities ul li p:not(.gfacilities_text, .gfacilities_small){
       margin-block-start:0;
       margin-block-end: 0;
}
.block__content .gfacilities{
  position: relative;
}
.block__content .gfacilities h2{
  margin: 20px 0 10px 10px;
  letter-spacing:2px;
  padding: 0;
  border: none;
}
.block__content .gfacilities p.gfacilities_notice{
  position:absolute;
  top: 0;
  right:10px;
}
.block__content .gfacilities ul li:nth-child(3) p.gfacilities_text {
    letter-spacing: -1px;
}

/* image left*/
.image-left {
  float: left; /* LTR */
  margin: 0.5em 1.4em 0.6em 0; /* LTR */
  max-width: 50%;
}
@media screen and (max-width: 43.75rem) {
 .image-left {
    float: none;
    max-width: 100%;
     margin:auto;
 }
}
.image-left img {
  display: block;
  padding: 0 0 10px 0;
}
.image-left .field-label-above {
  margin-top: 0;
}
.image-left .field-label {
  margin-bottom: 0.5em;
}
.image-left .field-label-inline .field-label {
  margin-bottom: 0;
  line-height: 1;
}
.ul-right{
  font-weight:bold;
  padding-top: 16px;
}
.image-left .cap{
    font-size: 90%;
    color: #a9a9a9;
    margin-bottom: 10px;
}
.image-left br{
    display:none;
}

.cl{
  clear:both;
}

h2.cl{
  padding-top:30px;
}
h4{
  font-size: 1.2rem;
}

/* webform */
.form-item__label {
  font-size: var(--font-size-base);
}
.fieldset__legend {
    border-top-left-radius: unset;
    border-top-right-radius: unset;
    background-color: unset;
    font-size: var(--font-size-base);
    font-weight: bold;
    line-height: var(--line-height-s);
}
.fieldset__label {
    color: var(--color-text-neutral-medium);;
    line-height: var(--line-height-s);
    font-weight: bold;
    padding-inline-start: 0;
    padding-inline-end: 0;
}
.fieldset__wrapper {
    padding-block: 0;
}
.fieldset--group .fieldset__legend--visible ~ .fieldset__wrapper {
    border: none;
    border-bottom-right-radius: none;
    border-bottom-left-radius: none;
}
#edit-fu-airu-upload{
  padding: 10px var(--sp0-75);
}

.fieldset__wrapper .description {
    font-size: var(--font-size-s);
    line-height: var(--line-height-s);
}
/* Required star change color*/
.form-item__label.form-required::after,
.fieldset__label.form-required::after,
.required-mark::after {
  background-image: url("data:image/svg+xml,%3Csvg height='16' width='16' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='m0 7.562 1.114-3.438c2.565.906 4.43 1.688 5.59 2.35-.306-2.921-.467-4.93-.484-6.027h3.511c-.05 1.597-.234 3.6-.558 6.003 1.664-.838 3.566-1.613 5.714-2.325l1.113 3.437c-2.05.678-4.06 1.131-6.028 1.356.984.856 2.372 2.381 4.166 4.575l-2.906 2.059c-.935-1.274-2.041-3.009-3.316-5.206-1.194 2.275-2.244 4.013-3.147 5.206l-2.856-2.059c1.872-2.307 3.211-3.832 4.017-4.575-2.081-.402-4.058-.856-5.93-1.356' fill='%23e33f1e'/%3E%3C/svg%3E%0A");
}

/* User field */
.field:not(:last-child) {
    margin-block-end: var(--sp);
}

/* Input button */
input.form-submit{
    white-space: normal;
}
/* Application flow */
.flow{
  text-align: center;
    width: 80%;
    margin: auto;
}
.flow ul.step{
  list-style: none;
  padding-left: 0;
  margin-left:0px;
  display: inline-block;
  margin-inline-start: 0;
}
.flow .step > li{
  clear:both;
  position: relative;
  padding: 20px 10px 5px 10px;
  margin-bottom: 30px;
  background:#ededed;
  font-size: 14px;
  display:block;
  text-align: center;
  font-weight: bold;
}
.flow .step > li:not(:last-child)::after{
    content: "";
    position: absolute;
    bottom: -30px;
    left: 43%;
    border-width: 15px 60px;
    border-color: #ededed transparent transparent transparent;
    border-style: solid;
}

.flow ul.step2{
  list-style: none;
  padding-left: 0;
  margin-left:0px;
}

.flow .step2 > li.arrow, .step2 > li.arrow2{
  float: left;
  width: 49%;
  position: relative;
  padding: 20px 10px 5px 10px;
  margin-bottom: 30px;
  margin-right:2%;
  background: #dafac8;
  font-size: 14px;
  display:block;
  text-align: center;
  font-weight: bold;
}
.flow .step2 > li.arrow2{
  min-height: 121px;
}
.flow .step2 > li.arrow::after, .step2 > li.arrow2::after{
  content: "";
  position: absolute;
  bottom: -30px;
  left:35%;
  border-width: 15px 60px;
  border-color: #dafac8 transparent transparent transparent;
  border-style: solid;
}
.flow .step2 > li.stop{
  float: left;
  width: 49%;
  position: relative;
  padding: 20px 10px 5px 10px;
  margin-bottom: 25px;
  margin-right:0px;
  background: #fac8da;
  font-size: 14px;
  display:block;
  text-align: center;
  font-weight: bold;
}
.flow .step2 > li.stop_arrow{
  float: left;
  width: 49%;
  position: relative;
  padding: 20px 10px 5px 10px;
  margin-bottom: 25px;
  margin-right:0px;
  background: #fac8da;
  font-size: 14px;
  display:block;
  text-align: center;
  font-weight: bold;
}
.flow .step2 > li.stop_arrow::after{
  content: "";
  position: absolute;
  bottom: -30px;
  left:36%;
  border-width: 15px 60px;
  border-color: #fac8da transparent transparent transparent;
  border-style: solid;
}
.flow p.comment{
  font-size: 12px;
  font-weight: normal;
  text-align: left;
  line-height: 120%;
}
.flow p.go{
  font-size: 13px;
  font-weight: bold;
  text-align: center;
  line-height: 120%;
}
.flow .step ul.step_list{
  font-size: 12px;
  font-weight: normal;
   text-align: left;
  padding-left:60px;
}

@media only screen and (max-width: 43.75rem){
.flow{
    width: 100%;
}
  .flow .step > li:not(:last-child)::after{
    left: 38%;
    border-width: 15px 30px;
  }
  .flow .step2 > li.arrow::after, .step2 > li.arrow2::after{
    left: 30%;
    border-width: 15px 30px;
  }
  .flow .step2 > li.stop_arrow::after{
    left: 30%;
    border-width: 15px 30px;
  }
}

/*read more*/
.field--name-field-notice .readmore-text {
        white-space: pre-wrap;
        line-height: var(--line-height-base);
}
.field--name-field-notice .readmore-summary {
        white-space: pre-wrap;
        line-height: var(--line-height-base);
}
.field--name-field-notice .field__item {
    white-space: pre-wrap;
}

