/*
Theme Name: Jupago Portfolio
Theme URI: http://underscores.me/
Author: jupago
Author URI: http://jupago.com
Description: Designer who codes
Version: 2.1.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: jupago
Tags:©

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned with others.

Jupago Portfolio is based on Underscores http://underscores.me/, (C) 2012-2015 Automattic, Inc.
Underscores is distributed under the terms of the GNU GPL v2 or later.

Normalizing styles have been helped along thanks to the fine work of
Nicolas Gallagher and Jonathan Neal http://necolas.github.com/normalize.css/
*/

/*--------------------------------------------------------------
# Normalize
--------------------------------------------------------------*/
html { font-family: sans-serif; -webkit-text-size-adjust: 100%; -ms-text-size-adjust: 100%; margin: 0; height: 100%; } body { margin: 0; min-height: 100%; } article,aside,details,figcaption,figure,footer,header,main,menu,nav,section,summary { display: block; } audio,canvas,progress,video { display: inline-block; vertical-align: baseline; } audio:not([controls]) { display: none; height: 0; } [hidden],template { display: none; } a { background-color: transparent; } a:active, a:hover { outline: 0; } abbr[title] { border-bottom: 1px dotted; } b, strong { font-weight: bold; } dfn { font-style: italic; } h1 { font-size: 2em; margin: 0.67em 0; } mark { background: #ff0; color: black } small { font-size: 80%; } sub, sup { font-size: 75%; line-height: 0; position: relative; vertical-align: baseline; } sup { top: -0.5em; } sub { bottom: -0.25em; } img { border: 0; } svg:not(:root) { overflow: hidden; } figure { margin:0; } hr { box-sizing: content-box; height: 0; } pre { overflow: auto; } code,kbd,pre,samp { font-family: monospace, monospace; font-size: 1em; } button,input,optgroup,select,textarea {color: inherit;font: inherit;margin: 0;} button {overflow: visible;} button,select { text-transform: none;} button,html input[type="button"],input[type="reset"],input[type="submit"] {-webkit-appearance: button;cursor: pointer;} button[disabled],html input[disabled] {cursor: default;} button::-moz-focus-inner,input::-moz-focus-inner {border: 0;padding: 0;} input {line-height: normal;} input[type="checkbox"],input[type="radio"] {box-sizing: border-box;padding: 0;} input[type="number"]::-webkit-inner-spin-button,input[type="number"]::-webkit-outer-spin-button {height: auto;} input[type="search"] {-webkit-appearance: textfield;box-sizing: content-box;} input[type="search"]::-webkit-search-cancel-button,input[type="search"]::-webkit-search-decoration {-webkit-appearance: none;} fieldset {border: 1px solid #c0c0c0;margin: 0 2px;padding: 0.35em 0.625em 0.75em;} legend {border: 0;padding: 0;} textarea {overflow: auto;} optgroup {font-weight: bold;} table {border-collapse: collapse;border-spacing: 0;} td,th {padding: 0;}

/*--------------------------------------------------------------
# Typography
--------------------------------------------------------------*/

/***************************************************************
These styles are subject to the following license agreement(s):

https://store.typenetwork.com/cart/eula/occupant-fonts
https://store.typenetwork.com/cart/eula/occupant-fonts
***************************************************************/

html {
	font-size: 10px; /* reset */
}

body {
	color: var(--jpblack);
	font-family: 'Poppins', sans-serif;
	font-style: Normal;
	font-weight: 200;
	line-height: 1.5;
	font-size: 1rem;
	margin: 0;
	/*  */
	background: var(--jpgray);
}

button,
input,
select,
textarea {
	color: var(--jpblack);
	font-style: Normal;
	font-size: 1.2rem;
}

b, strong {
    font-style: Normal;
    font-weight: 500;
}

h1, h2, h3, h4, h5, h6 {
	font-family: 'Poppins', sans-serif;
	font-style: normal;
	font-weight: 300;
	line-height: 1.2;
}

h4 {
	margin: 2rem 0 1rem;
}

h1 strong, h1 b,
h2 strong, h2 b,
h3 strong, h3 b,
h4 strong, h4 b,
h5 strong, h5 b,
h6 strong, h6 b {
	font-family: 'Poppins', sans-serif;
  font-style: normal;
  font-weight: 800;
	clear: both;
}

h1 { font-size: 4rem; line-height: 1; }
h2 { font-size: 3.2rem; line-height: 1; margin: auto; }
h3 { font-size: 2.4rem; }
h4 { font-size: 1.6rem; }
p  {
  font-size: 1.6rem;
  margin-bottom: 1.5em;
  max-width: 70rem
}

@media all and (min-width:800px) {
	h1 { font-size: 6rem; }
	h2 { font-size: 4.4rem; }
	h3 { font-size: 4rem; }
	h4 { font-size: 2.2rem; }
	p  {
    font-size: 1.8rem;
  }
}

dfn, cite, em, i {
	font-style: italic;
}

blockquote {
	margin: 2rem;
	background: white;
	padding: 2rem;
	border-radius: 1rem
}

blockquote p {
	margin: 0;
}

blockquote p + p {
	margin-top : 2rem;
}


address {
	margin: 0 0 1.5em;
}

pre {
	background: #f6f6f6;
	font-family: "Courier 10 Pitch", Courier, monospace;
	font-size: 15px;
	font-size: 0.9375rem;
	line-height: 1.6;
	margin-bottom: 1.6em;
	max-width: 100%;
	overflow: auto;
	padding: 1.6em;
}

code, kbd, tt, var {
	font-family: Monaco, Consolas, "Andale Mono", "DejaVu Sans Mono", monospace;
	font-size: 15px;
	font-size: 0.9375rem;
}

abbr, acronym {
	border-bottom: 1px dotted #666666;
	cursor: help;
}

mark, ins {
	background: #fff9c0;
	text-decoration: none;
}

big {
	font-size: 125%;
}

/*--------------------------------------------------------------
# Elements
--------------------------------------------------------------*/
html {
	box-sizing: border-box;
}

*,
*:before,
*:after { /* http://css-tricks.com/inheriting-box-sizing-probably-slightly-better-best-practice/ */
	box-sizing: inherit;
}

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

blockquote,
q {
	quotes: "" "";
}

hr {
	background-color: var(--jppink);
	border: 0;
	height: 1px;
	margin-bottom: 1.5em;
}

ul,
ol {
	margin: 0 0 1.5em 1em;
	padding: 0;
}

ul {
	list-style: disc;
}

ol {
	list-style: decimal;
}

li { margin-bottom: 5px; }

li > ul,
li > ol {
	margin-bottom: 0;
	margin-left: 1.5em;
}

li::marker {
	color: var(--jppink)
}

dt {
	font-weight: bold;
}

dd {
	margin: 0 1.5em 1.5em;
}

img {
	height: auto; /* Make sure images are scaled correctly. */
	max-width: 100%; /* Adhere to container width. */
}

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

/*--------------------------------------------------------------
# Forms
--------------------------------------------------------------*/
button,
input[type="button"],
input[type="reset"],
input[type="send"] {
	border: none;
    border-radius: 0;
    background: var(--jppink);
    box-shadow: none;
    color: var(--jpgray);
    font-size: 12px;
    font-size: 0.75rem;
    line-height: 1;
    padding: 10px 60px;
    text-shadow: none;
    letter-spacing: 1px;
    text-transform: uppercase;
    transform: background 0.3s;
}

button:hover,
input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover
button:focus,
input[type="button"]:focus,
input[type="reset"]:focus,
input[type="submit"]:focus,
button:active,
input[type="button"]:active,
input[type="reset"]:active,
input[type="submit"]:active {
    background:  var(--jpblack);
    color: var(--jppink);
}

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
textarea {
	color: #666666;
	border: 1px solid #f6f6f6;
	border-radius: 0;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
textarea:focus {
	color: var(--jpblack);
}

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"] {
	padding: 3px;
}

textarea {
	padding-left: 3px;
	width: 100%;
}

/*--------------------------------------------------------------
# Navigation
--------------------------------------------------------------*/
/*--------------------------------------------------------------
## Links
--------------------------------------------------------------*/
a,
a:visited {
	color: var(--jpblue);
	text-decoration: none;
    cursor: url("images/Jupago_cursor.png") 6 8, auto;
}

a:hover,
a:focus,
a:active {
	text-decoration:underline;
}

a:focus {
	outline: thin dotted;
}

a:hover,
a:active {
	outline: 0;
}

button a {
    color: #14171E !important;
}

/*--------------------------------------------------------------
## Menus
--------------------------------------------------------------*/
.main-navigation {
    font-size: 1.2rem;
    text-align: right;
}

.main-navigation ul {
	display: flex;
    list-style: none;
    margin: 0;
    padding: 0;
    flex-wrap: wrap;
    max-width: 160px;
}

.main-navigation li {
	width: 100%;
	margin: 0;
}

@media (max-width:700px) {

	.jupago-logo {
	    margin: auto 0 auto auto;
		transform: scale(0.6);
	}

	.header_logo_wrapper {
    	width: 40vw;
    	margin: auto 0;
	}

	.main-navigation ul {
	    width: 55vw;
	}

}

.header_logo_wrapper {
	display: flex;
    justify-content: space-between;
	width: min(180ch, 100vw - 4rem);
    padding: 1.5rem 0 3rem;
    margin: auto;
}

@media (min-width:700px) {

	.main-navigation {
		font-size: 1.3rem;
		margin: auto 0;
	}

	.main-navigation ul {
		flex-wrap: nowrap;
		max-width: 100%;
	}

	.main-navigation li {
		width: auto;
		text-align: center;
	}
}

.main-navigation a {
	position: relative;
	display: block;
    text-decoration: none;
    color: var(--jppink);
    margin: 0 0 0 20px;
	padding: 4px 0;
    text-transform: uppercase;
    letter-spacing: 3px;
    transition: 0.5s ease-in-out;
}

.main-navigation a:hover {
	color: var(--jpblue);
}


.main-navigation a:after {
	position: absolute;
    content: '';
    display: block;
    width: 100%;
    height: 2px;
    left: 0;
    bottom: -2px;
    background: var(--jppink);
    opacity: 0;
    transform: scaleX(0);
    transition: all .2s ease;
}

.main-navigation a:hover:after {
    opacity: 1;
    transform: scaleX(1);
}

.main-navigation .current_page_item > a,
.main-navigation .current-menu-item > a,
.main-navigation .current_page_ancestor > a,
.main-navigation .current-menu-ancestor > a {
	color: var(--jpblue);
}

.site-main .comment-navigation,
.site-main .posts-navigation,
.site-main .post-navigation {
    background: var(--jpblack);
	max-width: 780px;
    padding: 20px 40px;
    margin: 0 auto 1.5em;
    overflow: hidden;
	font-size: 1.4rem;
}

.comment-navigation .nav-previous,
.posts-navigation .nav-previous,
.post-navigation .nav-previous {
	float: left;
	width: 50%;
}

.comment-navigation .nav-next,
.posts-navigation .nav-next,
.post-navigation .nav-next {
	float: right;
	text-align: right;
	width: 50%;
}

.site-main .comment-navigation a,
.site-main .posts-navigation a,
.site-main .post-navigation a{
color: var(--jpgray)
}

.cat-links {
 display: none;  /* CATEGORIES ON YOUR POST FOOTER OR NOT!?  */
}

/*--------------------------------------------------------------
# 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:focus {
	background-color: var(--jpgray);
	border-radius: 3px;
	box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
	clip: auto !important;
	color: var(--jpblack);
	display: block;
	font-size: 14px;
	font-size: 0.875rem;
	font-weight: bold;
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000; /* Above WP toolbar. */
}

/* Do not show the outline on the skip link target. */
#content[tabindex="-1"]:focus {
	outline: 0;
}

/*--------------------------------------------------------------
# Clearings
--------------------------------------------------------------*/
.clear:before,
.clear:after,
.entry-content:before,
.entry-content:after,
.comment-content:before,
.comment-content:after,
.site-content:before,
.site-content:after,
.site-footer:before,
.site-footer:after {
	content: "";
	display: table;
	table-layout: fixed;
}

.clear:after,
.entry-content:after,
.comment-content:after,
.site-content:after,
.site-footer:after {
	clear: both;
}

/*--------------------------------------------------------------
## Color System
--------------------------------------------------------------*/
:root { 
	--jpblue:  #2a93cf; 
	--jpblue: oklch(0.6 0.2 247); 
}
:root { 
	--jppink:  #ff114f; 
	--jppink:  oklch(0.7 0.3 18.5); 

}
:root { --jpgray:  #ebeff2; }
:root { --jpblack: #14171E; }

/* color shortcodes */
.white {
	color: var(--jpgray);
}

.pink {
	color: var(--jppink)
}

.blue,
.pink a,
.white a {
	color: var(--jpblue)
}

.black {
	color: var(--jpblack);
}

.dark-bg {
	background-color: var(--jpblack);
	color: var(--jpgray);
}

.lite-bg,
.white_wrapper {
	background-color: var(--jpgray);
	color: var(--jpblack);
}

.white_wrapper {
	padding: 15px;
}

/*--------------------------------------------------------------
## CSS grid system
--------------------------------------------------------------*/

/* implicit */
colspan2 { grid-column: span 2 }
colspan3 { grid-column: span 3 }
colspan4 { grid-column: span 4 }
colspan5 { grid-column: span 5 }
colspan6 { grid-column: span 6 }
colspan7 { grid-column: span 7 }
colspan8 { grid-column: span 8 }
colspan9 { grid-column: span 9 }

rowspan2 { grid-row: span 2 }
rowspan3 { grid-row: span 3 }
rowspan4 { grid-row: span 4 }
rowspan5 { grid-row: span 5 }
rowspan6 { grid-row: span 6 }
rowspan7 { grid-row: span 7 }
rowspan8 { grid-row: span 8 }
rowspan9 { grid-row: span 9 }

/* explicit */
colatob { grid-column: 1 }
colatoc { grid-column: 1 / span 2  }
colatod { grid-column: 1 / span 3  }
colatoe { grid-column: 1 / span 4  }
colatof { grid-column: 1 / span 5  }
colatog { grid-column: 1 / span 6  }
colatoh { grid-column: 1 / span 7  }
colatoi { grid-column: 1 / span 8  }
colatoj { grid-column: 1 / span 9  }

colbtoc { grid-column: 2 }
colbtod { grid-column: 2 / span 2  }
colbtoe { grid-column: 2 / span 3  }
colbtof { grid-column: 2 / span 4  }
colbtog { grid-column: 2 / span 5  }
colbtoh { grid-column: 2 / span 6  }
colbtoi { grid-column: 2 / span 7  }
colbtoj { grid-column: 2 / span 8  }

colctod { grid-column: 3 }
colctoe { grid-column: 3 / span 2  }
colctof { grid-column: 3 / span 3  }
colctog { grid-column: 3 / span 4  }
colctoh { grid-column: 3 / span 5  }
colctoi { grid-column: 3 / span 6  }
colctoj { grid-column: 3 / span 7  }

coldtoe { grid-column: 4 }
coldtof { grid-column: 4 / span 2  }
coldtog { grid-column: 4 / span 3  }
coldtoh { grid-column: 4 / span 4  }
coldtoi { grid-column: 4 / span 5  }
coldtoj { grid-column: 4 / span 6  }

coletof { grid-column: 5 }
coletog { grid-column: 5 / span 2  }
coletoh { grid-column: 5 / span 3  }
coletoi { grid-column: 5 / span 4  }
coletoj { grid-column: 5 / span 5  }

colftog { grid-column: 6 }
colfeoh { grid-column: 6 / span 2  }
colfeoi { grid-column: 6 / span 3  }
colfeoj { grid-column: 6 / span 4  }

colgtoh { grid-column: 7 }
colgtoi { grid-column: 7 / span 2  }
colgtoj { grid-column: 7 / span 3  }

colhtoi { grid-column: 8 }
colhtoj { grid-column: 8 / span 2  }

colitoj { grid-column: 8  }

/*--------------------------------------------------------------
## portfolio
--------------------------------------------------------------*/

/* about to slow this down with a variable font! */
@font-face {
    /* src: url('variablefonts/Fit-Variable.woff2') format("woff2");
    font-family: FitVF;
    font-style: normal;
    font-weight: normal;
	font-display: block; */
}

/* Portfolio page */
.portfolio-wrapper {
	display: grid;
}

/*  GLOBAL */
.portfolio-project {
	position: relative;
	display: grid;
    grid-template-columns: 1fr;
	grid-template-rows: repeat(auto-fill, minmax(30px, auto));
    padding: 60px 20px 150px 20px;
    margin: 0 auto;
	width: 100%;
}

.portfolio-project:after {
	position: absolute;
    content: "";
    width: 100%;
    height: 14vw;
    bottom: -7vw;
    background: var(--jpblue);
    transform: skewY(4deg);
	    z-index: 1;
}

.portfolio-project:nth-of-type(even):after {
    transform: skewY(-4deg);
}

.portfolio-project:nth-of-type(2):after,
.portfolio-project:nth-of-type(5):after,
.portfolio-project:nth-of-type(10):after {
	background: var(--jpgray);
}

.portfolio-project:nth-of-type(3):after,
.portfolio-project:nth-of-type(6):after {
    background: #ffffff;
}

.portfolio-project:nth-of-type(4):after,
.portfolio-project:nth-of-type(7):after,
.portfolio-project:nth-of-type(9):after {
    background: var(--jpblack);
}

.portfolio-project:nth-of-type(8):after {
    background: var(--jpblue);
}

.project-header2 {
	font-style: normal;
	font-weight: 800;
    font-size: 16vmax;
	font-size: calc(1rem + 5vmin);
	line-height: 1;
	color: var(--jpblue);
	margin: 0 0 50px;
	word-break: break-word;
	grid-column: 1;
	grid-row: 2;
}

.project-header4 {
	z-index: 4;
    color: var(--jppink);
    line-height: 1.2;
    text-transform: uppercase;
    margin: 0 0 25px 0;
    letter-spacing: 1px;
}

.project-image-wrapper {
	z-index: 4;
	grid-column: 1;
}

.project-blurb {
	padding-bottom: 25px;
	z-index: 5;
	grid-column: 1;
}

.project-bgimage {
    background-size: 300px;
    background-position: bottom right;
    height: 100%;
    background-repeat: repeat-y;
}

.project-bgimage-wrapper {
    z-index: 1;
    grid-column: 1 / -1;
    grid-row: 1 / -1;
}

/*  project styling */
.portfolio-project:nth-of-type(4),    /* AE */
.portfolio-project:nth-of-type(7),    /* WGH */
.portfolio-project:nth-of-type(9)  { /* AUDNC */
	background-color: var(--jpblack);
}

.portfolio-project:nth-of-type(1),
.portfolio-project:nth-of-type(8) {    /* FCH */
	background-color: var(--jpblue);
}

.portfolio-project:nth-of-type(1) .project-blurb,  /* FCH */
.portfolio-project:nth-of-type(4) .project-blurb,  /* AE */
.portfolio-project:nth-of-type(7) .project-blurb,  /* WGH */
.portfolio-project:nth-of-type(9) .project-blurb { /* AUDNC */
	color: var(--jpgray);
}

.portfolio-project:nth-of-type(3), /* EASCO */
.portfolio-project:nth-of-type(6) { /* Gil Noble */
	background-color: #ffffff;
}

.portfolio-project:nth-of-type(1) .project-image-wrapper,
.portfolio-project:nth-of-type(8) .project-image-wrapper {
	text-align: center;
}

.portfolio-project:nth-of-type(1) .project-image-wrapper img,
.portfolio-project:nth-of-type(8) .project-image-wrapper img {
	max-width: 70%;
}

.portfolio-project:nth-of-type(7) .project-image-wrapper {
	margin-left: -100px;
}

@media (min-width:700px) {
	.portfolio-project {
		grid-template-columns: repeat(12, 1fr);
    	grid-template-rows: 10vw auto auto 60px auto 3vw auto auto auto 5vw;
    	padding: 10vw 0 0 0;
	}

	.portfolio-project:nth-of-type(1) {
		padding: 0;
	}

	.project-header2 {
		grid-row: 3;
	    grid-column: 2 / span 10;
	    margin: 0;
	}

	.project-header4 {
        grid-row: 2;
        grid-column: 2 / span 10;
		text-align: center;
	}

	p.project-descripion {
		margin: 0;
	}

	.project-blurb {
	    grid-row: 5;
	}

	/* the image */
	.portfolio-project:nth-of-type(1) .project-image-wrapper,
	.portfolio-project:nth-of-type(8) .project-image-wrapper {
		grid-column: 2 / span 6; grid-row: 5;
		padding: 0 25px;
	}

	.portfolio-project:nth-of-type(2) .project-image-wrapper {
		grid-column: 2 / 12; grid-row: 5;
	}

	.portfolio-project:nth-of-type(4) .project-image-wrapper {
		grid-column: 7 / 12; grid-row: 4 / span 5;
		padding: 0 25px;
	}

	.portfolio-project:nth-of-type(3) .project-image-wrapper,
	.portfolio-project:nth-of-type(5) .project-image-wrapper {
		grid-column: 7 / span 5; grid-row: 5;
		margin-top: -50px; padding: 0 25px;
	}

	.portfolio-project:nth-of-type(6) .project-image-wrapper {
		grid-column: 1 / -1; grid-row: 4 / span 2;
	}

	.portfolio-project:nth-of-type(7) .project-image-wrapper {
		grid-row: 5; grid-column: 1 / span 7;
		margin-left: -8vw; margin-top: -50px;
	}

	.portfolio-project:nth-of-type(9) .project-image-wrapper {
		grid-row: 5; grid-column: 3 / span 8;
	}

	/*TDC  */
	.portfolio-project:nth-of-type(10) .project-image-wrapper {
		grid-row: 5; grid-column: 3 / span 4;
	}

	/* ------ the blurb ------ */
	.portfolio-project:nth-of-type(1) .project-blurb,
	.portfolio-project:nth-of-type(7) .project-blurb,
	.portfolio-project:nth-of-type(8) .project-blurb,
	.portfolio-project:nth-of-type(10) .project-blurb {
		grid-column: 8 / span 4;
	}

	/* bottom center  */
	.portfolio-project:nth-of-type(2) .project-blurb,
	.portfolio-project:nth-of-type(9) .project-blurb {
		grid-column: 2 / 12; grid-row: 7;
	    max-width: 600px;
	    margin: 0 auto;
	}

	.portfolio-project:nth-of-type(3) .project-blurb,
	.portfolio-project:nth-of-type(4) .project-blurb,
	.portfolio-project:nth-of-type(5) .project-blurb,
	.portfolio-project:nth-of-type(6) .project-blurb  {
		grid-column: 2 / span 4;
	}
}


.portintro-wrapper {
	background: var(--jpblack);
	display: grid;
	position: relative;
	padding-bottom: 20vw;
	margin: 0 -2rem;
}


.portintro-wrapper:after {
	position: absolute;
    content: "";
    width: 100%;
    height: 14vw;
    bottom: -7vw;
    background: var(--jpgray);
    transform: skewY(-4deg);
}

.portfolio-summary-wrapper {
    color: var(--jpgray);
    display: grid;
    position: relative;
    padding: 0 0 20vw;
    margin: auto;
}

.portfolio-summary-wrapper:after {
	position: absolute;
    /* content: ""; */
    width: 100%;
    height: 14vw;
    bottom: -7vw;
    background: var(--jpblue);
    transform: skewY(-4deg);
}

.portfolio-summary {
	max-width: 800px;
    padding: 0 20px;
    margin: auto;
}


.portfolio-intro {
	color: var(--jpgray);
	padding: 8vw 0 10rem;
	margin: auto;
}

.portfolio-item {
    flex: 1 1 400px;
    margin: 15px;
}

.portfolio-header {
	border-top: solid 2px var(--jpgray);
    margin: 20px 15px;
	padding-top: 10px;
}

.portfolio-credits {
    font-size: 1.2rem;
}

.portfolio-intro h1 {
	font-size: 8vw;
	font-weight: 800
}

.portfolio-summary li {
	font-size: 2.4rem;
}

.portfolio-summary h4 {
	border-top: dashed 1px var(--jppink);
	padding-top: 1rem
}

/* variable header */
h1.snug {
	/* font-family: snug-variable, sans-serif; */
	font-family: scale-variable, "scale-variable", sans-serif;
	font-variation-settings: "wdth" 60, "wght" 400;
	font-size: calc(1.2rem + 14vw);
	font-weight: normal;
	color: var(--jppink);
	line-height: .85;
	margin: 0;
	display: grid;
	grid-auto-rows: auto;
	/* transform: skewY(-4deg); */
	animation: hue 30s infinite alternate;
}

/* @keyframes hue {
	from {
		filter: hue-rotate(0deg);
	}
	to {
		filter: hue-rotate(360deg);
	}
} */


h1.snug .row {
	position: relative;
	display: flex;
	align-items: baseline;
	gap: .2ch;
}

.snug .row3 {
	margin-block: 1rem;
}

.snug .row:before, 
.snug .row:after {
	width: 100%;
	right: 0;
	height: 1px;
	content: "";
	position: absolute;
	border-bottom: dashed 1px var(--jpblue);
	z-index: 1;
}

.snug .row:before {
	bottom: 20.5%;
}

.snug .row:after {
	top: 10%;
}

.snug .row2:before,
.snug .row2:after { border-bottom-color: var(--jppink);}


.snug .IM {
	font-variation-settings: "wdth" 50, "wght" 400;
}

.snug .A {
	font-variation-settings: "wdth" 50, "wght" 200;
}

.snug .BSD {
		font-variation-settings: "wdth" 175, "wght" 200;
		font-size: calc(1.2rem + 5vw);
		margin-left: auto;
}

.snug .JP  {
	font-variation-settings: "wdth" 72, "wght" 300;
}

.snug .NYC {
font-variation-settings: "wdth" 50, "wght" 900;
}

.snug .Web  {
	font-variation-settings: "wdth" 50, "wght" 200;
	/* filter: hue-rotate(180deg); */
}

.snug .DES  {
	font-variation-settings: "wdth" 50, "wght" 900;
	/* filter: hue-rotate(180deg); */
}

/* 
	span.JP:before {
	    color: rgba(0,0,0,0.4);
	    content: attr(shadow);
	    right: 0;
	    bottom: 0;
	    position: absolute;
	    text-shadow: none;
	    transform-origin: top right;
		transform: scale(1.04) rotateX(10deg) rotateY(40deg);
	    z-index: -1;
			transition: 0.5s ease-in-out;
	}

	.portfolio-intro h1:hover span.JP:before {
	}

     span.WD:before {
	    color: rgba(0,0,0,0.4);
	    content: attr(shadow);
	    left: 0;
	    position: absolute;
	    text-shadow: none;
	    transform-origin: bottom left;
	     transform: scale(1.04) rotateX(10deg) rotateY(16deg); 
		transform: scale(1.04) rotateX(10deg) rotateY(36deg);
	    z-index: -1;
		transition: 0.5s ease-in-out;
	} */


	.shadow-bk {
		text-shadow:
			10px 10px 0 var(--jpblack),
			-3px -3px 0 var(--jpblack),
			 3px -3px 0 var(--jpblack),
			-3px  3px 0  var(--jpblack),
			 3px  3px 0  var(--jpblack)
	}

	.shadow-wh {
		text-shadow:
			10px 10px 0 var(--jpgray),
			-3px -3px 0 var(--jpgray),
			 3px -3px 0 var(--jpgray),
			-3px  3px 0 var(--jpgray),
			 3px  3px 0 var(--jpgray)
	}

	.shadow-bl {
		text-shadow:
			10px 10px 0 var(--jpblue),
			-3px -3px 0 var(--jpblue),
			 3px -3px 0 var(--jpblue),
			-3px  3px 0 var(--jpblue),
			 3px  3px 0 var(--jpblue)
	}


.project-image {
	width: 100%;
	position: relative;
}


/*--------------------------------------------------------------
## Galleries ACF
--------------------------------------------------------------*/
.gallery-wrapper {
	display: grid;
	grid-template-columns: repeat(auto-fit,minmax(340px,1fr));
	grid-gap: 15px;
	padding: 15px;
}

.gallery-image img {
    display: block;
}

.gallery-project {
    display: grid;
	 box-shadow: 0px 3px 4px rgba(0,0,0,0.4);
}

.gallery-project:hover {
	box-shadow: 0px 20px 20px  rgba(0,0,0,0.2);
    transform: translateY(-10px);

}

.gallery-image-wrapper,
.gallery-descripion-wrapper {
	grid-column: 1;
	grid-row: 1;
    margin: auto
}

.gallery-descripion-wrapper {
	background: rgba(20, 23, 30, 0.8);
	color: var(--jpgray);
	width: 100%;
    height: 100%;
	display: flex;
	opacity: 0;
    transition: opacity 0.5s;
}

.gallery-project:hover .gallery-descripion-wrapper {
	opacity: 1;
	transition: opacity 0.5s;
	transition-delay: 0.1s;
}

.gallery-descripion {
    margin: auto;
	opacity: 0;
    padding: 0 15px 15px 15px;
    text-align: center;
}

.gallery-project .gallery-descripion > * {
	transition: 375ms cubic-bezier(0.7, 0, 0.3, 1);
	transform: translateY(20px);
	display: block;
}

.gallery-project:hover .gallery-descripion {
	opacity: 1;
	transition: opacity 0.5s, transform 0.5s;
}

.gallery-project:hover .gallery-descripion > * {
	transform: translateY(0);
}

.gallery-project:hover  .gallery-descripion > * {
	transition-delay: 0.2s;
}

.gallery-project:hover  .gallery-descripion > * + * {
	transition-delay: 0.4s;
}

.gallery-project:hover  .gallery-descripion > * + * + * {
	transition-delay: 0.5s;
}

.gallery-descripion img {
	display: block;
	width: 80%;
	margin: auto;
	width: 80%;
}

.gallery-descripion a {
	color: var(--jppink);
    padding: 8px 16px;
    text-transform: uppercase;
    background: rgba(0,0,0,0.9);
    transition: all 0.2s;
    display: block;
    max-width: 240px;
    margin: 1rem auto;
}

gallery-descripion a:hover,
gallery-descripion a:active {
    text-decoration: none;
    color: var(--jpgray);
    background: var(--jppink);
	transition: all 0.2s;
}

/*--------------------------------------------------------------
## JOURNAL
--------------------------------------------------------------*/

.homejournal-wrapper {
	position: relative;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
	grid-gap: 1rem;
    max-width: 1000px;
    margin: auto;
    padding: 25px;
}

/* global*/
.home-journal {
    margin-top: auto;
}

.home-journal a {
	display: block;
	padding: 1rem;
	color:var(--jppink);
	transition: 0.5s all ease-in-out;
}

.home-journal a:hover {
	 background: hsla(226, 22%, 20%, 0.5);
}

.home-journal h2 {
	word-break: break-word
}

@media (min-width:700px) {
	.homejournal-wrapper {
		grid-template-columns: repeat(8, 1fr);
	}
}


/* 4x4 */
.home-journal:nth-of-type(12n+1),
.home-journal:nth-of-type(12n+8) {
	grid-column: span 4; grid-row: span 4;

}
/* 4x2 */
.home-journal:nth-of-type(12n+2),
.home-journal:nth-of-type(12n+6),
.home-journal:nth-of-type(12n+7),
.home-journal:nth-of-type(12n+11) {
	grid-column: span 4; grid-row: span 2;
}
/* 2x2 */
.home-journal:nth-of-type(12n+3),
.home-journal:nth-of-type(12n+5),
.home-journal:nth-of-type(12n+10),
.home-journal:nth-of-type(12n+12)  {
	grid-column: span 2; grid-row: span 2;
}
/* 2x4 */
.home-journal:nth-of-type(12n+4),
.home-journal:nth-of-type(12n+9) {
	grid-column: span 2; grid-row: span 4;
}

.home-journal:nth-of-type(12n+2)  a,
.home-journal:nth-of-type(12n+5)  a,
.home-journal:nth-of-type(12n+10)  a { color: var(--jpblue); }
.home-journal:nth-of-type(12n+6)  a,
.home-journal:nth-of-type(12n+9)  a { color: var(--jpgray); }

/* animation */
.home-journal {
	/* animation: RotateMenuA 15s ease-in-out infinite alternate; */
}

.home-journal:nth-of-type(odd) {
	/* animation: RotateMenuB 15s ease-in-out infinite alternate; */
}

.home-journal:nth-of-type(3n + 1) {
	 /* animation: RotateMenuC 15s ease-in-out infinite alternate; */
}

.home-journal:nth-of-type(5n + 1) {
	 /* animation: RotateMenuD 15s ease-in-out infinite alternate; */
}

.home-journal::after {
  content: '';
  position: absolute;
  z-index: -1;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}


@keyframes RotateMenuA {
    0%{
        -webkit-transform: translate(-10px, 10px);
        transform: translate(-10px, 10px); }
	100% {
		-webkit-transform: translate(0, 0);
		transform: translate(0, 0);
	 }
}

@keyframes RotateMenuB {
	0%{
		-webkit-transform: translate(20px, -14px)
		rotate(-4deg); transform: translate(20px, -14px);
	}
    100% {
        -webkit-transform: translate(0, 0);
        transform: translate(0, 0); }
}

@keyframes RotateMenuC {
	0% {
		-webkit-transform: translate(26px, 10px);
		transform: translate(26px, 10px);
		}
    100% {
            -webkit-transform: translate(0, 0) rotate(0deg);
            transform: translate(0, 0) rotate(0deg);
        }
	}

@keyframes RotateMenuD {
	0% {
		-webkit-transform: translate(-30px, -20px);
		transform: translate(-30px, -20px);
	}
    100% {
        -webkit-transform: translate(0, 0);
        transform: translate(0, 0);
    }
}

/*--------------------------------------------------------------
## Posts and pages
--------------------------------------------------------------*/
.sticky {
	display: block;
}

.hentry {
	margin: 0 0 1.5em;
}

.byline,
.updated:not(.published) {
	display: none;
}

.single .byline,
.group-blog .byline {
	display: none;
}

.entry-meta {
    font-size: 1.4rem;
}

.entry-content {
	width: calc(100% - 4rem);
	margin-inline: auto
}

.tag-standardwidth .entry-content {
	max-width: 78rem;
}


.page-id-103 .entry-content, /* about */
.page-id-382 .entry-content, /* about */
.category-brief-dispatches .entry-content {
    max-width: 780px;
	 border-top: solid 1px var(--jppink);
}

.page-id-103 .entry-content {
	margin-top: 60px;
} /* about */

.wrapper_660 {
	max-width: 660px;
	 margin: 0 auto;
}

.page-content,
.entry-content,
.entry-summary {
    padding-bottom: 5rem;
	margin: 0 auto;
    font-size: 1.8rem;
}

.page-links {
	clear: both;
	margin: 0 0 1.5em;
}

.site {
	position: relative;
	min-height: 100%;
	border: solid 5px;
	border-image: linear-gradient(to right, var(--jppink), var(--jpblue)) 1;
}

.page .entry-header { display: none; }
.page-template-page-portfolio .entry-header {display: block}

.entry-header {
	margin: 30px auto;
    padding: 0 3% 30px;
    color: var(--jpblack);
    text-align: center;
    line-height: 0.8;
	font-weight: bold
}

.entry-title {
    margin: 10px 0;
}

.jupago_wrapup {
    border: solid 1px var(--jpblack);
    background: var(--jpgray);
    padding: 3%;
}

.site-branding {
    text-align: center;
    position: absolute;
    left: 2.5rem;
    top: 7.5rem;
    vertical-align: text-top;
}

/* SVG Logo */
.jupago-logo {
	  width: 6rem;
	  display: grid;
	  grid-template-columns: 6fr 4fr 4fr 6fr;
	  grid-gap: 4px;
}

/* SVG values */
.jupago-logo svg {
  width: 100%;
  transition: all 0.5s ease-in-out;
  overflow: visible;
}

/* invividual */
.j1, .j2 {
  fill: var(--jppink);
}

.p1, .p2 {
  fill: var(--jpblack);
}

.home .p1, .page-template-page-2019journal .p1,
.home .p2, .page-template-page-2019journal .p2 {
  fill: var(--jpgray);
}

.j1 { align-self: end; }

.jupago-logo:hover .p1 { animation: jp_animate-p1 8s infinite; }
.jupago-logo:hover .p2 { animation: jp_animate-p2 8s infinite; }
.jupago-logo:hover .j1 { animation: jp_animate-j1 8s infinite; }
.jupago-logo:hover .j2 { animation: jp_animate-j2 8s infinite; }

/* dark bg */
.home .jupago-logo:hover .j1,
.page-template-page-2019journal .jupago-logo:hover .j1 { animation: jp_animate-j1-darkbg 8s infinite; }
.home .jupago-logo:hover .j2,
.page-template-page-2019journal .jupago-logo:hover .j2 { animation: jp_animate-j2-darkbg 8s infinite; }
.home .jupago-logo:hover .p1,
.page-template-page-2019journal .jupago-logo:hover .p1 { animation: jp_animate-p1-darkbg 8s infinite; }
.home .jupago-logo:hover .p2,
.page-template-page-2019journal .jupago-logo:hover .p2 { animation: jp_animate-p2-darkbg 8s infinite; }

@keyframes jp_animate-j1 {
    40%, 45% { fill: var(--jppink); }
    55%, 60% { fill: var(--jpblack); }
    70%, 75% { fill: var(--jppink); }
    85%, 90% { fill: var(--jpblack); }
	100%     { fill: var(--jppink); }
}

@keyframes jp_animate-j2 {
    32%      { transform: translateX( 0 ); }
    40%, 45% { transform: translateX(-18px); fill: var(--jppink); }
    55%, 60% { transform: translateX(-18px); fill: var(--jpblack); }
    70%, 75% { transform: translateX(-18px); fill: var(--jppink); }
    85%, 90% { transform: translateX(0); fill: var(--jpblack); }
    100%     { fill: var(--jppink); }
}

@keyframes jp_animate-p1 {
    9%, 15%  { transform: translateY(38px); }
    25%, 30% { transform: translateY(0); }
    40%, 45% { transform: translateX(18px); fill: var(--jpblack); }
    55%, 60% { transform: translateX(18px); fill: var(--jppink);  }
    70%, 75% { transform: translateX(18px); fill: var(--jpblack);  }
    85%, 90% { transform: translateX(0); fill: var(--jppink); }
    100%     { fill: var(--jpblack); }
}

@keyframes jp_animate-p2 {
    2%       { transform: translateY(0); }
    11%, 16% { transform: translateY(38px); }
    22%      { transform: translateY(0); }
    40%, 45% { fill: var(--jpblack); }
    54%, 60% { fill: var(--jppink); }
    70%, 75% { fill: var(--jpblack); }
    85%, 90% { fill: var(--jppink); }
    100%     { fill: var(--jpblack); }
}

/* Dark BG */
@keyframes jp_animate-j1-darkbg {
	40%, 45% { fill: var(--jppink); }
    55%, 60% { fill: var(--jpgray); }
    70%, 75% { fill: var(--jppink); }
    85%, 90% { fill: var(--jpgray); }
	100%     { fill: var(--jppink); }
}

@keyframes jp_animate-j2-darkbg {
	32%      { transform: translateX( 0 ); }
    40%, 45% { transform: translateX(-16px); fill: var(--jppink); }
    55%, 60% { transform: translateX(-16px); fill: var(--jpgray); }
    70%, 75% { transform: translateX(-16px); fill: var(--jppink); }
    85%, 90% { transform: translateX(0); fill: var(--jpgray); }
    100%     { fill: var(--jppink); }
}

@keyframes jp_animate-p1-darkbg {
	9%, 15%  { transform: translateY(32px); }
    25%, 30% { transform: translateY(0); }
    40%, 45% { transform: translateX(16px); fill: var(--jpgray); }
    55%, 60% { transform: translateX(16px); fill: var(--jppink);  }
    70%, 75% { transform: translateX(16px); fill: var(--jpgray);  }
    85%, 90% { transform: translateX(0); fill: var(--jppink); }
    100%     { fill: var(--jpgray); }
}

@keyframes jp_animate-p2-darkbg {
	2%       { transform: translateY(0); }
    11%, 16% { transform: translateY(32px); }
    22%      { transform: translateY(0); }
    40%, 45% { fill: var(--jpgray); }
    54%, 60% { fill: var(--jppink); }
    70%, 75% { fill: var(--jpgray); }
    85%, 90% { fill: var(--jppink); }
    100%     { fill: var(--jpgray); }
}


/* ------ top header ------ */
.home .site-header,
.page-template-page-2019journal {
	    background-color: var(--jpblack);
}

.site-header {
}

.tags-links {
	display: none;
}

/* Content */
.site-content {
	min-height: 100%;
}

.site-content:after {
  content: "";
  display: block;
}

/* ------ Footer ______ */

.site-footer {
	position: relative;
    margin: 0 auto;
    padding: 12vw 0 0 0;
}

.site-info {
	position: relative;
    display: grid;
    grid-template-rows: auto auto;
}

.social_stuff {
	position: relative;
    margin: auto;
    max-width: 400px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    grid-row: 2;
    grid-column: 1;
}

.social_stuff img {
    max-width: 60px;
	  padding: 10px;
	  filter: drop-shadow(5px 10px 2px rgba(0,0,0,0.2));
}

#jp-relatedposts {
    padding: 20px;
    background: #ffffff;
}

.balloons {
    margin: auto;
    max-width: 400px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    grid-row: 1 / -1;
    grid-column: 1;
}

.balloons img {
	height: 20rem;
    filter: drop-shadow(5px 20px 2px rgba(0,0,0,0.2));
}

.balloon-j {
    left: 20px;
 }

.balloon-p {
	left: 130px;
 }

.balloons .balloon-j{
	animation: FloatJ 8s ease-in-out infinite alternate;
}

.balloons .balloon-p{
	animation: FloatP 10s ease-in-out infinite alternate;
}

@keyframes FloatJ{
    0%{
        -webkit-transform: translate(-10px, 10px) rotateY(-5deg);
        transform: translate(-10px, 10px) rotateY(-5deg);
	}
	100% {
		-webkit-transform: translate(10px, 10px) rotateY(5deg);
        transform: translate(10px, 10px) rotateY(5deg);
	 }
}


@keyframes FloatP{
    0%{
        -webkit-transform: translate(10px, 10px) rotateY(8deg);
        transform: translate(10px, 10px) rotateY(8deg);
	}
	100% {
		-webkit-transform: translate(-8px, 10px) rotateY(-5deg);
        transform: translate(-8px, 10px) rotateY(-5deg);
	 }
}


/* contact & forms */
.gform_wrapper.contact_jp_wrapper {
    padding: 20px;
		background: #f6f6f6;
    margin: 16px auto;
    max-width: 500px;
}

.gform_wrapper .top_label input.medium,
.gform_wrapper .top_label select.medium,
.contact_jp_wrapper .name_first,
.contact_jp_wrapper .name_last {
	width: 100% !important;
}

.contact_jp_wrapper.gform_wrapper ul.gform_fields li.gfield {
    padding-right: 16px;
}

#field_1_27 {
    display: none;
}

li.gfield {
    padding: 10px 0;
}

.gform_wrapper .gsection {
    border-bottom: 5px solid var(--jppink);
    padding: 0;
}

.ui-slider-handle {
	background: var(--jppink);
}

.ui-widget-header,
.ui-state-hover {
	background: var(--jpblack);
}

.ui-slider-horizontal {
    height: 6px;
}

.ui-slider-horizontal .ui-slider-handle {
    border-radius: 90%;
    top: -8px;
}


/* 404 error page */
.error404-bg {
	position: absolute;
    background-image: url(images/404_jupago_1200.jpg);
    background-size: cover;
    background-position: center;
    width: 100%; width: 100vw;
    height: 100%; height: 100vh;
}


.error-404 {
    display: flex;
    margin: auto;
    width: 100%;
    padding: 30px% 6% 0;
    flex-wrap: wrap;
}

.error-404 .page-header {
    color: var(--jpgray);
    margin: auto;
    padding: 0;
    width: 100%;
    text-align: center;
 }

.error-404 .page-content {
    background: rgba(239,241,243,0.9);
    margin: 1em auto;
    padding: 0px 20px;
    max-width: 530px;
}


 .page-header h1 {
 	margin: 0;
 }


/* Flex me! */
.flexbox-wrapper {
    display: flex;
    align-items: stretch;
    flex-wrap: wrap;
    justify-content: space-between;
    flex: 1 1 200px;
}


.flexbox-quad {
/*    width: 25%;
    padding: 10px;*/
}

.flexbox-triple {
/*    width: 32%;
    width: calc(100% / 3 - 10px);
    padding: 20px;*/
}

.flexbox-double {
/*    width: 50%;
    padding: 10px;*/
}

.flexbox-single {
/*    width: 100%;
    padding: 10px;*/
}

/* Packery Styleguide */
.packery-item,
.packery-item--width2 {
	width: 25%;
	float: left;
	padding:10px;
}

.packery-item img {
	display: block;
	max-width: 100%;
}

.packery {
	background: var(--jpgray);
}

/* clear fix */
.packery:after {
	content: '';
	display: block;
	clear: both;
}

/* media queries */
@media all and (min-width:600px) {

	.packery-item {
		width: 12.5%;
	}

	.packery-item--width2 {
		width: 25%;
	}

}

/* Custom Fields */

.cf_wrapper {
    display: grid;
}

.cf_text {
	margin: auto;
	width: 96vw;
	max-width: 700px;
}

/*--------------------------------------------------------------
## Asides
--------------------------------------------------------------*/
.blog .format-aside .entry-title,
.archive .format-aside .entry-title {
	display: none;
}

/* ------ Comments -------*/
.comments-area {
	padding: 30px 3%;
    background: var(--jpgray);
    max-width: 700px;
    margin: 1.5em auto 6em auto;
}

.comments-title {
    font-size: 1em;
    line-height: 1.5;
    margin: 20px 0;
}

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

.comment-body {
    background: var(--jpgray);
    padding: 10px;
    margin: 10px 0;
}

.comment-respond {
    margin-top: 50px;
}

.comment-content a {
	word-wrap: break-word;
}

.bypostauthor {
	display: block;
}

#jp-relatedposts h3.jp-relatedposts-headline em {
    font-size: 1.5em;
}

/*--------------------------------------------------------------
# Infinite scroll
--------------------------------------------------------------*/
/* Globally hidden elements when Infinite Scroll is supported and in use. */
.infinite-scroll .posts-navigation, /* Older / Newer Posts Navigation (always hidden) */
.infinite-scroll.neverending .site-footer { /* Theme Footer (when set to scrolling) */
	display: none;
}

/* When Infinite Scroll has reached its end we need to re-display elements that were hidden (via .neverending) before. */
.infinity-end.neverending .site-footer {
	display: block;
}

/*--------------------------------------------------------------
# Media
--------------------------------------------------------------*/
.page-content .wp-smiley,
.entry-content .wp-smiley,
.comment-content .wp-smiley {
	border: none;
	margin-bottom: 0;
	margin-top: 0;
	padding: 0;
}

/* Make sure embeds and iframes fit their containers. */
embed,
iframe,
object {
	max-width: 100%;
}

/*--------------------------------------------------------------
## Captions
--------------------------------------------------------------*/
.wp-caption {
	margin-bottom: 1.5em;
    color: var(--jpblack);
    background: #ffffff;
    font-size: 0.8em;
    max-width: 600px;
	margin: 0 auto 30px;
	padding: 15px;
	box-shadow: 0px 3px 4px #666666;
}

.wp-caption img {
	margin-bottom: 10px;
}

.wp-caption img[class*="wp-image-"] {
	display: block;
	margin-left: auto;
	margin-right: auto;
}


.wp-caption-text {
    padding: 0.5em 0;
    text-align: left;
}

/*--------------------------------------------------------------
## Galleries
--------------------------------------------------------------*/
.gallery {
	margin-bottom: 1.5em;
}

.gallery-item {
	display: inline-block;
	text-align: center;
	vertical-align: top;
	width: 100%;
}

.gallery-columns-2 .gallery-item { max-width: 50%; }
.gallery-columns-3 .gallery-item { max-width: 33.33%; }

.gallery-columns-4 .gallery-item {
	max-width: 25%;
}

.gallery-columns-5 .gallery-item {
	max-width: 20%;
}

.gallery-columns-6 .gallery-item {
	max-width: 16.66%;
}

.gallery-columns-7 .gallery-item {
	max-width: 14.28%;
}

.gallery-columns-8 .gallery-item {
	max-width: 12.5%;
}

.gallery-columns-9 .gallery-item {
	max-width: 11.11%;
}

.gallery-caption {
	display: block;
}

/* scroll JS remove flicer */
html.sr .project-image-wrapper img {
    visibility: hidden;
}


/* Unify my animation times */
.dots_logo, .dots_logo:hover {
    /* transition: all 0.5s ease-in-out; */
	  transition: 0.5s cubic-bezier(0.7, 0, 0.3, 1);
}

.gallery-project, .gallery-project:hover,
.project-image img, .project-image img:hover {
	transition: transform 0.3s, box-shadow 0.3s;
	transition-timing-function: ease-in-out;
}
