@charset "utf-8";

@media screen and (max-width : 640px) {

/* ==================================================
Base-Layout
================================================== */
/* body
================================================== */
body {
	font-size: 87.5%;
	-webkit-text-size-adjust:none;
}
/* wrapper
================================================== */
#tmp_wrapper {
	width:100%;
	min-width:320px;
}
.container{
	padding: 0 10px;
	width: 100%;
}
/* contents
================================================== */
#tmp_contents,
#tmp_maincontents {
	word-wrap:break-word;
}
/* format-layout
================================================== */
.wrap_col_nm,
.wrap_col_rgt_navi,
.column_full .wrap_col_main,
.column_lnavi .wrap_col_main,
.column_rnavi .wrap_col_main {
	float:none;
}
.wrap_col_lft_navi {
	float:none;
	position:static;
	z-index:auto;
}
.col_main {
	padding:0;
}
.format_free .wrap_col_rgt_navi{
	width: 100%;
}
/* top
================================================== */
.format_top #tmp_main_menu,
.format_top #tmp_main {
	float:none;
	width:100%;
}
/* free
================================================== */
.format_free .wrap_col_lft_navi {
	display:none;
}
.format_free .column_lnavi .col_main {
	margin-left:0;
}
.format_free .column_rnavi .wrap_col_main,
.format_free .column_rnavi .col_main {
	margin-right:0;
	padding: 0;
}
/* ==================================================
header
================================================== */
#tmp_header {
	position:relative;
	z-index: 1000;
	padding: 7px 0 5px; 
	background-color: #ffffff;
	color: #222222;
	z-index: 9999;
	border-bottom: 3px solid #7a0606;
}
#tmp_hlogo {
	padding: 14px 0 0;
	margin: 0;
	text-align:center;
}
#tmp_hlogo h1,
#tmp_hlogo p {
    width: 133px;
    height: 21px;
    -webkit-background-size: 100% auto;
    -moz-background-size: 100% auto;
    background-size: 100% auto;
}
#tmp_hlogo a {
	width: 133px;
    height: 21px;
}
#tmp_hlogo h1 span,
#tmp_hlogo p span {
	width: 133px;
    height: 21px;
}
#tmp_mean li a{
	width: 46px;
}
.gnavi{
	display: none;
}
/* sp_menu
================================================== */
.spmenu_open {
	position:absolute;
	width: 100%;
	min-height: 100%;
    z-index: 9999;
    background: #ffffff;
    color: #222222;
    position: absolute;
}
.spmenu_open::before {
	content:"";
	min-height: 100%;
	height:100%;
	width:100%;
	position:absolute;
	top:0;
	left:0;
	background-color: rgba(0,0,0,0.5);
	z-index:699;
}
#tmp_sma_menu{
	top: 63px;
}
#tmp_sma_menu .container{
	padding: 0;
}
#tmp_sma_rmenu,
#tmp_sma_mmenu{
	border-radius: 0;
}
#tmp_sma_mmenu{
	padding: 22px 10px 22px;
	border-bottom: 5px solid #ffffff;
}
    #tmp_sma_mmenu .browse_support {
        display: block;
    }
#tmp_fsize,
#tmp_color,
#tmp_read,
#tmp_language {
	float: none;
    margin-right: 0;
}

#tmp_fsize a,
#tmp_read a,
#tmp_language a {
    display: block;
    border-radius: 0;
    -moz-border-radius: 0;
    -webkit-border-radius: 0;
    text-align: left;
    padding: 11px 14px 8px 34px;
	font-size: 85.7%;
}
#tmp_read a,
#tmp_language a {
        border-top: none;
}
#tmp_fsize a {
    background-size: 14px auto;
}
#tmp_read a{
    background-size: 18px auto;
}
#tmp_language a {
    background-size: 12px auto;
}
#tmp_switch_sp_style {
	display: none;
}
#tmp_hnavi_s,
.spmenu_open #tmp_hnavi_s {
	display: block;
	list-style: none;
}
#tmp_mean{
	padding: 0;
}
#tmp_hnavi_s li a,
#tmp_hmenu a{
	position: relative;
	text-align: center;
	width: 46px;
	min-width: 46px;
	height: 48px;
	font-size: 0.56rem;
	padding: 0;
	border-radius: 5px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
}
#tmp_mean li{
	margin: 0 3px;
}
#tmp_hmenu{
	margin-left: 3px;
}
#tmp_mean li a{
	padding: 30px 0 0;
}
#tmp_hnavi_lmenu a{
	background-position: center 7px;
	background-size: 20px 20px;
	-webkit-background-size: 20px 20px;
	-moz-background-size: 20px 20px;
}
#tmp_hnavi_mmenu a{
	background-position: center 7px;
	background-size: 19px 20px;
	-webkit-background-size: 19px 20px;
	-moz-background-size: 19px 20px;
}
#tmp_hmenu a{
	padding: 30px 0 0 0;
	background-position: center 10px;
	background-size: 17px 15px;
	-webkit-background-size: 17px 15px;
	-moz-background-size: 17px 15px;
}
#tmp_hnavi_mmenu a.active,
#tmp_hmenu a.active{
	background-position: center 10px;
	background-size: 13px 13px;
	-webkit-background-size: 13px 13px;
	-moz-background-size: 13px 13px;
	border-radius: 5px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
}
#tmp_hnavi_mmenu a:after,
#tmp_hmenu a:after{
	bottom: -26px;
	height: 30px;
}
#tmp_hmenu a:after{
	display: none;
    content: "";
    position: absolute;
    left: 0;
    width: 100%;
    color: inherit;
    background-color: #7a0606;
}
#tmp_hmenu a.active:after{
	display: block;
}
#tmp_sma_rmenu {
    padding: 17px 10px 40px;
    border-bottom: 14px solid #ffffff;
}
#tmp_search{
	margin-left: 0;
}
#tmp_search .box_search{
	width: 100%;
    margin: 0 0 27px;
}
#tmp_search .menu_sch_ttl{
	width: 100%;
	float: none;
	margin-bottom: 5px;
}
#tmp_search .menu_sch_ttl label{
	font-size: 85.7%;
}
#tmp_search .sch_box input{
	height: 40px;
	border-radius: 5px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	background-size: 99px 16px !important;
	-webkit-background-size: 99px 16px !important;
	-moz-background-size: 99px 16px !important;
}
#tmp_search .sch_btn input{
	width: 50px;
	height: 40px;
	font-size: 0.875rem;
	border-radius: 0 5px 5px 0;
	-webkit-border-radius: 0 5px 5px 0;
	-moz-border-radius: 0 5px 5px 0;
}
.utilities_link{
	margin-bottom: 0;
}
.utilities_link ul li{
	width: 100%;
	float: none;
	border-right: none;
    margin-bottom: 2px;
}
.utilities_link ul li:nth-child(n){
	clear: both;
}
.utilities_link ul li:last-child{
	margin-bottom: 0;
}
.utilities_link li a{
	min-height: auto;
	padding: 23px 10px 16px;
}
.utilities_link li a span{
	padding-left: 23px;
	background-position: left 4px;
	background-size: 6px 8px;
	-webkit-background-size: 6px 8px;
	-moz-background-size: 6px 8px;
}
.information_link{
	margin: 0 -3px;
}
.information_link table,
.information_link tr,
.information_link td{
	display: block;
}
.information_link td{
	width: 50%;
	max-width: 50%;
	float: left;
	padding: 1px;
}
.information_link td a{
	display: table;
	text-decoration: none;
	width: 100%;
	min-height: 58px;
	background-color: #ffffff;
	color: #222222;
}
.information_link td a span{
	display: table-cell;
	vertical-align: middle;
	color: #222222;
	background-color: transparent;
	padding-left: 20px;
	background-position: 10px 22px;
	background-size: 6px 8px;
	-webkit-background-size: 6px 8px;
	-moz-background-size: 6px 8px;
}
/* gnavi
================================================== */
#tmp_gnavi {
	display:none;
}
/* pankuzu
================================================== */
#tmp_pankuzu {
	display:block;
	margin-top: 33px;
	font-size: 85.7%;
	padding:0 10px;
	margin-bottom: 40px;
}
.socials_print_wrap {
    text-align: center;
    margin: 0 0 25px;
}
#tmp_print{
	display: none;
}
/* lnavi
================================================== */
/* rnavi
================================================== */
.rnavi_func{
	padding: 3px;
	margin-bottom: 28px;
	border-radius: 5px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
}
.rnavi_func_wrap{
	padding: 5px 4px;
	color: inherit;
	background-color: #ffffff;
}
.rnavi_func_ttl{
	font-size: 128.6%;
	padding: 16px 10px 16px;
	border-radius: 3px 3px 0 0;
    -webkit-border-radius: 3px 3px 0 0;
    -moz-border-radius: 3px 3px 0 0;
}
.rnavi_func_des{
	font-size: 100%;
	line-height: 1.6;
	margin-bottom: 22px;
}
.rnavi_func_cnt{
	padding: 14px 11px 15px 8px;
}
.rnavi_func_cnt li a{
	font-size: 100%;
	background-position: 4px 7px;
	background-size: 14px 14px;
	-webkit-background-size: 14px 14px;
	-moz-background-size: 14px 14px;
}
.rnavi_func_cnt li {
    margin-bottom: 13px;
}
.rnavi_func_cnt .rnavi_button a{
	font-size: 128.6%;
	border-radius: 5px;
	padding: 19px 20px 20px 53px;
	background-position: 22px center;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	background-size: 18px 18px;
	-webkit-background-size: 18px 18px;
	-moz-background-size: 18px 18px;
}
.rnavi_banner_ttl a{
	font-size: 125%;
}
/* pnavi
================================================== */
/* plugin
================================================== */
.plugin {
	display:none; /* do not edit */
}
/* model_change
================================================== */
.wrap_mc_pc {
    display: block;
    text-align: center;
    margin: 20px 0 0;
}
.wrap_mc_pc #tmp_switch_pc_style {
    display: inline-block;
    border: 1px solid #7A0606;
    border-radius: 20px;
    background: #FFFFFF url("../../../../shared/site_toshokan/images/header/pc_icon.png") 17px center/12px auto no-repeat;
    padding: 6px 21px 5px 42px;
    font-size: 85.7%;
    text-decoration: none;
    font-weight: bold;
}
/* ==================================================
footer
================================================== */
#tmp_footer{
	padding-top: 58px;
	color: inherit;
	background:transparent url(/shared/site_toshokan/images/footer/footer_bg_sp.png) repeat-x left top;
	background-size: 320px auto;
	-webkit-background-size: 320px auto;
	-moz-background-size: 320px auto;
}
.footer_wrap{
	padding: 35px 0 32px;
}
.footer_logo{
	margin-bottom: 28px;
}
.footer_logo p{
	width: 237px;
	height: 38px;
	background-size: 100% auto;
	-webkit-background-size: 100% auto;
	-moz-background-size: 100% auto;
}
.pnavi {
    right: 10px;
    top: -100px;
}
.pnavi a{
	width: 180px;
	padding: 13px 10px 16px 35px;
	background-size: 12px;
	-webkit-background-size: 12px;
	-moz-background-size: 12px;
	border-radius: 3px 3px 0 0;
    -webkit-border-radius: 3px 3px 0 0;
    -moz-border-radius: 3px 3px 0 0;
}
/* fnavi */
.footer_cnt {
	padding:0;
	clear:both;
}
.footer_cnt address {
	font-style:normal;
	padding-right: 0;
	margin-bottom: 23px;
}
.footer_cnt address p{
	width: 100%;
    float: none;
}
.footer_link_home{
	position: relative;
	top: 0;
	right: 0;
	text-align: center;
	margin-bottom: 40px;
}
.footer_link_home img{
	max-width: 167px;
}
.copyright {
	text-align:center;
	clear:both;
	font-size: 78.6%;
}
/* ==================================================
class
================================================== */

/* float ▼Do not edit
================================================== */
.float_lft,
.float_rgt {
	float:none;
	margin-left:0 !important;
	margin-right:0 !important;
}
/* youtube ▼Do not edit
================================================== */
#tmp_contents .frame_youtube,
#tmp_contents .frame_ustream {
	position:relative;
	display:block;
	height:0;
	padding-bottom:56.25%;
	overflow:hidden;
	min-width:200px;
}
#tmp_contents .frame_youtube object,
#tmp_contents .frame_ustream object,
#tmp_contents .frame_youtube iframe,
#tmp_contents .frame_ustream iframe {
	position:absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
}


/* ==================================================
parts
================================================== */
/* parts ▼Do not edit
============================== */
div.col2 div.col2L,
div.col3 div.col3L,
div.col3 div.col3M,
div.col2 div.col2 div.col2L,
div.fixed_col2 div.fixed_col2L {
	width:100%;
	margin-right:0;
	display: block;
	float:none;
	clear:both;
}
div.col2 div.col2R,
div.col3 div.col3R,
div.col2 div.col2 div.col2R,
div.fixed_col2 div.fixed_col2R {
	width:100%;
	display: block;
	float:none;
	clear:both;
}
#tmp_contents div.col3 ul,
#tmp_contents div.col2 ul {
	margin-bottom:0;
}
div.img_cap {
	width:auto !important;
}
#tmp_contents img {
	max-width:100%;
	height:auto;
}
#tmp_contents ul,
#tmp_contents ol {
	margin-left:22px;
}
#tmp_contents table {
	width:auto;
}
#tmp_contents table table {
	max-width:100%;
}
#tmp_contents table th,
#tmp_contents table td {
	width:auto;
}
#tmp_contents table.gsc-search-box td.gsc-input {
	width:100% !important;
}
#tmp_contents input[type="text"],
#tmp_contents textarea {
	width:100% !important;
	padding:0;
	box-sizing:border-box;
	-webkit-box-sizing:border-box;/* Webkit */
}

/* ==================================================
CMS-parts
================================================== */


/* col2
================================================== */


/* col2_pub */


div.col2 div.col2L {
	padding-right: 0;
}

div.col2 div.col2R {
	padding-left: 0;
}

.column_cnt div.col2 div.col2L {
	padding-right: 0;
}

.column_cnt div.col2 div.col2R {
	padding-left: 0;
}

/* col3_pub */

div.col3 div.col3L,
div.col3 div.col3M {
	padding-right: 0;
}

div.col3 div.col3R {
	padding-left: 0;
}

div.col3 div.col3M {
	padding-left: 0;
}

.column_cnt div.col3 div.col3L,
.column_cnt div.col3 div.col3M {
	padding-right: 0;
}

.column_cnt div.col3 div.col3R {
	padding-left: 0;
}

.column_cnt div.col3 div.col3M {
	padding-left: 0;
}


/* event_cal
================================================== */
/* cate_ttl
================================================== */
#tmp_cate_ttl img {
    height:auto;
    max-width:100%;
}


/* Scroll Table
================================================== */
.scroll_table {
	overflow-x:auto;
	margin-bottom:17px;
	padding:15px 5px 5px;
	background-color:transparent;
	background-size:75px 15px;
}
.scroll_table {
	overflow-x:scroll;
}
.scroll_table_switch {
	text-align:right;
	margin:0 0 10px;
	font-size:100%;
	line-height:1.2;
}
.scroll_table_switch a {
	border: 1px solid #ecedf3;
	color:#333333;
	display:inline-block;
	padding:8px 10px 8px 70px;
	text-decoration:none;
	background:#f1f4f7 url(/shared/site_toshokan/images/icon/scroll_table_ex.png) 10px center no-repeat;
	background-size:46px 20px;
	min-width:9em;
	text-align:center;
	box-shadow: 0 2px 3px 0 rgba(96, 103, 120, 0.45);
    -webkit-box-shadow: 0 2px 3px 0 rgba(96, 103, 120, 0.45);
	-moz-box-shadow: 0 2px 3px 0 rgba(96, 103, 120, 0.45);
	border-radius: 3px;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
}
.scroll_table_switch a.scroll {
	background:#f1f4f7 url(/shared/site_toshokan/images/icon/scroll_table_df.png) 10px center no-repeat;
	background-size:46px 20px;
}
.scroll_table::-webkit-scrollbar{
 height: 5px;
}
.scroll_table::-webkit-scrollbar-track{
 background: #F1F1F1;
}
.scroll_table::-webkit-scrollbar-thumb {
 background: #BCBCBC;
}

/* ==================================================
accessibility style change:font-size
================================================== */
.fsize_big #tmp_fsize .fsize_box ul,
.fsize_big #tmp_fsize .fsize_box ul{
	min-width: 98px;
}
.fsize_small .information_link td span {
    background-position: left center;
}
.fsize_big .pnavi,
.fsize_big2 .pnavi{
    top: -121px;
}
.fsize_big2 #tmp_hmenu a {
    font-size: 0.56rem;
}
.fsize_big2 #tmp_read a{
	padding-left: 40px;
}
.fsize_big2 .utilities_link li a span{
	background-position: left 12px;
}
/* ==================================================
clearfix
================================================== */
#tmp_sma_lnavi_cnt .switch_menu .noicon_list:after {
	content: ""; /* Do not edit */
	display: table; /* Do not edit */
	clear: both; /* Do not edit */
}
}