
.heading-font {
  font-family: 'Muli', 'Helvetica', 'Arial', 'sans-serif';
  font-weight: 200;
  letter-spacing: 1px;
}
.body-font {
  font-family: 'Muli', 'Helvetica', 'Arial', 'sans-serif';
}
.alt-font {
  font-family: 'Muli', 'Helvetica', 'Arial', 'sans-serif';
  text-transform: uppercase;
  letter-spacing: 2px;
}
html,
body {
  height: 100%;
  width: 100%;
}
body {
  font-family: 'Muli', 'Helvetica', 'Arial', 'sans-serif';
}
a {
  color: #aa0000;
}
a:hover,
a:focus {
  color: #337ab7;
}
hr {
  width: 80%;
  margin: 25px auto 0;
  border-width: 1px;
  border-color: rgba(34, 34, 34, 0.1);
}
hr.light {
  border-color: white;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: 'Muli', 'Helvetica', 'Arial', 'sans-serif';
  font-weight: 200;
  color: #4d4d4d;
  /*letter-spacing: 1px;*/
}
p {
  font-size: 18px;
  line-height: 1.5;
  margin-bottom: 20px;
  color: #4d4d4d;
}

h2 {
  font-size: 18px;
}

@media (min-width: 768px) {
  p {
    font-size: 22px;
  }
  h2 {
    font-size: 24px;
  }
}

@media (min-width: 992px) {
  p {
    font-size: 26px;
  }
  h2 {
    font-size: 28px;
  }
}


.navbar-default {
  background-color: white;
  border-color: rgba(34, 34, 34, 0.05);
  /*-webkit-transition: all 0.35s;
  -moz-transition: all 0.35s;
  transition: all 0.35s;*/
  font-family: 'Muli', 'Helvetica', 'Arial', 'sans-serif';
  font-weight: 300;
  letter-spacing: 1px;
}
.navbar-brand.affix-top, .navbar-brand {
  display: none;
}
.navbar-default .navbar-header .navbar-brand:hover,
.navbar-default .navbar-header .navbar-brand:focus {
  color: #337ab7;
}
.navbar-default .navbar-header .navbar-toggle {
  font-size: 12px;
  color: #4d4d4d;
  padding: 8px 10px;
}
.navbar-default .nav > li > a {
  font-family: 'Muli', 'Helvetica', 'Arial', 'sans-serif';
  text-transform: uppercase;
  letter-spacing: 2px;
  font-size: 11px;
}
.navbar-default .nav > li > a,
.navbar-default .nav > li > a:focus {
  color: #4d4d4d;
  text-align: right;
  margin-right: 20px;
}
.navbar-default .nav > li > a:hover,
.navbar-default .nav > li > a:focus:hover {
  color: #aa0000;
  cursor: pointer;
}
.navbar-default .nav > li.active > a,
.navbar-default .nav > li.active > a:focus {
  color: #337ab7 !important;
  background-color: transparent;
}
.navbar-default .nav > li.active > a:hover,
.navbar-default .nav > li.active > a:focus:hover {
  background-color: transparent;
}
@media (min-width: 768px) {
  .navbar-default {
    background-color: transparent;
    border-color: transparent;
  }
  .navbar-brand {
    font-size:30px;
    padding: 10px 15px;
  }
  .navbar-default .navbar-header .navbar-brand:hover,
  .navbar-default .navbar-header .navbar-brand:focus {
    color: black;
  }
  .navbar-default .nav > li > a,
  .navbar-default .nav > li > a:focus {
    color: #4d4d4d;
    text-align: center;
  }
  .navbar-default .nav > li > a:hover,
  .navbar-default .nav > li > a:focus:hover {
    color: #0e7198;
  }
  .navbar-default.affix {
    background-color: white;
    border-color: rgba(34, 34, 34, 0.1);
  }
  .navbar-default.affix .navbar-header .navbar-brand {
    color: #4d4d4d;
  }
  .navbar-default.affix .navbar-header .navbar-brand:hover,
  .navbar-default.affix .navbar-header .navbar-brand:focus {
    color: #aa0000;
  }
  .navbar-default.affix .nav > li > a,
  .navbar-default.affix .nav > li > a:focus {
    color: #4d4d4d;
  }
  .navbar-default.affix .nav > li > a:hover,
  .navbar-default.affix .nav > li > a:focus:hover {
    color: #aa0000;
  }
}

.vertical {
  -webkit-writing-mode: vertical-rl;
  -moz-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  width: 50%;
  margin: 0 auto;
}

header {
  /*position: relative;*/
  width: 100%;
  min-height: 380px;
  overflow-y: hidden;
}
header .header-content {
  text-align: left;
  padding: 60px 0 0px;
  /*min-height: 380px;*/
  /*position: relative;*/
}

/*header .header-content-image {
  padding: 60px 0 0px;
}*/

header .header-content .header-content-inner {
  position: relative;
  margin: 0 auto;
  /*min-height: 380px;*/
}

header .header-content .header-content-inner.vertical {
  width: 216px;
  /*min-height: 380px;*/
}


header .header-content .header-content-inner h1 {
  /*margin-top: 140px;*/
  letter-spacing: 4px;
  line-height: 1.5em;
}

header .header-content .header-content-inner .catch-logo {
  margin-bottom: 50px;
}

@media (min-width: 768px) {
  header {
    min-height: 100%;
    min-height: 380px;
  }
  header .header-content {
    text-align: left;
    padding: 0;
    height: 100vh;
    min-height: 380px;
  }
  header .header-content .header-content-inner {
    max-width: none;
    margin: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 100%;
    min-height: 380px;
  }header .header-content .header-content-inner h1 {
    margin-top: 140px;
    letter-spacing: 4px;
    line-height: 1.5em;
  }
  header .header-content .header-content-inner h1 {
    /*margin-top: 140px;*/
    letter-spacing: 4px;
    line-height: 1.5em;
  }
}
@media (min-width: 992px) {
  header .header-content .header-content-inner h1 {
    font-size: 35px;
  }
  header .header-content .header-content-inner {
    width: auto;
  }
}

section.banner {
  height:100%;
  width: 100%;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-attachment: fixed;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
}

section.banner .row {
  margin-right: 0px;
  margin-left: 0px;
}

section.banner .banner-content h1 {
  margin-top: 0;
  margin-bottom: 30px;
  font-size: 35px;
  letter-spacing: 5px;
  line-height: 1.5em;
  /*display: inline;*/
}

section.banner#repair .banner-content h1 {
  font-size: 18px;
}

#japan-made {
  background-image: url("../img/sewing.jpg");
  height: 100vh;
  min-height: 500px;
}

#repair {
  background-image: url("../img/repair.jpg");
  height: 100vh;
  min-height: 500px;
}

@media only screen and (max-width: 480px), only screen and (max-device-width: 480px) {
  #japan-made {
    background-attachment:scroll;
  }
  #repair {
    background-attachment:scroll;
  }
}

section.banner .banner-content {
  text-align: left;
  padding: 0;
  height: 100vh;
  min-height: 500px;
}
section.banner .banner-content .banner-content-inner {
  max-width: none;
  margin: 0;
  position: relative;
  top: 50%;
  transform: translateY(-50%);
}

section.banner#japan-made .banner-content-inner .vertical {
  width: 104px;
}

section.banner#repair .banner-content-inner .vertical {
  width: 135px;
  min-height: 300px;
}

section.banner .smoke {
  background-color: rgba(0, 0, 0, 0.5);
}

section.banner .smoke h1, section.banner .smoke h2 {
  color: #fff;
}

@media (min-width: 768px) and (min-height: 644px){
  section.banner#japan-made .banner-content h1 {
    font-size: 40px;
  }
  section.banner#japan-made .banner-content-inner .vertical {
    width: 120px;
  }
  section.banner#repair .banner-content h1 {
    font-size: 35px;
  }
  section.banner#repair .banner-content-inner .vertical {
    width: 250px;
  }
}
@media (min-width: 992px) and (min-height: 644px){
  section.banner#japan-made .banner-content h1 {
    font-size: 50px;
  }
  section.banner#japan-made .banner-content-inner .vertical {
    width: 150px;
  }
  section.banner#repair .banner-content h1 {
    font-size: 40px;
  }
  section.banner#repair .banner-content-inner .vertical {
    width: 300px;
  }
}

section.concept {
  padding-top: 50px;
  padding-bottom: 50px;
}

section.concept h1, section.concept h2 {
  letter-spacing: 2px;
  line-height: 1.5;
}

@media (min-width: 992px) {
  section.concept {
    padding-top: 100px;
    padding-bottom: 50px;
  }
}

@media (min-width: 768px) {
  .row.vertical-align {
      display: flex;
      align-items: center;
  }
  section.products {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}

section.products h1, section.products h2 {
  letter-spacing: 2px;
  line-height: 1.5;
}

section.products .section-heading h1 {
  font-weight: 700;
}

@media (min-width: 992px) {
  section.products h2 {
    font-size: 28px;
  }
}

.last-bit {
  min-height: 100vh;
  width: 100%;
  border-collapse: collapse;
  display: table;
}

section.contact h1, section.contact h2 {
  letter-spacing: 2px;
  line-height: 1.5;
}

section.contact .section-heading h1 {
  font-weight: 700;
}


section.contact h2 {
  font-size: 20px;
}

section.contact .contact-column hr {
  width: 30%;
  margin: 10px auto 15px;
  border-width: 1px;
  border-color: rgba(34, 34, 34, 0.1);
}

section.contact p {
  font-size: 18px;
}

section.contact .contact-icon {
  margin-top: 60px;
  margin-bottom: 40px;
}

section.contact .contact-column {
  margin-top: 30px;
  margin-bottom: 25px;
}

section.contact a {
  font-family: 'Muli', 'Helvetica', 'Arial', 'sans-serif';
  font-weight: 200;
  font-size: 20px;
  letter-spacing: 2px;
  text-transform: uppercase;
}

section.contact a:hover,
section.contact a:focus {
  text-decoration: none;
  cursor: pointer;
}

section.contact i {
  font-size: 60px;
}

section.contact .contact-column-field p,
section.contact .contact-column-fieldname p
{
  text-align: center;
}

@media (min-width: 768px) {
  section.contact .contact-column-field p
  {
    text-align: left;
  }
  section.contact .contact-column-fieldname p
  {
    text-align: right;
  }
  section.contact {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}

footer {
  background-color: #4d4d4d;
  padding: 50px 0;
  text-align: center;
  display : table-row;
  vertical-align: bottom;
}
footer p {
  font-size: 12px;
  margin: 0;
  color: white;
  margin-top: 50px;
}
footer ul {
  margin-bottom: 0;
}
footer ul li a {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.3);
}
footer ul li a:hover,
footer ul li a:focus,
footer ul li a:active,
footer ul li a.active {
  text-decoration: none;
}

.text-dark {
  color: #4d4d4d;
}
.no-gutter > [class*='col-'] {
  padding-right: 0;
  padding-left: 0;
}
.btn-outline {
  color: #aa0000;
  border-color: #aa0000;
  border: 1px solid;
}
.btn-outline:hover,
.btn-outline:focus,
.btn-outline:active,
.btn-outline.active {
  color: white;
  background-color: #aa0000;
  border-color: #aa0000;
}
.btn {
  font-family: 'Muli', 'Helvetica', 'Arial', 'sans-serif';
  text-transform: uppercase;
  letter-spacing: 2px;
  border-radius: 300px;
}
.btn-xl {
  padding: 15px 45px;
  font-size: 11px;
}

.btn-repair {
  color: white;
  font-size: 16px;
}
::-moz-selection {
  color: white;
  text-shadow: none;
  background: #4d4d4d;
}
::selection {
  color: white;
  text-shadow: none;
  background: #4d4d4d;
}
img::selection {
  color: white;
  background: transparent;
}
img::-moz-selection {
  color: white;
  background: transparent;
}
body {
  webkit-tap-highlight-color: #4d4d4d;
}

.g-recaptcha {
  margin-top: 0px;
  margin-bottom: 20px;
  display: inline-block;
  transform: scale(0.75);
  -webkit-transform:scale(0.75);
  transform-origin: 0 0;
  -webkit-transform-origin: 0 0;
}

@media (min-width: 330px) {
  .g-recaptcha {
    transform: none;
    -webkit-transform: none;
  }
}

.col-no-padding {
  padding-left: 0px;
  padding-right: 0px;
}

.clickable {
  cursor: pointer;
}

@media (min-width: 768px) {
  .modal-wide .modal-dialog {
    width: 90%;
  }
}

#swipebox-overlay {
  background: white;
}

.swipebox .img-responsive {
  margin: 0 auto;
}

#swipebox-slider {
    touch-action: pinch-zoom;
}

#swipebox-bottom-bar {
  touch-action: none;
}

#swipebox-top-bar {
  touch-action: none;
}

#swipebox-close {
  touch-action: none;
}

.swipebox > img:hover {
  border: 1px solid;
  border-color: #aa0000;
}

/*Fix for POS older iOS*/

body.modal-open {
    position: fixed;
    overflow: hidden;
    left:0;
    right:0;
}
.modal
{
    -webkit-overflow-scrolling: auto !important;
    overflow-y: auto !important;
}
