/*===WEBSITE UPDATED 2020===*/

@import url('https://fonts.googleapis.com/css?family=Cormorant+Garamond:300,700|Titillium+Web:200,200i,400,400i,700|Orbitron:700&display=swap');

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

body {
    font-family: 'Titillium Web', sans-serif;
    font-size: 20px;
    line-height: 1.4;
    color: var(--color-woodsmoke);
}

:root {

    /*TEXT HOVER EFFECT HOME PAGE*/
    --maskX: 0;
    --maskY: 50;
    /*---GRID ASPECT RATIO VARIABLES---*/
    --wrapper: calc(var(--section-width) - (2 * var(--grid-margin)));
    --grid-gutter: 5px;
    --grid-margin: 1em;
    --section-width: 100vw;
    --noOfColumns: 3;
    --noOfGutters: calc(var(--noOfColumns) - 1);
    --ratioA: 1;
    --ratioB: 1;
    --factor: calc(var(--ratioB) / var(--ratioA));
    --row-height: calc(( (var(--wrapper) - (var(--noOfGutters) * var(--grid-gutter))) / var(--noOfColumns)) * var(--factor));
    /*===PRIMARY COLOURS===*/
    --color-woodsmoke:      #161B1E;
    --color-tundora:        #474747;
    --color-tory-blue:      #115293;
    --color-deep-cerulean:  #0080AC;
    --color-wedgewood:      #497894;
    --color-white:          #FFFFFF;
    /*===SECONDARY COLOURS===*/
    --color-monza:          #D30C0C;
    --color-pomegranate:    #F7410D;
    --color-sazerac:        #FFF6E5;
    --color-gallery:        #F0F0F0;
    --color-silver:         #CCCCCC;
    --color-boulder:        #767676;
    --color-apple:          #57B849;
    --color-ultramarine:    #040496;
    --color-regal-blue:     #004874;
    --color-blue-ribbon:    #0057FF;
    --color-eastern-blue:   #1B8DAA;
    --color-neptune:        #75A1B8;
    --color-jagged-ice:     #D2E8EE;
    --color-botticelli:     #CCDBE3;
}

/*=======END ROOT VARIABLES=======*/
/*=======END ROOT VARIABLES=======*/

.index #content {
    background-color: #fff;
    position: relative;
}

/*=======GRID ASPECT RATIO=======*/
/*=======GRID ASPECT RATIO=======*/

.grid-aspect-cells {
    display: grid;
    grid-template-columns: repeat(var(--noOfColumns), minmax(0, 1fr));
    grid-auto-flow: dense;
    grid-auto-rows: minmax(var(--row-height), auto);
    grid-gap: var(--grid-gutter);
    margin: 0 var(--grid-margin);
}

.splash .grid-aspect-cells {
    grid-column: 4;
    margin-top: 6em;
    margin-bottom: 5em;
}

/*---TEMP COMING SOON---*/
.square-cells {
    position: relative;
}

.square-cells::before {
    content: "New sections coming soon!";
    position: absolute;
    white-space: nowrap;
    top: -60px;
    right: 0;
    left: 0;
    font-size: 24px;
    padding: 8px;
    color: var(--color-white);
    background: red;
    text-align: center;
    clip-path: polygon(0% 0%, 100% 0%, calc(100% - 20px) 50%, 100% 100%, 0% 100%, 20px 50%);
    -webkit-clip-path: polygon(0% 0%, 100% 0%, calc(100% - 20px) 50%, 100% 100%, 0% 100%, 20px 50%);  
}

/*=======END GRID ASPECT RATIO=======*/
/*=======END GRID ASPECT RATIO=======*/


/*--------------------------------------------------------------
Accessibility
--------------------------------------------------------------*/
/* Text meant only for screen readers */
.screen-reader-text {
	clip: rect(1px, 1px, 1px, 1px);
	position: absolute !important;
	height: 1px;
	width: 1px;
	overflow: hidden;
}

.screen-reader-text:hover,
.screen-reader-text:active,
.screen-reader-text:focus {
	background-color: #f1f1f1;
	border-radius: 3px;
	box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
	clip: auto !important;
	color: #21759b;
	display: block;
	font-size: 14px;
	font-weight: bold;
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000;
}

/*===HEADER===*/

.masthead {
    padding: .5em .8em;
    background: linear-gradient(135deg, rgba(44,62,80,1) 0%, 
        rgba(0,128,172,1) 170px, rgba(0,128,172,0) 170px, 
        rgba(0,128,172,0) 180px, rgba(0,128,172,0.8) 180px, 
        rgba(0,128,172,0.8) 215px, rgba(0,128,172,0) 215px, 
        rgba(0,128,172,0) 100%), linear-gradient(45deg, rgba(0,128,172,0) 0, 
        rgba(0,128,172,0) 160px, rgba(0,128,172,0.15) 160px, 
        rgba(0,128,172,0.15) 190px, rgba(0,128,172,0) 190px, 
        rgba(0,128,172,0) 195px, rgba(0,128,172,0.3) 195px, 
        rgba(0,128,172,0.3) 230px, rgba(0,128,172,0) 230px, 
        rgba(0,128,172,0) 100%);
}

.logo a {

    width: 158.25px;
    height: 30px;
    display: block;
}

#svg-logo {
    width: 158.25px;
    height: 30px;
    /*filter: drop-shadow(0 1px 2px rgba(0,57,172,0.9));*/
    filter: drop-shadow(0 1px 1.5px rgba(0,0,0,0.3));

}

#svg-logo .st0 {
    fill:#fff;
}


/*--------------------------------------------------------------
MAIN NAV
--------------------------------------------------------------*/

.main-nav {
    width: 12em;
    height: 100vh;
    position: fixed;
    top: 52px;
    right: -12em; 
    z-index: 10;
	font-size: 1.1em;
    color: var(--color-white);
    transition: right cubic-bezier(0.19, 1, 0.22, 1) 100ms;
}

.main-nav ul {
	display: flex;
	flex-wrap: wrap;
	margin: 0;
	padding: 0;
    list-style-type: none;
    width: 100%;
    flex-direction: column;
}

.reveal .main-nav {
    right: 0;
}

.main-nav ul li {
    height: 44px;
    position: relative;
    right: -14em;
    margin-bottom: 2px;
    margin-left: 1.3em;
    opacity: 0;
    background-color: var(--color-apple);
    clip-path: polygon(.5em 0%, 100% 0, 100% 100%, .5em 100%);
}

.main-nav ul li.active-page {
    margin-left: 0;
    background-color: var(--color-monza);
    clip-path: polygon(20px 0, 100% 0, 100% 100%, 20px 100%, 0 50%);
}

.main-nav ul li.active-page:hover {
    background-color: var(--color-monza);
}
.reveal .main-nav ul li {
    right: 2px;
    opacity: 1;
}

/*---SLIDE IN---*/

.main-nav ul li:nth-child(1) {
    transition: right 500ms cubic-bezier(0.19, 1, 0.22, 1) 200ms, opacity ease-in-out 150ms;
}

.main-nav ul li:nth-child(2) {
    transition: right 500ms cubic-bezier(0.19, 1, 0.22, 1) 230ms, opacity ease-in-out 150ms;
}

.main-nav ul li:nth-child(3) {
    transition: right 500ms cubic-bezier(0.19, 1, 0.22, 1) 260ms, opacity ease-in-out 150ms;
}

.main-nav ul li:nth-child(4) {
    transition: right 500ms cubic-bezier(0.19, 1, 0.22, 1) 290ms, opacity ease-in-out 150ms;
}

.main-nav ul li:nth-child(5) {
    transition: right 500ms cubic-bezier(0.19, 1, 0.22, 1) 320ms, opacity ease-in-out 150ms;
}

.main-nav ul li:nth-child(6) {
    transition: right 500ms cubic-bezier(0.19, 1, 0.22, 1) 350ms, opacity ease-in-out 150ms;
}

.main-nav ul li:nth-child(7) {
    transition: right 500ms cubic-bezier(0.19, 1, 0.22, 1) 380ms, opacity ease-in-out 150ms;
}

.main-nav ul li:nth-child(8) {
    transition: right 500ms cubic-bezier(0.19, 1, 0.22, 1) 410ms, opacity ease-in-out 150ms;
}

/*---LINKS---*/

.main-nav a {
    height: 44px;
    display: block;
    position: relative;
    padding: .3em 0 .4em 1em;
	color: #fff;
    text-decoration: none;
    transition: all ease-in-out 300ms;
    background: hsl(0, 0%, 10%);
    clip-path: polygon(.5em 0%, 100% 0, 100% 100%, .5em 100%);
}

.main-nav ul li.active-page a {
    padding-left: 1.8em;
    background: hsl(0, 0%, 10%);
    clip-path: polygon(20px 0, 100% 0, calc(100% - 25px) 50%, 100% 100%, 20px 100%, 0 50%);
}

.main-nav a:focus,
.main-nav a:hover,
.main-nav a:active {
    color: var(--color-apple);
    margin-left: .5em; 
}

.main-nav .active-page a:focus,
.main-nav .active-page a:hover,
.main-nav .active-page a:active {
    color: var(--color-monza);
    text-decoration: none;
    clip-path: polygon(20px 0, 100% 0, 100% 50%, 100% 100%, 20px 100%, 0 50%);
}

/*---TRIGGER---*/
/*---TRIGGER---*/

.trigger {
    width: 48px;
    height: 48px;
    position: fixed;
    top: 2px;
    right: 2px;
    background-color: hsl(0, 0%, 10%);
    border: none;
    padding: 10px 6px;
}

/*---BURGER TIME---*/
/*---BURGER TIME---*/

#burber-meatballs-cheese {
    width: 35px;
    height: 28px;  
}

#burber-meatballs-cheese * {
    fill: var(--color-white);
    transition: all 300ms ease-in;
}

#bottom-bun {
    transform: translateY(-8px);
}

#meat-balls [class*="ball"] {
    opacity: 0;
}

.reveal #top-bun {
    fill:#e26525;
    transition-delay: 100ms;
}

.reveal #cheese {
    fill:#ffd703;
    transition-delay: 200ms;
}

.reveal #meat-balls .ball-1 {
    fill:#9f1610;
    transition-delay: 400ms;
    opacity: 1;
}

.reveal #meat-balls .ball-2 {
    fill:#932005;
    transition-delay: 500ms;
    opacity: 1;
}

.reveal #meat-balls .ball-3 {
    fill:#992204;
    transition-delay: 600ms;
    opacity: 1;
}

.reveal #bottom-bun {
    fill:#e26525;
    transition-delay: 300ms;
    transform: translateY(0) !important;
}

/*======GENERIC STYLES======*/
/*======GENERIC STYLES======*/

a {
    color: #004874;
    text-decoration: underline;
}

a:hover, 
a:active, 
a:focus {
    color: var(--color-woodsmoke);
    text-decoration: none;   
}

*:focus {
    outline: 0;
}

hr {
    margin-top: 1.5rem;
    margin-bottom: 1.5rem;
    border: 0;
    border-top: 1px solid var(--color-boulder);
}

img {
    display: block;
    border: 0;
    width: 100%;
    height: auto;
}


/*--------------------------------------------------------------
TYPOGRAPHY
--------------------------------------------------------------*/

h1, h2 {
    font-family: 'Cormorant Garamond', serif;
    margin: 0;
}

h3, h4, h5 {
    font-family: 'Titillium Web', sans-serif;
    margin: 0;
}

h2 {
    font-size: 15vw;
    line-height: 1;
}

p {
    margin-top: 0;
    margin-bottom: 0.5em;
}

ul, ol {
    margin-top: 0;
}

h1.page-heading {
    font-size: 21vw;
    font-weight: 700;
    line-height: 1;
    margin-bottom: 2rem;
}

h2.section-heading {
    font-size: 16vw;
    font-weight: 700;
    margin-bottom: 0;
}

h3.subheading {
    font-size: 6vw;
    font-weight: 200;
    font-style: italic;
}

/*MUST BE NEXT AFTER MAIN SERIF FONT LARGE*/
h3.sub-title {
    font-family: 'Titillium Web', sans-serif;
    font-weight: 200;
    font-size: 6vw;
}

h2.section-heading + h3.subheading {
    margin-bottom: 2rem;
}

h3.heading-3 {
    font-size: 9vw;
    font-weight: 700;
    text-transform: uppercase;
}

h4.heading-4 {
    font-size: 7vw;
    font-weight: 700;
    text-transform: uppercase;
    margin-top: 0;
    margin-bottom: .7em;
}

h5.heading-5 {
    font-size: 6.2vw;
    font-weight: 700;
    color: var(--color-woodsmoke);
}

h5.heading-5 + p,  
h5.heading-5 + ul {
    margin-top: 1rem;;
}

p.lead {
    font-size: 26px;
    font-family: 'Titillium Web', sans-serif;
}

p.lead + p,
p.lead + ul,
p.lead + ol {
    margin-top: .75em;
}

.italic {
    font-style: italic;
}

/*---TEMP---*/
.red-highlight::first-line {
    color: var(--color-monza);
}

/*---CLIP PATH TEXT EFFECT---*/

#titleContainer {
    position: relative;
}

.titleWrapper {
    cursor: default;
}

.cloneWrapper {
    position: absolute;
    z-index: 7;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    transition: all 0.8s cubic-bezier(0.165,0.84,0.44,1); 
    clip-path: polygon(0 0,calc(var(--maskX) * 1% + (var(--maskY) - 50) * .4%) 0,calc(var(--maskX) * 1% + (var(--maskY) - 50) * -.4%) 100%,0 100%)
}

/*---END TEXT EFFECT---*/

.content-title {
    position: relative;
    padding-top: 80px;
    padding-bottom: 10px;
    color: #004874;
    line-height: 1;
}

.content-title span.ampersand {
    color: #CCDBE3;
}

.cloneWrapper .content-title {
    color: var(--color-eastern-blue);
}

.cloneWrapper .content-title span.ampersand {
    color: #D2E8EE;
}

.content-title span.main-title-words {
    z-index: 1;
    position: relative;
}

.content-title span.ampersand {
    font-size: 75vw;
    position: absolute;
    left: 50vw;
    bottom: 0;
    line-height: 0.65;
    z-index: 0;
}

.splash-content {
    padding-top: 60px;
    padding-right: 1em;
    padding-left: 1em;
    overflow: hidden;
}

.splash-text {
    padding-left: 18px;
    border-left: 3px solid var(--color-eastern-blue);
    margin-top: 2rem;
}

.lead {
    font-size: 26px;
}

.cell {
    height: var(--row-height);
    position: relative;
    border: 1px solid #f0f0f0;
    background: rgba(255,255,255,0.3);
    color: white;
    margin: 0;
    overflow: hidden;  
}

.cell:hover {
    border-color: #ccc;
    background: rgba(255,255,255,0.05);
}

.cell.double {
    height: calc(var(--row-height) * 2 + var(--grid-gutter));
    grid-column: span 2;
    grid-row: span 2;
}

/*===TEMP OPACITY===*/
/*===TEMP OPACITY===*/

.cell[class*="item"]:not(.item5) figure {
    opacity: .6;
}

figure {
    margin: 0;
}

.cell-inner {
    display: grid;
    width: 100%;
    height: 100%;
}

.svgDuoSquare {
    width: 100%;
    height: 100%;
    display: block;
}

.cell-inner img, .cell-inner svg {
    height: 100%;
    display: block;
}

.cell-inner img, .cell-inner svg, .caption {
    grid-column: 1;
    grid-row: 1;
}

.caption {
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
    z-index: 3;
}

a .caption h3 {
    font-family: 'Titillium Web', sans-serif;
    color: #fff;
    margin: 0;
    padding: 0 0.4em 0.3em 0;
    font-size: 5vw;
    font-weight: 700;
    text-shadow: 1px 1px 2px rgba(0,0,0,0.9);
}

.caption-title {
    opacity: 0;
}

.cell a:focus .caption-title,
.cell a:hover .caption-title,
.cell a:active .caption-title {
    opacity: 1;
}

/*===GREEN===*/
.item3 a:focus [class^="image-duo-"],
.item3 a:hover [class^="image-duo-"],
.item3 a:active [class^="image-duo-"] {
    opacity: 1;
    filter: url(#filterDuoGreen);  
}

/*===PURPLE===*/
.item-5 .svgDuoSquare {
    background-color: #D9C4A4;
}

.item5 a:focus [class^="image-duo-"],
.item5 a:hover [class^="image-duo-"],
.item5 a:active [class^="image-duo-"] {
    opacity: 1;
    filter: url(#filterDuoPurple);  
}

/*===RED===*/
.item6 a:focus [class^="image-duo-"],
.item6 a:hover [class^="image-duo-"],
.item6 a:active [class^="image-duo-"] {
    opacity: 1;
    filter: url(#filterDuoRed);  
}

/*===ORANGE===*/
.item7 a:focus [class^="image-duo-"],
.item7 a:hover [class^="image-duo-"],
.item7 a:active [class^="image-duo-"] {
    opacity: 1;
    filter: url(#filterDuoOrange);
}

/*===BLUE===*/
.item8 a:focus [class^="image-duo-"],
.item8 a:hover [class^="image-duo-"],
.item8 a:active [class^="image-duo-"] {
    opacity: 1;
    filter: url(#filterDuoBlue);
}

/*===YELLOW===*/
.item9 a:focus [class^="image-duo-"],
.item9 a:hover [class^="image-duo-"],
.item9 a:active [class^="image-duo-"] {
    opacity: 1;
    filter: url(#filterDuoYellow);
}

.button {
    display: inline-block;
    color: #fff;
    font-weight: 700;
    background-color: #007c89;
    font-size: 1em;
    font-weight: 600;
    padding: 0.5em 2em;
    transition: all 150ms ease-in;
    text-shadow: 0.5px 0.5px 1px rgba(0,0,0,0.15);
    text-decoration: none;
    border: none;
    text-transform: uppercase;
}

a.button:hover, 
a.buttona:active, 
a.buttona:focus {
    color: #fff;
}

.button.primary {
    color: #fff;
    background-color: #0057ff;
    box-shadow: inset 0 0 0 0.07rem #0057ff;
}


.button.primary:hover {
    background-color: #040496;
    box-shadow: inset 0 0 0 0.07rem #040496;
}

/*===YOUTUBE EMBED===*/

.embed-responsive .embed-responsive-item, .embed-responsive iframe {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

.embed-responsive {
    position: relative;
    display: block;
    width: 100%;
    padding: 0;
    overflow: hidden;
}

.embed-responsive::before,  .embed-responsive-vertical::before {
    display: block;
    content: "";
}

.embed-responsive-16by9::before {
    padding-top: 56.25%;
}

.embed-responsive-vertical .embed-responsive-item, .embed-responsive-vertical iframe {
    position: absolute;
    top: 0;
    bottom: 0;
    left: -2px;
    width: 100%;
    height: 100%;
    border: 0;
}

.embed-responsive-vertical {
    position: relative;
    display: block;
    width: 100%;
    padding: 0;
    overflow: hidden;
    /*width: 376px;
    height: 667px;*/
    width: 377px;
    height: 668px;
}

.embed-responsive-19by9::before {
    padding-top: 177.4%;
}

/*--------------------------------------------------------------
TWO CONTENT COLUMNS GRID LAYOUT 
--------------------------------------------------------------*/
.main-area > .grid-4-col {
    display: grid;
    grid-template-columns: minmax(1em, 1fr) repeat(2, minmax(auto, 25em)) minmax(1em, 1fr);
    padding: 7em 0;
}

.grid-col-1-span-4 {
    grid-column: 1/span 4;
}

.grid-col-2-span-2 {
    grid-column: 2/span 2;
}

/*======CONTACT FORM======*/
/*======CONTACT FORM======*/

#contactForm {
    width:100%;
}

#contactForm .form-group * {
    transition: all 200ms cubic-bezier(0.0, 0, 0.2, 1) 0ms;
}

#contactForm fieldset {
    border: none;
    margin: 0;
    padding: 0;
}

.form-control {
    width: 100%;
    display: block;
    padding: .5rem 0;
    font-size: 18px;
    line-height: 1.25;
    color: var(--color-woodsmoke);
    -webkit-tap-highlight-color: transparent;
    border: none;
    border-bottom: 1px solid #767676;
    background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24"><path d="M7.9 17.1l-5.5-5.5-1.8 1.8L8 20.8 23.5 5.1l-1.8-1.8L7.9 17.1z" fill="%234eb239"/></svg>') no-repeat right -35px / 24px 24px;
}

.form-control:focus {
    color: var(--color-woodsmoke);
    border-color: transparent;
    outline: 0;
}

input[aria-invalid="true"].form-control,
textarea[aria-invalid="true"].form-control {
    border-color: red;
}

textarea {
    resize: none;
}

.form-group {
  position: relative;
}

.form-group:not(:last-of-type) {
    margin-bottom: 2em;
}

.form-control-placeholder {
  position: absolute;
  top: 0;
  color: #767676;
}

.form-control:focus + .form-control-placeholder,
.form-control:valid + .form-control-placeholder {
  font-size: 70%;
  transform: translate3d(0, -100%, 0);
}

input[aria-invalid="true"].form-control + .form-control-placeholder, 
textarea[aria-invalid="true"].form-control + .form-control-placeholder {
    font-size: 70%;
    transform: translate3d(0, -100%, 0);
    color: var(--color-monza);
}

.form-control:focus + .form-control-placeholder {
    color: #115293;
}

.focus-border {
    width: 100%;
    height: 2px;
    display: block;
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0; 
    z-index: 2;
    transform: scaleX(0);
    transition: transform 280ms cubic-bezier(0.0, 0, 0.2, 1) 0ms;
    background-color: #115293;
}

.form-control:focus + .form-control-placeholder + .focus-border {
    transform: scaleX(1);
}

.form-control:valid:not([aria-invalid="true"]) {
    border-color: #57b846;
    background-position: right center;
}

textarea.form-control:valid:not([aria-invalid="true"]) {
    background-position: right 7px;
}

/*MOZ FIX*/
:not(output):-moz-ui-invalid {
    box-shadow: none;
}

input:invalid {
    box-shadow: none;
}

/*CHROME FIX*/
@-webkit-keyframes autofill {
    to {
        color: var(--color-woodsmoke);
        background: transparent;
    }
}

input:-webkit-autofill {
    -webkit-animation-name: autofill;
    -webkit-animation-fill-mode: both;
}

/*
input:-internal-autofill-selected {
    background-color: red !important;
    background-image: inherit !important;
    color: var(--color-woodsmoke) !important;
}
*/

input:-webkit-autofill {
    -webkit-text-fill-color: var(--color-woodsmoke);
}
input:-webkit-autofill:focus {
    -webkit-text-fill-color: var(--color-woodsmoke);
}

/*======END CONTACT FORM======*/
/*======END CONTACT FORM======*/

.just-self-center {
    justify-self: center;
}

.bg-cerulean {
    background-color: var(--color-deep-cerulean);
}

.bg-wedgewood {
    background-color: var(--color-wedgewood);
}

.bg-white {
    background-color: var(--color-white);
}

.light-shadow {
    box-shadow: 1px 1px 4px rgba(0,0,0,0.2);
}

.light-border {
    border: 1px solid var(--color-gallery);
}

.text-white {
    color: #fff;
}

.light-text-shadow {
    text-shadow: 0.5px 0.5px 1px rgba(0,0,0,0.15);
}

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

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

.pt-0 {
    padding-top: 0 !important;
}

.pb-1 {
    padding-bottom: 1em;
}

.pb-2 {
    padding-bottom: 2em;
}

.pb-4 {
    padding-bottom: 4em;
}

.pl-1 {
    padding-left: 1em;
}

.mb-0 {
    margin-bottom: 0;
}

.mb-small {
    margin-bottom: 0.25em;
}


.mb-1 {
    margin-bottom: 1em;
}

.mt-0-5 {
    margin-top: .5em;
}

.mt-1 {
    margin-top: 1em;
}

.mt-1-5 {
    margin-top: 1.5em;
}

.mt-2 {
    margin-top: 2em;
}

.mt-3 {
    margin-top: 3em;
}

.mt-4 {
    margin-top: 4em;
}

.mt-5 {
    margin-top: 5em;
}

.mt-8 {
    margin-top: 8em;
}

.mt-10 {
    margin-top: 10em;
}

.margin-rl-auto {
    margin-right: auto;
    margin-left: auto;
}


/*--------------------------------------------------------------
UX PAGE 
--------------------------------------------------------------*/

.ux .main-area > section {
    padding: 5em 1em;
}

.main-area .notes {
    margin-top: 1em;
}

.main-area .flex-cols {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
    justify-content: center;
}

h2.section-heading + h3.subheading {
    margin-top: .75rem;
    margin-bottom: 4rem;
}

.ux-design-process {
    text-align: center;
}

[class^="ux-step"] {
    width: 18%;
    min-width: 232px;
    margin-bottom: .5em;
}

[class^="ux-step"] h3 {
    width: 200px;
    height: 200px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto .3em;
    background-color: var(--color-sazerac);
    border: 4px solid var(--color-eastern-blue);
    border-radius: 50%;
}

[class^="ux-step"] a {
    text-decoration: none;
    color: var(--color-woodsmoke);
    
}

[class^="ux-step"] a * {
    transition: all 220ms cubic-bezier(0.19, 1, 0.22, 1);
}

[class^="ux-step"] a:focus h3,
[class^="ux-step"] a:hover h3,
[class^="ux-step"] a:active h3 {
    border-color: var(--color-apple);
    color: var(--color-apple);
    background-color: var(--color-white);
}

[class^="ux-step"] a:focus p,
[class^="ux-step"] a:hover p,
[class^="ux-step"] a:active p {
    color: var(--color-apple);
}

.current-highlight h3 {
    border-color: var(--color-pomegranate);
    border-width: 6px;
    color: var(--color-pomegranate);
    text-shadow: 1px 1px 2px rgba(0,0,0,0.3);
}

.de-emphasized a h3 {
    background-color: #fffaef;
    border-color: #76bbcc;
    color: #737678;
}

.de-emphasized {
    color: #737678;
}

.first-stage .current-highlight h3 {
    background: url("../images/capital-markets-trading.jpg") no-repeat center center/cover var(--color-sazerac);
}

.second-stage .current-highlight h3 {
    background: url("../images/synthesizing-research.jpg") no-repeat center center/cover var(--color-sazerac);
}

.third-stage .current-highlight h3 {
    background: url("../images/site-map.png") no-repeat center center/cover var(--color-sazerac);
}

.fourth-stage .current-highlight h3 {
    background: url("../images/wire-frame.png") no-repeat center center/cover var(--color-sazerac);
}

.fifth-stage .current-highlight h3 {
    background: url("../images/usability-testing.jpg") no-repeat center center/cover var(--color-sazerac);
}

.current-highlight p {
    font-weight: bold;
    color: var(--color-pomegranate);
    font-size: 22px;
}

.rectangular-cells {
    display: grid;
    grid-auto-flow: dense;
    gap: 1em;
}

.text-cell {
    padding: .75em 1em;
    background-color: var(--color-gallery);
}

.image-cell {
    padding: .75em .75em .75em;
    background-color: var(--color-gallery);
}

ol.italic > li {
    font-style: italic;
}

.nested-ul {
    font-style: normal;
}

ol > li .nested-ul > li:first-of-type,
.no-bullet-list > li .nested-ul > li:first-of-type {
    margin-top: .5em;
}

.no-bullet-list {
    list-style: none;
    padding-left: 0;
}

.r-cell p {
    text-shadow: 1px 1px 2px rgba(255,255,255,1);
}

[class^="ux-note"] {
    margin-bottom: 1em;
}

[class^="ux-note"] h5.heading-5 {
    margin-top: 2rem;
}

.r-cell hr {
    border-bottom: 1px solid var(--color-white);
}

.audio-cell audio {
    width: 100%;
}

.audio-cell figcaption {
    margin-bottom: .25em;
}

.main-area .ux-stage + .content-section {
    padding-top: 0;
}

/*---QUOTE + CIRCLE SHAPE---*/

.quote, .circle-shape {
    width: 300px;
    height: 300px;
    position: relative;
    margin: 1em auto;
}

.quote::before {
    content: "\201C";
    font-size: 270px;
    height: 82px;
    line-height: .78;
    line-height: 1;
    position: absolute;
    top: -48px;
    left: 0;
    z-index: 1;
    font-family: sans-serif, serif;
    color: rgb(204, 204, 204);
    opacity: .9;
}

.text-quote {
    width: 100%;
    height: 100%;
    background: radial-gradient(ellipse at center, rgba(0,128,172,1) 0%,rgba(0,128,172,1) 70%,rgba(0,128,172,0) 70.3%);
    position: relative; 
    margin: 0;
    color: var(--color-white);
}

.circle-bg-tory-blue {
    background: radial-gradient(ellipse at center, rgba(17,82,147,1) 0%,rgba(17,82,147,1) 70%,rgba(17,82,147,0) 70.3%);
}

.text-quote p {
    height: 100%;
    text-align: center;
    font-size: 21px;
    line-height: 1.25;
    padding: 0;
    font-style: italic;
    text-shadow: .5px .5px 1px rgba(0,0,0,0.3);
}

.text-quote::before {
    content: "";
    width: 50%;
    height: 100%;
    float: left;
    shape-outside: polygon(98% 0%, 0% 0%, 0% 100%, 98% 100%, 50% 94%, 23.4% 82.7%, 6% 65.6%, 0% 50%, 6% 32.6%, 23.4% 17.3%, 50% 6%);
    shape-margin: 7%;
}

.text-quote p::before {
    content: "";
    width: 50%;
    height: 100%;
    float: right;
    shape-outside: polygon(2% 0%, 100% 0%, 100% 100%, 2% 100%, 50% 94%, 76.6% 82.7%, 94% 65.6%, 100% 50%, 94% 32.6%, 76.6% 17.3%, 50% 6%);
    shape-margin: 7%;
}

.quote blockquote footer {
    width: 100%;
    position: absolute;
    bottom: 25px;
    text-align: center;
    text-shadow: .5px .5px 1px rgba(0,0,0,0.3);
}

.quote blockquote cite {
    font-size: 17px;
}

/*=======MAGAZINE GRID LAYOUT============================*/
/*=======MAGAZINE GRID LAYOUT============================*/

.figcaption-hero {
    margin-left: 7%;
    padding: 1em;
}

.figcaption-hero p {
    font-size: .9rem;
    font-style: italic;
    padding-bottom: 18px;
    border-bottom: 3px solid #75a1b8;
}

.article-author {
    font-size: 1.3rem;
    margin: 2em 1em 0;
    text-align: right;  
}

.main-article {
    padding: 1em;
}

.main-article-title {
    text-transform: uppercase;
    font-size: 1.9rem;
    letter-spacing: 0.06em;
    font-family: 'Orbitron', sans-serif;
    margin-bottom: 1em;
}

/*=======TABLE============================*/
/*=======TABLE============================*/

.table {
    width: 100%;
    min-width: 600px;
    text-align: left;
}

.table td, .table th {
    padding: .75rem;
    vertical-align: top; 
}

.table thead th {
    background-color: var(--color-boulder);
    color: var(--color-white);
    text-shadow: 0 1px 2px rgba(0,0,0,0.3);
}

.table td, .table tbody th {
    border-top: 1px solid var(--color-boulder);
    box-shadow: inset 0 1px 1px white;
}

.table tbody th {
    background-color: var(--color-silver);
    text-shadow: 0 1px 2px rgba(255,255,255,.9);
}

.table-overflow {
    display: block;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
}

/*=======CARDS============================*/
/*=======CARDS============================*/

.websites .main-area > section {
    padding: 5em 1em;
}

.main-area > section.section-heading-wrap {
    padding-bottom: 0;
}

.websites .main-area > section + .content-section {
    padding: 1em;
    margin-bottom: 5em;;
    background-color: var(--color-gallery);
}

.image-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); /*ALLOW PADDING iPHONE 5*/
    grid-auto-rows: 280px;
    grid-auto-flow: dense;
    gap: 1em;
}

.image-cards-aspect {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); /*ALLOW PADDING iPHONE 5*/
    grid-auto-rows: minmax(min-content, max-content);
    /*grid-auto-rows: 200px;*/
    grid-auto-flow: dense;
    gap: 1em;
}

.image-card {
    position: relative;
    overflow: hidden;
    box-shadow: 1px 1px 4px rgba(0,0,0,0.2);
}

.image-card h5 {
    position: absolute;
    z-index: 1;
    right: 0;
    bottom: 0;
    padding: .2rem .7rem .2rem 2.3rem;
    color: var(--color-white);
    background-color: rgba(0,0,0,.8);
    text-align: right;
    clip-path: polygon(calc(0% + 28px) 0%, 100% 0, 100% 100%, 0 100%);
    -webkit-clip-path: polygon(calc(0% + 28px) 0%, 100% 0, 100% 100%, 0 100%);
    text-shadow: 0 1px 0 rgba(0,0,0,.9); 
}

.image-card a:hover + h5 {
    color: var(--color-eastern-blue);
    transition: all 220ms cubic-bezier(0.19, 1, 0.22, 1);
    transition-delay: 100ms;
}

.image-card img {
    height: 100%;
    object-fit: cover;
    object-position: 50% 0;
    transition: all 220ms cubic-bezier(0.19, 1, 0.22, 1);
}

.image-card a:active img {
    border: 5px solid var(--color-silver);
}

/*==================FOOTER==================*/
/*==================FOOTER==================*/

.colophon {
    background: url(../images/capital-markets-trading.jpg) no-repeat center center/cover var(--color-sazerac);
    background: url(../images/texture-bg.png) repeat fixed #474747;
    padding: 0.7em;
    font-size: 0.8em;
    clip-path: polygon(calc(50% - 123px) 0%, calc(50% + 123px) 0%, calc(50% + 167px) 100%, calc(50% - 167px) 100%);
    -webkit-clip-path: polygon(calc(50% - 123px) 0%, calc(50% + 123px) 0%, calc(50% + 167px) 100%, calc(50% - 167px) 100%);
    transition: all 300ms;
}

.colophon a {
    color: #aaa;
    text-shadow: 0.5px -1px 1px rgba(0,0,0,0.8), 0 1px 1px #555;
    text-decoration: none;
}

.colophon a:hover {
    color: #fff;
}

/*--------------------------------------------------------------
RANDOM DESIGNS PAGE 
--------------------------------------------------------------*/

.random-designs .main-area > section {
    padding: 5em 1em;
}

/*.width-auto img {
    width: auto !important;
}

.random-designs .image-card img {
    object-position: 100% 100%;
}*/

/*==================MEDIA QUIRIES==================*/
/*==================MEDIA QUIRIES==================*/


@media (min-width: 620px) {

    .masthead {
        background: linear-gradient(135deg, rgba(44,62,80,1) 0%, 
            rgba(0,128,172,1) calc(100% - 200px), rgba(0,128,172,0) calc(100% - 200px),
            rgba(0,128,172,0) calc(100% - 190px), rgba(0,128,172,0.8) calc(100% - 190px),
            rgba(0,128,172,0.8) calc(100% - 155px), rgba(0,128,172,0) calc(100% - 155px),
            rgba(0,128,172,0) 100%), linear-gradient(45deg, rgba(0,128,172,0) 0, 
            rgba(0,128,172,0) calc(100% - 210px), rgba(0,128,172,0.15) calc(100% - 210px),
            rgba(0,128,172,0.15) calc(100% - 180px), rgba(0,128,172,0) calc(100% - 180px),
            rgba(0,128,172,0) calc(100% - 175px), rgba(0,128,172,0.3) calc(100% - 175px),
            rgba(0,128,172,0.3) calc(100% - 140px), rgba(0,128,172,0) calc(100% - 140px),
            rgba(0,128,172,0) 100%);
    }

    h2 {
        font-size: 3.2em;
    }

    h3.sub-title {
        font-size: 1.6em;
    }


    /*---NEW SIZES---*/
    h1.page-heading {
        font-size: 85px;
    }
    
    h2.section-heading {
        font-size: 67px;
    }

    h3.subheading {
        font-size: 23px;
    }

    h3.heading-3 {
        font-size: 36px;
    }

    h4.heading-4 {
        font-size: 28px;
    }

    h5.heading-5 {
        font-size: 25px;
    }

    .content-title span.ampersand {
        font-size: 6.2em;
        left: 0.55em;
        bottom: 0;
    }

    a .caption h3 {
        padding: 0 0.4em 0.3em 0;
        font-size: 32px;
    }

    /*===CELL ITEM BEFORE CONTENT===*/
    /*===CELL ITEM BEFORE CONTENT===*/

    .cell[class*="item"]::before {
        content: "";
        width: 100%;
        position: absolute;
        top: 0;
        right: -120%;
        z-index: 2;
        color: #fff;
        transition: all 220ms cubic-bezier(0.19, 1, 0.22, 1);
        transition-delay: 500ms;
        font-size: 53vw;
        line-height: 48%;
        opacity: 0.3;
        text-indent: -4vw;
    }

    .cell[class*="item"]:focus::before,
    .cell[class*="item"]:hover::before,
    .cell[class*="item"]:active::before {
        top: 0;
        right: 0;
    }

    .cell.item1::before, .cell.item1::after,
    .cell.item2::before, .cell.item2::after,
    .cell.item4::before, .cell.item4::after,
    .cell.item9::before, .cell.item9::after {
        content: none !important;
    }

    /*.cell.item3::before {
        content: "3";
    }*/

    .cell.item5::before {
        content: "5";
    }

    /*.cell.item6::before {
        content: "6";
    }

    .cell.item7::before {
        content: "7";
    }

    .cell.item8::before {
        content: "8";
        font-size: 106vw;
        text-indent: -7.5vw;
    }*/

    /*===CELL ITEM AFTER CONTENT===*/
    /*===CELL ITEM AFTER CONTENT===*/

    .cell.item5::after{
        content: "";
        width: 100%;
        height: 100%;
        position: absolute;
        top: 0;
        left: -100%;
        background: rgba(0,0,0,0.7);
        border-radius: 4px;
        transition: all 200ms cubic-bezier(0.19, 1, 0.22, 1);
        transition-delay: 400ms;
        clip-path: polygon(0 0, 90% 0, 45% 100%, 0 100%);
        -webkit-clip-path: polygon(0 0, 90% 0, 45% 100%, 0 100%);
    }

    .cell[class*="item"]:focus::after,
    .cell[class*="item"]:hover::after,
    .cell[class*="item"]:active::after {
        top: 0;
        left: 0;
    }

    /*---UX PAGE---*/

    .rectangular-cells {
        grid-template-columns: repeat(2, minmax(280px, 1fr));
        padding-top: 2rem;
    }

    .col-span-full {
        grid-column: 1 / -1;
    }

    .row-span-2 {
        grid-row: span 2;
    }

    .row-span-3 {
        grid-row: span 3;
    }

    .row-span-4 {
        grid-row: span 4;
    }

    .row-span-5 {
        grid-row: span 5;
    }

    .image-cards {
        grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
        grid-auto-rows: 320px;
    }

    .image-cards-aspect {
        grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
        /*grid-auto-rows: 226px;*/
    }
}

/*======= < 1199px============================*/
/*======= < 1199px============================*/

@media only screen and (max-width: 1199px) {
    .r-cell ol.ordered-list > li:not(:first-of-type) {
        margin-top: 1.5em;
    }
}

/*=======LAYOUT > 850px============================*/
/*=======LAYOUT > 850px============================*/

@supports (grid-area: auto) {
	@media (min-width: 850px) {

        .trigger {
            width: 58px;
            height: 58px;
            padding: 13px 9px;
        }
        
        #burber-meatballs-cheese {
            width: 40px;
            height: 32px;  
        }
        
        .main-nav {
            top: 62px;
        }

        body.index {
            background:url(data:image/svg+xml;base64,PHN2ZyBpZD0iTGF5ZXJfMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB2aWV3Qm94PSIwIDAgMTQzMyAxMDU5Ij48c3R5bGU+LnN0MXtmaWxsOiNlYmViZWJ9PC9zdHlsZT48cGF0aCBkPSJNLjUgMXYxMDU3aDE0MzJWODA0LjlsLS45LjUtNjUuNC0zNy44LTY1LjQtMzcuOHYtMTUxbDY1LjQtMzcuOCA2NS40LTM3LjguOS41di0yMDBsLS45LjUtNjUuNC0zNy44LTY1LjQtMzcuN1Y3Ny41bDY1LjQtMzcuOEwxNDMxLjYgMmwuOS41VjFILjV6bTk5OC42IDI1My41bDY1LjQgMzcuOCA2NS40IDM3Ljh2MTUxLjFsLTY1LjQgMzcuOC02NS40IDM3LjgtNjUuNC0zNy44LTY1LjQtMzcuOFYzMzBsNjUuNC0zNy44IDY1LjQtMzcuN3ptMjc0LjgtMjUuOWwtNjUuNCAzNy43LTY1LjQgMzcuOC02NS40LTM3LjgtNjUuNC0zNy43Vjc3LjVsNjUuNC0zNy44TDExNDMuMSAybDY1LjQgMzcuOCA2NS40IDM3Ljh2MTUxem0xMy44IDMyOC4xbC02NS40LTM3LjgtNjUuNC0zNy44VjMzMGw2NS40LTM3LjggNjUuNC0zNy44IDY1LjQgMzcuOCA2NS40IDM3Ljh2MTUxLjFsLTY1LjQgMzcuOC02NS40IDM3Ljh6bS0xMzAuOSAyNzQuNWw2NS40LTM3LjggNjUuNC0zNy43IDY1LjQgMzcuNyA2NS40IDM3Ljh2MTUxLjFsLTY1LjQgMzcuOC02NS40IDM3LjgtNjUuNC0zNy44LTY1LjQtMzcuOFY4MzEuMnptLTEzLjctMjUuOGwtNjUuNC0zNy44LTY1LjQtMzcuOHYtMTUxbDY1LjQtMzcuOCA2NS40LTM3LjggNjUuNCAzNy44IDY1LjQgMzcuOHYxNTFsLTY1LjQgMzcuOC02NS40IDM3Ljh6bS0yNzQuOSAyNS44bDY1LjQtMzcuOCA2NS40LTM3LjcgNjUuNCAzNy43IDY1LjQgMzcuOHYxNTEuMWwtNjUuNCAzNy44LTY1LjQgMzcuOC02NS40LTM3LjgtNjUuNC0zNy44VjgzMS4yem0tMTMuNy0yNS44bC02NS40LTM3LjgtNjUuNC0zNy44di0xNTFsNjUuNC0zNy44IDY1LjQtMzcuOCA2NS40IDM3LjggNjUuNCAzNy44djE1MWwtNjUuNCAzNy44LTY1LjQgMzcuOHptLTI3NC44IDI1LjhsNjUuNC0zNy44IDY1LjQtMzcuNyA2NS40IDM3LjcgNjUuNCAzNy44djE1MS4xbC02NS40IDM3LjgtNjUuNCAzNy44LTY1LjQtMzcuOC02NS40LTM3LjhWODMxLjJ6bS0xMy44LTI1LjhsLTY1LjQtMzcuOC02NS40LTM3Ljh2LTE1MWw2NS40LTM3LjggNjUuNC0zNy44IDY1LjQgMzcuOCA2NS40IDM3Ljh2MTUxbC02NS40IDM3LjgtNjUuNCAzNy44em0tMjc0LjggMjUuOGw2NS40LTM3LjggNjUuNC0zNy43IDY1LjQgMzcuNyA2NS40IDM3Ljh2MTUxLjFsLTY1LjQgMzcuOC02NS40IDM3LjgtNjUuNC0zNy44LTY1LjQtMzcuOFY4MzEuMnptLTI4OC42IDBsNjUuNC0zNy44IDY1LjQtMzcuNyA2NS40IDM3LjcgNjUuNCAzNy44djE1MS4xbC02NS40IDM3LjgtNjUuNCAzNy44LTY1LjQtMzcuOC02NS40LTM3LjhWODMxLjJ6IiBmaWxsPSJub25lIi8+PHBhdGggY2xhc3M9InN0MSIgZD0iTTEzNjYuMiAyNjYuNGwtNjUuNC0zNy44Vjc3LjVsNjUuNC0zNy43TDE0MzEuNiAybC45LjV2MzAxLjJsLS45LjR6TTExNDMuMSAxMy41bDYwLjQgMzQuOSA2MC40IDM0Ljl2MTM5LjZsLTYwLjQgMzQuOS02MC40IDM0LjktNjAuNC0zNC45LTYwLjQtMzQuOVY4My4zbDYwLjQtMzQuOSA2MC40LTM0LjltMC0xMS41bC02NS40IDM3LjgtNjUuNCAzNy44djE1MWw2NS40IDM3LjcgNjUuNCAzNy44IDY1LjQtMzcuOCA2NS40LTM3LjdWNzcuNWwtNjUuNC0zNy44TDExNDMuMSAyek0xMjIyLjIgNTE4LjlsLTY1LjQtMzcuOFYzMzBsNjUuNC0zNy43IDY1LjUtMzcuOCA2NS40IDM3LjggNjUuNCAzNy43djE1MS4xbC02NS40IDM3LjgtNjUuNCAzNy44ek05OTkuMSAyNjYuMWw2MC40IDM0LjkgNjAuNCAzNC45djEzOS41bC02MC40IDM0LjktNjAuNCAzNC45LTYwLjQtMzQuOS02MC40LTM0LjlWMzM1LjlsNjAuNC0zNC45IDYwLjQtMzQuOW0wLTExLjZsLTY1LjQgMzcuOC02NS41IDM3Ljd2MTUxLjFsNjUuNCAzNy44IDY1LjQgMzcuOCA2NS40LTM3LjggNjUuNC0zNy44VjMzMGwtNjUuNC0zNy44LTY1LjMtMzcuN3pNMTM2Ni4yIDc2Ny42bC02NS40LTM3Ljh2LTE1MWw2NS40LTM3LjggNjUuNC0zNy44LjkuNXYzMDEuMmwtLjkuNXpNMTAxMi4yIDcyOS44di0xNTFsNjUuNS0zNy44IDY1LjQtMzcuOCA2NS40IDM3LjggNjUuNCAzNy44djE1MWwtNjUuNCAzNy44LTY1LjQgMzcuOC02NS40LTM3Ljh6TTg1NC41IDUxNC44bDYwLjQgMzQuOSA2MC40IDM0Ljl2MTM5LjZsLTYwLjQgMzQuOS02MC40IDM0LjktNjAuNC0zNC45LTYwLjQtMzQuOVY1ODQuNmw2MC40LTM0LjkgNjAuNC0zNC45bTAtMTEuNkw3ODkuMSA1NDFsLTY1LjQgMzcuOHYxNTFsNjUuNCAzNy44IDY1LjQgMzcuOCA2NS40LTM3LjggNjUuNC0zNy44di0xNTFMOTE5LjkgNTQxbC02NS40LTM3Ljh6TTU2NS45IDUxNC44bDYwLjQgMzQuOSA2MC40IDM0Ljl2MTM5LjZsLTYwLjQgMzQuOS02MC40IDM0LjktNjAuNC0zNC45LTYwLjQtMzQuOVY1ODQuNmw2MC40LTM0LjkgNjAuNC0zNC45bTAtMTEuNkw1MDAuNSA1NDFsLTY1LjQgMzcuOHYxNTFsNjUuNCAzNy44IDY1LjQgMzcuOCA2NS40LTM3LjggNjUuNC0zNy44di0xNTFMNjMxLjMgNTQxbC02NS40LTM3Ljh6TTEyODcuNyA3NTUuN2w2NS40IDM3LjggNjUuNCAzNy43djE1MS4xbC02NS40IDM3LjgtNjUuNCAzNy44LTY1LjUtMzcuOC02NS40LTM3LjhWODMxLjJsNjUuNC0zNy43ek05OTkuMSA3NTUuN2w2NS40IDM3LjggNjUuNCAzNy43djE1MS4xbC02NS40IDM3LjgtNjUuNCAzNy44LTY1LjQtMzcuOC02NS41LTM3LjhWODMxLjJsNjUuNS0zNy43ek03MTAuNSA3NTUuN2w2NS40IDM3LjggNjUuNCAzNy43djE1MS4xbC02NS40IDM3LjgtNjUuNCAzNy44LTY1LjQtMzcuOC02NS40LTM3LjhWODMxLjJsNjUuNC0zNy43ek00MjEuOSA3NTUuN2w2NS40IDM3LjggNjUuNSAzNy43djE1MS4xbC02NS41IDM3LjgtNjUuNCAzNy44LTY1LjQtMzcuOC02NS40LTM3LjhWODMxLjJsNjUuNC0zNy43ek0xMzMuNCA3NjcuM2w2MC40IDM0LjkgNjAuNCAzNC45djEzOS41bC02MC40IDM0LjktNjAuNCAzNC45LTYwLjQtMzQuOS02MC40LTM0LjlWODM3TDczIDgwMi4xbDYwLjQtMzQuOG0wLTExLjZMNjggNzkzLjQgMi41IDgzMS4ydjE1MS4xbDY1LjQgMzcuOCA2NS40IDM3LjggNjUuNC0zNy44IDY1LjQtMzcuOFY4MzEuMmwtNjUuNC0zNy44LTY1LjMtMzcuN3oiLz48L3N2Zz4=) no-repeat calc(100% + 2px) calc(100% + 25px)/60% auto fixed #fff;
        }

        .max-ch {
            max-width: 56ch;
        }

        h1.site-title {
            font-size: 1.4em;
        }
    
        h1.site-title span  {
            font-size: 4em;
        } 
    
        h2 {
            font-size: 3.2em;
        }

        /*---NEW SIZES---*/
        h1.page-heading {
            font-size: 10vw;
        }
        
        h2.section-heading {
            font-size: 7.9vw;
        }
    
        h3.subheading {
            font-size: 2.7vw;
        }

        h3.heading-3 {
            font-size: 4.2vw;
        }

        h4.heading-4 {
            font-size: 3.2vw;
        }
    
        h5.heading-5 {
            font-size: 2.8vw;
        }
        
        .colophon {
            width: 100%;
            position: fixed;
            z-index: 3;
            left: 0;
            bottom: 0;
            margin-top: -44px;
        }

        .light-box-active .colophon {
            opacity: 0;
        }

        .logo a {
            width: 211px;
            height: 40px;
        }
        
        #svg-logo {
            width: 211px;
            height: 40px;
        }

        :root {
            /*SECTION IS ONE(fr) OF THREE(fr) OF TOTAL vw*/
            --section-width: 50vw;
        }
        .splash {
            display: flex;
        }

        .splash-content {
            align-self: center;
        }

        .cell[class*="item"]::before {
            font-size: 27vw;
            text-indent: -2.4vw;
        }

        .cell.item8::before {
            font-size: 56vw;
            text-indent: -4.4vw;
        }

        a .caption h3 {
            padding: 0 0.4em 0.3em 0;
            font-size: 2.8vw;
        }

        /*====MAGAZINE GRID LAYOUT====*/
        .grid-spread {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            grid-template-rows: 40px max-content 1fr max-content 40px;
        }

        .figure-hero {
            grid-area: 1/1/6/4;
            /*---ROW START/COLUMN START . ROW END/COLUMN END---*/
        }

        .figure-hero img {
            height: 100vh;
            object-fit: cover;
        }

        .figcaption-hero {
            grid-area: 2/4/3/5;
            margin-left: 0;
            background: rgba(255,255,255,0.6);
        }

        .article-author {
            grid-area: 3/2/4/5;
            justify-self: end;
            align-self: end;
        }

        .main-article {
            grid-area: 4/2/5/5;
            background: rgba(255,255,255,0.85);
        }

        .main-article-title {
            text-shadow: 0.5px 0.5px 1px rgba(255,255,255,0.6);
        }

        /*---UX PAGE---*/

        [class^="ux-note"] {
            width: 50%;
        }
        
        .page-intro p {
            margin-right: auto;
            margin-left: auto;
        }

        [class^="ux-note"]:nth-child(odd) {
            padding-right: .5em;
        }
        
        [class^="ux-note"]:nth-child(even) {
            padding-left: .5em;
        }

        .quote, .circle-shape {
            width: 370px;
            height: 370px;
        }

        .quote::before {
            font-size: 300px;
        }

        .text-quote p {
            font-size: 26px;
        }

        .quote blockquote footer {
            bottom: 32px;
        }

        /*---IMAGE CARDS---*/

        .double-width {
            grid-column: span 2;
        }
    }
}



/*=======GRID LAYOUT > 1200px============================*/
/*=======GRID LAYOUT > 1200px============================*/

@supports (grid-area: auto) {
	@media (min-width: 1200px) {

        :root {
            /*SECTION IS ONE(fr) OF THREE(fr) OF TOTAL vw*/
            --section-width: calc(100vw / 3);
        }

        body.index {
            background-size: 720px auto;
        }

        /*=======MAIN CONTENT=======*/
        .splash {
            display: grid;
            grid-template-columns: 0.3fr 1.2fr 0.2fr 1fr 0.3fr;
            grid-auto-rows: auto;
            grid-auto-flow: dense;
            padding-bottom: 14em;
        }

        .splash-content {
            grid-column: 2;
            align-self: end;
            padding-right: 0;
            padding-left: 0;
        }

        .splash-text {
            max-width: 55ch;
        }
        
        .splash .grid-aspect-cells {
            margin-top: 12em;
            margin-bottom: 0;
        }

        a .caption h3 {
            padding: 0 0.8vw 0.8vw 0;
            font-size: 1.5vw;
        }
        .content-title span.ampersand {
            font-size: 22vw;
            left: 12vw;
            bottom: 0;
        }

        h2 {
            font-size: 3.8vw;
        }

        h3.sub-title {
            font-size: 1.6em;
        }

        /*---MAX FONT SIZES---*/
        h1.page-heading {
            font-size: 120px;
        }

        h2.section-heading {
            font-size: 95px;
        }

        h3.subheading {
            font-size: 31px;
        }

        h3.heading-3 {
            font-size: 50px;
        }

        h4.heading-4 {
            font-size: 38px;
        }
    
        h5.heading-5 {
            font-size: 33px;
        }

        /*---FRONT PAGE CELLS---*/
        .cell[class*="item"]::before {
            font-size: 16vw;
            line-height: 50%;
            text-indent: -1.4vw;
        }

        .cell.item8::before {
            font-size: 34vw;
            text-indent: -2.6vw;
        }

        /*====MAGAZINE GRID LAYOUT====*/

        .grid-spread {
            display: grid;
            grid-template-columns: 50vw 55px minmax(auto, 35em) 55px;
            grid-template-rows: 55px repeat(2, auto);
        }

        .figure-hero {
            grid-area: 1/1/4/2;
            /*---ROW START/COLUMN START . ROW END/COLUMN END---*/
        }

        .figcaption-hero {
            grid-area: 3/3/4/4;
            margin-left: 0;
            padding: 0;
        }

        .figcaption-hero p {
            border-bottom: none;
            border-top: 3px solid #75a1b8;
            padding-top: 18px;
            padding-bottom: 0;
            max-width: 52ch;
        }

        .article-author {
            display: none;
        }

        .main-article {
            grid-area: 2/3/3/4;
            margin: 0 0 2em;
            padding: 0;
        }

        .form-group:not(:last-of-type) {
            margin-bottom: 1.2em;
        }

        .main-article-title {
            font-size: 2rem;
        }

        /*---UX PAGE---*/

        .ux-design-process, .ux-design-process h3 {
            position: relative;
        }
        
        .ux-design-process::before {
            content: "";
            /* width: 78%;*/
            width: 75%;
            height: 4px;
            position: absolute;
            top: 100px;
            background-color: var(--color-woodsmoke); 
        }

        .second-stage .ux-design-process::before {
            background: linear-gradient(to right, #737678 0%,#737678 26%,#161b1e 26%,#161b1e 100%);
        }

        .third-stage .ux-design-process::before {
            background: linear-gradient(to right, #737678 0%,#737678 50%,#161b1e 50%,#161b1e 100%);
        }

        .fourth-stage .ux-design-process::before {
            background: linear-gradient(to right, #737678 0%,#737678 74%,#161b1e 74%,#161b1e 100%);
        }

        .fifth-stage .ux-design-process::before {
            background-color: #737678;
        }

        .ux-step-5 {
            position: relative;
        }
    
        .ux-step-5 h3::before {
            content: "";
            width: 0;
            height: 0;
            position: absolute;
            top: 86px;
            left: -23px;
            z-index: 1;
            border-style: solid;
            border-width: 12px 0 12px 24px;
            border-color: transparent transparent transparent var(--color-woodsmoke);
        }

        /*---UX PAGE---*/

        .quote {
            shape-outside: circle(50%);
            margin: 15px 20px 15px 0;
        }

        .clear-both {
            clear: both;
        }

        .circle-shape {
            float: right;
            shape-outside: circle(50%);
            margin: 15px 0 15px 33px; /*RAGGED RIGHT*/
        }

        .rectangular-cells {
            grid-template-columns: repeat(3, minmax(280px, 1fr));
        }

        .col-span-2 {
            grid-column: span 2;
        }

        .col-span-full {
            /*grid-column: span 3;*/
            grid-column: 1 / -1;
        }

        .two-col-grid {
            display: grid;
            gap: 1.5em;
            grid-template-columns: repeat(2, minmax(300px, 1fr));
        }

        .two-col-grid li {
            max-width: 71ch;
        }

        /*---WEBSITE IMAGE CARDS---*/

        .triple-width {
            grid-column: span 3;
        }

        .quadruple-width {
            grid-column: span 4;
        }
        
        .double-height {
            grid-row: span 2;
        }
        
        .triple-height {
            grid-row: span 3;    
        }

        .quadruple-height {
            grid-row: span 4;
        }

        .quintuple-height {
            grid-row: span 5;
        }

        .sextuple-height {
            grid-row: span 6;
        }
    } 
}

/*@supports (grid-area: auto) {*/
	@media (min-width: 1600px) {

        .cell[class*="item"]::before {
            font-size: 17vw;
        }

        .cell.item8::before {
            font-size: 34vw;
            text-indent: -2.6vw;
        }

        /*====MAGAZINE GRID LAYOUT====*/

        .grid-spread {
            display: grid;
            grid-template-columns: 50vw 55px minmax(auto, 10em) minmax(auto, 35em) 55px;
            grid-template-rows: 80px minmax(auto, 14em) 1fr auto 0.5fr;
        }

        .figure-hero {
            grid-area: 1/1/6/2;
            /*---ROW START/COLUMN START . ROW END/COLUMN END---*/
        }

        .figcaption-hero {
            grid-column: 3;
            grid-row: 2;
            margin-left: 0;
            padding: 0;
        }

        .figcaption-hero p {
            border-top: none;
            border-bottom: 3px solid #75a1b8;
            padding-top: 0;
            padding-bottom: 18px;
            max-width: 58ch;
        }

        .article-author {
            display: block;
            grid-column: 4;
            grid-row: 3;
            padding: 0;
        }

        .main-article {
            grid-column: 4;
            grid-row: 4;
            margin: 2em 0;
            padding: 0;
        }

        .form-group:not(:last-of-type) {
            margin-bottom: 2em;
        }

        /*====UX PAGE====*/

        .ux-design-process h3 {
            width: 240px;
            height: 240px;
        }

        .ux-design-process::before {
            top: 118px;
        }
    
        .ux-step-5 h3::before {
            top: 104px;
        }

        .fifth-stage .ux-step-5 h3::before {
            top: 102px;
            border-color: transparent transparent transparent #737678;
        }

        .float-left {
            float: left;
        }

        .quote.float-left + p::after {
            content: "";
            display: table;
            clear: both;
        }
    }
/*}*/

@media (min-width: 1920px) {
    .ux .main-area > section,
    .random-designs .main-area > section /*,
    .websites .main-area > section*/ {
        max-width: 1920px;
        margin-right: auto;
        margin-left: auto;
    }
}


