/* =============================================================================
   HTML5 CSS Reset Minified - Eric Meyer
   ========================================================================== */

html,body,div,span,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,abbr,address,cite,code,del,dfn,em,img,ins,kbd,q,samp,small,strong,sub,sup,var,b,i,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,figcaption,figure,footer,header,hgroup,menu,nav,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;outline:0;font-size:100%;vertical-align:baseline;background:transparent}
body{line-height:1}
article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}
nav ul{list-style:none}
blockquote,q{quotes:none}
blockquote:before,blockquote:after,q:before,q:after{content:none}
a{margin:0;padding:0;font-size:100%;vertical-align:baseline;background:transparent;text-decoration:none}
mark{background-color:#ff9;color:#000;font-style:italic;font-weight:bold}
del{text-decoration:line-through}
abbr[title],dfn[title]{border-bottom:1px dotted;cursor:help}
table{border-collapse:collapse;border-spacing:0}
hr{display:block;height:1px;border:0;border-top:1px solid #ccc;margin:1em 0;padding:0}
input,select{vertical-align:middle}
li{list-style:none}

textarea,
input.text,
input[type="text"],
input[type="button"],
input[type="submit"],
.input-checkbox {
-webkit-appearance: none;
border-radius: 0;
}

:root {
    --text: #1c1714;
    --white: #ffffff;
    --bg: #f7f1e5;
    --border: #121212;
    --line: #2a2a2a;
}




/* 
==========================================================================
GLOBAL & WP SPECIFIC STYLES
==========================================================================
*/

* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-text-size-adjust: none;   
}

input, textarea, select {
    -webkit-border-radius:0; 
    border-radius:0;
}

img,
audio,
video,
canvas {
  max-width: 100%;
}

html {
  min-height: 100%;
  margin-bottom: 1px;
  overflow: -moz-scrollbars-vertical!important; 
}

::selection {
  background: var(--white);
  color: var(--black);
}

::-moz-selection {
  background: var(--white);
  color: var(--black);
}

::-webkit-selection {
  background: var(--white);
  color: var(--black);
}

.cf:before,.cf:after {content: " "; /* 1 */    display: table; /* 2 */}
.cf:after {clear: both;}
.cf {clear: both;}

strong, b {
  font-weight:bold;
}

em, i {
  font-style:italic;
}

img.alignright {
  float:right;
  margin:0 0 2em 1em;
}

img.alignleft {
  float:left;
  margin:0 2em 1em 0;
}

img.aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.alignright {
  float:right;
  margin:0 0 2em 1em;
}

.alignleft {
  float:left;
  margin:0 0 2em 1em;
}

img.wp-smiley {
  float: none;
  margin: 0 0 0 5px;
  vertical-align:middle;
}

p {
  margin: 0 0 20px 0;
}

a {
  color: var(--white);
  text-decoration: none;
}

a:hover {
  color: var(--yellow);
  text-decoration: none;
}


/* 
==========================================================================
H & LINKS
==========================================================================
*/

h1 {
  font: 30px "Libre Baskerville", Helvetica , Arial, sans-serif;  
  margin:0 0 20px 0;
  padding:0;
}

h2 {
  font: 26px "Libre Baskerville", Helvetica , Arial, sans-serif;  
  margin:0 0 20px 0;
  padding:0;
}

h3 {
  font: 22px "Libre Baskerville", Helvetica , Arial, sans-serif;
  margin:0 0 20px 0;
  padding:0;
}

h4 {
  font: 20px "Libre Baskerville", Helvetica , Arial, sans-serif;
  margin:0 0 20px 0;
  padding:0;
}

h5 {
  font: 18px "Libre Baskerville", Helvetica , Arial, sans-serif;
  margin:0 0 20px 0;
  padding:0;
}


/* 
==========================================================================
GENERAL
==========================================================================
*/

body {
  background: var(--bg);
  color: var(--text);
  font: 18px/1.45 'Libre Baskerville', Helvetica, Arial, sans-serif;
  margin:0;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  font-variant-numeric: tabular-nums;
  font-optical-sizing: auto;
}


.container {
  width:100%;
  margin: 0 auto;
  height: 1000px;
}

.inner {
  position: relative;
  width: 100%;
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 30px;
}



/* 
==========================================================================
HEADER
==========================================================================
*/

header {
  position: relative;
  width:100%;
  margin: 0 auto;
  padding: 40px 0;
  z-index: 999;
}

.header-grid {
  width: 100%;
  display: grid;
  grid-template-columns: auto auto auto;
  grid-column-gap: 0;
  grid-row-gap: 0;
  justify-items: stretch;
  align-items: center;
}

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

.hc-middle {
  text-align: center;
  display: inline-grid;
}

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

.logo {
    width: 350px;
    height: auto;
    margin: 0 auto;
    display: block;
  transition: all 0.3s ease-in;    
}

.logos {
    width: 250px;
    height: auto;
    margin: 0 auto;
    display: block;
  transition: all 0.3s ease-in;    
}

.logos img,
.logo img {
  width: 100%;
  height: auto;
  display: block;
  margin: 0;
}


nav ul {
  list-style: none;
}



.home-hero {
position: relative;
  width: 100%;
  max-width: 1440px;
  margin: 0 auto;
  padding: 20px 0 100px 0;
  border-bottom: 1px solid var(--text);
}

.home-hero::after {
  content: "";
  width: 100%;
  height: 1px;
  background: var(--text);
  position: absolute;
  bottom: 3px;
}

.home-hero-inner {
  width: 100%;
  max-width: 800px;
  margin: 0 auto;
  text-align: center;
}

.home-hero h1 {
    margin: 50px 0 0 0;
display: block;
    font-family: 'Libre Baskerville', Helvetica, Arial, sans-serif;
    font-size:34px;

    font-weight: 900;

    text-align: center;

}


@keyframes Coolgradient {
    0%   { background-position: 5% 0%; }
    50%  { background-position: 96% 100%; }
    100% { background-position: 5% 0%; }
}

@media screen and (max-width: 768px) {
  .home-hero {
    padding: 50px 0;
  }

  .home-hero-title {
    height: 50vh;
    min-height: 200px;
  }

  .home-hero-title h1 {
    font-size: clamp(42px, 13vw, 70px);
    line-height: 0.95;
  }
}

.hero-work-grid {
  width: min(620px, 46vw);
  margin-left: auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 280px 250px;
  gap: 30px;
  align-self: start;
}

.hero-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: grayscale(100%);
}

.hero-img-1 {
  grid-column: 1 / 3;
  grid-row: 1;
  width: 85%;
  justify-self: end;
}

.hero-img-2 {
  grid-column: 1 / 2;
  grid-row: 2;
}

.hero-img-3 {
  grid-column: 2 / 4;
  grid-row: 2;
}

@media screen and (max-width: 960px) {
  .home-hero .inner {
    display: block;
  }

  .hero-work-grid {
    margin-top: 60px;
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    gap: 24px;
  }

  .hero-img,
  .hero-img-1,
  .hero-img-2,
  .hero-img-3 {
    grid-column: auto;
    grid-row: auto;
    width: 100%;
    height: auto;
  }
}

.text-grid {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr 2fr 2fr;
    grid-column-gap: 50px;
    grid-row-gap: 50px;
    justify-items: stretch;
    align-items: inital;
    margin: -1px auto 0 auto;
    padding: 50px 0;
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);   
  transition: all 0.3s ease-in;    
}

.text-col h5 {
  font-size: 15px;
  font-weight: 500;
  margin: 0 0 5px 0;
}

.text-col p {
  margin: 0;
  color: var(--grey);
   font-size: 18px;
}

.text-grid:hover {
  color: var(--white);
  opacity: 0.5;
  cursor: pointer;
  transition: all 0.3s ease-in-out;    
}

.white-block {
  display: block;
  position: relative;
  background: var(--black);
  padding: 100px 0;
}

.grey-block {
  display: block;
  position: relative;
  background: var(--greysect);
  padding: 100px 0;
   z-index: 2;
}

.black-block {
  display: block;
  position: relative;
  background: var(--black);
  padding: 100px 0;
   z-index: 2;
}


.page-intro {
  margin: 0 0 50px 0;
}

.page-intro h5 {
  color: var(--grey);
  font-size: 14px;
  text-transform: uppercase;
  margin: 0 0 5px 0;
font-weight: 500;

}

.page-intro h2 {
  color: var(--white);
  font-size: 30px;
  margin: 0;
  font-weight: 300;
}


.port-home-grid {
  width: 100%;
}

.masonry {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 25px;
  align-items: baseline;
}

.masonry-item {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.port-home-item {
  display: block;
  background: var(--greybg);
  overflow: hidden;
}

.masonry-item:nth-of-type(4),
.masonry-item:nth-of-type(5),
.masonry-item:nth-of-type(6) {
  display: flex;
  align-self: end;
}


.port-home-img {
  position: relative;
  display: block;
  overflow: hidden;
  background: #000;
  isolation: isolate;
}

.port-home-img img {
  display: block;
  width: 100%;
  max-height: 325px;
  margin: 0;
  object-fit: cover;
  filter: grayscale(100%) contrast(1.08);
  opacity: 0.72;
  transform: none;
  transition:
    filter 0.45s ease,
    opacity 0.45s ease,
    transform 0.45s ease;
}

.masonry-item:nth-child(1) .port-home-img img {
  height: 275px;
}

.masonry-item:nth-child(2) .port-home-img img {
  height: 335px;
}

.masonry-item:nth-child(3) .port-home-img img {
  height: 300px;
}

.masonry-item:nth-child(4) .port-home-img img {
  height: 300px;
}

.masonry-item:nth-child(5) .port-home-img img {
  height: 350px;
}

.masonry-item:nth-child(6) .port-home-img img {
  height: 275px;
}



.glitch {
  background: #000 no-repeat center;
  background-size: 0;
  height: 100vh;
  position: relative;
  overflow: hidden;
}
.glitch::before, .glitch::after,
.glitch .channel {
  background: inherit;
  background-size: cover;
  bottom: 0;
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
}
.glitch::before {
  animation: glitch-before 0.5s linear infinite alternate both;
  content: "";
}
@keyframes glitch-before {
  0% {
    clip-path: polygon(0% 17.8554815316%, 100% 17.8554815316%, 100% 24.3883980755%, 0% 24.3883980755%);
    transform: translate(-6.5790010014%, 0.1904543913%);
  }
  2% {
    clip-path: polygon(0% 12.5030049186%, 100% 12.5030049186%, 100% 20.8405742015%, 0% 20.8405742015%);
    transform: translate(6.2322922987%, 0.2835438231%);
  }
  4% {
    clip-path: polygon(0% 70.6828796285%, 100% 70.6828796285%, 100% 75.6041870575%, 0% 75.6041870575%);
    transform: translate(-4.5559395431%, 0.107678385%);
  }
  6% {
    clip-path: polygon(0% 25.2306917577%, 100% 25.2306917577%, 100% 33.1118894633%, 0% 33.1118894633%);
    transform: translate(3.2637580654%, 0.0980781236%);
  }
  8% {
    clip-path: polygon(0% 22.6358638298%, 100% 22.6358638298%, 100% 26.7813573968%, 0% 26.7813573968%);
    transform: translate(2.8391832446%, -0.4434081342%);
  }
  10% {
    clip-path: polygon(0% 74.7576656442%, 100% 74.7576656442%, 100% 79.2174027655%, 0% 79.2174027655%);
    transform: translate(-4.0860795355%, -0.3198286952%);
  }
  12% {
    clip-path: polygon(0% 74.1402993607%, 100% 74.1402993607%, 100% 78.7992300482%, 0% 78.7992300482%);
    transform: translate(7.5523247879%, 0.2875507294%);
  }
  14% {
    clip-path: polygon(0% 53.2682166865%, 100% 53.2682166865%, 100% 54.5513145529%, 0% 54.5513145529%);
    transform: translate(6.1942052586%, 0.4839264233%);
  }
  16% {
    clip-path: polygon(0% 12.5619138281%, 100% 12.5619138281%, 100% 22.3155530669%, 0% 22.3155530669%);
    transform: translate(6.6027511573%, -0.3685544501%);
  }
  18% {
    clip-path: polygon(0% 23.0426166479%, 100% 23.0426166479%, 100% 26.5900405373%, 0% 26.5900405373%);
    transform: translate(-0.1945772982%, 0.026406848%);
  }
  20%, 100% {
    clip-path: none;
    transform: none;
  }
}
.glitch::after {
  animation: glitch-after 0.5s linear infinite alternate both;
  content: "";
}
@keyframes glitch-after {
  0% {
    clip-path: polygon(0% 23.4199276201%, 100% 23.4199276201%, 100% 26.2840134148%, 0% 26.2840134148%);
    transform: translate(5.0408547465%, -0.058877041%);
  }
  2% {
    clip-path: polygon(0% 66.989019014%, 100% 66.989019014%, 100% 72.5806253576%, 0% 72.5806253576%);
    transform: translate(-0.0876250078%, 0.0899508498%);
  }
  4% {
    clip-path: polygon(0% 60.3268209949%, 100% 60.3268209949%, 100% 69.0753107216%, 0% 69.0753107216%);
    transform: translate(-6.8824817678%, -0.4108261041%);
  }
  6% {
    clip-path: polygon(0% 89.9503933389%, 100% 89.9503933389%, 100% 99.1330739633%, 0% 99.1330739633%);
    transform: translate(3.6019986773%, 0.100748394%);
  }
  8% {
    clip-path: polygon(0% 80.760806745%, 100% 80.760806745%, 100% 82.4489397384%, 0% 82.4489397384%);
    transform: translate(6.5428907761%, -0.3383761857%);
  }
  10% {
    clip-path: polygon(0% 39.27565829%, 100% 39.27565829%, 100% 44.6580790748%, 0% 44.6580790748%);
    transform: translate(-3.8842538387%, 0.0268567482%);
  }
  12% {
    clip-path: polygon(0% 82.4288554103%, 100% 82.4288554103%, 100% 84.0338946989%, 0% 84.0338946989%);
    transform: translate(-6.2957556245%, -0.2371514695%);
  }
  14% {
    clip-path: polygon(0% 68.9650291078%, 100% 68.9650291078%, 100% 73.1638282162%, 0% 73.1638282162%);
    transform: translate(-2.8597778312%, 0.1536129339%);
  }
  16% {
    clip-path: polygon(0% 50.5413524067%, 100% 50.5413524067%, 100% 54.0193728244%, 0% 54.0193728244%);
    transform: translate(7.8392185332%, 0.0214888149%);
  }
  18% {
    clip-path: polygon(0% 37.606513066%, 100% 37.606513066%, 100% 45.6606285285%, 0% 45.6606285285%);
    transform: translate(-5.0589322052%, 0.2515782303%);
  }
  20%, 100% {
    clip-path: none;
    transform: none;
  }
}
.glitch .channel {
  mix-blend-mode: screen;
}
.glitch .channel::before {
  bottom: 0;
  content: "";
  display: block;
  mix-blend-mode: multiply;
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
}
.glitch .r {
  animation: rgb-shift-r 0.5s steps(1, jump-end) infinite alternate both;
}
@keyframes rgb-shift-r {
  0% {
    transform: translate(1.3518408634%, -0.4410944077%);
  }
  2% {
    transform: translate(1.0848632399%, -0.0960104852%);
  }
  4% {
    transform: translate(0.9729204704%, 0.3297548356%);
  }
  6% {
    transform: translate(-1.4554365707%, -0.2164557287%);
  }
  8% {
    transform: translate(-1.5207855908%, 0.3756010188%);
  }
  10% {
    transform: translate(-1.4167094904%, 0.367004406%);
  }
  12% {
    transform: translate(0.843630458%, -0.0839438427%);
  }
  14% {
    transform: translate(-0.7319433422%, 0.1200925881%);
  }
  16% {
    transform: translate(-0.9327900189%, 0.3017876259%);
  }
  18% {
    transform: translate(-0.2633553033%, 0.2553248867%);
  }
  20%, 100% {
    transform: none;
  }
}
.glitch .r::before {
  background: #f00;
}
.glitch .g {
  animation: rgb-shift-g 0.5s steps(1, jump-end) infinite alternate both;
}
@keyframes rgb-shift-g {
  0% {
    transform: translate(-1.206714101%, 0.4138067107%);
  }
  2% {
    transform: translate(-0.8160450143%, -0.1423355371%);
  }
  4% {
    transform: translate(0.5098975616%, -0.4212768157%);
  }
  6% {
    transform: translate(-1.1612808798%, 0.1495853709%);
  }
  8% {
    transform: translate(0.0683036292%, 0.3337106665%);
  }
  10% {
    transform: translate(-0.4362834894%, -0.1681727294%);
  }
  12% {
    transform: translate(0.5091069051%, 0.3624695729%);
  }
  14% {
    transform: translate(-1.4527576578%, 0.1311238251%);
  }
  16% {
    transform: translate(-0.246687914%, -0.058488771%);
  }
  18% {
    transform: translate(-1.2677473129%, 0.2833582867%);
  }
  20%, 100% {
    transform: none;
  }
}
.glitch .g::before {
  background: #0f0;
}
.glitch .b {
  animation: rgb-shift-b 0.5s steps(1, jump-end) infinite alternate both;
}
@keyframes rgb-shift-b {
  0% {
    transform: translate(1.7436102253%, 0.2408281175%);
  }
  2% {
    transform: translate(0.1335410378%, 0.247420137%);
  }
  4% {
    transform: translate(0.7120697988%, 0.3692707775%);
  }
  6% {
    transform: translate(-1.9284141221%, 0.234149144%);
  }
  8% {
    transform: translate(1.8457986289%, -0.1514252327%);
  }
  10% {
    transform: translate(0.6162977376%, 0.1359166338%);
  }
  12% {
    transform: translate(-1.7062577764%, 0.3426366335%);
  }
  14% {
    transform: translate(-0.5679008386%, -0.2233075151%);
  }
  16% {
    transform: translate(0.2451894633%, 0.2192893556%);
  }
  18% {
    transform: translate(-0.557373323%, -0.1867524738%);
  }
  20%, 100% {
    transform: none;
  }
}
.glitch .b::before {
  background: #00f;
}

.has-animated .port-home-img {
  opacity: 1;
  transition: all 0.1s ease-in-out;  
}


.has-animated:hover .port-home-img {
  filter: grayscale(100%);
  opacity: 1;
  transition: all 0.1s ease-in-out;  
}


.port-home-text {
  background: var(--greybg);
  padding: 25px;
}

.port-home-text h5 {
  color: var(--grey);
  font-size: 14px;
  text-transform: uppercase;
  margin: 0 0 5px 0;
  font-weight: 400;
}

.port-home-text h2 {
  color: var(--white);
  font-size: 20px;
  font-weight: 400;
  margin: 0;
}

@media screen and (max-width: 960px) {
  .masonry {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media screen and (max-width: 640px) {
  .masonry {
    grid-template-columns: 1fr;
  }

  .port-home-img img,
  .masonry-item:nth-child(1) .port-home-img img,
  .masonry-item:nth-child(2) .port-home-img img,
  .masonry-item:nth-child(3) .port-home-img img,
  .masonry-item:nth-child(4) .port-home-img img,
  .masonry-item:nth-child(5) .port-home-img img,
  .masonry-item:nth-child(6) .port-home-img img {
    
  }
}


.home-statement {
  padding: 50px 0;
}

.statement-grid {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-column-gap: 100px;
  grid-row-gap: 100px;
  justify-items: stretch;
  align-items: start;
  margin: 0 auto;
}

.statement-grid h5 {
  font: 18px 'Libre Baskerville', Helvetica , Arial, sans-serif;
  margin: 10px 0 0 0;
  padding: 0;
  color: var(--white);
}


.home-statement-title {
  padding: 0 0 150px 0;
}

.home-statement-title h1 {
  color: var(--white);
  font-size: 35px;
  font-weight: 300;
}

.two-grid {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  justify-items: stretch;
  align-items: inital;
  margin: 15px auto;
}

.two-text-col h3,
.service-text-col h2 {
  font-size: 20px;
  margin: 0 0 10px 0;
  border-bottom: 1px dotted var(--grey);
  display: inline-block;
  padding: 0 5px 5px 5px;
}

.two-text-col ul {
  margin: 15px 15px 30px 15px;
}

.two-text-col li {
  margin: 0 0 5px 0;
  list-style-type: square;
}

.service-home-title {
  display: block;
}

.service-home-title a {
  font-size: 16px;
  margin: 0 0 10px 0;
  border-bottom: 1px dotted var(--grey);
  padding: 0 5px 5px 5px;
}

.home-services a {
  font-size: 16px;
  margin: 0 0 10px 0;
  border-bottom: 1px dotted var(--grey);
  padding: 0 5px 5px 5px;
}

.home-cta {
  background: var(--white);
  padding: 100px 0;
}

.home-cta h2 {
  color: var(--black);
  font-size: 35px;
  font-weight: 300;
}

.cta-grid-alt {
  width: 100%;
  display: grid;
  grid-template-columns: 2fr 1fr;
  grid-column-gap: 100px;
  grid-row-gap: 100px;
  justify-items: stretch;
  align-items: center;
  margin: 0 auto;
}


.big-button-holder {
  position: relative;
  width: 250px;
  height: 250px;
}

.big-button {
  padding: 0;
  background: var(--white);
  color: var(--black);
  font-weight: 600;
  height: 250px;
  display: block;
  width: 250px;
  position: relative;
  border-radius: 50%;
  text-align: center;
  transition: all 0.3s ease-in-out;   
  animation: circle 5s .3s infinite cubic-bezier(1,.015,.295,1.225) alternate;
  -webkit-animation: circle 5s .3s infinite cubic-bezier(1,.015,.295,1.225) alternate;   
}

.big-button-text,
.big-button-text:hover {
  position: absolute;
  top: 115px;
  left: 0;
  right: 0;
  text-align: center;
  margin: 0 auto;
  z-index: 9999;
  color: var(--black);
  font-weight: 600;
  font-size: 18px;
  text-transform: uppercase;
}

.big-button span {
  text-align: center;
  margin: 0 auto;
  vertical-align: middle;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  right: 0;
}
 




@keyframes circle {
  0%  {
    border-radius:50% 50% 50% 50%;
    background: var(--midgrey);
    transform:rotate(0deg);
  }
  
  10% {
    border-radius:0 50% 50% 50%;
    background: var(--grey);
    transform:rotate(0deg);
  }
  
  20%  {
    border-radius:50% 50% 50% 50%;
    background: var(--grey);
    transform:rotate(45deg);
  }
  30%  {
    border-radius:50% 0 50% 50%;
    background:var(--orange);
    transform:rotate(90deg);
  }
  
   40%  {
    border-radius:50% 50% 50% 50%;
        background: var(--grey);
    transform:rotate(45deg);
  }
  
  50%  {
    border-radius:50% 50% 0 50%;
        background: var(--midgrey);
    transform:rotate(90deg);
  }
  
  60%  {
    border-radius:50% 50% 50% 50%;
    background:var(--orange);
    transform:rotate(90deg);
  }
 
 
  70%  {
    border-radius:50% 50% 50% 0;
    background: var(--grey);
    transform:rotate(135deg);
  }
  
  80%   {
    border-radius:50% 50% 50% 50%;
     background: var(--midgrey);
    transform:rotate(90deg);
  }
 
  90% {  
    border-radius:0 50% 50% 50%;
     background: var(--grey);
    transform:rotate(180deg);
  }
  
  100% {  
    border-radius:50% 50% 50% 50%;
     background: var(--midgrey);
    transform:rotate(180deg);
  }
}

.circle {
  animation-name: anitest;
  animation-duration:4s;
  animation-delay:1s;
  animation-iteration-count:infinite;
  animation-timing-function: linear;
  animation-direction:alternate;
  -webkit-animation: anitest 4s 1s infinite linear alternate;
    -moz-animation: anitest 4s 1s infinite linear alternate;
    -ms-animation: anitest 4s 1s infinite linear alternate;
    -o-animation: anitest 4s 1s infinite linear alternate;
    animation: anitest 4s 1s infinite linear alternate;
} 

.big-button:hover {
  padding: 0;
  background: var(--grey);
  color: var(--black);
  transition: all 0.3s ease-in-out;    
}

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

footer {

}


/* 
==========================================================================
MEDIA QUERIES
==========================================================================
*/



@media screen and (max-width: 960px) {

}


@media screen and (max-width: 768px) {

}


@media screen and (max-width: 524px) {

}


@media screen and (max-width: 480px) {

}


@media screen and (max-width: 320px) {

 .container {
  min-width:240px;
  width:100%;
 }
 
}
/* ==========================================================
   CODEPEN-STYLE IMAGE GLITCH OVERRIDE
   Keeps the normal image visible, then briefly reveals clipped
   duplicated image slices + fine scanline/static noise.
   ========================================================== */

.port-home-img.glitch {
  position: relative;
  display: block;
  overflow: hidden;
  isolation: isolate;
  height: auto !important;
  background: #000;
  background-image: none !important;
  background-size: cover;
}

.port-home-img.glitch img {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  height: 100%;
  max-height: 325px;
  object-fit: cover;
  filter: grayscale(100%) contrast(1.08);
  opacity: 0.72;
  transform: translate3d(0, 0, 0) scale(1);
  transition: none;
}

.masonry-item.is-colour .port-home-img.glitch img {
  filter: grayscale(0%) contrast(1);
  opacity: 1;
  transform: none;
}

.port-home-img.glitch::before,
.port-home-img.glitch::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  background-image: var(--glitch-img);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  opacity: 0;
}

/* subtle blocky scan/static layer, not a white box */
.port-home-img.glitch .glitch-layer:first-of-type {
  position: absolute;
  inset: 0;
  z-index: 4;
  pointer-events: none;
  opacity: 0;
  mix-blend-mode: screen;
  background:
    repeating-linear-gradient(
      0deg,
      rgba(255,255,255,0.16) 0 1px,
      rgba(255,255,255,0) 1px 7px
    ),
    repeating-linear-gradient(
      90deg,
      rgba(255,255,255,0.08) 0 1px,
      rgba(255,255,255,0) 1px 11px
    ),
    linear-gradient(
      90deg,
      rgba(0,255,255,0.24),
      rgba(255,0,80,0.18)
    );
}

.port-home-img.glitch .glitch-layer:nth-of-type(2),
.port-home-img.glitch .glitch-layer:nth-of-type(3) {
  display: none;
}

.masonry-item.is-glitching .port-home-img.glitch::before {
  opacity: 0.95;
  filter: grayscale(100%) contrast(1.25);
  animation: glitch-slices-a 0.9s steps(1, end) both;
}

.masonry-item.is-glitching .port-home-img.glitch::after {
  opacity: 0.85;
  filter: grayscale(100%) contrast(1.3);
  animation: glitch-slices-b 0.9s steps(1, end) both;
}

.masonry-item.is-glitching .port-home-img.glitch .glitch-layer:first-of-type {
  animation: glitch-static-blocks 0.9s steps(1, end) both;
}

@keyframes glitch-slices-a {
  0% {
    clip-path: polygon(0 12%, 100% 12%, 100% 20%, 0 20%);
    transform: translate3d(-14px, -2px, 0);
  }
  10% {
    clip-path: polygon(0 66%, 100% 66%, 100% 73%, 0 73%);
    transform: translate3d(18px, 1px, 0);
  }
  20% {
    clip-path: polygon(0 34%, 100% 34%, 100% 42%, 0 42%);
    transform: translate3d(-22px, 0, 0);
  }
  30% {
    clip-path: polygon(0 78%, 100% 78%, 100% 86%, 0 86%);
    transform: translate3d(12px, 2px, 0);
  }
  40% {
    clip-path: polygon(0 48%, 100% 48%, 100% 54%, 0 54%);
    transform: translate3d(-9px, -1px, 0);
  }
  50%, 100% {
    opacity: 0;
    clip-path: inset(0);
    transform: none;
  }
}

@keyframes glitch-slices-b {
  0% {
    clip-path: polygon(0 24%, 100% 24%, 100% 29%, 0 29%);
    transform: translate3d(10px, 1px, 0);
  }
  12% {
    clip-path: polygon(0 55%, 100% 55%, 100% 61%, 0 61%);
    transform: translate3d(-18px, -1px, 0);
  }
  24% {
    clip-path: polygon(0 7%, 100% 7%, 100% 14%, 0 14%);
    transform: translate3d(22px, 2px, 0);
  }
  36% {
    clip-path: polygon(0 88%, 100% 88%, 100% 96%, 0 96%);
    transform: translate3d(-12px, 0, 0);
  }
  50%, 100% {
    opacity: 0;
    clip-path: inset(0);
    transform: none;
  }
}

@keyframes glitch-static-blocks {
  0% {
    opacity: 0.5;
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
    transform: translate3d(0, 0, 0);
  }
  10% {
    opacity: 0.72;
    clip-path: polygon(0 18%, 100% 18%, 100% 21%, 0 21%, 0 36%, 100% 36%, 100% 39%, 0 39%, 0 74%, 100% 74%, 100% 78%, 0 78%);
    transform: translate3d(8px, 0, 0);
  }
  20% {
    opacity: 0.45;
    clip-path: polygon(0 9%, 100% 9%, 100% 13%, 0 13%, 0 52%, 100% 52%, 100% 56%, 0 56%, 0 84%, 100% 84%, 100% 87%, 0 87%);
    transform: translate3d(-10px, 0, 0);
  }
  30% {
    opacity: 0.65;
    clip-path: polygon(0 28%, 100% 28%, 100% 31%, 0 31%, 0 63%, 100% 63%, 100% 67%, 0 67%);
    transform: translate3d(14px, 0, 0);
  }
  45%, 100% {
    opacity: 0;
    clip-path: inset(0);
    transform: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  .port-home-img.glitch::before,
  .port-home-img.glitch::after,
  .port-home-img.glitch .glitch-layer:first-of-type {
    animation: none !important;
    opacity: 0 !important;
  }
}




.navigation__checkbox {
  display: none;
}

/* MENU BUTTON */
.navigation__button {
  position: fixed;
  top: 28px;
  right: 28px;

  width: 50px;
  height: 50px;

  z-index: 2000;

  display: flex;
  align-items: center;
  justify-content: center;

  cursor: pointer;
  background: transparent;
}

/* EXPANDING BACKGROUND */
.navigation__background {
  position: fixed;
  top: 25px;
  right: 25px;

  width: 50px;
  height: 50px;

  border-radius: 50%;
  background: #2e3a96;

  z-index: 1000;

  transform: scale(0);
  transform-origin: center;

  transition: transform 0.8s cubic-bezier(0.86, 0, 0.07, 1);
}

/* NAV OVERLAY */
.navigation__nav {
  position: fixed;
  inset: 0;

  width: 100%;
  height: 100vh;

  z-index: 1500;

  opacity: 0;
  visibility: hidden;

  transition:
    opacity 0.3s ease,
    visibility 0s linear 0.45s;
}

/* OPEN NAV */
.navigation__checkbox:checked ~ .navigation__background {
  transform: scale(90);
}

.navigation__checkbox:checked ~ .navigation__nav {
  opacity: 1;
  visibility: visible;

  transition:
    opacity 0.3s ease,
    visibility 0s;
}

/* MENU LIST */
.navigation__list {
  position: absolute;
  top: 50%;
  left: 50%;

  transform: translate(-50%, -50%);

  list-style: none;
  text-align: center;
  width: 100%;
}

/* MENU ITEMS */
.navigation__item {
  margin: 20px 0;

  opacity: 0;
  transform: translateX(120px);

  transition:
    opacity 0.45s ease,
    transform 0.45s ease;
}

/* OPEN ANIMATION */
.navigation__checkbox:checked ~ .navigation__nav .navigation__item {
  opacity: 1;
  transform: translateX(0);
}

/* OPEN STAGGER */
.navigation__item:nth-child(1) {
  transition-delay: 0.08s;
}

.navigation__item:nth-child(2) {
  transition-delay: 0.14s;
}

.navigation__item:nth-child(3) {
  transition-delay: 0.2s;
}

.navigation__item:nth-child(4) {
  transition-delay: 0.26s;
}

.navigation__item:nth-child(5) {
  transition-delay: 0.32s;
}

/* CLOSE STAGGER */
.navigation__checkbox:not(:checked) ~ .navigation__nav .navigation__item:nth-child(1) {
  transition-delay: 0.32s;
}

.navigation__checkbox:not(:checked) ~ .navigation__nav .navigation__item:nth-child(2) {
  transition-delay: 0.26s;
}

.navigation__checkbox:not(:checked) ~ .navigation__nav .navigation__item:nth-child(3) {
  transition-delay: 0.2s;
}

.navigation__checkbox:not(:checked) ~ .navigation__nav .navigation__item:nth-child(4) {
  transition-delay: 0.14s;
}

.navigation__checkbox:not(:checked) ~ .navigation__nav .navigation__item:nth-child(5) {
  transition-delay: 0.08s;
}

/* LINKS */
.navigation__link {
  display: inline-block;

  font-size: 50px;

  font-weight: 700;
  line-height: 1;

  color: #fff;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    transform 0.2s ease,
    opacity 0.2s ease;
}

.navigation__link:hover {
  
}

.navigation__link span {
  margin-right: 16px;
  opacity: 0.4;
}

/* HAMBURGER ICON */
.navigation__icon {
  position: relative;

  width: 30px;
  height: 3px;

  background: #fff;
  display: block;
}

.navigation__icon::before,
.navigation__icon::after {
  content: "";
  position: absolute;
  left: 0;

  width: 30px;
  height: 3px;

  background: #fff;

  transition:
    transform 0.2s ease,
    top 0.2s ease;
}

.navigation__icon::before {
  top: -10px;
}

.navigation__icon::after {
  top: 10px;
}

/* ACTIVE ICON */
.navigation__checkbox:checked + .navigation__button .navigation__icon {
  background: transparent;
}

.navigation__checkbox:checked + .navigation__button .navigation__icon::before {
  top: 0;
  transform: rotate(45deg);
}

.navigation__checkbox:checked + .navigation__button .navigation__icon::after {
  top: 0;
  transform: rotate(-45deg);
}

.hold {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.hold-wrap {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px 20px;
}