﻿header {
  position: relative;
  z-index: 15;
  padding: 0.67rem 1.5rem;
  background-color: #121212;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
header .logo {
  position: relative;
  z-index: 30;
  display: block;
  width: 2.33rem;
  height: 2.49rem;
}
header .logo svg {
  display: block;
  fill: #fff;
  width: 100%;
  height: 100%;
}
@media (min-width: 950px) {
  header {
    padding-top: 0.95rem;
    padding-bottom: 0.95rem;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }
}
@media (min-width: 950px) and (min-width: 900px) {
  header {
    padding-left: 3rem;
    padding-right: 3rem;
  }
}
@media (min-width: 950px) {
  header .logo {
    width: 3.0989rem;
    height: 3.3117rem;
  }
}
.overscroll-mask {
  position: absolute;
  z-index: 15;
  bottom: calc(100% - 1px);
  left: 0;
  right: 0;
  width: 100%;
  height: 15rem;
  background-color: #000;
}
header .mobile-icons {
  position: absolute;
  top: 50%;
  right: 1.5rem;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
header .mobile-icons a {
  float: left;
}
header .mobile-icons .search-toggle {
  display: block;
  width: 1.4rem;
  height: 1.28rem;
  margin-right: 1.5rem;
}
header .mobile-icons .search-toggle svg {
  display: block;
  fill: #fff;
  width: 100%;
  height: 100%;
  transition: fill 125ms ease-out;
}
header .mobile-icons .search-toggle:hover svg {
  fill: #cf0;
}
header .mobile-icons .menu-toggle {
  display: block;
  width: 23px;
  height: 15.341px;
  position: relative;
}
header .mobile-icons .menu-toggle .bar {
  width: 100%;
  height: 2px;
  background-color: #fff;
  display: block;
  position: absolute;
  right: 0;
  top: 50%;
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
  -webkit-animation-duration: 250ms;
  animation-duration: 250ms;
  transition: background-color 125ms ease-out;
}
header .mobile-icons .menu-toggle .bar-1 {
  width: 86%;
  -webkit-transform: translateY(-7px);
  transform: translateY(-7px);
}
header .mobile-icons .menu-toggle .bar-3 {
  width: 75%;
  -webkit-transform: translateY(7px);
  transform: translateY(7px);
}
header .mobile-icons .menu-toggle.expanded .bar-1 {
  -webkit-animation-name: menuToggleClose1;
  animation-name: menuToggleClose1;
}
header .mobile-icons .menu-toggle.expanded .bar-2 {
  -webkit-animation-name: menuToggleClose2;
  animation-name: menuToggleClose2;
}
header .mobile-icons .menu-toggle.expanded .bar-3 {
  -webkit-animation-name: menuToggleClose3;
  animation-name: menuToggleClose3;
}
header .mobile-icons .menu-toggle.animated:not(.expanded) .bar-1 {
  -webkit-animation-name: menuToggleOpen1;
  animation-name: menuToggleOpen1;
}
header .mobile-icons .menu-toggle.animated:not(.expanded) .bar-2 {
  -webkit-animation-name: menuToggleOpen2;
  animation-name: menuToggleOpen2;
}
header .mobile-icons .menu-toggle.animated:not(.expanded) .bar-3 {
  -webkit-animation-name: menuToggleOpen3;
  animation-name: menuToggleOpen3;
}
header .mobile-icons .menu-toggle:hover .bar {
  background-color: #cf0;
}
@media (min-width: 950px) {
  header .mobile-icons {
    display: none;
  }
}
.navigation-mobile {
  position: absolute;
  z-index: 20;
  top: 100%;
  left: 0;
  width: 100%;
  background-color: #1a1a1a;
  overflow: hidden;
  max-height: 0;
  transition: max-height 250ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.navigation-mobile svg {
  display: block;
  position: absolute;
  top: 50%;
  right: 1.5rem;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  fill: #fff;
  width: 1rem;
  height: 1rem;
  transition: all 250ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.navigation-mobile > li {
  border-bottom: solid 1px #000;
}
.navigation-mobile > li a {
  position: relative;
  display: block;
  background-color: #1a1a1a;
  color: #fff;
  font-style: italic;
  font-weight: bold;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  text-decoration: none;
  font-size: 90%;
  padding: 2rem 1.5rem;
  opacity: 0;
  -webkit-transform: scaleX(1.1);
  transform: scaleX(1.1);
  transition: all 250ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transition-delay: 125ms;
}
.navigation-mobile > li a:hover {
  background-color: #272727;
}
.navigation-mobile > li a.expanded {
  transition-delay: 0;
  background-color: #dedede;
  color: #000;
}
.navigation-mobile > li a.expanded svg {
  fill: #000;
  -webkit-transform: translateY(-50%) rotateX(180deg);
  transform: translateY(-50%) rotateX(180deg);
}
.navigation-mobile > li:last-child {
  border-bottom: none;
}
.navigation-mobile > li > ul {
  max-height: 0;
  overflow: hidden;
  transition: max-height 250ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
  background-color: #313131;
}
.navigation-mobile > li > ul > li {
  border-bottom: solid 1px #4e4e4e;
}
.navigation-mobile > li > ul > li > a {
  background-color: #313131;
  font-weight: normal;
  font-style: italic;
  letter-spacing: 0.1em;
  padding-top: 1.5rem;
  padding-bottom: 1.5rem;
}
.navigation-mobile > li > ul > li > a:hover {
  background-color: #3e3e3e;
}
.navigation-mobile > li > ul > li > a.expanded:hover {
  background-color: #dedede;
}
.navigation-mobile > li > ul > li:first-child > a {
  border-top: solid 1px #313131;
}
.navigation-mobile > li > ul > li:first-child > a.expanded {
  border-top-color: #fff;
}
.navigation-mobile > li > ul > li:last-child {
  border-bottom: none;
}
.navigation-mobile > li > ul > li > ul {
  max-height: 0;
  overflow: hidden;
  transition: max-height 250ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
  background-color: #fff;
}
.navigation-mobile > li > ul > li > ul > li {
  border-bottom: none;
}
.navigation-mobile > li > ul > li > ul > li > a {
  background-color: #fff;
  color: #000;
  font-weight: normal;
  font-style: italic;
  letter-spacing: 0.1em;
  text-transform: none;
  padding: 1.33rem 2.5rem;
}
.navigation-mobile > li > ul > li > ul > li > a::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 1.5rem;
  right: 1.5rem;
  height: 1px;
  background-color: #dedede;
}
@media (min-width: 900px) {
  .navigation-mobile > li > ul > li > ul > li > a::after {
    left: 3rem;
  }
}
@media (min-width: 900px) {
  .navigation-mobile > li > ul > li > ul > li > a::after {
    right: 3rem;
  }
}
.navigation-mobile > li > ul > li > ul > li > a:hover {
  background-color: #fff;
  padding-left: 3rem;
}
.navigation-mobile > li > ul > li > ul > li:first-child {
  padding-top: 0.5rem;
}
.navigation-mobile > li > ul > li > ul > li:last-child {
  border-bottom: none;
  padding-bottom: 0.5rem;
}
.navigation-mobile > li > ul > li > ul > li:last-child > a {
  border-bottom: none;
}
.navigation-mobile > li > ul > li > ul > li:last-child > a::after {
  display: none;
}
.navigation-mobile > li > ul > li > ul.opening {
  max-height: 19.98rem;
}
.navigation-mobile > li > ul > li > ul.opening > li > a {
  opacity: 1;
  -webkit-transform: none;
  transform: none;
}
.navigation-mobile > li > ul > li > ul.opening > li:nth-child(1) > a {
  transition-delay: 0ms;
}
.navigation-mobile > li > ul > li > ul.opening > li:nth-child(2) > a {
  transition-delay: 41.6666666667ms;
}
.navigation-mobile > li > ul > li > ul.opening > li:nth-child(3) > a {
  transition-delay: 83.3333333333ms;
}
.navigation-mobile > li > ul > li > ul.opening > li:nth-child(4) > a {
  transition-delay: 125ms;
}
.navigation-mobile > li > ul > li > ul.opening > li:nth-child(5) > a {
  transition-delay: 166.666666667ms;
}
.navigation-mobile > li > ul > li > ul.opening > li:nth-child(6) > a {
  transition-delay: 208.333333333ms;
}
.navigation-mobile > li > ul > li > ul.open {
  transition: none;
  max-height: none;
}
.navigation-mobile > li > ul > li > ul.open > li:nth-child(1n + 1) > a {
  transition-delay: 0s;
}
.navigation-mobile > li > ul > li > ul.closing {
  transition-delay: 125ms;
}
.navigation-mobile > li > ul > li > ul.closing > li:nth-child(6) > a {
  transition-delay: 0ms;
}
.navigation-mobile > li > ul > li > ul.closing > li:nth-child(5) > a {
  transition-delay: 41.6666666667ms;
}
.navigation-mobile > li > ul > li > ul.closing > li:nth-child(4) > a {
  transition-delay: 83.3333333333ms;
}
.navigation-mobile > li > ul > li > ul.closing > li:nth-child(3) > a {
  transition-delay: 125ms;
}
.navigation-mobile > li > ul > li > ul.closing > li:nth-child(2) > a {
  transition-delay: 166.666666667ms;
}
.navigation-mobile > li > ul > li > ul.closing > li:nth-child(1) > a {
  transition-delay: 208.333333333ms;
}
.navigation-mobile > li > ul.opening {
  max-height: 25rem;
}
.navigation-mobile > li > ul.opening > li > a {
  opacity: 1;
  -webkit-transform: none;
  transform: none;
}
.navigation-mobile > li > ul.opening > li:nth-child(1) > a {
  transition-delay: 0ms;
}
.navigation-mobile > li > ul.opening > li:nth-child(2) > a {
  transition-delay: 50ms;
}
.navigation-mobile > li > ul.opening > li:nth-child(3) > a {
  transition-delay: 100ms;
}
.navigation-mobile > li > ul.opening > li:nth-child(4) > a {
  transition-delay: 150ms;
}
.navigation-mobile > li > ul.opening > li:nth-child(5) > a {
  transition-delay: 200ms;
}
.navigation-mobile > li > ul.open {
  transition: none;
  max-height: none;
}
.navigation-mobile > li > ul.open > li:nth-child(1n + 1) > a {
  transition-delay: 0s;
}
.navigation-mobile > li > ul.closing {
  transition-delay: 125ms;
}
.navigation-mobile > li > ul.closing > li:nth-child(5) > a {
  transition-delay: 0ms;
}
.navigation-mobile > li > ul.closing > li:nth-child(4) > a {
  transition-delay: 50ms;
}
.navigation-mobile > li > ul.closing > li:nth-child(3) > a {
  transition-delay: 100ms;
}
.navigation-mobile > li > ul.closing > li:nth-child(2) > a {
  transition-delay: 150ms;
}
.navigation-mobile > li > ul.closing > li:nth-child(1) > a {
  transition-delay: 200ms;
}
.navigation-mobile > li.language a {
  background-color: #000;
}
.navigation-mobile > li.language a:hover {
  background-color: #1a1a1a;
}
.navigation-mobile > li.language a.expanded {
  background-color: #dedede;
}
.navigation-mobile > li.language > ul > li > a {
  background-color: #313131;
}
.navigation-mobile > li.language > ul > li > a:hover {
  background-color: #3e3e3e;
}
.navigation-mobile.opening {
  max-height: 36em;
}
.navigation-mobile.opening > li > a {
  opacity: 1;
  -webkit-transform: none;
  transform: none;
}
.navigation-mobile.opening > li:nth-child(1) > a {
  transition-delay: 0ms;
}
.navigation-mobile.opening > li:nth-child(2) > a {
  transition-delay: 41.6666666667ms;
}
.navigation-mobile.opening > li:nth-child(3) > a {
  transition-delay: 83.3333333333ms;
}
.navigation-mobile.opening > li:nth-child(4) > a {
  transition-delay: 125ms;
}
.navigation-mobile.opening > li:nth-child(5) > a {
  transition-delay: 166.666666667ms;
}
.navigation-mobile.opening > li:nth-child(6) > a {
  transition-delay: 208.333333333ms;
}
.navigation-mobile.open {
  transition: none;
  max-height: none;
}
.navigation-mobile.open > li:nth-child(1n + 1) > a {
  transition-delay: 0s;
  transition-duration: 125ms;
  transition-timing-function: ease-out;
}
.navigation-mobile.closing {
  transition-delay: 125ms;
}
.navigation-mobile.closing > li:nth-child(6) > a {
  transition-delay: 0ms;
}
.navigation-mobile.closing > li:nth-child(5) > a {
  transition-delay: 41.6666666667ms;
}
.navigation-mobile.closing > li:nth-child(4) > a {
  transition-delay: 83.3333333333ms;
}
.navigation-mobile.closing > li:nth-child(3) > a {
  transition-delay: 125ms;
}
.navigation-mobile.closing > li:nth-child(2) > a {
  transition-delay: 166.666666667ms;
}
.navigation-mobile.closing > li:nth-child(1) > a {
  transition-delay: 208.333333333ms;
}
header .wide {
  display: none;
  font-size: 80%;
  position: absolute;
  top: 50%;
  line-height: 3em;
  margin-top: -0.05em;
}
header .wide a {
  color: #fff;
  font-style: italic;
  font-weight: bold;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  text-decoration: none;
}
header .wide a span {
  position: relative;
}
header .wide a span::after {
  content: "";
  position: absolute;
  bottom: -0.66em;
  left: 0;
  height: 2.5px;
  right: 100%;
  background-color: #fff;
  transition: right 125ms ease-out;
}
header .wide a:hover span::after {
  right: 0;
}
header .main-nav {
  z-index: 1;
  width: 100%;
  left: 9rem;
  text-align: left;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
header .main-nav a {
  margin-right: 2.5em;
}
header .main-nav a:last-child {
  margin-right: 0;
}
header .main-nav svg {
  width: 0.9em;
  height: 0.7em;
  fill: #fff;
  opacity: 0.75;
  display: inline-block;
  vertical-align: baseline;
  margin-left: 0.75em;
  transition: all 250ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
header .main-nav a.open svg {
  fill: #cf0;
  opacity: 1;
  -webkit-transform: rotateX(180deg);
  transform: rotateX(180deg);
}
header .rhs-links {
  z-index: 2;
  right: 1.5rem;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  white-space: nowrap;
}
@media (min-width: 900px) {
  header .rhs-links {
    right: 3rem;
  }
}
header .rhs-links svg {
  display: inline-block;
}
header .rhs-links .search-toggle svg {
  vertical-align: middle;
  width: 1.33em;
  height: 1.33em;
  fill: #fff;
  margin-left: 1.5em;
}
header .rhs-links .language-toggle {
  margin-left: 3.5em;
  position: relative;
}
header .rhs-links .language-toggle::before {
  position: absolute;
  content: "";
  left: -1.75em;
  top: 50%;
  width: 1px;
  height: 3em;
  background-color: #dedede;
  opacity: 0.5;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
header .rhs-links .language-toggle svg {
  vertical-align: baseline;
  width: 0.9em;
  height: 0.7em;
  fill: #fff;
  opacity: 0.75;
  margin-left: 0.75em;
}
header .dropdown {
  position: absolute;
  z-index: 20;
  top: 100%;
  left: 0;
  width: 100%;
  height: 435px;
  max-height: 0;
  overflow: hidden;
  background-color: #000;
  transition: max-height 250ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
header .dropdown .inner {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  -webkit-transform: translateY(-50%) scaleX(1.1);
  transform: translateY(-50%) scaleX(1.1);
  opacity: 0;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
  text-align: center;
  transition-property: all;
  transition-duration: 83.3333333333ms;
  transition-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
@media (min-width: 900px) {
  header .dropdown .inner {
    padding-left: 3rem;
    padding-right: 3rem;
  }
}
header .dropdown.open {
  max-height: 435px;
}
header .dropdown.open .inner {
  -webkit-transform: translateY(-50%) scaleX(1);
  transform: translateY(-50%) scaleX(1);
  opacity: 1;
  transition-duration: 250ms;
  transition-delay: 125ms;
}
header .dropdown.sports,
header .dropdown.team {
  font-size: 100%;
}
header .dropdown.sports .blocks,
header .dropdown.team .blocks {
  display: inline-block;
}
header .dropdown.sports .blocks::after,
header .dropdown.team .blocks::after {
  content: "";
  display: table;
  clear: both;
}
header .dropdown.sports a,
header .dropdown.team a {
  display: block;
  float: left;
  position: relative;
  width: 14rem;
  height: 14rem;
  text-decoration: none;
  font-style: italic;
  font-weight: bold;
  letter-spacing: 0.25em;
  color: #fff;
  text-transform: uppercase;
  background-size: 200% 200%, cover;
  background-position: 100% 100%, 50% 50%;
  background-repeat: no-repeat;
  margin-left: 3px;
  transition: color 125ms ease-out, background-position 125ms ease-out;
}
header .dropdown.sports a span,
header .dropdown.team a span {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  color: inherit;
}
header .dropdown.sports a:first-child,
header .dropdown.team a:first-child {
  margin-left: 0;
}
header .dropdown.sports a:hover,
header .dropdown.team a:hover {
  color: #000;
  background-position: 0% 0%, 50% 50%;
}
header .dropdown.sports {
  font-size: 120%;
}
header .dropdown.sports a.tennis {
  background-image: linear-gradient(-30deg, transparent 50%, #cf0 50%),
    url("../img/nav-square-tennis.jpg");
}
header .dropdown.sports a.squash {
  background-image: linear-gradient(-30deg, transparent 50%, #cf0 50%),
    url("../img/nav-square-squash.jpg");
}
header .dropdown.sports a.padel {
  background-image: linear-gradient(-30deg, transparent 50%, #cf0 50%),
    url("../img/nav-square-padel.jpg");
}
header .dropdown.sports a.badminton {
  background-image: linear-gradient(-30deg, transparent 50%, #cf0 50%),
    url("../img/nav-square-badminton.jpg");
}
header .dropdown.team a {
  color: #cf0;
}
header .dropdown.team a::before,
header .dropdown.team a::after {
  position: absolute;
  content: "";
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  width: 9rem;
  height: 3.2412587413rem;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  transition: opacity 125ms ease-out;
}
header .dropdown.team a::before {
  background-image: url("../img/team-dunlop-logo.svg");
}
header .dropdown.team a::after {
  background-image: url("../img/team-dunlop-logo-black.svg");
  opacity: 0;
}
header .dropdown.team a:hover::before {
  opacity: 0;
}
header .dropdown.team a:hover::after {
  opacity: 1;
}
header .dropdown.team a span {
  top: 75%;
}
header .dropdown.team a.tennis {
  background-image: linear-gradient(-30deg, transparent 50%, #cf0 50%),
    url("../img/nav-square-alt-tennis.jpg");
}
header .dropdown.team a.squash {
  background-image: linear-gradient(-30deg, transparent 50%, #cf0 50%),
    url("../img/nav-square-alt-squash.jpg");
}
header .dropdown.team a.padel {
  background-image: linear-gradient(-30deg, transparent 50%, #cf0 50%),
    url("../img/nav-square-alt-padel.jpg");
}
header .dropdown.team a.badminton {
  background-image: linear-gradient(-30deg, transparent 50%, #cf0 50%),
    url("../img/nav-square-alt-badminton.jpg");
}
header .dropdown .list {
  display: inline-block;
  vertical-align: top;
  text-align: left;
  margin-left: 8.5em;
}
header .dropdown .list:first-child {
  margin-left: 0;
}
header .dropdown .list h4 {
  position: relative;
  font-style: italic;
  font-weight: bold;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: #fff;
  padding-bottom: 1.75em;
  margin-bottom: 2.25em;
  font-size: 100%;
}
header .dropdown .list h4::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 2.5em;
  height: 4px;
  background-color: #fff;
}
header .dropdown .list a {
  display: block;
  color: #fff;
  text-decoration: none;
  font-style: italic;
  letter-spacing: 0.1em;
  margin-top: 1.5em;
  font-size: 90%;
  transition: color 125ms ease-out;
}
header .dropdown .list a:hover {
  color: #cf0;
}
@media (min-width: 950px) {
  header .wide {
    display: block;
  }
}
@media (min-width: 1150px) {
  header .main-nav {
    left: 50%;
    text-align: center;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
  }
}
@media (min-width: 1250px) {
  header .main-nav a {
    margin-right: 4.33em;
  }
}
