
* {
	border: none;
	margin: 0px;
	padding: 0px;
}

html {
	min-width: 1100px;
	overflow-y: scroll;
}

body {
	color: #545454;
	font-family: Yu Gothic, "Yu Gothic", sans-serif;
	font-size: 95%;
	font-weight: 500;
}

.sp {
	display: none;
}

h1,
h2,
h3,
h4 {
	font-weight: bold;
	text-align: center;
}

h1.copy {
	text-align: left;
}

h2.top-caption {
	font-size: 45px;
	line-height: 1em;
	padding-bottom: 20px;
}

h2.second-title {
	font-size: 28px;
	font-weight: bold;
	padding: 50px 0px 30px 0px;
}

h2.second-title-bg {
	font-size: 28px;
	font-weight: bold;
	padding: 10px 0px 30px 0px;
}

h2.second-title span.border,
h2.second-title-bg span.border {
	border: 3px solid #66bfc6;
	display: block;
	margin: auto;
	margin-top: 10px;
	width: 100px;
}

h3.subtitle {
	font-size: 120%;
	font-weight: bold;
	padding: 15px 0px 2px 0px;
}

h3.data {
	border-bottom: 2px dotted #cc0404;
	color: #cc0404;
	font-size: 130%;
	font-weight: bold;
	margin-bottom: 15px;
	text-align: left;
}

h3.underline {
	border-bottom: 2px solid white;
	color: white;
	font-size: 25px;
	font-weight: bold;
	margin-bottom: 5px;
	padding-bottom: 3px;
	text-align: left;
}

p {
	font-weight: 500;
	letter-spacing: 0.7px;
	line-height: 1.9em;
	margin: 15px 0px;
	text-align: justify;
	text-justify: distribute;
}

p.caption-sub {
	font-size: 18px;
	font-weight: bold;
	text-align: center;
}

p.mn {
	margin: 0px;
}

p.right {
	text-align: right;
}

p.mn-right {
	margin: 0px;
	text-align: right;
}

p.center {
	text-align: center;
}

p.mn-center {
	margin: 0px;
	text-align: center;
}

sup,
sub {
	font-size: 80%;
	line-height: 4px;
	vertical-align: top;
}

a {
	color: #545454;
	overflow: hidden;
}

a:hover {
	filter: alpha(opacity=50);
	-moz-opacity: 0.50;
	-moz-transition: all 0.3s;
	-ms-transition: all 0.3s;
	opacity: 0.50;
	-o-transition: all 0.3s;
	transition: all 0.3s;
	-webkit-transition: all 0.3s;
}

span.link-btn a,
a.link-btn {
	background: url(images/link_btn.png) no-repeat right 20px center;
	background-size: 8px;
	border: 1px solid #545454;
	border-radius: 50px;
	color: #545454;
	font-size: 15px;
	font-weight: bold;
	padding: 15px 110px;
	text-align: center;
	text-decoration: none;
}

span.link-btn a:hover,
a.link-btn:hover {
	background: url(images/link_btn_w.png) no-repeat right 20px center #66bfc6;
	background-size: 8px;
	border: 1px solid white;
	color: white;
	opacity: 1;
}

a.link-btn-w {
	background: url(images/link_btn.png) no-repeat right 20px center white;
	background-size: 8px;
	border-radius: 50px;
	color: #545454;
	font-size: 15px;
	font-weight: bold;
	padding: 18px 110px;
	text-align: center;
	text-decoration: none;
}

a.link-btn-w:hover {
	background-color: #ffcc6c;
	opacity: 1;
}

a.link-btn-o {
	background: url(images/link_btn_w.png) no-repeat right 20px center #ffa800;
	background-size: 8px;
	border-radius: 50px;
	color: white;
	font-size: 15px;
	font-weight: bold;
	padding: 18px 110px;
	text-align: center;
	text-decoration: none;
}

a.link-btn-o:hover {
	background-color: #66bfc6;
	opacity: 1;
}

a.link-btn-prev {
	background: #91cbce url(images/link_btn_prev.png) no-repeat left 12px center;
	background-size: 8px;
	color: white;
	font-weight: normal;
	padding: 10px 30px 10px 45px;
	text-decoration: none;
}

a.link-btn-next {
	background: #91cbce url(images/link_btn.png) no-repeat right 12px center;
	background-size: 8px;
	color: white;
	font-weight: normal;
	padding: 10px 45px 10px 30px;
	text-decoration: none;
}

a.link-btn-s {
	background: url(images/link_btn.png) no-repeat right 15px center;
	background-size: 5px;
	border: 1px solid #545454;
	border-radius: 30px;
	color: #545454;
	font-size: 12px;
	font-weight: bold;
	margin: auto;
	padding: 8px 40px;
	text-align: center;
	text-decoration: none;
}

a.link-btn-s:hover {
	background: url(images/link_btn_w.png) no-repeat right 15px center #66bfc6;
	background-size: 5px;
	border: 1px solid white;
	color: white;
	opacity: 1;
}

a.contact-mail-btn {
	background: url(images/link_btn.png) no-repeat right 20px center,url(images/contact_mail_icon.png)no-repeat left 40px center white;
	background-size: 8px,30px;
	border-radius: 50px;
	color: #545454;
	display: block;
	font-size: 17px;
	font-weight: bold;
	letter-spacing: 1.8px;
	margin: auto;
	margin-top: 40px;
	padding: 23px 0px;
	text-align: center;
	text-decoration: none;
	width: 450px;
}

a.contact-mail-btn:hover {
	background-color: #ffcc6c;
	opacity: 1;
}

ul {
	list-style-type: none;
}

ol {
	line-height: 1.8em;
	margin-left: 14px;
}

ol li {
	padding: 4px 0px 10px 5px;
	text-align: left;
}

sup {
	line-height: 1em;
}

table {
	border-collapse: collapse;
	line-height: 1.8em;
	width: 100%;
}

span.xx-large {
	font-size: 200%;
	line-height: 1.5em;
}

span.x-large {
	font-size: 150%;
	line-height: 1.5em;
}

span.large {
	font-size: 125%;
	line-height: 1.5em;
}

span.small {
	font-size: 85%;
	line-height: 1.4em;
}

span.marker {
	background: linear-gradient(transparent 60%, #faed5c 0%);
}

span.red {
	color: #fdffa6;
	font-weight: bold;
}

ul.list {
	line-height: 1.5em;
	text-align: justify;
	text-justify: distribute;
}

ul.list li {
	background: url(images/ul_list_li.png) no-repeat 5px 12px;
	background-size: 6px;
	display: block;
	padding: 4px 0px 4px 20px;
}

ul.notelist {
	line-height: 1.5em;
	list-style-type: none;
	margin: 5px 0px 0px 1.8em;
}

ul.notelist li {
	line-height: 1.5em;
	padding: 3px 0px;
	text-indent: -1.2em;
}

ul.notelist li span.maker {
	margin-right: 0.2em;
}

div.space10px {
	clear: both;
	font-size: 5px;
	height: 10px;
}

div.space15px {
	clear: both;
	font-size: 5px;
	height: 15px;
}

div.space20px {
	clear: both;
	font-size: 5px;
	height: 20px;
}

div.space50px {
	clear: both;
	font-size: 5px;
	height: 50px;
}

div.photos {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

div.photos a {
	display: block;
	height: auto;
	width: 320px;
}

div.photos img {
	height: auto;
	width: 100%;
}

/***********************************************************************/
table.list-table th {
	background-color: #62b3b9;
	border: 1px solid #898989;
	color: white;
	font-weight: bold;
	padding: 10px 15px;
	text-align: center;
	width: 30%;
}

table.list-table td {
	background-color: white;
	border: 1px solid #898989;
	padding: 10px 25px;
	text-align: left;
	width: 70%;
}

table.list-table td a {
	color: #545454;
	font-weight: 500;
}

/***********************************************************************/
table.form-table {
	border-top: 1px solid white;
}

table.form-table tr {
	border-bottom: 1px solid white;
}

table.form-table th {
	color: white;
	font-weight: bold;
	padding: 15px 10px;
	text-align: center;
	width: 180px;
}

table.form-table td {
	padding: 15px 0px;
	text-align: left;
	width: 600px;
}

table.form-table td select.month {
	margin-bottom: 5px;
}

table.form-table td span.wideform {
	display: block;
	margin: 4px 0px;
}

table.form-table td input,
table.form-table td select {
	font-family: YuGothic, "Yu Gothic", sans-serif;
	font-size: 100%;
	padding: 10px;
}

table.form-table td span.comment {
	padding-left: 10px;
}

table.form-table td.m {
	text-align: center;
	width: 80px;
}

table.form-table td.m span {
	background-color: #ffa800;
	border: 2px solid white;
	border-radius: 60px;
	color: white;
	font-size: 80%;
	font-weight: bold;
	padding: 12px 8px;
}

table.form-table td textarea {
	font-family: YuGothic, "Yu Gothic", sans-serif;
	font-size: 100%;
	padding: 10px;
	width: 600px;
}

form input.submit {
	background: url(images/link_btn_w.png)no-repeat right 20px center #ffa800;
	background-size: 10px;
	border: 2px solid white;
	border-radius: 50px;
	color: white;
	font-family: Yu Gothic, "Yu Gothic", sans-serif;
	font-size: 20px;
	font-weight: bold;
	margin: auto;
	padding: 20px 0px;
	pointer-events: auto;
	width: 400px;
}

form input.submit:hover {
	background: url(images/link_btn_w.png)no-repeat right 20px center #a0a0a0;
	background-size: 10px;
	cursor: pointer;
}

/***********************************************************************/
ul.room-list {
	text-align: center;
}

ul.room-list li {
	display: inline-block;
	font-size: 14px;
	margin: 10px;
	position: relative;
	width: 500px;
}

ul.room-list li div.img {
	display: table-cell;
	vertical-align: middle;
}

ul.room-list li div.img img {
	height: 245px;
	width: 245px;
}

ul.room-list li div.text {
	background-color: white;
	color: #545454;
	display: table-cell;
	padding: 20px 25px;
	vertical-align: middle;
	width: 205px;
}

ul.room-list li div.text h3 {
	border-bottom: 2px solid #545454;
	font-size: 15px;
	margin-bottom: 8px;
	padding-bottom: 8px;
}

ul.room-list li div.text ul.detail {
	padding-bottom: 16px;
}

ul.room-list li div.text ul.detail li {
	margin: 0px;
	text-align: left;
	width: 200px;
}

ul.room-list li div.text a.link-btn-s {
	display: block;
	margin: auto;
	padding: 8px 0px;
	width: 200px;
}

ul.room-list li span.category {
	font-weight: bold;
	left: 0px;
	position: absolute;
	top: 0px;
}

ul.room-list li span.category span {
	padding: 4px 10px;
}

body#single div.single-category span a {
	color: white;
}

ul.room-list li span.category span.family,
body#single div.single-category span.family a,
div.blog-category-list a.family {
	background-color: #ffa800;
}

ul.room-list li span.category span.single,
body#single div.single-category span.single a,
div.blog-category-list a.single {
	background-color: #505895;
}

ul.room-list li span.category span.sf,
body#single div.single-category span.sf a,
div.blog-category-list a.sf {
	background-color: #39ab44;
}

/***********************************************************************/
ul.blog-list {
	margin: 20px 0px 50px 0px;
	text-align: center;
}

ul.blog-list li {
	border: 1px solid #d5d5d5;
	display: inline-block;
	font-size: 14px;
	margin: 0px 20px 30px 20px;
	vertical-align: top;
	width: 340px;
}

ul.blog-list li a {
	color: #545454;
	font-weight: 500;
	text-decoration: none;
}

ul.blog-list li span.img {
	display: block;
	height: 213px;
	margin: auto;
	width: 340px;
}

ul.blog-list li span.img img {
	height: 100%;
	object-fit: cover;
	width: 100%;
}

ul.blog-list li span.category {
	display: block;
	text-align: center;
}

ul.blog-list li span.category span {
	display: block;
}

span.category span a {
	color: white;
	padding: 8px 20px;
	text-decoration: none;
}

a span.category span {
	box-sizing: border-box;
	color: white;
	display: inline-block;
	padding: 5px 10px;
	width: 100%;
}

span.category span.news a,
a span.category span.news {
	background-color: #bb3434;
}

span.category span.diary a,
a span.category span.diary {
	background-color: #62b3b9;
}

span.category span.voice a,
a span.category span.voice {
	background-color: #fc7a7a;
}

span.category span.study a,
a span.category span.study {
	background-color: #ffa800;
}

span.category span.diy a,
a span.category span.diy {
	background-color: #865930;
}

ul.blog-list li div.text {
	background-color: white;
	padding: 20px 20px 15px 20px;
}

ul.blog-list li div.text h3 {
	font-size: 130%;
	font-weight: bold;
	min-height: 60px;
	padding-top: 10px;
	text-align: left;
}

div.blog-category-list {
	text-align: center;
}

div.blog-category-list a {
	color: white;
	display: inline-block;
	font-weight: bold;
	margin: 0px 5px;
	padding: 10px 0px;
	text-decoration: none;
	width: 170px;
}

div.blog-category-list a.news {
	background-color: #bb3434;
}

div.blog-category-list a.diary {
	background-color: #62b3b9;
}

div.blog-category-list a.voice {
	background-color: #fc7a7a;
}

div.blog-category-list a.study {
	background-color: #ffa800;
}

div.blog-category-list a.diy {
	background-color: #865930;
}

/***********************************************************************/
h2.screen-reader-text {
	display: none;
}

div.nav-links span.current {
	background-color: #ffa800;
	color: white;
	padding: 10px;
}

div.page {
	text-align: center;
}

div.page a.page-numbers {
	background-color: white;
	color: #545454;
	font-weight: normal;
	padding: 10px;
	text-decoration: none;
}

div.page span.link-btn-next a,
div.page a.link-btn-next {
	background: #87c6c9 url(images/link_btn.png) no-repeat right 12px center;
	background-size: 6px;
	color: white;
	font-weight: bold;
	padding: 10px 45px 10px 30px;
	text-decoration: none;
}

div.page span.link-btn-prev a,
div.page a.link-btn-prev {
	background: #87c6c9 url(images/link_btn_prev.png) no-repeat left 12px center;
	background-size: 6px;
	color: white;
	font-weight: bold;
	padding: 10px 30px 10px 45px;
	text-decoration: none;
}

/***********************************************************************/
body#single span.category span {
	margin: auto;
	margin-bottom: 5px;
	padding: 4px 0px;
	width: 180px;
}

body#single h1.blogtitle {
	font-size: 25px;
	padding-top: 10px;
}

body#single div.body h2 {
	border-bottom: 2px solid #62b3b9;
	border-left: 20px solid #62b3b9;
	font-size: 22px;
	margin: 20px 0px;
	padding-left: 10px;
	text-align: left;
}

body#single div.body a.link-btn {
	background: url(images/link_btn_w.png) no-repeat right 20px center #66bfc6;
	border: none;
	color: white;
	display: block;
	margin: auto;
	margin-bottom: 30px;
	margin-top: 30px;
	padding: 10px 0px;
	width: 400px;
}

body#single div.body a.link-btn:hover {
	background: url(images/link_btn.png) no-repeat right 20px center #66bfc6;
	border: none;
	color: #545454;
}

body#single div.body figure.wp-block-image {
	margin: 30px 0px;
}

body#single div.body ul {
	text-align: left;
}

body#single div.body ul li {
	background: url(images/ul_list_li.png)no-repeat left top 12px;
	background-size: 6px;
	margin-left: 10px;
	padding: 3px 0px 3px 13px;
}

/***********************************************************************/
#header {
	height: 90px;
	position: relative;
}

#header p#header-copy {
	display: block;
	font-size: 12px;
	font-weight: bold;
	left: 130px;
	margin: 0px;
	position: absolute;
	text-align: center;
	top: 18px;
	width: 220px;
}

#header #header-logo {
	left: 40px;
	position: absolute;
	text-align: center;
	top: 10px;
}

#header #header-logo a {
	text-decoration: none;
}

#header #header-logo img {
	height: auto;
	width: 90px;
}

#header-menu {
	bottom: 23px;
	display: block;
	position: absolute;
	right: 40px;
	width: auto;
}

#sp-icon {
	display: none;
}

ul#menu {
	background: none;
	display: block;
	font-size: 87%;
	font-size: 0px;
	letter-spacing: 1.5px;
	position: static;
}

ul#menu li {
	border-left: 1px solid #c6c6c6;
	display: inline-block;
	font-size: 13px;
}

ul#menu li.sp {
	display: none;
}

ul#menu li:nth-child(6) {
	border-right: 1px solid #c6c6c6;
}

ul#menu li a {
	background: none;
	color: #545454;
	font-weight: bold;
	padding: 0px 25px;
	text-decoration: none;
}

ul#menu li a:hover {
	background: none;
}

#maintitle {
	background-position: center center;
	background-repeat: no-repeat;
	height: 240px;
}

#maintitle #title {
	margin: auto;
	padding-top: 70px;
	text-align: center;
	width: 400px;
}

#maintitle #title a {
	color: #545454;
	text-decoration: none;
}

#maintitle #title img {
	height: auto;
	width: 100%;
}

#maintitle #title em {
	display: block;
	font-size: 16px;
	font-weight: bold;
	letter-spacing: 0.2em;
	line-height: 1.2em;
	padding-top: 10px;
}

div.main {
	margin: 0px auto;
	text-align: center;
	width: 1000px;
}

div.main-s {
	margin: 0px auto;
	text-align: center;
	width: 860px;
}

div.main-blog {
	margin: 0px auto;
	text-align: center;
	width: 800px;
}

div.bg-blue {
	background-color: #66bfc6;
	border-bottom: 2px solid white;
	border-top: 2px solid white;
	color: white;
	padding: 20px 0px;
}

div.bg-blue h2.second-title span.border,
div.bg-blue h2.second-title-bg span.border {
	border: 3px solid #545454;
}

div.bg-slash {
	background: url(images/bg_slash.gif)repeat;
	padding: 20px 0px;
}

div.bg-slash-gray {
	background: url(images/bg_slash_gray.gif)repeat;
	padding: 20px 0px;
}

div.white-container {
	background-color: white;
	border-radius: 20px;
	margin: auto;
	padding: 30px 40px;
	text-align: center;
	width: 880px;
}

#footer {
	text-align: center;
}

#footer #contact {
	background-color: #62b3b9;
	color: white;
	padding: 60px 0px;
}

#footer #contact p {
	text-align: center;
}

#footer #contact p strong {
	font-weight: bold;
}

#footer #contact span.number {
	background: url(images/contact_tel_icon.png)no-repeat left center;
	background-size: 22px;
	font-size: 40px;
	font-weight: bold;
	padding-left: 32px;
}

#footer #contact span.number a {
	font-size: 40px;
	font-weight: bold;
	text-decoration: none;
}

#footer #contact span.time {
	font-weight: bold;
}

#footer #contact div.calendar {
	color: #545454;
	margin: 0px auto;
	padding-top: 30px;
	width: 530px;
}

#footer #contact div.calendar div.table-left {
	float: left;
	width: 260px;
}

#footer #contact div.calendar div.table-right {
	float: right;
	width: 260px;
}

#footer #contact div.calendar table {
	width: 100%;
}

#footer #contact div.calendar table caption {
	background-color: #399397;
	color: white;
}

#footer #contact div.calendar table tr.head td {
	background-color: white;
	color: black;
}

#footer #contact div.calendar table td {
	background: none;
	background-color: white;
	border: 1px solid #b1b1b1;
	font-size: 85%;
	line-height: 1.2em;
	padding: 3px 6px;
	text-align: center;
	width: 14%;
}

#footer #contact div.calendar table td.sun {
	background-color: #ffdbdb;
	color: #ff0000;
}

#footer #contact div.calendar table td.sat {
	background-color: #b7dff4;
	color: #0000ff;
}

#footer #contact div.calendar table td.holiday {
	background-color: #fb6c2e;
	color: white;
}

#footer #contact div.calendar table td strong {
	background-color: #399397;
	color: white;
	padding: 0px 5px;
}

#footer #contact div.calendar span.holiday {
	background-color: #fb6c2e;
	color: white;
	font-size: 85%;
	padding: 3px 15px;
}

#footer #contact div.calendar span.today {
	background-color: #399397;
	color: white;
	font-size: 85%;
	font-weight: bold;
	padding: 3px 15px;
}

#footer #contact #contact-line a {
	background: url(images/link_btn.png) no-repeat right 20px center,
	url(images/footer_line_logo.svg)no-repeat left 38px center white;
	background-size: 8px,
	35px;
	border-radius: 50px;
	color: #545454;
	display: block;
	font-size: 17px;
	font-weight: bold;
	letter-spacing: 1.8px;
	margin: auto;
	margin-top: 40px;
	padding: 15px 0px 15px 30px;
	text-align: center;
	text-decoration: none;
	width: 300px;
}

#footer #contact #contact-line a:hover {
	background-color: #ffcc6c;
	opacity: 1;
}



#footer ul#footernav {
	display: block;
	padding: 23px 0px;
	text-align: center;
}

#footer ul#footernav li {
	border-left: 1px solid #c6c6c6;
	display: inline-block;
	font-size: 95%;
	line-height: 0em;
	padding: 10px 23px;
	text-align: center;
}

#footer ul#footernav li:last-child {
	border-right: 1px solid #c6c6c6;
}

#footer ul#footernav li a {
	color: #545454;
	font-weight: bold;
	text-decoration: none;
}

#footer #footer-info {
	margin: auto;
	padding: 60px 0px;
	width: 700px;
}

#footer #footer-info #footer-logo,
#footer #footer-info #footer-info-detail {
	display: table-cell;
	vertical-align: middle;
}

#footer #footer-logo {
	display: block;
	margin: auto;
	width: 180px;
}

#footer #footer-info #footer-info-detail {
	padding-left: 30px;
}

#footer #footer-info #footer-info-detail h4 {
	text-align: left;
}

address {
	font-style: normal;
	font-weight: 500;
	text-align: left;
}

address a {
	color: #545454;
	font-weight: 500;
}

p#copy {
	font-size: 80%;
	line-height: 0em;
	text-align: left;
}

#pagetop {
	bottom: 20px;
	position: fixed;
	right: 20px;
}

#pagetop a {
	display: block;
	height: 100px;
	width: 100px;
}

#pagetop a img {
	height: auto;
	width: 100%;
}

