html {
  scroll-behavior: smooth;
}

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

body {
  line-height: 1;
}

ol,
ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

body {
  -webkit-text-size-adjust: none;
}

/* Basic */

@-ms-viewport {
  width: device-width;
}

body {
  -ms-overflow-style: scrollbar;
}

@media screen and (max-width: 480px) {
  html,
  body {
    min-width: 320px;
  }
}

html {
  box-sizing: border-box;
}

*,
*:before,
*:after {
  box-sizing: inherit;
}

body {
  background: #ffffff;
}

/* Type */

body {
  background-color: #ffffff;
  color: #565656;
}

body,
input,
select,
textarea {
  font-family: Raleway, Helvetica, sans-serif;
  font-size: 14pt;
  font-weight: 300;
  line-height: 1.75;
  letter-spacing: 0.025em;
}

@media screen and (max-width: 1680px) {
  body,
  input,
  select,
  textarea {
    font-size: 12pt;
  }
}

@media screen and (max-width: 1280px) {
  body,
  input,
  select,
  textarea {
    font-size: 11pt;
  }
}

@media screen and (max-width: 980px) {
  body,
  input,
  select,
  textarea {
    font-size: 12pt;
  }
}

@media screen and (max-width: 736px) {
  body,
  input,
  select,
  textarea {
    font-size: 11pt;
  }
}

@media screen and (max-width: 480px) {
  body,
  input,
  select,
  textarea {
    font-size: 11pt;
  }
}

@media screen and (max-width: 360px) {
  body,
  input,
  select,
  textarea {
    font-size: 10.5pt;
  }
}

input,
select,
textarea {
  color: inherit;
}

a {
  -moz-transition: border-bottom-color 0.2s ease;
  -webkit-transition: border-bottom-color 0.2s ease;
  -ms-transition: border-bottom-color 0.2s ease;
  transition: border-bottom-color 0.2s ease;
  color: inherit;
  text-decoration: none;
  border-bottom: dotted 1px;
}

a:hover {
  border-bottom-color: transparent;
}

strong,
b {
  color: inherit;
  font-weight: 500;
}

em,
i {
  font-style: italic;
}

p {
  margin: 0 0 2em 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  color: inherit;
  font-weight: 300;
  line-height: 1.5;
  margin: 0 0 1.75rem 0;
  letter-spacing: 0.05em;
}

h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a {
  color: inherit;
  text-decoration: none;
}

@media screen and (max-width: 1280px) {
  h1,
  h2,
  h3,
  h4,
  h5,
  h6 {
    margin: 0 0 1.5rem 0;
  }
}

@media screen and (max-width: 736px) {
  h1,
  h2,
  h3,
  h4,
  h5,
  h6 {
    margin: 0 0 1.25rem 0;
  }
}

h1 {
  font-size: 3.25em;
  line-height: 1.1;
  margin: 0 0 1.5rem 0;
  letter-spacing: 0.025em;
}

@media screen and (max-width: 736px) {
  h1 {
    font-size: 2em;
    line-height: 1.3;
    margin: 0 0 1rem 0;
  }
}

h2 {
  font-size: 2.5em;
  line-height: 1.3;
}

@media screen and (max-width: 1280px) {
  h2 {
    font-size: 2.25em;
  }
}

@media screen and (max-width: 736px) {
  h2 {
    font-size: 1.5em;
    line-height: 1.5;
  }
}

h3 {
  font-size: 1.75em;
}

@media screen and (max-width: 736px) {
  h3 {
    font-size: 1.25em;
  }
}

h4 {
  font-size: 1.1em;
}

@media screen and (max-width: 736px) {
  h4 {
    font-size: 1em;
  }
}

h5 {
  font-size: 0.9em;
}

h6 {
  font-size: 0.7em;
}

sub {
  font-size: 0.8em;
  position: relative;
  top: 0.5em;
}

sup {
  font-size: 0.8em;
  position: relative;
  top: -0.5em;
}

blockquote {
  border-left: solid 4px;
  font-style: italic;
  margin: 0 0 2em 0;
  padding: 0.5em 0 0.5em 2em;
}

code {
  border-radius: 0.5rem;
  font-family: "Courier New", monospace;
  font-size: 0.9em;
  margin: 0 0.25em;
  padding: 0.25em 0.65em;
}

pre {
  -webkit-overflow-scrolling: touch;
  font-family: "Courier New", monospace;
  font-size: 0.9em;
  margin: 0 0 2em 0;
}

pre code {
  display: block;
  padding: 1em 1.5em;
  overflow-x: auto;
}

hr {
  border: 0;
  border-bottom: solid 1px;
  margin: 3em 0;
}

hr.major {
  margin: 5em 0;
}

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

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

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

blockquote {
  border-left-color: rgba(86, 86, 86, 0.25);
}

hr {
  border-bottom-color: rgba(86, 86, 86, 0.25);
}

code {
  background: rgba(86, 86, 86, 0.075);
}

/* Image */

.image {
  border-radius: 0.5rem;
  border: 0;
  display: inline-block;
  position: relative;
}

.image img {
  border-radius: 0.5rem;
  display: block;
}

.image.left,
.image.right {
  max-width: 40%;
}

.image.left img,
.image.right img {
  width: 100%;
}

.image.left {
  float: left;
  margin: 0 1.5em 1em 0;
  top: 0.25em;
}

.image.right {
  float: right;
  margin: 0 0 1em 1.5em;
  top: 0.25em;
}

.image.main {
  display: block;
  margin: 0 0 3em 0;
  width: 100%;
}

.image.main img {
  width: 100%;
}

/* List */

ol {
  list-style: decimal;
  margin: 0 0 2em 0;
  padding-left: 1.25em;
}

ol li {
  padding-left: 0.25em;
}

ul {
  list-style: disc;
  margin: 0 0 2em 0;
  padding-left: 1em;
}

ul li {
  padding-left: 0.5em;
}

dl {
  margin: 0 0 2em 0;
}

dl dt {
  display: block;
  font-weight: 500;
  margin: 0 0 1em 0;
}

dl dd {
  margin-left: 2em;
}

ul.icons li a.icon:hover:before {
  background-color: rgba(86, 86, 86, 0.075);
}

/* Actions */

ul.actions {
  display: -moz-flex;
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  cursor: default;
  list-style: none;
  margin-left: -1em;
  padding-left: 0;
}

ul.actions li {
  padding: 0 0 0 1em;
  vertical-align: middle;
}

@media screen and (max-width: 480px) {
  ul.actions:not(.fixed) {
    -moz-flex-direction: column;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    margin-left: 0;
    width: 100% !important;
  }

  ul.actions:not(.fixed) li {
    -moz-flex-grow: 1;
    -webkit-flex-grow: 1;
    -ms-flex-grow: 1;
    flex-grow: 1;
    -moz-flex-shrink: 1;
    -webkit-flex-shrink: 1;
    -ms-flex-shrink: 1;
    flex-shrink: 1;
    padding: 1em 0 0 0;
    text-align: center;
    width: 100%;
  }

  ul.actions:not(.fixed) li > * {
    width: 100%;
  }

  ul.actions:not(.fixed) li:first-child {
    padding-top: 0;
  }
}

/* Section/Article */

section header h1:before,
section header h2:before,
section header h3:before,
section header h4:before,
section header h5:before,
section header h6:before,
article header h1:before,
article header h2:before,
article header h3:before,
article header h4:before,
article header h5:before,
article header h6:before {
  content: "";
  display: block;
  width: 2em;
  height: 1px;
  border-top: solid 1px;
  margin: 0 0 1em 0;
}

section header p,
article header p {
  font-size: 1.25em;
}

section header.major,
article header.major {
  text-align: center;
  margin: 0 0 3em 0;
}

section header.major h1:before,
section header.major h2:before,
section header.major h3:before,
section header.major h4:before,
section header.major h5:before,
section header.major h6:before,
article header.major h1:before,
article header.major h2:before,
article header.major h3:before,
article header.major h4:before,
article header.major h5:before,
article header.major h6:before {
  margin-left: auto;
  margin-right: auto;
}

@media screen and (max-width: 736px) {
  section header p,
  article header p {
    font-size: 1em;
  }

  section header p br,
  article header p br {
    display: none;
  }
}

/* Table */

.table-wrapper {
  -webkit-overflow-scrolling: touch;
  overflow-x: auto;
}

table {
  margin: 0 0 2em 0;
  width: 100%;
}

table tbody tr {
  border: solid 1px;
  border-left: 0;
  border-right: 0;
}

table td {
  padding: 0.75em 0.75em;
}

table th {
  font-size: 0.9em;
  font-weight: 500;
  padding: 0 0.75em 0.75em 0.75em;
  text-align: left;
}

table thead {
  border-bottom: solid 2px;
}

table tfoot {
  border-top: solid 2px;
}

table thead {
  border-bottom-color: rgba(86, 86, 86, 0.25);
}

table tfoot {
  border-top-color: rgba(86, 86, 86, 0.25);
}

table tbody tr {
  border-color: rgba(86, 86, 86, 0.25);
}

table tbody tr:nth-child(2n + 1) {
  background-color: rgba(86, 86, 86, 0.075);
}

/* Wrapper */

.wrapper {
  padding: 7.5em 0 5.5em 0;
}

.wrapper > .inner {
  width: 72em;
  max-width: 100%;
  margin: 0 auto;
}

@media screen and (max-width: 1680px) {
  .wrapper > .inner {
    width: 64em;
  }
}

.wrapper.style2 {
  background-color: #f7f7f7;
}

.wrapper.style3 {
  background-color: #565656;
  color: #ffffff;
  background-image: -moz-linear-gradient(
      to top,
      rgba(86, 86, 86, 0.7),
      rgba(86, 86, 86, 0.7)
    ),
    url("bg.jpg");
  background-image: -webkit-linear-gradient(
      to top,
      rgba(86, 86, 86, 0.7),
      rgba(86, 86, 86, 0.7)
    ),
    url("bg.jpg");
  background-image: -ms-linear-gradient(
      to top,
      rgba(86, 86, 86, 0.7),
      rgba(86, 86, 86, 0.7)
    ),
    url("bg.jpg");
  background-image: linear-gradient(
      to top,
      rgba(86, 86, 86, 0.7),
      rgba(86, 86, 86, 0.7)
    ),
    url("bg.jpg");
  background-size: cover, cover;
  background-position: center, center;
  background-repeat: repeat, no-repeat;
  background-attachment: fixed;
}

.wrapper.style3 blockquote {
  border-left-color: rgba(255, 255, 255, 0.25);
}

.wrapper.style3 hr {
  border-bottom-color: rgba(255, 255, 255, 0.25);
}

.wrapper.style3 code {
  background: rgba(255, 255, 255, 0.075);
}

.wrapper.style3 ul.icons li a.icon:hover:before {
  background-color: rgba(255, 255, 255, 0.075);
}

.wrapper.style3 ul.icons li a.icon:hover:before {
  background-color: rgba(255, 255, 255, 0.075);
}

.wrapper.style3 table thead {
  border-bottom-color: rgba(255, 255, 255, 0.25);
}

.wrapper.style3 table tfoot {
  border-top-color: rgba(255, 255, 255, 0.25);
}

.wrapper.style3 table tbody tr {
  border-color: rgba(255, 255, 255, 0.25);
}

.wrapper.style3 table tbody tr:nth-child(2n + 1) {
  background-color: rgba(255, 255, 255, 0.075);
}

@media screen and (max-width: 980px) {
  .wrapper.style3 .spotlight:last-of-type {
    border-bottom-color: rgba(255, 255, 255, 0.25);
  }
}

@media screen and (max-width: 980px) {
  .wrapper.style3 > .inner.split > :first-child {
    border-bottom-color: rgba(255, 255, 255, 0.25);
  }
}

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

.wrapper.featured > .inner {
  display: -moz-inline-flex;
  display: -webkit-inline-flex;
  display: -ms-inline-flex;
  display: inline-flex;
  -moz-flex-direction: row;
  -webkit-flex-direction: row;
  -ms-flex-direction: row;
  flex-direction: row;
  -moz-align-items: center;
  -webkit-align-items: center;
  -ms-align-items: center;
  align-items: center;
  padding: 2em 0;
  width: auto;
  text-align: left;
}

.wrapper.featured > .inner > .image {
  display: block;
  margin: 0 4em 2em 0;
  width: 21em;
}

.wrapper.featured > .inner > .image img {
  border-radius: 100%;
  width: 100%;
}

.wrapper.featured > .inner > .content h1 {
  font-size: 4em;
}

.wrapper.featured > .inner > .content h1:before {
  display: none;
}

.wrapper.featured > .inner > .content p {
  font-size: 1.5em;
  margin: 0 0 1.5em 0;
}

@media screen and (max-width: 1280px) {
  .wrapper.featured > .inner {
    padding: 0;
  }

  .wrapper.featured > .inner > .content h1 {
    font-size: 3.5em;
  }

  .wrapper.featured > .inner > .content p {
    font-size: 1.25em;
  }
}

@media screen and (max-width: 980px) {
  .wrapper.featured > .inner {
    display: block;
    text-align: center;
  }

  .wrapper.featured > .inner > .image {
    margin: 0 auto 3em auto;
    width: 18em;
  }

  .wrapper.featured > .inner > .content p {
    margin: 0 0 2em 0;
  }
}

@media screen and (max-width: 736px) {
  .wrapper.featured > .inner > .image {
    margin: 0 auto 2.5em auto;
    width: 13em;
  }

  .wrapper.featured > .inner > .content h1 {
    font-size: 2.5em;
  }

  .wrapper.featured > .inner > .content p {
    font-size: 1em;
  }
}

@media screen and (max-width: 360px) {
  .wrapper.featured > .inner > .image {
    margin: 0 auto 2em auto;
    width: 11em;
  }
}

.wrapper.split > .inner {
  display: -moz-flex;
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  -moz-flex-direction: row;
  -webkit-flex-direction: row;
  -ms-flex-direction: row;
  flex-direction: row;
}

.wrapper.split > .inner > * {
  width: 50%;
  -ms-flex: 1;
}

.wrapper.split > .inner > :first-child {
  margin-right: 2em;
}

.wrapper.split > .inner > :last-child {
  margin-left: 2em;
}

@media screen and (max-width: 1280px) {
  .wrapper.split > .inner > :first-child {
    margin-right: 1.5em;
  }

  .wrapper.split > .inner > :last-child {
    margin-left: 1.5em;
  }
}

@media screen and (max-width: 980px) {
  .wrapper.split > .inner {
    display: block;
    text-align: center;
  }

  .wrapper.split > .inner header h2::before,
  .wrapper.split > .inner header h3::before,
  .wrapper.split > .inner header h4::before,
  .wrapper.split > .inner header h5::before,
  .wrapper.split > .inner header h6::before {
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .wrapper.split > .inner > * {
    width: 100%;
  }

  .wrapper.split > .inner > :first-child {
    margin-right: 0;
    border-bottom: solid 1px rgba(86, 86, 86, 0.25);
    padding-bottom: 2em;
    margin-bottom: 4em !important;
  }

  .wrapper.split > .inner > :last-child {
    margin-left: 0;
  }
}

@media screen and (max-width: 1280px) {
  .wrapper {
    padding: 6em 3em 4em 3em;
  }

  .wrapper > .inner {
    width: 100%;
  }
}

@media screen and (max-width: 736px) {
  .wrapper {
    padding: 4em 2em 2em 2em;
  }
}

@media screen and (max-width: 480px) {
  .wrapper {
    padding: 4em 1.5em 2em 1.5em;
  }
}

@media screen and (max-width: 360px) {
  .wrapper {
    padding: 3em 1em 1em 1em;
  }
}

/* Header */

#header {
  position: fixed;
  right: 2em;
  top: 2em;
  z-index: 10000;
}

#header ul {
  display: -moz-flex;
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  -moz-align-items: center;
  -webkit-align-items: center;
  -ms-align-items: center;
  align-items: center;
  list-style: none;
  margin: 0;
  padding: 0;
}

#header ul li {
  display: block;
  padding: 0;
}

#header ul li a {
  display: block;
  position: relative;
  height: 3.75em;
  line-height: 3.75em;
  padding: 0 2em 0 0;
  border: 0;
}

#header ul li a[href="#menu"] {
  -moz-transition: width 0.2s ease, border-radius 0.2s ease, color 0.2s ease;
  -webkit-transition: width 0.2s ease, border-radius 0.2s ease, color 0.2s ease;
  -ms-transition: width 0.2s ease, border-radius 0.2s ease, color 0.2s ease;
  transition: width 0.2s ease, border-radius 0.2s ease, color 0.2s ease;
  -webkit-tap-highlight-color: transparent;
  background-color: rgba(73, 73, 73, 0.9);
  border-radius: 100%;
  color: #565656;
  overflow: hidden;
  padding: 0;
  text-decoration: none;
  white-space: nowrap;
  font-size: 0.8em;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  text-indent: -4.6875em;
  width: 4.6875em;
  height: 4.6875em;
  line-height: 4.6875em;
}

#header ul li a[href="#menu"]:before {
  -moz-transition: all 0.2s ease;
  -webkit-transition: all 0.2s ease;
  -ms-transition: all 0.2s ease;
  transition: all 0.2s ease;
  content: "";
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100' viewBox='0 0 100 100' preserveAspectRatio='none'%3E%3Cstyle%3Eline %7B stroke-width: 6px%3B stroke: %23ffffff%3B %7D%3C/style%3E%3Cline x1='10' y1='30' x2='90' y2='30' /%3E%3Cline x1='10' y1='50' x2='90' y2='50' /%3E%3Cline x1='10' y1='70' x2='90' y2='70' /%3E%3C/svg%3E");
  background-position: center;
  background-repeat: no-repeat;
  width: 4.6875em;
  height: 4.6875em;
  background-size: 2.5em;
}

#header ul li a[href="#menu"]:hover {
  color: #ffffff;
  text-indent: 0;
  width: 9.6875em;
  border-radius: 4.6875em;
  padding-left: 1.875em;
}

#header ul li a[href="#menu"]:hover:before {
  background-size: 1.5625em;
}

@media screen and (max-width: 736px) {
  #header {
    right: 1em;
    top: 1em;
  }

  #header ul li a {
    height: 3em;
    line-height: 3em;
    padding: 0 1em 0 0;
  }

  #header ul li a[href="#menu"] {
    text-indent: -3.75em;
    width: 3.75em;
    height: 3.75em;
    line-height: 3.75em;
  }

  #header ul li a[href="#menu"]:before {
    width: 3.75em;
    height: 3.75em;
    background-size: 2.1875em;
  }

  #header ul li a[href="#menu"]:hover {
    border-radius: 100%;
    padding-left: 0;
    text-indent: -3.75em;
    width: 3.75em;
  }

  #header ul li a[href="#menu"]:hover:before {
    background-size: 2.1875em;
  }
}

/* Footer */

#footer .copyright {
  text-align: center;
  opacity: 0.35;
  font-size: 0.8em;
  margin: 4em 0 0 0;
}

#footer .copyright:before {
  content: "";
  display: block;
  width: 4rem;
  height: 1px;
  margin: 0 auto 2rem auto;
  border-top: solid 1px;
  opacity: 0.5;
}

@media screen and (max-width: 980px) {
  #footer ul.actions {
    -moz-justify-content: center;
    -webkit-justify-content: center;
    -ms-justify-content: center;
    justify-content: center;
    width: 100%;
    margin-left: 0;
  }

  #footer ul.actions li:first-child {
    padding-left: 0;
  }
}

/* Intro */

#intro .image {
  -moz-transition: opacity 0.75s ease-in-out;
  -webkit-transition: opacity 0.75s ease-in-out;
  -ms-transition: opacity 0.75s ease-in-out;
  transition: opacity 0.75s ease-in-out;
}

#intro .content {
  -moz-transition: -moz-transform 0.5s ease-in-out, opacity 0.5s ease-in-out;
  -webkit-transition: -webkit-transform 0.5s ease-in-out,
    opacity 0.5s ease-in-out;
  -ms-transition: -ms-transform 0.5s ease-in-out, opacity 0.5s ease-in-out;
  transition: transform 0.5s ease-in-out, opacity 0.5s ease-in-out;
  -moz-transition-delay: 0.35s;
  -webkit-transition-delay: 0.35s;
  -ms-transition-delay: 0.35s;
  transition-delay: 0.35s;
}

@media screen and (max-width: 980px) {
  #intro ul.actions {
    -moz-justify-content: center;
    -webkit-justify-content: center;
    -ms-justify-content: center;
    justify-content: center;
    width: 100%;
    margin-left: 0;
  }

  #intro ul.actions li:first-child {
    padding-left: 0;
  }
}

#intro {
  opacity: 0; /* Start hidden */
  animation: fadeIn 1s forwards; /* Apply fade-in animation */
}

@keyframes fadeIn {
  from {
    opacity: 0; /* Start fully transparent */
  }
  to {
    opacity: 1; /* End fully opaque */
  }
}

.button {
  -moz-appearance: none;
  -webkit-appearance: none;
  -ms-appearance: none;
  appearance: none;
  -moz-transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
  -webkit-transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
  -ms-transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
  transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
  border-radius: 0.5rem;
  border-style: solid;
  border-width: 1px !important;
  border-color: inherit !important;
  color: inherit !important;
  cursor: pointer;
  display: inline-block;
  font-weight: 500;
  font-size: 0.7em;
  height: 4.28571em;
  line-height: 4.28571em;
  border-radius: 4.28571em;
  padding: 0 2.85714em;
  text-align: center;
  text-decoration: none;
  white-space: nowrap;
  text-transform: uppercase;
  letter-spacing: 0.2em;
}
.button:hover {
  border: solid 1px;
}

.button.large {
  font-size: 0.85em;
  height: 3.92857em;
  line-height: 3.92857em;
  border-radius: 3.92857em;
  padding: 0 2.5em;
}
.button {
  background-color: transparent;
}
.button:hover {
  background-color: rgba(86, 86, 86, 0.075);
}
.button.primary {
  background-color: #565656;
  border-color: #565656;
  color: #ffffff !important;
}
.button.primary:hover {
  background-color: rgba(86, 86, 86, 0.075);
  color: inherit !important;
}
