
body {
	max-width: 480px;
	min-width: 380px;
	-webkit-text-size-adjust: 90%;
}

.df {
	display: none;
}

.sp {
	display: inline;
}

div.sp {
	display: block;
}

.spwideimg {
	height: auto;
	width: 100%;
}

h2.subtitle img {
	height: auto;
	max-width: 250px;
	width: 100%;
}

p {
	line-height: 1.8em;
}

p.spjustify {
	text-align: justify;
}

a:hover {
	filter: alpha(opacity=60);
	-moz-opacity: 0.60;
	opacity: 0.60;
}

body#entry div.body i a,
a.link-btn {
	background-position: right 20px center;
	display: block;
	margin: 5px 0px;
	padding: 10px 20px 10px 20px;
	text-align: center;
}

a.link-btn-prev {
	padding: 10px 50px 10px 70px;
}

ul.list li {
	background-position: 2px 12px;
	padding: 8px 0px 8px 22px;
}

span.img-left,
span.img-right {
	display: block;
	float: none;
	margin: 0px;
	padding-bottom: 10px;
	text-align: center;
}

/***********************************************************************/
div.indent {
	padding-left: 0px;
}

div.en-header,
div.en-footer,
div.enl-header,
div.enl-footer {
	background-image: none;
}

div.en-footer {
	border: 1px solid #e0e0e0;
	padding: 15px;
	width: auto;
}

div.enl-footer {
	border: 1px solid #e0e0e0;
	padding: 15px;
	width: auto;
}

div.mainbtn {
	padding: 0px 10px;
}

div.mainbtn ul li {
	float: left;
	height: auto;
	padding: 3px 0px;
	text-align: center;
	width: 50%;
}

div.mainbtn ul li img {
	height: auto;
	max-width: 312px;
	width: 95%;
}

table.list-table  th {
	line-height: 1.3em;
	padding: 10px 8px;
	text-align: center;
	white-space: nowrap;
	width: auto;
}

table.list-table td {
	line-height: 1.6em;
	padding: 10px 5px 10px 15px;
	white-space: normal;
}

form h2 {
	padding: 10px;
	text-align: center;
}

table.form-table {
	border-top: 0px;
}

table.form-table tr {
	display: block;
	position: relative;
}

table.form-table th {
	border: none;
	display: block;
	font-size: 100%;
	font-weight: bold;
	padding: 10px 0px 10px 5%;
	text-align: left;
	width: 95%;
}

table.form-table td {
	border: none;
	clear: both;
	display: block;
	line-height: 1.5em;
	padding: 10px 2% 30px 5%;
}

table.form-table td.m {
	border: none;
	display: block;
	float: right;
	height: 30px;
	padding: 0px;
	position: absolute;
	right: 10px;
	top: 5px;
	width: 30px;
}

table.form-table td.m span {
	background-color: white;
	color: #202f56;
	display: table-cell;
	font-size: 12px;
	line-height: 1em;
	vertical-align: middle;
}

table.form-table td input.size500,
table.form-table td input.size300,
table.form-table td input.size200 {
	width: 90%;
}

table.form-table td textarea {
	width: 90%;
}

table.form-table td table th {
	background-color: white;
	color: #88724f;
	display: inline-block;
	padding: 5px 20px;
	text-align: right;
	white-space: nowrap;
	width: 30%;
}

table.form-table td table td {
	display: inline-block;
	padding: 5px 0px;
}

input.submit {
	display: block;
	font-size: 24px;
	padding: 18px 5%;
	width: 90%;
}

body#form p.error {
	padding: 30px 20px;
}

body#form table.form-table th,
body#form table.form-table td {
	padding-bottom: 10px;
	padding-top: 10px;
}

body#form table.form-table td {
	padding-bottom: 30px;
	padding-left: 20px;
}

body#form table.form-table td.textarea {
	white-space: pre-wrap;
}

/***********************************************************************/
div.works-list ul li {
	display: block;
	margin: 0px 0px 50px 0px;
}

div.works-list ul li a {
	background: url(images/link_btn.svg) no-repeat right bottom;
	background-size: 30px;
	display: block;
	text-decoration: none;
}

div.works-list ul li a span.img {
	display: block;
}

div.works-list ul li a span.img img {
	height: 150px;
	object-fit: cover;
	width: 100%;
}

div.works-list ul li a span.text {
	display: block;
	margin: auto;
	padding: 10px 0px 0px 0px;
	width: 100%;
}

div.works-list ul li a span.text span.detail {
	display: block;
	padding: 4px 0px 12px 0px;
}

div.works-list ul li a span.text span.category {
	display: inline-block;
}

div.category {
	margin: 0px auto;
	text-align: center;
}

div.category h2 {
	color: #a69081;
}

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

a span.category span {
	box-sizing: border-box;
	color: white;
	font-size: 90%;
	padding: 3px 20px;
}

div.page a.next {
	margin: 30px 0px;
}

div.page a.prev {
	display: inline;
	padding-left: 30px;
}

div.page span.link-btn-prev,
div.page span.link-btn {
	display: block;
	margin-bottom: 40px;
}

body#single h1 {
	font-size: 25px;
}

body#single div.body {
	margin: 0px -15px;
	padding: 20px;
}

body#single div.body h2 {
	font-size: 120%;
}

body#single div.body img {
	height: auto;
	width: 100%;
}

body#single div.body iframe {
	padding: 30px 0px;
	width: 100%;
}

/***********************************************************************/
#header-bg {
	background-position: center top;
	background-repeat: no-repeat;
	background-size: cover;
	height: 280px;
}

#header {
	height: 40px;
	margin: 0px;
	padding: 5px 0px 5px 0px;
	text-align: center;
	width: auto;
}

#header #header-copy {
	font-size: 9px;
	margin: 0px;
	padding: 5px 20px;
}

#header #header-logo {
	display: block;
	left: 50%;
	-ms-transform: translateX(-50%);
	padding-top: 80px;
	top: 0;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
}

#header-menu {
	border-bottom: none;
	height: 0px;
	padding: 0px;
	width: auto;
}

#sp-icon {
	display: inline;
}

ul#globalnav {
	display: none;
	left: 0px;
	list-style-type: none;
	padding: 0px;
	position: absolute;
	text-align: center;
	top: 50px;
	width: 100%;
	z-index: 990;
}

ul#globalnav li {
	background-color: rgba(255,255,255,0.95);
	border-top: 1px solid #d0d0d0;
	display: block;
	height: 60px;
	text-align: center;
}

ul#globalnav li:last-child {
	border-bottom: 1px solid #d0d0d0;
}

ul#globalnav li a {
	color: #434343;
	display: block;
	height: 50px;
	padding-top: 10px;
	text-decoration: none;
}

ul#globalnav li a:hover {
	background-color: #a9a9a9;
	color: #434343;
	opacity: 0.7;
}

ul#globalnav li:first-child a {
	height: 40px;
	padding-top: 20px;
}

#title {
	height: 230px;
	margin: 0px auto;
	padding: 0px;
	position: relative;
	text-align: center;
}

#title h1 {
	background-color: rgb(0,0,0,0.7);
	bottom: 0;
	color: white;
	font-size: 35px;
	padding-top: 25px;
	position: absolute;
	width: 100%;
}

#title h1 em {
	font-size: 12px;
}

#title-s {
	height: 200px;
	margin: 0px auto;
	padding: 0px;
	position: relative;
	text-align: center;
}

#title-s p {
	background-color: rgb(0,0,0,0.7);
	bottom: 0;
	font-size: 20px;
	padding: 20px 0px;
	position: absolute;
	width: 100%;
}

#title-s p a {
	color: white;
}

div.bg-gray {
	padding: 20px 0px;
}

div.main-s,
div.main {
	padding: 0px 25px;
	width: auto;
}

#rightbtn {
	display: none;
}

#rightbtn-sp {
	display: inline;
}

#rightbtn-sp {
	bottom: 115px;
	position: fixed;
	right: 10px;
	z-index: 100;
}

#footer {
	padding-top: 20px;
}

#footer h4 {
	padding: 20px 0px 20px 0px;
}

#footer a.link-btn {
	margin: 0px 30px 40px 30px;
}

#footer ul#footernav {
	background-color: black;
	margin: 0px;
	padding: 0px;
}

#footer ul#footernav li {
	border-bottom: 1px solid white;
	border-left: none;
	display: block;
	padding: 0px;
}

#footer ul#footernav li:last-child {
	border-right: none;
}

#footer ul#footernav li a {
	background-color: #e0e0e0;
	background-size: 20px;
	border: none;
	color: black;
	display: block;
	font-size: 100%;
	font-weight: 600;
	padding: 25px 20px;
	text-decoration: none;
}

#footer ul#footernav li a:hover {
	background-color: rgba(255,255,255,0);
	color: white;
	color: white;
	filter: alpha(opacity=50);
	-moz-opacity: 1;
	opacity: 1;
	text-decoration: none;
}

p#copy {
	font-size: 70%;
}

#pagetop {
	bottom: 60px;
	position: fixed;
	right: 10px;
}

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

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

