html {
  height: 100%;
}
body {
  font-family: "Helvetica Neue";
  color: #333;
  height: 100%;
}
body.overflow-hidden {
  overflow: hidden;
}
a {
  text-decoration: none;
}
a:hover {
  color: #1192d4;
  text-decoration: underline;
}
a:focus-visible {
  outline: none;
}
button:focus {
  outline: none !important;
}
img {
  max-width: 100%;
  max-height: 100%;
}
.ec-layoutRole {
  min-height: 100%;
  display: flex;
  flex-direction: column;
}
.ec-layoutRole__footer {
  margin-top: auto;
}
.ec-blockTopBtn {
  position: fixed;
  bottom: 0;
  right: 9px;
  background-color: #D0D0D0;
  width: 43px;
  height: 43px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  opacity: 1;
}
.ec-blockBtn--action {
  background-color: #2177AA;
}
.ec-blockBtn--action:hover {
  background-color: #2177AA;
}
.ec-blockBtn--action:focus,
.ec-blockBtn--action:active:focus,
.ec-blockBtn--cancel:focus {
  outline: none;
}
.ec-blockBtn--cancel:active,
.ec-blockBtn--cancel.active {
  box-shadow: none;
}
.ec-blockBtn--cancel:active:focus {
  background-color: transparent;
  color: inherit;
  outline: none;
}
.ec-layoutRole .ec-layoutRole__contents {
  max-width: 1200px;
}
.ec-layoutRole .ec-layoutRole__left {
  display: block;
}
.ess-phone__hidden {
  display: none;
}
.ess-blockHeading {
  color: #323232;
}
.ess-blockHeading .ess-blockHeading__en {
  font-size: 28px;
  font-weight: 500;
}
.ess-blockHeading .ess-blockHeading__ja {
  font-size: 18px;
  font-weight: bold;
}
.product-symbol-code {
  display: inline-block;
}
.ess-page-title {
  font-size: 18px;
  margin: 15px 0 0;
}
.ess-heading {
  color: #1192d4;
  font-size: 18px;
  padding: 2px 0 0 20px;
  line-height: 1;
  position: relative;
  margin: 2px 0 0;
}
.ess-heading:before {
  content: '';
  width: 5px;
  height: 100%;
  background-color: #1192d4;
  position: absolute;
  left: 0;
  top: -2px;
}
.ess-description-list {
    border: 1px solid #e7e5e5;
}
.ess-description-list dl {
    border-top: 1px dotted #e7e5e5;
    margin-bottom: 1px;
}
.ess-description-list dt {
  background-color: #F5F5F5;
  padding: 10px;
  font-weight: normal;
}
.ess-description-list dd {
  padding: 10px;
}
.ck-content {
  word-break: break-all;
  overflow: hidden;
}
.ck-content .table {
  margin-left: 0;
  display: block !important;
  overflow: auto;
}
.ck-content .table table {
  width: inherit !important;
}
input {
  color: #323232 !important;
}
input::placeholder,
input::-webkit-input-placeholder {
  color: #D1D1D1 !important;
}
.ess-mypage-title {
  font-size: 18px;
  margin: 20px 0 24px 6px;
}

@media (min-width: 801px) {
  .ess-mypage-title {
    font-weight: bold;
  }
  .ec-layoutRole .ec-layoutRole__left {
    width: 0;
  }
  .ec-layoutRole .ec-layoutRole__mainWithColumn {
    width: 100%;
  }
  .ess-description-list dl {
    display: flex;
    border-top: 1px dotted #e7e5e5;
    margin-bottom: 1px;
  }
  .ess-description-list dt {
    width: 240px;
    padding: 20px 25px;
  }
  .ess-description-list dd {
    width: calc(100% - 240px);
    padding: 20px 25px;
  }
  .ess-page-title {
    font-size: 27px;
    font-weight: bold;
    margin: 50px 0 0;
  }
  .ess-heading {
    font-size: 22px;
  }
  .ess-mypage-title {
    font-size: 20px;
    margin: 20px 0 30px;
  }
}
@media (max-width: 800px) {
    .form-control {
        font-size: 16px;
    }
}

@media only screen and (min-width: 1200px) {
  .ec-layoutRole .ec-layoutRole__left {
    margin-right: 10px;
    width: 290px;
    border-right: 1px solid #BEBEBE;
  }
  .ec-layoutRole .ec-layoutRole__mainWithColumn {
    width: 890px;
  }
}

.font-three-page {
    font-family: "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif !important;
}
.font-three-page .style-number {
    font-family: 'Arvo', serif;
}
.btn {
    border-radius: 3px!important;
    border: none!important;
    font-weight: normal!important;
    font-size: 16px!important;
}
.btn-primary {
    border: none;
}
.note-require-name {
  padding-top: 7px;
  color: #313131;
  font-size: 14px;
}
@font-face {
  font-family: Arvo;
  src: url('../../assets/fonts/Arvo/Arvo-Regular.ttf');
}

.ec-searchnavRole .category-name {
  font-family: system-ui !important;
}

.fz-13 {
  font-size: 13px;
}

.fz-15 {
  font-size: 15px;
}

.fz-16 {
  font-size: 16px;
}

.fz-18 {
  font-size: 18px;
}

.fz-20 {
  font-size: 20px;
}

.fz-24 {
  font-size: 24px;
}

.pr-05 {
  padding-right: 5px;
}

.w-auto {
  width: auto !important;
}
.letterSpaceMid {
  letter-spacing: 1px;
}

.cursor-not-allow {
  cursor: not-allowed;
}
.addr01-disable {
  background-color: #fff!important;
}
