@charset "UTF-8";
/*------------------------
VARIABLES
-------------------------*/
/*------------------------
HEADER FOOTER
-------------------------*/
/*------------------------
Denso Fonts
-------------------------*/

/* 英語用 */
@font-face {
  font-family: 'DENSO';
  font-style: normal;
  font-weight: 400;
  src: url('../font/DENSO-Regular.woff') format("woff");
}

@font-face {
  font-family: 'DENSO';
  font-style: normal;
  font-weight: 700;
  src: url('../font/DENSO-Bold.woff') format("woff");
}

/* 日本語用 */
@font-face {
  font-family: 'DENSOTP2017';
  font-style: normal;
  font-weight: 400;
  src: url('../font/DENSOTP2017-Regular.woff') format("woff");
}

@font-face {
  font-family: 'DENSOTP2017';
  font-style: normal;
  font-weight: 700;
  src: url('../font/DENSOTP2017-Bold.woff') format("woff");
}

/* 中国語用 */
@font-face {
  font-family: 'NotoSansCJKsc';
  font-style: normal;
  font-weight: 400;
  src: url('../font/NotoSansCJKsc-Regular.otf') format("opentype");
}

@font-face {
  font-family: 'NotoSansCJKsc';
  font-style: normal;
  font-weight: 700;
  src: url('../font/NotoSansCJKsc-Bold.otf') format("opentype");
}


/* ==========================================================================
header
========================================================================== */
#header{
  position: relative;
  z-index: 2;
  background-color: #fff;
}

.header {
  background: #FFF;
  max-width: 1026px;
  margin: 0 auto;
  padding: 30px 24px; }
  @media only screen and (max-width: 768px) {
    .header {
      min-width: 320px;
      padding: 20px; } }
  @media only screen and (max-width: 768px) {
    .header ul.d-inline {
      width: 100%; } }

@media only screen and (max-width: 768px) {
  .header.login-header {
    height: auto; } }

.header-title {
  font-size: 16px;
  margin-bottom: 0;
}
  @media only screen and (max-width: 768px) {
    .header-title {
      display: block;
      width: 100%;
      /* ロゴ画像高さ */
      margin: 0 auto 30px;
      padding-left: 0; } }
  .header-title img {
    max-width: 400px;
    max-height: 70px;
    object-fit: contain;
  }

.header-info {
  list-style: none;
  text-indent: 0;
  font-size: 16px;
  margin: 0;
  padding: 0;
  float: right; }
  @media only screen and (max-width: 768px) {
    .header-info {
      display: block;
      float: none;
      text-align: center;
      font-size: 12px; } }

.header-info-item {
  list-style: none;
  text-indent: 0;
  color: #4d4d4d;
  margin-left: 16px; }
  .header-info-item a {
    color: #ccc; }
    .header-info-item a:hover {
      opacity: 0.5; }

.global-menu-box {
  border-top: 1px solid #e5e5e5;
  box-shadow: 0 2px 4px 0px rgba(229,229,229,0.2);
  position:relative;
}

.global-menu {
  max-width: 1026px;
  margin: 0 auto;
  list-style: none;
  text-indent: 0;
  background: #FFF;
  position: relative;
  font-size: 16px;
  display: flex;
  align-items: center;
  margin-bottom: 0;
  padding: 20px 24px;
}
  @media only screen and (max-width: 768px) {
    .global-menu {
      margin: 0 auto;
      min-width: 100%;
      height: 65px; } }

.global-menu-item,
.global-menu-item-cart {
  list-style: none;
  text-indent: 0;
  text-align: center;
  position: relative;
  margin-right: 20px;}
  .global-menu-item .fas,
  .global-menu-item-cart .fas  {
    width: 100%;
    display: block;
    text-align: center; }
    @media only screen and (max-width: 768px) {
      .global-menu-item .fas,
      global-menu-item-cart .fas {
        width: 100%;
        font-size: 20px; } }

.header_submenu_inner2 .active {
  text-decoration: underline;
  color: #666;
}

.global-menu .active{
  border-bottom: 2px solid #e1002a;
}

.global-menu-left {
  float: right; }
  @media only screen and (max-width: 768px) {
    .global-menu-left {
      float: none;
      padding: 0; } }

.badge-cart {
  position: absolute;
  top: -8px;
  right: -8px;
  width: 23px;
  height: 23px;
  border-radius: 50%;
  background: #A70000;
  color: #FBFBFB;
  font-size: 10px;
  border-radius: 50%;
  margin: 0 auto;
  text-align: center;
  line-height: 19px;
  padding: 2px;
 }

.global-menu-box.transform {
  width: 100%;
  z-index: 15;
  position: fixed;
  top: 0;
  left: 0;
  transition: 0s;
  background: #fff;
}

/*------------------------
submenu
-------------------------*/

#header_submenu{
  text-align: right;
}

.header_submenu_inner1{
  margin-bottom: 20px;
}
.header_submenu_inner1 a{
  color: #4163b1;
}
.header_submenu_inner1 a:hover{
  text-decoration: underline;
  color: #4163b1;
}
.header_submenu_inner2,
.header_submenu_inner3{
  margin-bottom: 0;
}
.header_submenu_inner2 a:hover,
.header_submenu_inner3 .dropdown a:hover{
  text-decoration: underline;
  color: #666;
}

#header_submenu li{
  position: relative;
}

.header_submenu_inner1 li::after,
.header_submenu_inner2 li::after{
  content: "";
  position: absolute;
  top: 5px;
  right:-20px;
  width: 1px;
  height: 14px;
  margin: 0 10px;
  border-right: 1px solid #e5e5e5;
}

.header_submenu_inner1 li:last-child::after,
.header_submenu_inner2 li:last-child::after{
  content: none;
  border-right: none;
}

.fa-download,.fa-globe,.fa-user{
  color: #ccc;
  font-size: 16px;
}

/*------------------------
main_menu
-------------------------*/
.global-menu-item::after{
  content: "";
  position: absolute;
  top: 3px;
  right: -10px;
  width: 1px;
  height: 16px;
  border-right: 1px solid #e5e5e5;
}
.global-menu-item:last-child:after{
  content: none;
  border-right: none;
}
.global-menu-item:first-child::before{
  content: "";
  position: absolute;
  top: 3px;
  left: -10px;
  width: 1px;
  height: 16px;
  border-left: 1px solid #e5e5e5;
}

.global-menu .cart{
  position: absolute;
  top: 10px;
  bottom: 0;
  right: 18px;
  margin: auto 0;
  height: 2.7em;
}
.global-menu .cart a:hover{
  border-bottom: none;
}
.global-menu .cart:hover{
  border-bottom: 2px solid #e1002a;
}
.global-menu-item a:hover,
.global-menu-item-cart a:hover{
  border-bottom: 2px solid #e1002a;
  text-decoration: none;
  color:#666;
}
.global-menu-item a:visited,
.global-menu-item-cart a:visited{
  border-bottom: 2px solid #e1002a;
  text-decoration: none;
  color:#666;
}

.lang-menu ul{
  padding: 8px 0;
}

.lang-menu li{
  margin-right: 0!important;
}
.lang-menu li:hover{
  border-bottom:none!important;
}

/* cart */
.cart{
  text-align: center;
  position: relative;
  top: 4px;
}

.cart p{
  font-size: 12px;
  margin-bottom: 0;
  margin-top: 0;
}
.fa-shopping-cart{
  font-size: 24px;
  margin-right: 0;
  margin-left: -4px;
}

/* ==========================================================================
footer
========================================================================== */
.footer {
  color: #ccc;
  line-height: 18px;
  font-size: 12px;
  background-color: #404040;}
  @media only screen and (max-width: 768px) {
    .footer {
      width: 100%;
      padding: 0 8px;
      text-align: center; } }

.content-footer {
  position: fixed;
  bottom: 0;
  right: 0;
  padding: 4px;
  font-size: 10px;
  text-align: right;
  padding-right: 18px;
  width: 100%;
  background: #f2f2f2; }

.page-top {
  position: fixed;
  bottom: 20px;
  right: 10px;
  background: #a70000;
  text-align: center;
  opacity: 0.5;
  color: #FFF;
  cursor: pointer; }
  .page-top a {
    color: #FFF;
    width: 70px;
    height: 30px;
    display: block;
    padding-top: 6px; }
  .page-top a:hover {
    color: #FFF; }
  .page-top:hover {
    opacity: 0.8; }

.gFooter {
	position: relative;
	margin: 0;
	padding: 0;
}

.gFooter__content {
	border-top: 1px solid #666;
	box-sizing: content-box;
	position: relative;
	max-width: 978px;
	margin: 0 auto;
	padding: 10px 20px;
}

.gFooter__content:before, .gFooter__content:after {
	content: " ";
	display: table;
}

.gFooter__content:after {
	clear: both;
}

.gFooter__infoNav {
	float: left;
	margin: 0;
	padding: 0;
}

.gFooter__infoNavItem {
	margin-top: 2px;
	display: inline-block;
	padding: 0 0 0 5px;
	line-height: 1.25;
}

.gFooter__infoNavItem:before {
	content: "";
	display: inline-block;
	position: relative;
	top: 1px;
	width: 1px;
	height: 10px;
	margin: 0 10px 0 0;
	background-color: #fff;
}

.gFooter__infoNavItem:first-child {
	padding-left: 0;
	border-left: none;
}

.gFooter__infoNavItem:first-child:before {
	display: none;
}

.gFooter__infoNavLink, .gFooter__infoNavNoLink {
	font-size: 10px;
	font-size: 0.625rem;
	color: #fff;
	vertical-align: middle;
}

.gFooter__infoNavLink:hover {
	color: #fff;
	text-decoration: underline;
}

.gFooter__infoNavNoLink:hover {
	color: #fff;
	text-decoration: none;
}

.gFooter__copyright {
	font-size: 14px;
	font-size: 0.875rem;
	margin: 0;
	padding: 0;
	color: #999;
	line-height: 1.25;
}

.gFooter__infoNav, .gFooter__copyright {
	float: none;
}

/*------------------------
LAYOUT
-------------------------*/

html {
  height: 100%;
  padding: 0;
  margin: 0;
  font-family: "DENSOTP2017","DENSO","NotoSansCJKsc",Roboto,"Noto Sans JP";
  color: #666; }

body {
  font-family: "DENSOTP2017","DENSO","NotoSansCJKsc",Roboto,"Noto Sans JP";
  font-size: 16px;
  color: #666;
  background: #262626; }
  @media only screen and (max-width: 768px) {
    body {
      min-width: 320px; } }

body.login-bg {
  background: #FFF; }

a {
  color: #666; }

a:hover {
  text-decoration: none;
  color: #333; }

#mainWrapper {
  background: #FFF; }
  @media only screen and (max-width: 768px) {
    #mainWrapper {
      min-width: 320px; } }

ul, li {
  list-style: none;
  padding: 0; }

p.pl-summary {
	white-space:pre-wrap;
	max-width:490px;
}

p.pd-summary {
	white-space:pre-wrap;
}

p.pd-detail {
	white-space:pre-wrap;
	padding-left: 18px;
}

th.dt-del-btn{
	width:60px;
}

th.dt-price {
	width:100px;
}

th.dt-qty {
	width:100px;
}

th.dt-sub-total {
	width:100px;
}

label.dt-total-val{
	margin-bottom: 0px;
}

td.dt-img{
	width:180px;
	vertical-align:middle;
}

li.pl-top{
	vertical-align: top;
	display: table-cell;
}

li.pl-middle{
	vertical-align: middle;
	display: table-cell;
}

li.pl-bottm{
	vertical-align: bottom;
	display: table-cell;
}

.main {
  padding-bottom: 150px;
  font-size: 16px;
  background: #FFF;
  max-width: 978px;
  margin: 0 auto;
  border-radius: 5px; }
  @media only screen and (max-width: 768px) {
    .main {
      min-width: 320px; } }

 .dropdown-menu {
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 1000;
  display: none;
  float: left;
  min-width: 10rem;
  padding:0;
  margin: 5px 0 0;
  font-size: 1rem;
  color: #212529;
  text-align: left;
  list-style: none;
  background-color: #fff;
  background-clip: padding-box;
  border: 1px solid rgba(0, 0, 0, 0.15);
  border-radius: 0.25rem;
}

.form-search {
  top: 8px;
  right: 0;
  width: 80%; }
  .form-search:after {
    content: "";
    display: block;
    position: absolute;
    right: 0;
    top: 10px;
    z-index: 10;
    background-image: url(../images/search-solid.svg);
    background-repeat: no-repeat;
    width: 40px;
    height: 25px; }
  .form-search input {
    padding-right: 50px; }
  @media only screen and (max-width: 768px) {
    .form-search {
      top: auto;
      bottom: 8px;
      right: 0;
      width: 100%; } }

.form-search .input-group-text {
  border-top-left-radius: .3rem;
  border-bottom-left-radius: .3rem; }

.contents {
  background: #fff; }

.content-body-main {
  margin: 24px 0; }

.explanation-list p{
  margin-bottom: 30px;
}
.explanation-list li{
  margin:  0;
  padding: 0;
}
.explanation-list li:before{
  content:'';
  width:  10px;
  height:  10px;
  display:  inline-block;
  background-color: rgba(220,53,69,0.3);
  border-radius:  50%;
  position:  relative;
  top: -1px;
  margin-right: 5px;
}
.precautions_inner a{
  color: #4163b1;
}

.precautions_inner a:hover{
  text-decoration: underline;
  color: #4163b1;
}

.product-list,
.product-detail {
  padding: 0;
  list-style: none; }

.product-list-item {
  border: 1px solid #FFF;
  border-radius: .3rem; }
  .product-list-item + .product-list-item {
    margin-top: 10px; }
  .product-list-item a {
    color: inherit; }
  .product-list-item:hover {
    box-shadow: none !important;
    border: 1px solid #ced4da; }

.product-list-item-block,
.product-detail-item-block {
  padding: 18px;
  list-style: none;
  min-height: 200px;
  border-radius: .3rem; }
  @media only screen and (max-width: 768px) {
    .product-list-item-block,
    .product-detail-item-block {
      flex-direction: column; } }

.product-image {
  width: 180px;
  min-width: 180px;
  max-width: 180px;
  max-height: 180px;
  align-self: center;
  text-align: center;}
  @media only screen and (max-width: 768px) {
    .product-image {
      width: 100%;
      max-width: 100%;
      text-align: center;
      padding-bottom: 10px; } }
  .product-image img {
    max-width: 100%;
    max-height: 180px;
    height: auto;
    vertical-align: middle; }

.product-desc {
  padding: 0 10px;
  min-height:180px;
  max-width:490px;
  min-width:490px;
}

.product-name {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 12px;
  color: #a70000; }

.product-price {
  width: 180px;
  min-width: 180px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  text-align: right; }
  @media only screen and (max-width: 768px) {
    .product-price {
      width: 100%; } }

.product-kbn-1 {
  background: #bfbf4d;
  color: #FFF;
  border-radius: 0;
  font-size: 12px;
  font-weight: normal; }

.product-kbn-0 {
  background: #71965a;
  color: #FFF;
  border-radius: 0;
  font-size: 12px;
  font-weight: normal; }

@media only screen and (max-width: 768px) {
  .pagination {
    font-size: 12px; } }

.price-text {
  font-size: 20px;
  font-weight: 700; }

.more-btn {
  width: 100%;
  text-align: center;
  margin-top: 10px;
  background: #fb930c;
  padding: 10px 0;
  color: #FFF; }
  .more-btn:hover {
    background: #ffc107; }

.add-cart-btn {
  width: 100%;
  text-align: center;
  background: #a70000;
  color: #FFF; }
  .add-cart-btn .fas {
    font-size: 30px; }
  .add-cart-btn:hover {
    background: #BB0D0D;
    color: #FFF; }

.product-detail-image {
  max-width: 50%;
  min-width: 50%;
  width: 50%; }
  @media only screen and (max-width: 768px) {
    .product-detail-image {
      width: 100%;
      max-width: 100%;
      text-align: center;
      padding-bottom: 10px; } }
  .product-detail-image img {
    max-width: 100%;
    max-height: 438px;
    height: auto;
    vertical-align: middle; }
    @media only screen and (max-width: 768px) {
      .product-detail-image img {
        max-width: 300px;
        text-align: center;
        padding-bottom: 10px; } }

.product-detail-price {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  justify-content: flex-end;
  max-width: 50%;
  width: 50%;
  min-width: 50%;
  padding-left: 10px; }
  @media only screen and (max-width: 768px) {
    .product-detail-price {
      max-width: 100%;
      width: 100%;
      min-width: 100%;
      padding-bottom: 10px;
      padding-left: 0; } }
  .product-detail-price .product-name {
    margin-bottom: 0; }

.product-detail-info {
  padding: 20px 10px; }

.detail-info-title {
  padding: 18px 0 18px 0;
  font-size: 16px;
  font-weight: 700;
  border-bottom: 1px dashed rgba(80, 80, 80, 0.5);
  position: relative;
  margin-bottom: 20px; }

.price-num {
  margin: 10px 0;
  font-weight: 700;
  width: 100%;
  justify-content: flex-end; }
  @media only screen and (max-width: 768px) {
    .price-num {
      text-align: right; } }

.product-detail-image-home {
  max-width: 100%;
  height: 150px;
  position: relative;
  text-align: center; }
  .product-detail-image-home img {
    max-width: 100%;
    max-height: 140px;
    position: absolute;
    margin: auto;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0; }

.product-detail-price-home {
  ax-width: 100%; }
  .product-detail-price-home .product-name, .product-detail-price-home p {
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis; }

.stepper {
  color: #808080; }

.step {
  padding: 20px;
  border: 1px solid rgba(80, 80, 80, 0.5);
  margin: 10px;
  position: relative;
  width: 100%;
  text-align: center; }
  .step:after {
    content: "";
    position: absolute;
    border-top: 1px solid #999;
    border-right: 1px solid #999;
    width: 8px;
    height: 8px;
    top: 47.5%;
    right: -.8em;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg); }
  @media only screen and (max-width: 768px) {
    .step {
      padding: 8px;
      position: relative;
      font-size: 12px;
      margin: 0;
      border: none;
      border-top: 1px solid rgba(80, 80, 80, 0.5);
      border-bottom: 1px solid rgba(80, 80, 80, 0.5);
      border-right: 1px solid rgba(80, 80, 80, 0.5); }
      .step .fas {
        display: block; }
      .step:after {
        display: none; }
      .step:first-child {
        border-left: 1px solid rgba(80, 80, 80, 0.5); } }

.step:last-child:after {
  border: none; }

.step.step-active {
  color: #fff;
  background: #808080; }

.cart-info {
  position: absolute;
  bottom: 0;
  right: 0; }

.table-soft th {
  font-weight: normal;
  border-top: none; }

.td-total {
  border-bottom: 0px solid #262626; }

.product-table {
  border-top: 1px solid #262626; }

.note {
  background: #f5f5f5;
  border: 1px solid #CCC;
  padding: 10px; }

@media only screen and (max-width: 768px) {
  .table tbody tr:not(:first-child) td.td-col-del {
    border-top: 1px solid #262626; } }

.login-label-item{
	width:7rem;
}

.label-item,
.label-item01 {
  width: 16rem; }

.label-item02 {
  display: inline-block;
  padding-left: 5rem;
  width: 16rem; }

.label-item03 {
  padding-left: 3rem; }

@media only screen and (max-width: 768px) {
  .label-item, .label-item01, .label-item02, .label-item03 {
    width: 100%;
    display: inline-block;
    padding: 0;
    font-weight: 700; } }

@media only screen and (max-width: 768px) {
  .label-item, .label-item02, .label-item03 {
    border-left: 2px solid #ccc;
    padding-left: 10px;
    margin-bottom: 10px; } }

.list-data {
  flex-grow: 1; }

.news-date {
  width: 80px;
  display: inline-block;
  float: left;
  line-height: 1.5rem; }

.news-title {
  width: 100%;
  display: inline-block;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  margin-left: -80px;
  padding-left: 80px;
  color: #666; }

a:hover .news-title {
  color: red; }

.main-title {
  padding: 18px 0 18px 18px;
  font-size: 24px;
  border-bottom: 1px solid rgba(80, 80, 80, 0.5);
  position: relative; }

@media only screen and (max-width: 768px) {
  .main-title-list {
    padding-bottom: 58px; } }

.main-title:after {
  content: "";
  display: block;
  position: absolute;
  top: 22px;
  left: 0;
  height: 20px;
  border-left: 2px solid #a70000; }

.regist-label {
  min-width: 10em;
  justify-content: center;
  display: flex;
  padding: 2px 0; }

.regist-item {
  justify-content: center;
  display: flex; }

.regist-label-sm {
  min-width: 3em;
  justify-content: center;
  display: flex;
  padding: 2px 0; }

.form-regist-group {
  border: 1px solid rgba(80, 80, 80, 0.05);
  background: #fff;
  padding: 12px 16px;
  margin-bottom: -1px; }

.btn-area {
  padding-top: 16px;
  padding-bottom: 18px;
  border-top: 1px solid rgba(80, 80, 80, 0.1);
  overflow: hidden; }

.info-panel {
  padding: 8px 8px 18px;
  background: #fff; }

.sub-title {
  padding: 8px 0 8px 10px;
  position: relative;
  border-bottom: 1px solid rgba(80, 80, 80, 0.1);
  font-size: 18px;
  background: #fff;
  margin: 0; }

.sub-title:before {
  content: "";
  display: block;
  width: 1px;
  height: 12px;
  position: absolute;
  left: 0;
  top: 12px;
  border-left: 1px solid #505050; }

.sub-title:after {
  content: "";
  display: block;
  width: 1px;
  height: 12px;
  position: absolute;
  left: 1px;
  top: 12px;
  border-left: 1px solid rgba(80, 80, 80, 0.3); }

.info-list {
  list-style: none; }

.info-list-item {
  border-bottom: 1px dashed rgba(80, 80, 80, 0.3);
  margin-bottom: 8px;
  padding-bottom: 8px; }

.info-list-item:last-child {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0; }

.text-date {
  font-weight: normal;
  font-size: 14px;
  line-height: 16px;
  vertical-align: center;
  display: inline-block;
  padding: 4px;
  padding-left: 0;
  color: #505050;
  margin-left: -5px; }

.text-info-title {
  margin-bottom: 0;
  font-size: 14px;
  line-height: 20px;
  padding-top: 4px;
  padding-left: 12px;
  border-left: 2px solid rgba(80, 80, 80, 0.3);
  color: #505050; }

.text-info-text {
  padding-top: 12px;
  margin-bottom: 0; }

.scroll-area {
  height: 300px;
  overflow-y: scroll;
  padding: 12px 18px; }

.system-menu-list {
  padding: 0;
  margin: 0 0 8px 0;
  border: 1px solid #000; }
  @media only screen and (max-width: 768px) {
    .system-menu-list {
      margin-left: 0; } }
  @media only screen and (max-width: 575px) {
    .system-menu-list {
      margin-left: 0; } }
  .system-menu-list .system-menu-item {
    display: block;
    padding: 12px 14px;
    height: 100%; }
    .system-menu-list .system-menu-item dl, .system-menu-list .system-menu-item dd, .system-menu-list .system-menu-item dt {
      margin-bottom: 0;
      position: relative; }
    .system-menu-list .system-menu-item dd {
      padding-top: 16px; }
    .system-menu-list .system-menu-item dt {
      border-bottom: 1px solid rgba(255, 255, 255, 0.3);
      padding-bottom: 8px; }

.nav-system-download,
.nav-system-cd,
.nav-system-license {
  padding-left: 30px; }

.nav-system-download:before,
.nav-system-cd:before,
.nav-system-license:before {
  content: "";
  display: block;
  width: 25px;
  height: 25px;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: left center;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto; }

.nav-system-download:before {
  background-image: url(../images/icon-download.png); }

.nav-system-cd:before {
  background-image: url(../images/icon-cd.png); }

.nav-system-license:before {
  background-image: url(../images/icon-ribbon.png); }

.id-table {
  border: 1px solid rgba(80, 80, 80, 0.3);
  border-bottom: none;
  padding: 0; }
  .id-table dt {
    font-weight: normal;
    background: #f5f5f5;
    background-color: #f5f5f5;
    background-image: linear-gradient(to top, rgba(0, 0, 0, 0.05), #f5f5f5);
    padding: 8px;
    border-bottom: 1px solid rgba(80, 80, 80, 0.3); }
  .id-table dd {
    padding: 8px;
    border-bottom: 1px solid rgba(80, 80, 80, 0.3);
    margin-bottom: 0; }

.status-on {
  font-size: 12px;
  display: block;
  text-align: center;
  width: 100%;
  color: #fff;
  background: #2196F3;
  padding: 2px 4px; }

.status-off {
  font-size: 12px;
  display: block;
  text-align: center;
  width: 100%;
  color: #fff;
  background: #ccc;
  padding: 2px 4px; }

.price-info, .price-num {
  text-align: right; }

@media only screen and (max-width: 768px) {
  .form-inline .form-control {
    width: 100%; } }

@media only screen and (max-width: 768px) {
  .table .table-soft {
    display: none; } }

@media only screen and (max-width: 768px) {
  .table tbody .td-total {
    width: 50%;
    float: left;
    height: 82px; } }

/*------------------------
TABLE PARTS
-------------------------*/
.datatables th {
  white-space: nowrap; }
.datatables thead {
  cursor: pointer; }

.col-no {
  min-width: 60px; }

.col-chk {
  min-width: 64px; }

.col-id {
  min-width: 130px; }

.col-name {
  min-width: 150px; }

.col-auth {
  min-width: 100px; }

.col-state {
  min-width: 90px; }

.col-oem {
  min-width: 80px; }

.col-simuke {
  min-width: 80px; }

.col-date {
  min-width: 120px; }

.col-log_no {
  min-width: 130px; }

.col-soft_ver {
  min-width: 230px; }

.col-hard_ver {
  min-width: 100px; }

.col-hard_text {
  min-width: 100px; }

.col-text {
  min-width: 100px; }

.scroll-table-area {
  width: 100%;
  overflow-x: auto; }
  .scroll-table-area thead, .scroll-table-area td {
    white-space: nowrap; }

/*------------------------
PANEL DIALOG PARTS
-------------------------*/
.login-panel {
  padding: 1em 1em 0.5em;
  display: block;
  border-radius: 5px; }

/*------------------------
LIBRARY CUSTMIZE
-------------------------*/
.far, .fas, .fa {
  margin-right: 8px; }

.switch {
  position: relative;
  display: inline-block;
  width: 120px;
  height: 34px; }

.switch-b {
  position: relative;
  display: inline-block;
  width: 120px;
  height: 34px; }

/* Hide default HTML checkbox */
.switch input,
.switch-b input {
  display: none; }

/* The slider */
.switch .slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #ccc;
  -webkit-transition: .4s;
  transition: .4s; }

.switch .slider:before {
  position: absolute;
  content: "";
  height: 26px;
  width: 26px;
  left: 4px;
  bottom: 4px;
  background-color: white;
  -webkit-transition: .4s;
  transition: .4s; }

.switch input:checked + .slider {
  background-color: #2196F3; }

.switch input:focus + .slider {
  box-shadow: 0 0 1px #2196F3; }

.switch input:checked + .slider:before {
  -webkit-transform: translateX(86px);
  -ms-transform: translateX(86px);
  transform: translateX(86px); }

.switch input:checked + .slider:after {
  content: "利用する";
  color: #fff;
  line-height: 35px;
  padding-left: 4px;
  position: absolute;
  left: 4px;
  top: 1px; }

.switch input + .slider:after {
  content: "利用しない";
  color: #fff;
  line-height: 35px;
  padding-left: 4px;
  position: absolute;
  right: 6px;
  top: 1px; }

/* The slider */
.switch-b .slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #ccc;
  -webkit-transition: .4s;
  transition: .4s; }

.switch-b .slider:before {
  position: absolute;
  content: "";
  height: 26px;
  width: 26px;
  left: 4px;
  bottom: 4px;
  background-color: white;
  -webkit-transition: .4s;
  transition: .4s; }

.switch-b input:checked + .slider {
  background-color: #2196F3; }

.switch-b input:focus + .slider {
  box-shadow: 0 0 1px #2196F3; }

.switch-b input:checked + .slider:before {
  -webkit-transform: translateX(86px);
  -ms-transform: translateX(86px);
  transform: translateX(86px); }

.switch-b input:checked + .slider:after {
  content: "ON";
  color: #fff;
  line-height: 35px;
  padding-left: 4px;
  position: absolute;
  left: 4px;
  top: 1px; }

.switch-b input + .slider:after {
  content: "OFF";
  color: #fff;
  line-height: 35px;
  padding-left: 4px;
  position: absolute;
  right: 6px;
  top: 1px; }

.card {
  border-radius: 0; }

.card .card-header a[data-toggle="collapse"] {
  display: block;
  padding: .75rem 1.25rem;
  margin: -.75rem -1.25rem; }

.news-title {
  position: relative; }

.badge-list {
  position: relative;
  top: -2px;
  display: inline-block;
  width: 25px;
  height: 25px;
  line-height: 25px;
  padding: 0;
  text-align: center;
  background-color: #ed1c24;
  color: #fff;
  border-radius: 100%;
  font-size: 10px; }

/*------------------------
BTN
-------------------------*/
.btn {
  letter-spacing: 1px; }

.btn-login {
  width: 100%;
  color: #fff;
  padding: 8px;
  background-color: #086496;
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.2), #086496);
  border: 1px solid #086496; }
  .btn-login:hover {
    color: #fff;
    background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), #086496); }

.btn-regist-user {
  width: 100%;
  color: #fff;
  padding: 8px;
  background-color: #333333;
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.2), #333333);
  border: 1px solid #333333; }
  .btn-regist-user:hover {
    color: #fff;
    background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), #333333); }
  @media only screen and (max-width: 575px) {
    .btn-regist-user {
      font-size: 12px; } }

.btn-action {
  color: #fff;
  background-color: #086496;
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.2), #086496);
  border: 1px solid #086496; }
  .btn-action:hover {
    color: #fff;
    background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), #086496); }

.btn-system {
  color: #fff;
  background-color: #086496;
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.2), #086496), url(../images/btn_bg.png);
  background-repeat: no-repeat;
  background-size: auto,contain;
  background-position: top,right bottom;
  border: 1px solid #086496; }
  .btn-system:hover {
    color: #fff;
    background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), #086496); }
  .btn-system a {
    color: #fff; }

.btn-clear {
  color: #505050;
  background-color: #fff;
  background-image: linear-gradient(to top, rgba(80, 80, 80, 0.1), #ffffff);
  border: 1px solid #cccccc; }
  .btn-clear:hover {
    color: #000;
    background-image: linear-gradient(to top, rgba(80, 80, 80, 0.2), #ffffff); }

.cart-maker-image {
  width: 180px;
  min-width: 180px;
  max-width: 180px;
  max-height: 180px;
  align-self: center;
  text-align: center;}
  @media only screen and (max-width: 768px) {
    .cart-maker-image {
      width: 100%;
      max-width: 100%;
      text-align: center;
      padding-bottom: 10px; } }
  .cart-maker-image img {
    max-width: 100%;
    max-height: 180px;
    height: auto;
    vertical-align: middle; }
