@charset "utf-8";
:root {
  --header: 155px;
  scroll-padding: calc(var(--header) + 0px);
  @media screen and (max-width: 768px) {
  --header: 82px;
  }
}
img{
}
em{
  color: #C00;
  font-style: normal;
  font-weight: bold;
}
/*  Basic Elements
----------------------------------------------*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, /*ul, li,*/ fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td {
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
}
ul {
  margin-top: 1em;
  margin-bottom: 1em;
  padding-left: 22px;
  line-height: 1.8;
}
ul li{
  margin-bottom: .5em;
}

.container ul ul {
  margin-top: 0;
}
.container ul.link_list, .container ul.list_icon, .container ul.txt_list {
  padding: 0;
  margin-top: 0;
  margin-bottom: 1em;
}
.container ul.link_list li, .container ul.list_icon li, .container ul.txt_list li {
  margin: 0;
  padding: 0;
  list-style: none !important;
  padding-left: 26px;
  background: url("../images/icon_list01.svg") no-repeat;
  background-size: 16px;
  text-indent: 0;
  background-position: top 0.35em left;
}
.container ul.link_list li:before, .container ul.list_icon li:before, .container ul.txt_list li:before {
  content: none !important;
}
.container .txt_red {
  color: #cc0000;
}
blockquote, q {
  quotes: none;
}
blockquote:before, blockquote:after, q:before, q:after {
  content: '';
  content: none;
}
:focus {
  outline-color: #2171cc;
  outline: 3px double #2171cc #fff; /* 外側の枠線 */
  outline-offset: 2px; /* 枠線同士の距離感 */
  box-shadow:
    -2px -2px #fff, 2px -2px #fff, 2px 2px #fff, -2px 2px #fff;
}
p {
  line-height: 1.8;
  margin-bottom: 1.5em;
}
#contentsBox p + p {
}
#contentsBox .newsBlock p + p {
  margin-top: 0;
}
#contentsBox a, #contentsBox p a {
  color: #333;
}
iframe {
  max-width: 100%;
}
ruby {
  ruby-align: distribute-space;
  ruby-overhang: auto;
  ruby-position: above;
  line-height: 1;
}
ins {
  text-decoration: none;
}
del {
  text-decoration: line-through;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
 /* table-layout: fixed;*/
}
.facilityBox-data table{
  table-layout:auto;
  
}


.icn-all,
.icn-center,
.icn-ome,
.icn-nagabuchi,
.icn-daimon,
.icn-baigo,
.icn-sawai,
.icn-osoki,
.icn-nariki,
.icn-shinmachi,
.icn-imai,
.icn-annex{
	color:#FFF;
	border-radius:0;
	 display:inline-block;
  padding: 0 .5em;
	 margin-top:3px;
	 position:relative;
  margin-left: 3px;
  font-size: 1.2rem;
  border: 1px solid #FFF;
  line-height: 1.8;
}

.icn-all {
	background: #b7002f;
}

.icn-annex{
	background: #666666;
}
.icn-center{
	background: #287bb0;
}
.icn-ome{
	background: #01307d;
}
.icn-nagabuchi{
	background: #868CB7;
}
.icn-daimon{
	background: #4e9b00;
}
.icn-baigo{
	background: #b71ea3;
}
.icn-sawai{
	background:#787525;
}
.icn-osoki{
	background: #BD593A;
}
.icn-nariki{
	background: #993300;
}
.icn-shinmachi{
	background: #3b7970;
}
.icn-imai{
	background: #660099;
}


table caption {
  background-color: #10467D;
  color: #fff;
  padding: 2px;
  font-weight: bold;
}
.skip {
  position: absolute;
  left: -9999px;
}
.red {
  color: #cc0000;
  font-weight: bold;
}
/* float */
.clearfix {
  display: flow-root;
}
a img:hover {}
img.img50 {
  width: 50%;
}
.TAC{
  text-align: center;
}
.TAR{
  text-align: right;
}
.clm{
  width: auto;
  @media screen and (min-width: 769px) {
  display: flex;
    
/*  justify-content: center;*/
  flex-wrap: wrap;
    gap:20px;
  }
}

.clm2 > p,.clm2 > div {
  /*text-align: center;*/
  @media screen and (min-width: 769px) {
  }
}

/*fukidashi*/

/*fukidashi*/
.fukidashiBox{
  display: flex;
  align-items: center;
}

@media screen and (min-width: 769px) {
    .fukidashiBox{
    width:100%;
      max-width: 540px;
      margin: 0 auto;
}
}


    .fukidashi_txt{
    position:relative;
    min-height:3em;
    background:#FFFF66;
      border:5px solid #5C9BB8;
      border:1px solid #000;
    padding:10px;
    text-align:left;
    color:#000;
      margin: 1em auto 1em;
      border-radius: 10px;
      width: calc(100% - 140px);
        
}
.fukidashi_txt p{
  margin: .8em 0;
}

.fukidashi_txt:after{
    content: '';
    position: absolute;
    width: 0;
    height: 0;
    display: block;
    border-style: solid;
    border-color: transparent #FFFF66 #FFFF66 transparent;
    border-width: 15px;
    top: 50%;
  margin-top: -16px;
    right: -14px;
    border-radius: 0 0 5px 0;
    box-shadow: 2px 2px 0px #000;
    transform: scaleX(0.7) rotate(-45deg);
}
.fukidashiBoxL{
}
.fukidashiBoxL .fukidashi_txt{
  background: #84E291;
margin: 1em auto 1em 16px;
  width:100%;
}
.fukidashiBoxL .fukidashi_txt:after{
    border-color: transparent #84E291 #84E291 transparent;
    transform: scaleX(0.7) rotate(-225deg);
    right:auto;
  left:-14px;
}


.room .fukidashi_txt{
  background: #EFFBFF;
}
.room .fukidashi_txt:after{
    border-color: transparent #FFF #FFF transparent;
}

.fukidashiBox_leftImg .fukidashi_txt:after{
    border-color: transparent #EFFBFF #EFFBFF transparent;
    transform: scaleX(0.7) rotate(-225deg);
    right:auto;
  left:-14px;
}


.room_annai,
.room{
  border: 4px solid #2575BE;
    border-radius: 2em .6em 3em .4em/.3em 4em .6em 2em;
  background: #FFF;
  padding: 1em;
}
.room_tit{
  width: 70%;
  margin: auto;
}

#eventarea .calendarTbl th{
  width: auto;
}
.calendarTbl {
  table-layout: fixed;
}

.calendarTbl td,
.calendarTbl th{
vertical-align: top;
  @media screen and (max-width: 768px) {
    padding:3px;
  }
}
#inner_wrap .box_c .calendarTbl td p{
margin-bottom: 0px;
}
.calendarTbl .holy{
	 background:rgba(255,204,204,1);
 }

table.calendarTbl td span{
  @media screen and (max-width: 768px) {
  font-size: 1.2rem;
  }
}
/*
.fukidashi_txt:before{
    border: solid transparent;
    content:'';
    height:0;
    width:0;
    pointer-events:none;
    position:absolute;
    border-color: rgba(255, 255, 255, 0);
    border-top-width:22px;
    border-bottom-width:12px;
    border-left-width:12px;
    border-right-width:12px;
    margin-left: -12px;
    border-top-color:#5C9BB8;
    top:calc(100% + 3px);
    left:82px;
    }
.fukidashi_txt:after{
    border: solid transparent;
    content:'';
    height:0;
    width:0;
    pointer-events:none;
    position:absolute;
    border-color: rgba(255, 255, 255, 0);
    border-top-width:20px;
    border-bottom-width:10px;
    border-left-width:10px;
    border-right-width:10px;
    margin-left: -10px;
    border-top-color:#fff;
    top:100%;
    left:82px;
    }
    */
    
    .fukidashi_img{
      text-align: right;
    }
    .fukidashi_img img{
      width: 120px;
      margin: auto;
    }
    
.ul-leftspace{
    margin-left: 4em!important;

}

.list_pop{
  margin: 0;
  padding: 0;
  display: flex;
  gap:10px;
  justify-content: center;
  
  @media screen and (max-width: 768px) {
    flex-wrap: wrap;
  }
}
.list_pop li{
  margin: 0;
  padding: 0;
  list-style: none;
  width: calc(100% / 5);
  text-align: center;
  @media screen and (max-width: 768px) {
    width: calc(100% / 3);
  }
}

/*------------------------------------------------
   link
------------------------------------------------*/
a {
  color: #1F5189;
  text-decoration: underline;
}
a:visited {
  color: #551A8B;
}
a:hover {
  /*color: #1F5189;*/
  text-decoration: none;
}
a.ex_link {
  padding-right: 5px;
}
/*------------------------------------------------
	base
------------------------------------------------*/
html {
  width: 100%;
  height: 100%; /*	overflow-y: scroll;*/
  font-size: 62.5%;
}
html:not(:target) {
  font-family: 'Lucida Grande', 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', メイリオ, Meiryo\9;
}
body {
  width: 100%;
  color: #333;
  line-height: 2;
  text-align: left;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  -webkit-text-size-adjust: 100%;
  font-size: 1.6rem;
  -webkit-text-size-adjust: 100%;
}
.wrapper {
  position: sticky;
  top: 0;
  left: 0;
  z-index: 100;
}
/*----------------------------------------------------------
	topicpath
----------------------------------------------------------*/
ul.topicpath {
  width: 100%;
  margin: 0;
}
ul.topicpath > li {
  display: inline-block;
  padding: 0px;
  margin: 0px
}
ul.topicpath > li:after {
  padding: 5px;
  content: ">";
}
ul.topicpath > li:last-child:after {
  content: " ";
}
/*cms*/
ol#topicpath {
  width: 100%;
  margin: 0 0 1em 0;
}
ol#topicpath > li {
  display: inline-block;
  padding: 0px;
  margin: 0px
}
ol#topicpath > li a {
  color: #333;
}
ol#topicpath > li:after {
  padding: 5px;
  content: ">";
}
ol#topicpath > li:last-child:after {
  content: " ";
}
/*----------------------------------------------------------
	Layout
----------------------------------------------------------*/
header {
  background: #fff;
  border-bottom: 2px solid #2575BE;
}
header .container .row {
  display: flex;
  align-items: center;
}
header .col {
  padding-left: 0;
}
header .container .col {
  float: none;
  padding: 0px 0;
}
header .md-9 {
  padding: 16px 0 0;
}
header .nav_upper {
  display: flex;
  justify-content: flex-end;
  align-items: center;
}


.nav_upper_links ul{
  margin: 0px auto;
  padding: 0px;
  list-style: none;
  gap: 0 30px;
  width: 100%;
  display: flex;
  justify-content: space-between;
}
.nav_upper_links ul li {
  display: flex;
  width: auto;
  text-align: center;
  margin-bottom: 0;
}
.nav_upper_links ul span.gnav-ic{
  display: block;  
  vertical-align: top;
}
.nav_upper_links ul span.gnav-ic-txt{
  font-size: 1.4rem;
  vertical-align: top;
  font-weight: bold;
}
span.gnav-ic-txt img{
  vertical-align: middle;
}

header .nav_upper .nav_upper_links ul {
  align-items: center;
  margin: 0px auto;
  padding: 0px;
  list-style: none;
  width: 100%;
  display: flex;
  justify-content: space-between;
  
}
header .nav_upper .nav_upper_links ul li {
  display: flex;
  align-items: center;
}
header .nav_upper .nav_upper_links ul a {
  color: #333;
  text-decoration: none;
}
header .nav_upper .nav_upper_links ul a:hover {
  text-decoration: underline;
}
header .nav_upper .nav_upper_sns ul {
  display: flex;
  align-items: center;
  padding: 0;
  margin: 0;
}
header #gnav_area {
  display: flex;
  justify-content: flex-end;
}
header .nav_upper .nav_upper_sns ul li {
  margin-left: 20px;
  line-height: 0;
  list-style: none;
}
header .nav_upper .nav_upper_sns ul li a {
  display: block;
}
header .nav_upper .nav_upper_sns ul li img {
  width: 30px;
  height: auto;
}
@media screen and (max-width: 1075px) {
  header .nav_upper .nav_upper_links ul a {
    font-size: 1.4rem;
  }
}
/*　本文へ　*/
.skip {
  width: 1px;
  color: #333;
  font-size: 0.1%;
  line-height: 0;
  background-color: #fff;
  position: absolute;
  left: -3000px;
  z-index: 9999;
}
a.skip {
  background-color: #eee !important;
  color: #333 !important;
  text-align: center;
  padding: 5px 0;
  top: auto;
}
a.skip:active {
  display: block;
  width: 99.99%;
  font-size: 1.6rem;
  line-height: 1.8;
  top: 0;
  left: 0;
}
a.skip:focus {
  display: block;
  width: 99.99%;
  font-size: 1.6rem;
  line-height: 1.8;
  top: 0;
  left: 0;
}
#header_logo {
  margin-right: 10px;
  margin-bottom: 0;
  padding: 3px 0;
}
#header_logo a {
  display: inline-block;
}
p#header_logo {}
@media screen and (max-width: 1075px) {
  #header_logo img {
    max-width: 200px;
  }
}
header .container {
  background: #fff;
  margin: 0 auto;
  position: relative;
  /*  padding: 0 80px; */
}

#bookSearch_area{
  background: #2575BE;
}


.googleSearch{
  background: #d0e1f3;
  color: #000;
}
#bookSearch_area a{
  color: #FFF;
}

.googleSearch{
  margin: 1em 0;
}
#bookSearch_area .container {
  display: flex;
  max-width: 768px;
}

.googleSearch .container{
  max-width: 738px;
  color: #10467D;
  
}
#cse-search-box .search_inputFlex{
  display: flex;
  width: 100%;
  padding-bottom: .5em;
}
.search_inputFlex #tmp_query{
  width: 81%;
    border: 1px solid #ccc !important;
    @media screen and (max-width: 768px) {
      width:59%;
    }
  }
.search_inputFlex .search_btn{
    font-weight: bold;
  cursor: pointer;
  border: none;
  min-height: 1.9em;
  width: 21%;
  color: #10467D;
  background: #d0e1f3;
  border: 1px solid #10467D;
    @media screen and (max-width: 768px) {
      width:40%;
    }
}
#bookSearch, #d_libSearch {
  text-align: center;
  width: 100%;
  justify-content: center;
  align-items: center;
  padding: 0 10px 10px;
  position: relative;
}
#bookSearch {
}
#d_libSearch {
}
#bookSearch div, #d_libSearch div {
  line-height: 1.2;
  padding: 0;
  width: 100%;
  margin: 0 auto;
}


.bookSearch_titleWrap{
  color: #FFF;
  
  @media screen and (min-width: 769px) {
  
  display: flex;
  justify-content:space-between;
  }
}
.bookSearch_titleWrap ul,.bookSearch_titleWrap li{
  list-style: none;
  margin: 0;
  padding: 0;
}
.bookSearch_titleWrap ul{
  margin-left: auto;
}
.bookSearch_titleWrap li{
  display: inline-block;
  margin-left: 1em;
}

.bookSearch_titleWrap a{
  color: #FFF;
}

p.bookSearch_title {
  margin-bottom: 0;
}
p.d_libSearch_title {
  padding: .8em .5em .2em;
  text-align: left;
  color: #10467D;
  font-weight: bold;
  width: 100%;
  display: flex;
  align-items: stretch;
  flex-wrap: wrap;
}
.btn_area {
  display: flex;
}
.bookSearch_link, .d-bookSearch_link {
  margin-left: auto;
}
.bookSearch_link a, .bookSearch_link a:visited {
  color: #fff;
  font-weight: bold;
}
.d-bookSearch_link a, .d-bookSearch_link a:visited {
  color: #10467D;
  font-size: 80%;
}
#bookSearch .bookSearch_field p strong, #d_libSearch .bookSearch_field p strong {
  font-size: 90%;
  text-align: left !important;
  font-weight: normal;
}
#bookSearch .bookSearch_link a, #bookSearch_sp .bookSearch_link a, #d_libSearch .bookSearch_link a, #d_libSearch_sp .bookSearch_link a {
  font-size: 80%;
}
#bookSearch .bookSearch_link .arrow::before, #bookSearch .bookSearch_link .arrow::after, #bookSearch_sp .bookSearch_link .arrow::before, #bookSearch_sp .bookSearch_link .arrow::after {
  border-left: 4px solid #fff;
}
#d_libSearch .d-bookSearch_link .arrow::before, #d_libSearch .d-bookSearch_link .arrow::after {
  border-left: 4px solid #10467D !important;
}
#bookSearch .formTxt, #d_libSearch .formTxt {
  width: 80%;
  min-height: 2em;
  margin: 0 auto;
  padding: 0 0 0 5px !important;
  background-position: 10px center !important;
  border: 1px solid #ccc !important;
}
#bookSearch .booksearch_btn, #bookSearch_sp .booksearch_btn, #d_libSearch .d_libsearch_btn, #d_libSearch_sp .d_libsearch_btn {
  font-weight: bold;
  cursor: pointer;
  border: none;
  min-height: 1.9em;
  width: 19%;
  margin-left: -5px;
}

.inner_row #bookSearch .formTxt, #d_libSearch .formTxt {
  width: 79%;
  @media screen and (max-width: 768px) {
    width: 59%;
  }
  
}
.inner_row #bookSearch .booksearch_btn{
  width: 20%;
  @media screen and (max-width: 768px) {
  width: 40%;
  }
}

#bookSearch .booksearch_btn, #bookSearch_sp .booksearch_btn {
  color: #10467D;
  background: #d0e1f3;
}
#d_libSearch .d_libsearch_btn, #d_libSearch_sp .d_libsearch_btn {
  color: #fff;
  background: #10467D;
  white-space: nowrap;
}
#bookSearch .booksearch_btn:hover, #bookSearch_sp .booksearch_btn:hover, #d_libSearch .d_libsearch_btn:hover, #d_libSearch_sp .d_libsearch_btn:hover {
  text-decoration: underline;
}
/*header .header_search {
  background: #10467D;
  padding: 10px 0;
}
header .header_search .header_search_inner {
  background: none;
}
header .header_search .tab_area_wrap {
  display: flex;
  justify-content: flex-start;
  background: #edf5fc;
  width: 100%;
  max-width: 850px;
  margin: 0 auto;
  border-radius: 6px;
}
header .header_search .tab_area_wrap .tab_nav {
  display: flex;
  flex-direction: column;
  cursor: pointer;
  width: 215px;
}
header .header_search .tab_area_wrap .tab_nav .tab_tit {
  background: #E2E2E2;
  color: #555;
  border: none;
  font-weight: bold;
  height: 50%;
  padding: 8px 20px;
  cursor: pointer;
  margin: 0;
  position: relative;
  display: flex;
  align-items: center;
}
header .header_search .tab_area_wrap .tab_nav .tab_tit:focus {
  box-shadow: none;
}
header .header_search .tab_area_wrap .tab_nav .tab_tit.active {
  background: #d0e1f3;
  color: #314a5d;
}
header .header_search .tab_area_wrap .tab_nav .tab_tit.active::after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  border-left: 10px solid #d0e1f3;
  border-right: 0;
  position: absolute;
  right: -10px;
}
header .header_search .tab_area_wrap .tab_nav .tab_tit#tabA {
  border-radius: 6px 0 0 0;
}
header .header_search .tab_area_wrap .tab_nav .tab_tit#tabB {
  border-radius: 0 0 0 6px;
}
header .header_search .tab_area_wrap .tab_area_inner {
  width: calc(100% - 215px);
  padding: 10px 20px;
}
header .header_search .tab_area_wrap .tab_area_inner #contentA fieldset, header .header_search .tab_area_wrap .tab_area_inner #contentA label, header .header_search .tab_area_wrap .tab_area_inner #contentA .form_cont {
  display: flex;
}
header .header_search .tab_area_wrap .tab_area_inner #contentB .search-input fieldset, header .header_search .tab_area_wrap .tab_area_inner #contentB .search-input label, header .header_search .tab_area_wrap .tab_area_inner #contentB .search-input.form_cont {
  display: flex;
  width: 100%;
}
header .header_search .tab_area_wrap .tab_area_inner #contentA fieldset .formTxt, header .header_search .tab_area_wrap .tab_area_inner #contentA label .formTxt {
  width: calc(100% - 100px);
  border: 1px solid #10467D;
  border-radius: 6px 0 0 6px;
}
header .header_search .tab_area_wrap .tab_area_inner #contentB .search-input .formTxt {
  width: calc(100% - 100px);
  border: 1px solid #10467D;
  border-radius: 6px 0 0 6px;
}
header .header_search .tab_area_wrap .tab_area_inner #contentA fieldset .search_btn, header .header_search .tab_area_wrap .tab_area_inner #contentA label .search_btn {
  width: 100px;
  padding: 3px 10px;
}
header .header_search .tab_area_wrap .tab_area_inner #contentB .search-input .d_libsearch_btn {
  background-color: #10467D !important;
  color: #fff !important;
  border: none;
  cursor: pointer;
  border-radius: 0 6px 6px 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100px;
  padding: 3px 10px;
}
header .header_search .tab_area_wrap .tab_area_inner #contentA fieldset .search_btn img, header .header_search .tab_area_wrap .tab_area_inner #contentA label .search_btn img, header .header_search .tab_area_wrap .tab_area_inner #contentB .search-input .d_libsearch_btn img {
  margin-left: 2px;
}
header a.search_link_icon {
  color: #333;
}*/
header.active {
  color: red;
}
p.skip {
  position: absolute;
  left: -9999px;
}
.iframe p.skip {
  position: initial;
  left: initial;
  width: initial;
  color: initial;
  font-size: initial;
  line-height: initial;
  background: none;
  z-index: initial;
}
.iframe iframe {
  width: 100% !important;
}
#sp_navi, #sp_navi_txt {
  display: none;
}
.search_field {
  width: 11em;
  padding: 5px;
  background-color: #fff;
  border: 1px solid #10467D;
  padding-left: 10px;
  border-radius: 6px 0 0 6px;
}
#header_search {
  float: right;
  display: flex;
  align-items: center;
}
header .search_btn {
  background-color: #10467D !important;
  color: #fff !important;
  border: none;
  cursor: pointer;
  padding: 0 10px;
  border-radius: 0 6px 6px 0;
  display: flex;
  align-items: center;
  justify-content: center;
  /*  height: 29px;*/
}
header .search_btn img {
  margin-left: 2px;
}
.design_control {
  float: right;
}
.font_btn, .font_btn .title, .bg_btn, .bg_btn .title {
  float: left;
}
.font_btn {
  width: 190px;
  display: none;
}
.font_btn .title {
  margin: 3px 0px;
}
.bg_btn {
  display: flex;
}
.bg_btn .title {
  margin: 3px 10px;
}
.search_link_btn {
  width: auto;
  padding: 7px 10px 7px 0;
  float: left;
  margin: 0 0 0 20px;
}
.search_link_btn a {
  color: #333;
  font-size: 1.5rem;
  display: block;
  text-decoration: none;
}
.search_link_btn a:hover {
  text-decoration: underline;
}
.search_btn a {
  color: #333;
}
#cse-search-box {
  display: flex;
  align-items: center;
}
#cse-search-box fieldset, #cse-search-box .form_cont, #cse-search-box label {
  display: flex;
}
/* 　フォントサイズ変更ボタンstyle　*/
#font-size div.small, #font-size div.medium, #font-size div.large {
  color: #fff !important;
  font-size: 1.4rem;
  display: inline-block;
  cursor: pointer;
  background: #000;
  letter-spacing: 0.1em;
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  border-radius: 5px;
  padding-top: 2px;
}
#font-size div.small a, #font-size div.medium a, #font-size div.large a {
  color: #fff !important;
  text-decoration: none !important;
  padding: .5em;
}
#font-size div.active {
  color: #FFF !important;
  background: #10467D;
}
#font-size div.active a {
  color: #FFF !important;
  text-decoration: none !important;
}
#font-size div.small, #font-size div.medium, #font-size div.large {
  border: 1px solid #fff;
  margin: 0 2px;
}
@media screen and (max-width: 1075px) {
  .search_link_btn a {
    font-size: 1.4rem;
  }
  #cse-search-box fieldset {
    font-size: 1.4rem;
  }
}
ul#bgcolor li {
  display: inline-block;
  cursor: pointer;
  letter-spacing: 0.1em;
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  border-radius: 5px;
  font-size: 1.4rem;
}
ul#bgcolor li a {
  display: block;
  text-decoration: none;
  padding: 0px 0.6em;
}
ul#bgcolor li {
  border: 1px solid #fff;
  margin: -2px;
}
ul#bgcolor li#bc_btn01 {
  color: #333;
  background-color: #ccc;
}
ul#bgcolor li#bc_btn01 a {
  color: #333;
}
ul#bgcolor li#bc_btn02 {
  background-color: #333;
}
ul#bgcolor li#bc_btn02 a {
  color: #fff;
}
ul#bgcolor li#bc_btn03 {
  background-color: #1F5189;
}
ul#bgcolor li#bc_btn03 a {
  color: #ffff00;
}
div#changeArea {
  line-height: 1.8;
}
div#changeArea ul#fontSize {
  *zoom: 1; /*forIE6,7*/
  margin-bottom: 10px;
}
div#changeArea ul#fontSize:after {
  content: "";
  display: block;
  clear: both;
}
div#changeArea ul#fontSize li {
  background-color: #ccc;
  padding: 10px 15px;
  margin-right: 5px;
  float: left;
  cursor: pointer;
}
div#changeArea ul#fontSize li:hover {
  background-color: #eee;
}
div#changeArea ul#fontSize li.active {
  background-color: #999;
}
div#changeArea ul#fontSize li.active:hover {
  background-color: #999;
}
/*----------------------------------------------------------
	Grobal Menu
----------------------------------------------------------*/

nav#gnavi {
  width: 100%;
  @media screen and (min-width: 769px) {
    padding-bottom:2px;
  }
}
nav#gnavi .container {
  margin: 0 auto;
  position: relative;
  padding: 0;
}
nav#gnavi .container ul {
  margin: 0px auto;
  padding: 0px;
  list-style: none;
  width: 100%;
  display: flex;
  justify-content: center;
  justify-content: space-between;
  gap:0 10px;
  background-color: #FFF;
}
nav#gnavi .container li {
  display: flex;
  width: auto;
  margin-bottom: 0;
  text-align: center;
}
nav#gnavi span {
  font-size: 1.2rem;
  display: block;
  margin-bottom: .2em;
}
nav#gnavi .container li[id^="gnav"] > a {
  display: block;
  width: 100%;
  justify-content: center;
  align-items: center;
  text-decoration: none;
  color: #333;
  font-size: 1.8rem;
  position: relative;
  line-height: 1.8;
  padding: 10px;
  font-weight: bold;
  padding:10px 10px;
}
nav#gnavi .container li[id^="gnav"] > a img {
  margin-left: 2px;
}
nav#gnavi .container li:hover {
  background-position: center center;
}
nav#gnavi .container li a:hover, nav#gnavi .container li a.active {
  content: none !important;
}
nav#gnavi .container li a:hover{
  text-decoration: underline;
  
}

#sp_opac_navi {
  display: none;
}
#sp_menu {
  display: none;
}
#sp_navi_box .js-navCloseToggle {
  display: none;
}
@media screen and (max-width: 1075px) {
  header .container {
    padding-left: 10px;
    padding-right: 10px;
  }
  nav#gnavi .container li[id^="gnav"] > a {
    font-size: 1.4rem;
  }
  nav#gnavi .container li[id^="gnav"]:last-child > a {
    padding-right: 0;
  }
}


dl.contest{
  dt{
    font-weight: bold;
  }
  dd{
    margin-left: 1.5em;
  }
}

/*----------------------------------------------------------
	main
----------------------------------------------------------*/
noscript div {
  text-align: center;
  background: #6B7C18;
  margin: 20px auto 20px;
  padding: 5px;
  width: 960px;
  color: #fff;
}
ul#skip {
  position: absolute;
  overflow: hidden;
  height: 0;
  width: 0;
}
#top_wrap, #inner_wrap {
/*  background: -moz-linear-gradient(top, #edf5fc, #FFF);
  background: -webkit-linear-gradient(top, #edf5fc, #FFF);
  background: linear-gradient(to bottom, #edf5fc, #FFF);
 */
}
#top_wrap{
background:url("../images/top_bg.png") repeat-x top left;
}

#top_wrap {
  padding-top: 0;
}
#top_wrap .container, #inner_wrap .container {
  margin: 0 auto 0;
  clear: both;
}
#inner_wrap .box_c p {
  /*padding: 10px 0;*/
  /*  margin-bottom: 20px;*/
}
#inner_wrap .box_c p.layout_c {
  text-align: center;
}
.row {
  margin: 0 !important;
}
#top_wrap .md-4 {
  padding-right: 0 !important;
  padding-left: 0 !important;
}
#top_wrap .box_l, #inner_wrap .box_l {
  /*padding-right:40px!important;*/
  padding-left: 0 !important;
}
#top_wrap .box_c {
  padding-left: 0 !important;
  padding-right: 0 !important;
}
#top_wrap .box_r_top {
  padding-right: 0 !important;
}
/*  slide
----------------------------------------------*/
#mainVisual {
  position: relative;
}
.slidewrap {
  width: 100%;
  margin-bottom: 20px;
  overflow: hidden;
}
ul.slides {
  padding-left: 0;
}
.slides li {
  list-style: none !important;
}
/*  Main leftBox
----------------------------------------------*/
/*#bookSearch {
  border: 5px solid #cdf7d2;
  background-color: #f0fcef;
  text-align: center;
  width: 100%;
  margin-bottom: 20px;
  padding-bottom: 10px;
}
#bookSearch div {
  line-height: 1.8;
  padding: 5px 10px;
}
p.bookSearch_title:before {
  content: url(../images/icon_search.svg);
  margin: 10px 0px 10px 5px;
  position: relative;
  top: 8px;
  color: #fff;
  left: -5px;
}
p.bookSearch_title {
  font-size: 1.8rem;
  background-color: #cdf7d2;
  padding: 0px 5px 7px 5px;
  text-align: center;
}*/
#bookSearch .bookSearch_field p strong {
  font-size: 1.5rem;
  text-align: left !important;
  font-weight: normal;
}
/*#bookSearch .bookSearch_link a, #bookSearch_sp .bookSearch_link a {
  font-size: 1.5rem;
  margin-bottom: 10px;
}*/
#bookSearch .bookSearch_link .arrow:before, #bookSearch .bookSearch_link .arrow:after, #bookSearch_sp .bookSearch_link .arrow:before, #bookSearch_sp .bookSearch_link .arrow:after {
  border-left: 4px solid #333333;
}
/*#bookSearch .formTxt {
  width: 100%;
  height: 40px;
  margin: 10px auto;
  padding: 0 0 0 5px !important;
  background-position: 10px center !important;
  border: 1px solid #ccc !important;
}*/
#bookSearch .search_btn, #bookSearch_sp .search_btn {
  color: #fff;
  background: #10467D;
  font-size: 1.8rem;
  font-weight: bold;
  width: 100%;
  padding: 5px 0;
  cursor: pointer;
  margin: 5px 0;
  border: none;
  border-radius: 5px;
}
#bookSearch .search_btn:hover, #bookSearch_sp .search_btn:hover {
  background-color: #357166;
}
/*usemenu_link*/
.usemenu_link {
  box-sizing: border-box;
  overflow: hidden;
  margin-bottom: 20px;
}
p.usemenu_title {
  font-size: 1.8rem;
  border-left: 5px solid #10467D;
  background-color: #cdf7d2;
  padding: 0 0 7px 0;
  text-align: center;
}
p.usemenu_title:before {
  content: url(../images/icon_usermenu.svg);
  margin: 10px 5px;
  position: relative;
  top: 8px;
}
.usemenu_box_title {
  background-color: #B9D530;
  border-bottom: 3px solid #8ba024;
  font-size: 1.8rem;
  font-weight: bold;
  padding: 3px 10px 10px 10px;
}
.usemenu_link li {
  background-color: #f0fcef;
  margin-top: 0;
  width: 100%;
  font-size: 1.8rem;
  text-align: left;
  margin-bottom: 2px;
}
.usemenu_link li a {
  position: relative;
  display: block;
  padding: 3px 3px 3px 10px;
  color: #222;
  font-size: 1.5rem;
  text-decoration: none;
  vertical-align: middle;
  min-height: 50px;
}
.usemenu_link li.topl-01 a::before {
  content: url(../images/icon_mypage.svg);
  margin-right: 10px;
  position: relative;
  top: 5px;
}
.usemenu_link li.topl-02 a::before {
  content: url(../images/icon_newbook.svg);
  margin-right: 10px;
  position: relative;
  top: 5px;
}
.usemenu_link li.topl-03 a::before {
  content: url(../images/icon_best.svg);
  margin-right: 10px;
  position: relative;
  top: 5px;
}
.usemenu_link li.topl-04 a::before {
  content: url(../images/icon_recommend.svg);
  margin-right: 10px;
  position: relative;
  top: 5px;
}
.usemenu_link li.topl-05 a::before {
  content: url(../images/icon_magazine.svg);
  margin-right: 10px;
  position: relative;
  top: 5px;
}
.usemenu_link li.topl-06 a::before {
  content: url(../images/icon_newspaper.svg);
  margin-right: 10px;
  position: relative;
  top: 5px;
}
.usemenu_link li a:hover {
  text-decoration: underline;
}
.usemenu_link_r {
  border-left: 3px solid #6B7C18;
}
.usemenu_link_r li {
  background-color: #F9FDFA;
  padding: 5px 0;
  margin-top: 0;
  width: 100%;
  font-size: 1.8rem;
  border-bottom: 1px solid #ccc;
  text-align: left;
}
.usemenu_link_r li:last-child {
  border-bottom: none;
}
.usemenu_link_r li a {
  display: block;
  position: relative;
  padding: 3px 3px 3px 20px;
  color: #333;
  font-size: 1.5rem;
  font-weight: bold;
  text-decoration: none;
}
.usemenu_link_r li a:hover {
  text-decoration: underline;
}
.banner_area {
  margin-top: 20px;
}
.box_l h3#adbanner {
  background-color: #3E840F;
  color: #fff;
  font-weight: bold;
  text-align: center;
  margin-top: 1em;
  margin-bottom: 0;
  padding: .5em;
}
.box_l #adbanner_wrap {
  border: 1px solid #3E840F;
  background-color: #fff;
  text-align: center;
  padding-top: 1em;
}
p.link_btn_title {
  font-size: 1.8rem;
  border-left: 5px solid #10467D;
  background-color: #cdf7d2;
  padding: 0 0 7px 0;
  text-align: center;
}
p.link_btn_title:before {
  content: url(../images/icon_libmemu_g.svg);
  margin: 10px 5px;
  position: relative;
  top: 8px;
}
.link_btn_list {
  margin: .5em 0;
  display: flex;
  flex-wrap: wrap;
}
.link_btn_list li {
  padding: 1px 0 0;
  margin: 0 0 5px 0;
  vertical-align: top;
  line-height: 1;
  display: table;
  width: 100%;
}
.link_btn_list li a {
  border: 1px solid #CCC;
  color: #333;
  font-size: 1.6rem;
  text-decoration: none;
  padding: 10px;
  height: 4.6em;
  vertical-align: middle;
  display: table-cell;
  width: 100%;
  padding-left: 70px;
  border-collapse: collapse;
}
.link_btn_list li a:hover {
  text-decoration: underline;
}
.link_btn_list li a.lbl_cld {
  background: url(../images/pic_libcalendar.png) no-repeat 7px center #FFF;
}
.link_btn_list li a.lbl_spo {
  background: url(../images/pic_libmemu01.png) no-repeat 7px center #FFF;
}
.link_btn_list li a.lbl_org {
  background: url(../images/pic_libmemu02.png) no-repeat 7px center #FFF;
}
.link_btn_list li a.lbl_sup {
  background: url(../images/pic_libmemu03.png) no-repeat 7px center #FFF;
}
.link_btn_list li a.lbl_arc {
  background: url(../images/pic_libmemu04.png) no-repeat 7px center #FFF;
}
.aboutlib_area {
  margin-bottom: 20px;
  width: 100%;
}
.aboutlib_area p.aboutlib_title {
  font-size: 1.8rem;
  border-left: 5px solid #10467D;
  padding: 0 0 7px 0;
}
.aboutlib_area p.aboutlib_title:before {
  content: url(../images/icon_libmemu_g.svg);
  margin: 10px 5px;
  position: relative;
  top: 8px;
}
.aboutlib_menu {
  line-height: 1.8;
  margin: .5em 0;
}
.aboutlib_menu li {
  text-align: left;
}
.aboutlib_menu li a {
  position: relative;
  padding-left: 1.5em;
}
.aboutlib_menu li a:before {
  content: '';
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4px 0 4px 6px;
  border-color: transparent transparent transparent #333333;
  position: absolute;
  top: 50%;
  left: 0;
  margin-top: -4px;
  margin-left: 10px;
}
.keywordBlock {
  text-align: center;
  width: 100%;
  margin-bottom: 20px;
  padding: 0 10px 10px 10px;
}
.keyword_title {
  padding: 0 15px 7px 0;
  text-align: center;
  font-size: 2rem !important;
  margin-top: 0;
  background: transparent;
}
.keyword_title:before {
  content: url(../images/icon_search.svg);
  margin: 10px 0px 10px 5px;
  position: relative;
  top: 8px;
  left: -5px;
}
.title_keywordList {
  margin-top: 10px;
}
.title_keywordList li {
  float: left;
  background: #fff;
  margin-right: 5px;
  margin-bottom: 5px;
  border-radius: 50px;
  border: 0;
  list-style: none !important;
}
.title_keywordList li a {
  display: block;
  padding: 0.2em 0.8em;
  font-size: 1.5rem;
}
.title_comment {
  background: #eaeaea;
	padding: 5px;
}
.ind_searchCommentBox {
  margin-top: 20px;
}
.ind_searchCommentBox p {
  margin-top: 1em;
}
/*  Main innerBox
----------------------------------------------*/

.contents_header{
    background: #2575BE;
 padding-bottom: 3em; 
padding-top: .5em;

@media screen and (max-width: 768px) {
padding-left: 1em;
  padding-right: 1em;
  }
}
.contents_header a,.contents_header *{
  color: #fff!important;
}
.contents_header h1{
  margin-bottom: 0!important;
  text-align: center;
}


#inner_wrap h1 {
}
.index #inner_wrap h1::before {
  content: none;
}
#inner_wrap h1 span {
  
}
#inner_wrap h1.ico_news, #inner_wrap h1.ico_event {
  /*
  border-bottom: 2px solid #3D7927;
  background: none;
  margin: 0;
  border-left: none;
  font-weight: bold;
  padding: 0 0 18px !important;*/
}
#inner_wrap h1.ico_news::before {
  content: none;
}
#inner_wrap h1.ico_event::before {
  content: none;
}
h2 {
  background: #FBFCED;
  padding: 10px 15px 10px 15px;
  font-size: 2.0rem;
  margin-top: 2em;
  margin-bottom: 0.7em;
  clear: both;
  line-height: 1.8;
  border-left: 3px solid #2575BE;
}
h3 {
  padding: 5px 10px 5px 0px;
  font-size: 1.8rem;
  margin: 1.8em 0 0.7em;
  clear: both;
  border-bottom: #ccc dotted 1px;
  line-height: 1.8;
}
h3::before{
  content: "■";
  color: #2575BE;
  margin-right: .3em;
}

h4 {
  color: #10467D;
    margin-bottom: 1em;
  font-size: 1.8rem;
  font-weight: bold;
}
h4:after {
}
h5 {
  font-weight: bold;
  margin: 1.8em 0 0.7em;
  font-size: 1.6rem;
}
p.leadTxt {
  font-weight: bold;
  font-size: 1.8rem;
  margin-top: 20px;
  color: #3F2B0C;
}

.pagelink_list .pagelink_list_tit{
  font-weight: bold;
  margin: .5em 0 0 0;
}

div.pagelink_list, div#pagelink_list, .archiveList {
  margin: 15px 0;
  padding: 10px;
  background-color: #F2F8FF;
  border-radius: 10px;
}
div.pagelink_list ul, div#pagelink_list ul, .archiveList ul {
  padding-left: 0;
  border: 2px dotted #287BB0;
  border-radius: 10px;
  margin: 0;
  padding: 10px;
}
.archiveList li, div.pagelink_list li, div#pagelink_list li, .archiveList li {
  margin-right: 20px;
  float: left;
  margin-bottom:.5em;
  margin-top:.5em;
  list-style: none !important;
  padding-left: 20px;
  background: url(../images/icon_list01.svg) no-repeat;

  text-indent: 0;
  background-position: top 0.35em left;
}


.archiveList li a, div.pagelink_list li a, div#pagelink_list li a, .archiveList li a{
  text-decoration: none;
  &:hover{
    text-decoration: underline;
  }
}


ul.normal {
  margin: 15px 0;
}
ul.normal li {
  list-style-type: disc !important;
  margin-left: 1em;
}
ul.txt_list {
  margin: 15px 0;
}
ul.txt_list li {
  padding: 0 0 0 1em;
  text-indent: -.5em;
}
ul.txt_list > li:before {
  content: url(../images/icon_txt_list.svg);
  position: relative;
  top: 0;
  margin-right: 5px;
}
ul.txt_list li .point_list li {
  padding-left: 20px;
  background: url(../images/icon_list.svg) no-repeat left 15px;
}
ul.point_list, p.point_list {
  margin-bottom: 10px;
}
ul.point_list li, p.point_list li {
  background: url(../images/icon_list.svg) no-repeat left 8px;
  padding-left: 10px;
}
ul.data_list {
  margin: 15px 0;
}
ul.data_list li {
  margin-bottom: 6px;
  padding: 2px 0 0 1.5em;
  text-indent: -1.5em;
  border-bottom: 1px dotted #ccc;
}
ul.data_list li::before {
  content: url(../images/icon_data_list.svg);
  position: relative;
  top: 5px;
  margin-right: 10px;
}
ul.data_list li.d2 {
  margin-left: 30px;
}
ul.pdfList {
  margin: 15px 0;
  list-style: none !important;
  padding: 0;
}
ul.pdfList li {
  margin-bottom: 6px;
  padding: 2px 0 0 1.5em;
  text-indent: -1.5em;
  border-bottom: 1px dotted #ccc;
  list-style: none !important;
}
ul.pdfList li::before {
  content: url(../images/icon_data_list.svg);
  position: relative;
  top: 5px;
  margin-right: 10px;
}
table.document {
  line-height: 1.8;
}
table.document th {
  text-align: center;
}
table.document .thumb {
  width: 25%;
}
table.document img {
  width: 100px;
}
.box_c ol {
  margin-left: 1.5em;
  margin-bottom: 20px;
}
ol.number {
  list-style-type: decimal !important;
  margin-top: 20px;
  margin-left: 20px;
}
ol.number li {
  padding-bottom: 5px;
}
div.txt_box01 {
  background-color: #FFEDE6;
  margin-bottom: 20px;
  padding: 1em .5em;
  border: 1px solid #B22D00;
}
div.txt_box02 {
  background-color: #fff;
  margin-bottom: 20px;
  padding: .5em;
  border: 1px solid #3b8806;
}
.btnrss {
  background: #f5fcda;
  border: 1px solid #d8ec93;
  margin-bottom: 2em;
}
.btnrss a {
  color: #3a7d1e;
  text-decoration: none;
  padding: .5em 0;
  display: block;
  text-align: center;
  font-weight: bold;
}
.btnrss a:before {
  content: url("../images/icn_btn_rss.png");
  margin-right: 10px;
  position: relative;
  top: 3px;
}
/* top　right
----------------------------------------------*/
.box_r_top li a:hover, .usemenu_link a:hover {
  /*  opacity: 0.8;*/
  filter: saturate(150%);
}
/* 開館カレンダー
----------------------------------------------*/

.top_cal_wrap{
  background: #FAF9F4;
  padding: 1em 0;
}


.calendar_area .calendar_title_area {
  text-align: center;
  margin-bottom: 10px;
}
.calendar_area .tit01 {
  text-align: center;
  font-size: 3rem;
  border: none;
  background: none;
  padding: 0;
  font-weight: normal;
  margin: 0;
  margin-right: 1em;
  margin-bottom: 0;
}
.cal_more{
  text-align: right;
  margin-top: -1em;
}

.lib_cal_wrap {
}
.calendar_data {
  background-color: #10467D;
  text-align: center;
  font-weight: bold;
  color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 200px;
  padding: 6px 16px;
  max-height: 44px;
  line-height: 1.8;
}
.tit-facility {
  display: block;
  font-size: 2.7rem;
  color: #333;
  line-height: 1.6;
}
.data-facility {
  margin-top: -.4em;
  display: inline-block;
  font-size: 1.6rem;
}
.facility-list {
  box-sizing: border-box;
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  padding: 0;
}
.facility-list a {
  display: table-cell;
  vertical-align: middle;
  padding:5px 10px;
  padding-left: 70px;
  line-height: 1.8;
  font-weight: bold;
  color: #314a5d;
  text-decoration: none;
}
.facility-list a:hover {
  text-decoration: underline;
}
.facility-list a span {
  color: #314a5d;
}
.facility-list li {
  background: url(../images/icon_cal_open.png) no-repeat 10px center #FFF;
  display: table;
  width: calc(100% / 5 - 16px );
  border-radius: 100px;
  -webkit-transition: 0.4s;
  transition: 0.4s;
  box-shadow: 0 0 5px 0 rgb(0 0 0 / 14%);
}
.facility-list li:hover {
  box-shadow: 0 0 20px 0 rgb(0 0 0 / 14%);
}
.facility-list li:last-child {
  border-bottom: none;
  margin-bottom: 0px;
}
.facility-list .closed {
  background: url(../images/icon_cal_close.png) no-repeat 10px center #F1F1F1;
}
.facility-list .closed a, .facility-list .closed .tit-facility {
  color: #676767;
}
.facility-list p.fltb {
  display: table-cell;
  vertical-align: middle;
  padding-left: 45px;
  line-height: 1.8;
  text-decoration: none;
  font-weight: bold;
}
.lib_cal_links {
  width: 50%;
  margin: 20px 0 0;
}
.lib_cal_links ul {
  display: flex;
  height: 100%;
  gap: 20px;
  justify-content: flex-end;
  padding: 0;
  margin: 0;
}
.lib_cal_links ul li {
  border-radius: 6px;
  display: flex;
  justify-content: center;
  align-items: center;
  width: calc(33.3% - 10px);
  box-shadow: 0 0 20px 0 rgb(0 0 0 / 14%);
  -webkit-transition: 0.4s;
  transition: 0.4s;
}
.lib_cal_links ul li.cal_links01 {
  background: url(../images/icon_kouminkan.svg) no-repeat center 20px #ffffff;
}
.lib_cal_links ul li.cal_links02 {
  background: url(../images/icon_servicecenter.svg) no-repeat center 20px #ffffff;
}
.lib_cal_links ul li.cal_links03 {
  background: url(../images/icon_opac_cal.svg) no-repeat center 20px #ffffff;
}
.lib_cal_links ul li:hover {
  box-shadow: none;
}
.lib_cal_links ul li a {
  color: #10467d;
  display: flex;
  width: 100%;
  height: 100%;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  padding: 75px 5px 4px;
}
.lib_cal_links ul li a:hover {
  text-decoration: underline;
}
.lib_cal_links ul li a .name {
  font-size: 1.5rem;
  font-weight: bold;
}
.lib_cal_links ul li a .name img {
  margin-left: 2px;
}
.lib_cal_links ul li a .txt {
  font-size: 1.4rem;
}
.lib_info {
  margin-bottom: 20px;
}
.lib_info .title {
  padding: 0 15px 7px 0;
  text-align: center;
  font-size: 2rem !important;
  margin-top: 0;
  background: transparent;
}
.lib_info .title:before {
  content: url(../images/icon_mobilib.svg);
  margin: 10px 5px;
  position: relative;
  top: 8px;
}
.lib_info .status {
  background-color: #FBD1C7;
  text-align: center;
  padding: 5px;
}
.lib_info .notice {
  text-align: center;
  padding: 5px;
}
.lib_info .list {
  padding: 5px 10px;
}
.lib_info .list li {
  list-style: none !important;
}
.lib_info .list li::before {
  content: url(../images/icon_lib_info.png);
  position: relative;
  top: 0px;
  margin-right: 5px;
}
.cancel {
  color: #d91b00;
}
.wait {
  color: #005a64;
}
.lib_info ul.link_list {
  padding-left: 15px;
}
ul.lib_info_menu {
  background-color: #FFF;
  padding: 10px;
  margin-bottom: 10px;
  border: 1px solid #ccc;
  border-top: none;
}
div#banner_area {}
div#banner_area ul.slides {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  padding: 10px 0 0;
  flex-wrap: wrap;
}
div#banner_area ul.slides li {
    margin: 10px;
    background-color: #fff8df;
    padding: 10px;
}

.editBnrList{
  padding: 0;
  margin:  1em 0 2em;
  display: flex;
  flex-wrap: wrap;
  gap:10px;
}
.editBnrList li{
  list-style: none;
  padding: 0;
  
    width:calc(100% / 2 - 10px);
  @media screen and (min-width: 769px) {
    width:calc(100% / 5 - 10px);
  }
  
}
.editBnrList li a{
  display: flex;
  align-items: center;
  width: 100%;
  background: #FFF;
  border: 1px solid #CCC;
  border-radius: 5px;
  padding: 5px;
  padding-right: 2px;
  line-height: 1.5;
}
.editBnrList li a img{
  vertical-align: middle;
}
.editBnrList li .editBnrImg{
  padding-right: 5px;
}


.koukokuBnr{
}
.koukokuBnr ul{
  margin: 0 0 3em;
  padding: 0;
}
.koukokuBnr li{
  display: inline-block;
  list-style: none;
  
  margin: .2em;
  padding: 0;
  width: auto;
}

/*  Footer
----------------------------------------------*/


.fixBtns{
  z-index: 110;
  position: fixed;
  right: 0;
  top: 200px;
}
.fixBtns ul{
  
  margin: 0;
  padding: 0;
}
.fixBtns li{
  list-style: none;
  margin-bottom: 0;
}

.fixBtns a{
  display: block;
  background: #112D6E;
  color: #FFF;
  text-decoration: none;
  font-size: 1.2rem;
  text-align: center;
  min-width: 40px;
  height: 11em;
  text-align: center;
}
.fixBtns a span{
 /* width: .5em;*/
  margin: auto;
  display: block;
  
  
  text-align: center;
@media screen and (min-width: 769px) {
  letter-spacing: .2em;
  width: 60%;
  word-break:break-all;
  
  -ms-writing-mode: tb-rl;
writing-mode: vertical-rl;
text-orientation: upright;
  }
  
}
.fixBtns a>img{
  margin-top: 5px;
}
.fixBtns a:hover{
  text-decoration: underline;
}

.fixBtns a i{
  display: block;
  width: 40px;
  height: 40px;
  margin: 0 auto;
  background: url("../images/side_login.svg") no-repeat center center ;
}

.fixBtns a{
  border: 1px solid #fff;
}
.fixBtns-line a{
  height: 12em;
  background-color: #FFF;
  color: #000;
  border: 1px solid #2D893A;
  
}


.fixBtns-line a i{
  background-image: url("../images/side_line.svg");
  margin-bottom: .5em;
}


  @media screen and (max-width: 768px) {
    body{
      padding-bottom: 3.5rem;
    }
    .fixBtns{
      border-top: 1px solid #FFF;
      top: inherit;
      bottom:0;
      width:100%;
    }
    
    .fixBtns ul{
      display: flex;
      justify-content: space-between;
    }
    .fixBtns ul li{
      width: 50%;
    }
    .fixBtns a{
      width:100%;
      padding:5px 0;
      height: auto;
      height: 4rem;
    }
    
    .fixBtns a i{
      display: inline-block;
      vertical-align: middle;
    }
    .fixBtns a span{
      display:inline-block;
    }
    
    
.fixBtns-line a i{
  width: 30px;
  height: 30px;
  background-size: 30px 30px;
  margin-right: 5px;
    }
    
  .fixBtns img{
      margin-left: 5px;
    }
    
  }



.footerbg{
  background: url("../images/footer.png") repeat-x center bottom;
  padding: 117px 5px 0;
  text-align: right;
  position: relative;
}
#kids_chi-non a{
  position: absolute;
  display: inline-block;
  bottom: -10px;
  z-index: 1;
  left:50%;
  margin-left: -80px;
}


footer {
  border-top: 3px solid #112D6F;
  text-align: center;
}
footer .container {
  margin: 0 auto;
}
footer .container a {
}
footer .container ul{
  padding:0 .5em;
  margin-left: -10px;
}
footer .container li {
  display: inline;
  color: #333;
  margin-left: 10px;
  /*  white-space: nowrap;*/
}
footer .container li::before {
  background-color: #000;
  content: "";
  display: inline-block;
  height: 7px;
  margin-right: 10px;
  position: relative;
  top: -3px;
  width: 1px;
}

footer .container li:first-child::before{
  display: none;
}
#ftr_name{
  margin-top: .5em;
  font-weight: bold;
  font-size: 1.8rem;
}
#copyright{
  padding-bottom: .5em;
}
/*----------------------------------------------------------
	お知らせ イベント
----------------------------------------------------------*/

.topnews_tit{
  position:relative;
  margin-top: 1em;
  margin-bottom: 1em;
}



.topnews_tit h2{
  margin: 0 auto;
}

.topnews_more{
  @media screen and (min-width: 769px) {
  position: absolute;
  right: 0;
  top:.5rem;
  }
}

h2.ico_news {
  background: none !important;
  padding: 0 !important;
  border-left: none !important;
  font-weight: normal !important;
  font-size: 2.8rem !important;
  margin-bottom: 0 !important;
  color: #333 !important;
  border-bottom: none !important;
  display: flex;
  flex-direction: column;
  align-items: center;
}
h2.ico_news span {
  font-size: 1.4rem !important;
  margin-top: 4px;
}
h2.ico_news span.entxt {
  font-size: 2.8rem !important;
  margin-top: 0;
}
h2.ico_news span.jptxt {
  font-size: 1.4rem !important;
  margin-top: 4px;
}
h2.ico_event {
  background: none !important;
  padding: 0 0 10px !important;
  border-left: none !important;
  font-weight: normal !important;
  font-size: 2.8rem !important;
  margin-bottom: 0 !important;
  color: #333 !important;
  border-bottom: none !important;
  display: flex;
  flex-direction: column;
  align-items: center;
}
h2.ico_event span {
  font-size: 1.4rem !important;
  margin-top: 4px;
}
h2.ico_news_imp {
  background: #ffc1b9 !important;
  border-left: 4px solid #c1321e !important;
}
h2.ico_news, h2.ico_event {
}


.newsBlock{
  padding: 0px 30px 10px;
  margin-bottom: 0;
  @media screen and (max-width: 768px) {
  padding: 0px 10px 10px;
  }
}
.newsBlock.newsBlock-important {
  margin-top: 60px;
  background: #ffe9e8;
  border-radius: 6px;
}
.newsBlock, .eventBlock {
  margin-bottom: 80px;
  position: relative;
  background: none;
}
.newsBlock ul, .eventBlock ul {
  padding: 0 1em .5em;
}
.index .eventBlock ul {
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
  justify-content: center;
}
.index .eventBlock ul li {
  padding: 0;
  width: calc(100% / 5 - 15px);
  -webkit-transition: 0.4s;
  transition: 0.4s;
  line-height: 1.8;
  margin: 10px 0;
  border: none;
}
.index .eventBlock ul li:nth-child(n+5) {
  /*display: none;*/
}
.index .eventBlock ul li a {
  text-decoration: none;
  display: grid;
  grid-template: auto 1fr / auto;
  height: 100%;
  background-color: #fff !important;
  box-shadow: 0 0 20px 0 rgb(0 0 0 / 14%);
  border-radius: 6px;
  -webkit-transition: 0.4s;
  transition: 0.4s;
  padding: 0;
  border: 1px solid #CCC;
}
.index .eventBlock ul li a:hover {
  box-shadow: none;
}
.index .eventBlock ul li .event_summary {
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  padding: 10px;
}
.index .eventBlock ul li .event_summary p, .index .eventBlock ul li .event_summary span {
  text-indent: 0;
}
.index .eventBlock ul li .event_summary .date {
  display: flex;
  flex-wrap: wrap;
}
.index .eventBlock ul li .event_summary .data {
  color: #333;
  font-weight: bold;
  width: auto;
}
.index .eventBlock ul li .event_summary .title{
  overflow: hidden;
}
.index .eventBlock ul li .event_summary .linktit {
  color: #333;
  overflow: hidden;
}
.index .eventBlock ul li:hover .event_summary .linktit {
  text-decoration: underline;
}
.index .eventBlock ul li .event_summary .icn-new {
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  border-radius: 5px;
  min-width: 2.5em;
  margin-bottom: 2px;
  margin-top: 2px;
  color: #AA4747;
  font-size: 1.4rem;
  font-weight: bold;
  padding: 2px 5px;
  text-align: center;
  display: inline-block;
}
.index .eventBlock ul li .event_summary span {
  text-decoration: none !important;
}
.index .eventBlock ul li a:hover .event_summary span {
  text-decoration: none !important;
}
.index .eventBlock ul li .event_img {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
  border-radius: 6px 6px 0 0;
  text-indent: 0;
  margin-right: 0;
  max-width: none;
}
.index .eventBlock ul li .event_img:before {
  display: block;
  content: "";
  padding-top: 56.25%;
}
.index .eventBlock ul li .event_img img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  object-position: 0 0;
}
.index .eventBlock ul li .event_img.no_thumb img {
  object-fit: none;
  object-position: unset;
  background: #d0e1f3;
}
.eventBlock th {
  width: 16%;
}


.newsBlock{
  
}

.btnList a,
.topnews_more a{
    padding: 5px 2em;
  text-decoration: none;
  background: #FFF;
  color: #000;
  border: 1px solid #000;
  display: block;
  font-weight: normal;
  margin: auto;
  text-align: center;
  width: 100%;
  max-width: 260px;
  border-radius: 50px;
  &:hover{
    text-decoration: underline;
  }
}

.newsBlock.newsBlock-important{
  background: #FEE9E8;
  border: 4px solid #700000;
}

.kids .newsBlock, .kids .eventBlock {
  background: transparent;
}
.kids .eventBlock .tab_content{
  padding: 1em;

  @media screen and (max-width: 768px) {
    padding: 1em 0;
  }
  background: #FFF;
  border: 1px solid #ccc;
  border-radius: 0 0 10px 10px;
}

.kids .eventBlock .tab_content li a{
  text-decoration: none;
}
.kids .eventBlock .tab_content li a:hover .title_area{
  text-decoration: none;
}


/*
.kids .eventBlock .btnList a {
  background: #fff !important;
  color: #2DAE8D !important;
  right: 40px !important;
}
.kids .eventBlock .btnList a:after {
  border-top: 8px solid #2DAE8D !important;
}
*/
.kids .newsBlock dt p.data, .eventBlock dt p.data {
  width: 13em;
}
p.no-data {
  padding: 0 .5em 1em;
}
/*
.newsBlock .btnList a:hover, .eventBlock .btnList a:hover {
  border: 2px;
}
*/
.newsBlock ul, .eventBlock ul {
  padding: 0;
  list-style: none;
  margin-top: 0;
}
.index .newsBlock ul, .index .eventBlock ul {
  padding: 0;
}
.newsBlock.detail_page ul, .eventBlock.detail_page ul, .newsBlock.detail_page ol, .eventBlock.detail_page ol {
  padding: 1em 1.5em;
}
.newsBlock ul li, .eventBlock ul li {
  list-style: none;
}
.newsBlock ul li p{
  margin: 0;
}

.newsBlock.detail_page ul li, .eventBlock.detail_page ul li {
  border: none;
  list-style: disc;
}
.newsBlock.detail_page ol li, .eventBlock.detail_page ol li {
  border: none;
  list-style: decimal;
}
.index .newsBlock ul li:last-child, .index .eventBlock ul li:last-child {
  border: none;
}
.newsBlock ul li a, .eventBlock ul li a {
  display: flex;
  padding-bottom: .8em;
  padding-top: .8em;
}
.newsBlock ul li a{
  text-decoration: none;
}

.newsBlock .tab_content ul li a{
  text-decoration: none;
  
}


.newsBlock ul.link_list li, .eventBlock ul.link_list li {
  border: none;
}
.newsBlock ul.link_list li a, .eventBlock ul.link_list li a {
  padding: 0;
  display: inline-block;
  text-decoration: underline;
}
.newsBlock ul.link_list li a:hover, .eventBlock ul.link_list li a:hover {
  text-decoration: none;
}
.eventBlock ul li .event_img {
  position: relative;
  width: 100%;
  max-width: 150px;
  height: 100%;
  overflow: hidden;
  border-radius: 0;
  text-indent: 0;
  margin-right: 30px;
}
.eventBlock ul li .event_img:before {
  display: block;
  content: "";
  padding-top: 56.25%;
}
.eventBlock ul li .event_img img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  object-position: 0 0;
}
.eventBlock ul li .event_img.no_thumb img {
  object-fit: none;
  object-position: unset;
  background: #d0e1f3;
}
.eventBlock ul li .event_summary {
  display: flex;
  flex-direction: column;
}
#contentsBox .eventBlock ul li .event_summary .name {
  margin-top: 10px;
}
.newsBlock ul li .data, .eventBlock ul li .data {
  width: 340px;
  margin-bottom: 0;
}
.newsBlock ul li .data .date, .eventBlock ul li .data .date {
  font-weight: bold;
  font-size: 1.6rem;
  text-decoration: none;
  color: #333;
}
.newsBlock ul li a .name {
  width: calc(100% - 340px);
  font-size: 1.6rem;
  color: #333;
}
.newsBlock ul li a:hover .name, .eventBlock ul li a:hover .name {
  text-decoration: none;
}
.newsBlock dl, .eventBlock dl {
  padding: 0;
  overflow: hidden;
  line-height: 1.8;
  font-size: 1.6rem;
  display: flex;
  flex-wrap: wrap;
}
.newsBlock dl:last-child, .eventBlock dl:last-child, .newsBlock_imp dl:last-child, .eventBlock_imp dl:last-child {
  border: none;
}
.newsBlock_imp dl, .eventBlock_imp dl {
  padding: 10px 0px;
  overflow: hidden;
  line-height: 1.8;
  font-size: 1.6rem;
  border-bottom: 1px solid #ccc;
  background-color: #FDE9E7;
}
.newsBlock dt, .eventBlock dt {
  background: none;
  margin-bottom: 0;
  font-weight: bold;
  /*  width: 40%;*/
  width: 290px;
  display: flex;
  padding-bottom: 1em;
  padding-top: 1em;
  border-bottom: 1px solid #4A4A4A;
}
.newsBlock dt p.data, .eventBlock dt p.data {
  font-size: 100%;
  margin-right: 15px;
}
.newsBlock span.title:hover, .eventBlock span.title:hover {
  text-decoration: none;
}
.newsBlock span.title, .eventBlock span.title {
  font-size: 1.6rem;
  text-decoration: underline;
  text-align: left;
}
.newsBlock span, .eventBlock span {
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  border-radius: 5px;
  font-size: 1.4rem;
  text-align: center;
  min-width: 2.5em;
  margin-bottom: 2px;
  margin-top: 2px;
 /* display: inline-flex;*/
}

.kids .eventBlock span.data{
  text-align: left;
}
.kids .eventBlock span.title_area span{
  display: initial;
}
.kids .eventBlock span.title_area{
  display: initial;
  text-align: left;
}
span.icn-no {
  display: none;
}
span.ic_eve, span.ic_gn, span.ic_bn, span.ic_pl, span.ic_bl, span.ic_pk, span.ic_rd, span.ic_ye, span.ic_bk{
  font-size: 1.2rem !important;
  font-weight: normal;
  border-radius: 4px;
  white-space: nowrap !important;
  color: #fff;
  padding: .2em .5em;
  height: 2em;
  margin-left: 5px;
  text-decoration: none;
}
span.ic_eve {
  background: #005a64;
}
span.ic_gn {
  background: #258600;
}
span.ic_bn {
  background: #A76425;
}
span.ic_pl {
  background: #650086;
}
span.ic_bl {
  background: #004986;
}
span.ic_pk {
  background: #A4005B;
}
span.ic_rd {
  background: #A40000;
}
span.ic_ye {
  background: #68610a;
}
span.ic_bk {
  background: #555555;
}
/*タブ改修追加ここから*/
.eventBlock .tab_area .tab_content {
  display: none !important;
}
.eventBlock .tab_area .tab_content[aria-hidden=false] {
  display: block !important;
}
/*タブ改修追加ここまで*/
/*
.newsBlock .btnList a, .eventBlock .btnList a, #contentsBox .newsBlock .btnList a, #contentsBox .eventBlock .btnList a {
  padding: 5px;
  background: #10467D;
  color: #FFF;
  text-decoration: none;
  display: block;
  font-weight: normal;
  margin: 20px auto;
  text-align: center;
  width: 100%;
  max-width: 260px;
  border-radius: 6px;
}
.newsBlock .btnList a:hover, .eventBlock .btnList a:hover {
  text-decoration: underline;
}
*/

.eventBlock .tab_nav {
  display: flex;
  gap:3px;
  margin: 10px 0px 0;
  border-bottom: 2px solid #112D6F;
}
.eventBlock .tab_nav .tab_switch:focus{
  box-shadow: none;
}

.eventBlock .tab_nav .tab_switch {
  display: block;
  text-align: center;
  color: #333;
  text-decoration: none;
  font-size: 1.6rem;
  padding: 10px 3px;
  width: 25%;
  border: none;
  line-height: 1.8;
  background-color: #FFF;
  cursor: pointer;
  border-radius: 6px 6px 0 0;
  border: 1px solid #ccc;
  font-weight: bold;
  @media screen and (max-width: 768px) {
  font-size: 1.4rem;
  }
}
.eventBlock .tab_nav .tab_switch.active {
  background-color: #112D6F;
  color: #FFF;
}
.eventBlock .tab_area .tab_content {
  display: none !important;
}
.eventBlock .tab_area .tab_content[aria-hidden=false] {
  display: block !important;
}
.newsBlock dd {
  margin: 0;
  padding-bottom: 20px;
  padding-top: 1em;
  width: calc(100% - 290px);
  border-bottom: 1px solid #4A4A4A;
}
.newsBlock dt:nth-last-child(2), .newsBlock dd:last-child {
  border-bottom: none;
}
.newsBlock dd a {
  color: #333;
}
#inner_wrap .box_c .newsBlock dd {
  margin: 0;
}
#inner_wrap .box_c .newsBlock .news_text + .news_link, #inner_wrap .box_c .newsBlock .news2_text + .news2_link {
  margin-top: 20px;
}
.eventBlock dd {
  margin: 0;
  padding-bottom: 20px;
}
#inner_wrap .box_c .eventBlock dd {
  margin: 0;
}
.newsBlock span.icn-important, .eventBlock span.icn-important {
  background: #AA4747;
  color: #fff;
  font-size: 1.2rem;
  font-weight: normal;
  border-radius: 4px;
  white-space: nowrap !important;
  height: 2em;
  margin-left: 5px;
  padding: 0em .5em .2em;
}
.newsBlock span.icn-new, .eventBlock span.icn-new {
  color: #AA4747;
  font-size: 1.4rem;
  font-weight: bold;
  padding: 2px 5px;
  text-align: center;
  display: inline-block;
}
.newsBlock span.icn-no, .eventBlock span.icn-no {
  display: none;
}
.newsBlock caption, .eventBlock caption, .contentsBlock caption {
  line-height: 0;
  text-indent: -9999px;
}
.newsBlock table.tbl, .eventBlock table.tbl {
  margin: 20px 0 40px;
  width: 100%;
  border-top: 1px solid #ccc;
  border-left: 1px solid #ccc;
}
.newsBlock table.tbl th, .eventBlock table.tbl th {
  font-weight: bold;
  padding: 8px 6px 8px 6px;
  background: #ffe3b9;
  border-bottom: 1px solid #ccc;
  border-right: 1px solid #ccc;
  font-size: inherit;
  min-width: 14%;
  vertical-align: top;
}
.newsBlock table.tbl td, .eventBlock table.tbl td {
  font-weight: normal;
  padding: 3px 8px;
  background-color: #fff;
  border-right: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
  font-size: inherit;
}
.newsBlock table.tbl td .link_list li, .eventBlock table.tbl td .link_list li {
  font-size: 1.6rem;
  margin-left: 1em;
  border-bottom: none !important;
  padding: 0 0 0 5px !important;
}
.newsArea_page, .news2Area_page, .gaiyouArea_page, .sakuhinArea_page {
  overflow: hidden;
  padding: 10px 0;
  text-align: right;
}
.newsArea_page .newsArea_pagenum a, .news2Area_page .newsArea_pagenum a {
  color: #333;
}
.news_link, .news2_link, .news_file {
  margin: 0;
  padding: 0;
  list-style: none !important;
  padding-left: 26px;
  background: url(../images/icon_list01.svg) no-repeat;
  background-size: 16px;
  text-indent: 0;
  background-position: top 0.35em left;
}
.news_link a::before, .news2_link a::before, .news_file a::before {
  content: none;
}
.contentIn {
  background: #fff;
  padding: 20px;
}
.contentIn #contents {
  padding: 1em;
}
.flow {
  margin: 0px;
}
.flow li {
  float: left;
  white-space: nowrap;
  font-size: 1.6rem;
}
/* =========================================================
eventArea
========================================================= */
#eventarea {
  padding-top: 20px;
  margin-bottom: 20px;
}
#eventarea table {
  width: 100%;
  border-bottom: #ccc solid 1px;
  padding-bottom: 15px;
  margin-bottom: 15px;
  line-height: 1.8;
}
#eventarea th {
  font-weight: bold;
  text-align: left;
  width: 16%;
}
#eventarea td.icon {
  width: 10%;
  text-align: left;
}
#eventarea td img {
  vertical-align: -0.25em;
  margin-left: 5px;
}
#eventarea td .event_end {
  color: #F52124;
  font-weight: bold;
  margin-left: 10px;
}
/*---------- index ----------*/
.index .eventTitle {
  background: none;
  padding: 0px;
  color: #fff;
  position: relative;
  margin-top: 0px;
  margin-bottom: 0px;
  width: 480px;
}
.index .eventTitle .more {
  position: absolute;
  right: 10px;
  top: 10px;
}
.index #eventarea {
  clear: both;
  padding: 20px 10px 10px 10px;
  margin-bottom: 20px !important;
  background-color: #fff;
}
.index #eventarea table {
  width: 100%;
  border-bottom: #ccc solid 1px;
  padding-bottom: 15px;
  margin-bottom: 15px;
  line-height: 1.8;
}
.index #eventarea th {
  font-weight: bold;
  text-align: left;
  width: 33%;
}
.index #eventarea td.icon {
  width: 15%;
  text-align: left;
}
.index #eventarea td img {
  vertical-align: -0.25em;
  margin-left: 5px;
}
.event_end {
  color: #F52124;
  font-weight: bold;
  margin-left: 10px;
}
#news_day, #news2_day {
  color: #1F733A;
  font-weight: bold;
  margin: 10px 10px 10px 10px;
}
#news_title {
  background: url(../images/icon_news.svg) no-repeat left top #F7FCE6;
  width: 685px;
  padding: 10px 0 6px 15px;
  font-size: 2.0rem;
  border-bottom: #CBE8B5 solid 1px;
  color: #333;
  font-weight: bold;
  margin-top: 10px;
  margin-bottom: 20px;
  clear: both;
}
.news_text {
  margin-bottom: 0;
}
.t-style01 caption {
  text-align: center;
  background-color: #357166;
  color: #fff;
  padding: 5px;
  font-weight: bold;
}
.t-style01 caption.none {
  display: none;
}
.t-style01, .event_tblbox {
  line-height: 1.8;
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 15px;
}
.t-style01 th, .event_tblbox th {
  border-top: #aaa 1px dotted;
  border-bottom: #aaa 1px dotted;
  border-left: #aaa 1px dotted;
  border-right: #aaa 1px dotted;
  text-align: left;
  background: #f0f7fd;
  padding: 10px;
  font-weight: bold;
}
.event_tblbox th {
  width: 12%;
  text-align: center;
  letter-spacing: 0.1em;
}
.t-style01 td, .event_tblbox td {
  border-top: #aaa 1px dotted;
  border-bottom: #aaa 1px dotted;
  border-right: #ccc 1px solid;
  text-align: left;
  padding: 0 5px;
}
.t-style01 .head01, .event_tblbox .head01 {
  text-align: center;
  background: #0068b6;
  color: #fff;
  font-weight: bold;
  padding: 5px !important;
  line-height: 1.0;
}
/*---------- index ----------*/
.t-style02 {
  line-height: 1.8;
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 15px;
  text-align: center;
}
.t-style02 caption {
  text-align: center;
  background-color: #357166;
  color: #fff;
  padding: 5px;
  font-weight: bold;
}
.t-style02 caption.none {
  display: none;
}
.t-style02 th {
  border-left: #aaa 1px dotted;
  border-bottom: #aaa 1px dotted;
  border-top: #277948 3px solid;
  border-right: #aaa 1px dotted;
  text-align: left;
  background: #f0f7fd;
  padding: 10px;
  font-weight: bold;
}
.t-style02 td {
  border-top: #aaa 1px dotted;
  border-bottom: #aaa 1px dotted;
  border-right: #ccc 1px solid;
  border-left: #ccc 1px solid;
  text-align: left;
  padding: 10px;
  background: #fff;
}
.t-style02 .head01 {
  text-align: center;
  background: #0068b6;
  color: #fff;
  font-weight: bold;
  padding: 5px !important;
  line-height: 1.0;
}
.info_list {
  display: grid;
  grid-auto-rows: 1fr;
  grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr;
  grid-template-rows: 1fr;
  gap: 10px;
  height: 100%;
}
.info_list li a {
  display: grid;
  box-sizing: border-box;
  height: 100%;
  color: #333;
  background-color: #e3f0c7;
  border: 2px solid #fff;
  padding: 2.5em 0.5em;
  font-size: 1.8rem;
  font-weight: bold;
  line-height: 1.8;
  text-align: center;
  text-decoration: none;
  place-items: center;
  position: relative;
}
.info_list li a span {
  font-weight: normal;
  font-size: 1.4rem;
}
.info_list li a img {
  position: absolute;
  right: 0.5em;
  bottom: 0.5em;
}
.facilityBox{
  @media screen and (min-width: 769px) {
      display: table;
    width: 100%;
  }
}
.facilityBox-pic{
    text-align: center;
  @media screen and (min-width: 769px) {
      display: table-cell;
    width: 300px;
    vertical-align: top;
    padding: 0 10px 0 0;
  }
}
.facilityBox-data {
  @media screen and (min-width: 769px) {
    display: table-cell;
    vertical-align: top;
  }
  }

#map_canvas iframe{
  width: 100%;
}

.list_L{
  padding-left: 0;
  font-size: 2.4rem;
@media screen and (max-width: 768px) {
    font-size: 1.8rem;
  }
}
.list_L li{
  list-style: none;
  margin-bottom: .5em;
}
.list_L li a{
  border: 1px solid #ccc;
  display: block;
  padding: .5em ;
  padding-left: 2em;
  border-radius: 5px;
  position: relative;
}
.list_L li a:before {
  content: '';
  width: 22px;
  height: 22px;
  background: #2575BE;
  border-radius: 50%;
  position: absolute;
  top: 0;
  left: 12px;
  bottom: 0;
  margin: auto;
}
.list_L li a:after {
  content: '';
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 6px 0 6px 8px;
  border-color: transparent transparent transparent #fff;
  position: absolute;
  top: 0;
  left: 20px;
  bottom: 0;
  margin: auto;
}
.apple_wrap{
  font-size: 120%;
}
.adbanner_foot{
}





/* =========================================================
osusume
========================================================= */
#ya_osusume {
  margin-bottom: 80px;
  position: relative;
}
#ya_osusume {
  margin-bottom: 40px;
  position: relative;
}
#ya_osusume h2.ico_osusume {
  background: none;
  border: none;
  padding: 0 !important;
  font-weight: normal !important;
  font-size: 2.8rem !important;
  color: #333 !important;
  border-bottom: none !important;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 0;
}
#ya_osusume h2.ico_osusume span {
  font-size: 1.4rem !important;
  margin-top: 4px;
}
.kidsosusumetop {
  margin-bottom: 50px;
  position: relative;
}
.kidsosusumetop .booklistbox {
  margin-top: 1em;
}
.kidsosusumetop p.books_title {
  margin-bottom: 0 !important;
}
#ya_osusume .booklist .open, #ya_osusume .booklist .open, .kidsosusumetop .booklist .open {
  display: flex;
  justify-content: space-between;
  padding: 0;
  align-items: stretch;
  margin: 10px 0 0;
}
#ya_osusume .booklist .open li, .kidsosusumetop .booklist .open li {
  text-align: center;
  flex: 1 0 auto;
  justify-content: center;
  margin: 0;
}
#ya_osusume .booklist .open li {
  text-align: center;
  justify-content: center;
  margin: 0;
}
#ya_osusume .booklist .open li a, #ya_osusume .booklist .open li a, .kidsosusumetop .booklist .open li a {
  color: #333;
  text-decoration: none;
  padding: 20px 30px;
  display: grid;
  grid-template-rows: repeat(1, auto auto 1fr);
  height: 100%;
  justify-content: center;
  /*background: #fff;*/
  position: relative;
  -webkit-transition: 0.4s;
  transition: 0.4s;
}
#ya_osusume .booklist .open li a {
  padding: 20px;
}
#ya_osusume .booklist .open li a:hover, #ya_osusume .booklist .open li a:hover, .kidsosusumetop .booklist .open li a:hover {
  border-radius: 6px;
  box-shadow: 0 0 20px 0 rgb(0 0 0 / 14%);
  z-index: 5;
}
#ya_osusume .booklist .open li a:focus, #ya_osusume .booklist .open li a:focus, .kidsosusumetop .booklist .open li a:focus {
  z-index: 5;
}
#ya_osusume .booklist .open li p.books_title, #ya_osusume .booklist .open li p.books_title, .kidsosusumetop .booklist .open li p.books_title {
  font-size: 1.6rem;
  font-weight: normal;
  border: none;
  margin: 10px 0 0;
}
#ya_osusume .booklist .open li:hover p.books_title, #ya_osusume .booklist .open li:hover p.books_title, .kidsosusumetop .booklist .open li:hover p.books_title {
  text-decoration: underline;
}
div#booklist .title {
  background-color: #ebf9ef;
  padding: 5px 10px;
}
/*
#ya_osusume .btnList a, #ya_osusume .btnList a {
  padding: 5px;
  background: #10467D;
  color: #FFF;
  text-decoration: none;
  display: block;
  font-weight: normal;
  margin: 20px auto;
  text-align: center;
  width: 100%;
  max-width: 260px;
  border-radius: 6px;
}
#ya_osusume .btnList a:hover, #ya_osusume .btnList a:hover {
  text-decoration: underline;
}
*/
.booksWrap {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 1em;
  padding: 0 1em 1em;
  background: #fff;
}
#ya_osusume .booksWrap, #ya_osusume .booksWrap {
  border: none;
  display: block;
  margin: 0 0 50px;
  padding: 0;
  background: none;
  width: calc(100% / 6);
  height: auto;
  position: relative;
}
#ya_osusume .booksWrap img, #ya_osusume .booksWrap img {
  display: block;
  width: auto;
  height: 180px;
  /*object-fit: cover;　縦長固定*/
  object-fit: contain;
  object-position: center;
  margin: 0 auto .5em;
}
p.books_title {
  padding: 0 .5em;
  font-size: 2.0rem;
  margin-bottom: 1em;
  color: #3e1a09;
  font-weight: bold;
  border-bottom: #3e1a09 dotted 1px;
  width: 100%;
  border-left: none;
}
p.books-opac {
  text-align: center;
  display: block;
  background: #10467d;
  color: #ffffff;
  text-decoration: none;
  margin-top: 0.5em;
  padding: 0.5em 0;
  border-radius: 5px;
  text-decoration: none !important;
}
.kidsosusumetop .booksWrap {
  margin-bottom: 0;
  width: 100%;
  height: auto;
  position: relative;
  border-left: none;
}
.kidsosusumetop .booksWrap img {
  display: block;
  width: auto;
  height: 180px;
  object-fit: cover;
  object-position: center;
  margin: 0 auto .5em;
}
dl dd .booksWrap:last-child {
  border: none;
}
ul.booklist {
  display: flex;
  flex-direction: column;
}
.booksL {
  width: 25%;
  vertical-align: top;
  padding-right: 5%;
  text-align: center;
}
.booksL .bookthumb {
  max-height: 200px;
}
.booksL .sp {
  display: none !important;
}
.booksR {
  width: 68%;
  vertical-align: top;
}
.books_subtitle {
  font-size: 1.4rem;
  margin-left: 1em;
}
.booksR p {
  padding: 0 0 0 10px;
  position: relative;
  margin-bottom: 0.3em !important;
}
a.books-opac {
  text-align: center;
  display: block;
  background: #a7c36c;
  color: #333;
  text-decoration: none;
  margin-top: 0.5em;
  padding: 0.2em 0;
  border-radius: 5px;
}
ul.book_list li {
  float: left;
  margin-right: 10px;
  width: 140px;
  font-size: 1.4rem;
}
ul.book_list img {
  margin-bottom: 10px;
}
/*  ya
----------------------------------------------*/

/*lightbox*/

  .lb-image {    
      @media screen and (min-width: 769px) {
        max-width: 900px !important;   /* 横幅600pxまで */
        max-height: 900px !important;  /* 高さ400pxまで */
        width: auto !important;
        height: auto !important;
      }
  }


.ya .logo{
  text-align: center;
  background: none!important;
}

.teens_lead{
  text-align: center;
  font-weight: bold;
  padding:0 1em;
@media screen and (min-width: 769px) {
  font-size: 2.4rem;
  }
  margin-bottom: 1em;
}

.ya #contentsBox {
@media screen and (min-width: 769px) {
  padding-bottom: 120px;
  }
}
.ya #contentsBox .ya_h1 a {
  display: block;
  line-height: 0;
}
.ya #inner_wrap {
  background: #FFFEF5;
}
.ya_index #inner_wrap{
  background:#FFFEF5 url(../images/ya/teen_topbg.png) no-repeat center top 1170px;
}
.ya #inner_wrap .logo{
  @media screen and (max-width: 768px) { 
  background:#FFFEF5 url(../images/ya/ya_bg.png) no-repeat center bottom!important;
  background-size: 100% auto!important;
 
    padding:10px!important;
  }
}

.ya .logo img{
@media screen and (max-width: 768px) { 
  max-width: 50%;
  }
}

.ya #kidsmenu_box .search_area {
  width: 100%;
  max-width: 260px;
  background: #fff;
  padding: 0 20px 20px;
  margin-bottom: 40px;
}
.ya #kidsmenu_box .search_area .title {
  background: #10467d;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px 20px;
  margin: 0 -20px 20px;
}
.ya #kidsmenu_box .search_area .title span {
  display: flex;
  min-height: 32px;
  background: url(../images/ya/icon_search.svg) no-repeat center left;
  background-size: 32px;
  align-items: center;
  color: #fff;
  font-weight: bold;
  font-size: 2.0rem;
  padding-left: 40px;
}

.ya_book{
  background: #F4E841;
  padding-bottom: 1em;
}
.ya_book .btnList{
  display: none;
}
.ya_search_title{
  text-align: right;
  margin-bottom: 0;
  @media screen and (max-width: 768px) {
  padding-right: 1em;
  }
}
.ya_serach_area{
  max-width: 750px;
  margin:  0 auto;
}
.ya_search_tit{
  color: #003070;
  font-size: 2.6rem;
  font-weight: bold;
  display: inline-block;
  width: 170px;
  padding-right:.5em;
  box-sizing: border-box;
  
  @media screen and (max-width: 768px) {
    width:100%;
  }
}
.ya_search_tit label::before{
  content: url("../images/ic_search.svg");
  vertical-align: middle;
  margin-right: 5px;
}

.ya.ya_index #inner_wrap .h2,
.ya.ya_index #inner_wrap h2,
.ya.ya_index #inner_wrap h2.ico_news{
  background: none;
  border: 0;
  padding: 0;
  font-weight: bold;
  font-size: 3.2rem;
  text-align: center;
  color: #003070!important;
  margin-top: 2em;
}
.booklistbox{
}


.ya-menu{
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  padding: 0;
  margin: 2.5em 0 2em 0;
  font-size: 2.6rem;
  @media screen and (max-width: 768px) {
    gap: 15px;
    font-size: 1.8rem;
  }
}
.ya-menu li{
  padding: 0;
  margin: 0;
  list-style: none;
  width: calc(100% / 2 - 15px);
  @media screen and (min-width: 769px) {
  width: calc(100% / 3 - 20px);
  }
}
.ya-menu li a{
  display: block;
  display: flex;
  height: 100%;
  align-items: center;
  justify-content: center;
  border: 2px solid #003070;
  text-align: center;
  padding: .8em 1em;
  background: #FFF;
  text-decoration: none;
  @media screen and (min-width: 769px) {
  }
}
.ya-menu li a:hover{
  text-decoration: underline;
}
.ya-menu li{
  z-index: 1;
  position: relative;
}
.ya-menu li::after {
  content: "";
  position: absolute;
  top: 4px;   /* 下にずらす */
  left: 4px;  /* 右にずらす */
  width: 100%;
  height: 100%;
  display: inline-block;
  border: 2px solid #003070;
  background: #F4E841;
  
  z-index: -1; /* 背面に置く */
}
.ya-menu li:nth-of-type(2)::after,
.ya-menu li:nth-of-type(4)::after,
.ya-menu li:nth-of-type(9)::after{
  background: #3D6EB8;
  
}
.ya-menu li:nth-of-type(3)::after,
.ya-menu li:nth-of-type(5)::after,
.ya-menu li:nth-of-type(7)::after{
  background: #57B6E4;
  
}

.ya_news .newsBlock ul{
  background: #FFF;
  border: 2px solid #003070;
  margin-top: 1em;
  @media screen and (min-width: 769px) {
  padding: 10px 20px;
  }
}

.ya .footerbg{
  background: none;
  padding: 0;
  
  @media screen and (min-width: 769px) {
    margin-top: -120px;
  }
}


/*
.ya .btnList a, .ya #contentsBox .btnList a {
background: #f5f784;
    padding: 6px 10px;
    display: block;
    text-align: center;
    color: #222;
    text-decoration: none;
    border-radius: 0;
}
.ya .btnList a img, .ya #contentsBox .btnList a img {
  margin-left: 2px;
}
.ya .btnList a:hover, .ya #contentsBox .btnList a:hover {
  text-decoration: underline;
}
*/
.ya #kidsmenu_box .search_area .btnList {
  margin-top: 20px;
}
.ya .lib_area {
  margin: 0;
  list-style: none;
  width: 100%;
  max-width: 260px;
  padding: 0 5px;
}
.ya .lib_area li {
  list-style: none;
  max-width: 250px;
  margin: 20px 0 0;
}
.ya .lib_area li a {
  background: #10467d;
  display: block;
  color: #fff;
  text-decoration: none;
}
.ya .lib_area li a:hover {
  text-decoration: underline;
}
.ya .lib_area li a span {
  display: block;
  color: #fff;
  background: url(../images/ya/icon_arrow.svg) no-repeat center right 20px;
  padding: 11px 40px 11px 20px;
}
.ya .lib_area li a img {
  margin-left: 2px;
}
.ya .contentIn {
  padding: 0;
  background: none;
}
.ya #inner_wrap h1 {
  border: none;
  margin-top: 20px;
  position: relative;
  background: #F8E531;
  color: #003070;
  font-size: 3.2rem;
  padding: .5em;
}
.ya:not(.ya_index) #inner_wrap h1:after {
  display: none;
}
.ya:not(.ya_index) #inner_wrap h2 {
  border: 0;
  background: none;
  border-bottom:5px solid #F8E531;
  padding: 12px 0px;
  position: relative;
  margin-top: 30px;
  margin-bottom: 25px;
  line-height: 1.8;
  position: relative;
}
.ya:not(.ya_index) #inner_wrap h2::after{
  content: "";
  width: 100%;
  background: #3FA9E0;
  height: 5px;
  display: block;
  position: absolute;
  left: 0px;
  bottom: 0px;
    /*transform: rotate(-0.2deg);*/
}

.ya #inner_wrap h2.ico_news {
}
.ya #inner_wrap h2 .entxt {
  display: none;
}
.ya #inner_wrap h2 .jptxt {
  margin: 0;
  font-size: 2.0rem !important;
  display: block;
  text-align: left;
}
/*.ya #inner_wrap h2:before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 15px solid transparent;
  border-left: 15px solid transparent;
  border-top: 15px solid #1C53A3;
  border-bottom: 0;
  position: absolute;
  bottom: -15px;
}*/
.ya #inner_wrap h3 {
  border: 0;
  padding: 0;
}
.ya #inner_wrap h3::before{
  content: "■";
  color: #3FA9E0;
  margin-right: .3em;
}
.ya #inner_wrap h4 {
  border-bottom: solid 2px #0078C0;
  padding: .2em 0;
  font-size: 1.7rem;
}
.ya #inner_wrap h4:after {
  content: none;
}
.ya #inner_wrap h5 {
  color: #1c54a5;
}
.ya table caption {
  background: -moz-linear-gradient(left, #0054A5, #003F7B);
  background: -webkit-linear-gradient(left, #0054A5, #003F7B);
  background: linear-gradient(to right, #0054A5, #003F7B);
}
.ya table th {
  background: #ecf4ff;
}
.ya_index #inner_wrap h1 {
  margin-top: 0;
  padding: 0 !important;
}
.ya_index #inner_wrap h1:after {
  content: none;
}
.ya_index #inner_wrap .contents_area > :first-child {
  margin-top: 0;
}
.ya_index .ya_search {
  margin-bottom: 20px;
}
.ya_index .ya_search fieldset {
  display: flex;
  
@media screen and (max-width: 768px) {
  flex-wrap: wrap;
  padding:0 1em;
  margin-top:-2em;
  }
  
}
.ya_index .ya_search .search_field {
  width: auto;
  width: calc(100% - 120px - 120px);
  border: 2px solid #112D6F;
  border-radius: 0;  
  @media screen and (max-width: 768px) {
    width: calc(100% - 120px);
  }
}
.ya_index .ya_search button {
  background: #112D6F;
  color: #fff;
  width: 120px;
  min-width: 120px;
  border: none;
  min-height: 40px;
  cursor: pointer;
  font-size: 2rem;
}
.ya_index .ya_search button img {
  margin-left: 2px;
}
.ya_newbook .booksWrap {
  background: none;
}
#booklist_all .ya_newbook ul li .book_content .book_content_R .books_contents {
  
}



/*
#booklist_all .ya_newbook ul li .book_content .btnList a {
  background: #f5f784;
  border-radius: 0;
}
*/
/*  利用案内
----------------------------------------------*/
.guide_list {
  padding-bottom: 10px;
  border-bottom: #ccc dotted 1px;
  margin-bottom: 20px;
}
.guide_list li {
  margin-right: 20px;
  background: url(../images/icon_list.svg) no-repeat center left;
  padding-left: 20px;
}
/*  館内案内
----------------------------------------------*/
.sub_box .gbtn a {
  position: relative;
  top: 6px;
  right: 6px;
  padding: .5em 1em .5em 2em;
  background: #1d7a00;
  color: #fff;
  text-decoration: none;
  display: block;
  font-weight: normal;
  border-radius: 20px;
  margin-top: 4px;
  margin-right: 2px;
}
.sub_box .gbtn a::after {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  left: 8px;
  width: 0;
  height: 0;
  margin: -4px 0 0 0;
  border-top: 8px solid #fff;
  border-left: 8px solid transparent;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
.info_tab {
  border-bottom: 1px solid #FFC159;
}
.info_tab a {
  text-decoration: none;
  color: #333333;
  display: block;
}
.info_tab li.active {
  background-color: #FFC159;
  font-weight: bold;
}
.info_tab li {
  padding: .2rem;
  background-color: #FFFDE1;
  border-top-right-radius: .5rem;
  border-top-left-radius: .5rem;
  border: 1px solid #FFC159;
  width: 32%;
  margin-right: .5%;
  display: inline-block;
  border-bottom: none;
  font-size: 1.8rem;
}
.tab-pane:first-child .tab-pane-header {
  border-top-left-radius: 0;
}
.floor_detail::after {
  clear: both;
  content: ".";
  display: block;
  height: 0;
  visibility: hidden;
}
.floor_detail {
  margin: 20px 0 0;
}
.floor_detail li.map_detail01, .floor_detail li.map_detail02 {
  float: left;
  margin: 0 0 0 2%;
  padding: 0 0 20px;
  width: 48%;
  line-height: 1.8;
  font-size: 1.5rem;
}
.floor_detail li dt {
  color: #21773c;
  font-size: 1.8rem;
  font-weight: bold;
  padding: 10px 0;
}
#map {
  margin-bottom: 20px;
  position: relative;
  padding-bottom: 56.25%;
  padding-top: 30px;
  height: 0;
  overflow: hidden;
}
#map iframe, #map object, #map embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
details, summary {
  display: none !important;
}
/*Clear Float*/
.floor_detail:after {
  content: ".";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
}
.floor_detail_01 {
  zoom: 1;
}
.floormap_img {
  text-align: center;
  margin: 20px 0;
}
/*  サイトマップ
----------------------------------------------*/
ul#sitemap_list li a {
  margin-left: 20px;
  padding: 3px 0 5px 10px;
  line-height: 2;
  font-size: 116%;
}
ul#sitemap_list li a::before {
  content: url("../images/icon_list.svg");
  margin-right: 10px;
  position: relative;
  top: 2px;
}
ul#sitemap_list li.d2 {
  padding-top: 3px;
  text-indent: 2em;
}
/*  こどもページ
----------------------------------------------*/
body.kids {
  background-image: none;
}
.kids #contentsBox {
  margin-bottom: 60px;
}
.kids #inner_wrap {
  background: linear-gradient(to bottom, #E5F9FF, #FFF);
  padding-top: 20px;
}
.kids #inner_wrap_in {
  /*
  background-size: 1344px auto;
  background-position: top center;
  padding-bottom: 160px;*/
}
.kids footer {
  margin: 0;
}
.kids #inner_wrap .container {
  position: relative;
  z-index: 5;
}
/*
.kids .btnList a {
  border-radius: 200px;
}
*/
.kids .kids_serach_area {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.kids .sp {
  display: none !important;
}
body.kids h1.logo {
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
  text-align: center;
}
body.kids h1.logo img {
}
#kidsmenu_box .lib_area li {
  margin-bottom: 10px;
}
.kids .index_menu li a img, .kids .lib_area li a img {
  vertical-align: top;
  -webkit-transform: rotate(0);
  transform: rotate(0);
  -webkit-transition: .1s ease-in-out;
  transition: .1s ease-in-out;
  /*  height: 220px;*/
}
.kids .index_menu li a:hover img, .kids .lib_area li a:hover img {
  -webkit-transform: rotate(-3deg);
  transform: rotate(-3deg);
}
.kids .contentIn {
  background: none;
  padding: 20px 0 0;
}
.kids h2.ico_news, .kids p.ico_event {
  margin: 0 !important;
}
.kids h2.ico_event {
  margin-bottom: 0 !important;
  padding-top: .3em !important;
}
.kids h2.ico_event::before {
  content: none !important;
}
.kids div.kids_h1 {
  text-align: center;
}
.kids #contentsBox div.kids_h1 {
  padding-left: 0;
  margin-bottom: 20px;
}
.kids #contentsBox div.kids_h1 a {
  display: block;
  line-height: 0;
}
.kids div.kids_h1::before {
  content: none !important;
  margin-right: 0px;
  position: static;
}
.kids #inner_wrap h1, .kids .eventBlock p.title_bar {
  
}
.kids #inner_wrap h1::before {
  content: none;
}
/*.kids #inner_wrap #eventarea h2::before, .kids #inner_wrap h2.pen::before {
  content: none;
}*/
.kids #inner_wrap #eventarea h2, .kids .contents_area .title, .kids #inner_wrap h2.pen, .kids #inner_wrap h3 {}
.kids #inner_wrap h1 {
  font-size: 3.2rem;
  margin: .3em 0 1em;
}
.kids h2 {
  border: 0;
  background: #CFE8B4;
  position: relative;
  padding: .5em 65px .5em 20px;
  border-radius: 10px;
  font-size: 2.4rem;
}
.kids h2::after{
  content:url("../images/kids/kids_h2.png");
  position: absolute;
  right: -10px;
  bottom: -10px;
}
.kids h3 {
  border: 0;
  border-left: #456A96 solid 6px;
  font-size: 2rem;
  padding: .1em .5em;
  
}
.kids h3::before{
  display: none;
}

.kids h4 {
  border-bottom:dotted 3px #456A96;
  font-size: 1.8rem;
  padding: .2em;
}
.kids h4:after {
  display: none;
}
.kids .container ul.link_list li, .kids .container ul.txt_list li {
  background: url(../images/kids/kids_icon_list01.svg) no-repeat;
  background-size: 12px;
  background-position: top 0.5em left;
}
.kids .contents_area {
  min-height: 350px;
}
.kids #eventarea {
  padding: 0;
  margin-bottom: 0;
}
.kids .footer_area {
  clear: both;
  height: 17px;
}
.kids .introduction_area {
  margin-top: 30px;
}




.kids_search {
  padding: 2em 0 2em;

}
.kids_search_title {
  text-align: center;
  font-weight: bold;
  color: #333;
  margin-bottom: 10px;
  font-size: 1.6rem;
}
.kids_search label{
  display: flex;
  align-items:center;
}

.kids_search .search_field {
  height: 40px;
  width: 70%;
  float: left;
  background-color: #FFF;
  border: 1px solid #2575BE;
  border-radius: 40px 0 0 40px;
}
.kids_search .search_field::placeholder {
  color: #666666;
}
.kids_search .search_btn {
  border: 0 none;
  cursor: pointer;
  display: block;
  float: left;
  height: 40px;
  line-height: 0;
  overflow: hidden;
  padding: 0 !important;
  width: 30%;
  color: #fff;
  margin: -24px !important;
  vertical-align: middle;
  padding-left: 30px;
  background: #2575BE;
  border-radius:40px;
  font-weight: bold !important;
}
.kids_search .search_btn img {
  margin-left: 2px;
}
.kids ul.index_menu {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  margin: 20px 0px 40px;
  padding: 0;
  gap: 40px;
}
.kids ul.index_menu li {
  display: flex;
}

.kids_btn_more{
  text-align: center;
  
}


.kids_btn_more ul{
@media screen and (min-width: 769px) {
  display: flex;
  justify-content: center;
  gap:10px;
  }
}

.kids_btn_more ul li{
  list-style: none;
  margin-bottom: 1em;
}
.kids_btn_more a{
  display: inline-block;
  padding: .8em 2em;
  background: #2575BE;
  color: #FFF;
  border-radius: 40px;
  text-decoration: none;
}
.kids_btn_more a:hover{
text-decoration: underline;
}

/*
.newsBlockKids .btnList a {
  background: #c9eefd !important;
  color: #333;
}
.newsBlockKids .btnList a:after {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  left: 2px;
  width: 0;
  height: 0;
  margin: -3px 0 0 0;
  border-top: 8px solid #fff;
  border-left: 8px solid transparent;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
.newsBlockKids .btnList a:hover {
  background-color: #566313;
}
*/

ul.kids_txt_list {
  margin: 15px 0;
}
ul.kids_txt_list li {
  margin-bottom: 6px;
  padding: 2px 0 0 1.5em;
  text-indent: -1.5em;
}
ul.kids_txt_list li::before {
  content: url(../images/icon_txt_list.svg);
  position: relative;
  top: 2px;
  margin-right: 10px;
}
.kids_btn {}
.kids_btn a {
  padding: 5px;
  background: #10467D;
  color: #FFF;
  text-decoration: none;
  display: block;
  font-weight: normal;
  margin: 20px auto;
  text-align: center;
  width: 100%;
  max-width: 280px;
  border-radius: 200px;
  line-height: 2;
}
.kids_btn a:hover {
  /*  opacity: 0.8;*/
  text-decoration: underline;
}
.kids .booksL {
  display: table-cell;
  width: 25%;
  vertical-align: top;
  padding-right: 5%;
  text-align: center;
}
.kids .booksL img {
  width: 174px;
  height: auto;
}
.booksR .sp {
  display: none !important;
}
.kids .booksR {
  display: table-cell;
  width: 68%;
  vertical-align: top;
}
.kids .booksR .books_title {
  font-size: 2.0rem;
  font-weight: bold;
}
.kids .booksR .books_subtitle {
  font-size: 1.8rem;
  font-weight: bold;
}
.kids .booksR p {
  margin-top: 0 !important;
  margin-bottom: 0.5em !important;
}
.kids a.books-opac {
  text-align: center;
  display: block;
  background: #A5D850;
  color: #333;
  text-decoration: none;
  margin-top: 0.5em;
  padding: 10px 0;
  border-radius: 5px;
}
.kids ul.book_list li {
  float: left;
  margin-right: 10px;
  width: 140px;
  font-size: 1.4rem;
}
.kids ul.book_list img {
  margin-bottom: 10px;
}
.kids .footer_area {
  clear: both;
}
.kids .t-style01 th, .child .t-style02 th, .kids .event_tblbox th {
  border-top: #aaa 1px dotted;
  border-bottom: #aaa 1px dotted;
  border-left: #aaa 1px dotted;
  border-right: #aaa 1px dotted;
  text-align: left;
  background: #fff;
  padding: 10px;
  font-weight: bold;
}
.kids .event_tblbox th {
  width: 14% !important;
  text-align: center !important;
  letter-spacing: 0.1em;
}
.kids .t-style01 td, .kids .event_tblbox td {
  border-top: #aaa 1px dotted;
  border-bottom: #aaa 1px dotted;
  border-right: #ccc 1px solid;
  text-align: left;
  padding: 10px;
  background: #fff;
}
.kids .t-style01 .head01, .kids .event_tblbox .head01 {
  text-align: center;
  background: #0068b6;
  color: #fff;
  font-weight: bold;
  padding: 5px !important;
  line-height: 1.0;
}
.kids #kidsmenu_box .lib_area {
  margin: 0;
  padding: 0;
}
.kids #kidsmenu_box .lib_area li {
  list-style: none;
  margin-bottom: 20px;
  max-width: 260px;
}
.kids #kidsmenu_box .lib_area li a {
  display: block;
}
.kids .lib_area li a img {
  height: auto;
}
/*よくある質問
----------------------------------------------*/
.faq_box {
  margin-bottom: 5em;
}
.faq_box dl {
  margin-bottom: 2em;
  border: 1px solid #ccc;
}
.faq_box dl dt {
  position: relative;
  padding: 0.5em 0.5em 0.5em 4em;
  background: #eff6fc;
  font-weight: bold;
  font-size: 1.6rem;
}
.faq_box dl dt span {
  width: 30px;
  height: 30px;
  text-align: center;
  position: absolute;
  top: 0.5em;
  left: 1.2em;
  border: 1px solid #ffffff;
  background-color: #10467D;
  color: #fff;
  padding-top: 0;
  border-radius: 5px;
  font-weight: bold;
  line-height: 1.8;
}
.faq_box dl dd {
  position: relative;
  padding: 1.5em 1.5em 1.5em 4em;
  font-size: 1.6rem;
}
.faq_box dl dd span.answer {
  width: 30px;
  height: 30px;
  text-align: center;
  position: absolute;
  top: 1.5em;
  left: 1.2em;
  border: 1px solid #10467D;
  color: #10467D;
  padding-top: 0;
  border-radius: 5px;
  font-weight: bold;
  line-height: 1.8;
} 


/*  etc
----------------------------------------------*/
/*  icon　*/
a.btn {
  color: #fff;
  text-decoration: none;
  background-color: #008093;
  border-radius: 50px;
}
a:hover.btn {
  background-color: #0f6d7b;
}
/*  icon　*/
.arrow {
  position: relative;
  padding: 0 0 0 6px;
  vertical-align: middle;
  font-size: 1.6rem;
}
.arrow-up.icon {
  color: #333;
  position: absolute;
  margin-left: 10px;
  margin-top: 3px;
  width: 1px;
  height: 16px;
  background-color: currentColor;
}
.arrow-up.icon:before {
  content: '';
  position: absolute;
  left: -5px;
  top: 1px;
  width: 10px;
  height: 10px;
  border-top: solid 1px currentColor;
  border-right: solid 1px currentColor;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
/*table*/
table {
  border-top: 1px solid #ccc;
  border-left: 1px solid #ccc;
  margin:0 auto 1.5em auto;
  width: 99%;
}
table span {
  font-weight: normal;
}
table th {
  font-weight: bold;
  padding: 10px;
  background: #f0f7fd;
  border-bottom: 1px solid #ccc;
  border-right: 1px solid #ccc;
  font-size: inherit;
  min-width: 15%;
  text-align: left;
  vertical-align: middle;
}
table td {
  font-weight: normal;
  padding: 10px;
  background-color: #fff;
  border-right: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
  font-size: inherit;
  vertical-align: middle;
  line-height: 1.8;
}
th.number {
  width: 7% !important;
  min-width: 7% !important;
}
.pagetop {
  background-color: transparent;
  padding: 0;
  border: none;
  
  cursor: pointer;
  line-height: 0;
  border: 2px solid #FFF;
}
.pagetop a {
  text-decoration: none;
  color: #fff;
}
.spotlight-group img, .spl-pane img {
  pointer-events: none;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-touch-callout: none;
  -moz-user-select: none;
  user-select: none;
}
.header_search .tab_area .tab_content {
  display: none !important;
  line-height: 1.8;
}
.header_search .tab_area .tab_content a {
  display: block;
  margin-bottom: 10px;
  text-align: left;
  color: #333;
}
.header_search .tab_area .tab_content a img {
  margin-left: 2px;
}
.header_search .tab_area .tab_content[aria-hidden=false] {
  display: block !important;
}
.top_btn_area {
  display: flex;
  gap: 26px;
  margin: 80px 0;
}
.top_btn_area .btn_search {
  width: calc(100% / 4);
}
.top_btn_area .btn_right {
  display: flex;
  flex-wrap: wrap;
  gap: 26px;
  width: calc(75% - 26px);
  justify-content: space-between;
}
.top_btn_area .btn_right div {
  width: calc(100% / 3 - 17.33333px);
}
.top_btn_area .btn_search a, .top_btn_area .btn_right div a {
  border-radius: 6px;
  box-shadow: 0 0 20px 0 rgb(0 0 0 / 14%);
  -webkit-transition: 0.4s;
  transition: 0.4s;
  display: flex;
  width: 100%;
  height: 100%;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  padding: 78px 5px 4px;
  color: #333;
  font-weight: bold;
  font-size: 2.0rem;
}
.top_btn_area .btn_search a:hover, .top_btn_area .btn_right div a:hover {
  box-shadow: none;
  text-decoration: underline;
}
.top_btn_area .btn_search a {
  background: url(../images/icon_btns_search.svg) no-repeat center 60px #fff;
  padding: 4px 5px;
  padding-top: calc(50% - 3em);
}
.top_btn_area .btn_guide a {
  background: url(../images/icon_btns_guide.svg) no-repeat center 20px #fff;
}
.top_btn_area .btn_mypage a {
  background: url(../images/icon_btns_mypage.svg) no-repeat center 20px #fff;
}
.top_btn_area .btn_facility a {
  background: url(../images/icon_btns_facility.svg) no-repeat center 20px #fff;
}
.top_btn_area .btn_kidspage a {
  background: url(../images/icon_btns_kids.svg) no-repeat center 20px #fff;
}
.top_btn_area .btn_yapage a {
  background: url(../images/icon_btns_ya.svg) no-repeat center 20px #fff;
}
.top_btn_area .btn_denshi a {
  background: url(../images/icon_btns_denshi.svg) no-repeat center 20px #fff;
}
.top_btn_area .btn_search a img, .top_btn_area .btn_right div a img {
  margin-left: 2px;
}
.library_layout {
  display: flex;
  gap: 24px;
  flex-wrap: wrap;
  margin: 80px 0;
}
.search_panel {
  flex: 1 1 600px;
  background-color: #f5f5f5;
  padding: 16px;
}
.mobile_library_content {
  flex: 2 1 300px;
  background-color: #f5f5f5;
  padding: 16px;
}
.info_area {
  display: flex;
  justify-content: space-between;
}
.info_area .information {
  margin-right: 40px;
/*  width: calc(100% - 390px);*/
  width: calc(100% - 0px);
  background: #d0e1f3;
  border: 6px;
  padding: 30px 20px;
}
.info_area .information h2 {
  margin: 0 0 30px;
  background: none;
  border: none;
  font-size: 2.8rem !important;
  padding: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.info_area .information h2 span {
  font-size: 1.4rem !important;
  margin-top: 4px;
}
.info_area .information .links {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  padding: 0;
}
.info_area .information .links li {
  width: calc(50% - 10px);
  display: grid;
}
.info_area .information .links li a {
  background: #FFF;
  border-radius: 6px;
  display: flex;
  align-items: center;
  color: #10467D;
  text-decoration: none;
  padding: 16px 10px;
  padding-left: 64px;
  font-size: 1.8rem;
  min-height: 90px;
}
.info_area .information .links li a:hover {
  text-decoration: underline;
}
.info_area .information .links li.info a {
  background: url(../images/icon_info_info.svg) no-repeat left 10px center #FFF;
}
.info_area .information .links li.dayori a {
  background: url(../images/icon_info_dayori.svg) no-repeat left 10px center #FFF;
}
.info_area .information .links li.ad a {
  background: url(../images/icon_info_ad.svg) no-repeat left 10px center #FFF;
}
.info_area .information .links li.vol a {
  background: url(../images/icon_info_vol.svg) no-repeat left 10px center #FFF;
}
.info_area .information .links li.yt a {
  background: url(../images/icon_info_youtube.svg) no-repeat left 10px center #FFF;
}
.info_area .information .links li.contact a {
  background: url(../images/icon_info_mail.svg) no-repeat left 10px center #FFF;
}
.info_area .information .links li.info .name span {
  display: block;
  font-size: 1.4rem;
}
.info_area .X_area {
  overflow: hidden;
}
.info_area .X_area .title {
  padding-left: 40px;
  background: url(../images/icon_X.png) no-repeat left center;
  background-size: 30px;
  font-size: 2.2rem;
  font-weight: bold;
  margin-bottom: 10px;
}
.access_area {
  position: relative;
  margin: 80px 0;
  min-height: 450px;
}
.access_area .container:before, .access_area .container:after {
  content: none;
}
.access_area .txt_area {
  width: 300px;
  position: relative;
  z-index: 10;
  margin-right: -300px;
}
.access_area .txt_area h2 {
  margin: 0 0 30px;
  background: none;
  border: none;
  font-size: 2.8rem !important;
  padding: 0;
  display: flex;
  flex-direction: column;
}
.access_area .txt_area h2 span {
  font-size: 1.4rem !important;
  margin-top: 4px;
}
.access_area .txt_area p {
  margin-bottom: 0.8em;
}
.access_area .txt_area p.name {
  font-weight: bold;
  font-size: 1.8rem;
}
.access_area .txt_area .line_bnr {
  margin-top: 1.5em;
  display: block;
  line-height: 0;
}
.access_area .map_area {
  border: 1px solid #CCC;
}
.access_area .map_area .map_area_inner {
  line-height: 0;
}
.map_area_inner iframe{
  width: 100%;
}

.newsBlock.detail_page #news_day, .newsBlock.detail_page #news2_day, .eventBlock.detail_page #news_day, .eventBlock.detail_page #news2_day {
  margin: 0 0 10px;
  color: #333;
}
#inner_wrap .detail_page h1.ico_news, #inner_wrap .detail_page h1.ico_event {
  margin-bottom: 30px;
}
.eventBlock.detail_page .eyecatch {
  width: 40%;
  margin: 10px auto;
}
.box_acc {
  margin-top: 16px;
}
.box_acc .js-Toggle {
  width: 100%;
  border: none;
  display: flex;
  align-items: center;
  color: #fff;
  background: #517862;
  justify-content: flex-start;
  padding: 12px 46px 12px 12px;
  cursor: pointer;
  font-weight: bold;
  position: relative;
  text-align: left;
}
.box_acc .Toggle_content {
  display: none;
  padding: 10px;
  background: #f0f7fd;
}
.box_acc .js-Toggle .icon_btn_open {
  display: block;
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
}
.box_acc .js-Toggle .icon_btn_close {
  display: none;
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
}
.box_acc.is-open .js-Toggle .icon_btn_open {
  display: none;
}
.box_acc.is-open .js-Toggle .icon_btn_close {
  display: block;
}
.faq_area .box_acc .js-Toggle {
  padding-left: 3em;
}
.faq_area .box_acc .js-Toggle:before {
  content: "Q";
  display: inline-block;
  width: 1em;
  height: 1em;
  position: absolute;
  left: 10px;
  font-size: 2.4rem;
}
/*  おすすめ本（新着図書）
----------------------------------------------*/
#booklist_all ul {
  margin: 0;
  padding: 0;
}
#booklist_all ul li {
  padding: 0;
  display: block;
  margin-bottom: 2em;
}
#booklist_all ul li h2 {
  margin: 0;
}
#booklist_all ul li .sub {
  font-size: 1.6rem;
  margin-left: 1em;
}
#booklist_all ul li .book_content {
  display: flex;
}
#booklist_all ul li .book_content .book_content_L {
  width: calc(25% + 20px);
  text-align: center;
  margin-top: 20px;
  margin-right: 20px;
}
#booklist_all ul li .book_content .book_content_L .book_thumb {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 1em;
}
#booklist_all ul li .book_content .book_content_L .book_thumb img {
  max-height: 200px;
  width: auto;
  max-width: none;
}

/*
#booklist_all ul li .book_content .btnList a {
  background: #10467D;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 6px;
  padding: 4px 0;
  max-width: 180px;
  margin: 20px auto 0;
  text-decoration: none;
}
#booklist_all ul li .book_content .btnList a:hover {
  text-decoration: underline;
}
*/

#booklist_all ul li .book_content .book_content_R {
  width: calc(75% - 20px);
  margin-top: 20px;
}
#booklist_all ul li .book_content .book_content_R > *:first-child {
  margin-top: 0;
}
#booklist_all ul li .book_content .book_content_R .books_contents {
  margin: 20px 0 0;

  padding: 20px;
}
/*  文字色
----------------------------------------------*/
span.color1, span.kids_color1, span.ya_color1 {
  color: #cc0000;
  font-weight: bold;
  margin: 0 !important;
  padding: 0 !important;
  font-size: 1.6rem !important;
}
span.color2, span.kids_color2, span.ya_color2 {
  color: #005a64;
  font-weight: bold;
  margin: 0 !important;
  padding: 0 !important;
  font-size: 1.6rem !important;
}
/* レイアウト調整用スタイル
----------------------------------------------*/
.clear {
  clear: both;
  overflow: hidden;
}
.clearLeft {
  clear: left;
}
.clearRight {
  clear: right;
}
/* text */
.redTxt {
  color: #bd1700;
}
.greenTxt {
  color: #276279;
}
.lh01 {
  line-height: 1;
}
.lh02 {
  line-height: 1.1;
}
.lh03 {
  line-height: 1.2;
}
.lh04 {
  line-height: 1.3;
}
.lh05 {
  line-height: 1.4;
}
.lh06 {
  line-height: 1.5;
}
.lh07 {
  line-height: 1.6;
}
.lh08 {
  line-height: 1.7;
}
.lh09 {
  line-height: 1.8;
}
.lh10 {
  line-height: 1.9;
}
.lh11 {
  line-height: 2;
}
.blt {
  font-weight: bold;
}
.nlt {
  font-weight: normal;
}
.capt {
  font-size: 1.5rem;
}
.mint {
  font-size: 1.6rem !important;
  color: #333 !important;
}
.bigt {
  font-size: 1.8rem;
}
.alignl {
  text-align: left;
}
.TAC, .alignc {
  text-align: center !important;
}
.alignr {
  text-align: right;
}
.valignt {
  vertical-align: top;
}
.valignm {
  vertical-align: middle;
}
.valignb {
  vertical-align: bottom;
}
.FL, .fleft {
  float: left;
}
.FR, .fright {
  float: right;
}
.pcFR{
  @media screen and (max-width: 768px) {
    float:none;
  }
}

/* width */
.w-5 {
  width: 5% !important;
}
.w-10 {
  width: 10% !important;
}
.w-15 {
  width: 15% !important;
}
.w-20 {
  width: 20% !important;
}
.w-25 {
  width: 25% !important;
}
.w-30 {
  width: 30% !important;
}
.w-35 {
  width: 35% !important;
}
.w-40 {
  width: 40% !important;
}
.w-45 {
  width: 45% !important;
}
.w-50 {
  width: 50% !important;
}
.w-55 {
  width: 55% !important;
}
.w-60 {
  width: 60% !important;
}
.w-65 {
  width: 65% !important;
}
.w-70 {
  width: 70% !important;
}
.w-75 {
  width: 75% !important;
}
.w-80 {
  width: 80% !important;
}
.w-85 {
  width: 85% !important;
}
.w-90 {
  width: 90% !important;
}
.w-95 {
  width: 95% !important;
}
.w-100 {
  width: 100% !important;
}
.m0auto {
  margin: 0 auto !important;
}
.mt0 {
  margin-top: 0px !important;
}
.mb0 {
  margin-bottom: 0px !important;
}
.mt10 {
  margin-top: 10px !important;
}
.mr10 {
  margin-right: 10px !important;
}
.mb10 {
  margin-bottom: 10px !important;
}
.ml10 {
  margin-left: 10px !important;
}
.mt20 {
  margin-top: 20px !important;
}
.mr20 {
  margin-right: 20px !important;
}
.mb20 {
  margin-bottom: 20px !important;
}
.ml20 {
  margin-left: 20px !important;
}
.mt30 {
  margin-top: 30px !important;
}
.mr30 {
  margin-right: 30px !important;
}
.mb30 {
  margin-bottom: 30px !important;
}
.ml30 {
  margin-left: 30px !important;
}
.mt40 {
  margin-top: 40px !important;
}
.mr40 {
  margin-right: 40px !important;
}
.mb40 {
  margin-bottom: 40px !important;
}
.ml40 {
  margin-left: 40px !important;
}
.mt50 {
  margin-top: 50px !important;
}
.mr50 {
  margin-right: 50px !important;
}
.mb50 {
  margin-bottom: 50px !important;
}
.ml50 {
  margin-left: 50px !important;
}
.mt60 {
  margin-top: 60px !important;
}
.mr60 {
  margin-right: 60px !important;
}
.mb60 {
  margin-bottom: 60px !important;
}
.ml60 {
  margin-left: 60px !important;
}
.mt70 {
  margin-top: 70px !important;
}
.mr70 {
  margin-right: 70px !important;
}
.mb70 {
  margin-bottom: 70px !important;
}
.ml70 {
  margin-left: 70px !important;
}
.ml80 {
  margin-left: 80px !important;
}
.ml100 {
  margin-left: 100px !important;
}
/* form
----------------------------------------------*/
.contact_form dt, .contact dt {
  border-bottom: 2px solid #10467d;
  font-size: 120%;
  font-weight: bold;
  margin: .25em 0 .25em;
}
.contact_form input[type=text], .contact_form textarea, .contact input[type=text], .contact textarea {
  background: #fff;
  border: solid 1px #cccccc;
  border-radius: 2px;
  box-sizing: border-box;
  display: inline-block;
  font-size: 16px;
  font-weight: 300;
  height: 38px;
  outline: 0;
  margin: .5em 0;
  padding: 3px 10px;
  transition: background-color .1s linear;
  width: 70%;
}
.contact_form select, .contact select {
  background: #fff;
  border: solid 1px #cccccc;
  border-radius: 2px;
  box-sizing: border-box;
  display: inline-block;
  font-size: 16px;
  font-weight: 300;
  height: 38px;
  outline: 0;
  margin: .5em 0;
  padding: 3px 10px;
  width: 30%;
  cursor: pointer;
  background-image: url("../images/icon_select.svg");
  background-position: right 10px center;
  background-repeat: no-repeat;
  background-size: 13px 13px;
}
.btn {
  display: inline-block;
  cursor: pointer;
  width: 100%;
  max-width: 30%;
  color: #fff;
  border: 2px solid #10467d;
  background: #10467d;
  padding: 1em 2em;
  font-weight: bold;
  text-decoration: none;
  text-align: center;
}
.btn:hover {
  color: #10467d !important;
  background: #fff !important;
  border: 2px solid #10467d;
}
.err {
  color: #c1321e !important;
}
/* 管理画面　修正・設定等ボタンスタイル
----------------------------------------------*/
#library_admin form[method="post"] button, #library_admin form[method="post"] input[type="submit"], #library_admin form[method="post"] input[type="button"] {
  font-family: 'Lucida Grande', 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', メイリオ, Meiryo\9;
  font-weight: normal;
  font-size: 1em;
  -webkit-appearance: none;
  -webkit-font-smoothing: antialiased;
  margin: 10px 0;
  cursor: pointer;
  border-style: none;
  padding: 5px;
}
#library_admin form[method="post"] button:hover, #library_admin form[method="post"] input:hover {
  filter: saturate(150%);
  border: 2px;
}
#library_admin form[method="post"] {
  max-width: 980px;
  margin: 0 auto;
}
/*公開後　指示により削除*/
header .nav_upper .nav_upper_sns ul li:last-child, .access_area .txt_area .line_bnr {
  display: none;
}
/*　アーカイブページ調整用　*/
.archiveArea .booksWrap {
  display: inline-block;
}
.contentsArea {
  display: flex;
}
.contentsArea .booksL {
  width: 25%;
  vertical-align: top;
  padding-right: 5%;
  text-align: center;
}
.contentsArea .booksR {
  width: 68%;
  vertical-align: top;
}