@charset "utf-8";
@media only screen and (min-width: 767px) and (max-width: 768px) {
  body {
    min-width: 100%;
  }
  .container {
    min-width: 100%;
  }
  #contentsBox, .md-1, .md-2, .md-3, .md-4, .md-5, .md-6, .md-7, .md-8, .md-9, .md-10, .md-11, .md-12, nav#gnavi .container ul {
    width: 100%;
  }
  .banner_area li {
    width: 49.3%;
  }
  /*  #sp_navi_box {
    display: block !important;
  }*/
}
@media screen and (max-width: 768px) {
	body{
	  font-size: 1.4rem;
	}
	body.isTop{
    background-position: top 40px center;
    background-size: 130% auto;
	}
  .col {
    min-height: 1px;
    position: relative;
    padding-left: 0px !important;
    padding-right: 0px !important;
  }
  /* header */
  header {
    min-width: 100%;
    /*    padding-top: 10px;*/
    border-radius: 0 0 20px 20px;
  -webkit-transition: 0.4s;
  transition: 0.4s;
  }
	header.open {
    border-radius: 0;
	}
  header .container {
    padding: 0 !important;
    margin: 0 auto;
    text-align: center;
    height: 100%;
  }
  header .character, #header_search, .search_link_btn {
    display: none;
  }
header .md-8 {
    padding: 0;
}
  /* navi */
  #sp_menu {
        display: flex;
    position: relative;
    /* height: 40px; */
  }
	#sp_navi_login{
    display: block;
    width: 100%;
    text-align: center;
        margin-left: 0.5em;
	}
	#sp_navi_login a{
	}
  #sp_navi {
    display: block;
    /*    position: absolute;
    top: 0;
    right: 0;*/
    width: 100%;
    text-align: center;
        margin-left: 0.5em;
  }
  #panel-btn {
    border: none;
    -webkit-font-smoothing: initial;
  }
  #sp_navi_txt {
    display: block;
    position: absolute;
    top: 5px;
    left: 20px;
    z-index: 100;
    font-weight: bold;
    pointer-events: none;
    color: #fff;
  }
  #sp_navi_txt::before {
    content: "メニューを開く";
  }
  #sp_navi_txt.open {
    left: 20px;
  }
  #sp_navi_txt.open::before {
    content: "メニューを閉じる";
  }
	#sp_navi_login a{
    display: flex;
    flex-direction: column;
    min-width: 58px;
    align-items: center;
    color: #333;
    text-decoration: none;
	}
	#sp_navi_login img{
    height: 21px;
        margin: 6px 0 3px;
	}
	#sp_navi_login_label{
    font-size: 1.2rem;
    line-height: 1;
	}
  header .container .row {
        justify-content: space-between;
        padding: 4px 10px;
    position: relative;
  }
	header .container .row:before,
	header .container .col:before,
	header .container .row:after,
	header .container .col:after {
		content: none;
	}
  h1#header_logo, p#header_logo {
    position: static;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: 0;
    padding: 0;
    font-size: 100%;
	line-height: 1.8;
  }
	h1#header_logo, p#header_logo a{
    display: block;
    line-height: 0;
        text-align: left;
	}
  #header_logo img {
        height: 34px;
        width: auto;
    padding-top: 0;
  }
	header .container .col{
    position: static;
    padding: 0;
    width: auto;
	}
  #sp_navi_box {
    display: none;
    overflow: hidden;
    position: absolute;
    left: 0;
    z-index: 150;
	background: #fff;
    overflow-y: scroll;
    width: 100vw;
  }
	header .nav_upper{
    flex-direction: column;
    align-items: center;
    justify-content: center;
        padding: 1.5em 10px;
	}
	header .nav_upper .nav_upper_links{
        margin-bottom: 1.5em;
	}
	header .nav_upper .nav_upper_links ul a{
        font-size: 1.6rem;
	}
	#btn_h_search {
        margin-left: 0.5em;
}
	#btn_h_search img{
    max-width: 48px;
	}
  /*slide*/
	.flex-viewport{
    max-width: none;
	}
  .slidewrap {
    width: 100%;
    float: none;
    height: auto;
    margin-bottom: 0px;
  }
  .flex-control-nav {
    display: none;
  }
  .flexslider {
    text-align: center !important;
	      margin: 0 0 40px !important;
  }
	.flexslider .slides{
    margin-left: 0 !important;
	}
	.flexslider .slides > li{
    margin-left: 0 !important;
	}
	.custom_nav_number span{
    margin-right: 2em !important;
    font-size: 1.6rem !important;
	}
	.flex-pauseplay{
    width: 20px !important;
    height: 20px !important;
	}
	.flex-pauseplay a{
    width: 20px !important;
    height: 20px !important;
    background-size: 100% !important;
	}
	.flex-direction-nav{
    height: 20px !important;
	}
	.flex-direction-nav .flex-prev,
	.flex-direction-nav .flex-next{
    width: 16.5px !important;
    height: 20px !important;
    background-size: 100% !important;
    margin-top: -32px;
	}
	.swiper_control{
    margin: 0 auto;
    max-width: 80%;
	}
	
	.swiper-button-prev, .swiper-button-next{
        width: 26px;
        height: 26px;
    margin-top: -20px;
	}
	.swiper_control .btn_center{
    font-size: 1.4rem;
	}
	.slider_control_btn.stop .icon_stop:before,
	.slider_control_btn.start .icon_start:before{
        width: 22px;
        height: 15px;
        background-size: 22px;
	}
	.swiper-pagination-bullet{
    width: 12px;
    height: 4px;
    margin: 0 .2em;
	}
	.swiper-slide{
    margin-bottom: 10px;
	}
	.swiper-button-prev{
    left: 0;
}
.swiper-button-next{
    right: 0;
}
  /*navi*/
  nav#gnavi {
    min-width: 100%;
  }
  nav#gnavi .container {
    padding: 0;
  }
  nav#gnavi ul {
    width: 100% !important;
    flex-direction: column;
  }
  nav#gnavi .container li:first-child {
    border-left: none;
  }
  nav#gnavi .container li[id^="gnav"] > a {
    width: 100%;
    height: auto;
        padding: 0.75em 5px 0.75em 10px;
    margin-top: 0;
    font-size: 100% !important;
    border-bottom: 1px solid #9F918A;
    justify-content: left;
    line-height: 1.5;
  }
	nav#gnavi .container li[id^="gnav"]:last-child > a{
    border-bottom: none;
	}
  nav#gnavi li {
    float: none;
    width: 100%;
    background-color: #fff;
  }
  nav#gnavi .container li {
    text-align: left;
    height: auto;
    border-left: none;
    border-right: none;
  }
  nav#gnavi .container li, nav#gnavi .container li a, nav#gnavi .container li a:hover, nav#gnavi .container li a.current {
    background-image: none !important;
  }
  nav#gnavi .container li#gnav1 a:before, nav#gnavi .container li#gnav2 a:before, nav#gnavi .container li#gnav3 a:before, nav#gnavi .container li#gnav4 a:before, nav#gnavi .container li#gnav5 a:before, nav#gnavi .container li#gnav6 a:before {
    content: none;
  }
  nav#gnavi .container li#gnav6, nav#gnavi .container li#gnav7 {
    display: block;
  }
  nav#gnavi .container li#gnav6 img, nav#gnavi .container li#gnav7 img {
    display: inline-block;
  }
  nav#gnavi li span.hide {
    display: block;
    font-size: 1.6rem;
  }
  nav#gnavi ul li img {
    display: none;
  }
	nav#gnavi ul #gnav2 img {
		display: block;
	}
  nav#gnavi li a {
    display: block;
    position: relative;
    padding: 10px 25px 10px 10px;
    border-bottom: 1px solid #D9D9D6;
    background: #fff;
    color: #566313;
    font-size: 1.4rem;
    font-weight: bold;
    text-decoration: none;
  }
  nav#gnavi li:hover {
    background: #efefef;
  }
	#sp_navi_login{
    display: block;
    width: 100%;
    text-align: center;
    margin-left: 1em;
	}
	#sp_navi_login a{
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    width: 100%;
    background: none;
    color: #222;
    text-decoration: none;
    min-width: 40px;
    height: 100%;
    justify-content: center;
	}
	#sp_navi_login a img{
        height: 19px;
        margin: 2px 0 2px;
	}
	#sp_navi_login_label{
    font-size: 0.9rem;
    line-height: 1;
    margin-top: 0.2em;
	}
  nav#gnavi li:nth-child(odd) a {}
  #panel-btn {
    /*    display: inline-block;
    position: relative;
    width: 100%;
    height: 40px;
    border: 1px solid #F6F6F6;
    background: #F6F6F6;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;*/
  }
  #panel-btn {
    display: flex;
        flex-direction: column;
    align-items: center;
    position: relative;
    width: 100%;
        padding: 15px 0 5px;
    background: none;
    color: #222;
    text-decoration: none;
        min-width: 40px;
  }

	#panel-btn #sp_navi_label{
        font-size: 0.9rem;
        line-height: 1;
        margin-top: 1.4em;
	}
  #panel-btn-icon {
    display: block;
        position: relative;
    top: 50%;
    width: 18px;
    height: 2px;
    background: #EF7C39;
    transition: .2s;
  }
  #panel-btn-icon:before, #panel-btn-icon:after {
    display: block;
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 18px;
    height: 2px;
    background: #EF7C39;
    transition: .3s;
  }
  #panel-btn-icon:before {
    margin-top: -8px;
  }
  #panel-btn-icon:after {
    margin-top: 6px;
  }
  #panel-btn .close {
    background: transparent;
  }
  #panel-btn .close:before, #panel-btn .close:after {
    margin-top: 0;
  }
  #panel-btn .close:before {
    transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg);
  }
  #panel-btn .close:after {
    transform: rotate(-135deg);
    -webkit-transform: rotate(-135deg);
  }
  ul.topicpath {
    width: 100%;
    margin: 0 0 10px;
    background: #efefef;
  }
  #sp_navi_box .js-navCloseToggle {
    width: 100%;
    border: none;
    display: block;
        padding: 0.75em 10px;
        border-bottom: 2px solid #9f918a;
        color: #222;
        margin-top: 20px;
  }
  #sp_navi_box .js-navCloseToggle span {
    position: relative;
    padding-left: 20px;
    line-height: 1;
        color: #333;
  }
  #sp_navi_box .js-navCloseToggle span:before {
    display: block;
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 14px;
    height: 2px;
    background: #000;
    transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg);
    margin-top: -1px;
  }
  #sp_navi_box .js-navCloseToggle span:after {
    display: block;
    display: block;
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 14px;
    height: 2px;
    background: #000;
    transform: rotate(-135deg);
    -webkit-transform: rotate(-135deg);
    margin-top: -1px;
  }
  /* opac navi*/
  #sp_opac_navi {
    display: block;
    z-index: 9999;
    margin-top: 20px;
  }
  #sp_opac_navi ul {
    margin: 10px;
    border: 1px solid #999;
    border-radius: 5px;
    background-color: #f4feff;
  }
  #sp_opac_navi ul:after {
    content: "";
    display: block;
    clear: both;
  }
  #sp_opac_navi ul li {
    list-style: none;
    float: left;
    width: 50%;
    min-width: 130px;
    height: 45px;
    line-height: 45px;
    border-right: 1px solid #999;
    border-bottom: 1px solid #999;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
  }
  .box_l #bookSearch {
    display: none;
  }
  #sp_opac_navi ul li:nth-child(even) {
    border-right: none;
  }
  #sp_opac_navi ul li:nth-last-child(1), #sp_opac_navi ul li:nth-last-of-type(2) {
    border-bottom: none;
  }
  #sp_opac_navi ul li:nth-last-of-type(2):nth-child(even) {
    border-bottom: 1px solid #999;
  }
  #sp_opac_navi ul li a {
    display: block;
    padding-left: 15px;
    height: 45px;
    color: #566313;
    font-weight: bold;
    font-size: 1.4rem;
  }
  #spForm {
    width: 100%;
    height: 3em;
    margin: 0 auto 1em;
  }
	
	#inner_wrap h1{
    font-size: 2.2rem;
    width: calc(100% + 20px);
    margin-left: -10px;
    background-size: auto 6px;
	}
	h2{
    font-size: 1.8rem;
	}
	h3{
    font-size: 1.6rem;
	}
	h5{
    font-size: 1.6rem;
	}
	.faq_box dl dt,
	.faq_box dl dd{
    font-size: 1.4rem;
	}
	
  /* index */
  #honbun_btn, .design_control, .searchBlock, .sidemenu, .libLink, nav#sp {
    display: none;
  }
  #top_wrap .container {
    width: 100%;
    padding: 0 !important;
    margin-bottom: -80px;
  }
  #main_visual .container {
    padding: 0;
  }
  #main_visual {
    margin: 0;
    padding: 0;
    height: auto;
  }
  #mainVisual .txt_greeting {
    right: 10px;
  }
	.lib_cal_area{
    padding: 0 15px;
	}
  .usemenu_link li.ft {
    font-size: 1.6rem;
    margin: 1em 0;
  }
	#mainVisual{
    margin-top: 0;
	}
  .top_row {
    display: flex;
    display: -webkit-flex;
    flex-flow: column nowrap;
    width: 100%;
  }
  .top_row .box_c {
    order: 1;
    -webkit-order: 1;
    margin: 0;
  }
  .top_row .box_r_top {
    order: 3;
    -webkit-order: 3;
    text-align: center;
  }
  .top_row .box_l {
    order: 2;
    -webkit-order: 2;
    margin-bottom: 1em;
  }
  .banner_area {
    margin-top: 0px;
    text-align: center;
    margin-bottom: 20px;
  }
  .top_row .box_l .banner_area {
    text-align: center;
  }
  .top_row .box_l .banner_area ul li {
    display: inline;
    width: 40%;
    height: auto;
    margin: .2em;
  }
  .top_row .box_l .banner_area p img {
    width: auto;
    height: auto;
  }
  #top_wrap .box_l, #inner_wrap .box_l {
    padding-right: 0 !important;
  }
  .newsBlock dd, .eventBlock dd {
    margin: 0 !important;
    padding: 0 !important;
    clear: both;
  }
  .newsBlock dd span, .eventBlock dd span {
    white-space: nowrap !important;
  }
  .newsBlock dt, .eventBlock dt {
    width: 100% !important;
  }
  .newsBlock dt p.data, .eventBlock dt p.data {
    margin-right: 5px;
    width: auto;
  }
  #top_wrap .box_r_top {
    padding-left: 0 !important;
    margin-bottom: 1em;
  }
  .usemenu_link_r {
    margin-bottom: 1em;
  }
  /*#top_wrap .box_r_top ul li {
	display: inline;
}*/
  #top_wrap .box_r_top ul li:nth-child(even) {}
  #top_wrap .box_r_top img {
    height: auto;
    margin: 1%;
  }
  #top_wrap .box_r_top .usemenu_link {
    margin: 20px 0;
  }
  #top_wrap .box_r_top .usemenu_link li {
    display: block;
  }
  #top_wrap .box_r_top #bn_map {
    display: none;
  }
  .newsBlock {
    margin-top: 10px;
        margin-bottom: 0;
  }
	.newsBlock.detail_page{
    padding-bottom: 20px;
	}
  .eventBlock .tab_area .tab_menu .tab_tit a {
    font-size: 1.2rem;
  }
  .link_btn_list li, div#banner_area ul.slides li {
    padding: 1px 0 0;
    vertical-align: top;
    line-height: 1;
    display: table;
    width: calc(50% - 20px);
    margin: 10px;
    box-sizing: border-box;
  }
  .link_btn_list li a {
    line-height: 1.6;
  }
  table {
    width: 100% !important;
  }
  table th,
	#eventarea th{
    white-space: normal !important;
    width: 30%;
  }
  /* inner */
	.contentIn{
    padding: 0 10px 0;
	}
  div#pagelink_list ul li {
    white-space: normal !important;
    /*    padding-left: 4em;
    text-indent: -3em;*/
  }
  .inner_row {
    display: flex;
    display: -webkit-flex;
    flex-flow: column nowrap;
    width: 100%;
    padding: 0 15px;
  }
  .inner_row .box_l {
    order: 2;
    -webkit-order: 2;
    margin: 0;
  }
  .inner_row .box_c {
    order: 1;
    -webkit-order: 1;
    margin: 0;
  }
  .inner_row .box_r {
    order: 3;
    -webkit-order: 3;
    margin: 0;
  }
	#top_wrap, #inner_wrap{
    padding-top: 15px;
	}
	#top_wrap{
		padding-top: 0;
	}
  #inner_wrap .container {
    padding: 0;
  }
  .lib_acc_l, .lib_acc_r {
    float: none;
    width: 100%;
  }
  .lib_acc_r {
    margin-top: 1.5em;
  }
  .booksR .pc {
    display: none !important;
  }
  .booksR .sp {
    display: block !important;
  }
	.kids #inner_wrap_in{
    padding-bottom: 80px;
    background-size: 672px auto;
	}
  .kids ul.index_menu li {
    width: auto;
    margin: 20px;
  }
	.kids .kids_serach_area{
    margin-top: 20px;
    flex-direction: column;
	}
	.kids_search_title{
    margin-right: 0;
    margin-bottom: 1em;
	}
  .kids_search {
    float: none;
  }
	.kids_search label{
    display: flex;
    flex-direction: column;
	}
	.kids_search .search_field{
    width: 100%;
    border-radius: 10px;
	}
	.kids_search .search_btn{
    width: 100%;
    border-radius: 10px;
    margin: 0 !important;
	}
	.kids ul.index_menu{
        margin: 0;
        gap: 20px;
	}
	.kids ul.index_menu li{
        margin: 0;
	}
	.kids .index_menu li a img, .kids .lib_area li a img{
        height: auto;
	}
	.kids .index_menu li:last-child, .kids .lib_area li:last-child{
		margin-top: 20px;
	}
	.kids .index_menu li:last-child a img, .kids .lib_area li:last-child a img{
        height: 69px;
	}
  .kids .md-4, .kids .md-8, .ya .md-4, .ya .md-8 {
    width: 100%;
  }
  .kids div.kids_h1, .kids .contents_area, .kids h2.ico_event, .kids .contents_area .kids #inner_wrap h2.pen {
    background-size: 100% !important;
    height: auto;
    padding: 0 !important;
  }
  .kids_index .kids #inner_wrap h1 {
    background-size: 100% !important;
    padding: .3em .5em;
        padding: 0 !important;
        margin-bottom: 20px;
        margin-left: -15%;
  }
	.kids #contentsBox{
    margin-bottom: 40px;
	}
	.kids #kidsmenu_box .lib_area li{
    margin: 0 auto 20px;
	}
  .kids .introduction_area, .kids #kidsmenu_box {
    text-align: center;
  }
  .kids #kidsmenu_box .edu_area {
    background-position: center;
  }
  .kids .eventBlock .btnList a {
    top: 0;
    right: 20px !important;
    margin: 2px;
  }
  .kids .contents_area, .kids_btn {
    width: 100%;
  }
  .kids #eventarea,
  .ya #eventarea {
    padding: 0;
  }
  /*  .kids #inner_wrap h1, .kids .eventBlock p.title_bar {
    background-repeat: repeat-y !important;
    border-radius: 5px;
  }
  .kids .kids_guide h2 {
    background-size: cover !important;
  }*/
	.kids_index.kids #inner_wrap h1{
		padding: 0 !important;
		margin: 0;
        text-align: left;
        width: 100%;
	}
	.kids #inner_wrap h1, .kids .eventBlock p.title_bar,
	.ya #inner_wrap h1{
    font-size: 2.2rem;
        background-size: auto 6px;
	}
	.kids h2{
        font-size: 1.8rem;
    background-size: auto 200px;
    margin-top: 36px;
	}
	.kids h2:before{
    background-size: auto 50px;
        height: 50px;
	}
	.ya #inner_wrap h2{
    padding: 10px;
    font-size: 1.8rem;
    background-size: auto 200px;
    margin-top: 36px;
	}
	.ya #kidsmenu_box .search_area{
    max-width: none;
	}
	.ya .lib_area,
	.ya .lib_area li{
    max-width: none;
	}
  .facility-list li {
    height: auto;
    min-height: 3em;
  }
  .facility-list .closed {
    /*    padding: 0px !important;*/
  }
	.page_ya .flexbox{
    flex-direction: column;
	}
  h2.ico_news, h2.ico_event {
    font-size: 1.8rem !important;
  }
	h2.ico_news span.entxt,
	h2.ico_event span.entxt{
        font-size: 3.2rem !important;
    padding-top: 10px;
        padding-right: 14px;
	}
	h2.ico_news span.jptxt,
	h2.ico_event span.jptxt{
    font-size: 1.2rem !important;
    padding-top: 10px;
        margin-left: 1em;
	}
	h2.ico_news{
		text-align: center;
		padding: 0 !important;
        min-width: auto;
	}
	.index .newsBlock.newsBlock-important ul{
    width: 100%;
    padding: 0;
    border-left: none;
    border-top: 1px solid #D4C1B3;
    margin-top: 15px;
	}
	.search_menu_area{
    margin: 0;
	}
  .pagetop {
    display: none !important;
  }
  /* footer */
  footer {
    height: auto;
    min-width: 100%;
  }
  footer .container {
    padding: 0;
    text-align: center;
    margin: 0 auto;
    background-size: 100%;
    height: auto;
  }
  footer .container .row {
    padding: 20px 0;
  }
  #ftr_r {
    text-align: center;
    margin-top: 20px;
  }
	p#ftr_name{
    font-size: 2.2rem;
    margin-bottom: 0;
	}
	#ftr_r ul{
    font-size: 1.2rem;
    width: 50%;
    align-items: flex-start;
        text-align: left;
	}
  div#banner_area ul {
    justify-content: space-evenly;
  }
  #bookSearch .search_btn, #bookSearch_sp .search_btn {}
  #sp_opac_navi .bookSearch_field {
    text-align: center;
    padding: 20px 10px;
  }
  #bookSearch_sp {
    margin: 0 10px;
    border-radius: 6px 6px 0 0;
  }
	
	header .header_search{
    padding: 10px;
	}	
	header .header_search .tab_area_wrap .tab_nav{
    width: 144px;
	}
	header .header_search .tab_area_wrap .tab_nav .tab_tit{
		font-size: 1.2rem;
        padding: 6px 0 6px 5px;
	}
	header .header_search .tab_area_wrap .tab_area_inner{
        width: calc(100% - 144px);
        padding: 10px 5px 10px 14px;
	}
	.header_search .tab_area .tab_content{
    font-size: 1.3rem;
	}
	header .header_search .tab_area_wrap .tab_area_inner #contentA fieldset .formTxt,
	header .header_search .tab_area_wrap .tab_area_inner #contentA label .formTxt,
	header .header_search .tab_area_wrap .tab_area_inner #contentB .search-input .formTxt{
    width: calc(100% - 55px);
}
	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,
	header .header_search .tab_area_wrap .tab_area_inner #contentB .search-input .d_libsearch_btn{
        width: 55px;
        padding: 3px 5px;
	}
	
	footer{
        margin-top: 60px;
    padding: 40px 0;
	}
	footer .footer_sitemap{
    display: none;
	}
	footer .container .row{
    flex-direction: column;
        padding: 20px 15px;
	}
	footer .footer_txts{
    margin-top: 0;
    padding: 0 10px;
        margin-bottom: 30px;
	}
	footer .footer_txt_area .md-5{
    margin-top: 0;
	}
	#ftr_r{
    align-items: center;
        padding: 0;
        margin: 0;
	}
	
  .index .newsBlock,
  .index .eventBlock {
        margin: 40px 15px;
        padding: 0;
	}
	#toposusume{
    margin-top: 50px;
    margin-bottom: 50px;
	}
	.newsBlock ul, .eventBlock ul{
    padding: 0 10px;
	}
	.eventBlock ul li .event_img{
    max-width: 100px;
    margin-right: 10px;
	}
	.newsBlock ul li .data, .eventBlock ul li .data{
	}
	.index .newsBlock .right_box{
    width: 100%;
    margin-top: 24px;
	}
.index .eventBlock .common_event .left_box .btnList{
	display: none;
}
	.index .eventBlock .common_event .left_box .btnList a{
        width: fit-content;
        margin: 0 auto;
	}
.index .eventBlock .common_event .right_box .btnList{
	display: block;
}
	
	.calendar_area .tit01{
    font-size: 2.0rem;
	}
	.calendar_data{
    font-size: 1.4rem;
    max-height: none;
        padding: 3px 14px;
	}
	.lib_cal_wrap{
    flex-direction: column;
	}
	.facility-list{
    width: 100%;
    justify-content: space-between;
    gap: 12px;
	}
	.facility-list li,
	.facility-list .closed{
        width: calc(50% - 6px);
        background-size: 22px;
        max-width: none;
	}
	.facility-list li span{
        font-size: 1.3rem;
	}
	.facility-list li span.data-facility{
        font-size: 1.2rem;
	}
	.calendar_area .calendar_title_area{
    margin-bottom: 0;
	}
	.lib_cal_links a{
    text-align: center;
	}
	.lib_cal_links p{
		display: inline-block;
        background-size: 22px;
        padding-left: 38px;
	}
	.lib_cal_links a .name {
    font-size: 1.3rem;
}
	.lib_cal_links a .txt{
    font-size: 1.0rem;
	}
	.lib_cal_links{
    width: 100%;
	}
	.lib_cal_links ul{
    flex-direction: column;
    gap: 16px;
	}
	.lib_cal_links ul li{
    width: 100%;
        background-size: 28px auto !important;
        background-position: left 10px center !important;
	}
	.lib_cal_links ul li a{
    padding: 10px 10px 10px 48px;
    align-items: flex-start;
	}
	.lib_cal_links ul li a .name{
		font-size: 1.4rem;
	}
	.lib_cal_links ul li a .txt{
    font-size: 1.2rem;
	}
	#top_wrap .container{
        margin-bottom: 0;
	}
	.newsBlock.newsBlock-important{
        padding: 20px 20px 0;
        margin: 40px 15px;
    flex-direction: column;
	}
	.newsBlock ul, .eventBlock ul{
    padding: 0 10px;
	}
	.newsBlock ul li a{
    flex-direction: column;
	}
	.newsBlock ul li .data, .eventBlock ul li .data,
	.newsBlock ul li .name{
		width: 100%;
	}
	.newsBlock .btnList a, .eventBlock .btnList a{
    margin: 10px auto;
	}
	.top_btn_area{
        padding: 0 15px;
        margin: 40px 0;
	}
	.top_btn_area .row01{
    flex-direction: column;
	}
	.top_btn_area .row01 .search_box{
    width: 100%;
    padding: 30px 20px;
    flex-direction: column;
    align-items: flex-start;
	}
	.top_btn_area .row01 .search_box .txts{
    background: url(../images/icon_search.png) no-repeat 0 center;
    background-size: 48px;
    padding-left: 70px;
    margin-right: 0;
	}
	.top_btn_area .row01 .search_box .form_box{
    width: 100%;
    margin-top: 16px;
	}
	.top_btn_area .row01 .search_box form .formTxt{
    width: calc(100% - 90px);
	}	
	.top_btn_area .row01 .search_box form .search_btn{
    padding: 0 16px;
    width: 90px;
	}
	.top_btn_area .btn_search{
    width: 100%;
	}
	.top_btn_area .btn_right{
    width: 100%;
    gap: 14px;
	}
	.top_btn_area .btn_right div{
    width: calc(100% / 2 - 7px);
	}
	.top_btn_area .btn_search a, .top_btn_area .btn_right div a{
        font-size: 1.8rem;
        padding: 45px 10px 10px;
        background-size: auto 30px;
        line-height: 1.75;
	}
	.top_btn_area .btn_search a{
		background: #fff;
        padding: 25px 10px;
	}
	.top_btn_area .btn_search a span{
    display: flex;
    align-items: center;
	}
	.top_btn_area .btn_search a span:before{
		content: "";
		display: inline-block;
		width: 30px;
		height: 30px;
    background: url(../images/icon_btns_search.svg) no-repeat;
        background-size: 30px;
        margin-right: 10px;
	}
	.top_btn_area .row01 .btn_mypage{
    width: 100%;
	}
	.top_btn_area .row02 ul{
    gap: 14px 20px;
    flex-wrap: wrap;
		margin-top: 20px;
	}
	.top_btn_area .row02 ul li{
    width: calc((100% - 20px) / 2);
    margin: 0;
	}
	.top_btn_area .row02 ul li a{
    font-size: 1.2rem;
    padding: 10px 30px 10px 30px;
	}
	.top_btn_area .row02 ul li:after{
    background-size: 10px;
    width: 26px;
    margin-left: -26px;
	}
	.index .eventBlock ul{
        gap: 0 14px;
	}
	.index .eventBlock ul li{
    width: calc(100% / 2 - 7px);
	}
	#toposusume .booklist{
    padding: 0;
	}
	#toposusume .booklist .open, .kidsosusumetop .booklist .open{
    flex-wrap: wrap;
		margin: 0;
	}
	#toposusume .booksWrap{
    width: calc(100% / 3);
	}
	#toposusume .booklist .open li a, .kidsosusumetop .booklist .open li a{
    padding: 10px;
	}
	#toposusume .booksWrap img{
    width: 100%;
    height: auto;
        min-width: 80px;
	}
	#toposusume .booksWrap small{
    line-height: 1.75;
	}
	#toposusume .booklist .open li p.books_title, .kidsosusumetop .booklist .open li p.books_title{
    font-size: 1.4rem;
	}
	.info_area{
    flex-direction: column;
	}
	.info_area .information{
    width: 100%;
    padding: 20px 10px;
        margin: 0 0 50px;
	}
	.info_area .information .links{
    gap: 10px;
    flex-direction: column;
        margin: 0;
	}
	.info_area .information .links li{
    width: 100%;
	}
	.info_area .information .links li a{
        min-height: 66px;
        padding: 4px 10px;
    padding-left: 64px;
        font-size: 1.6rem;
	}
	.info_area .information .links li.info .name span{
        font-size: 1.2rem;
	}
	.info_area .X_area{
    text-align: center;
	}
	.info_area .X_area .title{
    display: inline-block;
        font-size: 2.0rem;
	}
	.twitter-timeline{
    margin: 0 auto;
	}
	.twitter-timeline iframe{
    height: 300px !important;
	}
	.access_area{
        margin: 50px 0;
		margin-bottom: 0;
	}
	.access_area .txt_area h2{
    margin: 0 0 20px;
	}
	.access_area .txt_area p.name{
    font-size: 1.6rem;
    margin-bottom: 0;
	}
	.access_area .map_area{
    flex-direction: column;
	}
	.access_area .txt_area{
    width: 100%;
    margin-right: 0;
	}
	.access_area .txt_area .line_bnr{
    text-align: center;
	}
	.access_area .map_area{
        position: initial;
        margin-top: 20px;
        display: block;
	}
	.access_area .map_area:before{
		content: none;
	}
	.access_area .map_area .map_area_inner{
    width: 100% !important;
	}
	.index .newsBlock{
    flex-direction: column;
	}
	.index .newsBlock .left_box .btnList{
		display: none;
	}
	.index .newsBlock .right_box .btnList{
		display: block;
        margin-top: 20px;
	}
	.index .newsBlock .right_box .btnList a{
    width: fit-content;
    margin: 0 auto;
	}
	h2.ico_news,
	h2.ico_event{
    display: flex;
    align-items: center;
        flex-direction: row;
	}
	h2.ico_news:before,
	h2.ico_event:before{
    position: absolute;
    top: 0;
	}
	.index .eventBlock .common_event{
    flex-direction: column;
        margin-bottom: 30px;
	}
	.index .eventBlock .right_box{
    width: 100%;
        margin-top: 24px;
	}
/*	.index .eventBlock .right_box .tab_area_wrap{
    display: flex;
    flex-wrap: wrap;
	}*/
	.index .eventBlock .common_event ul{
    gap: 15px;
        margin: 0;
	}
	.index .eventBlock .common_event ul li{
    width: calc(100% / 2 - 10px);
	}
	.index .eventBlock .common_event ul li.btnList a{
        display: flex;
        align-items: center;
        width: 100%;
        max-width: none;
        background: none !important;
        justify-content: center;
        border-radius: 0;
	}
	.index .eventBlock .common_event ul li.btnList a span{
        background: url(../images/ctrl_btn_next.svg) no-repeat !important;
        background-position: left center !important;
        padding-left: 60px;
        min-height: 46px;
        display: flex;
        align-items: center;
	}
	.index .eventBlock .toshokan_block h3{
    margin-top: 30px;
        background-size: auto 6px;
	}
	.index .eventBlock .toshokan_block .toshokan_block_inner{
    flex-direction: column;
    gap: 40px;
	}
	.index .eventBlock .toshokan_block .toshokan_block_inner .toshokan_box{
    width: 100%;
	}
	.index .eventBlock .toshokan_block .toshokan_block_inner h4 span{
    font-size: 1.8rem;
	}
	.index .eventBlock ul li{
    width: 100%;
	}
	.index .eventBlock .toshokan_block .toshokan_block_inner .chuo_block h4 span,
	.index .eventBlock .toshokan_block .toshokan_block_inner .takesato_block h4 span,
	.index .eventBlock .toshokan_block .toshokan_block_inner .shouwa_block h4 span{
    background-size: 34px;
    padding-left: 46px;
	}
	.top_bnr_area{
    padding: 40px 15px;
	}
	.top_bnr_area .social_bnr ul{
        gap: 16px;
    flex-direction: column;
	}
	.top_bnr_area .social_bnr ul li{
    width: 100%;
	}
	.top_bnr_area .btn_bnr {
    margin-top: 40px;
	}
	.top_bnr_area .btn_bnr ul{
    gap: 16px;
	}
	.top_bnr_area .btn_bnr ul li{
    width: calc(100% / 2 - 8px);
    margin: 0;
	}
	.top_bnr_area .sponsor_bnr {
    margin-top: 40px;
	}
	.top_bnr_area .sponsor_bnr ul{
    gap: 16px;
    justify-content: flex-start;
	}
	.top_bnr_area .sponsor_bnr ul li{
    width: calc(100% / 2 - 8px);
        text-align: center;
	}
	.top_bnr_area .sponsor_bnr .sponsor_bnr_title{
    background-size: auto 6px;
	}
	ol#topicpath{
    line-height: 1.75;
    font-size: 1.4rem;
	}
	ol#topicpath > li:after{
		padding: 5px 10px;
	}
	
	#ya_osusume .booklist{
    padding: 0 30px;
	}
	#ya_osusume .ya_newbook .swiper-button-prev,
	#ya_osusume .ya_newbook .swiper-button-next{
        width: 24px;
        height: 24px;
	}
	
	/*  おすすめ本（新着図書）
----------------------------------------------*/
	#booklist_all ul li h2{
    display: flex;
    flex-direction: column;
	}
	#booklist_all ul li h2 .sub{
    margin: 10px 0 0 0;
	}
	#booklist_all ul li .book_content{
    flex-direction: column;
	}
	#booklist_all ul li .book_content .book_content_L,
	#booklist_all ul li .book_content .book_content_R{
    width: 100%;
    margin-right: 0;
	}
	
	.about_search_cont .search_box h2, .about_search_cont .g_search_box h2{
    background-size: 28px;
    padding-left: 38px;
	}
	.about_search_cont .search_box .txts, .about_search_cont .g_search_box .txts{
    flex-direction: column;
    align-items: flex-start;
	}
	.about_search_cont .search_box .txts .search_link_btn, .about_search_cont .g_search_box .txts .search_link_btn{
    display: block;
    margin-top: 1em !important;
	}
	.about_search_cont .search_box .form_box form .formTxt, .about_search_cont .g_search_box .form_box form .search_field{
    width: calc(100% - 90px);
	}
	.about_search_cont .search_box .form_box form .search_btn, .about_search_cont .g_search_box .form_box form .search_btn{
    padding: 0 16px;
    width: 90px;
	}
	
	.kids .contentIn{
    padding: 0 10px 0;
	}
	.kids #inner_wrap h1{
    width: calc(100% + 20px);
    margin-left: -10px;
	}
	
	.page_ya .yacorner_box .flexbox{
    flex-direction: column;
	}
	.page_ya .yacorner_box .flexbox .mr20{
    margin: 0 0 10px !important;
    text-align: center;
	}
	.page_ya .yacorner_box img{
        width: 100%;
	}
	
	.lib_data{
    flex-direction: column;
    align-items: center !important;
	}
	
	.contentIn #contents {
    padding: 0;
}
	.faq_box ul li .q_txt, .faq_box ul li .a_txt{
        font-size: 1.4rem;
	}
	.faq_box ul li .q_txt span{
    top: 0.5em;
	}
	
	.blogBlock .blog_content_wrap{
    flex-direction: column;
	}
	.blogBlock .blog_content_wrap .blog_content{
    width: 100%;
	}
	
}


/*202504改修*/
@media screen and (max-width: 768px) {
	.index .eventBlock .common_event .left_box .btnList{
    display: block;
        margin-top: 20px;
        margin-bottom: 20px;
	}
	.index .eventBlock .common_event .left_box .btnList a{
    margin: 0;
	}
	#btn_h_login{
		display: none !important;
	}
	.sp_disblock{
		display: flex !important;
	}
}