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

h1.subtitle,
h2.subtitle {
	font-size: 20px;
	line-height: 1.5em;
	padding: 30px 0 10px 0;
}

.df {
	display: none;
}

span.sp {
	display: inline;
}

div.sp {
	display: block;
}

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

p {
	line-height: 1.8em;
}

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

p.spjustify {
	text-align: justify;
}

/***********************************************************************/

table.list-table th {
	display: block;
	padding: 5px 15px;
	width: auto;
}

table.list-table td {
	display: block;
	padding: 10px 15px 30px 15px;
}

ul.inkantype {
	display: block;
}

ul.inkantype li {
	margin: 0 0 40px 0;
	padding: 0 30px 20px 30px;
	width: 100%;
}

ul.inkantype li h2 {
	font-family: YuMincho, "Yu Mincho", serif;
	font-size: 30px;
}

ul.set {
	display: block;
}

ul.set li {
	margin: 0 20px 30px 20px;
}

ul.set li h2 {
	font-size: 28px;
}

ul.set li p {
	font-size: 16px;
}

div.warranty10year {
	padding: 30px 20px 40px 20px;
}

div.warranty10year h2 {
	font-size: 25px;
}

div.warranty10year div.mark {
	float: right;
	padding: 20px 0 0 20px;
	position: static;
}

div.warranty10year div.mark img {
	height: auto;
	width: 100px;
}

div.scrollhint {
	background-color: #f2e8e4;
	border: 2px solid #d4bba2;
	border-right: 0;
	overflow: auto;
	padding: 10px;
	white-space: nowrap;
}

/***********************************************************************/

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

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

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

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

table.form-table td.m {
	border: none;
	display: block;
	padding: 2px;
	position: absolute;
	right: 30px;
	top: 5px;
}

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

select {
	width: 100%;
}

input.submit {
	display: block;
	font-size: 24px;
	margin: 0 auto;
	padding: 18px 0;
	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;
}

/***********************************************************************/

ul.bloglist {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

ul.bloglist li {
	margin: 10px 0;
	width: 48%;
}

ul.bloglist li a {
	margin: 0;
	padding: 10px;
	width: 100%;
}

ul.bloglist li a span.category span,
body#single span.category span a,
ul.footercategory li span a {
	width: auto;
}

ul.footercategory {
	display: block;
	text-align: center;
}

ul.footercategory li {
	display: inline-block;
}

div.page a.next {
	display: inline;
	padding: 8px 50px 8px 30px;
}

div.page a.prev {
	display: inline;
	padding: 8px 30px 8px 50px;
}

div.category {
	padding: 0 30px;
}

div.category span {
	display: block;
	padding: 5px 0;
}

div.category span a {
	display: block;
}

body#single h1 {
	font-size: 26px;
	line-height: 1.5em;
	padding: 16px;
}

body#single p.datecategory {
	margin: 20px 0 0 0;
}

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

body#single div.body h2 {
	font-size: 20px;
}

body#single div.body figure {
	height: auto;
	margin: 10px 0;
	padding: 0;
	width: auto;
}

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

body#single div.body figure figcaption {
	font-size: 14px;
	line-height: 1.5em;
}

/***********************************************************************/

#header {
	height: 54px;
}

#header-icon {
	left: 10px;
	position: absolute;
	top: 7px;
}

#header-icon img {
	height: auto;
	width: 40px;
}

#header-logo {
	padding-top: 5px;
	position: static;
	text-align: center;
	transform: translateX(0%);
	width: 100%;
}

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

#header h1 {
	font-size: 12px;
	padding: 40px 0 10px 5px;
	text-align: justify;
}

#hamburger {
	display: inline;
	height: 50px;
	position: absolute;
	right: 10px;
	top: 2px;
	width: 50px;
	z-index: 3;
}

#hamburger:hover {
	cursor: pointer;
	opacity: .7;
}

#hamburger span,
#hamburger span:before,
#hamburger span:after {
	background: #3b0e09;
	display: block;
	height: 2px;
	position: absolute;
	transition-duration: .3s;
	transition-property: transform;
	width: 35px;
}

#hamburger span {
	left: 50%;
	top: 50%;
	transform: translate( -50%, -50% );
}

#hamburger span:before {
	content: "";
	transform: translateY( -10px ) rotate( 0deg );
}

#hamburger span:after {
	content: "";
	transform: translateY( 10px ) rotate( 0deg );
}

#hamburger.open span {
	background: transparent !important;
}

#hamburger.open span:before {
	transform: rotate( 45deg ) !important;
}

#hamburger.open span:after {
	transform: rotate( -45deg ) !important;
}

#globalnav {
	background-color: white;
	border-top: 3px solid white;
	display: none;
	padding-top: 5px;
	position: absolute;
	width: 100%;
	z-index: 2;
}

nav#globalnav ul {
	border-top: 1px solid #d6d6d6;
	display: block;
	padding: 0;
	width: auto;
}

nav#globalnav ul li {
	border-bottom: 1px solid #d6d6d6;
	display: block;
	padding: 0;
}
nav#globalnav ul li:nth-child(1),
nav#globalnav ul li:nth-child(2),
nav#globalnav ul li:nth-child(9),
nav#globalnav ul li:nth-child(10) {
	position: static;
}


nav#globalnav ul li a {
	background: white url(images/link_btn.svg) no-repeat right 30px center;
	background-size: 18px;
	font-size: 16px;
	padding-bottom: 10px;
	padding-top: 10px;
}

nav#globalnav ul li a:hover {
	background-color: #efdec3;
	background-position: right 25px center;
}

nav#globalnav ul li a:after {
	display: none;
}

nav#globalnav ul li a em {
	display: none;
}

nav#globalnav a#header-onlineshop {
	display: block;
	height: auto;
	margin: 10px;
	padding: 20px 54px 20px 44px;
	position: static;
	text-align: center;
}

#title {
	padding: 50px 0;
}

#title h1,
#title p:first-child {
	font-size: 30px;
}

#title p:last-child {
	font-size: 15px;
	margin: 0;
}

#title-s {
	padding: 20px 0 5px 0;
}

div.main,
div.main-s,
div.main-w,
div.spmain {
	padding: 0 20px;
	width: auto;
}

#footer {
	display: block;
	padding: 30px 20px 0 20px;
	width: 100%;
}

#footer h3 {
	text-align: center;
}

p#footer-tel {
	font-size: 14px;
	padding-top: 10px;
}

p#footer-tel span {
	font-size: 18px;
	margin-left: 5px;
}

p#footer-contact {
	padding-top: 0;
}

ul#footer-sns {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	padding-top: 20px;
}

ul#footer-sns li {
	margin: 0 12px;
}

nav#footernav {
	padding-top: 30px;
}

nav#footernav ul {
	display: block;
	height: auto;
}

nav#footernav ul li a {
	display: block;
	font-family: YuMincho, "Yu Mincho", serif;
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 1px;
	padding: 10px 14px;
	position: relative;
	text-decoration: none;
	writing-mode: horizontal-tb;
}

nav#footernav ul li a {
	background: white url(images/link_btn.svg) no-repeat right 30px center;
	background-size: 16px;
	border-bottom: 1px solid #d6d6d6;
}

nav#footernav ul li a:hover {
	background-color: #efdec3;
	background-position: right 25px center;
}

nav#footernav ul li a:after {
	display: none;
}

nav#footernav ul li a:hover:after {
	transform: scaleY(1);
}

nav#footernav ul li a em {
	display: none;
}

#footer-online {
	position: static;
}

#footer-online p a.link-btn {
	background-size: 60px, 22px;
	font-size: 20px;
	padding: 10px 65px 10px 85px;
}

#footer-online p a.link-btn:hover {
	background-size: 60px, 22px;
}

#footer-online p a.link-btn em {
	display: block;
	font-size: 12px;
	line-height: 1.4em;
}

#footer-online p:last-child {
	font-size: 11px;
}

#footer-copy {
	background-color: #585858;
	padding: 5px;
}

#footer-copy p {
	color: white;
	font-size: 11px;
	padding-left: 20px;
	width: auto;
}

#pagetop {
	position: static;
}

#pagetop div {
	position: relative;
}

#pagetop div a {
	bottom: -20px;
	position: absolute;
	right: 20px;
}

#pagetop a {
	background-size: 12px;
	font-size: 14px;
	height: 60px;
	padding-top: 30px;
	width: 60px;
}

#pagetop a:hover {
	background-size: 12px;
}
