/*
 Theme Name:   tokusui
 Template:     twentysixteen
*/


/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/

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, 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,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
	display: block;
}
body {
	line-height: 1;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}
.entry-content a, .entry-summary a, .taxonomy-description a, .logged-in-as a, .comment-content a, .pingback .comment-body > a, .textwidget a, .entry-footer a:hover, .site-info a:hover {
    box-shadow: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
#content {
	margin-top:50px;
}
.entry-title {
    font-family: Montserrat,"Helvetica Neue",sans-serif;
    font-size: 1.7rem;
    font-weight: 700;
    line-height: 1.25;
    margin-bottom: 1em;
	float:none;
}
.entry-title a {
	text-decoration:none;
}
.entry-content , .entry-footer {
	font-size:1.3rem;
	line-height:1.7;
	text-align:justify;
}
.entry-content p {
	margin-top:17px;
}
#secondary {
	font-size:1.3rem;
	line-height:1.7;
	text-align:justify;
}
.widget .widget-title {
	font-size:1.7rem;
	line-height:1;
	text-align:justify;
}
.entry-header, .post-thumbnail, .entry-content, .entry-summary, .entry-footer, .comments-area, .image-navigation, .post-navigation, .page-header, .page-content, .content-bottom-widgets {
    margin-left: 7.6923%;
	margin-right: 7.6923%;
}
.sidebar, .widecolumn {
    margin-bottom: 5.25em;
    padding-right: 7.6923%;
	padding-left: 7.6923%;
}


html {
    font-size: 62.5%;
	height: 100%;
}
body {
    color: #333;
	font-family: "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","メイリオ",Meiryo,Osaka,"ＭＳ Ｐゴシック","MS PGothic",sans-serif;
    letter-spacing: 0.04em;
    line-height: 1.7;
    margin: auto;
	height: 100%;
	position:relative;
}

ul, ol {
    margin: 0;
}
ul.children {
    margin-left: 14px;
}
}
.breadcrumbs {
    font-size: 1.3rem;
    line-height: 1;
    margin: 0 auto 10px;
    max-width: 980px;
    padding-top: 60px;
    width: 90%;
}
a {
    transition: all 0.2s cubic-bezier(0.39, 0.575, 0.565, 1) 0s;
	color:#001c58;
	text-decoration:underline;
}
a:hover {
	color:#7a89a8;
	text-decoration:none;
}
footer p.page-top {
	text-align:center;
}
header.main {
	background-color:#fff;
	position:fixed;
	width:100%;
	height:55px;
	z-index:1000;
}
h1 {
	width:200px;
	margin:10px 0 0 15px;
}
h1 img {
	width:100%;
	max-width:341px;
	height:auto;
	vertical-align: top;
}

nav {
	background-color: rgba(0, 28, 88, 0.9);
	height: 100%;
    left: 0;
    position: fixed;
    top: 0;
    width: 100%;
	display:none;
	z-index: 6000;
}
nav .inner {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
	-ms-transform:translateY(-50%);
    -webkit-transform:translateY(-50%);
    width: 100%;
}
nav .inner > li {
    border-bottom: 1px solid #fff;
    display: block;
    margin: 0 8%;
    padding: 3% 0;
	font-size:1.4rem;
}
nav .inner > li > a {
    color: #fff;
    text-align: center;
    text-decoration: none;
    vertical-align: middle;
    width: 100%;
	position:relative;
	display: block;
    padding: 3px 0;
}
nav .inner > li i {
	display:none;
}
#sp_btn {
    height: 15px;
    position: fixed;
    right: 15px;
    top: 20px;
    width: 20px;
    z-index: 7000;
}
.sp_disp_block {
    display: block !important;
}

#sp_btn span:nth-child(1) {
    top: 0;
}
#sp_btn span:nth-child(2) {
    top: 6px;
}
#sp_btn span:nth-child(3) {
    top: 12px;
}
#sp_btn span {
    background: #323232 none repeat scroll 0 0;
    display: block;
    height: 2px;
    left: 0;
    position: absolute;
    transition: all 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55) 0s;
    width: 100%;
}
#sp_btn.open span:nth-child(1) {
    top: 6px;
    transform: rotate(45deg);
	-ms-transform:rotate(45deg);
    -webkit-transform:rotate(45deg);
	background: #fff;
}
#sp_btn.open span:nth-child(2) {
    opacity: 0;
}
#sp_btn.open span:nth-child(3) {
    top: 6px;
    transform: rotate(-45deg);
	-ms-transform:rotate(-45deg);
    -webkit-transform:rotate(-45deg);
    background: #fff;
	
}
footer {
	position:relative;
	border-top: 2px solid #ededed;
}
footer ul#fnav {
	font-size: 1.3rem;
	line-height: 1.3em;
	width: 90%;
	max-width: 980px;
	margin: 50px auto 0 auto;
	border-bottom: 1px solid #ccc;
}
footer ul#fnav li {
	display:inline-block;
	margin:0 10px 5px 0;
}
footer ul#fnav li i , footer ul#snav li i {
	padding-right:5px;
}
footer ul#snav {
	font-size: 1.3rem;
	line-height: 1.3em;
	width: 90%;
	max-width: 980px;
	margin: 10px auto 20px auto;
}
footer ul#snav li {
	display:inline-block;
	margin:0 10px 5px 0;
}
address {
	width: 90%;
	max-width: 980px;
	margin: 20px auto;
}
address strong {
	font-size: 1.8rem;
}
address p {
	font-size: 1.3rem;
}
footer > div {
	width:100%;
	background-image: url(images/bg_footer.png);
	background-size:100% auto;
	background-repeat:no-repeat;
	background-color:#2ca5ff;
}
footer > div p {
	padding:50px 0;
	color:#fff;
	font-size:1rem;
	line-height:1;
	text-align:center;
	width:90%;
	margin:0 auto 0 auto;
}

.breadcrumbs {
	width: 90%;
max-width: 980px;
margin: 0 auto;
font-size: 1.3rem;
}
.taxonomy-description {
font-size: 1.3rem;
}

@media print, screen and (min-width: 769px) {
.breadcrumbs {
	padding-top:55px;
}
.site-content {
	width:90%;
	max-width:980px;
	margin:0 auto;
}
.site-content {
    padding:0;
}
.sidebar, .widecolumn {
    padding-left: 0;
    padding-right: 0;
}
.sidebar {
    float: right;
    margin-left: 0;
    width: 25%;
}
.content-area {
    float: left;
    margin-right: 0;
    width: 65%;
}
.entry-header, .post-thumbnail, .entry-content, .entry-summary, .entry-footer, .comments-area, .image-navigation, .post-navigation, .page-header, .page-content, .content-bottom-widgets {
    margin-left: 0;
    margin-right: 0;
}
body:not(.search-results) article:not(.type-page) .entry-content {
    float: none;
    width:100%;
}
body:not(.search-results) article:not(.type-page) .entry-footer {
    float: none;
   margin-top: 10px;
    width: 100%;
}
#secondary li {
	font-size:1.3rem;
	line-height:1.7;
	text-align:justify;
}
.widget input.search-field[type="search"] {
    font-size:1.3rem;
}
input.search-field[type="search"] {
     font-size:1.3rem;
}
header.page-header h1 {
    margin: 10px 0 0 0;
    width: 200px;
	float:none;
}
nav.navigation {
	text-align:left;
	width:100%;
	float:none;
}
.post-navigation .meta-nav {
    font-size: 1.3rem;
}

header.main {
	position:relative;
	width:90%;
	max-width:980px;
	margin:0 auto;
	height:auto;
	overflow:hidden;
}
h1 {
	width:45%;
	margin: 40px 0 0;
	float:left;
}
header.entry-header h1 {
	width:100%;
}
.sp_disp_block {
    display: none !important;
}
nav {
    background: none;
	position:relative;
	float:right;
	text-align:right;
	display:block !important;
	width:55%;
}
nav .inner {
	position:relative;
	transform: translateY(0px);
	-ms-transform:translateY(0px);
    -webkit-transform:translateY(0px);
	top:0;
	 padding-top: 68px;
}
ul.inner li {
	margin:0 0 0 8%;
	display:inline-block;
	line-height:1;
}
ul.inner li:nth-child(1) {
	display:none;
}
ul.inner li:nth-child(6) {
	position:absolute;
	top:5px;
	right:0;
	font-size:1.2rem;
}
nav .inner > li i {
	padding-right:5px;
	display:inline-block;
}
nav .inner > li {
    border:none;
    font-size: 1.4rem;
    padding: 0;
}
nav .inner > li > a {
	color:#333;
}
nav .inner > li > a:hover {
	color:#ccc;
}
footer p.page-top {
    position: absolute;
  	top: 100px;
    right: 30px;
}
footer > div p {
	text-align:right;
}

}


footer address {
    text-align: center;
}
footer address dl {
    font-size: 1.3rem;
    margin-top: 5px;
}
@media print, screen and (min-width: 600px) {
    footer address {
        text-align: left;
        display: flex;
        flex-wrap: wrap;
    }
    footer address strong {
        width: 100%;
    }
    footer address dl {
        margin-right: 30px;
    }
}
@media print, screen and (min-width: 1000px) {
    footer address strong {
        width: auto;
        margin-right: 30px;
    }
}