@charset "UTF-8";

body {
	overflow-x: hidden;
}
div#mf_hidden {
	overflow: hidden;
	width: 1px;
	height: 1px;
	padding: 0px;
	margin: 0px;
}
div#mf_hidden input {
	margin: 10px;
}
div.mf_thanks {
	padding: 30px;
}
div.mf_thanks p {
	line-height: 1.7em;
}
div.mf_thanks ul.mf_caution {
	margin: 0px;
	padding: 0px;
}
div.mf_thanks ul.mf_caution li {
	display: block;
	color: #C00;
	margin: 0px;
	padding: 5px 0px;
}
div#mf_thanks {
	text-align: center;
	font-size: 18px;
	padding: 20px 0px;
}
div#mf_thanks strong {
	color: #C00;
	font-size: 24px;
}
form#mailform {
	padding: 10px 0px;
        padding-top: 120px;
        margin-top: -120px;
}
form#mailform dl dt {
	float: left;
	width: 160px;
	clear: both;
	font-size: 12px;
	padding: 10px 0px;
	text-align: right;
	border-top: solid 1px #CCC;
	margin: 0px;
}
form#mailform dl dd {
	border-top: solid 1px #CCC;
	margin: 0px;
	padding: 10px 5px 20px 170px;
	font-size: 12px;
	line-height: 1.5em;
	text-align: left;
}
form#mailform dl dd ul,form#mailform dl dd ol {
	margin: 0px;
	padding: 0px;
}
form#mailform dl dd ul li,form#mailform dl dd ol li {
	margin: 0px;
	padding: 0px;
	list-style: none;
}

.must {
    display: block;
    background-color: #A51C24;
    border: solid 2px #A51C24;
    /* text-shadow: 0px 1px 2px #933; */
    padding: 0 7px;
    font-size: 14px;
    color: #FFF;
    float: left;
    margin: 0px 5px 3px;
    border-radius: 20px;
    /* box-shadow: 0px 0px 5px #CCC; */
    background-image: url(_images/mf_header.png);
    background-size: 100% 100%;
    line-height: 1.5em;
}
.optionally {
	display: block;
	background-color: #06C;
	border: solid 2px #06C;
	text-shadow: 0px 1px 2px #933;
	padding: 2px 5px;
	font-size: 10px;
	color: #FFF;
	float: left;
	margin: 0px 5px;
	border-radius: 4px;
	box-shadow: 0px 0px 5px #CCC;
	background-image: url(_images/mf_header.png);
	background-size: 100% 100%;
}
form#mailform label {
	border-radius: 3px;
	margin: 3px;
	display: inline-block;
	white-space: nowrap;
}
form#mailform label.mf_checked {
	padding: 3px;
	border: solid 1px #CCC;
	background-color: #E8EEF9;
	box-shadow: 0px 1px 3px #CCC inset;
}
form#mailform label.mf_not_checked {
	padding: 3px;
	border: solid 1px #EEE;
}
table#mf_confirm_table {
	border-spacing: 0px;
	border-collapse: collapse;
	width: 100%;
}
table#mf_confirm_table tr.mf_colored {
	background-color: #F6F7F9;
}
table#mf_confirm_table tr.mf_achroma {
	background-color: #FFF;
}
table#mf_confirm_table tr th,table#mf_confirm_table tr td {
	text-align: left;
	font-size: 12px;
	border-top: solid 1px #CCC;
	padding: 5px 10px;
}
table#mf_confirm_table tr th {
	white-space: nowrap;
	width: 200px;
}
table#mf_confirm_table tr td {
	line-height: 1.5em;
	word-break: break-all;
}
div#mf_phase_confirm {
	clear: both;
}
div#mf_phase_confirm h4 {
	font-size: 36px;
	padding: 10px 0px 0px 0px;
	text-align: center;
}
div#mf_phase_confirm div#mf_phase_confirm_inner {
}
div#mf_overlay {
	position: absolute;
	display: none;
	z-index: 10001;
}
div#mf_overlay_inner {
	background-color: #FFF;
	padding: 15px;
	margin: 0px auto;
	border-radius: 5px;
	box-shadow: 0px 0px 10px #000;
	width: 640px;
	max-width: 90%;
}
div#mf_overlay_background {
	background-color: #000;
	position: absolute;
	display: none;
	z-index: 10000;
}
div#mf_loading_screen {
	z-index: 20000;
	opacity: 0.8;
	display: none;
	background-color: #000;
	position: absolute;
}
div#mf_loading {
	z-index: 20001;
	position: absolute;
	display: none;
	width: 40px;
	height: 40px;
	background-image: url(_images/mf_loading.gif);
}
.mf_colored {
	background-color: #F6F7F9;
}
.mf_achroma {
	background-color: #FFF;
}
div.mf_err {
	clear: both;
	display: none;
	text-align: left;
	margin: 5px 0px 0px 0px;
	padding: 3px 0px 5px 17px;
	color: #F00;
	font-size: 12px;
	line-height: normal;
	background-image: url(_images/mf_error.gif);
	background-repeat: no-repeat;
	background-position: 0px 1px;
}
.mf_parent_error {
	border: solid 2px #F00;
}
.problem {
	background-color: #FCC;
}
div#mf_error {
	background-color: #FEE;
	border: solid 1px #F00;
	padding: 10px;
	display: none;
}
div#mf_error p {
	padding: 0px;
	margin: 0px;
	font-size: 14px;
	text-align: center;
}
div#mf_error p strong {
	font-size: 18px;
	color: #F00;
}
.error_area{
    color: red;
    margin-bottom: 60px;
}
div#mf_warning {
	background-color: #FEE;
	border: solid 1px #F00;
	padding: 10px;
	display: none;
	border-radius: 5px;
}
div#mf_warning p {
	padding: 0px;
	margin: 0px;
	font-size: 14px;
	text-align: center;
}
div#mf_warning p strong {
	font-size: 18px;
	color: #F00;
}
div#mf_price {
	color: #C00;
	font-size: 36px;
	padding: 10px;
	font-weight: bolder;
}
div#mf_price span {
	color: #666;
	font-size: 12px;
	font-weight: normal;
}
button.mf_next,button.mf_prev {
	font-size: 18px;
	margin: 10px;
	padding: 5px 10px;
}
button.mf_next {
	float: right;
}
button.mf_prev {
	float: left;
}
ul#mf_phase_stat {
	padding: 10px;
	text-align: center;
}
ul#mf_phase_stat li {
	display: inline-block;
	padding: 8px 15px;
	border-radius: 5px;
	margin: 0px 5px;
	list-style: none;
	font-size: 14px;
}
ul#mf_phase_stat li.mf_phase_arrow {
	box-shadow: none;
	color: #999;
	padding: 8px 0px;
}
ul#mf_phase_stat li.mf_active_phase {
	box-shadow: 0px 1px 6px #000;
	background-image: url(_images/mf_header.png);
	background-size: 100% 100%;
	background-color: #0068B7;
	border: solid 2px #0068B7;
	font-weight: bolder;
	color: #FFF;
	text-shadow: 0px 1px 3px #000;
}
ul#mf_phase_stat li.mf_inactive_phase {
	background-image: url(_images/mf_header.png);
	background-size: 100% 100%;
	background-color: #EEE;
	border: solid 2px #EEE;
	color: #999;
	box-shadow: 0px 1px 6px #CCC;
}
div#mf_shopping_cart {
	border: solid 1px #CCC;
	margin: 0px;
	padding: 0px;
}
div#mf_shopping_cart p {
	margin: 0px;
	text-align: center;
	padding: 20px 10px;
	font-size: 12px;
	background-color: #FEE;
}
table.mf_shoppingcart {
	border-spacing: 0px;
	border-collapse: collapse;
	width: 100%;
}
table.mf_shoppingcart thead tr td {
	background-color: #EEE;
	border-bottom: solid 1px #CCC;
	text-align: center;
	font-size: 12px;
	padding: 5px;
}
table.mf_shoppingcart tbody tr th,table.mf_shoppingcart tbody tr td {
	font-size: 12px;
	padding: 5px;
	border-bottom: solid 1px #CCC;
}
table.mf_shoppingcart tbody tr td select {
	display: block;
	margin: 0px auto;
	text-align: center;
}
table.mf_shoppingcart tbody tr td select option {
	text-align: center;
}
table.mf_shoppingcart tbody tr th span {
	display: block;
	font-weight: normal;
	font-size: 10px;
	color: #666;
	padding: 3px 0px;
}
table.mf_shoppingcart tfoot tr td {
	padding: 5px;
	font-size: 16px;
	font-weight: bolder;
	color: #900;
}
td.msc_price {
	font-size: 12px;
	text-align: right;
}
div.mf_buttons {
	clear: both;
	padding: 10px 0px;
	text-align: center;
}
div.mf_buttons button#mf_button_send {
}
div.mf_buttons button#mf_button_cancel {
}
.imagebutton {
	margin: 0px;
	padding: 0px;
	border: none;
	outline: none;
	background: none;
}
.mf_element_all {
	max-width: 90%;
}
.mf_element_text,
.mf_element_number,
.mf_element_select-one,
.mf_element_email,
.mf_element_tel,
.mf_element_textarea,
.mf_element_date
.mf_element_password {
/*	border: solid 1px #CCC;*/
    border: none;
    border-radius: 2px;
/*	box-shadow: 0px 0px 3px #CCC inset;*/
    padding: 3px 8px;
    margin: 2px;
    vertical-align: middle;
}
.mf_element_checkbox,
.mf_element_radio {
	vertical-align: middle;
	margin: 0px 2px;
}
.mf_element_file {
	font-size: 12px;
	display: inline-block;
	padding: 10px 10px;
	vertical-align: middle;
	border: solid 1px #CCC;
	border-radius: 3px;
	box-shadow: 0px 0px 5px #CCC inset;
	background: #EEE;
}
.mf_element_submit,.mf_element_reset,.mf_element_button,button.mf_next,button.mf_prev {
	border-radius: 5px;
	padding: 5px 10px;
	border: solid 1px #CCC;
	background: gradient(linear, center top, center bottom, from(#EEE), to(#CCC));
	background: -webkit-gradient(linear, center top, center bottom, from(#EEE), to(#CCC));
	background: -moz-linear-gradient(top, #EEE, #CCC);
	background: -ms-linear-gradient(top, #EEE 0%, #CCC 100%);
	text-shadow: 0px 2px 0px #FFF;
	font-size: 18px;
	cursor: pointer;
	outline: none;
}
.mf_element_reset {
	color: #333;
}
.mf_element_submit:hover,.mf_element_reset:hover,.mf_element_button:hover,button.mf_next:hover,button.mf_prev:hover {
	background: gradient(linear, center top, center bottom, from(#FFF), to(#CCC));
	background: -webkit-gradient(linear, center top, center bottom, from(#FFF), to(#CCC));
	background: -moz-linear-gradient(top, #FFF, #CCC);
	background: -ms-linear-gradient(top, #FFF 0%, #CCC 100%);
	box-shadow: 0px 2px 15px #CCC;
}
button.mf_next,button.mf_prev {
	font-size: 14px;
}
input#mf_reserve_item,input#mf_reserve_date {
	display: none;
}
div#mf_reserve_wrapper {
	position: relative;
	overflow: hidden;
	border: solid 1px #CCC;
}
div#mf_reserve_inner {
	position: relative;
	padding: 0px 0px 0px 100px;
	overflow: auto;
}
div#mf_reserve_wrapper table {
	border-spacing: 0px;
	border-collapse: collapse;
}
div#mf_reserve_wrapper table.mf_reserve_table_label {
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100px;
	background-color: #FEE;
	z-index: 100;
}
div#mf_reserve_wrapper table.mf_reserve_table_value {
	padding: 0px 0px 0px 0px;
}
div#mf_reserve_wrapper table.mf_reserve_table_value tr td.mf_reserve_active,
div#mf_reserve_wrapper table.mf_reserve_table_value tr td.mf_reserve_warning {
	cursor: pointer;
}
div#mf_reserve_wrapper table.mf_reserve_table_value tr td.mf_reserve_active:hover,
div#mf_reserve_wrapper table.mf_reserve_table_value tr td.mf_reserve_warning:hover {
	background-color: #E8EEF9;
}
div#mf_reserve_wrapper table.mf_reserve_table_value tr td.mf_reserve_current {
	background-color: #0068B7;
	color: #FFF;
}
td.mf_reserve_disabled {
	background-color: #CCC;
}
td.mf_reserve_warning {
	background-color: #FFC;
}
div#mf_reserve_wrapper table tr td,div#mf_reserve_wrapper table tr th {
	border: solid 1px #CCC;
	padding: 0px 5px;
	font-size: 12px;
	text-align: center;
	font-weight: normal;
	height: 20px;
	text-align: left;
}
td.mf_reserve_week_0 {
	color: #F00;
	background-color: #FEE;
}
td.mf_reserve_week_6 {
	color: #00F;
	background-color: #EEF;
}
div.mf_ok {
	border-radius: 5px;
	background-color: #090;
	border: solid 1px #090;
	display: inline-block;
	line-height: 1.5em;
	padding: 0px 5px;
	margin: 0px 2px;
	color: #FFF;
	font-size: 10px;
	background-image: url(_images/mf_header.png);
	background-size: 100% 100%;
	display: none;
}
div.prefcodeWrapper {
	position: relative;
}
div.prefcodeResult {
	position: absolute;
	top: 0px;
	left: 0px;
	padding: 5px;
	border: solid 1px #CCC;
	background-color: #FFF;
	box-shadow: 0px 0px 5px #CCC;
	display: none;
}
div.prefcodeResult div {
	cursor: pointer;
}
div.prefcodeResult div:hover {
	background-color: #C9EBFB;
}
div.prefcodeResult div.prefcodeNext {
	background-color: #EEE;
	text-align: center;
}
div.prefLoading {
	padding: 60px 100px;
	background: url(_images/mf_zip_loading.gif) no-repeat center center;
}
.hidefield {
	height: 0px;
	overflow: hidden;
}
.showfield {
	height: auto;
	overflow: visible;
}
div.mf_attached_thumbnails {
	display: none;
	padding: 5px;
	margin: 5px auto;
	border: solid 1px #CCC;
	border-radius: 3px;
	box-shadow: 0px 0px 5px #CCC inset;
	background: #EEE;
}
div.mf_attached_thumbnails ul {
	margin: 0px;
	padding: 0px;
}
form#mailform dl dd div.mf_attached_thumbnails ul li {
	display: inline-block;
	vertical-align: top;
	padding: 0px;
	border: solid 4px #FFF;
	margin: 5px;
	box-shadow: 0px 2px 5px #999;
}
form#mailform dl dd div.mf_attached_thumbnails ul li a {
	display: block;
	max-height: 100px;
	overflow: hidden;
}
div.mf_attached_thumbnails ul li a img {
	display: block;
	max-width: 80px;
}
button.mf_attached_reset {
	font-size: 14px;
}
div.mf_guide {
	position: relative;
	width: 1px;
	height: 1px;
}
div.mf_guide div {
	position: absolute;
	bottom: 0px;
	left: 0px;
	margin-top: -2em;
	white-space: nowrap;
	border-radius: 5px;
	padding: 5px 10px;
	line-height: 1em;
	font-size: 12px;
	color: #FFF;
	font-weight: bolder;
	background: #F00;
	display: none;
}
.mf_ok {
	background-color: rgba(0,255,0,0.2);
}
.mf_ng {
	background-color: rgba(255,0,0,0.2);
}
div#mf_OperationCheck {
}
div#mf_OperationCheck div#mf_OperationCheck_inner {
	display: none;
}
div#mf_OperationCheck strong {
	background: #090;
	display: block;
	color: #222;
	text-align: center;
	border-radius: 3px;
}
div#mf_OperationCheck * {
	padding: 0px;
	margin: 0px;
	font-size: 12px;
}
div#mf_OperationCheck p {
	padding: 0px 5px;
	margin: 0px;
	font-size: 12px;
}
div#mf_OperationCheck p a {
	color: #0C0;
	text-decoration: none;
}
div#mf_OperationCheck p a:hover,
div#mf_OperationCheck p button:hover {
	text-decoration: underline;
}
div#mf_OperationCheck p button {
	border: none;
	background: none;
	color: #0C0;
	cursor: pointer;
}
div#mf_OperationCheck div#mf_OperationCheck_inner ul {
}
div#mf_OperationCheck ul li,
div#mf_OperationCheck ul li label,
div#mf_OperationCheck ul li label input {
	line-height: 12px;
	font-size: 12px;
	list-style: none;
	vertical-align: middle;
}
div#mf_OperationCheck ul li {
	padding: 5px 10px;
}
div#mf_OperationCheck ul li label {
	text-decoration: underline;
}
button#mf_recorder_record,
button#mf_recorder_clear,
button#mf_recorder_restore {
	border-radius: 5px;
	padding: 5px 10px 5px 2em;
	border: solid 1px #CCC;
	background: gradient(linear, center top, center bottom, from(#EEE), to(#CCC));
	background: -webkit-gradient(linear, center top, center bottom, from(#EEE), to(#CCC));
	background: -moz-linear-gradient(top, #EEE, #CCC);
	background: -ms-linear-gradient(top, #EEE 0%, #CCC 100%);
	text-shadow: 0px 2px 0px #FFF;
	font-size: 16px;
	cursor: pointer;
	outline: none;
	display: inline-block;
	margin: 5px auto;
}
button#mf_recorder_record {
	background: url(_images/mf_record_disabled.png) no-repeat 5px center #EEE;
	background-size: 24px 24px;
}
button#mf_recorder_clear {
	background: url(_images/mf_record_remove.png) no-repeat 5px center #EEE;
	background-size: 24px 24px;
}
button#mf_recorder_restore {
	background: url(_images/mf_record_restore.png) no-repeat 5px center #EEE;
	background-size: 24px 24px;
}
button.enabled#mf_recorder_record,
button.enabled#mf_recorder_clear,
button.enabled#mf_recorder_restore {
	background: url(_images/mf_record_enabled.png) no-repeat 5px center #EEE;
	background-size: 24px 24px;
}
div#mf_recorder_wrap {
	border: solid 1px #CCC;
	padding: 10px;
	text-align: center;
	margin: 5px auto;
}
td.request_image {
	width: 100px;
}
td.request_image img {
	max-width: 100px;
}
button.mf_submit_enable {
	background: none;
	background: #000090;
}
button.mf_submit_disable {
	background: none;
	background: #FD8282;
}
span.mf_tips {
	background-image: url(_images/mf_header.png);
	background-size: 100% 100%;
	background-color: #FCC;
	display: block;
	border-radius: 5px;
	padding: 10px;
	margin: 2px;
	box-shadow: 0px 2px 10px #999;
}
span.mf_tips strong {
	color: #800040;
}
span.mf_tips span {
	display: block;
	padding: 10px;
	color: #008080;
}
span.mf_tips em {
	font-style: normal;
	color: #090;
	font-weight: bold;
}

/* mail custom */
form#mailform {
    max-width: 1100px;
    width: 90%;
    margin-left: auto;
    margin-right: auto;
}

form#mailform dl dt {
  font-size: 18px;
  border: none;
  width: 250px;
  padding-top: 15px;
}
form#mailform dl dd {
  font-size: 18px;
  border: none;
  padding-left: 260px;
  padding-bottom: 10px;
}
form#mailform dl dd.mail_info {
  color: #C1976D;
  margin-top: -15px;
}

form#mailform dl.items label {
  display: block;
}

form#mailform label.mf_checked {
  border: none;
  box-shadow: none;
  background-color: transparent;
}

form#mailform label.mf_not_checked {
  border: none;
}

form#mailform .mailform{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-bottom: 50px;
}
form#mailform .mailform .full_width{
    width: 100%;
    margin-bottom: 1.2em;
    padding-top: 1.4em;
}
form#mailform .mailform .half_width{
    width: 48.5%;
    margin-bottom: 1.2em;
    padding-top: 1.4em;
}
form#mailform .mailform .bg_full_width{
    margin-right: 51.5%;
}
form#mailform .mailform .half_width:has(.must){
    padding-top: 0;
}
form#mailform .mailform .tel p{
    text-align: right;
    font-size: 90%;
}

form#mailform .mailform dl{
    padding-top: 20px;
}
form#mailform .mailform dl dt{
    width: 100%;
    text-align: left;
    display: flex;
    flex-direction: column;
}
form#mailform .mailform dl dt .must{
    width: calc(2em + 18px);
}
form#mailform .mailform dl dd{
    padding-left: 2.5em;
}

/* 元のinputの色 */
form#mailform .mailform input::-webkit-input-placeholder,form#mailform .mailform textarea::-webkit-input-placeholder{
   background: #E8E8E8;
    color: #808080;
}
form#mailform .mailform input::-moz-placeholder,form#mailform .mailform textarea::-moz-placeholder{
    background: #E8E8E8;
    color: #808080;
}
form#mailform .mailform input:placeholder-shown,form#mailform .mailform  textarea:placeholder-shown{
    background: #E8E8E8;
    color: #808080;
}/* 元のinputの色 */

form#mailform .mailform input{
    max-width: 100%;
    width: 100%;
    font-size: 110%;
    padding: .7em 1.3em;
    border-radius: .8em;
    background: #F4F4F4;/* 入力された時のinputの色 */
    color: #000;
    font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
}
form#mailform .mailform .toiawase{
    width: 100%;
    padding-top: 20px;
}
form#mailform .mailform textarea{
    max-width: 100%;
    width: 100%;
    height: 450px;
    font-size: 110%;
    padding: 1em 1.3em;
    border-radius: .8em;
    background: #F4F4F4;
    color: #000;
    font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
}


.mf_colored {
  background-color: transparent;
}

.mf_element_submit,
.mf_element_button,
button.mf_next,
button.mf_prev {
  text-shadow: none;
}

section #mailform dl dd input[type="text"],
section #mailform dl dd input[type="email"],
section #mailform dl dd input[type="tel"] {
  height: 32px;
  line-height: 32px;
}

section #mailform button {
    font-size: 110%;
    border: solid 1px #A39855;
    border-radius: .3em;
    color: #fff;
    padding: .2em 2.2em;
    cursor: pointer;
    background: #A39855;
    color: #000;
    transition: filter 0.3s ease;
    filter: brightness(1);
}

section #mailform button:hover {
    filter: brightness(1.25);
}

#mail_check #con_13{
    padding: 0 5%;
}
#mail_check #con_13, .thanks_page {
    text-align: center;
    padding-top: 70px;
}
#mail_check #con_13 h2, .thanks_page h2{
    margin-bottom: 60px;
    font-size: 140%;
    font-weight: bold;
    color: #113142;
    text-align: center;
}
.thanks_page{
    padding-bottom: 100px;
}
.thanks_page .detail_cont p{
    margin-bottom: 1em;
}
.thanks_page .detail_cont p a{
    color: #fff;
}

input[type="button"],input[type="submit"]{
    padding: .3em 1em;
    margin-bottom: 80px;
    background: #113142;
    border: solid 1px #113142;
    border-radius: 0.3em;
    color: #fff;
    font-size: 110%;
}
input[type="button"]:hover,input[type="submit"]:hover{
    filter: brightness(1.5);
    opacity: .9;
    cursor: pointer;
}
#mailform button[type="submit"] {
    background: #113142;
    color: #fff;
    border: solid 1px #113142;
    border-radius: 7px;
    width: 160px;
    padding-top: 0.2em;
    padding-bottom: 0.2em;
    font-size: 110%;
    transition: all .2s;
}
#mailform button:hover {
    color: #113142;
    background: rgba(255,255,255,.4);
    cursor: pointer;
}
.con13_form{
    display: flex;
    justify-content: center;
    margin: 60px 0;
}
.con13_form table{
    max-width: 900px;
    width: 100%;
}
.con13_form table th{
    white-space: nowrap;
    background: #eee;
}
.con13_form table td, .con13_form table th{
    border: solid 1px #000;
    padding: .2em 1em;
    text-align: left;
}

.top_btn{
    margin-top: 80px;
    font-size: 110%;
}
.top_btn a{
    padding: .5em 1em;
    margin-bottom: 80px;
    background: #A39855;
    border: solid 1px #A39855;
    border-radius: 0.3em;
    color: #000;
}
.top_btn a:hover{
    filter: brightness(1.25);
    text-decoration: none;
}

form#mailform dl dd.input_stl{
/*    line-height: 3em;*/
}
form#mailform dl dd.input_stl label{
    margin-right: 3em;
    line-height: 2.5em;
}
form#mailform dl dd.input_stl.dd_stl01 label{
    line-height: 1.3em;
}

form#mailform .input_stl label {
margin: 12px 8px;
padding-left: 0;
align-items: center;
cursor: pointer;
}
form#mailform .input_stl input {
margin: 0;
width: 0;
opacity: 0;
float: left;
}
form#mailform .dummyInput {
    position: relative;
    top: 0;
    left: 0;
    display: block;
    width: 2em;
    height: 2em;
    background: #fff;
    /* box-shadow: 1px 1px 4px #ccc; */
    margin-right: .5em;
    float: left;
    background: #E8E8E8;
    border-radius: 10px;
}
form#mailform .input_stl.dd_stl01 .dummyInput{
    border-radius: 2em;
    width: 1.3em;
    height: 1.3em;
}
form#mailform .input_stl input:checked + .dummyInput{
background: #F4F4F4;
}
form#mailform .input_stl.dd_stl01 input:checked + .dummyInput{
    border: solid 1px #888;
}
form#mailform .input_stl input:checked + .dummyInput::before {
content: "";
display: block;
position: absolute;
width: 50%;
height: 50%;
top: 0;
bottom: 0;
left: 0;
right: 0;
margin: auto;
border-radius: 2em;
transform-origin: center;
background: #113142;
}
form#mailform .input_stl.dd_stl02 input:checked + .dummyInput::before {
content: "";
display: block;
position: absolute;
top: 50%;
bottom: inherit;
left: 50%;
right: inherit;
width: 35%;
height: 5px;
border-radius: 2em;
transform: translate(-5px, 6px) rotateZ(-135deg);
transform-origin: 1px 1px;
background: #113142;
}
form#mailform .input_stl.dd_stl02 input:checked + .dummyInput::after {
content: "";
display: block;
position: absolute;
top: 50%;
left: 50%;
width: 70%;
height: 5px;
border-radius: 2em;
transform: translate(-5px, 6px) rotateZ(-45deg);
transform-origin: 1px 1px;
background: #113142;
}

#mailform p.info{
    margin-bottom: 50px;
}
#mailform p.info2{
    width: 100%;
    text-align: center;
    color: #972626;
    padding-top: 15px;
}

#contact_us .mailform .input_stl {
    margin-bottom: 2em;
}

form#mailform .input_box .input_stl.dd_stl02.active{
    opacity: 1;
    display: block;
    transition: all .5s;
}
form#mailform  .input_box .input_stl.dd_stl02{
    display: none;
    opacity: 0;
}
form#mailform  .input_box .input_stl.dd_stl02 input + .dummyInput{
    opacity: 1;
    transition: all .5s;
}
form#mailform  .input_stl.dd_stl02 input:disabled + .dummyInput{

}
form#mailform .policy_check{
    width: 100%;
    text-align: center;
    padding-top: 80px;
}
form#mailform .policy_check p{
    margin-bottom: 20px;
}
form#mailform .policy_check a{
    color: #000;
}
form#mailform .policy_check a:hover{
    color: #000;
}

@media screen and (max-width: 1360px) {
    form#mailform dl dd.input_stl label{
        margin-right: 1.8em;
    }
}
@media screen and (max-width: 768px) {
	form#mailform dl dt {
		float: none;
		width: auto;
		padding: 5px;
		text-align: left;
	}
	form#mailform dl dd {
		clear: both;
		border-top: none;
		padding: 5px 15px;
		line-height: 1.5em;
	}
	div.mf_buttons button {
		font-size: 14px;
	}
	div#mf_phase_confirm h4 {
		font-size: 18px;
	}
	ul#mf_phase_stat {
		padding: 0px;
		text-align: left;
	}
	ul#mf_phase_stat li {
		text-align: center;
		padding: 5px 0px;
		border-radius: 3px;
		margin: 5px;
		list-style: none;
		font-size: 14px;
		width: 28%;
	}
	ul#mf_phase_stat li.mf_phase_arrow {
		bos-shadow: none;
		display: none;
	}
	ul#mf_phase_stat li.mf_active_phase {
	}
	ul#mf_phase_stat li.mf_inactive_phase {
	}
	table#mf_confirm_table tr th {
		white-space: nowrap;
		width: 100px;
	}
	div#mf_thanks {
		text-align: center;
		font-size: 18px;
		padding: 20px 0px;
	}
	div#mf_thanks strong {
		color: #C00;
		font-size: 24px;
		display: block;
	}

    form#mailform dl dt {
      width: auto;
    }
    form#mailform dl dd {
      padding-left: 5px;
    }
    form#mailform .must {
      margin-left: 0;
    }
    form#mailform .mailform{
        margin-bottom: 2em;
    }
    form#mailform .mailform input{
        font-size: 100%;
    }
    form#mailform .mailform .tel p{
        text-align: left;
        font-size: 80%;
    }
    form#mailform .mailform .half_width,form#mailform .mailform .name, form#mailform .mailform .mail_address {
        width: 100%;
    }
    form#mailform .mailform .toiawase textarea{
        height: 260px;
    }
    
    form#mailform .mailform dl{
        width: 100%;
    }
    form#mailform .mailform dl dd{
        padding-left: 0;
    }
    #mail_check #con_13, .thanks_page {
        text-align: left;
    }
    #mail_check .form_btn ,.thanks_page .top_btn{
        text-align: center;
    }
    
    form#mailform dl dd.input_stl{
        display: flex;
        flex-wrap: wrap;
        margin-bottom: 1em;
    }
    form#mailform dl dd.input_stl label{
        margin-right: 0;
        width: 100%;
        line-height: 2em;
        margin-top: 0;
    }
    form#mailform .input_stl label{
        width: 100%;
    }
    #mailform p.info2{
        text-align: left;
    }
    form#mailform .policy_check p{
        text-align: left;
    }
    form#mailform .policy_check label{
        width: auto;
    }
    form#mailform .mailform .bg_full_width{
        margin-right: 0;
    }
    form#mailform dl dt,form#mailform dl dd{
        font-size: 16px;
    }
}
@media screen and (max-width: 480px) {
    .mf_element_all {
        max-width: 100%;
    }
    form#mailform .mailform .name input, form#mailform .mailform .mail_address input{
        font-size: 100%;
        padding: 0.8em 1.3em;
    }
    
    form#mailform dl dd.input_stl label{
        margin-right: 2em;
    }
    
    #mailform p.info {
        margin-bottom: 2em;
    }
    .con13_form table{
        font-size: 90%;
    }
}
@media screen and (max-width: 350px) {
    
    .con13_form table{
        font-size: 80%;
    }
}