/*
 Theme Name: Nagisa Kodomo En
 Description: The custom theme of Nagisa Kodomo En using the parent theme Twenty Seventeen.
 Author: Hide Sodeyama
 Author URI: dessodesign.com
 Template: twentyseventeen
 Version: 1
 */
 
 
 @media screen and (min-width: 48em) {
.site-title {
    font-size: 64px;
    font-size: 6rem;
}
}

/*===============================================================
1.0 Global
===============================================================*/

body {
	background: #f8f9ea url(images/bg_topbar.png) repeat-x center -4px;
}
body, p, li, span, h1, h2, h3, h4, h5, h6, button, input, select, textarea {
    color: #606060;
}
.site {
	overflow: hidden;
}
p {
	line-height: 1.8;
}
a {
	transition: opacity .2s ease;
	opacity: 1;
}
a:hover {
	opacity: 0.5;
}
main a {
	color: #3671dd;
}
main a:hover {
	color: #777;
}
.bg-pink { background-color: #f38482; }
.bg-purple { background-color: #988bc2; }
.bg-yellow { background-color: #f9cf4d; }
.bg-blue { background-color: #40c5e7; }
.bg-green { background-color: #60c3a9; }

/* Clearings
-------------------------------------------------------------- */
.clearfix:before, .clearfix:after { 
	content: ""; 
	display: table; 
}
.clearfix:after { 
	clear: both; 
}
.clearfix { 
	zoom: 1; 
}

/* Image Gallery
-------------------------------------------------------------- */
.gallery-item {
    text-align: center;
    margin: 1em 0;
    padding: 0;
    width: 100%;
}
.gallery-item a img {
	border-radius: 50%;
}
.gallery-caption {
    text-align: center;
    padding: 5px 0;
    font-style: normal;
}

/*===============================================================
1.0 Header
===============================================================*/

/* Branding
---------------------------------------------------------------*/
.site-logo-container {
	background: #f7f3ce url(images/bg_topbar.png) repeat-x center -10px;
}
a.site-logo {
	display: block;
	padding-top: 1.5em;
	background: none;
	text-align: center;
}
	.page-template-page-home a.site-logo {
		background: url(images/bg_site_logo_wave.png) repeat-x center bottom -26px;
	} 
a.site-logo:hover {
	opacity: 1;
}
.img-site-logo {
	display: block;
	width: 150px;
	height: auto;
	margin: 0 auto;
	margin-bottom: 1em;
}
	.page-template-page-home .img-site-logo {
		width: 75%;
		max-width: 220px;
		margin: 0 auto;
		margin-bottom: 1em;
	} 
.site-title-tag {
	display: block;
	font-size: 18px;
	font-size: 1.125rem;
	line-height: 1;
}
.site-title-name {
	margin-top: 12px;
	margin-bottom: 0;
	padding: 0 0 30px;
	font-size: 36px;
	font-size: 2.25rem;
	line-height: 1;
}
.site-title-prefix {
	padding-right: 0.4em;
	font-size: 18px;
	font-size: 1.125rem;
	vertical-align: middle;
}
.page-template-page-home a.site-logo .phone_address {
	display:block;
	padding: 0 0 18px;
}
	a.site-logo .phone_address {
		display:none;
	}
a.site-logo .phone_address .site-title-phone {
	display: block;
	font-size: 24px;
	font-size: 1.5rem;
}	
.floating-dot {
	display: none;
}

@media (min-width: 960px) {
	.site-header {
		max-width: 1200px;
		height: 220px;
		margin: 0 auto;
		background-color: transparent;
		overflow: visible;
	}
	.site-logo-container {
		position: absolute;
		top: -35px;
		left: 40px;
		background: none;
		z-index: 100;
	}
	a.site-logo {
		width: 330px;
		height: 330px;
		padding-top: 36px;
		border-radius: 50%;
		overflow: hidden;
		background: #f7f3ce url(images/bg_site_logo_wave.png) repeat-x center top 226px;
		color: #454545;
	}
	.page-template-page-home a.site-logo {
		background-color: #f7f3ce;
	} 
	.img-site-logo {
		width: 220px;
		height: auto;
		margin-bottom: 12px;
	}
	.site-title-tag {
		font-size: 16px;
		font-size: 1rem;
	}
	.site-title-name {
		padding: 0 0 20px;
	}
	.site-title-prefix {
		font-size: 16px;
		font-size: 1rem;
	}
	a.site-logo .phone_address {
		display:block;
		padding: 0;
	}
	a.site-logo .phone_address .site-title-phone {
		display: block;
		font-size: 24px;
		font-size: 1.5rem;
	}
	a.site-logo .phone_address .site-title-address {
		display: block;
	}
	.floating-dot {
		display: block;
		position: absolute;
		border-radius: 50%;
		z-index: 200;
	}
	.dot-pink {
		width: 24px;
		height: 24px;
		left: 24px;
		bottom: -16px;
	}
	.dot-purple {
		width: 60px;
		height: 60px;
		left: 338px;
		top: 50px;
	}
	.dot-yellow {
		display: none;
	}
	.dot-blue {
		width: 40px;
		height: 40px;
		left: -66px;
		top: 114px;
	}
	.dot-green {
		width: 28px;
		height: 28px;
		left: 500px;
		top: 36px;
	}
}
@media (min-width: 1024px) {
	.dot-yellow {
		display: block;
		width: 42px;
		height: 42px;
		left: 420px;
		top: 144px;
	}
}

/* Main Navi
---------------------------------------------------------------*/
.navigation-top {
	background-color: transparent;
	border: none;
    left: auto;
    right: 0;
    width: auto;
}
.navigation-top .wrap {
	padding: 0;
}
.navigation-top ul#top-menu {
	list-style: none;
}
.navigation-top ul#top-menu li {
	float: left;
}
.navigation-top ul#top-menu li a {
	display: block;
	width: 112px;
	padding: 90px 0 24px;
	font-size: 16px;
    font-size: 1rem;
    line-height: 1;
	text-align: center;
	transition: opacity .25s ease;
	opacity: 1;
	color: inherit;
}
.navigation-top ul#top-menu li a:hover {
	opacity: 0.6;
}
.navigation-top ul#top-menu li#menu-item-34 a {
	background: url(images/icon_menu_home.png) no-repeat center top;
}
.navigation-top ul#top-menu li#menu-item-37 a {
	background: url(images/icon_menu_about.png) no-repeat center top;
}
.navigation-top ul#top-menu li#menu-item-36 a {
	background: url(images/icon_menu_calendar.png) no-repeat center top;
}
.navigation-top ul#top-menu li#menu-item-35 a {
	background: url(images/icon_menu_entry.png) no-repeat center top;
}
.navigation-top ul#top-menu li#menu-item-136 a {
	background: url(images/icon_menu_blog.png) no-repeat center top;
}

/* Responsive Menu
---------------------------------------------------------------*/
.responsive-menu-container {
	opacity: 0.9
}
button#responsive-menu-button {
    width: 64px !important;
    height: 64px !important;
    right: 15px !important;
    background: #6b59a6 !important;
    border-radius: 50%;
    opacity: 0.9
}
.responsive-menu-open button#responsive-menu-button:hover,
.responsive-menu-open button#responsive-menu-button:focus,
button#responsive-menu-button:hover, 
button#responsive-menu-button:focus {
    background: #6b59a6 !important;
}
.responsive-menu-button:before {
	display: block;
	content: "MENU";
	font-family: "新丸ゴ R";
	font-size: 10px;
	font-size: 0.625rem;
	color: #fff;
}

/* Sub Navi
---------------------------------------------------------------*/
.header-sub-menu {
	position: absolute;
	right: 20px;
	top: 40px;
}
@media (min-width: 1240px) {
	.header-sub-menu {
		right: 0;
	}
}
.header-sub-menu ul#menu-header-sub-menu {
	margin: 0;
	list-style: none;
}
.header-sub-menu ul#menu-header-sub-menu li {
	float: left;
	margin-left: 1.25em;
}
.header-sub-menu ul#menu-header-sub-menu li a {
	display: block;
	margin: 0;
	padding: 0;
	font-size: 14px;
    font-size: 0.875rem;
    line-height: 16px;
	color: #888 !important;
}

.header-sub-menu ul#menu-header-sub-menu li#menu-item-43 a:before {
	display: none;
	font-family: "Font Awesome 5 Solid";
	content: "\f3c5";
}
.header-sub-menu ul#menu-header-sub-menu li#menu-item-43 a .fa-map-marker-alt {
	font-size: 1.125em;
	margin-right: 0.3em;
}
.header-sub-menu ul#menu-header-sub-menu li#menu-item-42 a:before {
	display: none;
	font-family: "Font Awesome 5 Solid";
	content: "\f2b6";
}
.header-sub-menu ul#menu-header-sub-menu li#menu-item-42 a .fa-envelope-open {
	margin-right: 0.3em;
}
.header-sub-menu ul#menu-header-sub-menu li#menu-item-1813 a:before {
	display: none;
	font-family: "Font Awesome 5 Solid";
	content: "\f007";
}
.header-sub-menu ul#menu-header-sub-menu li#menu-item-1813 a .fa-user {
	margin-right: 0.3em;
}

/*===============================================================
1.0 CONTENT AREA
===============================================================*/

.site-content {
	padding-top: 0;
}
.site-content .wrap {
   max-width: 1200px;
   padding: 25px 15px;
}
.site-content-contain {
	background-color: transparent;
}

@media (min-width: 768px) {
	.site-content .wrap {
		padding: 45px 30px;
	}
}

.page:not(.home) #content {
    padding-bottom: 0;
}

/*===============================================================
1.0 FOOTER
===============================================================*/

.site-footer {
	position: relative;
	margin-top: -16px;
	border: none;
}

.page-template-page-home .site-footer {
		margin-top: 0;
	}
@media (min-width: 768px) {
	.page-template-page-home .site-footer {
		margin-top: -20px;
	}
}
.footer-wave {
	height: 24px;
	background: url(images/bg_footer.png) repeat-x center top;
}
.footer-full-width {
	background-color: #49cc96;
}
.site-footer .wrap {
	padding: 2.5em 1em 4em;
	text-align: center;
}
.footer-col-lt {
	margin-bottom: 40px;
}

@media (min-width: 768px) {
	.footer-col-lt,
	.footer-col-rt {
		float: left;
		width: 50%;
		padding: 0 2em;
	}
}

h1.footer-h1 {
	margin: 12px 0 0;
	padding: 0;
}
h1.footer-h1 span {
	color: #fff;
}
.footer-h1 .sub-heading {
	font-size: 0.5em;
}
.site-footer .phone_address {
	margin-top: 0.5em;
}
.site-footer .phone_address .site-title-phone {
	display: block;
	font-size: 24px;
	font-size: 1.5rem;
	color: #fff;
}
.site-footer .phone_address .site-title-address {
	display: block;
	color: #fff;
}

.site-footer .supporters {
	background: url(images/icon_menu_supporter.png) no-repeat center 10px;
}
.site-footer .supporters .heading-supporters {
	margin: 0;
	padding: 100px 0 0.75em;
	color: #fff;
}
.site-footer .supporters ul {
	list-style: none;
}
.site-footer .supporters ul li {
	margin-bottom: 10px;
	line-height: 1;
}
.copyright {
	display: block;
	margin-top: 30px;
	font-family: "HelveticaNeue", "Helvetica Neue", Helvetica;
	color: #fff;
}
.copyright span {
	display: inline-block;
}

/*===============================================================
1.0 HOME
===============================================================*/

.home-h2 {
	font-size: 26px;
    font-size: 1.625rem;
}

/* Slider
---------------------------------------------------------------*/
.slider-home-wrap {
	background: url(images/bg_slider.png) repeat center center;
}
.slider-home {
	max-width: 1200px;
	margin: 0 auto;
}

/* Main Content - Frame
---------------------------------------------------------------*/
.home-main-content {
	position: relative;
}
.home-wrap {
	padding-bottom: 0 !important;
}

/* Main Content - Intro
---------------------------------------------------------------*/
.home-intro {
	position: relative;
}
.home-intro p {
	margin-bottom: 1em;
	font-size: 21px;
	line-height: 1.8;
	color: #f38482;
}
.home-link-about {
	text-align: center;
}
.home-link-about a {
	display: block;
}
.home-link-about img {
	width: 60px;
	height: auto;
	vertical-align: middle;
}
.home-link-about span {
	display: inline-block;
	padding-right: 36px;
	font-size: 20px;
	font-size: 1.25rem;
	background: url(images/arrow_sm_purple.png) no-repeat right center;
	background-size: 30px 30px;
	line-height: 60px;
	vertical-align: middle;
}
@media (min-width: 768px) {
	.home-intro {
		padding-left: 460px;
		padding-bottom: 60px;
	}
}
@media (min-width: 980px) {
	.home-intro {
		padding-left: 500px;
		padding-right: 130px;
		padding-bottom: 0;
	}
	.home-intro p {
		margin-bottom: 1.5em;
	}
	.home-link-about {
		width: 120px;
		position: absolute;
		right: -16px;
		top: 0;
		text-align: left;
	}
	.home-link-about img {
		width: 120px;
		vertical-align: baseline;
	}
	.home-link-about span {
		display: block;
		width: 110px;
		margin: 0 auto;
		padding-right: 0;
		background-size: 24px 24px;
		font-size: 16px;
		font-size: 1rem;
		line-height: 36px;
		vertical-align: baseline;
	}
}

/* Main Content - Latest News
---------------------------------------------------------------*/
.news-list-wrap-home {
	 margin-top: 40px;
 }
.news-list-wrap-home .news-container-balloon {
	margin-left: -200px;
	margin-right: -200px;
	background: #c9ecf9 url(images/icon_menu_news.png) no-repeat center 20px;
}
.news-list-wrap-home .home-h2 {
	margin-bottom: 0.4em;
	padding-top: 100px;
	text-align: center;
}
.news-list-wrap-home .news-list-container {
	margin-left: 215px;
	margin-right: 215px;
	padding: 0 0 30px 0;
}
.news-list-wrap-home .news-list-container ul {
	list-style: none;
	margin: 0;
}
.news-list-wrap-home .news-list-container ul li {
	padding-bottom: 3px;
	border-bottom: #fff 2px dotted;
}
.news-list-wrap-home .news-list-container ul li a {
	display: block;
	margin-top: 2px;
	background: url(images/arrow_sm_blue.png) no-repeat right 50%;
	line-height: 1.4;
}
.news-list-wrap-home .news-list-container .news-date {
	font-size: 14px;
	font-size: 0.875rem;
	color: #40c5e7;
}
.news-list-wrap-home .news-list-container .news-title {
	margin: 0;
	margin-right: 36px;
	padding: 0;
	font-size: 18px;
	font-size: 1.125rem;
}
.news-list-wrap-home .news-link-archive-wrap {
	text-align: center;
}
.news-list-wrap-home .news-link-archive {
	display: inline-block;
	height: 40px;
	margin: 1em auto 0;
	padding-right: 30px;
	font-size: 16px;
	font-size: 1rem;
	line-height: 40px;
	background: url(images/arrow_sm_blue.png) no-repeat right center;
	background-size: 24px 24px;
}
		
@media (min-width: 768px) {
	.news-list-wrap-home {
		position: absolute;
		left: -60px;
		top: -110px;
		margin: 0;
		height: 780px;
		background: url(images/bear.png) no-repeat center 495px;
		z-index: 10;
	}
	.news-list-wrap-home .news-container-balloon {
		width: 500px;
		height: 500px;
		margin: 0;
		border-radius: 50%;
		background: #c9ecf9 url(images/icon_menu_news.png) no-repeat center 20px;
	}
	.news-list-wrap-home .news-list-container {
		width: 330px;
		margin: 0 auto;
		padding: 0;
	}
	.news-list-wrap-home .news-list-container .news-date {
		font-size: 12px;
		font-size: 0.75rem;
	}
	.news-list-wrap-home .news-list-container .news-title {
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
		max-width: 280px;
	}
}

/* Main Content - Latest Blog
---------------------------------------------------------------*/
.blog-list-wrap-home .blog-container-balloon {
	background: url(images/icon_menu_blog.png) no-repeat center top 20px;
}
.blog-list-wrap-home .home-h2 {
	margin-bottom: 0.3em;
	padding-top: 100px;
	text-align: center;
}
.blog-list-wrap-home .home-blog-tagline {
	margin-bottom: 0;
	text-align: center;
	font-size: 16px;
	font-size: 1rem;
}
.blog-list-wrap-home .blog-list-container ul {
	list-style: none;
	margin: 0;
	padding-bottom: 2em;
	border-bottom: #fff 2px dotted;
}
.blog-list-wrap-home .blog-list-container ul li {
	margin: 36px 0 0;
}
.blog-list-wrap-home .blog-list-container ul li a {
	display: block;
	background: url(images/arrow_sm_green.png) no-repeat right 20px top 165px;
}
.blog-list-wrap-home .blog-img img {
	display: block;
	width: 200px;
	height: 200px;
	margin: 0 auto;
	border-radius: 50%;
	object-fit: cover;
}
.blog-list-wrap-home .blog-list-container .blog-date {
	display: block;
	margin-top: 0.5em;
	padding: 0 20px;
	font-size: 14px;
	font-size: 0.875rem;
	color: #60c3a9;
	text-align: center;
}
.blog-list-wrap-home .blog-list-container .blog-title {
	margin: 0.5em 0 0;
	padding: 0 20px;
	font-size: 18px;
	font-size: 1.125rem;
	text-align: center;
}
.blog-list-wrap-home .blog-link-archive-wrap {
	text-align: center;
}
.blog-list-wrap-home .blog-link-archive {
	display: inline-block;
	height: 40px;
	margin: 20px auto;
	padding-right: 30px;
	font-size: 16px;
	font-size: 1rem;
	line-height: 40px;
	background: url(images/arrow_sm_green.png) no-repeat right center;
	background-size: 24px 24px;
}
@media (min-width: 768px) {
	.blog-list-wrap-home .blog-container-balloon {
		width: 800px;
		margin-right: -40px;
		background: 
			url(images/icon_menu_blog.png) no-repeat center top 20px,
			url(images/bg_home_blog.png) no-repeat center top;
		float: right;
	}
	
	.blog-list-wrap-home .blog-list-container {
		width: 700px;
		margin: 20px auto 0;
		padding-bottom: 15px;
	}
	.blog-list-wrap-home .blog-list-container ul {
		padding-bottom: 1.125em;
	}
	.blog-list-wrap-home .blog-list-container ul li {
		width: 32%;
		margin: 0 2% 0 0;
		float: left;
	}
	.blog-list-wrap-home .blog-list-container ul li:last-child {
		margin-right: 0;
	}
	.blog-list-wrap-home .blog-list-container ul li a {
		background-position: right 20px top 185px;
	}
	
	.blog-list-wrap-home .blog-list-container .blog-date {
		display: inline-block;
		margin-top: 0;
		font-size: 12px;
		font-size: 0.75rem;
		text-align: left;
	}
	.blog-list-wrap-home .blog-list-container .blog-title {
		margin: 0;
		text-align: left;
	}
}

/*===============================================================
1.0 PAGE
===============================================================*/

/* Global - Page Header
---------------------------------------------------------------*/
.page-header {
	position: relative;
	height: 140px;
	margin-bottom: 0 !important;
	background: url(images/bg_title_yellow.png) repeat center center;
}
.page-header .content-title {
	margin: 0;
	font-size: 40px !important;
	font-size: 2.5em !important;
	text-align: center;
	line-height: 140px;
	color: inherit !important;
}

/* Global - Page Header Icon
---------------------------------------------------------------*/
.page-header .page-icon {
	position: absolute;
	left: 50%;
	top: -16px;
	width: 60px;
	height: 60px;
	margin-left: -30px;
	background-size: cover;
}
@media (min-width: 768px) {
	.page-header .page-icon {
		left: auto;
		right: 100px;
		top: 50px;
		width: 120px;
		height: 120px;
		margin: 0;
	}
}

/* Global - Layout
---------------------------------------------------------------*/
.page .page-section-wrap-full-width:nth-of-type(even) {
	background: rgba(0,0,0,0.04);
}
.page .page-section-wrap-full-width:last-of-type {
	padding-bottom: 2em;
}
.page-section {
	max-width: 740px;
	margin: 0 auto;
	padding: 4em 2em;
}
.page-section.page-section-wide {
	max-width: 1200px;
}
.page-section p:last-child {
	margin-bottom: 0;
}

/* Global - Typography
---------------------------------------------------------------*/
.page-h2 {
	font-size: 36px;
	font-size: 2.2rem;
	text-align: center;
}
.page-h3 {
	font-size: 24px;
	font-size: 1.5rem;
	text-align: center;
	margin-bottom: 1.125em;
}

/* Global - Widget
---------------------------------------------------------------*/
.widget-title {
	font-size: 24px;
	font-size: 1.5rem;
	text-align: center;
	margin-bottom: 1.125em;
}
.widget-container {
	text-align: center;
}
.widget_archive ul {
	display: inline-block;
	list-style: none;
	text-align: left;
}
.widget_archive select {
	border-radius:50vh;
	border-right: 16px solid #fff;
    border-left: 16px solid #fff;
    border-top: none;
    border-bottom: none;
}

/* Global - Table
---------------------------------------------------------------*/
.page-table {
	margin: 0;
}
.page-table th,
.page-table td {
	padding: 0.8em;
	border-bottom: #ddd 1px solid;
	vertical-align: top;
}
th:first-child, td:first-child {
    padding-left: 0.4em;
}
th:last-child, td:last-child {
	padding-right: 0.4em;
}

/* Global - WP Page Navi
---------------------------------------------------------------*/
.wp-pagenavi-wrap {
	text-align: center;
}
.wp-pagenavi {
	margin-top: 40px;
}
.wp-pagenavi a, 
.wp-pagenavi span {
	display: inline-block;
	width: 3em;
	height: 3em;
	margin: 4px;
	padding: 0;
	background-color: #60c3a9; 
	border: none;
	border-radius: 50%;
	line-height: 3em;
	text-align: center;
    text-decoration: none;
    color: #fff;
}
.page-template-page-news-home .wp-pagenavi a:not(.previouspostslink):not(.nextpostslink), 
.page-template-page-news-home .wp-pagenavi span {
	background-color: #40c5e7; 
}
.wp-pagenavi a:hover, 
.wp-pagenavi span.current {
    color: #fff;
    opacity: 0.5;
}
.wp-pagenavi span.extend {
	width: 1em;
	background-color: transparent; 
	border-radius: 0;
	color: #555;
}
.wp-pagenavi .previouspostslink,
.wp-pagenavi .nextpostslink {
	background-color: #ccc;
}

/* About
---------------------------------------------------------------*/
.page-17 .page-header  {
	background-image: url(images/bg_title_purple.png);
}
.page-17 .page-header .page-icon {
	background-image: url(images/icon_menu_about_lg.png);
}
.page-17 .page-section .page-h2 {
	color: #988bc2;
}

.about-greeting-portlait {
	display: block;
	width: 260px;
	height: 260px;
	margin: 0 auto 1.75em;
	border-radius: 50%;
	object-fit: cover;
}
.about-greeting-position {
	display: block;
	text-align: center;
}
.about-greeting-name {
	display: block;
	font-size: 20px;
	font-size: 1.25rem;
	text-align: center;
}

/* Calendar
---------------------------------------------------------------*/
.page-19 .page-header  {
	background-image: url(images/bg_title_blue.png);
}
.page-19 .page-header .page-icon {
	background-image: url(images/icon_menu_calendar_lg.png);
}
.page-19 .page-section .page-h2 {
	color: #40c5e7;
}

/* Entry
---------------------------------------------------------------*/
.page-template-page-entry .page-header  {
	background-image: url(images/bg_title_pink.png);
}
.page-template-page-entry .page-header .page-icon {
	background-image: url(images/icon_menu_entry_lg.png);
}
.page-template-page-entry .page-section .page-h2 {
	color: #f38482;
}
.page-section-entry-intro {
	max-width: 740px;
	margin: 0 auto;
	padding: 4em 2em 0;
}
.page-template-page-entry li {
	margin-top: 1em;
}
.page-template-page-entry th,
.page-template-page-entry td {
	text-align: center;
}
.page-template-page-entry td {
	border-bottom: #ddd 1px solid;
}

/* Blog
---------------------------------------------------------------*/
.page-template-page-blog-home .page-header  {
	background-image: url(images/bg_title_green.png);
}
.page-template-page-blog-home .page-header .page-icon {
	background-image: url(images/icon_menu_blog_lg.png);
}
.page-template-page-blog-home .page-section .page-h2 {
	margin-bottom: 60px;
	color: #60c3a9;
}
.blog-list-wrap-page .blog-list-container ul {
	margin-bottom: -5%;
	list-style: none;
}
.blog-list-wrap-page .blog-list-container ul li {
	margin-bottom: 48px;
}

@media (min-width: 768px) {
	.blog-list-wrap-page .blog-list-container ul li {
		width: 30%;
		margin-right: 5%;
		margin-bottom: 5%;
		float: left;
	}
}
.blog-list-wrap-page .blog-list-container ul li:nth-child(3n) {
	margin-right: 0;
}
.blog-list-wrap-page .blog-list-container ul li a {
	display: block;
	background: url(images/arrow_md_green.png) no-repeat right 20px top 220px;
}
.blog-list-wrap-page .blog-img img {
	display: block;
	width: 240px;
	height: 240px;
	margin: 0 auto 0.5em;
	border-radius: 50%;
	object-fit: cover;
}
.blog-list-wrap-page .blog-list-container .blog-date {
	padding: 0 20px;
	font-size: 16px;
	font-size: 1rem;
	color: #60c3a9;
}
.blog-list-wrap-page .blog-list-container .blog-title {
  	margin: 0;
    padding: 0 20px;
    font-size: 18px;
    font-size: 1.25rem;
}

/* News
---------------------------------------------------------------*/
.page-template-page-news-home .page-header  {
	background-image: url(images/bg_title_blue.png);
}
.page-template-page-news-home .page-header .page-icon {
	background-image: url(images/icon_menu_news_lg.png);
}
.page-template-page-news-home .page-section .page-h2 {
	margin-bottom: 36px;
	color: #40c5e7;
}
.news-list-wrap-page .news-list-container ul {
	margin-bottom: 0;
	list-style: none;
}
.news-list-wrap-page .news-list-container ul li {
	border-bottom: #ddd 2px dotted;
}
.news-list-wrap-page .news-list-container ul li a {
	display: block;
	padding: 1em 0;
	background: url(images/arrow_sm_blue.png) no-repeat right center;
}
.news-list-wrap-page .news-list-container .news-date {
	padding: 0 0 0.25em;
	font-size: 16px;
	font-size: 1rem;
	color: #40c5e7;
}
.news-list-wrap-page .news-list-container .news-title {
  	margin: 0 40px 0 0;
    padding: 0;
    font-size: 18px;
    font-size: 1.25rem;
}

/* Access
---------------------------------------------------------------*/
.page-24 .page-section {
	max-width: 1200px;
}
.iframe-wrap {
    overflow: hidden;
    padding-bottom: 56.25%;
    position: relative;
    height: 0;
}
.iframe-wrap iframe {
    left: 0;
    top: 0;
    height: 100%;
    width: 100%;
    position: absolute;
}

/* 404 Error
---------------------------------------------------------------*/
.error-404 .page-section {
	padding-bottom: 8em;
}
.error-404 .entry-title {
	font-size: 24px !important;
	font-size: 1.5rem !important;
	text-align: center;
	line-height: 140px;
}
.error-404 .page-section p,
.error-404 .page-section form {
	visibility: hidden;
}

/*===============================================================
1.0 SINGLE
===============================================================*/

/* Global
---------------------------------------------------------------*/
.single-featured-image-header-wrap {
	width: 100%;
	background: url(images/bg_title_grey2.png) center top 30px;
}
.single-featured-image-header {
	max-width: 740px;
	margin: 0 auto;
}
.single-content-container {
	padding: 6em 0 3em;
}
.single-content-container .entry-footer {
	display: none;
}
.entry-title {
	font-size: 26px;
	font-size: 1.625rem;
}
.entry-content ul {
	margin-left: 3em;
}
.single-content-container .entry-header .post-date {
	font-size: 14px;
	font-size: 0.875rem;
}
.link-to-list {
	margin-top: 4em;
	padding-top: 3em;
	border-top: #ddd 2px dotted;
	font-size: 18px;
	font-size: 1.125rem;
	text-align: center;
}
.link-to-list a {
	height: 36px;
	padding-right: 36px;
	display: inline-block;
	line-height: 36px;
}

/* Global - Widget Area
---------------------------------------------------------------*/
.widget-wrap {
	background: rgba(0,0,0,0.04);
}
.widget-single {
	padding-bottom: 8.5em;
}
.widget-single .widget-container:first-of-type {
	margin-bottom: 48px;
}
@media (min-width: 768px) {
	.widget-single .widget-container {
		float: left;
		width: 50%;
		margin-bottom: 0;
	}
}
.widget-single .widget_recent_entries ul {
	max-width: 400px;
	margin: 0 auto;
	list-style: none;
}
.widget-single .widget_recent_entries ul li {
	position: relative;
	padding: 26px 0 4px;
	border-bottom: #fff 2px dotted;
	text-align: left;
}
.widget-single .widget_recent_entries ul li a {
	font-size: 16px;
    font-size: 1rem;
}
.widget-single .widget_recent_entries .post-date {
    position: absolute;
    left: 0;
    top: 6px;
    font-size: 13px;
    font-size: 0.8125rem;
    color: #777;
}

/* Blog
---------------------------------------------------------------*/
.single-blog .page-header  {
	background-image: url(images/bg_title_green.png);
}
.single-blog .page-header .page-icon {
	background-image: url(images/icon_menu_blog_lg.png);
}
.single-blog .single-content-container {
	padding-top: 3em;
}
.single-blog .page-section .page-h2 {
	color: #60c3a9;
}
.single-blog .single-content-container .entry-header .post-date {
	color: #60c3a9;
}
.single-blog .link-to-list a {
	background: url(images/arrow_sm_green.png) no-repeat right center;
}

/* News
---------------------------------------------------------------*/
.single-news .page-header  {
	background-image: url(images/bg_title_blue.png);
}
.single-news .page-header .page-icon {
	background-image: url(images/icon_menu_news_lg.png);
}
.single-news .page-section .page-h2 {
	color: #40c5e7;
}
.single-news .single-content-container .entry-header .post-date {
	color: #40c5e7;
}
.single-news .link-to-list a {
	background: url(images/arrow_sm_blue.png) no-repeat right center;
}

/*===============================================================
1.0 ARCHIVE
===============================================================*/

/* Font
---------------------------------------------------------------*/
.archive header .midashi,
.archive footer .midashi,
.archive h2,
.archive h3 {
	font-family: "じゅん 501"
}
.archive header .marugo,
.archive header li,
.archive footer .marugo,
.archive .page-numbers,
.archive .link-to-list,
.archive .widget-single li {
	font-family: "新丸ゴ R";
}

/* Pagenation
---------------------------------------------------------------*/
.archive .nav-links {
	font-size: 0;
}
.archive .pagination {
    border-top: none;
    font-size: 16px;
    font-size: 1rem;
    font-weight: normal;
    padding: 2em 0 0;
    text-align: center;
}
.prev.page-numbers,
.next.page-numbers {
    float: none;
}
.page-numbers,
.prev.page-numbers, 
.next.page-numbers {
	display: inline-block;
    width: 48px;
	height: 48px;
	margin: 4px;
	padding: 0;
	background-color: #60c3a9; 
	border: none;
	border-radius: 50%;
	font-size: 16px;
    font-size: 1rem;
	line-height: 48px;
	text-align: center;
    text-decoration: none;
    color: #fff;
    transition: opacity .2s ease;
}
.prev.page-numbers, 
.next.page-numbers {
	background-color: #ccc;
}
.icon-arrow-left,
.icon-arrow-right {
	visibility: hidden;
}
.prev.page-numbers:before {
	display: none;
	font-family: "Font Awesome 5 Solid";
	content: "\f104";
}
.next.page-numbers:before {
	display: none;
	font-family: "Font Awesome 5 Solid";
	content: "\f105";
}
.page-numbers .svg-inline--fa {
	margin-left: 10px;
}
.prev.page-numbers:focus, 
.prev.page-numbers:hover, 
.next.page-numbers:focus, 
.next.page-numbers:hover {
    background-color: #ccc;
    color: #fff;
}
.prev.page-numbers:hover, 
.next.page-numbers:hover {
    opacity: 0.5;
}
.page-numbers.current,
.page-numbers:hover,
.page-numbers:focus {
    font-size: 16px;
    font-size: 1rem;
    color: #fff;
    opacity: 0.5;
}
.pagination a:not(.prev):not(.next):hover,
.pagination a:not(.prev):not(.next):focus {
	color: #fff;
    -webkit-box-shadow: none;
    box-shadow: none;
}
.pagination a {
	transition: opacity .2s ease;
}
.page-numbers.dots {
	width: 1em;
	background-color: transparent; 
	border-radius: 0;
	color: #555;
}

.archive .link-to-list {
    margin-top: 1em;
}



.post-type-archive-blog .page-header  {
	background-image: url(images/bg_title_green.png);
}
.post-type-archive-blog .page-header .page-icon {
	background-image: url(images/icon_menu_blog_lg.png);
}
.post-type-archive-blog .page-section .page-h2 {
	color: #60c3a9;
}
.post-type-archive-blog .link-to-list a {
	background: url(images/arrow_sm_green.png) no-repeat right center;
}

.post-type-archive-news .page-header  {
	background-image: url(images/bg_title_blue.png);
}
.post-type-archive-news .page-header .page-icon {
	background-image: url(images/icon_menu_news_lg.png);
}
.post-type-archive-news .page-section .page-h2 {
	color: #40c5e7;
}
.post-type-archive-news .link-to-list {
	border: none;
}
.post-type-archive-news .link-to-list a {
	background: url(images/arrow_sm_blue.png) no-repeat right center;
}
