.appSpec {
  /* 仕様の文言を非表示にする場合は、display: none;にしてください */
  /* その場合は、main.cssの1行目のoverflow: hiddenを設定してください */
  display: none;

  /* 仕様の文言を表示にする場合は、display: block;にしてください */
  /* その場合は、main.cssの1行目のoverflow: hiddenをコメント化してください */
  /* display: block; */
}

body{
  user-select: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -khtml-user-select: none;
  -webkit-user-drag: none;
  -khtml-user-drag: none;
  background-image: none;
}

a{
  text-decoration: none;
  -webkit-touch-callout: none;
}

a:hover{text-decoration: none;}
.mobakuru-setting-title-black{color: #eeeeee;}
.mobakuru-background-color{background-color: #4682B4;}
.mobakuru-background-right-color{background-color: #99CCFF;}
#mobakuru-app_global_head {
  padding-top: 2px;
  position: fixed;
  width: 100%;
  height: 24px;
  top: 0;
  left: 0;
  z-index: 100;
  text-align: center;
}

#mobakuru-app_global_head > img {
  height: 22px;
}
#mobakuru-app_head {
  position: fixed;
  width: 100%;
  height: 42px;
  top: 25px;
  left: 0;
  z-index: 100;
  box-sizing: border-box;
}
#placesearch-close{
  margin-top:5px;
}

nav > div.iphone{
  height:auto;
  position:absolute;
  bottom:0px;
  right:0px;
}
nav > div.iphone-title{
  height:auto;
  position:absolute;
  bottom:10px;
  right:5px;
  left:5px;
}
nav > ul.iphone{
  height:auto !important;
  position:absolute;
  bottom:0px;
  left:0px;
}
#mobakuru-app_global_body {
  margin-top: 66px;
}
#mobakuru-app_global_body.iphonex {
  margin-top: 110px !important;
}
#mobakuru-app_global_body.iphone {
  margin-top: 76px !important;
}

.mobakuru-icon-size-12{
  width:12px;
  height:12px;
}

.mobakuru-icon-size-16{
  width:16px;
  height:16px;
}
.mobakuru-icon-size-20{width:20px;}
.mobakuru-icon-size-21{width:21px;}
.mobakuru-icon-size-24{width:24px;}
.mobakuru-icon-size-32{width:32px;height:32px;}
.mobakuru-menu-icon-size{width:48px;height:48px;}
.mobakuru-menu-icon-large{width:72px;height:72px;}
.mobakuru-menu-mobakuru-icon{height:50px;}
.rakuraku-menu-rakuraku-icon{height:60px;}
.mobakuru-icon_size_big {width: 48px;height: 48px;}
.mobakuru-icon_size_std {
  width: 32px;
  height: 32px;
}

.mobakuru-icon_size_mid {
  width: 24px;
  height: 24px;
}

.mobakuru-icon_size_mini {
  width: 16px;
  height: 16px;
}

.uk-modal-padding-top {
  padding-top: 45px;
}

.uk-close-alt {
  background: #CC0000;
  text-decoration: none;
}

.uk-close-alt:hover {
  text-decoration: none;
}


.mobakuru-modal-error {
  color: #c91032;
  background: #fff7f8;
  border: 1px solid #dc8d99;
}

/*-------------------*/
/*align*/
/*-------------------*/
.mobakuru-text-align-center{
  text-align: center;
}

/*-------------------*/
/*padding*/
/*-------------------*/

.mobakuru-padding-narrow{
  padding: 5px;
}

.mobakuru-padding-midele{
  padding: 10px;
}

.mobakuru-padding-std{
  padding: 10px;
}

.mobakuru-padding-wide{
  padding: 15px;
}


.mobakuru-padding-top-narrow{
  padding-top: 5px;
}

.mobakuru-padding-top-middle{
  padding-top: 10px;
}

.mobakuru-padding-top-wide{
  padding-top:15px;
}

.mobakuru-padding-top-bottom-narrow{
  padding-top: 5px;
  padding-bottom: 5px;
}

.mobakuru-padding-top-bottom-middle{
  padding-top: 10px;
  padding-bottom: 10px;
}

.mobakuru-padding-top-bottom-wide{
  padding-top: 15px;
  padding-bottom: 15px;
}

.mobakuru-padding-bottom-narrow{
  padding-bottom: 5px;
}

.mobakuru-padding-bottom-middle{
  padding-bottom: 10px;
}

.mobakuru-padding-bottom-wide{
  padding-bottom: 15px;
}

/*-------------------*/
/*dialog*/
/*-------------------*/
.mobakuru-dialog-top-widest{
  padding-top: 30px;
}

.mobakuru-dialog-top-none{
  padding-top: 0px;
}

/*背景マスク透明*/
.mobakuru-modal-clear{
  background: rgba(0,0,0,0.0);
}

/*背景黒のメッセージ用*/
.mobakuru-dialog-black{
  background: rgba(0,0,0,0.8);
  color: #fff;
}

.mobakuru-dialog-white{
  background: rgba(255,255,255,0.8);
}

.mobakuru-dialog-blueTransparency{
  background: rgba(70,120,150,0.8);
  color: #fff;
}

.mobakuru-modal-warning {
  color: #e28327;
  background: #fffceb;
  border: 1px solid #e28327;
}


.mobakuru-text-contrast {
  color: #000000 !important;
}

/*---------Gray---------*/
.mobakuru-button-gray {
  display: inline-block;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  vertical-align: middle;
  text-decoration: none;
  text-align: center;
  border: none;
  line-height: 28px;
  min-height: 30px;
  font-size: 1rem;
  padding: 0 12px;
  background: #f7f7f7;
  color: #444444;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-bottom-color: rgba(0, 0, 0, 0.3);
  background-origin: border-box;
  background-image: -webkit-linear-gradient(top, #ffffff, #eeeeee);
  background-image: linear-gradient(to bottom, #ffffff, #eeeeee);
  border-radius: 4px;
  text-shadow: 0 1px 0 #ffffff;
}
.mobakuru-button-gray:hover,
.mobakuru-button-gray:focus {
  background-color: #fafafa;
  color: #444444;
  outline: none;
  text-decoration: none;
  background-image: none;
}
.mobakuru-button-gray:active,
.mobakuru-button-gray.uk-active {
  background-color: #999999;
  color: #fafafa;
  border-color: rgba(0, 0, 0, 0.2);
  border-top-color: rgba(0, 0, 0, 0.3);
  background-image: none;
  box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.1);
}

/*---------done---------*/
.mobakuru-button-done {
  background-color: #ffa900;
  color: #000000;
  background-image: -webkit-linear-gradient(top, #ffcf00, #ff9000);
  background-image: linear-gradient(to bottom, #ffcf00, #ff9000);
  border-color: rgba(0, 0, 0, 0.2);
  border-bottom-color: rgba(0, 0, 0, 0.4);
  text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.2);
}
.mobakuru-button-done:hover,
.mobakuru-button-done:focus {
  background-color: #ffb21a;
  color: #ffffff;
  background-image: none;
}
.mobakuru-button-done:active,
.mobakuru-button-done.uk-active {
  background-color: #e69800;
  color: #ffffff;
  background-image: none;
  border-color: rgba(0, 0, 0, 0.2);
  border-top-color: rgba(0, 0, 0, 0.4);
  box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.2);
}

#loadingWrap {
  position: fixed;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  background-color: rgba(0,0,0, 0.2);
  z-index: 50000;
  display: none;
  -webkit-backface-visibility:hidden;
  backface-visibility:hidden;
}

#loadingWrap > span {
  position: absolute;
  display: block;
  top: 50%;
  left: 50%;
  width: 60px;
  height: 60px;
  margin-left: -30px;
  margin-top: -30px;
  border-radius: 5px;
}

#loadingWrap > span > span {
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 30px;
  display: block;
  width: 60px;
  height: 60px;
}

#dialogWrap {
  position: fixed;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  background-color: rgba(0,0,0, 0.6);
  z-index: 1000;
  -webkit-backface-visibility:hidden;
  backface-visibility:hidden;
}

.uk-form select,
.uk-form textarea,
.uk-form input:not([type]),
.uk-form input[type="text"],
.uk-form input[type="password"],
.uk-form input[type="datetime"],
.uk-form input[type="datetime-local"],
.uk-form input[type="date"],
.uk-form input[type="month"],
.uk-form input[type="time"],
.uk-form input[type="week"],
.uk-form input[type="number"],
.uk-form input[type="email"],
.uk-form input[type="url"],
.uk-form input[type="search"],
.uk-form input[type="tel"],
.uk-form input[type="color"] {
  background: #ddd;
  color: #000;
}

.uk-form select:focus,
.uk-form textarea:focus,
.uk-form input:not([type]):focus,
.uk-form input[type="text"]:focus,
.uk-form input[type="password"]:focus,
.uk-form input[type="datetime"]:focus,
.uk-form input[type="datetime-local"]:focus,
.uk-form input[type="date"]:focus,
.uk-form input[type="month"]:focus,
.uk-form input[type="time"]:focus,
.uk-form input[type="week"]:focus,
.uk-form input[type="number"]:focus,
.uk-form input[type="email"]:focus,
.uk-form input[type="url"]:focus,
.uk-form input[type="search"]:focus,
.uk-form input[type="tel"]:focus,
.uk-form input[type="color"]:focus {
  color: #000;
}

.error {
  color: #FFA900;
  font-weight: bold;
}

/*
 * Selection highlight
 */
 /* 文字のハイライトの色修正 */
::-moz-selection {
  background: #3399ff;
  color: #000;
  text-shadow: none;
}
::selection {
  background: #3399ff;
  color: #000;
  text-shadow: none;
}

/* 英語文字が改行しない問題の修正 */
.uk-modal-dialog {
  word-wrap: break-word;
}

/* ボタンを押したとき、タップハイライトカラーのちらつき防止 */
a, button { 
  -webkit-tap-highlight-color: rgba(0,0,0,0); 
  -webkit-backface-visibility:hidden;
  backface-visibility:hidden;
}

.margin-bottom10 {
  margin-bottom: 10px;
  overflow: hidden;
}

.margin-bottom20 {
  margin-bottom: 20px;
  overflow: hidden;
}

.margin-bottom25 {
  margin-bottom: 25px;
  overflow: hidden;
}

#startMarkerIcon {
  display: none;
  position:absolute;
  top: 50%;
  left: 50%;
  width: 58px;
  height: 58px;
  margin-left: -29px;
  margin-top: -58px;
  background-size: 58px 58px;
  background-repeat: no-repeat;
  cursor: pointer;
}

#startMarkerIcon_lock,
#startMarkerIcon_lock_dummy,
#endMarkerIcon_lock_dummy
#getoffMarkerIcon_lock {
  width: 58px;
  height: 58px;
  background-size: 58px 58px;
  background-repeat: no-repeat;
  cursor: pointer;
}

#endMarkerIcon {
  display: none;
  position:absolute;
  top: 50%;
  left: 50%;
  width: 58px;
  height: 58px;
  margin-left: -29px;
  margin-top: -58px;
  background-size: 58px 58px;
  background-repeat: no-repeat;
  cursor: pointer;
}

#endMarkerIcon_lock {
  width: 58px;
  height: 58px;
  background-size: 58px 58px;
  background-repeat: no-repeat;
  cursor: pointer;
}

#centerMarkerIcon {
  display: none;
  position:absolute;
  top: 50%;
  left: 50%;
  width: 24px;
  height: 24px;
  margin-left: -12px;
  margin-top: -18px;
  background-size: 24px 24px;
  background-repeat: no-repeat;
}

#centerTriangleMarkerIcon {
  display: none;
  position:absolute;
  top: 50%;
  left: 50%;
  width: 24px;
  height: 24px;
  margin-left: -12px;
  margin-top: -24px;
  background-size: 24px 24px;
  background-repeat: no-repeat;
}

#centerMarkerIcon_marker {
  width: 24px;
  height: 24px;
  background-size: 24px 24px;
  background-repeat: no-repeat;
}

.homeMarkerIcon,
.hospitalMarkerIcon,
.favoriteMarkerIcon
 {
  width: 24px;
  height: 24px;
  background-size: 24px 24px;
  background-repeat: no-repeat;
  cursor: pointer;
}

.taxiPositionIcon
 {
  width: 36px;
  height: 36px;
  background-size: 36px 36px;
  background-repeat: no-repeat;
  cursor: pointer;
}

.realtimeTaxiIcon
 {
  width: 48px;
  height: 48px;
  background-size: 192px 384px;
  background-position: 0px 0px;
  background-repeat: no-repeat;
  cursor: pointer;
}

.uk-modal-dialog {
  padding: 0px;
}

a, .uk-link {
  color: #ffaa00;
  text-decoration: underline;
  cursor: pointer;
}

a:hover,
.uk-link:hover {
  color: #ffcc00;
  text-decoration: underline;
  cursor: pointer;
}

.uk-search-close {
  display: none;
  position: absolute;
  top: 0;
  right: 0;
  width: 30px;
  height: 30px;
  line-height: 30px;
  text-align: center;
  font-size: 14px;
  color: rgba(0,0,0,.2);
  padding: 0;
  border: 0;
  -webkit-appearance: none;
  background: 0 0;
}

.uk-sortable > * {
  touch-action: auto;
}

.mobakuru-infoAddFavoriteButton {
  line-height: 20px;
}

.mobakuru-infoAddFavoriteButton img {
  line-height: 20px;
  vertical-align: top;
}

#favorite-button {
  line-height: 24px;
}

#favorite-button img {
  line-height: 24px;
  vertical-align: top;
}

#hospital-button {
  line-height: 24px;
}

#hospital-button img {
  line-height: 24px;
  vertical-align: top;
}

#home-button {
  line-height: 24px;
}

#home-button img {
  line-height: 24px;
  vertical-align: top;
}

#map .mobakuru-addFavoriteButton {
  line-height: 20px;
}

#map .mobakuru-addFavoriteButton img {
  line-height: 20px;
  vertical-align: top;
}

/*
  地図の上をtouchmoveしてもスクロールできない問題の解決
  iPhoneにて発生
  修正範囲は以下
  orderHistoryDetail.html
  orderCheck.html   
  order.html
*/
.map_over_parent {
  position: relative;
}

.map_over_child {
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  z-index: 50;
}

.table-center-middle {
  display: table-cell !important;
  vertical-align: middle !important;
}

/* ここを変更したら、以下のfont-size-normal font-size-large font-size-oversize も変更すること ここから-> */
html{
  font-size: 12px;
}
html.large{
  font-size: 16px;
}
html.oversize{
  font-size: 18px;
}

.font-size-normal {
  font-size: 12px;
}
.font-size-large{
  font-size: 16px;
}
.font-size-oversize{
  font-size: 18px;
}
.font-bold{
  font-weight: bold;
}

/* inputのplaceholderの縦位置が真ん中にならないため特大のみ補正する */
html.oversize .uk-form input[type="text"],
html.oversize .uk-form input[type="password"],
html.oversize .uk-form input[type="datetime"],
html.oversize .uk-form input[type="datetime-local"],
html.oversize .uk-form input[type="date"],
html.oversize .uk-form input[type="month"],
html.oversize .uk-form input[type="time"],
html.oversize .uk-form input[type="week"],
html.oversize .uk-form input[type="number"],
html.oversize .uk-form input[type="email"],
html.oversize .uk-form input[type="url"],
html.oversize .uk-form input[type="search"],
html.oversize input[type="search"],
html.oversize .uk-form input[type="tel"],
html.oversize .uk-form input[type="color"] {
  line-height: 1.5;
}
/* IEは、line-height 1.0でなければ、下にかなりずれる */
html.ie.oversize .uk-form input[type="text"],
html.ie.oversize .uk-form input[type="password"],
html.ie.oversize .uk-form input[type="datetime"],
html.ie.oversize .uk-form input[type="datetime-local"],
html.ie.oversize .uk-form input[type="date"],
html.ie.oversize .uk-form input[type="month"],
html.ie.oversize .uk-form input[type="time"],
html.ie.oversize .uk-form input[type="week"],
html.ie.oversize .uk-form input[type="number"],
html.ie.oversize .uk-form input[type="email"],
html.ie.oversize .uk-form input[type="url"],
html.ie.oversize .uk-form input[type="search"],
html.ie.oversize input[type="search"],
html.ie.oversize .uk-form input[type="tel"],
html.ie.oversize .uk-form input[type="color"] {
  line-height: 1.0;
}
/* <-ここまで */

.mc_dialog {
  display: none;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1010;
  overflow-y: auto;
  opacity: 1;
  width: 100%;
}

.mobakuru_button_width {
  min-width: 200px;
}

.mobakuru_button_text {
  padding: 5px;
  /*line-height: 1.2em;*/
}

.payment-kind-net {
  color: #000;
}

.net-payment-block {
  display: none;
}

.edit_div_margin {
  margin-top: 10px;
}

#payment_input h3 {
    display: block;
    color: #fff;
    width: 100%;
    text-align: left;
    border-left: 4px solid #fff;
    padding: 0 0 0 12px;
    margin: 10px 0 0px;
    font-size: 14px;
    line-height: 18px;
}

#payment_input h3.margin-top-zero {
    margin-top: 0px;
}

#payment_input .uk-grid > * {
    padding-left: 0px;
}

#payment_input .error ul {
    padding-left: 0px;
    margin-bottom: 20px;
}

#payment_input .uk-grid.dialog_title {
  width: 90%;
  margin: 0 auto;
  margin-top: 0px;
  margin-bottom: 0px;
}

#payment_input .uk-grid.register_info_wrap {
  width: 90%;
  margin: 0 auto;
  margin-top: 0px;
  margin-bottom: 0px;
}

#payment_input .uk-grid.input-field {
  width: 90%;
  margin: 0 auto;
  margin-top: 0px;
  margin-bottom: 20px;
}

#payment_input .uk-grid.buttons {
  width: 90%;
  margin: 0 auto;
  margin-top: 0px;
  margin-bottom: 20px;
}

#payment_input .payment_limit_month {
  min-width: 90px;
}

#payment_input .payment_limit_year {
  min-width: 90px;
}

#payment_input .register_info_content {
  border-bottom: solid 1px #fff;
  padding-bottom: 20px;
  margin-bottom: 15px;
}

#payment_input .payment-policy {
  margin-bottom: 10px;
}

.uk-success-deep-color {
  background-image: linear-gradient(to bottom, #bff478, #8fce56);
}

.text-underline {
  text-decoration: underline;
}

.input-error-background{
  background-color: #ffaa00 !important;
}

.travel-content {
  line-height: 1.7;
}

.travel-content .text-red {
  color: #E5191A;
}

.bottom-margin40 {
  margin-bottom: 40px;
}

/* 迎車中の方位ありアイコン */
.taxiPositionIcon2{
  width: 48px;
  height: 48px;
  background-size: 192px 384px;
  background-position: 0px 0px;
  background-repeat: no-repeat;
  cursor: pointer;
}
.tel-btn{
  margin-top:20%;
  padding:10% 25% 10% 25%
}
/* Mobilecall Top Menu */
#mobilecall-topmenu {
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  overflow-y: scroll;
  background-color: #ffffff;
  z-index: 999999;
  display: none;
}
#mobilecall-topmenu #mobakuru-app_topmenu_body {
  padding: 10px;
}
.input-margin-bottom {
  margin-bottom: 300px !important;
}

.app2018-hidden {
  display: none !important;
  visibility: hidden !important;
}

/* PaymentConfirm 手入力決済 支払い確認画面 */
#PaymentConfirm {
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  overflow-y: scroll;
  background-color: #ffffff;
  z-index: 1000000;
  color: #000;
  line-height: 1.5;
  font-size: 14px;
  display: none;
}

#PaymentConfirm .mc-order-title {
  font-size: 17px;
}

#PaymentConfirm .uk-navbar-content {
  line-height: 60px;
  height: 60px;
  color: #fff;
  position: absolute;
  top: 0px;
  left: 0;
  right: 0;
  margin: auto;
}

#PaymentConfirm .mc-content-wrap {
  padding: 10px;
  padding-top: 10px;
}

#PaymentConfirm .mc-order {
  padding: 10px 20px 10px 20px;
  border: 2px solid #ccc;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
  border-bottom-right-radius: 10px;
  border-bottom-left-radius: 10px;
}

#PaymentConfirm button {
  min-height: 60px;
  font-size: 21px;
}

#PaymentConfirm .mc-fare {
  min-height: 60px;
  background: #fff !important;
  font-size: 25px;
}

#PaymentConfirm input::placeholder {
  color: #aaa;
}

#PaymentConfirm .mc-cash {
  margin-top: 20px;  
}

#PaymentConfirm .uk-modal-dialog{
  margin-top: 50px;
}

#PaymentConfirm .uk-open{
  position: fixed;
  top: 0;
}

/* PaymentComplete 手入力決済 支払い完了画面 */
#PaymentComplete {
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  overflow-y: scroll;
  background-color: #ffffff;
  z-index: 1000000;
  color: #000;
  line-height: 1.5;
  font-size: 21px;
  display: none;
}

#PaymentComplete .mc-content-wrap {
  padding: 10px;
  padding-top: 10px;
}

#PaymentComplete button {
  min-height: 60px;
  font-size: 21px;
}

#PaymentComplete .uk-navbar-content {
  line-height: 60px;
  height: 60px;
  color: #fff;
  position: absolute;
  top: 0px;
  left: 0;
  right: 0;
  margin: auto;
}

#PaymentComplete .mc-fare {
  min-height: 60px;
  background: #fff !important;
  font-size: 60px;
}

#PaymentComplete .uk-modal-dialog{
  margin-top: 50px;
}

#PaymentComplete .uk-open{
  position: fixed;
  top: 0;
}

#PaymentConfirm .mc-content-wrap{
  position: relative;
}

#payment-modal-confirm{
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  z-index: 1000005;
  display: none;
  color: black;
}

#confirm-dialog-box{
  background-color: ghostwhite;
}

#resend-result-modal{
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  z-index: 1000005;
  display: none;
  color: black;
}

#resend-result-modal-box{
  background-color: ghostwhite;
}

#cancel-result-modal{
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  z-index: 1000005;
  display: none;
  color: black;
}

#cancel-result-modal-box{
  background-color: ghostwhite;
}

#loadingWrapPayment {
  position: fixed;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  background-color: rgba(0,0,0, 0.2);
  z-index: 1000006;
  display: none;
  -webkit-backface-visibility:hidden;
  backface-visibility:hidden;
}

#loadingWrapPayment > span {
  position: absolute;
  display: block;
  top: 50%;
  left: 50%;
  width: 60px;
  height: 60px;
  margin-left: -30px;
  margin-top: -30px;
  border-radius: 5px;
}

#loadingWrapPayment > span > span {
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 30px;
  display: block;
  width: 60px;
  height: 60px;
}

.uk-nav-bar{
  position: relative;
  background-color: #2b49ff;
  color: #ffffff;
  background-image: -webkit-linear-gradient(top, #005dff, #473cff);
  background-image: linear-gradient(to bottom, #005dff, #473cff);
  border-color: rgba(0, 0, 0, 0.2);
  border-bottom-color: rgba(0, 0, 0, 0.4);
  text-shadow: 0 -1px 0 rgb(255 255 255 / 0%);
  height: 60px;
}

.card-hint-container {
  display: flex;
  text-align: center;
  justify-content: center;
  align-items: center;
}