/* ==========================================================================
   HTML5 Boilerplate styles - h5bp.com (generated via initializr.com)
   ========================================================================== */
@font-face {
   font-family: "LL Circular Book Web";
   src: url("../fonts/lineto-circular-book.eot");
   src: url("../fonts/lineto-circular-book.eot?#iefix") format("embedded-opentype"),
        url("../fonts/lineto-circular-book.woff2") format("woff2"),
        url("../fonts/lineto-circular-book.woff") format("woff");
   font-weight: normal;
   font-style: normal;
}

@font-face {
   font-family: "LL Circular Medium Web";
   src: url("../fonts/lineto-circular-medium.eot");
   src: url("../fonts/lineto-circular-medium.eot?#iefix") format("embedded-opentype"),
        url("../fonts/lineto-circular-medium.woff2") format("woff2"),
        url("../fonts/lineto-circular-medium.woff") format("woff");
   font-weight: normal;
   font-style: normal;
}

@font-face {
   font-family: "LL Circular Bold Web";
   src: url("../fonts/lineto-circular-bold.eot");
   src: url("../fonts/lineto-circular-bold.eot?#iefix") format("embedded-opentype"),
        url("../fonts/lineto-circular-bold.woff2") format("woff2"),
        url("../fonts/lineto-circular-bold.woff") format("woff");
   font-weight: normal;
   font-style: normal;
}

@font-face {
   font-family: "LL Circular Black Web";
   src: url("../fonts/lineto-circular-black.eot");
   src: url("../fonts/lineto-circular-black.eot?#iefix") format("embedded-opentype"),
   		url("../fonts/lineto-circular-black.woff2") format("woff2"),
        url("../fonts/lineto-circular-black.woff") format("woff");
   font-weight: normal;
   font-style: normal;
}







html,
button,
input,
select,
textarea {
	color: #222;
}

html, 
html a {
	-webkit-font-smoothing: antialiased;
	text-shadow: 1px 1px 1px rgba(0,0,0,0.004);
	height: 100%;
}

body {
	font-size: 18px;
	line-height: 1.4;
	margin: 0 auto;
   	font-family: "LL Circular Book Web", "Helvetica", Arial;
	height: 100%;
	display: flex;
	flex-direction: column;
}

::-moz-selection {
	background: #b3d4fc;
	text-shadow: none;
}

::selection {
	background: #b3d4fc;
	text-shadow: none;
}

/*
 * A better looking default horizontal rule
 */
hr {
	display: block;
	height: 1px;
	border: 0;
	border-top: 1px solid #ccc;
	margin: 1em 0;
	padding: 0;
}

/*
 * Remove the gap between images, videos, audio and canvas and the bottom of
 * their containers: h5bp.com/i/440
 */
audio,
canvas,
img,
video {
	vertical-align: middle;
}

/*
 * Remove default fieldset styles.
 */
fieldset {
	border: 0;
	margin: 0;
	padding: 0;
}

/*
 * Allow only vertical resizing of textareas.
 */
textarea {
    resize: vertical;
}

/* header {
	flex: 1 0 auto;
}
 */

/* ================================================================ general */
.button {
	display: block;
	position: relative;
	color: transparent;
	font: 0/0 a;
	text-shadow: none;
}

.button {
	cursor: pointer;
}

a, 
a:link, 
a:visited, 
a:hover, 
a:active {
	color: #F73736;
}

a:hover {
	text-decoration: none; 
}

svg,
video {
    vertical-align: middle;
    display: block;
    border: 0;
}
/* svg /
    -webkit-backface-visibility: hidden;
    -webkit-transform: translateZ(0) scale(1.0, 1.0);
    transform: translateZ(0);
} */

.image {
    overflow: hidden;
    position: relative;
    width: 100%;
    margin: auto;
    top: 0;
}
.image img, 
.image svg,
.image video {
    border: 0;
    display: block;
    height: auto;
    width: 100%;
    position: absolute;
}
.image svg {
    height: 100%;
    vertical-align: top;
    top: 0;
}

section,
.full-width {
    clear: both;
    position: relative;
    width: 90%;
    margin-left: auto;
    margin-right: auto;
    max-width: 1360px;
    flex-shrink: 1 0 auto;
}

/*section, 
header,
h1,
.menu {
	padding-bottom: 60px;
}*/

.half-width {
	float: left;
	width: 50%;
}

.third-width {
	float: left;
	width: 312px;
}

.text-width {
	max-width: 1120px;
	width: 60%;
}


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

/* .waypoint {
	opacity: 0;
	position: relative;
	transform: scale(1.2);
} */

/* ================================================================ fonts */
h1 {
	font-family: "LL Circular Black Web", "Helvetica", Arial;
	/* color: #F73736; */
	margin: 0;
	line-height: 1.3em;
}

h2 {
	line-height: 1em;
}

h3 {
}

/*
section,
.modal {
    font-size: 1.375em;
    font-family: "LL Circular Book Web";
    line-height: 1.4em;
}
*/

p {
	font-size: 1em;
	margin: 0 0 1.3em;
	line-height: 1.6em;
}

ul {
	text-align: left;
}

.book {
	font-family: "LL Circular Book Web", "Helvetica", Arial;
}

.medium {
	font-family: "LL Circular Medium Web", "Helvetica", Arial;
}

.bold {
	font-family: "LL Circular Bold Web", "Helvetica", Arial;
}

.black {
	font-family: "LL Circular Black Web", "Helvetica", Arial;
}

/* ================================================================ text-colors */

.red {
	color: #F73736;
}

.green {
	color: #00C853;
}

.blue {
	color: #2979FF;
}

.yellow {
	color: #FFF000;
}

.white {
	color: #fff;
}

.dark {
	color: #000;
}

/* ================================================================ background-colors */

.background-red {
	background-color: #F73736;
	color: #fff;
}

.background-yellow {
	background-color: #FFF000;
	color: #000;
}

.background-blue {
	background-color: #2979FF;
	color: #fff;
}

.background-green {
	background-color: #00C853;
	color: #fff;
}

.background-grey {
	background-color: #F5F5F5;
	color: #000;
}

.background-black {
	background-color: #000;
	color: #fff;
}

#ajax-magic {
	z-index: 0;
}


/* ================================================================ general */
.page-overlay {
	position: fixed;
	z-index: 100;
	width: 100%;
	height: 100%;
	background: #fff;
	opacity: 1;
	top: 0;
	left: 0;
}

.page-content {
	padding-top: 11.2em;
}

section,
.full-width,
.title-image,
.the-work-list ul {
/*     margin-bottom: 5.55em; */
}

.full-bleed {
	width: 100%;
	max-width: 100%;
}

.no-margin {
	margin: auto;
}
.page-top-margin {
	margin-top: 8.3em;
}
.extra-margin {
	margin-bottom: 11.1em;
}
.extra-top-margin {
	margin-top: 11.1em;
}

.intro {
	margin-left: 50%;
	width: 30%;
	position: relative;
}

.colour-block {

}

/*distance from h1 to p*/
.title {
    margin-bottom: 1em;
    line-height: 1em;
    text-align: left;
	margin-bottom: .7em;
}

h1.title {
    font-size: 16.7vw;
    text-align: center;
    margin-bottom: 8vw;
    letter-spacing: -0.04em;
    text-transform: capitalize;
}

h2.black {
	font-size: 5.5vw;
	line-height: 1em;
	margin: 0 0 1em;
	letter-spacing: -0.02em;
}

.news-page h2.black,
.news-article h1.title {
	text-transform: none;
}

/* ================================================================ header */
.menubar {
	height: 20.5px;
	left: 0;
	padding-top: 4.4vh;
	position: absolute;
    right: 0;
	z-index: 20;
}



.sh-logo {
	width:  161px;
	height: 20.5px;
	position: absolute;
	left: 0;
	text-shadow: none;
	outline: none;
}


.sh-logo .image {
	height: 100%;
}

.sh-logo path {
	fill: #fff;
}

.is-about .sh-logo path,
.is-work .sh-logo path,
.is-news .sh-logo path,
.is-the-news .sh-logo path,
.is-attention-academy .sh-logo path,
.single .sh-logo path,
.is-people .sh-logo path,
.is-careers .sh-logo path,
.is-contact .sh-logo path,
.is-privacy-policy .sh-logo path {
	fill: #000;
}

.show-menu .sh-logo path {
	fill: #fff;
}
.show-menu .sh-logo:hover path {
	fill: #000;
}

.burger {
	position: absolute;
	right: 0;
}

.menu-button {
	width: 31px;
	height: 23px;
	cursor: pointer;
}

.menu-button svg {
	pointer-events: none;
}
.menu-button .cross {
	opacity: 0;
}

.menu-button rect {
	fill: #fff;
}

.is-about .menu-button rect,
.is-work .menu-button rect,
.is-news .menu-button rect,
.is-the-news .menu-button rect,
.is-attention-academy .menu-button rect,
.single .menu-button rect,
.is-people .menu-button rect,
.is-careers .menu-button rect,
.is-contact .menu-button rect,
.is-privacy-policy .menu-button rect {
	fill: #000;
}


.show-menu .menu-button rect {
	fill: #fff;
}
.show-menu .menu-button:hover rect {
	fill: #000;
}

.show-menu .menu-button:hover rect {
	fill: #000;
}

/* ================================================================ navigation */
.menus {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 19;
    height: 100%;
    width: 100%;
    display: none;
}

.main-menu {
	z-index: 1;
	position: relative;
	font-size: 72px;
	left: 0;
	right: 0;
	margin: 25vh auto 15vh;
}

.main-menu ul {
	margin: 0;
	padding: 0;
	list-style: none;
	text-transform: capitalize;
}

.main-menu li a {
	color: #fff;
	text-decoration: none;
	display: inline-block;
	outline: none;
}

.sub-menu {
	position: absolute;
	display: block;
	z-index: 1;
	font-size: 24px;
	left: 0;
	right: 0;
	bottom: 6vh;
	margin: auto;
}

.sub-menu ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

.sub-menu li {
	display: inline-block;
	margin-right: 7vw;
}
.sub-menu li a {
	text-decoration: none;
	color: #fff;
	transition: color 300ms;
	outline: none;
}

.menus li a { 
	text-decoration: none;
	color: #fff;
	transition: color 300ms;
	position: relative;
}
.menus li a:hover,
.menus li a.selected {
	color: #000;
}

.menus li a path,
.menus li a rect,
.menus li a ellipse {
	transition: fill 300ms;
}
.menus li a:hover path,
.menus li a.selected path,
.menus li a:hover rect,
.menus li a.selected rect,
.menus li a:hover ellipse,
.menus li a.selected ellipse {
	fill: #000;
}

.aa-menu-logo {
    position: absolute;
    top: 0;
    right: 0;
    height: 0;
    padding-bottom: 4%;
    width: 1.8vw;
}

.aa-menu-item br {
	display: none;
}

.menu-background {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
}

.panel {
    width: 25%;
    display: inline-block;
    height: 100%;
    vertical-align: top;
}

.panel .colour {
	width: 100%;
	position: relative;
	height: 100%;
	transition: background 300ms;
}

.menu-background .panel {
    display: block;
    position: absolute;
}

/* ================================================================ list grid */
.grid {
	overflow: hidden;
	padding: 0;
	margin: 0 auto 20px auto;
	list-style: none;
}
 .grid .item {
	padding: 0;
	position: relative;
	overflow: hidden;
}

/* 
@media all and (min-width: 500px) {
	.grid .item {
		float: left;
		width: 100%;
	}
} */
@media all and (min-width: 60em) {
	.grid .item {
		width: 50%;
	}
}

@supports(display: flex) {
	@media all and (min-width: 500px) {
		.grid {
			display: flex;
			flex-wrap: wrap;
		}
		.grid .item {
			display: flex;
			flex-direction: column;
		}
		.grid .item > * {
			flex: 1;
	    }
	}
}
/* for grid */

	@media all and (min-width: 500px) {
		.grid {
			display: grid;
			grid-gap: 2em;
		}
		.two-column-grid .grid {
			grid-template-columns: repeat(1, 1fr);
		}
		.five-column-grid .grid {
			grid-template-columns: repeat(2, 1fr);
		}
		.six-column-grid .grid {
			grid-template-columns: repeat(3, 1fr);
		}
		.client-list .grid {
			grid-template-columns: repeat(3, 1fr);
		}
		.grid .item {
			padding: 0;
			display: block;
			float: none;
			width: auto;
		}
	}
	@media all and (min-width: 50em) {
		.two-column-grid .grid {
			grid-template-columns: repeat(2, 1fr);
		}
		.five-column-grid .grid {
			grid-template-columns: repeat(5, 1fr);
		}
		.six-column-grid .grid {
			grid-template-columns: repeat(6, 1fr);
		}
		.grid .item {
			width: auto;
		}
	}

	@media all and (min-width: 880px) {
		.client-list .grid {
			grid-template-columns: repeat(5, 1fr);
		}
	}
	@media all and (min-width: 1100px) {
		.client-list .grid {
			grid-template-columns: repeat(5, 1fr);
		}
	}
	@media all and (min-width: 1400px) {
		.client-list .grid {
			grid-template-columns: repeat(6, 1fr);
		}
	}
	/* force the client list to use 3 columns on mobile */
	@media all and (max-width: 500px) {
		.client-list .grid {
			display: grid;
			grid-gap: 2em;
			grid-template-columns: repeat(2, 1fr);
		}
	}
}


/* ================================================================ home */
.video-overlay {
	z-index: 10;
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
}

.is-home .sh-logo {
	pointer-events: none;
}

.is-home .sh-logo path,
.is-home .menu-button rect {
	fill: #fff;
}
.is-home .menu-button:hover rect {
	fill: #000;
}
.home-video .sh-logo path,
.home-video .menu-button rect {
	fill: #F73736;
}
.home-video .menu-button:hover rect {
	fill: #fff;
}


.vertical-centered {
	height: 100vh;
	position: relative;
	z-index: 1;
}

.main-logo {
	position: absolute;
	height: 100%;
	width: 100%;
}

.main-logo path {
	fill: #F73736;
}
.main-logo .image {
    top: 0;
    position: absolute;
    bottom: 0;
    width: 73%;
    left: 0;
    right: 0;
}
.slogan h1,
.slogan h2 {
	margin: 0;
	position: absolute;
	top: 50%;
	left: 50%;
	white-space: nowrap;
	transform: translate(-50%,-50%);
	font-size: 6.5vw;
	text-align: left;
}
.slogan h1.title {
	text-transform: none;
}
.slogan h1 .break {
	display: block;
}
.always-fill {
	position: absolute;
}
.always-fill img {
	position: relative;
	display: block;
	width: 100%;
	height: 100%;
}

.always-fill {
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background: url(../media/images/home/we-are-on-a-mission.svg) #2979FF 50%;
	background-size: cover;
}

.video-container {
	position: absolute;
    z-index: 0;
    opacity: 0;
}
.intro-animation video {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 100;
    width: 100%;
    height: 100%;
}

.mute-container {
	position: absolute;
	z-index: 20;
	left: 0;
	right: 0;
	bottom: 5.8vh;
	height: 42.6px;
	pointer-events: none;
}
.mute {
	position: absolute;
	top: auto;
	left: auto;
	right: 0;
	margin: auto;
	display: none;
	z-index: 1;
	bottom: 0;
	cursor: pointer;
	width: 36px;
	height: 42.6px;
	pointer-events: all;
}

.mute .icon {
	transition: opacity 300ms;
}
.sound-off,
.muted .sound-on {
	opacity: 0;
}
.sound-on,
.muted .sound-off {
	opacity: 1;
}

.mute path {
	fill: #ffffff;
	stroke: #ffffff;
}

/* ================================================================ about us */
/* h1.title {
    transform: translate3d( 0, 0, 0);
} */
.add-space {
    margin-right: .2em;
}
.outerspan {
    overflow: hidden;
    display: inline-block;
}
.innerspan {
    transform: translateX(0%);
    position: relative;
    display: block;
}

.header-block {
	margin-bottom: 11.2vw;
	overflow-x: hidden;
}

.colour-block {
	color: #fff;
}

.block-content {
    margin: 0 0 0 14.5%;
    z-index: 1;
    position: relative;
    display: inline-block;
    padding-top: 10.5vw;
}

.block-content p {
	font-size: 1em;
	margin: 0;
	width: 50%;
	margin: 0 0 5.6em 45%;
}

.block-content .inner {
	margin-left: 45%;
	margin-bottom: 5.6em;
	width: 50%;
}
.block-content .inner p {
	margin-left: 0;
	width: auto;
}
.block-content p.no-margin {
	margin-bottom: auto;
}

.colour-block ol {
    margin: 2em auto;
}
.colour-block li {
    margin-bottom: 1em;
}

.block-image {
    height: 0;
    position: relative;
    z-index: 0;
    display: inline-block;
    vertical-align: top;
}

.colour-block .text-width {
    width: 58.7%;
}
.colour-block .block-image {
    padding-bottom: 58.7%;
    transform: translateY(-3.9%);
    width: 26.3%;
	position: absolute;
	top: 0;
	right: 0;
}

.about-block02 .text-width {
    width: 53%;
}
.about-block02 .block-image {
    padding-bottom: 54%;
    transform: translateY(-8%);
    width: 31.6%;
}

.superpower .image {
	height: 0;
	padding-bottom: 61.3%;
	width: 64.9%;
	margin: 0;
	max-width: 442px;
}

.column {
	width: 50%;
	display: inline-block;
	vertical-align: middle;
}

.superpower .full-width {
    padding: 12vw 0;
}


.cta {
	font-size: 0.78em;
	border: 1px solid;
	text-decoration: none;
	padding: 1.7em 0;
	text-transform: uppercase;
	display: inherit;
	transition: border 300ms, color 300ms;
	text-align: center;
	width: 360px;
	cursor: pointer;
}

.cta.blue {
	color: #2979FF;
	border-color: #2979FF;
}
.cta.white {
	color: #fff;
	border-color: #fff;
}
.cta.dark {
	color: #000;
	border-color: #000;
}


/* .cta.blue:hover {
	color: #fff;
	border-color: #2979FF;
	background-color: #2979FF;
} */


.cta:hover {
	color: #000;
	border-color: #000;
}
.cta.dark:hover {
	color: #fff;
	border-color: #fff;
}

p .cta {
	display: inline-block;
	margin-top: 90px;
}

.clients {
	padding: 11.2em 0 5.6em;
}

.client-list .grid {
	text-align: center;
}

.client-list ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.client-list .item {
    display: inline-block;
    width: 19%;
    text-align: center;
    max-width: 260px;
    margin: 0 3% 7.1vw;
}

.page-end {
	text-align: center;
	font-size: 2em;
	padding: 10.4vw 0;
}

.page-end .robin {
	height: 56px;
	padding: 0;
	width: 42px;
	margin-bottom: 1em;
}

.about-page a {
	color: #2979FF;
	transition: color 300ms;
}

.page-end a {
	display: inline-block;
	line-height: 1em;
	text-decoration: none;
	transition: color 300ms;
}
.page-end a:hover {
	color: #000;
}

.about-page .page-footer .image {
	height: 0;
	padding-bottom: 58.3%;
}

.scroll-arrow {
	width: 23px;
	height: 31px;
	position: relative;
	margin: 3vw auto 0;
	z-index: 1;
	left: 0;
	right: 0;
	top: auto;
	cursor: pointer;
}

.scroll-arrow path {
	transition: stroke 300ms;
}

.about-page .scroll-arrow path {
	stroke: #2979ff;
}


/* ================================================================ the work */
.the-work-page .scroll-arrow path {
	stroke: #F73736;
}


.the-work-list {
	max-width: 1920px;
}

.work-teasers {
	margin: 0;
	padding: 0;
}

.work-teaser {
	margin: 0 0 3.5vw;
	display: inline-block;
	width: 50%;
	vertical-align: top;
}

.work-item {
	text-decoration: none;
}

.work-teaser .thumbnail {
	height: 0;
	padding-bottom: 56.2%;
	background: #f5f5f5;
}

.work-teaser .content {
	padding: 1.5em 10% 0;
}

.work-teaser p.book,
.date {
	font-size: 16px;
	margin-bottom: .2em;
}
.work-teaser h2,
.news-teaser h2 {
	font-size: 36px;
}

.work-item h2,
.work-item p {
	color: #000;
	transition: color 300ms;
}

.work-item p.book,
.news-item .date {
	margin-bottom: .2em;
}

.work-item:hover h2,
.work-item:hover p {
	color: #F73736;
}

.work-block01 {
	overflow: hidden;
}
.work-block01 .text-width {
    width: 59%;
    padding-bottom: 22vw;
}

.work-block01 .block-image {
	transform: translateY(0);
	padding-bottom: 47.2%;
	width: 26.5%;
}

.work-block01 .cta {
    position: absolute;
	right: 25%;
	left: auto;
	height: auto;
}


.the-work-page .page-end .robin path {
	fill: #F73736;
}

.the-work-page a {
	color: #F73736;
	transition: color 300ms;
}
.the-work-page .page-footer .image {
	height: 0;
	padding-bottom: 58.3%;
}

.the-work-page .end-link {
	display: none;
}

.load-more-items {
    padding: 0;
    margin: 0;
}

/* ================================================================ casestudy */
.the-work-single-page {
	padding-top: 0;
}

.the-work-single-page .key-visual {
	margin-bottom: 4vw;
}
.work-block {
	margin-bottom: 11.2vw;
}

.no-bottom-margin {
	margin-bottom:  0;
	overflow-y: hidden;
}

.the-work-single-page .key-visual .image {
	z-index: 0;
}

.dark-overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	background: rgba(0,0,0,.3);
	z-index: 1;
}

.the-work-single-page .key-visual .image,
.dark-overlay {
	padding-bottom: 56.2%;
	height: 0;
}


.the-work-single-page .key-visual h1 {
	position: absolute;
	top: 21.5vw;;
	font-size: 4.8vw;
	color: #fff;
	margin: auto;
	width: 65%;
	left: 0;
	right: 0;
	z-index: 2;
	text-align: center;
	transition:  color 300ms;
}

.the-work-single-page .key-visual h1.white {
	color: #fff !important;
}

.info-block {
	width: 50%;
	margin: 0 auto 11.2vw;
}
.info {
    color: #000;
    display: inline-block;
    width: 50%;
    vertical-align: top;
}
.info p {
	margin: 0;
	font-size: 1.9vw;
	line-height: 1em;
}
.info .subheader {
	font-size: 0.8em;
	line-height: 2em;
}

.work-block {

}

.text-block {
	width: 31%;
	margin-left: 25%;
}

.text-block h2,
.text-img-block h2 {
	font-family: "LL Circular Black Web", "Helvetica", Arial;
	font-size: 1em;
	text-transform: uppercase;
	margin: 2em 0 0.5em;
	font-weight: 100;
}
.text-block .tagline {
	font-size: 3.7vw;
	text-align: left;
	margin: 0;
	width: 70%;
}

.no-bottom-margin .text-block,
.no-bottom-margin .quote-block {
    padding-bottom: 11.2vw;
    padding-top: 11.2vw;
}

.left-aligned .text-block {
	
}
.center-aligned {

}

.text-block p {
}


.text-img-block {
	width: 75%;
}
.text-img {
	margin-left: 25%;
}
.img-text {
	margin-right: 25%;
}

.text-img  .left-column {
	width: 40%;
}
.text-img .right-column {
	width: 60%;
}
.img-txt  .left-column {
	width: 60%;
}
.img-txt .right-column {
	width: 40%;
}
.text-img-block .text-column {
	width: 100%;
}
.text-img-block .image-column .image {
	width: 80%;
	height: auto;
	padding-bottom: 0;
}

.text-img-block .image img {
	position: relative;
}

.image-block .image {
	display: block;
}
.image-block .image img {
	position: relative;
}

.one-centered .image {
	width: 56.25%;
	margin-left: auto;
	margin-right: auto;
} 

.two-in-row {
	width: 56.25%;
	margin-left: auto;
	margin-right: auto;
}
.two-in-row .column {
	display: inline-block;
	margin: 0 1%;
	width: 48%;
}

.two-in-row .left-column {

}
.two-in-row .right-column {

}

.quote-block {
	margin-left: 25%;
	width: 44%;
}
.quote-block.center-aligned {
    text-align: center;
    margin-left: auto;
	margin-right: auto;
}

.quote {
	color: #BCBDC1;
	font-size: 2em;
	line-height: 1em;
	margin-bottom: 1em;
}

.quoted {
	font-size: 1.34em;
}


.play-button {
	cursor: pointer;
	position: absolute;
	top: 0;
	left: 0;
}

.embedded-video  {
	background: #fff;
	margin-bottom: 2vw;
}
.embedded-video  .play-button {
	position: absolute;
	width: 100%;
	height: 100%;
	transition: background 300ms;
	/* background: rgba(247,55,54,0); */
	background: rgba(0,0,0,0);
}
.embedded-video:hover .play-button {
	/* background: rgba(247,55,54,1); */
	background: rgba(0,0,0,.2);
}
.embedded-video:hover circle {
	transition: all 300ms;
}
.embedded-video:hover circle {
	fill: #DE3131;
}

.teaser img,
.embedded-video img,
.embedded-video g {
	transform-origin: center center;
	transform: scale(1, 1);
	transition: 300ms;
}
.teaser:hover img,
.embedded-video:hover img {
	transform: scale(1.1);
}

.embedded-video iframe {
	border: 0 none;
	position: absolute;
	top: 0;
	left: 0;
}

.the-work-single-page .page-end {
	padding-top: 0;
}



.next-previous {
	text-align: center;
	margin-bottom: 11.2vw;
}

.next-previous .link {
	display: inline-block;
	vertical-align: top;
	width: 26%;
}
.next-previous .return {
	margin: 0 18%;
	width: 11%;
}

.next-previous .previous p {
	text-align: right;
}
.next-previous .return p {
	text-align: center;
}
.next-previous .next {
	text-align: left;
}

.next-previous a {
	text-decoration: none;
	transition: color 300ms;
}
.next-previous a:hover {
	color: #000 !important;
}

.next-previous .previous a,
.next-previous .next a {
	width: 90%;
	display: block;
}
.next-previous .previous a {
	margin-left: 10%;
}

.next-previous .subheader {
	font-size: 1vw;
	margin: auto;
	text-transform: uppercase;
}

.next-previous .title {
	font-size: 3vw;
}

.the-work-single-page .page-footer .image {
	height: 0;
	padding-bottom: 59.1%;
}


/* ================================================================ the news */
.news-page .scroll-arrow path {
	stroke: #00C853;
}

.the-news-list {
	max-width: 1720px;
}

.news-teasers {
	margin: 0;
	padding: 0;
}

.news-teaser {
	margin: 0 20px 200px;
	display: inline-block;
	width: calc(50% - 40px);
	vertical-align: top;
}

.news-item {
	text-decoration: none;
}

.news-teaser .thumbnail {
	height: 0;
	padding-bottom: 56.2%;
	background: #f5f5f5;
}

.news-teaser .content {
	padding: 3.3em 5vw 0;
}

.news-teaser .date {
	font-size: 16px;
}

.news-item h2,
.news-item p {
	color: #000;
	transition: color 300ms;
}

.news-item:hover h2,
.news-item:hover p {
	color: #00C853;
}


.pagination {
	text-align: center;
	font-size: 2em;
	margin-bottom: 5.6em;
}

.pagination a {
	color: #000;
	text-decoration: none;
	margin: 0 0.1em;
	padding: 0 0.4em 0.5em;
	text-align: center;
	border-bottom: 0.3em solid #fff;
	transition: color 300ms, border-color 300ms;
}

.pagination .pagination-arrow {
    padding: 0;
    width: 1em;
    display: inline-block;
    height: 0.8em;
    vertical-align: middle;
    border: none;
}
.news-page .pagination .previous-arrow {
    margin-left: 0;
}
.news-page .pagination .next-arrow {
    margin-right: 0;
}
.pagination .pagination-arrow svg {
	position: relative;
	height: 100%;
	width: 100%;
}
.pagination .pagination-arrow path {
	stroke: #000;
	transition: stroke 300ms;
}
.pagination .pagination-arrow:hover path {
	stroke: #00C853;
}

.pagination-arrow {
	visibility: hidden;
}
.pagination-arrow.enabled {
	visibility: visible;
}

.news-page .pagination a:hover,
.news-page .pagination a.active {
	color: #00C853;
	border-color: #00C853;
}

.news-page .page-footer .image {
	height: 0;
	padding-bottom: 58.9%;
}

.news-page iframe {
	height: 46.3vh;
	width: 100%;
}



.wp-video {
	width: 100% !important;
	margin-bottom: 1em;
}
.wp-video video {
	width: 100%;
	height: 100%;
}

/* ================================================================ news article */
.news-article {
	padding-top: 12vw;
}

.news-article h1.title {
	font-size: 5vw;
	color: #000;
	text-align: left;
}

.news-image .image {
	height: 0;
	padding-bottom: 56.3%;
	margin-bottom: 11.2vw;
	background: #f5f5f5;
}

.news-article .text-width {
    max-width: 820px;
    width: 80%;
}

.news-article img {
	position: relative;
    width: 100%;
    height: auto;
}

.news p img {
    width: 100%;
    height: auto;
}
.news p img.half-width {
    width: 47%;
    height: auto;
    margin: 1%;
    float: none;
}

.news-article .page-end .robin path {
	fill: #000;
}

.news-buttons {
	text-align: center;
	font-size: 24px;
	margin-bottom: 8.3em;
}

.news-buttons a {
	color: #000;
	text-decoration: none;
	transition: color 300ms;
	display: inline-block;
}
.return {
	width: 6em;
}

.news-buttons a:hover {
	color: #F73736;
}


.about-article .news-image .image {
	width: 260px;
	padding-bottom: 245px;
	margin-bottom: 7.7vw; 
}

.about-article h1.title {
	color: #2979FF;
	max-width: 700px;
	margin: 0 auto 2.5vw;
	width: 80%;
	text-align: center;
}
.about-article .header-block {
    margin-bottom: 5.5vw;
}

.about-article .intro-block {
    margin-bottom: 7.7vw;
}

.about-article .subheader {
	font-size: 24px;
	margin: auto;
}

.about-article .page-end .robin path {
	fill: #2979FF;
}

.about-article h2 {
	margin: 0 auto;
	line-height: 1.3em;
	font-size: 24px;
	font-family: "LL Circular Black Web", "Helvetica", Arial;
}

.about-article a {
	color: #2979FF;
	text-decoration: none;
}
.about-article a:hover {
	color: #F73736;
}

.about-buttons a {
	color: #2979FF;
}

/* ================================================================ people */
.dark a {
	color: #F73736;
}

.dark .scroll-arrow:hover path {
	stroke: #F73736;
}

.people-page .text-section {

}

.people-page section {
	margin-bottom: 5.55em;
}

.people-page .colour-block {
	margin-bottom: 0;
}

.two-columns {
	position: relative;
}

.two-columns .column {
	display: inline-block;
	box-sizing: border-box;
	vertical-align: top;
}

.text-column {
    box-sizing: border-box;
    vertical-align: top;
    width: 35%;
}

.column-one.text-column {
    margin-left: 15%;
    padding-right: 5%;
}

.column-two.text-column {
    padding-left: 5%
}

.image-column .image,
.full {
	height: 0;
	padding-bottom: 56.3%;
}

.people-page .full {
    padding-bottom: 50%;
}

.two-columns h2 {
	margin-top: 0;
}

.centered {
	max-width: 820px;
	width: 80%;
	margin: 0 auto;
}
.centered.image {
	height: auto;
	padding-bottom: 0;
}
.centered.image img {
	position: relative;
}

.people-page .narrow .image {
	padding-bottom: 34%;
}

.the-people-list h2 {
	margin-top: 1em;
}
.the-people-list ul {
    padding: 0;
}

.the-people-list .item {
    display: inline-block;
    width: 20%;
    position: relative;
    vertical-align: top;
}

.client {
    width: 100%;
}

.the-people-list .hoverstate {
	width: 80%;
	height: 100%;
	padding: .5em 0 0;
	position: relative;
	z-index: 2;
	box-sizing: border-box;
	opacity: 0;
	transition: opacity 300ms;
}


.the-people-list .hero:hover  .hoverstate {
	opacity: 1;
}

.robin {
	height: 0;
	padding-bottom: 67%;
	position: relative;
	top: 0;
	left: 0;
	width: 74%;
	margin: auto;
}

.the-people-list .robin {
	background: #fff;
	margin: 0;
}

.hero .title,
.hero .subtitle,
.hero .location-name {
    font-size: 16px;
    margin: 0 0 0.5em;
    line-height: 1.3em;
}
.hero.ams .title,
.hero.ams .subtitle,
.hero.ams .location-name {
	color: #F73736;
}
.hero.nyc .title,
.hero.nyc .subtitle,
.hero.nyc .location-name {
	color: #2979FF;
}

.hero .title {
    font-size: 0.9em;
    text-transform: uppercase;
}
.hero .subtitle,
.hero .location-name {
    font-size: 0.78em;
}
.hero .location-name {
    margin-bottom: 1.4em;
}

.envelope {
	display: inline-block;
	height: auto;
}
.envelope .image {
	height: 31px;
	width: 40px;
	margin: 0;
}

.envelope:hover {
	background: none;
}

.envelope path {
	stroke: #fff;
	transition: stroke 300ms;
}
.envelope rect {
	transition: fill 300ms;
}

.ams .envelope rect {
	fill: #F73736;
}
.ams .envelope:hover path {
	stroke: #F73736;
}

.nyc .envelope rect {
	fill: #2979FF;
}
.nyc .envelope:hover path {
	stroke: #2979FF;
}

.ams .envelope:hover rect,
.nyc .envelope:hover rect {
	fill: #fff;
}

.eyes {
    position: absolute;
    z-index: 1;
    width: 24.8%;
    height: 0;
    padding-bottom: 8.9%;
    left: 24%;
	top: 45%;
}
.eye {
    width: 33%;
    height: 90%;
    position: absolute;
    border-radius: 1em;
    background: #fff;
    overflow: hidden;
}

.right-eye {
	right: 0;
}

.pupil {
	width: 75%;
	height: 75%;
	background-color: black;
	border-radius: 1em;
	left: 0;
	right: 0;
	margin: 0 auto;
}

.people-block01 .block-image {
    padding-bottom: 48.7%;
    transform: translateY(-4%);
    width: 26.3%;
}

.people-block01 h2 {
	width: 85%;
}

.contact-block {
	padding-top: 11.2em;
}


.column.address-column {
	margin: 0;
    width: 50%;
    padding-right: 0;
    padding-left: 10.4%;
    padding-bottom: 11.2vw;
    padding-top: 11.2vw;
}


.address-block h2.black {
    font-size: 2em;
}

.address-block a {
	color: #fff;
	text-decoration: none;
}

.address-block a:hover {
	color: #000;
}

.external-link .text {
	text-transform: uppercase;
	padding-bottom: 1em;
	border-bottom:  8px solid #fff;
	display: inline-block;
	margin-right: 1em;
	transition: color 300ms, border-color 300ms;
}
.external-link .arrow {
	height: 16px;
	width: 16px;
	z-index: 3; 
	display: inline-block;
	transform: translateX(0) translateY(0);
	transition: all 300ms;
}
.external-link:hover .arrow {
	transform: translateX(5px) translateY(-5px);
}

.external-link .arrow path,
.external-link .arrow line {
	stroke: #fff;
	transition: stroke 300ms;
}

.external-link:hover .text {
	color: #000;
	border-color: #000;
}
.external-link:hover .arrow path,
.external-link:hover .arrow line {
	stroke: #000;
}

.address-block .address {
	margin-top: 11.2vw;
	font-size: 16px;
}

.address-block .location {
	text-transform: uppercase;
}

.follow-us {
	position: absolute;
	top: 0;
	bottom: 0;
	margin-bottom: 0;
}

.social-links {
	height: 64px;
}

.social-links a {
	display: inline-block;
	width: 64px;
	top: 250px;
	margin: 0 1vw;
}

.social-links a path,
.social-links a circle {
	transition: fill 300ms;
}

.social-links a:hover path,
.social-links a:hover circle {
	fill: #F73736;
}

.social-links .first {
	margin-left: 0;
}
.social-links .last {
	margin-right: 0;
}


/* ================================================================ attention academy */
.attention-academy {

}

/* .attention-academy h1.title {
	transform: translateX(-7%);
	white-space: nowrap;
} */

.aa-logo-yellow {
    width: 7vw;
    height: 7vw;
    position: absolute;
    z-index: -1;
    transform: translateX(-9vw);
}

.attention-academy .scroll-arrow:hover path {
	stroke: #FFF000;
}

.aa-logo {
	width: 83px;
	height: 0;
	padding-bottom: 3.6%;
	left: 0;
	margin: 0 0 3vw;
}

.attention-academy-block01 .block-content {
    padding-top: 8vw;
}

.attention-academy-block01 .block-content .inner {
    margin-left: 0;
	width: 85%;
}

.attention-academy-block01 .text-width {
    width: 54%;
}

.attention-academy-block01 ol {
    padding-left: 1.3em;
}

.attention-academy-block01 .block-image {
	padding-bottom: 61.6%;
	transform: translateY(-4%);
	width: 31%;
	max-width: 650px;
}

.attention-academy .page-footer .image {
	height: 0;
	padding-bottom: 60.6%;
}


.aa-list {
	max-width: 1490px;
}

.aa-teasers {
	margin: 0;
	padding: 11.2vw 0 0 0;
}

.aa-teaser {
	margin: 0 0 11.2vw;
	display: block;
	width: 100%;
	vertical-align: top;
}

.aa-teaser .date{
	font-size: 0.9em;
}

.aa-item {
	text-decoration: none;
}
.dark .aa-item {
    color: #000;
	text-decoration: none;
	transition: color 300ms;
}
.aa-item:hover p,
.aa-item:hover h2,
.dark .aa-item:hover {
	color: #fff000;
}

.aa-item .column-one {
	width: 55%;
}

.aa-item .column-two {
	width: 45%;
	padding: 0 0 0 6.2vw;
}

.aa-item .thumbnail {
    height: 0;
    padding-bottom: 50%;
    background: #F5F5F5;
}

.aa-item h2 {
	font-size: 36px;
	text-transform: none;
}


/* .aa-item:hover .dark {
	color: #FFF000;
} */


.filter-list {
	margin: 0;
	padding: 10.4vw 0 0;
	text-align: center;
}
.filter-list li {
	display: inline-block;
	margin: 0 0.5em;
}


.tag {
    border: 2px solid;
    display: inline-block;
    padding: 0.3em 2em;
    border-radius: 2em;
	color: #000;
	text-decoration: none;
}

.attention-academy .tag {
	background-color: #fff000;
	border-color: #fff000;
	color: #000;
	margin-right: 1em;
	transition: color 300ms, border-color 300ms, background-color 300ms;
}
.attention-academy .aa-teasers .tag {
	background-color: #fff;
	pointer-events: none;
}
.attention-academy .tag:hover {
	border-color: #000;
	background-color: #000;
	color: #fff000;
}

.attention-academy .pagination a:hover,
.attention-academy .pagination a.active {
	color: #fff000;
	border-color: #fff000;
}

/* ================================================================ careers */
.careers .page-footer .image,
.privacy-page .page-footer .image {
	height: 0;
	padding-bottom: 60.6%;
}

.job .column-one {
	padding: 5.2vw 0 5.2vw 14.5vw;
}

.job .column-one h2 {
	font-size: 3.8vw;
	margin: 0;
	word-spacing: 21vw;
}

.job .column-one p {
	font-size: 1.3vw;
}
.job .column-two h2 {
	font-size: 1.4em;
}
.job .column-one p {
	text-transform: uppercase;
}

.job .column-two {
	padding: 5.2vw 14.5vw 5.2vw 0;
}

.page-end.dark .robin path {
	fill: #BCBDC1;
}

.careers .cta {
	color: #fff;
	border-color: #fff;
}
.careers .cta:hover {
	color: #000;
	border-color: #000;
}

.page-end.dark a {
	color: #BCBDC1;
	transition: color 300ms;
}
.careers .page-end.dark a {
	color: #000;
}

.page-end.dark  a:hover {
	color: #F73736;
}

.careers .cta {
	margin-top: 3.6em;
}

.background-yellow .cta,
.background-grey .cta {
	color: #000;
	border-color: #000;
}
.background-yellow .cta:hover,
.background-grey .cta:hover,
.background-black .cta:hover {
	color: #F73736;
	border-color: #F73736;
}

.about-page .background-grey .cta {
	color: #2979FF;
	border-color: #2979FF;
}
.about-page .background-grey .cta:hover {
	color: #000;
	border-color: #000;
}


/* ================================================================ privacy policy */
/* .privacy-page h1.title {
	transform: translateX(-7%);
	white-space: nowrap;
} */


/* ================================================================ misc */
.scroll-arrow:hover path {
	stroke: #000;
}


/* ================================================================ list grid *
.grid {
	overflow: hidden;
	padding: 0;
	margin: 0 auto 20px auto;
	list-style: none;
}
 .grid .item {
	padding: 0;
	position: relative;
	overflow: hidden;
}

/* 
@media all and (min-width: 500px) {
	.grid .item {
		float: left;
		width: 100%;
	}
} *
@media all and (min-width: 60em) {
	.grid .item {
		width: 50%;
	}
}

@supports(display: flex) {
	@media all and (min-width: 500px) {
		.grid {
			display: flex;
			flex-wrap: wrap;
		}
		.grid .item {
			display: flex;
			flex-direction: column;
		}
		.grid .item > * {
			flex: 1;
	    }
	}
}
/* for grid *
@supports(display: grid) {
	@media all and (min-width: 500px) {
		.grid {
			display: grid;
			grid-gap: 2em;
		}
		.two-column-grid .grid {
			grid-template-columns: repeat(1, 1fr);
		}
		.five-column-grid .grid {
			grid-template-columns: repeat(2, 1fr);
		}
		.six-column-grid .grid {
			grid-template-columns: repeat(3, 1fr);
		}
		.client-list .grid {
			grid-template-columns: repeat(4, 1fr);
		}
		.grid .item {
			padding: 0;
			display: block;
			float: none;
			width: auto;
		}
	}
	@media all and (min-width: 50em) {
		.two-column-grid .grid {
			grid-template-columns: repeat(2, 1fr);
		}
		.five-column-grid .grid {
			grid-template-columns: repeat(5, 1fr);
		}
		.six-column-grid .grid {
			grid-template-columns: repeat(6, 1fr);
		}
		.grid .item {
			width: auto;
		}
	}
	/* force the client list to use 3 columns on mobile *
	@media all and (max-width: 500px) {
		.client-list .grid {
			display: grid;
			grid-gap: 2em;
			grid-template-columns: repeat(3, 1fr);
		}
	}
}



/* ================================================================ 404 */
.error-page {
    padding: 14vw 0;
    text-align: center;
}
.error-page h2 {
	text-align: center;
	font-size: 24px;
	text-transform: uppercase;
	margin-bottom: .5em;
}

.four-oh-four {
    height: 0;
    padding-bottom: 19%;
    width: 32%;
}

.background-yellow .four-oh-four path {
	fill: #000000;
}

/* ================================================================ footer */
.footer {
	font-size: .9em;
	background: #F5F5F5;
	padding: 10.4vw 0;
}

.footer-inner {
	margin-left: 23%;
}

.no-footer .footer {
	display: none;
}


input {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

#mc_embed_signup {
    background: #F5F5F5 !important;
}

#mc_embed_signup form {
    text-align: left !important;
    padding: 0 !important;
    margin: 0 0 8em;
}
/*
#mc_embed_signup label {
font-size: 24px !important;
}
*/
#mc_embed_signup input.email {
    height: auto !important;
    font-size: 1em !important;
    max-width: 400px !important;
    padding: 0.9em 1em !important;
    height: auto !important;
    font-size: 16px !important;
    width: 100% !important;
    border-radius: 0 !important;
    margin: 0 .7em 1em 0 !important;
    border: 1px solid #000 !important;
}

#mc_embed_signup .button {
    font-family: "LL Circular Book Web", "Helvetica", Arial;
    text-transform: uppercase !important;
    background: none !important;
    border: 1px solid #000 !important;
    border-radius: 0 !important;
    font-weight: bold !important;
    color: #000 !important;
    padding: 0.65em 0 !important;
    font-size: 1em !important;
    width: 200px !important;
    height: auto !important;
}
#mc_embed_signup .button:hover {
    background-color: #000 !important;
    color: #fff !important;
}



.footer-logo {
    width: 161px;
    height: 19.3px;
    position: relative;
    display: block;
}
.footer-logo .image {
	height: 100%;
}
.footer-logo path {
	fill: #F73736;
}

.footer-logo,
.footer .description {
	margin: 0 0 2.8em;
}

.footer .description {
	max-width: 500px;
	width: 80%;
}

.footer a {
	color: #000;
	text-decoration: none;
}

.footer .offices {
	margin-bottom: 2.8em;
}
.footer .office {
	display: inline-block;
	margin: 0;
	width: 28%;
}
.footer .first {
	margin-left: 0;
}
.footer .last {
	margin-right: 0;
}

.footer .office-name {
	font-size: 24px;
}

.footer a {
	transition: color 300ms;
}
.footer a:hover {
	color: #F73736;
}

.footer .title {
	
}
.footer .address {
	margin-bottom: 0;
}

.social-media-container {
	margin-bottom: 1em;
}
.social-media {
	height: 22px;
	display: block;
}
.social-media a {
	width: 22px;
	height: 22px;
	display: inline-block;
	margin: 0 0.4em;
}

.social-media a path,
.social-media a circle {
	transition: fill 300ms;
}
.social-media a:hover path,
.social-media a:hover circle {
	fill: #F73736;
}

.footer .colours {
	height: 1.3em;
	bottom: 0;
	position: absolute;
	width: 100%;
	left: 0;
	margin: 0;
}


.footer .panel {
	vertical-align: bottom;
}

/* ================================================================ contact-page */





/* ================================================================ smooth scroll */
[data-scrollbar] {
    display: block;
    overflow: hidden;
    position: relative;
}

#main-scrollbar {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
}

.scroll-content {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
}

.scrollbar-track {
    position: absolute;
    opacity: 0;
    z-index: 1;
    background: rgba(222, 222, 222, .75);
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-transition: opacity 0.5s 0.5s ease-out;
    transition: opacity 0.5s 0.5s ease-out;
}

.scrollbar-track-x {
    bottom: 0;
    left: 0;
    width: 100%;
    height: 8px;
}

.scrollbar-track-y {
    top: 0;
    right: 0;
    width: 8px;
    height: 100%;
}

.scrollbar-thumb {
}

.scroll-animation {
    position: relative;
}
.scroll-animation .content {
    position: relative;
    transform: translate3d(0, 0, 0);
    overflow: hidden;
    width:  100%;
}

.viewport {
    position: relative;
    display: block;
    overflow: hidden;
}
.viewport .content {
    position: absolute;
    height: 100%;
    width: 100%;
}



.hide-on-desktop {
	display: none;
}
.hide-on-mobile {
	display: block;
}
.do-not-show {
	display: none;
}

.pagination .hide-on-mobile {
	display: inline-block;
}
.pagination .do-not-show {
	display: none;
}

/* ================================================================ mobile */
@media only screen and (max-height: 650px) {
	.sub-menu {
		position: relative;
		bottom: 0;
	}
}
@media only screen and (min-width: 1920px) {
	.slogan h1,
	.slogan h2 {
		font-size: 124px;
	}
}
@media only screen and (max-width: 1900px) {
	.main-menu {
		font-size: 3.7vw;
	}
	.sub-menu {
		font-size: 1.25vw;
	}
}

@media only screen and (max-width: 1580px) { 
	.footer-inner {
	    margin-left: 15%;
	}
	.footer .office {
		width: 30%;
	}
}

@media only screen and (max-width: 1300px) { 
	.sub-menu {
		font-size: 18px;
	}
	.attention-academy .aa-teasers .tag {
	    position: absolute;
	    right: 0;
	}
	.aa-item .column-one {
	    width: 40%;
	}
	.aa-item .column-two {
	    padding-left: 5%;
	    width: 55%;
	}
	.aa-item .column {
	    margin-left: 0;
	}
	.footer-inner {
	    margin-left: 10%;
	}
}

@media only screen and (max-width: 1280px) {
	.main-menu {
	    font-size: 44px;
	}
	.menus li a {
		margin-bottom: 0.4em;
		line-height: 1em;
	}
	.sub-menu {
	    font-size: 24px;
	}
}

@media only screen and (max-width: 1200px) {
	.aa-logo {
		width: 14%;
		padding-bottom: 6.5%;
	}
	.column.address-column {
		padding-left: 5.2%;
	}
	.social-links a {
	    width: 14%;
	}
}


@media only screen and (max-width: 1100px) { 
	body {
		font-size: 16px;
	}
	.intro {
		width: 40%;
	}
	.info p {
	    font-size: 1.4em;
	}
	.block-content {
			margin-left: 13%;
	}
	.block-content p {
		width: 65%;
		margin-left: 30%;
	}
	.the-people-list .item {
		width: 25%;
	}
	.next-previous .subheader {
		font-size: .9em;
	}
}

@media only screen and (max-width: 980px) { 
	.footer .office {
	    width: 45%;
	    margin-bottom: 2.8em;
	}
	.footer .office.last {
	    display: block;
	}
}

@media only screen and (max-width: 880px) { 
	section, 
	.full-width,
	.work-teaser,
	.news-teaser {
		display: block;
		width: 100%;
	} 
	.intro,
	.column,
	.full-width .inner,
	.colour-block .text-width,
	.text-block,
	.info-block,
	.mute-container,
	.clients h2.black,
	.news-teaser .content,
	.news-article .text-width,
	.aa-item .column-two,
	.the-people-list,
	.footer-inner {
		width: 86%;
		margin-left: 7%;
		max-width: 86%;
	}
	.menubar,
	.slogan h1,
	.slogan h2,
	.text-width,
	.client-list .grid,
	.the-work-single-page .key-visual h1,
	.quote-block {
		width: 86%;
	}
	h1.title,
	.main-menu ul,
	.sub-menu ul {
		margin-left: 7%;
	}

	.menubar {
	    padding: 48px 0;
	}
	.sh-logo {
	    height: 13px;
		margin-top: 2px;
	    width: 109px;
	}
	.menu-button {
	    width: 26px;
	    height: 18px;
	}
	.main-menu {
	    margin-top: 18vh;
	    margin-bottom: 5vh;
	    font-size: 36px;
	}
	.aa-menu-logo {
		width: 7.4vw;
		right: -6.1vw;
	}
	.sub-menu {
		position: relative;
		bottom: auto;
	}
	.sub-menu li {
		margin-bottom: 0.5em;
	}
	.slogan h1.title,
	.slogan h2.title {
		font-size: 8vw;
		margin: 0 0 0 7%;
		left: 0;
		width: auto;
		transform: translateX(0) translateY(0%);
		top: 20vh;
	}
	.slogan h1 span,
	.slogan h2 span {
		display: block;
	}
	.slogan h1 br {
		display: none;
	}

	.mute-container {
		height: 85px;
	}
	.mute {
		bottom: 48px;
	}
	
	h1.title {
		font-size: 13vw;
		width: 0;
		text-align: left;
	}
	.always-fill {
		background-image: url(../media/images/home/we-are-on-a-mission-mobile.svg);
	}
	.scroll-arrow {
		pointer-events: none;
		visibility: hidden;
	}
	.scrollbar-track {
		display: none !important;
	}
	.colour-block {
	    padding-bottom: 22vw;
	}
	.colour-block .text-width {
	    padding-top: 50%;
	}
	.colour-block h2 {
		width: 70%;
	}
	.colour-block .block-image {
		padding-bottom: 77%;
		transform: translateY(-21%);
		width: 100%;
		max-width: 100%;
	}
	.colour-block .text-width span {
		display: block;
	}
	.about-page .header-block {
		margin-bottom: 22vw;
	}
	.about-block02 {
		padding-bottom: 18vw;
		margin-top: 7vw;
	}
	.about-article .news-image .image {
		width: 180px;
		padding-bottom: 167px;
		margin-bottom: 7.7vw; 
	}
	.about-article .subheader,
	.about-article h2 {
		font-size: 18px;
		line-height: 1.3em;
		margin-bottom: .2em; 
	}
	.block-content .inner,
	.block-content p {
	    width: 100%;
	    margin-left: 0%;
	    margin-bottom: 0;
	}
	.block-content p {
		margin-bottom: 1.3em;
	}
	.text-section .column-two.text-column {
		padding: 0;
	}
	.superpower .full-width {
		padding: 18vw 0 22vw;
	}
	.superpower h2 {
		width: 50%;
	}
	.superpower .image {
		margin: 0 auto 17.2vw;
	}
	.cta {
		width: 200px;
		padding: 1em 0;
		text-align: center;
	}
	p .cta {
	    margin-top: 4em;
	}
	.work-block01 .cta {
		position: relative;
		right: 0;
		margin-bottom: 3em;
	}
	.the-work-single-page .key-visual h1 {
	    font-size: 64px
	}
	.the-work-page .page-footer .image {
	    padding-bottom: 93.5%;
	}

	.colour-block .cta {
	    width: 90%;
	    margin-left: 5%;
	}
	.text-block .tagline {
		font-size: 32px;
	}
	.next-previous .subheader {
		font-size: 1em;
	}
	.text-img-block {
		width: 100%;
		margin-left: auto;
		margin-right: auto;
	}
	.text-img-block .column {
	    width: 50%;
	    margin-left: auto;
	    margin-right: auto;
	    display: block;
	}
	.text-img-block .text-column,
	.text-img-block .image {
	    width: 100%;
	}
	.two-in-row {
		width: 100%;
	}
	.two-in-row .column {
	    display: block;
	    margin: 0 0 1.5em;
	    width: 100%;
	    max-width: 100%;
	}
	.one-centered .image {
		width: 100%;
		margin-bottom: 1.5em;
	}
	.quote-block {
	    margin-left: 7%;
	}
	.quote {
		font-size: 32px;
	}
	.quoted {
		font-size: 1em;
	}
	.next-previous .title {
		font-size: 24px;
	}
	.next-previous .return {
	    margin: 0 7%;
	    width: 15%;
	    text-align: center;
	}
	.social-media {
		height: 45px;
	}
	.social-media a {
	    width: 45px;
	    height: 45px;
	}
	.clients {
	    padding: 18.8vw 0 0;
	}
	.aa-logo-yellow {
	    transform: translateX(0);
	    position: relative;
	    transform: translateX(0);
		margin: 0 0 2em;
	}
	.aa-logo {
		display: none;
	}
	.colour-block ol {
		padding-left: 1.4em;
	}
	.colour-block .text-width li br {
	    display: none;
	}
	.work-teaser h2,
	.news-teaser h2,
	.aa-teaser h2.black {
		font-size: 32px;
	}
	.work-teaser,
	.news-teaser,
	.aa-teaser {
		margin: 0 0 11.2vw;
	}
	.news-teaser .content {
	    padding: 1em 0 0;
	}
	.news-article {
		padding-top: 8em;
	}
	.news-article h1.title {
	    font-size: 32px;
	    width: 100%;
		margin: 0 0 0.56em;
	}
	.attention-academy h1.title,
	.privacy-page h1.title {
	    transform: translateX(0);
	    white-space: normal;
	}
	.filter-list li {
		display: block;
		margin: 0 auto 1em;
	}
	.aa-item .column {
	    display: block;
	}
	.aa-item .column-one {
	    margin: 0;
	    width: 100%;
	    max-width: 100%;
	}
	.aa-item .column-two {
	    padding: 1.5em 0 0;
	}
	.attention-academy .aa-teasers .tag {
	    position: relative;
	    right: auto;
	    top: 0;
	    margin-top: 0;
	}
	.aa-teaser .date {
		margin-bottom: .2em;
	}
	.job .column-one {
    	padding: 9vw 0 0;
    }
	.job .column-two {
	    padding: 0 0 9vw;
	}
	.job .column-one h2 {
    	font-size: 36px;
    	word-spacing: normal;
	}
	.job .column-one p,
	.job .column-two h2 {
		font-size: 1.1em;
	}
	.column-two.text-column {
		padding-left: 0;
		margin-bottom: 3vw;
	}
	.people-page .image-column,
	.people-page .image.centered {
		display: block;
		margin: 0 0 5.5em;
		width: 100%;
		max-width: 100%;
	}
	.people-page h2 {
		font-size: 5.5vw;
		font-family: "LL Circular Black Web", "Helvetica", Arial;
	}
	.the-people-list .item {
		width: 33%;
	}
	.column.address-column {
		width: 100%;
		padding: 18.8vw 7%;
		display: block;
		position: relative;
		margin-bottom: 0;
		max-width: 100%;
	}
	.address-block .location {
	    margin-bottom: 2.3em;
	}
	.address-block h2.black {
		margin-bottom: 2em;
	}
	.tiktok-embed {
		height: 0;
		padding-bottom: 100%d
	}
	.social-links {
		margin: 22vw 0;
	}
	.page-end {
    	padding-bottom: 18.8vw;
	}
	.page-content .page-footer .image {
		height: auto;
		padding-bottom: 0;
	}
	.page-content .page-footer .image img,
	.page-content .page-footer .image svg {
		position: relative;
	}
	.page-end .robin {
	    padding-bottom: 5%;
		width: 4%;
		height: 0;
		margin-bottom: 2vw;
	}
	.page-end a {
		font-size: 3.7vw;
	}
	.footer p {
	    line-height: 1.5em;
	}
	.footer .office-name {
		margin-bottom: 0;
	}
	.social-media-container {
		margin-top: 18.8vw;
	}
	.social-links a {
		top: 0;
	}
	.footer {
	    padding-top: 18.8vw;
	}
	.hide-on-mobile,
	.pagination .hide-on-mobile {
		display: none ;
	}
	.hide-on-desktop {
		display: block ;
	}
}

@media only screen and (max-width: 800px) { 
	.filter-list .label {
		display: block;
		margin: 0 auto 1em;
	}
	.client-list .item {
		width: 27%;
	}
}

@media only screen and (max-width: 782px) { 
	.is-home .menubar {
	    /* background: none; */
	}

	.aa-menu-item br {
		display: inline-block;
	}
	.aa-menu-logo {
		top: 1.2em;
	}
	.mobile-menu-background {
		background: #fff;
	}
	.menubar.show-menu {
		background: transparent;
	}
	.news-teaser {
		margin: 0 0 15vw;
	}
	.info-block {
	    width: 80%;
	}
	.info {
		width: 100%;
		display: block;
	}

	.text-block,
	.text-img-block .column {
	    width: 80%;
	    margin-left: 10%;
	}

	.work-teaser {
		margin: 0 0 20vw;
	}
	.work-teaser .content {
		padding-top: 1em;
	}
	.client {
		max-width: 100%;
	}

	.aa-logo-yellow {
		width: 58px;
		height: 58px;
	}
	
	.the-people-list {
	    margin-bottom: 11.2vw;
	    width: 80%;
	}
	.the-people-list .hoverstate {
		opacity: 1;
		padding: 0 1em 1em 0;
	}
	.error-page {
		padding: 23vw 0 14vw;
	}
}


@media only screen and (max-width: 680px) { 
	.people-page .colour-block h2,
	h2.black {
	    font-size: 36px;
	}
	.address-block h2.black,
	.people-page h2 {
	    font-size: 32px;
	}
}

@media only screen and (max-width: 660px) { 
	body {
		font-size: 14px;
	}
	h1.title {
		font-size: 72px;
	}
	.slogan h1.title,
	.slogan h2.title {
		font-size: 44px;
	}
	.the-work-single-page .key-visual h1 {
	    font-size: 44px;
	}
	.the-work-single-page .key-visual h1 {
	    position: relative;
	    color: #fff;    
	    top: 1em;
   		padding-bottom: 1em;
   		text-align: left;
	}
	.info-block {
	    margin: 11.2vw 10%;
	}
	.pagination {
		font-size: 1.4em;
	}
	.news-page .pagination a {
		margin: 0 0.4em;
	}
	.page-end .robin {
	    width: 23px;
	    height: 30px;
	}
	.page-end a {
		font-size: 21px;
	}
}


@media only screen and (max-width: 620px) { 
	.superpower h2 {
		width: 60%;
	}
}

@media only screen and (max-width: 600px) { 
	.sub-menu {
		font-size: 20px;
	}
	.colour-block h2 {
		width: 100%;
	}
	.footer {
	    font-size: 1em;
	}
	.footer .office {
	    display: block;
	}
	.social-media a {
		margin: 0 3vw;
	}
}

@media only screen and (max-width: 550px) { 
	.colour-block .text-width {
	    padding-top: 56%;
	}
	.superpower h2 {
		width: 80%;
	}
	.client-list .item {
		width: 44%;
	}
}

@media only screen and (max-width: 480px) { 
	.sub-menu li {
		display: block;
	}
	.slogan h1 {
	    font-size: 6.5vw;
	    margin: auto;
	    width: 80%;
	    white-space: normal;
	}
	.news-page iframe {
	    height: 200px;
	}
	.attention-academy-block01 .text-width {
	    width: 80%;
	    margin-left: 10%;
	}
	.the-people-list .item {
		width: 50%;
	}
	.column.address-column {
		padding: 11.2vw 10%;
	}
	.news p img.half-width {
	    width: 100%;
	    margin: 0 0 20px;
	}
	.footer {
	    padding: 21vw 0;
	}
}


@media only screen and (max-width: 400px) { 
	.colour-block h2.black {
		width: 95%;
	}
	.work-block01 .text-width {
		width: 60%;
	}
	.one-centered .image {
	    width: 80%;
	}
	.play-button,
	.one-centered .play-button {
		width: 100%;
	}
	.superpower h2 {
		width: 100%;
	}
	.quote-block {
	    margin-left: 15%;
	    width: 70%;
	}
	.footer {
	    padding: 27vw 0;
	}
}