@charset "UTF-8";
@import "../fonts.css";
html {
  background-color: #f1f1f1;
}
html * {
  box-sizing: border-box;
}
body {
  max-width: 480px;
  margin: 0 auto;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS P Gothic", sans-serif;
  background-color: #fff;
}

a {
  color: #333;
  text-decoration: none;
  /* font-family: Montserrat; */
}

a:hover {
  color: inherit;
  text-decoration: underline;
}

a:hover img {
  opacity: 0.8;
}

.container {
  width: 100%;
  padding-left: 15px;
  padding-right: 15px;
}

header {
  padding-top: 15px;
  overflow: hidden;
  display: flex;
  padding: 15px 10px;
  align-items: center;
  justify-content: space-between;
}

img {
  vertical-align: middle;
  max-width: 100%;
  height: auto;
}
#logo {
  width: 43%;
  /* float: left; */
}

#logo img {
  max-width: 100%;
}

#header-des {
  width: 55%;
  /* float: left; */
  font-size: 10px;
  position: relative;
  /* padding-top: 20px; */
  text-align: right;
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

#header-des p {
  margin: 0;
  font-weight: bold;
  margin-top: 5px;
}

#header-btn-menu {
  width: 35px;
  /* position: absolute; */
  /* top: 0; */
  /* right: 10px; */
}

#header-btn-menu span {
  border-bottom: 4px solid #000;
  display: block;
  margin-top: 4px;
}

.des-info {
  color: #cc3333;
  text-align: right;
  /* padding-right: 50px; */
  margin-top: 0;
}

.des-info a {
  color: #cc3333;
}

.btn-menu {
  height: 30px;
  margin-top: 1px;
  border: none;
  background: none;
}

.img-center img {
  display: block;
  margin: 0 auto;
}

.text-center {
  text-align: center;
}

.contact-call {
  margin-top: 10px;
  color: #cc3333;
  font-style: italic;
}

.navbar-sakairib {
  border: none;
  background: none;
  text-align: center;
  font-weight: bold;
  min-height: auto;
  margin-bottom: 0;
}

.navbar-sakairib .navbar-brand {
  color: #c41922;
}

.navbar-sakairib .container-fluid > .navbar-header {
  border-bottom: 1px solid #c41b24;
}

.navbar-sakairib .navbar-toggle,
.navbar-sakairib .navbar-toggle {
  border-radius: 0;
  background-color: #c41922;
}

.collapse {
  display: none;
}

.navbar-sakairib ul.nav,
.navbar-sakairib ul.nav li {
  float: none;
}

.navbar-sakairib .navbar-toggle .icon-bar {
  background-color: #fff;
}

.navbar-sakairib .navbar-toggle:hover .icon-bar,
.navbar-sakairib .navbar-toggle:focus .icon-bar {
  background-color: #c41922;
}

.navbar-sakairib .navbar-nav > .active > a,
.navbar-sakairib .navbar-nav > .active > a:hover,
.navbar-sakairib .navbar-nav > .active > a:focus {
  color: #fff;
  background: #c41b24;
}
#menu ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
#menu ul li a {
  padding: 7px 15px;
  display: block;
}
.form-control {
  width: 100%;
  padding: 10px 15px;
  border: 1px solid #ccc;
}
h1.common-page-title {
  margin-bottom: 20px;
}

h2.title {
  font-size: 18px;
  border-left: 5px solid #cc3333;
  padding: 5px 0 5px 5px;
  font-weight: bold;
}

.top-product {
  display: block;
  overflow: hidden;
}

.sp-product p {
  overflow: hidden;
  margin-bottom: 0;
}

.sp-product {
  width: 50%;
  float: left;
  padding: 5px;
  text-align: center;
}

.hr_detail {
  margin: 10px 0;
}

.sp-product img {
  max-width: 100%;
  max-height: 100%;
  height: auto;
  width: auto;
}

.sp-product a {
  color: #000;
  font-weight: normal;
  font-size: 12px;
  display: block;
}
.sp-product a.thumbnail {
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 160 / 90;
}
.sp-product a.overwhite {
  height: 100px;
  margin-bottom: 5px;
}

.banner.sp-product a.overwhite {
  height: auto;
  background: none;
}

.view-all {
  float: right;
  font-size: 12px;
  color: #cc3333;
}

.view-all .glyphicon {
  font-size: 8px;
}

.example .sp-product p {
  overflow: hidden;
  margin-bottom: 0;
}

.common-page-title > .en,
#headline > .headline-block > .title {
  color: #cc3333 !important;
  border-bottom-color: #cc3333 !important;
}

.banner a {
  margin-bottom: 10px;
  display: block;
}

.banner img {
  height: auto;
}

.common-page-title > .en {
  display: table-cell;
  border-bottom: 2px solid #d9000d;
  font-size: 14pt;
  font-weight: bold;
  width: 10%;
  padding-right: 1em;
  line-height: 1;
  vertical-align: bottom;
  padding-bottom: 5px;
  color: #d9000d;
}

.common-page-title > .ja {
  display: table-cell;
  border-bottom: 2px solid #ccc;
  vertical-align: bottom;
  padding-bottom: 3px;
  font-size: 13pt;
  color: rgb(137, 137, 137);
}

#newsGroup {
  overflow-y: auto;
  max-height: 300px;
}

.news1Line .category {
  padding-top: 5px;
  color: #fff;
  width: 100px;
  font-size: 80%;
  text-align: center;
  vertical-align: middle;
}

.category img {
  width: 120px;
  float: left;
}

.news1Line > .title {
  vertical-align: middle;
  padding-left: 0;
  font-weight: bold;
  margin-bottom: 10px;
}

.banner a img {
  width: 100%;
  max-width: 100%;
}

.banner-ads {
  padding: 10px;
  background-color: #eeeeee;
  border: 1px #ccc solid;
}

.banner .banner-ads a {
  margin-bottom: 10px;
}

#sidebar .box {
  margin-top: 0;
  border: none;
  background: none;
}

#sidebar img {
  width: 100%;
  max-width: 100%;
}

#sidebar ul.products-sidebar-list {
  list-style: none;
  margin: 0;
  padding: 10px;
}

#sidebar ul.products-sidebar-list li a {
  display: block;
  padding-bottom: 5px;
}

#sidebar select,
#sidebar input {
  border-radius: 0;
}

.box .sidebar-search {
  padding: 20px;
  text-align: center;
  padding-top: 10px;
}
.box .sidebar-search button,
#sidebar .box button {
  background: none;
  background-image: url(./img/search.png);
  background-size: 100%;
  background-repeat: no-repeat;
  background-position: center;
  text-indent: -9999px;
  cursor: pointer;
  padding: 15px 75px;
  border: none;
  text-align: center;
}
.box .sidebar-search button:hover,
#sidebar .box button:hover {
  background-image: url(./img/search_hover.png);
}

.boxFirst {
  padding: 10px;
  overflow: hidden;
}

.boxFirst .priceType {
  display: block;
  padding-bottom: 5px;
}

.boxFirst .priceLeft,
.boxFirst .priceRight {
  width: 45%;
  display: table-cell;
}

.boxFirst .priceCenter {
  display: table-cell;
}

.boxFirst input {
  width: 80%;
  padding: 5px;
  border: 1px solid #ccc;
}

#sidebar .contact_box {
  padding: 20px;
}

#sidebar .contact_box img {
  width: auto;
  display: block;
  margin: 0 auto;
}

#sidebar .sns {
  text-align: center;
  padding: 20px 0;
}

#sidebar .sns img {
  width: auto;
  margin-bottom: 10px;
}

footer {
  background-color: #cc3333;
  color: #fff;
  text-align: center;
  overflow: hidden;
  margin-top: 50px;
}

footer .footerNavi {
  overflow: hidden;
}

footer ul {
  list-style: none;
  padding: 20px 0;
  margin: 0;
  text-align: center;
  color: #fff;
  width: 50%;
  float: left;
}

footer ul li a {
  color: #fff;
}

#copyright {
  width: 100%;
  background-color: #555;
  display: block;
  color: #fff;
  text-align: center;
  font-size: 75%;
  font-style: normal;
  padding: 10px 0;
}

/*CSS PRODUCT DETAIL */

.sp-product .title {
  border: 1px #cc3333 solid;
  padding: 2px 10px;
  color: #cc3333;
  margin-right: 10px;
}

.button .sp-product img {
  width: auto;
  height: auto;
}

.listCommon {
  overflow: hidden;
  padding-top: 20px;
}

.listCommon .rank_title {
  font-size: 14pt;
}

.ranks .rank_t {
  background-color: #ccc;
  border: 1px #ccc solid;
  padding: 10px 0;
  text-align: center;
  vertical-align: middle;
  font-size: 12px;
  font-weight: bold;
  margin-bottom: 0;
}

.ranks ul {
  overflow: hidden;
  list-style: none;
  margin: 0;
  padding: 0;
}

.ranks ul li {
  width: 50%;
  float: left;
  text-align: center;
}

.ranks ul li:nth-child(2n + 1) b,
.ranks ul li:nth-child(2n + 1) span {
  border-left: 1px solid #ccc;
}

.ranks ul li b,
.ranks ul li span {
  display: block;
  padding: 2px 0;
  border-right: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
}

.listCommon > table th,
.listCommon > table td {
  border: 1px #ccc solid;
  padding: 2px 0;
  text-align: center;
  background-color: #fff;
  vertical-align: middle;
  font-size: 12px;
}

/* CSS PAGINATOR */

.paginator {
  text-align: center;
  margin-top: 20px;
}

.paginator ul.pagination {
  margin-top: 5px;
}

.pagination > li:last-child > a,
.pagination > li:last-child > span,
.pagination > li:first-child > a,
.pagination > li:first-child > span {
  border-radius: 0;
}

.pagination > li > a,
.pagination > li > span {
  color: #cc3333;
}

.pagination > .active > a,
.pagination > .active > span,
.pagination > .active > a:hover,
.pagination > .active > span:hover,
.pagination > .active > a:focus,
.pagination > .active > span:focus {
  background-color: #cc3333;
  border-color: #cc3333;
}

.pagination > li > a:hover,
.pagination > li > span:hover,
.pagination > li > a:focus,
.pagination > li > span:focus {
  background-color: #cc3333;
  border-color: #cc3333;
  color: #fff;
}

/* CSS LIST GALLERY CATEGORIES */

.gallery_categories {
  list-style: none;
  margin: 0;
  padding: 0;
}

.gallery_categories li {
}

.gallery_categories li a {
  display: block;
  padding: 5px 20px;
  padding-left: 50px;
  background-image: url(./img/gallery-icon.jpg);
  background-repeat: no-repeat;
  background-position: 10px 6px;
  color: #000;
  font-weight: bold;
  font-size: 15px;
  border-bottom: 1px solid #bdbdbd;
  background-color: #efefef;
}

.gallery_categories li a.active,
.gallery_categories li a:hover {
  color: #cc3333;
  background-image: url(./img/gallery-icon-active.jpg);
  text-decoration: none;
}

.gallery_categories li a span.ex-ja {
  float: right;
  font-size: 13px;
}

.gallery {
  list-style: none;
  margin: 0;
  padding: 0;
}

.gallery li {
  padding: 0;
}

div#details {
  background: #fff;
}

#details table {
  width: 100%;
}

#details table th {
  width: 20%;
}

#details table th.thbody:last-child {
  width: 60%;
}

#details table tr td img {
  width: 100%;
  max-width: 100%;
}

#details table.info_product th {
  width: 35%;
}

#image-gallery li {
  width: 100%;
}

#image-gallery li img {
  width: 100%;
}

.group {
  display: block;
  overflow: hidden;
}

.group .item {
  width: 50%;
  float: left;
  padding: 5px;
  text-align: center;
}

.group .item img {
  max-width: 100%;
  height: auto;
}

#catalog .box {
  text-align: center;
  padding-top: 20px;
  padding-left: 10px;
  padding-right: 10px;
  padding-bottom: 50px;
}

#catalog .box .introText,
#catalog .box .ruleLink {
  text-align: center;
  margin: 1em 0 2em;
  /* font-family: Montserrat; */
}

#catalog .box .ruleLink {
  font-size: 120%;
  margin-bottom: 2em;
}

.rule li {
  margin-top: 1em;
}

.rule li.styleNone {
  list-style: none;
}

.rule li.styleNone ul {
  list-style: none;
  padding-left: 2em;
}

#method .box {
  padding-top: 20px;
  padding-left: 10px;
  padding-right: 10px;
  padding-bottom: 50px;
}

#method .box .title {
  color: #999;
  font-size: 16px;
  margin-bottom: 1em;
  border-bottom: 1px #ccc solid;
  font-weight: bold;
}

a.red,
.color-red {
  color: #cc3333 !important;
}

#method .box h2 {
  font-size: 16px;
  border-left: 5px solid #cc3333;
  padding: 5px 0 5px 5px;
  font-weight: bold;
}

#method .box ul {
  list-style: inside;
  margin-left: 0;
  padding-left: 10px;
}

#method .box ul li {
  margin-bottom: 0.5em;
}

#method .box ul li a {
  color: #333;
  text-decoration: none;
}

#method .box ul li a:hover {
  text-decoration: underline;
}

#method .box img {
  max-width: 100%;
  height: auto;
}

#method .mcontents,
#method .others {
  width: 100%;
  margin: 10px 0;
}

#method .box .contents2 .left {
  float: left;
  width: 30%;
  margin-right: 5%;
  margin-left: 10px;
  font-size: 100%;
  background-color: #396;
  text-align: center;
  color: #fff;
  padding: 0.4em 5px;
  /* font-family: Montserrat; */
}

#method .box .contents2 .right {
  float: left;
  width: 60%;
  /* font-family: Montserrat; */
}

#method .box .contents2 .allow {
  padding: 0.5em 0 0.5em 15%;
  clear: both;
  font-size: 150%;
  color: #339966;
}

#method .rightFig1 {
  float: left;
}

h3.line {
  border-bottom: 1px solid #000;
  display: table;
  margin: 30px 0px 15px;
  font-size: 14px;
}

.left-radius {
  margin: 5px 15px 30px;
  border-radius: 10px;
  border-left: 1px solid #000;
  padding-left: 10px;
}

table,
th,
td {
  border: 1px solid black;
  text-align: center;
  padding: 3px;
}

#method .box .subCaption {
  background-color: #888;
  padding: 0.4em 1em;
  color: #fff;
  margin: 2em 0 0;
  /* font-family: Montserrat; */
}

#method .commonBaseBox {
  background-color: #fff;
  padding: 15px;
  overflow: hidden;
  /* font-family: Montserrat; */
}

/* PDF CSS */

.calam h2 {
  font-size: 22px;
}

.calam ul {
  list-style: none;
  margin: 0;
  padding: 0;
  margin-bottom: 2em;
}

.calam ul li {
  font-size: 90%;
  background: url(../../img/catalog/icon_pdf.gif) no-repeat 0 2px;
  padding-left: 25px;
  border-bottom: 1px #ccc dotted;
  padding-bottom: 3px;
  margin-bottom: 15px;
}

.getReaderText,
.getReader {
  text-align: center;
  margin: 0 auto 10px;
}

table.cad-sm {
  width: 100%;
}

table.cad-sm th,
table.cad-sm td {
  border: 1px #ccc solid;
  padding: 5px 0;
}

table.cad-sm th {
  width: 50%;
}

.nofile {
  opacity: 0.5;
}

.kiyaku {
  margin-top: 30px;
}

#faq .box {
  padding: 10px;
  background: #eeeeee;
}

.faqList {
  list-style: none;
  margin: 0;
  padding: 0;
  margin-bottom: 3em;
}

#faq .box .faqList li {
  padding: 1em;
  background-color: #fff;
  border-bottom: 1px dotted #ccc;
}

#faq .box .faqList li:before {
  content: url(../../img/common/icon_tri.png);
  padding-right: 0.3em;
}

#faq .box .faq {
  list-style: none;
  margin: 0;
  padding: 0;
}

#faq .box .faq .faq-Q {
  margin-top: 1em;
  padding: 1em;
  background-color: #fff;
  border-left: 5px solid #d9000d;
}

#faq .box .faq .faq-Q {
  border-left-color: #cc3333 !important;
}

#faq .box .faq .faq-Q:before {
  content: "Q.";
  padding-right: 1em;
}

#faq .box .faq .faq-A:before {
  content: "A.";
  padding-right: 1em;
}

#faq .box .faq .faq-Q:first-child {
  margin-top: 0;
}

#faq .box .faq .faq-A {
  padding: 1em;
  /* font-family: Montserrat; */
}

.error-message {
  color: #f00;
}

#contact .box,
#company .box {
  padding: 10px;
  padding-bottom: 30px;
  background: #eeeeee;
}

.contact-form {
  background: #fff;
  padding: 10px;
  padding-bottom: 20px;
}

.form-group .form-label {
  padding-bottom: 5px;
}

.contact-symbol {
  color: #cc3333;
  font-weight: bold;
  font-size: 80%;
}

.form-group .form-input textarea,
.form-group .form-input select,
.form-group .form-input input {
  width: 100%;
  padding: 7px;
  font-size: 12pt;
}

.form-group .form-input input[type="radio"],
.form-group .form-input input[type="checkbox"] {
  width: auto;
}

.submit input[type="submit"] {
  padding-left: 20px;
  padding-right: 20px;
}

.contact-smallText {
  font-size: 90%;
  display: block;
  padding-top: 3px;
}

.form-group .form-input input.zipcode {
  width: 100px;
}

.form-group .form-input input.haveafter {
  width: 65%;
}

#company .box dl {
  list-style: none;
  overflow: hidden;
  background-color: #fff;
  border-bottom: 1px #ccc dotted;
  padding: 10px;
  display: block;
  margin-bottom: 0;
}

#company .box dl dt {
  width: 40%;
  float: left;
  padding-right: 10px;
}

#company .box dl dd {
  width: 60%;
  float: left;
  padding-right: 10px;
  word-wrap: break-word;
}

#company .box .info {
  background-color: #fff;
  border: 1px #ccc solid;
  padding: 10px;
  overflow: hidden;
  margin-top: 1em;
}

#company .box .info .picture {
  margin-bottom: 10px;
}

#company .box .info .text .name {
  font-size: 120%;
  font-weight: bold;
  margin-bottom: 0.5em;
}

#sitemap .box,
#policy .box {
  padding: 10px;
  background: #eeeeee;
}

#policy .box h2 {
  font-size: 130%;
  font-weight: bold;
  margin-bottom: 0.5em;
}

#policy .box h3 {
  font-size: 110%;
  font-weight: bold;
  margin-bottom: 0.3em;
}

#policy .box p {
  margin-bottom: 2em;
  padding-left: 1.5em;
}

#policy .box .date {
  text-align: right;
}

#sitemap .box ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

#sitemap .box li {
  background-color: #fff;
  border-bottom: 1px dotted #ccc;
  border-left: 3px solid #cc3333;
  padding: 0;
  margin: 0;
}

#sitemap .box ul li ul li ul li {
  border-left: 3px solid #999;
}

#sitemap .box li.nest {
  border: none;
}

#sitemap .box ul li ul {
  margin-left: 2em;
}

#sitemap .box li a {
  display: block;
  width: 100%;
}

#sitemap .box ul li a {
  padding: 0.5em 0 0.5em 1em;
}

#contact .box.thanks {
  margin-top: 20px;
  padding: 42px 0;
  background: #efe8d4;
  margin-bottom: 50px;
}

.details-info-block table,
.details-info-block table th,
.details-info-block table td {
  border: none;
  text-align: left;
}

.details-info-block table th.leftBlock {
  width: 35% !important;
}

.details-info-block > table .sep-line {
  height: 5px !important;
  margin-bottom: 5px !important;
}

.calam ul {
  display: block;
  overflow: hidden;
}

.calam ul li {
  width: 33%;
  float: left;
  display: inline;
}

@media screen and (max-width: 414px) {
  .sp-product a.overwhite {
    height: 90px;
  }
  .sp-product a {
    font-size: 7.5pt;
  }
  .calam ul li {
    font-size: 7.5pt;
    background-size: 7.5pt;
    padding-left: 10pt;
  }
  #details table.info_product th {
    width: 27%;
  }
}

@media screen and (max-width: 375px) {
  .sp-product a.overwhite {
    height: 82px;
  }
  .sp-product a {
    font-size: 10pt;
  }
  .calam ul li {
    font-size: 6pt;
    background-size: 6pt;
  }
  #details table.info_product th {
    width: 27%;
  }
}

@media screen and (max-width: 320px) {
  .sp-product a.overwhite {
    height: 68px;
  }
  .sp-product a {
    font-size: 5pt;
  }
  .calam ul li {
    font-size: 5pt;
    background-size: 5pt;
  }
  #details table.info_product th {
    width: 35%;
  }
}

.error {
  color: #c41922;
}

.sns-item {
  width: 32%;
  float: left;
  margin: 1%;
}

.sns-item:first-child {
  margin-left: 0;
}

.sns-item:last-child {
  margin-right: 0;
}

.galleries {
  display: flex;
  flex-wrap: wrap;
  margin-left: -5px;
  margin-right: -5px;
}

.galleries .sp-product {
  width: 100%;
  /*calc(50% - 1px);*/
}

.galleries .sp-product .gallery-thumbnail {
  display: block;
  overflow: hidden;
  text-decoration: none;
}

.galleries .sp-product .gallery-thumbnail .image {
  height: 0;
  padding-bottom: 56.25%;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  background-color: #e2e2e2;
  margin-bottom: 5px;
  border: 1px solid #ce8a8d;
  transition: all 0.3s;
}

.galleries .sp-product .gallery-thumbnail:hover .image {
  transform: scale(1.05) rotate(-1deg);
}

.galleries .sp-product a p {
  font-size: 12pt;
}

#products > .box.r-panel-banner-product {
  padding-bottom: 15px;
}

.r-panel-banner-product a.row {
  flex-wrap: wrap;
  background-color: #fff;
  text-decoration: none;
  transition: all 0.2s;
}
.r-panel-banner-product a.row:hover {
  box-shadow: 1px 1px 10px #ccc;
}
.r-panel-banner-product .row .img {
  width: 100%;
}
.r-panel-banner-product .row .img img {
  width: 100%;
}
.r-panel-banner-product .row .detail {
  width: 100%;
  padding: 0;
}

.r-panel-banner-product .row .detail .title {
  padding-left: 8px;
  margin-top: 10px;
  font-size: 30px;
  font-weight: bold;
}
.r-panel-banner-product .row .detail .title span {
  font-size: 0.5em;
  font-weight: 500;
  display: block;
  margin-bottom: 10px;
}
.r-panel-banner-product .row .detail ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
}
.r-panel-banner-product .row .detail ul li {
  width: 100%;
  padding: 5px 0;
  font-size: 16px;
}
.r-panel-banner-product .row .detail ul li.flex {
  display: flex;
}
.r-panel-banner-product .row .detail ul li.flex small {
  font-size: 0.8em;
  line-height: 1.2;
}
.r-panel-banner-product .row,
.r-panel-banner .row {
  display: flex;
  font-size: 20px;
  font-family: "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS P Gothic", sans-serif;
}

.top-product .image {
  position: relative;
  margin-bottom: 15px;
}

.top-product .image {
  position: relative;
}

.top-product .image .rpanel-label {
  position: absolute;
  font-size: 0.9em;
  text-align: right;
  right: 5px;
  top: 5px;
  padding: 5px;
}
.top-product .image .rpanel-label > span {
  background-color: #c41026;
  color: #fff;
  padding: 5px 10px;
  display: inline-block;
  margin-bottom: 5px;
}

.smartphone .hr_detail {
  margin: 30px 0;
}
