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

h2,
h5,
summary,
ul {
  border: 0;
  vertical-align: baseline
}

h5 {
  padding: 0
}

summary {
  margin: 0;
  list-style: none;
  width: 100%;
  /* text-transform: uppercase; */
  line-height: 1;
  padding: 8px 0 0
}

.flex-container>div,
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block
}

body,
p {
  font-weight: 400
}

body {
  line-height: 1;
  font-family: "beaufort-pro";
  color: #333;
  padding: 2rem 4rem;
  background: #f6f3f3;
}

blockquote,
q {
  quotes: none
}

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

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

* {
  box-sizing: border-box;
  /* font-size: calc(12px + .390625vw) */
}

.column {
  display: inline-flex;
  flex-wrap: wrap;
  flex-direction: column;
  align-content: flex-start;
  justify-content: space-between;
  padding: 0
}

.row {
  flex-direction: row;
  width: 100%;
  align-items: flex-start
}

p {
  line-height: 1.35;
  padding-right: 1rem
}

strong {
  font-weight: 700;
}

details {
  text-align: left;
  background-color: transparent;
  color: #333
}

summary {
  color: white;
  padding: 0.35rem;
}

details {
  border-bottom: 1px solid #333;
  cursor: pointer;
  background-color: #333;
}


summary::-webkit-details-marker {
  display: none
}

details[open] {
  background-color: transparent;
  color: #333;
  margin-bottom: 0;
}

.tableofcontents {
  margin: 0;
  font-weight: 600;
  font-family: montecatini-pro-largo
}

.tableofcontents li {
  padding: .5rem 0;
  font-weight: 600;
  text-align: left;
  text-transform: uppercase;
  font-size: 3rem;
  border-bottom: 1px solid #333
}

.tableofcontents li:hover {
  background-color: #fff;
  color: #333
}

.tableofcontents li:last-of-type {
  border-bottom: 0
}

.tableofcontents li>a {
  list-style-type: none;
  margin: 0;
  padding-left: 0;
  width: 100%;
  display: block;
  height: 100%
}

ol li {
  margin: 0 0 .5rem;
  padding: 0
}

ol {
  margin: .5rem 0;
  padding-left: 0;
}

.youarehere {
  background-color: red
}

.flex-container {
  display: flex;
  height: 100%;
  border: 1px solid #333;
  margin-top: 0
}

#sidebar {
  flex-basis: 168px;
  min-width: 20%;
  border-right: 1px solid #333
}

/*
.casestudy {
  padding: 2rem;
  border-top: 0
  background-color: white;
  color: #333;
}

.casestudy h3 {
  font-size: 1rem;
  margin: 0;
  font-weight: 600;
  line-height: 1;

}
.casestudy h3 {
  line-height: 1;
  margin-top: 1rem;
  margin-bottom: 1rem
}

.casestudy>h4:first-of-type {
  margin: 0 0 0 10%
}

.casestudy h4 {
  font-size: 1rem;
  line-height: 1;
  font-weight: 600;
  text-transform: uppercase;
  margin: 0
}

.casestudy p,
.casestudy p.intro {
  font-size: 1.25rem;
  font-weight: 300
}

.casestudy p {
  font-size: 1rem;
  line-height: 1.35;
  margin: 0 0 1em;
  vertical-align: baseline
} */

#textblock {
  max-width: 75%;
  margin-left: 10%
}


h1,
h2 {
  line-height: 1;
  margin-left: 0px;
}

.textblock h4 {
  margin-left: 0
}

h2 {
  font-size: 96px;
  font-weight:900;
  margin: 0px;
  color: #333;
  /* text-transform: uppercase; */
  letter-spacing: -0.06125em;
}

#casestudy h4 {
  font-size: 2vw;
  font-weight: 500;
  font-variant-caps: all-small-caps;
  letter-spacing: 1px;
}

#casestudy h2 {
  font-size: 3vw;
  font-weight: 100;
  font-variant-caps: all-small-caps;
  margin-bottom: 2rem;
}


.row {
  -ms-flex-wrap: wrap;
  display: block;
  flex-wrap: wrap;
  justify-content: start
}

.column img {
  margin: auto;
  width: auto
}

#imgfullwidth {
  object-fit: cover;
  object-position: center;
  max-height: 100%;
  aspect-ratio: 16/9
}

.masthead {
  border-top: 1px solid #333;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  border-left: 0;
  border-right: 0;
  padding: 4px 0 4px;
  margin-bottom: 0;
  margin-top: 1rem
}

.container-fullspread {
  border: 1px solid #555;
  padding: 2rem;
  display: flex
}

.topstripe {
  border-bottom: 1px solid #333;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  letter-spacing: normal;
  border-left: 0;
  border-right: 0;
  padding: 4px 0 8px;
  margin: 1rem 0 0;
}

.container {
  padding: 0;
  margin: 0 0 4rem;
  max-width: 100%
}

#vm-head {
  width: 100%;
  height: auto;
  margin-top: 1rem;
  display: block;
  border: 0
}

#workgrid div.column {
  margin: 2em 2em 2em 0;
  background-color: #fff
}

#workgrid img {
  height: inherit
}

h3.sectionhead {
  margin-bottom: 8px
}


a {
  text-decoration: none;
  color: #333
}


#achievements p {
  padding: 1rem;
  margin: 0;
  font-size: 12px;
  width: 50%;
  display: inline-block;
  border-top: 1px solid #333;
  border-left: 1px solid #333
}

@media screen and (max-width:640px) {
  body {
    padding: 1rem
  }
}

.grid-layout {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  grid-gap: 1px;
  grid-auto-rows: minmax(180px, auto);
  grid-auto-flow: dense;
  padding: 1px
}

.grid-item {
  padding: 1rem;
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
  color: #000;
  background-color: #ccc
}

.span-2 {
  grid-column-end: span 2;

  grid-row-end: span 2
}

.span-3 {
  grid-column-end: span 3;
  grid-row-end: span 4
}

img {
  -webkit-filter: grayscale(100%);
  -moz-filter: grayscale(100%);
  -ms-filter: grayscale(100%);
  filter: grayscale(100%);
  filter: gray;
  width: 100%;
  height: auto;
  object-fit: contain;
}

img:hover {
  -webkit-filter: none;
  -moz-filter: none;
  -ms-filter: none;
  filter: none
}

.tobeige:hover {
  background-color: rgb(255, 220, 180);
}

.topink:hover {
  background-color: pink;
}


#radcandour {
  margin-top: 1rem;
  position: relative
}

.twocolumnlist {
  display: flex;
  margin: 0;
  text-align: left;
  flex-direction: row;
  width: 50%;
  justify-content: space-around;
  border: 1px solid #333
}

.twocolumnlist p {
  border-bottom: 1px solid #333;
  font-size: 12px;
  padding-top: 0;
  padding-bottom: .5rem;
  line-height: 1;
  text-align: left
}

.twocolumnlist p:last-of-type {
  border-bottom: 0
}

.twocolumnlist div {
  width: 45%
}

.twocolumnlist div:first-of-type {
  border: 0
}

.topeight {
  border-top: 8px solid #333
}

.topfour {
  border-top: 4px solid #333
}

.toptwo {
  border-top: 2px solid #333
}

.top1 {
  border-top: 1px solid #333
}

#achievements {
  justify-content: flex-start
}

.byline {
  width: 100%;
  font-weight: 400
}

#clients {
  columns: 3;
  column-rule: 1px solid #333;
  column-gap: 1rem
}

ul {
  list-style-type: none;
  margin-bottom: 0;
  padding-bottom: 0;
}

.sb-16 {
  border-top: 16px solid #111
}

.sb-8 {
  border-top: 8px solid #111
}

.sb-4 {
  border-top: 4px solid #111
}

.sb-2 {
  border-top: 2px solid #111
}

.sb-1 {
  border-top: 1px solid #111
}

.sb-bottom-2 {
  border-bottom: 2px solid #111
}

.right {
  text-align: right
}

.margin {
  margin: calc(8px + 1.5625vw)
}

.no-margin {
  margin: 0
}

.no-margin-sides {
  margin-left: 0;
  margin-right: 0
}

.padding {
  padding: calc(16px + 1.5625vw)
}

.no-padding {
  padding: 0
}

.image-grid figure,
ul {
  margin: 0;
  padding: 0
}

.image-grid img {
  display: block;
  width: 100%;
  height: auto
}

.special-cards {
  list-style: none;
  margin: 0;
  padding: calc(8px + 1.5625vw);
  text-align: center;
  background: linear-gradient(0deg, #63d4ff 0, #2490ff 100%)
}

.special-cards>* {
  background: #fff;
  background: linear-gradient(0deg, #fff 0, #f1f1f1 100%);
  border-top: 1px solid #fff;
  border-bottom: 1px solid #999;
  box-shadow: 0 0 10px rgba(0, 0, 0, .2)
}

.masonry {
  /* transition: .25s ease-in-out; */
  column-gap: 0.5rem;
  column-fill: initial
}

.spanner {
  column-span: all
}

.masonry .brick {
  vertical-align: top;
}

.masonry .brick img {
  transition: .25s ease-in-out;
  backface-visibility: hidden;
  vertical-align: top;
  margin-bottom: 0.5rem;

}

/* .masonry .brick:hover img {
  opacity: .75
} */

.masonry.gutterless {
  column-gap: 0
}

.masonry.gutterless .brick {
  margin-bottom: 0
}

@media only screen and (min-width:768px) and (max-width:1023px) {
  .masonry {
    column-count: 3;
  }
}

@media only screen and (min-width:1024px) {
  .masonry {
    column-count: 3;
  }
}

@media only screen and (min-width:1440px) {
  .masonry {
    column-count: 3;
  }
}

#main {
  margin: 0px;
}

h3 {
  font-weight: 500;
  font-size: var(--xsmall);
  line-height: 1;
  margin-bottom: 8px;
  margin-top: 2rem;
}

h3>p {
  margin-bottom: 0
}

h3:first-of-type {
  margin-top: 2rem
}

p>a {
  text-decoration: underline
}

h4 {
  margin: 0;
  font-size: var(--xxsmall);
  font-weight: 400;
  line-height: 1.25;
  letter-spacing: .0125rem
}

.tracktitle {
  font-size: 24px;
}

h5 {
  width: 100%;
  font-size: 16px;
  margin: 0 0 1rem;
  font-weight: 500
}

p {
  margin: 0 0 1rem;
  font-weight: 400;
  font-size: 16px;
  max-width: 64ch
}

.intro {
  margin: 0 0 1rem
}

summary {
  text-transform: uppercase;
  font-size: 1.25rem;
  font-weight: 500;
  padding-bottom: .25rem;
}

details[open] {
  text-align: left;
  padding-bottom: 0;
  border-bottom: 2px solid #333
}

details[open] summary {
  color: #fff;
  margin-bottom: 0;
  padding: .5rem;
  background-color: #333;
  border-bottom: 2px solid #333
}

[data-join]>*,
[join]>* {
  padding: 0
}

column {
  background: #eaeaea;
}

.caption column {
  background: 0 0;
  text-align: center;
  padding: 0
}

figure {
  margin: 0;
  padding: 0
}

figure img {
  aspect-ratio: 1.1;
  object-fit: contain;
  object-position: center center;
  margin: 0;
  padding: 0
}

.image-cards figcaption {
  padding-left: 0;
  font-size: 12px;
  font-weight: 300
}

figcaption a {
  text-align: left;
  color: #333
}

a:hover {
  background: #fff
}

.casestudy p~h3 {
  margin-top: 2rem
}

.casestudy-subhead {
  margin-bottom: 2rem;
}

.casestudy h4 {
  margin-top: 1rem
}

.casestudy h2 {
  margin-bottom: 0
}

.casestudy ol {
  font-variant-numeric: oldstyle-nums;
  margin: 0;
  padding: 0;
}

.finalrow {
  border-bottom: 1px solid #333
}

header {
  margin-bottom: 0;
  font-size: 0.75rem;
}

.caption {
  background: 0 0;
  margin: 0
}

.hoverless:hover {
  background: 0 0
}

.about {
  padding: 2rem 3rem 3rem 3rem;
  font-size: clamp(.8rem, 1vw + 2px, 3rem);
  font-weight: 400;
  line-height: 1.35
}


.about>h3 {
  margin: 0 0 1rem -4px;
  font-weight: 900;
  font-size: 8rem;
  font-style: italic;
  letter-spacing: -4px;
}

.about>h4 {
  margin: 2rem 0 8px -1ch;
  font-size: 1.5rem;
}

.playlist li {
  margin-bottom: 0;
  padding: 0;
  border-bottom: 1px solid #333
}

.playlist li:hover {
  background-color: white;
}

em {
  font-style: italic
}

h5 a {
  font-weight: 600;
  text-decoration: underline
}

/* h2 {
  text-transform: uppercase;
  font-family: 'ohno-fatface-condensed';
  font-weight: 100;
  padding: 0;
  margin: 1rem 0 0 0;
  font-size: 2vw;
  color: #333;
  line-height: 1;
} */

.contents {
  border-top: 2px solid #333
}

p+h3 {
  margin-top: 0
}

.boxed {
  border: 1px solid #333;

}

.about>details {
  border-top: 1px solid #333;
  border-bottom: 0;
  margin-bottom: 1rem;
}

.about>details[open] {
  /* border: 1px solid #333; */
  padding: 1rem 2rem 2rem 1rem;
  background-color: #eaeaea;

}

.about>details[open]>ul {
  padding: 0;
}

.about>details[open] summary {
  background-color: transparent;
  color: #333;
  border: 0px;
  margin: 0;
  padding: 0;
}


.stretchtofill {
  width: 100%;
  height: auto;
  object-fit: contain;
  margin-top: 1rem;
}

blockquote {
  margin-bottom: 2rem;
  font-size: 2rem;
  font-family: 'forevs', sans-serif;
}

blockquote::before {
  content: '“';
  margin-left: -8px;
}

.introheading {
  font-size: 32px;
}


::selection {
  /* color: white; */
  background: red;
}

hr {
  border: 0;
  height: 1px;
  background: #333;
  background-image: linear-gradient(to right, #444, #000, #444);
}





.player {
  width: auto;
  margin: 0;
  border: 1px solid #333;
}

video,
audio,
.controls {
  width: 100%;
}

.controls {
  height: 36px;
}

button {
  display: block;
  float: left;
  border: 0;
  height: 100%;
  width: 64px;
  cursor: pointer;
  color: #333;
  font-family: "degular-text";
  font-weight: 500;
  font-size: 12px;
  text-transform: uppercase;
}

button:hover,
button:focus {
  background-color: #f00;
}

button:active {
  background-color: #333;
}

.controls div {
  font-size: 14px;
  font-weight: 500;
  display: inline-block;
  line-height: 36px;
  width: 45px;
  margin-right: 16px;
  padding-right: 0px;
  text-align: right;
  float: right;
  font-family: "degular-text";
}

video {
  margin-bottom: -5px;
}

r-c>* {
  background: #eaeaea;
}
