/* fonts */
@font-face {
  font-family: 'SST-Light';
  src: url("/microsite/shared/fonts/sst-light.eot") format("embedded-opentype"), url("/microsite/shared/fonts/sst-light.woff") format("woff"); }
@font-face {
  font-family: 'SST-Roman';
  src: url("/microsite/shared/fonts/sst-roman.eot") format("embedded-opentype"), url("/microsite/shared/fonts/sst-roman.woff") format("woff"); }
/* colors */
html,
body {
  background-color: #fff;
  font-family: 'SST-Light', 'SST-Roman', Arial, sans-serif;
  position: relative; }

h1,
h2 {
  font-family: 'SST-Light', 'SST-Roman', Arial, sans-serif; }

h1 {
  font-weight: normal; }

h2 {
  font-size: 2.25em; }

h3 {
  color: #2f353d; }

p {
  color: #2f353d;
  line-height: 1.5em;
  font-family: 'SST-Light', 'SST-Roman', Arial, sans-serif; }

a {
  text-decoration: none;
  color: #5865f5; }
  a:hover {
    color: #3e59f2; }

a.button {
  display: inline-block;
  padding: 1em 1.5em;
  transition: all 0.3s ease;
  margin-top: 1em;
  color: #fff; }

a.button.blue {
  background-color: #5865f5; }

a.button.blue:hover,
a.button.blue:focus {
  background-color: #3e59f2;
  transition: all 0.3s ease; }

a.button.orange {
  background-color: #dc3a1a; }

a.button.orange:hover {
  background-color: #be3216;
  transition: all 0.3s ease; }

a.button.teal {
  background-color: #5ec3eb;
  color: #0d101e;
  text-transform: uppercase;
  font-size: 12px;
  line-height: 1.5;
  width: 250px;
  padding: 14px;
  font-family: 'SST-Roman', Arial, sans-serif;
  font-weight: bold; }

a.button.teal:hover,
a.button.teal:focus {
  background-color: #fff;
  transition: all 0.3s ease; }

.sr-only {
  position: absolute;
  left: -10000px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden; }

header {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 5; }
  header .brand {
    padding: 12px 0;
    text-align: center;
    margin-right: 0; }
    header .brand a {
      display: inline-block; }
    header .brand img {
      max-width: 80px; }
  @media (min-width: 768px) {
    header .brand {
      text-align: left; }
      header .brand img {
        max-width: 80px; } }

.col-wrapper {
  position: relative;
  overflow: hidden; }
  @media (min-width: 768px) {
    .col-wrapper .col {
      float: left; }
    .col-wrapper .col2 {
      width: 50%;
      padding: 1em; }
    .col-wrapper .col3 {
      width: 33.33%; }
    .col-wrapper .col4 {
      width: 25%;
      padding: 1em; } }

.overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.7);
  opacity: 0; }
  @media (min-width: 768px) {
    .overlay {
      opacity: 1; } }

#banner {
  position: relative;
  height: auto;
  background-color: #000;
  min-height: 300px; }
  #banner .banner-img {
    position: relative;
    width: 100%;
    height: 300px;
    top: 0;
    left: 0;
    display: none; }
    #banner .banner-img#banner-parramatta {
      background: url("../img/sony-store-parramatta.jpg") center center no-repeat;
      background-size: cover;
      display: block; }
    #banner .banner-img#banner-chatswood {
      background: url("../img/sony-store-chatswood.jpg") center center no-repeat;
      background-size: cover; }
    #banner .banner-img#banner-castlehill {
      background: url("../img/sony-store-castlehill.jpg") center center no-repeat;
      background-size: cover; }
  #banner .caption {
    position: relative;
    display: block;
    text-align: center;
    background-color: #000; }
    #banner .caption .caption-inner {
      margin: 1em auto 0 auto; }
    #banner .caption h1 {
      color: #fff;
      line-height: 0.6em;
      display: inline-block;
      text-align: right; }
      #banner .caption h1 .sub {
        font-size: 0.35em;
        text-transform: uppercase; }
    #banner .caption p {
      color: #fff; }
  #banner .button-row {
    display: block;
    position: relative;
    bottom: 1em;
    width: 100%;
    text-align: center;
    padding-top: 1.5em;
    background-color: #000; }
    @media (min-width: 768px) {
      #banner .button-row {
        background-color: transparent; } }
  #banner .icon-button {
    display: inline-block;
    margin: 0 auto;
    text-align: center;
    color: white; }
    #banner .icon-button .icon {
      -webkit-animation: move 0.5s infinite alternate;
      animation: move 0.5s infinite alternate; }
  #banner .icon {
    width: 24px;
    margin: 5px auto 0 auto; }
@-webkit-keyframes move {
  from {
    transform: translateY(0); }
  to {
    transform: translateY(-3px); } }
@keyframes move {
  from {
    transform: translateY(0); }
  to {
    transform: translateY(-3px); } }
  @media (min-width: 768px) {
    #banner {
      height: 100vh; }
      #banner .banner-img {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        min-height: 400px; }
      #banner .caption {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        min-height: 400px;
        display: flex;
        align-items: center;
        background-color: rgba(0, 0, 0, 0.7); }
        #banner .caption h1 {
          font-size: 3.125rem; }
      #banner .caption-inner {
        max-width: 50%;
        margin: 0 auto; }
      #banner .button-row {
        display: block;
        position: absolute;
        bottom: 1em;
        width: 100%;
        text-align: center; }
      #banner .icon-button {
        display: inline-block;
        margin: 0 auto;
        text-align: center;
        color: white; } }

section {
  padding: 3em 0;
  text-align: center; }

#locations {
  padding: 3em 0 10px 0; }
  #locations .modal-wrapper > .col-wrapper {
    overflow: hidden; }
  #locations .g-col3 {
    background-color: #F1F5f9;
    min-height: 350px;
    position: relative;
    margin-bottom: 1em; }
    #locations .g-col3#chatswood {
      background: url("../img/sony-store-chatswood.jpg") center center no-repeat;
      background-size: cover; }
    #locations .g-col3#parramatta {
      background: url("../img/sony-store-parramatta_b.jpg") center center no-repeat;
      background-size: cover; }
    #locations .g-col3#castlehill {
      background: url("../img/sony-store-castlehill.jpg") center center no-repeat;
      background-size: cover; }
    #locations .g-col3 a.over {
      display: flex;
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      align-items: center;
      background-color: rgba(0, 0, 0, 0.6); }
    #locations .g-col3 span {
      display: block;
      text-align: center;
      width: 100%;
      color: #fff;
      font-size: 1.5em; }
  #locations .store-label {
    text-align: left;
    position: absolute;
    bottom: 2em;
    left: 0;
    z-index: 10; }
    #locations .store-label span {
      display: inline-block;
      width: auto; }
    #locations .store-label .store {
      color: #fff;
      background-color: #000;
      padding: 0.5em 1.5em;
      font-size: 1em; }
    #locations .store-label .location {
      color: #000;
      background-color: #fff;
      padding: 0.5em 1.5em;
      font-size: 1.5em;
      text-transform: uppercase; }
  @media (min-width: 768px) {
    #locations .modal-wrapper > .store-tiles {
      display: flex;
      flex-direction: row;
      align-items: stretch;
      justify-content: space-between;
      min-height: 500px; }
    #locations .g-col3 {
      margin-bottom: 0;
      width: 33%;
      min-height: 500px; }
      #locations .g-col3 a.over {
        display: flex;
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        align-items: center;
        background-color: transparent;
        opacity: 0;
        transition: opacity 0.3s ease; }
        #locations .g-col3 a.over:hover {
          opacity: 1;
          background-color: rgba(0, 0, 0, 0.7);
          transition: opacity 0.3s ease; }
        #locations .g-col3 a.over:focus {
          opacity: 1;
          background-color: rgba(0, 0, 0, 0.7);
          transition: opacity 0.3s ease; }
      #locations .g-col3 .store-label:hover + a.over {
        opacity: 1;
        background-color: rgba(0, 0, 0, 0.7);
        transition: opacity 0.3s ease; } }

.modal-wrapper {
  position: relative;
  overflow: hidden;
  min-height: 500px; }
  @media (min-width: 768px) {
    .modal-wrapper .store-tiles {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      z-index: 10; } }

.store-detail {
  width: 100%;
  height: 100%;
  display: none;
  z-index: 10;
  background-color: #1f2024;
  position: fixed;
  top: 0;
  left: 0;
  overflow: auto; }
  .store-detail button.close {
    background-color: #dc3a1a;
    color: #fff;
    border: none;
    width: 48px;
    height: 48px;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 12; }
  .store-detail .col-wrapper {
    background-color: #1f2024;
    min-height: 600px; }
  .store-detail .info {
    background-color: #1f2024;
    color: #fff;
    padding: 0;
    position: relative;
    z-index: 10;
    margin-bottom: 1em; }
    .store-detail .info .container {
      padding: 1em; }
    .store-detail .info h1 {
      margin-top: 1em; }
    .store-detail .info table.detail-table {
      margin: 0 auto; }
      .store-detail .info table.detail-table td {
        padding: 1em;
        vertical-align: top;
        text-align: left; }
    .store-detail .info table.hours-table td {
      padding: 0.5em; }
    .store-detail .info a {
      display: block;
      margin-top: 0.5em; }
    .store-detail .info .view-hours {
      color: #22c083;
      padding: 1em 0.5em;
      display: inline-block; }
      .store-detail .info .view-hours svg {
        vertical-align: middle;
        transition: transform 0.3s ease; }
      .store-detail .info .view-hours.open svg {
        transform: rotate(-180deg);
        transition: transform 0.3s ease; }
    .store-detail .info .xmas-hours {
      display: none; }
      .store-detail .info .xmas-hours tr {
        border-bottom: solid 1px #ccc; }
  .store-detail .map-container {
    padding: 0;
    min-height: 50vh;
    position: relative; }
    .store-detail .map-container iframe {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%; }
  @media (min-width: 768px) {
    .store-detail {
      position: relative;
      overflow: hidden; }
      .store-detail .col-wrapper {
        display: flex;
        align-items: stretch;
        flex-direction: row-reverse; }
      .store-detail .map-container {
        min-height: 300px; }
      .store-detail .info .container {
        padding: 2em; }
      .store-detail .info h1 {
        margin-top: 0; } }
  @media (min-width: 998px) {
    .store-detail .info .container {
      padding: 5em; } }

#signup {
  background-color: #1f2024; }
  #signup h2 {
    color: #fff;
    text-transform: uppercase;
    font-size: 1.5em;
    font-weight: bold; }
  #signup p {
    color: #fff; }

#benefits .benefit {
  margin: 2em 0; }
#benefits .icon svg {
  width: 5em;
  height: 5em;
  stroke-width: 0.5px;
  margin: 0 auto;
  stroke: #2f353d; }
#benefits h3 {
  color: #2f353d;
  margin-top: 1em;
  margin-bottom: 0; }
#benefits p {
  color: #2f353d;
  margin-top: 0.5em; }
#benefits #icon-zippay {
  width: 3em;
  margin: 0 auto; }
  #benefits #icon-zippay svg {
    width: 100%;
    height: auto; }

footer {
  padding-top: 2em !important; }
  footer h1 {
    color: #878792;
    font-family: 'SST-Roman', Arial, sans-serif; }
  footer #copyright-links {
    border-top: solid 1px #3c3c42; }
    footer #copyright-links p {
      color: #878792; }

.no-js .store-tiles {
  position: relative;
  margin-bottom: 3em; }
.no-js .store-detail {
  display: block;
  margin-bottom: 3em; }
  .no-js .store-detail .xmas-hours {
    display: block; }

/*# sourceMappingURL=main.css.map */
