@charset "UTF-8";

/* Common */

* { box-sizing:border-box; }
body,div,dl,dt,dd,ul,ol,li,
h1,h2,h3,h4,h5,h6,
form,input,textarea,
p,th,td { margin:0; padding:0; box-sizing:border-box; }
html,body { background:#fff; }
img { border:0; vertical-align:top; line-height:0; }
h1,h2,h3 { font-size:100%; font-weight:normal; }
ul,dl,ol { text-indent:0; }
li { list-style:none; }
em,th { font-style:normal; font-weight:normal; }
table { border:none; border-collapse:collapse; border-spacing:0; font-size:inherit; }
th,td { text-align:left; vertical-align:top; }
input,select,textarea { font-size:100%; }
.disabled{ filter: alpha(opacity=50); -moz-opacity:0.50; opacity:0.50; }
.good{ background: #FEE !important; }
.bad{ background: #EEF !important; }

input[type="text"],input[type="tel"],input[type="number"],select{
-webkit-appearance: none;
border-radius: 4px;
border: 1px solid #DDD;
padding: 0.5em;
}

select {
  /* styling */
  background-color: white;
  border: thin solid #DDD;
  border-radius: 4px;
  display: inline-block;
  font: inherit;
  line-height: 1.2em;
  padding: 0 3em 0 0.5em;
height:2em;

  /* reset */

  margin: 0;      
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-appearance: none;
  -moz-appearance: none;
}

select::-ms-expand { display:none; }

select.classic {
  background-image:
    linear-gradient(45deg, transparent 50%, #808080 50%),
    linear-gradient(135deg, #808080 50%, transparent 50%),
    linear-gradient(to right, #F5F5F5, #EEE);
  background-position:
    calc(100% - 17px) calc(1em - 2px),
    calc(100% - 12px) calc(1em - 2px),
    100% 0;
  background-size:
    5px 5px,
    5px 5px,
    2em 2em;
  background-repeat: no-repeat;
}

select.classic:focus {
  background-image:
    linear-gradient(45deg, white 50%, transparent 50%),
    linear-gradient(135deg, transparent 50%, white 50%),
    linear-gradient(to right, gray, gray);
  background-position:
    calc(100% - 12px) calc(1em - 2px),
    calc(100% - 17px) calc(1em - 2px),
    100% 0;
  background-size:
    5px 5px,
    5px 5px,
    2em 2em;
  background-repeat: no-repeat;
  border-color: grey;
  outline: 0;
}

#model01,#model02{
	display: none;
}

body{ font-family: "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3",  "メイリオ", "ＭＳ Ｐゴシック", "Lucida Grande", "Lucida Sans Unicode", Arial, Verdana, Sans-Serif; }

label img,
label input[type="radio"],
label input[type="checkbox"] { cursor:pointer; }

input[type="text"] { padding-left:5px; padding-right:5px; }
input[type="number"] { padding-left:5px; }

input[type="text"][readonly]{
    color:#000;
    cursor:not-allowed; /* 禁止カーソル */
text-align:right;
border:0;
padding:0;
}

/* Header */

#hd{ padding: 10px; }
#hd p img{ width: 100px; }

#mainvisual{
	display: table;
	width: 100%;
	min-width: 640px;
	height: 400px;
	margin-bottom: 20px;
}

#mainvisual h1{
	display: table-cell;
	width: 40%;
	vertical-align: middle;
	background: #04593A;
}

#mainvisual h1 span{
	display: block;
	margin: 20px;
	font-size: 24px;
	color: #FFF;
}

#mainvisual div{
	display: table-cell;
	width: 60%;
	vertical-align: middle;
	background: url("../img/mainvisual.jpg") no-repeat 0 50%;
	background-size: cover;
}

#mainvisual div img{ display: none; }

#lead p{
	font-size: 18px;
	line-height: 2;
	text-align: center;
}

/* Content */

.content{
	max-width: 980px;
	margin: 0 auto;
}

/* Section */

.section{
border-bottom: 1px solid #DDD;
padding: 40px 20px;
}

#order.section,#delivery.section{ border: 0; }

.section p{
font-size: 16px;
line-height: 1.5;
margin-bottom: 20px;
}

.section p span{
display:block;
font-size:12px;
color:#666;
text-indent:-1em;
padding-left:1em;
}


/* Headline */

h2{
font-size: 20px;
font-weight: bold;
color: #04593A;
margin-bottom: 30px;
}

h2 span{
display: inline-block;
background: #04593A;
color: #FFF;
width:32px;
height:32px;
line-height:32px;
text-align:center;
border-radius:50%;
-webkit-border-radius:50%;
-moz-border-radius:50%;
margin-right:10px;
}

h3{
	font-size: 18px;
	font-weight: bold;
	color: #000;
	margin-bottom: 15px;
}

h4{
	font-size: 16px;
	font-weight: bold;
	color: #000;
}

/* Button */

.btn{
	width: 320px;
	margin: 0 auto;
}

.btn a{
	display: block;
	background: #333;
	color: #EEE;
	padding: 15px 0;
	text-align: center;
	font-size: 24px;
	border-radius:8px;
	-webkit-border-radius:8px;
	-moz-border-radius:8px;
	text-decoration: none;
}

.btn span{
	display: block;
	background: #DDD;
	color: #AAA;
	padding: 15px 0;
	text-align: center;
	font-size: 24px;
	border-radius:8px;
	-webkit-border-radius:8px;
	-moz-border-radius:8px;
	text-decoration: none;
}

.btn a:active,
.btn a:hover{
	background: #000;
	color: #FFF;
}

.btn2{
	width: 240px;
	margin: 0 auto;
}

.btn2 a{
	display: block;
	background: #333;
	color: #EEE;
	padding: 10px 0;
	text-align: center;
	font-size: 16px;
	border-radius:8px;
	-webkit-border-radius:8px;
	-moz-border-radius:8px;
	text-decoration: none;
}

.btn2 a:active,
.btn2 a:hover{
	background: #000;
	color: #FFF;
}


/* Type */

#type > p{
font-size:14px;
margin: 0 0 20px 42px;
}

#type ul{
display:flex;
flex-direction: row;
flex-wrap:wrap;
margin: 0 0 0 42px;
}

#type ul li{
width:calc((100% - 40px) / 2);
margin: 0 40px 0 0;
}

#type ul li:nth-child(2n){
margin: 0;
}

#type ul li label{ display:block; }
#type ul li img{ width:100%; border:1px solid #DDD; margin: 0 0 10px; }
#type ul li input{ margin-right:5px; }


/* Thickness */

#thickness > div{
	margin: 0 0 20px 42px;
}

/* Size */

#size > p{
font-size:14px;
margin: 0 0 20px 42px;
}

#size > ul{
margin: 0 0 0 42px;
padding: 0 0 15px;
}

#size > ul li{
font-size:12px;
margin: 0 0 5px;
padding-left: 1em;
text-indent: -1em;
color: #900;
}

#size > div{
display:flex;
flex-direction: row;
flex-wrap:wrap;
margin: 0 0 0 42px;
}

#size > div > dl{
width:calc((100% - 40px) / 3);
margin: 0 20px 0 0;
}

#size > div > dl:nth-child(3n){
margin: 0;
}

#size div dl dt{
font-weight:bold;
margin: 0 0 10px;
font-size:18px;
}

#size div dl dd{
font-size:18px;
}

#size div dl dd input{
width:150px;
}


#size div dl dd p{
margin:10px 0 0;
font-size:12px;
color:#666;
}

#size > div > dl dl{ display:inline-block; }
#size > div > dl dl dt{ display:inline-block; font-weight:normal; margin-right:10px; }
#size > div > dl dl dd{ display:inline-block; margin-right:20px; }


/* Volume */

#volume > p{
font-size:14px;
margin: 0 0 20px 42px;
}

#volume > div{
margin: 0 0 0 42px;
font-size:14px;
}

#volume > div input{
font-size:18px;
width:5em;
}

/* Delivery */

#delivery > p{
font-size:14px;
margin: 0 0 20px 42px;
}

#delivery > ul{
margin: 0 0 0 42px;
font-size:16px;
display:flex;
flex-direction: row;
flex-wrap:wrap;
}

#delivery > ul li:nth-child(odd){ width:40%; }
#delivery > ul li:nth-child(even){ width:60%; }
#delivery > ul li input{ margin-right:5px; }

#delivery > ul li p{
margin-top:10px;
padding-left: 22px;
font-size:12px;
color:#666;
}

#delivery > ul li div#detail_delivery{ padding:10px 0 0 22px; }

#delivery > ul li div#detail_delivery input{ font-size:24px; width:5em; }

#delivery > ul li div#detail_delivery dl dt{
margin: 0 0 5px;
font-size:14px;
color: #04593A;
}

#delivery > ul li div#detail_delivery dl dd select{ font-size:18px; margin-right:10px; }


/* Result */

#result{
	border-top: 1px solid #DDD;
	background: #F7F7F7;
}

#result > div{
	width:980px;
	margin: 0 auto;
}

#result table{
	border-top: 2px solid #DDD;
	border-left: 2px solid #DDD;
	margin-bottom: 20px;
	width: 100%;
}

#result table th,
#result table td{
	padding: 10px;
	border-bottom: 2px solid #DDD;
	border-right: 2px solid #DDD;
	text-align: center;
	font-size: 16px;
	vertical-align: middle;
}

#result table th{
	background: #EEE;
	vertical-align: middle;
	white-space:nowrap;
	width: 25%;
}

#result table td{
	background: #FFF;
	vertical-align: middle;
	text-align:right;
	width: 75%;
}

#result table td span{
}

#result table label input{ margin-right: 10px; }

#result table td input{
color:#000;
border:0;
background:#FFF;
font-weight:bold;
text-align:right;
font-size:24px;
}

#result table td dl dt{
display:inline-block;
}

#result table td dl dd{
display:inline-block;
width:10em;
}

#result > div > dl{
	text-align: right;
	border-bottom: 2px solid #DDD;
	padding-bottom: 10px;
}

#result > div > dl dt{
	font-weight: bold;
	margin-bottom: 10px;
	display: inline;
	padding-right: 20px;
	color: #666;
}

#result > div > dl dd{
	display: inline;
}

#result > div > dl dd strong{
	font-size: 24px;
}
#result > div > dl dd strong input{
	font-size:28px;
	background:none;
	border:0;
	text-align:right;
	color:#000;
	font-weight:bold;
}

#result .caution{
margin: 40px auto 20px;
background:#FEE;
padding:20px;
}

#result .caution p{
font-size:14px;
text-align:center;
margin:0;
}

/* Order */

#order p{
	text-align: center;
	font-size: 16px;
	line-height: 2;
	margin-bottom: 40px;
}

#order > dl{
	display: table;
	width: 100%;
	padding-bottom: 40px;
}

#order > dl > dt,
#order > dl > dd{
	display: table-cell;
	vetical-align: middle;
	font-size: 18px;
}

#order > dl > dt{ width: 20%; }
#order > dl > dd{ width: 30%; }

#order > dl > dt{ font-size: 18px; text-align: center; }
#order > dl > dd input{ width: 100%; }

#order dd p.error1,
#order dd p.error2 { display:none; color:#F30; text-align:left; }
#order dd.error1 p.error1,
#order dd.error2 p.error2 { display:block; }
#order dd.error1 p.error1 input[type="text"],
#order dd.error2 p.error2 input[type="text"] { background:#FCC; }

p.error3 { display:none; color:#F30; text-align:center; }
#order.error3 p.error3 { display:block; }

/* Footer */

#ft{
	background: #000;
	padding: 20px 10px;
	text-align: center;
}

#ft address{
	color: #FFF;
	font-style: normal;
	font-family: Arial;
	font-size: 14px;
}

/* Error , Finish */

#error,#finish{
	text-align: center;
	padding: 40px 20px 60px;
	line-height: 2;
}

#error .btn,
#finish .btn{
	margin-top: 40px;
}

@media screen and (max-width:768px) {


}

@media screen and (min-width:641px) and (max-width:768px) {

}

@media screen and (max-width:640px) {
#hd p{ text-align:center; }
#mainvisual{ display:block;margin:0;min-width:auto; height:auto; }
#mainvisual h1,#mainvisual div{ display:block; width:auto; height:auto; text-align:center; }
#mainvisual h1 span{ margin:0;padding:15px 10px;font-size:18px; }
#mainvisual div img{ display:block; width:100%; }
#lead p{ font-size:14px; line-height:1.75; }
.section{ padding: 30px 20px; }
h2{ font-size: 16px; margin-bottom: 20px; }
h2 span{ width:24px; height:24px; line-height:24px; }

#type > p{
margin: 0 0 20px;
}

#type ul{
display:block;
margin: 0;
}

#type ul li{
width:100%;

margin: 0 0 20px;
}

#type ul li:nth-child(3n){
margin: 0 0 20px;
}

#type ul li img{ width:20%; display:inline-block; margin: 0 20px 0 0; vertical-align:middle; }

#thickness > div{ margin: 0 0 20px; }

#size > p,#size > ul{
margin: 0 0 20px;
}

#size > div{
display:block;
margin: 0;
}

#size > div > dl{
width:100%;
margin: 0 0 20px;
}

#size > div > dl:nth-child(3n){
margin: 0 0 20px;
}

#size div dl dt{
display:inline-block;
width:20%;
font-weight:bold;
margin: 0 0 10px;
font-size:18px;
vertical-align:top;
}

#size div dl dd{
display:inline-block;
width:80%;
font-size:18px;
}

#size div dl dd input{
width:150px;
}


#size div dl dd p{
margin:10px 0 0;
font-size:12px;
color:#666;
}

#size > div > dl dl{ display:inline-block; }
#size > div > dl dl dt{ display:inline-block; font-weight:normal; margin-right:10px; }
#size > div > dl dl dd{ display:inline-block; margin-right:20px; }

#volume > p{
font-size:14px;
margin: 0 0 20px;
}

#volume > div{
margin: 0;
font-size:14px;
}

#volume > div input{
font-size:18px;
width:5em;
}

#delivery > ul{
margin: 0;
font-size:14px;
display:block;
}

#delivery > ul li{
width:100%;
}

#delivery > ul li:nth-child(odd),#delivery > ul li:nth-child(even){ width:100%; }

#delivery > ul li input{
margin-right:5px;
}

#delivery > ul li p{
margin-top:10px;
padding-left: 20px;
font-size:12px;
color:#666;
}

#delivery > ul li div#detail_delivery{
padding:10px 0 0 20px;
}

#delivery > ul li div#detail_delivery input{
font-size:24px;
width:5em;
}

#delivery > ul li div#detail_delivery dl dt{
margin: 0 0 5px;
font-size:14px;
color: #04593A;
}

#delivery > ul li div#detail_delivery dl dd select{
display:block;
width: 100%;
font-size:18px;
margin: 0 0 10px;
}

#result{
	border-top: 1px solid #DDD;
	background: #F7F7F7;
}

#result > div{
	width: auto;
	margin: 0 auto;
}

#result table{
	border-top: 2px solid #DDD;
	border-left: 2px solid #DDD;
	margin-bottom: 20px;
	width: 100%;
}

#result table tbody{
width:100%;
}

#result table tr{ display:block;width:100%; }

#result table th,
#result table td{
display:block;
	width:100%;
	padding: 10px;
	border-bottom: 2px solid #DDD;
	border-right: 2px solid #DDD;
	text-align: center;
	font-size: 14px;
	vertical-align: middle;
}

#result table th{ text-align:left; }
#result table td{ text-align:right; }

#result table td span{
}

#result table label input{ margin-right: 10px; }

#result table td input{
color:#000;
border:0;
background:#FFF;
font-weight:bold;
text-align:right;
font-size:18px;
width:50%;
}

#result table td dl dt{
display:inline-block;
}

#result table td dl dd{
display:inline-block;
width:50%;
}

#result > div > dl{
	width: 100%;
	text-align: right;
	border-bottom: 2px solid #DDD;
	padding-bottom: 10px;
}

#result > div > dl dt{
display:inline-block;
	font-weight: bold;
	margin-bottom: 10px;
	padding-right: 0;
	font-size:14px;
	color: #666;
	display:block;
	text-align:left;
}

#result > div > dl dd{
display:inline-block;
}

#result > div > dl dd strong{
	font-size: 14px;
}
#result > div > dl dd strong input{
	font-size:22px;
	display:inline-block;
	width: 70%;
}

#order p{
	font-size: 14px;
	line-height: 1.75;
	margin-bottom: 40px;
}

#order > dl{
	display: block;
	width: 100%;
	padding-bottom: 40px;
}

#order > dl > dt,
#order > dl > dd{
	display: block;
	width: 100%; 
}

#order > dl > dt{ font-size: 14px; text-align: left; margin-bottom:5px; }
#order > dl > dd{ margin-bottom: 20px;; }
#order > dl > dd input{ width: 100%; }

.btn{ width: 100%; }

.btn a{
	display: block;
	background: #333;
	color: #EEE;
	padding: 15px 0;
	text-align: center;
	font-size:16px;
	border-radius:8px;
	-webkit-border-radius:8px;
	-moz-border-radius:8px;
	text-decoration: none;
}
.btn2{
	width: 100%;
}



}