* { margin: 0; padding: 0; border: 0; }
html, body { min-height: 100%; }
body{margin:0;padding:0;}
.fl_menu{list-style:none;}
.cms_imgleft{margin:3px 10px 10px 0;float:left;}
.cms_imgright{margin:3px 0 10px 10px;float:right;}
.clear{clear:both;}
.gallthumbnail{display:inline-block;border:1px solid #666;margin-right:5px;margin-bottom:5px;}
.fl_blogpostavatar{float:right;border:1px solid #eee;margin:0 0 5px 5px;}
.fl_commentavatar{float:left;border:1px solid #eee;margin:0 5px 0 0;}
.fl_commentname{display:block;margin-left:80px;text-transform:uppercase;margin-bottom:5px;font-size:10px;}
.fl_commentmessage{display:block;margin-left:80px;}
.fl_gtname{display:block;text-transform:uppercase;margin-bottom:5px;font-size:8pt;}
.fl_gtmessage{display:block;}
.fl_blogpost1, .fl_blogpost2{border-bottom:1px sold #eee;padding-bottom:20px;margin-bottom:20px;}
.fl_postinfo{text-transform:uppercase;margin-bottom:5px;font-size:10px;}
.fl_blogfooter{clear:both;}
.fl_comment1{display:block;padding:5px;margin-top:5px;}
.fl_comment2{display:block;padding:5px;background-color:#eee;margin-top:5px;}
.fl_commclear{display:block;clear:both;}
#fl_commsbox, #fl_tracksbox{clear:both;padding-top:15px;}
.fl_bigpic{border:1px solid #eee;}
.fl_bigcaption{margin-top:10px;}
.fl_gallpreview1{margin-bottom:10px;padding:5px;clear:both;}
.fl_gallpreview2{margin-bottom:10px;background-color:#eee;padding:5px;clear:both;}
.fl_gallpreview1 img, .fl_gallpreview2 img{float:left;border:1px solid #eee;}
.fl_galllink, .fl_galltext{display:block;margin-left:110px;}
.fl_mailform textarea{height:200px;}
.fl_rsslinks{padding-top:10px;clear:both;text-align:right;}
.fl_rsslinks a{text-transform:uppercase;font-size:8pt;text-decoration:none;margin-left:10px;}
.fl_rsslinks:empty{display:none;}
.fl_rating{float:right;text-align:right;}
#msgwrap{position:fixed;top:150px;left:50%;text-align:center;z-index:99;pointer-events:none;}
#msgbar{position:relative;color:#fff;border-width:3px;border-style:solid;padding:15px;font-size:28px;line-height:40px;width:300px;left:-168px;cursor:default;display: block; opacity: 0; transition: opacity 1s; pointer-events: none; }
#msgbar a{color:#fff;}
#msgbar.messageshown { opacity: 0.9; pointer-events: auto; }
#msgbar.messagehide { transition: none; pointer-events: none; opacity: 0; }
input, textarea{padding:10px;background-color:#fff;font-size:12px;}
textarea{height:150px;}
.fl_later{float:left;}
.fl_earlier{float:right;}
.flmsg_alert{background-color:#4ad;border-color:#079;}
.flmsg_error{background-color:#900;border-color:#600;}
.flmsg_success{background-color:#096;border-color:#066;}
.flmsg_generic{background-color:#666;border-color:#999;}
#fl_gallwrap{position:fixed;top:0;left:0;margin:0;padding:0;width:100%;height:100%;display:block;font-size:12px;line-height:20px;color:#333;text-align:center;z-index: 99; opacity: 0; pointer-events: none; transition: opacity 0.5s; }
#fl_gallwrap.fl_gallwrapshown { opacity: 1; pointer-events: auto; }
#fl_gallcover{position:fixed;width:100%;height:100%;top:0;left:0;margin:0;padding:0;background-color:#000;opacity:0.8;}
#fl_gallbox{position:relative;top:5%;margin:0 auto;background: #fff url('../gfx/fl_loading.svg') no-repeat center/32px auto;padding:10px;display:inline-block;min-width:32px;min-height:32px}
.gallhidden { display: none!important; }
#fl_gallpicwrap { overflow: hidden; transition: all 0.5s ease-in-out; max-width: 64px; max-height: 64px; width: 90vw; height: 90vh; }
#fl_gallpic{display:block;margin:0 auto;transition: opacity 0.5s; max-width: 100%; }
#fl_gallpic.galltransitionfast { transition: 0.2s all; }
#fl_gallpic.fl_gallpichidden { opacity: 0; }
#fl_gallbelowpic{clear:both;display:block;margin:0 -10px;overflow:hidden;position: relative; z-index: 51; transition: all 0.5s; opacity: 0; max-height: 0; }
#fl_gallbelowpic.fl_gallbelowpicshown { opacity: 1; max-height: 500px; }
#fl_gallwrap a{color:#666;text-decoration:none;}
#fl_gallwrap a:hover{color:#444;}
#fl_gallprevnext{background:url('../scripting/blank.gif');position:relative;}
#fl_gallprev, #fl_gallnext { position: absolute; top: 0; bottom: 0; width: 50%; display: none; z-index: 50; }
#fl_gallprev { left: 0; text-align: left; }
#fl_gallnext { right: 0; text-align: right; }
#fl_gallclose, #fl_gallslide{clear:right;float:right;}
#fl_gallclose { margin: 10px 10px 0 0; }
#fl_gallslide { margin-right: 10px; }
a#fl_gallprev:hover, a#fl_gallnext:hover, a#fl_gallclose:hover{border-width:0;}
#fl_gallprev img, #fl_gallnext img{visibility:hidden;padding-top:50px;}
#fl_gallprev:hover img, #fl_gallnext:hover img{visibility:visible;}
#fl_gallcaption { text-align: left; padding: 10px 10px 0; max-width: calc(100% - 120px); }
#fl_loading { display: none; position: fixed; top: 10px; right: 10px; background: #fff; padding: 3px; border: 1px solid #ccc; width: 32px; height: 32px; z-index: 150; }

#fl_tracksbox, .fl_rsslinks, .fl_rsslinks .rsscomments { display: none; }


:root {
	--hpi-text: #4c4c4c;
	--hpi-green: #75866e;
	--hpi-neutral: #f6f6f6;
}


html, body { background: #fff; color: var(--hpi-text); font: 18px/24px "Instrument Sans", sans-serif; }
p { margin: 25px 0; }
ul { margin: 25px; }
ol { margin: 25px; }
a { color: var(--hpi-green); }
a:hover { text-decoration: none; color: var(--hpi-text); opacity: 0.5; }
b, strong { font-weight: 600; }
img { max-width: 100%; height: auto!important; }

h1, h2, h3, h4, h5 { font-family: "DM Serif Display", serif; margin: 25px 0; font-weight: 400; }
h1 { font-size: 72px; line-height: 77px; margin-top: 0; }
h2 { font-size: 36px; line-height: 40px; }
h3 { font-size: 32px; line-height: 36px; }
h4 { font-size: 28px; line-height: 32px; }
h5 { font-size: 24px; line-height: 28px; }
h1 b, h1 strong, h2 b, h2 strong, h3 b, h3 strong, h4 b, h4 strong, h5 b, h5 strong { font-weight: 400; }
.textlabel { position: absolute; margin-left: -9999px; }
h1:empty { display: none; }
h2 em, h3 em, h4 em, h5 em { font-style: normal; color: var(--hpi-green); }
.gridbox h4:after { content: '.'; color: var(--hpi-green); }

.skipto a { position: absolute; margin-left: -9999px; top: auto; width: 1px; height: 1px; overflow: hidden; color: #fff!important; padding: 10px; background: var(--hpi-green); }
.skipto a:focus { margin-left: 0; width: auto; height: auto; opacity: 1; z-index: 50; }

.wrapper { max-width: 1100px; margin: 0 auto; padding: 0 50px; position: relative; }

header { background: linear-gradient(to bottom, rgba(0,0,0,0.75), rgba(0,0,0,0)); padding: 25px 0; position: fixed; top: 0; left: 0; right: 0; height: 150px; pointer-events: none; z-index: 50; }
.logo { width: 75px; display: inline-block; vertical-align: top; pointer-events: auto; }
.logo img { display: block; }

#menu { position: absolute; top: 0; right: 50px; pointer-events: auto; }
.fl_menu li, .fl_menu a { display: inline-block; }
.fl_menu a { font: 18px/30px "DM Serif Display", serif; margin-left: 25px; text-decoration: none; color: #fff; }
.fl_menu #menu_c_contact a { background: var(--hpi-green); border-radius: 15px; padding: 0 10px; }
header a:hover { opacity: 1; transform: scale3d(1.05,1.05,1); }
#menubutton, #menu_i_ { display: none; }
#menu_e_16 a { text-indent: -9999px; width: 18px; background: url('../gfx/icon-ig.svg') no-repeat center / contain; }

main { min-height: calc(100vh - 301px); box-sizing: border-box; margin-bottom: 50px; }
main>.wrapper:nth-child(2) { scroll-margin-top: 50px; }
main ul { list-style: none; }
main li { margin-top: 3px; }
main ul li:before { content: '\2022'; position: absolute; margin-left: -20px; color: var(--hpi-green); font-size: 1.1em; font-family: "DM Serif Display", serif; margin-top: -1px; }
blockquote { background: var(--hpi-neutral); margin: 25px; padding: 25px; }
.cms_imgleft, .cms_imgright { max-width: 400px; }
.cms_imgleft { margin: 3px 20px 20px 0; }
.cms_imgright { margin: 3px 0 20px 20px; }

#imgfade { height: 1600px; max-height: 90vh; min-height: 500px; background: var(--hpi-neutral); position: relative; margin-bottom: 50px; display: flex; overflow: hidden; }
#imgfade img { display: none; width: 100%; height: 100%!important; position: absolute; top: 0; left: 0; z-index: 5; object-fit: cover; object-position: center; transition: opacity 2s; }
#imgfade img:first-child { display: block; }
#imgfade.hasjs img { display: block; opacity: 0; }
#imgfade.hasjs img.curimg { opacity: 1; }
.pagetitle { max-width: 1100px; margin: 0 auto; padding: 0 50px; width: 100%; align-self: center; color: #fff; text-shadow: 0 0 50px rgba(0,0,0,0.75); position: relative; z-index: 10; }
.pagetitle h1 { max-width: 50%; }
.pagetitle h3 { margin: 0 0 15px; }
.pagetitle h3:after { display: none; }
.pagetitle .dot { color: var(--hpi-green); }
#imgfade button#tri { position: absolute; bottom: 15px; left: 50%; width: 20px; height: 20px; padding: 0; margin: 0 0 0 -10px; background: url('../gfx/tri.svg') no-repeat center / auto 10px; border-radius: 0; z-index: 40; }
#imgfade button#tri:hover { transform: scale3d(1.2,1.2,1); }

.frontabout { background: var(--hpi-neutral); position: relative; margin: 75px 0; }
.frontabouttext { margin-left: 50%; padding: 25px; }
.frontabouttext>*:last-child, .frontabouttext>*:last-child>* { margin-bottom: 0; }
.frontabouttext>*:first-child { margin-top: 0; }
.frontaboutimage { position: absolute; top: -25px; bottom: -25px; left: 0; right: 50%; background: var(--hpi-neutral); }
.frontaboutimage img { width: 100%; height: 100%!important; object-fit: cover; object-position: center; }

.frontportfolio { position: relative; }
.frontportfolio a.button { position: absolute; top: 0; right: 0; background: var(--hpi-neutral); color: var(--hpi-green)!important; margin: 0; }

.grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 50px;  }
.grid a { color: inherit; text-decoration: none; }
.grid a:hover { opacity: 1; color: var(--hpi-green); }
.gridimg { display: block; height: 0; padding-bottom: 66.666666%; background: var(--hpi-neutral); position: relative; overflow: hidden; }
.gridimg img { display: block; position: absolute; top: 0; left: 0; width: 100%; height: 100%!important; object-fit: cover; object-position: center; transition: transform 1s ease-out; }
.gridimg img.generic { top: 25%; bottom: 25%; height: 50%!important; object-fit: contain; }
.grid h4 { margin-bottom: 0; }
.grid p { font-family: "DM Serif Display", serif; margin: 20px 0 0; }
.grid a:hover .gridimg img { transform: scale3d(1.05,1.05,1); }

.projectdescwrap { float: right; width: calc(50% - 12.5px); margin: 25px 0 0; height: 0; padding-bottom: calc(50% - 12.5px); background: var(--hpi-neutral); position: relative; }
.projectdesc { position: absolute; top: 0; bottom: 0; left: 0; right: 0; padding: 25px; overflow: auto; -webkit-overflow-scrolling: touch; scrollbar-width: thin; scrollbar-color: var(--hpi-green) transparent; }
.projectdesc::-webkit-scrollbar { width: 6px; border-radius: 3px; }
.projectdesc::-webkit-scrollbar-track { background: transparent; }
.projectdesc::-webkit-scrollbar-thumb { background: var(--hpi-green); }
.projectdesc::-webkit-scrollbar-thumb:hover { background: var(--hpi-text); }

.projectdesc>*:first-child { margin-top: 0; }
.projectdesc>*:last-child { margin-bottom: 0; }

#projectimages { margin-top: -25px; }
.projectimages div { display: inline-block; width: calc(25% - 18.75px); margin: 25px 25px 0 0; vertical-align: top; cursor: pointer; overflow: hidden; position: relative; }
.projectimages div:nth-child(4n+0) { margin-right: 0; }
.projectimages div img { display: block; transition: transform 1s ease-out; }
.projectimages div:hover img { transform: scale3d(1.05,1.05,1); }
#projectimagesbefore div:before, #projectimagesbefore div:after { position: absolute; bottom: 0; content: 'Before.'; color: var(--hpi-green); font: 18px/18px "DM Serif Display", serif; left: 0; right: 0; padding: 50px 10px 10px; background: linear-gradient(to bottom, rgba(0,0,0,0), rgba(0,0,0,0.75)); z-index: 10; }
#projectimagesbefore div:after { content: 'Before'; color: #fff; }

.contactwrap { display: grid; grid-template-columns: 1fr 1fr; gap: 50px; }
.contactcontent>*:first-child { margin-top: 0; }

blockquote.testimonial { font: 36px/40px "DM Serif Display", serif; text-align: center; margin-bottom: 0; }
blockquote.testimonial:before { content: '“'; display: block; font-size: 144px; position: relative; top: 35px; padding-bottom: 25px; color: var(--hpi-green); }
blockquote.testimonial .testimonialfrom { margin-top: 25px; font-size: 24px; line-height: 28px; }

.pf-story main ul { display: grid; grid-template-columns: repeat(3, 1fr); grid-auto-rows: 1fr; gap: 25px; margin: 25px 0; }
.pf-story main ul li { display: block; margin: 0; background: var(--hpi-neutral); text-align: center; padding: 25px; align-content: center; font: 18px/24px "DM Serif Display", serif; }
.pf-story main ul li:before { display: none; }


footer { background: var(--hpi-green); color: #fff; font: 18px/24px "DM Serif Display", serif; padding: 50px 0; }
footer p { margin: 0; }
footer p.address { padding-top: 105px; background: url('../gfx/hpi-white.svg') no-repeat top left/100px auto; }
footer p.madeby { position: absolute; bottom: 0; right: 50px; }
footer a, footer a:hover { color: inherit; text-decoration: none; }

header { animation-duration: 2s; animation-iteration-count: 1; animation-name: slide-in-from-top; animation-fill-mode: forwards; }
.pagetitle h3, .pagetitle h1 { animation-duration: 2s; animation-iteration-count: 1; animation-name: slide-in-from-below; animation-fill-mode: forwards; }
.pagetitle h1:nth-child(2) { animation-duration: 2.25s; animation-name: slide-in-from-below-with-delay; }
.hasjs .blockready { opacity: 0; transform: translate3d(0,50px,0); }
.hasjs .blockdisp { animation-duration: 1s; animation-iteration-count: 1; animation-name: slide-in; animation-fill-mode: forwards; }
@keyframes slide-in-from-top {
    0% {
        opacity: 0;
        transform: translate3d(0, -50px, 0);
    }

    100% {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
}
@keyframes slide-in-from-below {
    0% {
        opacity: 0;
        transform: translate3d(0, 50px, 0);
    }
    5% {
        opacity: 0;
        transform: translate3d(0, 50px, 0);
    }


    100% {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
}
@keyframes slide-in-from-below-with-delay {
    0% {
        opacity: 0;
        transform: translate3d(0, 50px, 0);
    }
    25% {
        opacity: 0;
        transform: translate3d(0, 50px, 0);
    }

    100% {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
}

@keyframes slide-in {
  0% {
    opacity: 0;
    transform: translate3d(0,25px,0);
  }
  100% {
    opacity: 1;
    transform: translate3d(0,0,0);
  }
}



main label { display: block; font: 16px/20px "DM Serif Display", serif; margin: 10px 0 5px; }
input, textarea { -webkit-appearance: none; border-radius: 0; width: 100%; box-sizing: border-box; }
input, textarea, .fl_mailform textarea, select, button { font: 14px "Instrument Sans", sans-serif; color: var(--hpi-text); border: 0; background: var(--hpi-neutral); width: 100%; margin-right: 5px; display: block; padding: 10px; border-radius: 2px; box-sizing: border-box; height: 40px; position: relative; }
textarea, .fl_mailform textarea { height: 250px; }
input.checkbox, input[type=checkbox] { border: 0; width: auto; display: inline; background: transparent; -webkit-appearance: checkbox; height: auto; }
input:hover, textarea:hover, select:hover { background-color: var(--hpi-neutral); }
input:focus, textarea:focus, select:focus { background-color: var(--hpi-neutral); color: var(--hpi-text); }

a.button { text-decoration: none; text-align: center; display: inline-block; text-overflow: ellipsis; white-space: nowrap; overflow: hidden; max-width: 100%; box-sizing: border-box; }
input.emailsub, input.commentsub, input.formsub, .button, button { display: block; width: auto; font: 18px/30px "DM Serif Display", serif; height: 40px; margin: 0; padding: 5px 20px; color: #fff!important; border: 0; background: var(--hpi-green); border-radius: 20px; cursor: pointer; text-decoration: none; box-sizing: border-box; }
input.emailsub:hover, input.commentsub:hover, input.formsub:hover, .button:hover, button:hover { transform: scale3d(1.05,1.05,1); opacity: 1; }
input.emailsub { margin-top: 25px; }

.reqd, .err { font-weight: 600; color: #c00; }
.reqd { margin: 0 5px; }

a, button, input[type=submit] { transition: all 0.25s; }

@media (max-width: 979px) {
	html, body { min-width: 320px; -webkit-text-size-adjust: none; }
	.grid { gap: 25px; }
	.pagetitle h1 { max-width: 65%; }
	.cms_imgleft, .cms_imgright { max-width: 350px; }
}
@media (max-width: 839px) {
	.projectdescwrap { width: calc(75% - 6.25px); padding-bottom: calc(75% - 6.25px); }
	#projectimages div:nth-child(4n+0) { margin-right: 25px; }
	#projectimages div:nth-child(4n+3) { margin-right: 0; }
	.contactwrap { display: block; }
	.cms_imgleft, .cms_imgright { max-width: 300px; }
	.pf-story main ul { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
	.grid { grid-template-columns: repeat(2, 1fr); }
	.page_front .grid a:last-child:nth-child(odd) { display: none; }

	.cms_imgleft, .cms_imgright { max-width: 250px; }

	.frontabout { margin: 75px 25px 50px 0; }
	.frontaboutimage { position: relative; float: right; width: 40%; height: 0; padding-bottom: 40%; top: auto; left: auto; bottom: auto; right: auto; margin: -25px -25px 25px 25px; }
	.frontaboutimage img { position: absolute; top: 0; bottom: 0; left: 0; right: 0; }
	.frontabouttext { margin-left: 0; }

	#projectimages div:nth-child(4n+3) { margin-right: 25px; }
	.projectdescwrap { width: calc((100% / 3 * 2) - (25px / 3)); padding-bottom: calc((100% / 3 * 2) - (25px / 3)); }
	.projectimages div { width: calc((100% / 3) - (50px / 3)); }

	#projectimages div:nth-child(3n+2) { margin-right: 0; }
	#projectimagesbefore div:nth-child(4n+0) { margin-right: 25px; }
	#projectimagesbefore div:nth-child(3n+0) { margin-right: 0; }

}
@media (max-width: 649px) {
	html, body { font-size: 16px; line-height: 22px; }
	h1 { font-size: 48px; line-height: 52px; }
	h2 { font-size: 28px; line-height: 32px; }
	h3 { font-size: 24px; line-height: 28px; }
	h4 { font-size: 20px; line-height: 24px; }
	h5 { font-size: 18px; line-height: 22px; }
	.wrapper, .pagetitle { padding: 0 25px; }
	h1, h2, h3, h4, h5, p, blockquote, ul, ol { margin-top: 15px; margin-bottom: 15px; }
	
	header { padding: 15px 0; animation-name: none; }
	.logo, #menubutton { animation-duration: 2s; animation-iteration-count: 1; animation-name: slide-in-from-top; animation-fill-mode: forwards; }

	.logo { width: 50px; height: 50px; }
	#menu { position: fixed; top: 0; bottom: 0; left: 0; right: 0; background: var(--hpi-green); z-index: 60; display: flex; opacity: 0; transform: translate3d(0, -100%, 0); transition: all 0.5s ease-out; }
	.menushown #menu { opacity: 1; transform: translate3d(0,0,0); }
	.fl_menu { align-self: center; text-align: center; width: 100%; }
	.fl_menu li { display: block!important; }
	.fl_menu a { line-height: 50px; margin: 0; }
	#menu_i_ a { text-indent: -9999px; background: url('../gfx/hpi-white.svg') no-repeat top / contain; width: 80px; height: 80px; margin-bottom: 20px; }
	#menubutton { display: block; position: fixed; top: 20px; right: 25px; width: 40px; height: 40px; background: transparent; border-radius: 0; z-index: 61; pointer-events: auto; }
	#menubutton .rowbar { position: absolute; top: 19px; left: 11px; width: 18px; height: 3px; background: #fff; border-radius: 2px; transition: all 0.5s; }
	#menubutton .rowbar:first-child { top: 13px; }
	#menubutton .rowbar:last-child { top: 25px; }

	.menushown #menubutton .rowbar:first-child, .menushown #menubutton .rowbar:last-child { opacity: 0; }
	.menushown #menubutton .rowbar:nth-child(2) { transform: rotate(-45deg); }
	.menushown #menubutton .rowbar:nth-child(3) { transform: rotate(45deg); }
	
	#imgfade, main { margin-bottom: 25px; }
	.frontabout { margin: 40px 15px 25px 0; }
	.frontaboutimage { margin: -15px -15px 15px 15px; width: 30%; padding-bottom: 30%; }
	.frontabouttext { padding: 15px; }
	.frontportfolio { text-align: right; }
	.frontportfolio h2, .frontportfolio .grid { text-align: left; }
	.frontportfolio a.button { position: static; margin-top: 25px; }
	.grid p { margin-top: 10px; }

	footer { padding: 25px 0; font-size: 14px; line-height: 20px; }
	footer p.address { padding-top: 55px; background-size: auto 50px; }
	
	input.emailsub { margin-top: 15px; }
	.pf-story main ul { gap: 15px; }
	
	#imgfade { max-height: 80vh; }

	.cms_imgleft, .cms_imgright { max-width: 100%; display: block; margin: 15px auto; float: none; }
	
	.projectdescwrap { float: none; height: auto; width: auto; padding: 0; }
	.projectdesc { position: static; }
	.projectimages { margin-top: 0!important; }
	.projectimages div { margin: 25px 25px 0 0!important; }
	.projectimages div:nth-child(3n+0) { margin-right: 0!important; }
	blockquote.testimonial { margin: 25px 0 0; font-size: 28px; line-height: 32px; }
	blockquote.testimonialfrom { font-size: 18px; line-height: 22px; }
	blockquote.testimonial:before { font-size: 96px; top: 20px; padding-bottom: 10px; }

	@keyframes slide-in {
	  0% {
		opacity: 0;
		transform: translate3d(0,15px,0);
	  }
	  100% {
		opacity: 1;
		transform: translate3d(0,0,0);
	  }
	}


}
@media (max-width: 559px) {
	.pagetitle h1 { max-width: 75%; }
	.pf-story main ul { grid-template-columns: 1fr; grid-auto-rows: auto; }
}
@media (max-width: 479px) {
	footer p.madeby { position: static; margin-top: 25px; }
	.frontaboutimage { width: 125px; padding-bottom: 125px; }
	.grid { grid-template-columns: 1fr; }
	.page_front .grid a:last-child:nth-child(odd) { display: block; }
	
	.projectimages div { margin: 15px 15px 0 0!important; width: calc((100% / 3) - 10px); }
	.projectimages div:nth-child(3n+0) { margin-right: 0!important; }
	blockquote.testimonial { margin-top: 15px; }
}
@media (max-width: 399px) {
	.pagetitle h1 { max-width: 100%; }
}
@media (max-width: 359px) {
	#cf-turnstile { transform: scale(0.95); transform-origin: top left; }
	.frontaboutimage { width: 100px; padding-bottom: 100px; }
}
@media (max-height: 299px) {
	#menu_i_ a { width: 60px; height: 60px; }
	.fl_menu a { line-height: 40px; }
}