* {
    box-sizing: border-box;
}

@font-face {
    font-family: 'Olivera';
    font-style: normal;
    font-weight: 400;
    src: url('/assets/fonts/Olivera.ttf');
}

@font-face {
    font-family: 'Redacted';
    font-style: normal;
    font-weight: 400;
    src: url('/assets/fonts/redacted-script-regular.ttf');
}

@font-face {
    font-family: 'Redacted';
    font-style: normal;
    font-weight: 600;
    src: url('/assets/fonts/redacted-script-bold.ttf');
}

html, body {
    font-family: 'Source Sans 3';
    position: relative;
    float: left;
    width: 100%;
    padding: 0px;
    margin: 0px;

    background: #f5f6fa;

    user-select: none;
    /*touch-action: none;*/ /* FIXME!!! */
}

body {
    /*min-width: 480px;*/
    overflow-x: hidden;
}

.debug-ruler {
    position: fixed;
    left: 30px;
    top: 0px;
    width: 250px;
    height: 16px;
    line-height: 16px;
    text-align: center;
    color: white;
    background: black;
    z-index: 999;
    font-size: 13px;
    overflow: hidden;
}

.ruler {
    position: relative;
    width: 100%;
    height: 16px;
    display: none;
}

.ruler-1 {
    background: blueviolet;
}

.ruler-2 {
    background: cornflowerblue;
}

.ruler-3 {
    background: olivedrab;
}

.ruler-3 {
    background: orange;
}

a {
    position: relative;
    text-decoration: none;
    transition: all .33s ease-out;
    color: inherit;
}

a:visited {
    color: inherit;
}

a.nohover:hover:after {
    background:none;
}

a:hover {
    /*color: white;*/
    cursor: pointer;
}

/*a:after {
    position: absolute;
    content: "";
    left: 0px;
    top: 0px;
    width: 100%;
    height: 100%;
    background: rgba(255,255,255,.0);
    transition: all .33s ease-out;
    mix-blend-mode: overlay;
}

a:hover:after {
    position: absolute;
    content: "";
    left: 0px;
    top: 0px;
    width: 100%;
    height: 100%;
    background: rgba(255,255,255,.6);
    mix-blend-mode: overlay;
}*/

.fp-sec-cnt {
    position: relative;
    display: flex;
    flex-direction: column;
    height: 101vh;
    overflow: hidden;
}

.fp-sec-cnt-ovf {
    position: relative;
    overflow-x: hidden;
    display: flex;
    flex-direction: column;
    /*min-height: 101vh;*/
}

.fp-sec-cnt h1 {
    font-size: min(8vw, 3rem);
    color: #222;
    padding-left: 2vw;
    margin-bottom: 0;
}
  
.fp-sec-cnt h2 {
    margin-top: 0;
    padding-left: 2vw;
    color: #222;
}

.fp-sec-pubmart-flex {
    display: flex;
    flex-direction: column;
    padding-bottom: 3rem;
}

.fp-pubmart-section {
    position: relative;
	display: inline-block;
	border-radius: 1rem;
	font-size: 0;
    width: 100%;
    flex: 1;
    background: white;
    box-shadow: 0px 3rem 3rem -2rem rgba(0,0,0,.2);
    margin-top: 2rem;
    margin-bottom: 1rem;
    overflow: hidden;

    display: flex;
    flex-direction: row;
    border: 1px white solid;
}

.fp-pubmart-nav {
    position: relative;
    background: rgb(132 136 157 / 2%);
    flex: .33;

    display: flex;
    flex-direction: column;
    justify-content: center;
}

.fp-pubmart-navitem {
    width: 100%;
    position: relative;
    height: 3rem;
    margin-top: .1rem;
    margin-bottom: .1rem;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: left;
    line-height: 1.3rem;
    font-size: 1.2rem;
    color: #444;
    padding-left: 1.1rem;
    transition: all .33s ease-out;
}

.fp-pubmart-navitem:hover {
    background: rgba(0,0,0,.1);
    cursor: pointer;
}

.fp-pubmart-navitem:active {
    background: rgba(0,0,0,.18);
    cursor: pointer;
    transform: translateY(.2rem);
}

.fp-pubmart-navitem.selected {
    background: rgba(0,0,0,.1);
    cursor: pointer;
}

.fp-pubmart-nav:after {
    position: absolute;
    content: "";
    right: 0px;
    top: 0px;
    width: 3rem;
    height: 100%;
    z-index: 1;
    background: radial-gradient(ellipse at center right, rgba(81, 83, 93,.15) 0%, rgba(0,0,0,0) 70%);
    pointer-events: none;
}

.fp-pubmart-content {
    position: relative;
    flex: .66;
}

.fp-sec-persoprj {
    background: linear-gradient(135deg,#fafbff 30%,#b7bec488 100%);
    height: auto;
    overflow: hidden;
}

.fp-sec-persoprj h1 {
    text-shadow: 0px 1px 0px rgba(0, 0, 0, .2);
}

.fp-hgallery {
    position: relative;
    width: 100%;
    aspect-ratio: calc(16 / 9);
    margin-bottom: max(16px, 3rem);

    padding: 1rem;
	display: grid;
	grid-template-columns: repeat(10, 80vw);
	grid-template-rows: 1fr;
	grid-column-gap: 1rem;
	grid-row-gap: 1rem;
	/*overflow: hidden;*/
	scroll-snap-type: both mandatory;
	scroll-padding: 1rem;

    border-radius: 2rem;
}

.fp-htile {
    position: relative;
	scroll-snap-align: center;
	display: inline-block;
	border-radius: 1rem;
	font-size: 0;
    width: calc(100% - 1.8rem);
    background: white;
    padding: 1.5%;
    box-shadow: 0px 3rem 3rem -2rem rgba(0,0,0,.2);
}

.fp-htile-inner {
    position: relative;
    width: 100%;
    height: 100%;
    border-radius: .6rem;
    background: #0a1722;
    overflow: hidden;
}

.fp-htile-bg {
    position: absolute;
    width: 100%;
    height: 100%;
    background-size: cover;
    z-index: 0;
}

.fp-sec-hdr {
    position: relative;
    /*background: linear-gradient(180deg, #ffffff 30%, #d1d2d3 100%);*/
    background: linear-gradient(135deg,#fafbff 30%,#b7bec488 100%);
}

.fp-sec-hdr h2 {
    font-weight: 400;
    width: 43vw;
}

.fp-sec-hdr h1 {
    color: #111;
    font-size: 14vh;
    line-height: 17vh;
    margin-bottom: 8vh;
}

.fp-sec-hdr h1 div {
    width: 48vw;
    font-size: .4em;
    line-height: 1em;
}

.fp-sec-hdr .fp-hdr-profile {
    position: absolute;
    height: 101vh;
    right: 12vh;
}

.fp-hdr-filler {
    mix-blend-mode: darken;
    position: absolute;
    height: 100vh;
    width: auto;
    right: calc(-25rem + 5vw);
    aspect-ratio: 1;
    opacity: .2;
    bottom: -36vh;
}

.fp-hdr-filler video {
    background-color: transparent;
    width: 100%;
    height: 56%;
    object-fit: cover;
}

.fp-sec-videomaking {
    position: relative;
    display: flex;
    flex-direction: row;
    background: linear-gradient(135deg, #28282E 0%, #212126 100%);
    padding-bottom: 1rem;
}

.fp-sec-videomaking:after {
    position: absolute;
    content: "";
    left: 0px;
    bottom: 0px;
    width: 100%;
    height: 32px;
    background: linear-gradient(360deg, rgba(0,0,0,1) 0%, rgba(0,0,0,0) 100%);
}

.fp-sec-vmblock {
    position: relative;
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
}

.fp-sec-vmblock-top {
    position: relative;
    height: 10vh;
    min-height: 10rem;
}

.fp-sec-vmblock-bottom {
    position: relative;
    flex-direction: column;
}

.fp-sec-vmblock-bottom-p1, .fp-sec-vmblock-bottom-p2 {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    padding-bottom: 1rem;
}

.fp-sec-vmblock-bottom-p1 {
    font-size: 1rem;
    color: #f1f2f355;
    text-shadow: 0px 1px 1px black;
    padding-top: 1rem;
    text-transform: uppercase;
    font-weight: bold;
}

.fp-sec-vmblock-bottom-p1:after {
    position: absolute;
    content: "";
    left: 0;
    top: 0;
    width: 100%;
    height: 3em;
    background: radial-gradient(farthest-side at center 0, rgba(0,0,0,.4) 0%, rgba(0,0,0,0) 70%);
    pointer-events: none;
}

.fp-sec-vmblock-bottom img {
    height: 2rem;
    width: auto;
    vertical-align: -.2em;
    margin-left: .2em;
    margin-right: .2em;
    display: inline-block;
    /*filter: drop-shadow(0 .3em .2em black)*/
}

.fp-sec-vmblock-top h1 {
    position: relative;
    font-size: min(6vw, 3rem);
    color: #f1f2f3;
    text-align: left;
    text-transform: uppercase;
    line-height: 2.3rem;
    mix-blend-mode: overlay;
    text-shadow: .25rem .25rem .02rem black;
    margin-left: 2.5rem;
}

.fp-sec-vmblock-top h1 span {
    font-size: 6rem;
    opacity: .5;
    mix-blend-mode: overlay;
    position: absolute;
    left: -2.5rem;
    top: .7rem;
    text-shadow: none;
}

.fp-sec-vmblock-middle {
    position: relative;
    flex: 1;
    display: flex;
    flex-direction: row;
}

.fp-sec-vm-first, .fp-sec-vm-last {
    position: relative;
    flex: 1;
    display: flex;
    z-index: 1;
}

.fp-sec-vm-first {
    color: white;
    line-height: 3rem;
    font-size: 1.5rem;
    justify-content: center;
    flex-direction: column;
}

.fp-sec-vm-txtbox {
    background: #17181a;
    padding: 5%;
    font-size: 1.2rem;
    line-height: 1.4rem;
    border: 1px rgba(255,255,255,.15) solid;
    box-shadow: 0 -.25rem .5rem rgba(0,0,0,0.53) inset;
    border-radius: 1rem;
    width: 100%;
    margin-bottom: 3rem;
}

.fp-sec-vm-txtbox img {
    height: 1.1em;
    vertical-align: -.2em;
    margin-left: .1em;
    margin-right: .1em;
    width: auto;
    display: inline-block;
}

.fp-sec-vm-txtbox div {
    border-bottom: 1px rgba(0,0,0,.5) solid;
    padding: 2%;
    margin-bottom: 1%;
    text-shadow: 0 1px 1px #000, 0 -1px 0px #ffffff25;
}

.fp-sec-vm-txtbox div i {
    font-size: .5em;
    line-height: 1em;
    opacity: .5;
    margin-left: .5em;
    margin-right: .5em;
}

.fp-sec-vm-txtbox div:last-child {
    border-bottom: none;
}

.fp-sec-vm-txtbox div small {
    opacity: .5;
    color: #d7dee4;
}

.fp-sec-vm-last {
    flex: 2;
}

.fp-sec-vm-last-icnt {
    filter: contrast(1.1) hue-rotate(30deg);
    perspective: 100vh;
    transform: translateZ(0);
    position: relative;
    width: 90%;
    height: 90%;
    margin: 5%;
    background: url(/assets/images/dt_ptf_back.webp);
    background-position: center center;
    background-size: cover;
    clip-path: polygon(5% 0, 100% 0, 95% 100%, 0 100%);
    margin-top: 0;
    transition: all .3s ease-out;
}

.fp-sec-vm-last-icnt:hover {
    transform: translateZ(0);
    cursor: pointer;
}

.fp-sec-vm-last-icnt:active {
    transform: translateZ(0) translateY(.4rem);
    cursor: pointer;
}

.fp-sec-vm-last-icnt.ue5en .ppl {
    filter: saturate(.45) brightness(.9) hue-rotate(-33deg) blur(.3px);
}

.fp-sec-vm-last-icnt .ppl {
    position: absolute;
    left: 0;
    top: 0;
    z-index: 1;
    width: 100%;
    height: 100%;
    margin: 0;
    background: url(/assets/images/dt_ptf_front.webp);
    background-position: center center;
    background-size: cover;
    animation: ppl-enter 2s ease-out;
    transition: all .3s ease-out;
}

.fp-sec-vm-last-icnt .tc {
    position: absolute;
    z-index: 2;
    left: 1rem;
    bottom: 1rem;
    background: black;
    font-family: monospace;
    padding: .5rem;
    padding-left: .5rem;
    padding-right: .5rem;
    font-size: 2rem;
    color: #ffffffCC;
    transition: all .3s ease-out;
    opacity: 0;
    line-height: 1.5rem;
    padding-top: 0;
}

.fp-sec-vm-last-icnt .tap {
    position: absolute;
    z-index: 4;
    right: 10%;
    bottom: 5%;
    width: 3rem;
    height: 3rem;
    color: white;
    animation: tapme 6s ease-in-out infinite;
    opacity: .5
}

.fp-sec-vm-last-icnt .tc small {
    font-size: .45em;
    opacity: .7;
}

.fp-sec-vm-last-icnt .wmark {
    position: absolute;
    z-index: 4;
    left: 10%;
    top: 5%;
    height: 2rem;
    width: auto;
    mix-blend-mode: screen;
    opacity: .5
}

@keyframes tapme {
    0%{transform: translateY(0rem);}
    75%{transform: translateY(0rem);}
    80%{transform: translateY(.5rem);}
    82%{transform: translateY(0rem);}
    84%{transform: translateY(.5rem);}
    86%{transform: translateY(0rem);}
}

.fp-sec-vm-last-icnt.ue5en .tc {
    opacity: 1;
}

.fp-sec-vm-last-icnt .ue5 {
    position: absolute;
    left: 0;
    top: 0;
    opacity: 1;
    z-index: 1;
    width: 100%;
    height: 100%;
    margin: 0;
    background: url(/assets/images/ue5_bg.jpg);
    background-position: center center;
    background-size: cover;
    filter: blur(1px);
    transition: all .3s ease-out;
    clip-path: polygon(-45% 0, -100% 0, -55% 100%, 0% 100%);
}

.fp-sec-vm-last-icnt .ins {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    z-index: 3;
    background: transparent;
    box-shadow: 0px 0px 200px black inset;
}

.fp-sec-vm-last-icnt.ue5en .ue5 {
    opacity: 1;
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0% 100%);
}

@keyframes ppl-enter {
    0% {background-position-x: 60%; opacity:0; transform: rotateY(-10deg) scale(1.1);}
    100% {background-position-x: center; opacity: 1; transform: rotateY(0deg);}
}

.fp-sec-vm-bg {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
}

.fp-sec-resume {
    background: #0a1722;
    height: 61vh;
}

.fp-sec-resume .fb-dyna-bg {
    position: absolute;
    left: -1vh;
    top: -1vh;
    width: calc(100% + 2vh);
    height: calc(100% + 2vh);
    filter: blur(5px);
    background:url("/assets/temporary/resume.png");
    background-position: center center;
    background-size: cover;
    mix-blend-mode: difference;
    opacity: .4;
}

.fp-sec-resume .fb-dyna-bg:after {
    position: absolute;
    content: "";
    left: 0px;
    top: 0px;
    width: 100%;
    height: 100%;
    background: linear-gradient(143deg, #00000000 33%, rgba(243, 187, 47, 0.358) 100%);
}

.fp-sec-resume h1, .fp-sec-resume h2 {
    padding-left: 0px;
}

.fp-sec-resume h1 {
    color: white;
    text-transform: uppercase;
    font-size: 6vh;
    text-align: center;
    opacity: 1.5;
    mix-blend-mode: overlay;
    width: 100%;
    margin-bottom: 3vh;
}

.fp-sec-resume h2 {
    color: white;
    text-align: center;
    font-size: 2vh;
    font-weight: 400;
    width: 100%;
}

.fb-dyna-content {
    position: absolute;
    left: 0px;
    top: 0px;
    width: 100%;
    height: 100%;

    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.fp-sec-resume .fp-button {
    margin-top: 2.5vh;
}

.fp-sec-resume .fp-button small {
    opacity: .5;
    font-style: italic;
}

.fp-sec-hire {
    background: linear-gradient(135deg, #ffffff 0%, #c1c2c3 100%);
}

.fp-sec-hire h1 {
    font-size: 6vw;
}

.fp-sec-hire .fp-center-col {
    display: block;
}

.fp-sec-hire h2 {
    font-size: 1.5vw;
    width: calc(100% - 15vh);
}

.fp-sec-hire h2 span {
    font-weight: 400;
}

.fp-sec-hire .fp-button {
    font-size: 3vh;
}

.fp-sec-footer {
    background: #111;
    color: rgba(255,255,255,.9);
    height: 4rem;
    padding: .5rem;
}

.fp-sec-resume-ctr {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.fp-sec-footer-ctr {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
}

.fp-sec-footer-mlogo {
    height: 2em;
    margin-top: .5em;
    filter: invert(1);
    width: auto;
}

.fp-sec-pubmart {
    background: linear-gradient(135deg, #ffffff 0%, #c1c2c3 100%);
    color: #444;
}

.fp-sec-pubmart h1 {
    font-size: min(6vw,3rem);
}

.fp-sec-pubmart-sheet {
    position: absolute;
    width: 40vw;
    height: 60vh;
    background: white;
    left: 7vw;
    bottom: 0px;
    /*box-shadow: 0vh 15vh 60vh -20vh rgb(51 55 67 / 90%);*/
    box-shadow: 0vh -6vh 60vh -20vh rgb(51 55 67 / 90%);
    padding: 3vw;
    text-align: left;
    font-size: 1.5vh;
    font-family: 'Redacted';
}

.pm-contents {
    opacity: .75;
}

.pm-hdr {
    width: 100%;
    border: 2px #555 solid;
    background: #CCC;
    padding: 1.5vh;
    text-align: center;
    font-size: 2vh;
    box-shadow: 0vh 10vh 20vh -8vh rgba(0,0,0,.5);
    box-shadow: 0vh 6vh 7vh -4vh rgba(0,0,0,.5);
    animation: pm-hdr-oscillate 5s ease-in-out infinite;
}

@keyframes pm-hdr-oscillate {
    0% {transform: translateY(-.5vh) scale(.99) rotate(.5deg); }
    50% {transform: translateY(+.5vh) scale(1.01) rotate(-.5deg); }
    100% {transform: translateY(-.5vh) scale(.99) rotate(.5deg); }
}

.pm-hdr-rf {
    position: relative;
    background: black;
    padding: 1vh;
    color: white;
    text-align: left;
    line-height: 1.5vh;
}

.pm-hdr-lne {
    width: 100%;
    padding-left: 1vh;
    padding-right: 1vh;
    min-height: 3.5vh;
    line-height: 1.5vh;
    border-bottom: 1px black solid;
    display: flex;
    flex-direction: row;
    overflow: hidden;
}

.pm-hdr-col {
    flex: 1;
    padding-left: 1vh;
}

.fp-sec-pdesign {
    background: linear-gradient(45deg, black 0%, #333 100%);
    color: white;
}

.fp-sec-pdesign h1 {
    position: relative;
    font-size: 5vw;
    mix-blend-mode: screen;
    color: #EEE;
}

.fp-sec-pdesign h2 {
    position: relative;
    color: #fa9549;
    opacity: .8;
}

.fp-sec-pubmart-sheet span {
    font-family: 'Times New Roman', Times, serif;
}

.pm-hdr b {
    font-weight: 900;
}

.fp-sec-pubmart-sheet img {
    width: 6vw;
    height: auto;
}

.fp-sec-pubmart-sheet:after {
    position: absolute;
    content: "";
    left: 0px;
    top: 0px;
    width: 100%;
    height: 100%;
    background: linear-gradient(190deg, #00000000 60%, #00000025 100%);
}

.fp-sec-hdr-maincnt {
    position: relative;
    left: 0;
    top: 0;
    width: 100%;
    flex: 1;
}

.fp-sec-flex-col {
    display: flex;
    flex-direction: column;
}

.fp-sec-top {
    position: relative;
    width: 100%;
    font-size: 1rem;
    padding-top: 2em;
    display: flex;
    flex-direction: row;
}

.fp-sec-top-center {
    width: 100%;
    padding-left: 7vh;
    padding-right: 7vh;
    display: flex;
}

.fp-sec-top-logo img {
    height: 100%;
    width: auto;
}

.fp-sec-top-logo {
    float: left;
}

.fp-ldrop-text {
    text-shadow: 11px 11px 2px rgba(0,0,0,.03), 10px 10px 2px rgba(0,0,0,.03), 9px 9px 2px rgba(0,0,0,.03), 8px 8px 2px rgba(0,0,0,.03), 7px 7px 2px rgba(0,0,0,.03), 6px 6px 2px rgba(0,0,0,.03), 5px 5px 2px rgba(0,0,0,0.03), 4px 4px 2px rgba(0,0,0,.03), 3px 3px 2px rgba(0,0,0,.03), 2px 2px 2px rgba(0,0,0,.03), 1px 1px 2px rgba(0,0,0,.03);
}

.fp-sec-top-nav {
    display: flex;
    flex-direction: row-reverse;
    padding-top: 1em;
    z-index: 99;
}

.fp-sec-top-nav a {
    color: #444;
    font-weight: bold;
    text-decoration: none;
	padding: 0 1em;
}

.fp-sec-top-nav a:hover {
    color: #666;
}

.hidden-desktop{
	display: none;
}

#open{
	display: none;
}

.fp-sec-hdr-topcenter {
    position: relative;
    width: 80%;
    max-width: 1200px;
    margin: 0 auto;
    height: 100%;
}

.fp-sec-hdr-topleft {
    position: relative;
    float: left;
    width: 30%;
}

.fp-sec-hdr-topright {
    position: relative;
    float: left;
}

.fp-sec-hdr-topright label{
	position: absolute;
	top: 0;
	left: 0;
	cursor: pointer;
}

.fp-sec-hdr-topright {
	width: 70%;
	text-align: right;
}

.fp-sec-hdr-topright span {
    font-size: 2.5em;
    width: 3em;
    height: 3em;
    border-radius: .8em;
    color: #111;
    float: right;
    text-align: right;
    padding-right: .5em;
    transition: all .33s ease-out;
}

.fp-sec-hdr-topright span:active {
    transform: translateY(5px) scale(.95);
}

.fp-sec-nav-el {
    height: 5vh;
    line-height: 5vh;
    padding-left: 1vh;
    padding-right: 1vh;
    margin-left: 2vh;
    color: #444;
    font-weight: 600;
}

.fp-sec-nav-el small {
    font-size: 2.2vh;
    display: inline-block;
    vertical-align: -11px;
    color: #888;
    font-weight: 100;
    transform: rotate(90deg);
}

.fp-sec-top-nav {
    height: 100%;
    flex: 1;
}

.fp-sec-scroll-idc {
    position: absolute;
    width: 6vh;
    aspect-ratio: .5;
    border-radius: 3vh;
    overflow: hidden;
    box-shadow: 0vh 1vh 1vh -0.5vh rgb(162 178 181);
    z-index: 1;
    bottom: 4vh;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    border: 3px #111 solid;
    left: calc(50% - 3vh);
    animation: anim-idc 4s ease-in-out infinite;
    transition: all .33s ease-out;
    background: #eaecf045;
}

.fp-sec-scroll-idc .inside {
    position: relative;
    width: 3vh;
    height: 3vh;
    bottom: 3vh;
    border-radius: 1.5vh;
    background: #111;
    animation: scroll-inside 2s ease-in-out infinite;
}

@keyframes scroll-inside {
    0% {opacity: 0; bottom: 3vh;}
    15% {opacity: 1; bottom: 3vh;}
    85% {opacity: 1; bottom: calc(3vh - 55%);}
    100% {opacity: 0; bottom: calc(3vh - 55%);}
}

@keyframes anim-idc {
    0% {transform: translateY(-1vh);}
    50% {transform: translateY(+1vh);}
    100% {transform: translateY(-1vh);}
}

.fp-center-col {
    position: relative;
    max-width: 50vw;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.fp-button {
    position: relative;
    float: left;
    /*display: flex;
    justify-content: center;
    align-items: center;*/
    padding-left: 30px;
    padding-right: 30px;
    background: #F3BA2F;
    color: black;
    text-transform: uppercase;
    border: none;
    outline: 0px;
    height: 8vh;
    font-weight: 600;
    font-size: 1.8vh;
    box-shadow: 0px 4vh 4vh -2vh rgba(0,0,0,.8);
    transition: all .33s ease-out;
}

.fp-button:hover {
    cursor: pointer;
}

.fp-button:active {
    transform: translateY(2vh) scale(.95);
    box-shadow: 0px 0vh 4vh -2vh rgba(0,0,0,.8);
}

.fp-button small {
    font-size: 1.2vh;
    text-transform: none;
}

.fp-sec-3d {
    position: fixed;
    width: calc(100% - 8vh);
    height: calc(101vh - 8vh);
    left: 4vh;
    top: 4vh;
    background: transparent;
    z-index: 1;
    opacity: 0;
}

.fp-sec-3d canvas {
    pointer-events: none;
}

.fp-sec-3d-label {
    color: white;
    position: absolute;
    padding: .3vh;
    border-radius: 2vh;
    padding-left: 1.2vh;
    padding-right: 1.2vh;
    background: rgba(255,255,255,.2);
    box-shadow: 0vh 2vh 1.5vh -1.2vh rgba(0,0,0,1);
    text-shadow: 0px 2px 0px black;
    backdrop-filter: blur(10px);
    border: 2px rgba(255,255,255,.2) solid;
    font-family: 'Source Sans 3';
    transition: all .33s ease-out;
    border-bottom: 3px #fa9549 solid;
}

.fp-sec-3d-label:hover {
    cursor: pointer;
    background: rgba(255,255,255,.4);
    border: 2px rgba(255,255,255,.6) solid;
    box-shadow: 0vh 2vh 1.5vh -1.2vh rgba(0,0,0,1), 0vh 1vh 5vh rgba(255,255,255,.5);
}

.fp-sec-3d-label small {
    margin-right: 12px;
    font-weight: 900;
}

.fp-sec-top-logo img {
    height: 3em;
}

.fp-sec-hdr .fp-hdr-profile {
    right: calc(-28rem + 5vw + 10vh);
}

/** Styling V2 **/
.sv2-section {
    position: relative;
    width: 100%;
}

.sv2-section-flex {
    display: flex;
    justify-content: center;
}

.sv2-section-fullpage {
    width: 100%;
    height: 101vh;
}

.sv2-section-clear {
    background: linear-gradient(135deg,#fafbff 30%,#b7bec488 100%);
    /*background: #FBFBFB;*/
}

.sv2-section-white {
    background: #FBFBFB;
    background: #f5f6fa;
}

.sv2-section-purewhite {
    background: white;
}

.sv2-section-black {
    background: #0b0b0b;
}

.sv2-halfblk {
    position: absolute;
    width: 100%;
    height: 50%;
    background: #0b0b0b;
}

.sv2-centered-content {
    position: relative;
    width: 100%;
    max-width: 1180px;
}

.sv2-flex-c-2 {
    position: relative;
    float: left;
}

.sv2-flex-c-2-r {
    position: relative;
    width: 50%;
    float: left;
    height: 100%;
}

.sv2-hdr-cnt {
    display: flex;
    flex-direction: column;
}

.sv2-flex-1 {
    flex: 1;
}

.sv2-flex-hdr {
    position: relative;
    width: 100%;
    min-height: 80px;
}

.sv2-pic-cnt {
    position: relative;
    display: flex;
    align-items: end;
}

.sv2-pic-cnt img {
    width: 100%;
    aspect-ratio: 1;
    object-fit: cover;
}

.sv2-disclaimer {
    box-shadow: 0px 1rem 4rem 0px rgba(0,0,0,.9);
    z-index: 1;
    padding: 1rem;
    font-weight: 300;
    border-radius: .6rem;
    margin-top: -6.5rem;
}

.sv2-padblock {
    padding: 5rem;
    padding-right: 0;
}

.sv2-text-bx-1 div {
    font-family: 'Source Serif 4';
    font-size: 1.8rem;
    color: #fbfbfb;
    background: #0b0b0b;
    position: absolute;
    top: -1.5rem;
    padding-left: 1rem;
    padding-right: 1rem;
}

.sv2-text-bx-1 {
    position: relative;
    color: #fbfbfba6;
    width: 100%;
    border-image: linear-gradient(156deg, #ffffff0d 0%,#fafbfc43 100%) 1;
    border-width: .4rem;
    border-style: solid;
    padding: 1rem;
    padding-top: 1.1rem;
    padding-bottom: .7rem;
    margin-top: .5rem;
    text-align: center;
}

.sv2-flex-centered {
    position: relative;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
}

.sv2-main-ttl {
    font-family: 'Source Serif 4';
    line-height: 2.8rem;
    color: #0b0b0b;
}

.sv2-main-ttl h1 {
    font-size: 6rem;
    margin-block-end: 0;
}

.sv2-main-ttl h2 {
    margin-block-start: 0;
    font-size: 2.6rem;
    font-weight: 300;
}

.sv2-main-ttl h2 b {
    font-weight: 600;
}

.sv2-main-ttl div {
    font-size: 1.5rem;
    line-height: 1.8rem;
    margin-top: 4rem;
}

.sv2-grayscaled {
    filter: grayscale(1) brightness(1.1) contrast(1.05);
    mix-blend-mode: multiply;
}

.sv2-serif-title {
    position: relative;
    font-family: 'Source Serif 4';
    font-size: 1.7rem;
    font-weight: 400;
}

#data-local-time {
    animation: hourblink 2s ease-in-out infinite;
}

@keyframes hourblink {
    0% {opacity: .9;}
    50% {opacity: .6;}
    100% {opacity: .9;}
}

/*.sv2-serif-title:after {
    content: "";
    position: absolute;
    left: -1.5rem;
    width: calc(100% + 3rem);
    top: 1.3rem;
    height: .55em;
    border-image: radial-gradient(ellipse at top center, rgba(0,0,0,0) 65%, rgba(0,0,0,.2) 100%) 1;
    border-width: .2rem;
    border-style: solid;
    z-index: 0;
    opacity: .5;
}*/

.sv2-text-blk {
    width: 80%;
    padding: 1rem;
    font-size: 1.1rem;
    font-weight: 350;
    text-justify: auto;
    text-align: center;
}

.sv2-text-blk a {
    color: #0b0b0b;
}

.sv2-flex-text {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.sv2-text-padder {
    padding: 1rem;
    padding-top: 3rem;
    padding-bottom: 3rem;
}

.sv2-button {
    position: relative;
    padding: .5rem;
    padding-left: 4rem;
    padding-right: 4rem;
    background: #0b0b0b;
    color: #fbfbfb;
    font-family: 'Source Sans 3';
    font-weight: 400;
    border: none;
    outline: 0px;
    font-size: 1.1rem;
    box-shadow: 0px 4vh 4vh -2vh rgba(0,0,0,.8);
    transition: all .33s ease-out;
    line-height: 1.1rem;
}

.sv2-button small {
    font-family: 'Source Serif 4';
    font-weight: 100;
    font-size: 0.6rem;
    opacity: .8;
}

.sv2-button:hover {
    cursor: pointer;
}

.sv2-button:active {
    transform: translateY(2vh) scale(.95);
    box-shadow: 0px 0vh 4vh -2vh rgba(0,0,0,.8);
}

.sv2-ftr-cnt {
    position: relative;
    display: flex;
    flex-direction: column;
    color: #fbfbfb;
    padding-top: 1rem;
    padding-bottom: 2rem;
}

.sv2-ftr-line {
    position: relative;
    width: 100%;
}

.sv2-ftr-item-4 {
    position: relative;
    float: left;
    width: 25%;
    min-height: 15rem;
    padding: 2rem;
}

.sv2-ftr-item-4 h1 {
    font-family: 'Source Serif 4';
    font-weight: 400;
    font-size: 1rem;
}

.sv2-ftr-item-4 div {
    color: #fbfbfbd2;
    font-weight: 400;
    font-size: .8rem;
    width: 100%;
    position: relative;
    float: left;
}

.sv2-ftr-logo {
    height: 3rem;
    margin-bottom: 1.5rem;
    width: auto;
}

.sv2-ftr-bottom {
    border-top: 1px #FBFBFB22 solid;
    padding: 2rem;
    padding-top: 1rem;
    padding-bottom: 0;
    width: 100%;

    display: flex;
    flex-direction: row;
    font-weight: 300;
    opacity: .7;
}

.sv2-ftr-bottom div {
    position: relative;
    flex: 1;
}

.sv2-ftr-bottom div:last-child {
    text-align: right;
}

.sv2-ic-row {
    position: relative;
    margin-top: 1rem;
    margin-left: -0.35rem;
}

.sv2-ic-row img {
    height: 1.5rem;
    width: auto;
    opacity: .6;
    margin-left: .25rem;
    margin-right: .25rem;
    transition: all .3s ease-out;
}

.sv2-ic-row a:hover img {
    opacity: 1;
    cursor: pointer;
}

.sv2-ftr-btncol {
    position: relative;
    width: 100%;
    padding-top: 1rem;
}

.sv2-ftr-btncol button {
    outline: 0;
    position: relative;
    float: left;
    border: 1px #fbfbfb55 solid;
    color: #fbfbfb;
    font-size: .8rem;
    font-weight: 400;
    height: 2rem;
    margin-bottom: .33rem;
    border-radius: .25rem;
    width: 100%;
    background: none;
    transition: all .33s ease-out;
}

.sv2-ftr-btncol button:hover {
    background: #fbfbfb;
    color: #0b0b0b;
    cursor: pointer;
}

.sv2-ftr-btncol button:active {
    transform: translateY(.2rem) scale(.99);
}

.sv2-ftr-btncol button small {
    font-size: .6rem;
    text-transform: uppercase;
    font-weight: 600;
    padding-top: -1rem;
    opacity: .7;
}

.sv2-inline-ic {
    display: inline;
    height: 1rem;
    width: auto;
    vertical-align: -.3rem;
    margin-right: .3rem;
}

.sv2-link-list {
    list-style-type: none; /* Remove bullets */
    padding: 0;
    margin: 0;
    padding-top: 1rem;
}

.sv2-link-list li {
    margin-bottom: .4rem;
    opacity: .6;
    transition: all .33s ease-out;
}

.sv2-link-list li:hover {
    opacity: 1;
}

.sv2-ftr-notch {
    display: none;
    position: absolute;
    width: 50%;
    height: 2rem;
    border-radius: 1rem;
    left: 25%;
    top: -1rem;
    background: #0b0b0b;
    border: .5rem #f5f6fa solid;
}

.sv2-section-footer {
    overflow: hidden;
}

.sv2-icon-button-1 {
    position: relative;
    padding: 1rem;
    padding-left: 2rem;
    padding-right: 2rem;
    background: #0b0b0b;
    color: rgba(240, 240, 240, 0.8);
    display: flex;
    flex-direction: row;
    height: 4rem;
    transition: all .33s ease-out;
    box-shadow: 0 2rem 2rem -1rem rgba(0,0,0,.5);
}

.sv2-icon-button-1:hover {
    color: #fbfbfb;
    cursor: pointer;
}

.sv2-icon-button-1:active {
    transform: translateY(1rem) scale(.99);
    box-shadow: 0 1rem 2rem -1rem rgba(0,0,0,.5);
}

.sv2-icon-button-1 div {
    height: 100%;
}

.sv2-icon-button-1 div:first-child {
    height: 100%;
    aspect-ratio: 1;
}

.sv2-icon-button-1 div:first-child img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    opacity: .8;
    transition: all .33s ease-out;
}

.sv2-icon-button-1:hover div:first-child img {
    opacity: 1;
}

.sv2-icon-button-1 div:last-child {
    padding-left: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.sv2-section-title {
    font-size: 2rem;
}

.sv2-section-title:after {
    content: attr(data-text);
    position: absolute;
    left: -2rem;
    top: -3rem;
    font-size: 5.5rem;
    font-weight: 100;
    opacity: .035;
}

.sv2-section-title.inverted:after {
    color: #fbfbfb;
    opacity: .08;
    white-space: nowrap;
} 

.sv2-section-title.inverted {
    color: #fbfbfb;
}

.sv2-block-c-2 {
    position: relative;
    width: 100%;
}

.sv2-block-c-2-item {
    position: relative;
    width: 50%;
    float: left;
    padding: 1rem;
}

.sv2-block-l-2 {
    position: relative;
}

.sv2-block-l-2-item {
    position: relative;
    width: 100%;
    padding: 1rem;
    float: left;
}

.sv2-highlighted-title {
    position: relative;
    background: #0b0b0b;
    font-weight: 500;
    color: #fbfbfb;
    padding: .5rem;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
    font-family: 'Source Serif 4';
    box-shadow: 0 1rem 2rem -1rem rgba(0,0,0,.5);
    border-radius: .5rem;
}

.sv2-smalltext-jsty {
    font-size: .9rem;
    text-align: justify;
}

.sv2-quoted-text {
    position: relative;
    font-size: 1rem;
    text-align: justify;
    padding-left: 3.5rem;
    padding-right: 3rem;
    font-weight: 400;
    font-style: italic;
}

.sv2-blocky-text {
    position: relative;
    font-size: 1rem;
    text-align: left;
    padding: 2rem;
    font-weight: 400;
    font-style: italic;
}

.sv2-quoted-text:before {
    position: absolute;
    z-index: 1;
    content: '“';
    left: -.5rem;
    top: -2rem;
    font-size: 7rem;
    color: #0b0b0b;
    opacity: .1;
}

.sv2-quoted-text:after {
    position: absolute;
    z-index: 1;
    content: '”';
    left: calc(100% - 6rem);
    top: calc(100% - 3.5rem);
    font-size: 7rem;
    color: #0b0b0b;
    opacity: .1;
}

.sv2-section-padtopbot {
    padding-top: 1rem;
    padding-bottom: 1rem;
}

.sv2-featured-skill {
    position: relative;
    float: right;
    padding: .5rem;
    padding-left: 1rem;
    padding-right: 1rem;
    font-family: 'Source Serif 4';
    font-weight: 600;
    background: #f5f6fa;
    color: #0b0b0b;
    border-bottom-left-radius: 1rem;
    border-bottom-right-radius: 1rem;
    margin-right: 1rem;
}

.sv2-bot-shade:after {
    position: absolute;
    content: "";
    left: 0;
    bottom: 0;
    width: 100%;
    height: 32px;
    background: linear-gradient(360deg,rgba(0,0,0,.08) 0,rgba(0,0,0,0) 100%);
}

.sv2-section-padded {
    padding-left: 3rem;
    padding-right: 3rem;
}

.sv2-grid-c-3 {
    position: relative;
    width: 100%;
    overflow: hidden;
    padding-bottom: 1rem;
}

.sv2-grid-c-3-item {
    position: relative;
    padding: 1rem;
    float: left;
    width: calc(100% / 3);
    aspect-ratio: 1;
}

.sv2-skill-card {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;

    border-image: radial-gradient(ellipse at top center, rgba(255,255,255,0) 65%, rgba(255,255,255,.4) 100%) 1;
    border-width: .2rem;
    border-style: solid;

    box-shadow: 0px 1rem 4rem 0px rgba(0,0,0,.9);
}

.sv2-skill-bg {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    filter: grayscale(1);
    opacity: .4;
    transition: all .33s ease-out;
}

.sv2-skill-card:hover {
    cursor: pointer;
}

.sv2-skill-card:hover div:last-child {
    opacity: .9;
}

.sv2-skill-card:hover .sv2-skill-bg {
    transform: translateY(-.3rem) scale(1.1);
}

.sv2-skill-card h2 {
    /*font-family: 'Source Serif 4';*/
    opacity: .6;
    transition: all .33s ease-out;
    transform: translateY(.1rem) scale(.99);
}

.sv2-skill-card:hover h2 {
    opacity: 1;
    transform: translateY(0) scale(1);
}

.sv2-skill-cnt {
    position: relative;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    padding: 1rem;
    color: #fbfbfb;
}

.sv2-skill-cnt div:last-child {
    opacity: 0;
    transition: all .33s ease-out;
    text-shadow: 0 0 1rem black, 0 0 .5rem black,  0 0 .1rem black;
}

.sv2-ftr-icofield {
    position: relative;
    width: 100%;
    display: flex;
    flex-direction: row;
}

.sv2-ftr-icofield div:first-child {
    position: relative;
    flex: 0;
    font-weight: 200;
}

.sv2-ftr-icofield div:last-child {
    position: relative;
    flex: 1;
}

.sv2-githash {
    opacity: .6;
    letter-spacing: .05rem;
    font-size: .75rem;
    padding-left: .1rem;
}

.sv2-ftr-worldmap {
    position: relative;
    width: 100%;
    aspect-ratio: 2.35;
    margin-top: 1.2rem;
}

.sv2-ftr-worldmap img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    aspect-ratio: 2.35;
    opacity: .3;
}

.sv2-ftr-worldmap-ovr {
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    width: 100%;
    aspect-ratio: 2.35;
}

.sv2-ftr-worldmap-ovr div {
    position: absolute;
    z-index: 1;
    width: .25rem;
    height: .25rem;
    background: linear-gradient(45deg, #fbfbfbAA 0%, #fbfbfb44 100%);
    border-radius: .125rem;
    transform-origin: center center;
}

.sv2-ftr-worldmap-ovr div:before {
    position: absolute;
    content: "";
    background: #fbfbfb;
    opacity: .2;
    width: .5rem;
    height: .5rem;
    border-radius: .25rem;
    left: -.125rem;
    top: -.125rem;
    transform: scale(1);
    animation: geodot 2s ease-out infinite;
}

.sv2-btn-row-2-c {
    position: relative;
    width: 100%;
    margin-top: .5rem;
}

.sv2-btn-row-2-c-item {
    position: relative;
    float: left;
    width: 50%;
    padding: .25rem;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.sv2-btn-row-2-c-item .sv2-icon-button-1 {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: min(4vw, 1rem);
}

.sv2-btn-row-2-c-item a {
    width: 100%;
}

.sv2-inline-fvr {
    height: 2.4em;
    margin-left: .35em;
    width: auto;
    display: inline;
}

@keyframes geodot {
    0% {transform: scale(1); opacity: 0;}
    10% {transform: scale(1); opacity: .2;}
    100% {transform: scale(1.5); opacity: 0;}
}

/** New responsive **/
/* Tablets */
@media (min-width: 768px) and (max-width: 979px)
{
    .fp-sec-top-logo img {
        height: 5em;
        padding-bottom: .5em;
    }

    .fp-sec-top-nav {
        display: flex;
        flex-direction: row;
        align-items: center;
        justify-content: center;
    }

    .ruler-rule1 {
        display: block;
    }
}

/* Transition 2 */
@media (max-width: 1300px)
{
    .sv2-grid-c-3-item {
        aspect-ratio: .65; 
    }
}

/* Large monitors */
@media (min-width: 980px)
{
    .fp-sec-hdr .fp-hdr-profile {
        right: calc(-36rem + 5vw + 10vh);
    }
}

/* Small monitors */
@media (max-width: 979px)
{
    .sv2-resume-btn {
        font-size: min(1.6vw,1rem) !important;
    }

    .sv2-grid-c-3-item {
        width: 50%;
        aspect-ratio: .78; 
    }

    .sv2-ftr-item-4 {
        width: 50%;
    }

    .sv2-flex-c-2-r {
        width: 100%;
        height: auto;
    }

    .fp-sec-vmblock-middle {
        flex-direction: column;
    }

    .fp-sec-vm-first {
        flex: 1;
    }

    .fp-sec-vm-last {
        flex: 2;
    }

    .fp-sec-vm-txtbox {
        font-size: max(2.2vw, 1.2rem);
        padding: 1.5%;
        margin-bottom: 0;
    }

    .fp-sec-vm-last-icnt {
        background-position-y: top;
        min-height: 60vh;
        margin-top: 5%;
    }

    .fp-sec-vm-last-icnt .ppl {
        background-position-y: top;
        min-height: 60vh;
    }

    .fp-sec-top-logo img {
        height: 4em;
        padding-bottom: .5em;
    }

    .fp-sec-hdr-topleft, .fp-sec-hdr-topright {
		width: 100%;
		text-align: center;
	}

    .fp-sec-top-nav {
        display: flex;
        flex-direction: row;
        align-items: center;
        justify-content: center;
    }

    .fp-sec-hdr .fp-hdr-profile {
        height: 70vh;
        right: calc(-17rem + 2vw);
        bottom: 0;
    }

    .fp-sec-hdr .fp-hdr-profile img {
        height: 100%;
        width: auto;
    }

    .fp-sec-hdr h2 {
        margin-top: 0vh;
        width: 40vw;
        font-size: 2.5vh;
        font-weight: 400;
    }

    .fp-hdr-filler {
        mix-blend-mode: darken;
        position: absolute;
        height: 78vh;
        width: auto;
        right: -13vw;
        aspect-ratio: 1;
        opacity: .2;
        bottom: -26vh;
    }

    .ruler-rule2 {
        display: block;
    }
}

/* Landscape phones, portrait tablets */
@media (max-width: 767px)
{
    .sv2-btn-row-2-c-item .sv2-icon-button-1 {
        padding-left: 0;
        padding-right: 0;
    }

    .sv2-icon-button-1 {
        font-size: min(3vw,1rem);
    }

    .sv2-btn-row-2-c-item {
        padding-left: 0;
        padding-right: 0;
        width: 100%;
        margin-bottom: .5rem;
    }

    .sv2-grid-c-3-item {
        width: 100%;
        height: fit-content;
        aspect-ratio: unset;
    }
    
    .sv2-grid-c-3-item .sv2-skill-cnt>div:last-child {
        opacity: .8;
    }

    .sv2-grid-c-3-item h2 {
        opacity: 1;
        transform: translateY(0) scale(1);
    }

    .sv2-block-c-2-item {
        width: 100%;
    }

    .fp-sec-hdr-topleft, .fp-sec-hdr-topright {
		width: 100%;
		text-align: center;
	}

    .fp-sec-hdr-topcenter {
        width: 90%;
    }

    .fp-sec-hdr h1 {
        font-size: 5em;
        margin-block-start: .2em;
    }

    .fp-sec-hdr h1 div {
        width: 40vw;
        font-size: .4em;
        line-height: 1em;
    }

    .ruler-rule3 {
        display: block;
    }
}

/* Intermediary step */
@media (max-width: 600px)
{
    .sv2-ftr-item-4 {
        width: 100%;
        min-height: 0;
        height: auto;
        padding-bottom: 0;
        text-align: center;
    }

    .sv2-ftr-item-4:last-child {
        padding-bottom: 1rem;
    }

    .sv2-ftr-bottom {
        flex-direction: column;
    }

    .sv2-ftr-bottom div:last-child {
        text-align: left;
    }

    .fp-sec-top-logo img {
        height: 3rem;
        margin-left: 1rem;
    }

    .fp-sec-top-nav {
        position: absolute;
        right: 0px;
    }

    .fp-sec-hdr h1 {
        font-size: 4em;
        margin-left: 8vw;
    }

    .fp-sec-hdr h2 {
        margin-top: 0vh;
        width: 30vw;
        font-size: 2.5vh;
        font-weight: 400;
        margin-left: 8vw;
    }

    .hidden-desktop {
		display: block;
	}

    .fp-sec-top-nav {
        display: flex;
        flex-direction: column;
        justify-content: end;
        align-items: end;
        opacity: 0;
    }
    
    .fp-sec-hdr-topcenter {
        width: 95%;
    }

    .fp-sec-hdr-topleft {
		width: 25%;
		text-align: center;
        float: left;
	}

    .fp-sec-hdr-topright {
		width: 75%;
		text-align: center;
        float: left;
	}

    input[type="checkbox"]:checked + .fp-sec-top-nav {
		height: 130px;
        margin-top: 3em;
        opacity: 1;
	}

    .fp-sec-top-nav {
		height: 0;
		overflow: hidden;
		transition: all .3s ease;
	}

    .fp-sec-top-nav>a{
		padding: 0 1em;
		display: block;
		border-bottom: solid 1px rgba(255,255,255,.1);
	}

    .ruler-rule4 {
        display: block;
    }
}

/* Landscape phones and down */
@media (max-width: 480px) 
{

    .ruler-rule5 {
        display: block;
    }
}

/** Dark mode management **/
@media (prefers-color-scheme: dark) {
    
}