@charset "utf-8";

:root {
	--colourTP: #00000000;
    --colourTL: #0000000F;
	--colour1: #181818;
    --colour1TL: #18181810;
    --colour1TL2: #1818180;
    --colour2: #FFF8F6;
    --colour3: #FFAA00;
    --colour4: #000000;
	--colour5: #C03030;
    --colour5TL: #C03030C0;
    --colour6: #FF00AA;
    --colour7: #FFAA00;
}

/*
    GENERAL
*/
*, html {
	font-size: 100%;
	margin: 0;
	padding: 0;
	scroll-behavior: smooth;
    cursor: crosshair;
}

#index-body {
    background-color: var(--colour2);
    background-size: cover;
    background-position: center;
	overflow-x: hidden;
	overflow-y: auto;
	min-height: 100vmin;
	display: flex;
	flex-direction: column;
	position: relative;
}

body {
    background-color: var(--colour3);
    background-image: url("plain-background.png");
    backdrop-filter: brightness(1);
    background-size: fill;
    background-position: center;
    background-attachment: fixed;
	overflow-x: hidden;
	overflow-y: auto;
	min-height: 100vmin;
	display: flex;
	flex-direction: column;
	position: relative;
}

    h1 {
	font-size: 3rem;
	font-family: "Inter";
	font-weight: 600;
	color: var(--colour1);
    padding-bottom: 1vmin;
    }

    p {
	font-size: 1rem;
	font-family: "Inter";
	font-weight: 400;
	text-decoration: none;
	color: var(--colour1);
    }
    
    a {
        cursor: url('cursor3.png') 10 10, auto;
    }

/*
    HEADER
*/
    header {
	display: block;
	justify-content: space-between;
	position: fixed;
	width: 192px;
    height: 100vh;
	top: 0%;
	left: 0%;
    padding-left: 0vmin;
    padding-right: 4vmin;
	z-index: 10;
    background-color: var(--colourTL);
    border-width: 4px;
    border-right-style: solid;
    border-color: var(--colour1);
    /*border-bottom-style: dashed;
    border-width: 2px;
    border-color: var(--colour1TL);*/
    }

    #wrapper h1:hover {
        color: var(--colour3);
        background: var(--colour1);
        border-color: var(--colour1);
    }

    #header ul {
        list-style-type: none;
        margin-right: 8vmin;
        background-color: red;
        min-width: 192px;
    }

    #header li {
        /*float: left;
        display: inline;*/
        margin-left: 4vmin;
        line-height: 8vmin;
    }

    .nav-home {
        font-size: 2.75rem;
        color: var(--colour1);
        font-family: "Bebas Neue";
        text-decoration: none;
        position: relative;
        line-height: 4rem;
        height: 4rem;
        padding-left: 4vmin;
        min-width: 192px;
        border-bottom-style: solid;
        border-width: 4px;
        border-color: var(--colour2);
    }
    
    .nav-home:hover {
        color: var(--colour1);
        background: var(--colour3);
    }
    
    .nav-home::before {
	
    color: var(--colour3);
	position: absolute;
	width: 192px;
	height: 100%;
	background-color: var(--colour1);
	bottom: 0;
	left: 0;
    padding-left: 4vmin;
	transform-origin: right;
	transform: scaleX(0);
	transition: transform .2s ease-in-out;
    }
    
    #home::before {
        content: '[HOME]';
    }
    
    #works::before {
        content: '[WORKS]';
    }
    
    #services::before {
        content: '[SERVICES]';
    }
    
    #contact::before {
        content: '[CONTACT]';
    }

    .nav-home:hover::before {
      transform-origin: right;
      transform: scaleX(1);
    }

    #nav {
	font-size: 1.25rem;
	color: var(--colour1);
	font-family: "Inter";
	font-weight: 450;
	text-decoration: none;
	position: relative;
    }

    #nav:hover {
        color: var(--colour1);
    }

    #nav::before {
	content: '';
	position: absolute;
	width: 100%;
	height: 2px;
	border-radius: 0.1rem;
	background-color: var(--colour3);
	bottom: 0;
	left: 0;
	transform-origin: right;
	transform: scaleX(0);
	transition: transform .2s ease-in-out;
}

#nav:hover::before {
  transform-origin: left;
  transform: scaleX(1);
}

#wrapper {
    display: flex;
    justify-content: flex-start;
}

/*
    FOOTER
*/
footer {
    background-color: var(--colourTP);
    position: absolute;
    bottom: 0%;
    left: 0%;
    width: 100vw;
}

#footer h1 {
    margin-left: 4vmin;
    margin-bottom: 1vmin;
    font-family: "Inter";
    font-size: 1.33vmin;
    color: var(--colour1);
    font-weight: 400;
}

/*
    MAIN TEXT
*/

    #main-text-container-container {
    margin: 0;
    position: absolute;
    top: 13vmax;
    /*-ms-transform: translateY(-50%);
    transform: translateY(-50%);*/
    max-width: 100%;
    max-height: 100%;
    }

    #main-text-container {
    margin: 0;
    /*-ms-transform: translateY(-50%);
    transform: translateY(-50%);*/
    margin-top: 2vmax;
    margin-right: 10vw;
    margin-left: 60%;
    max-width: 30%;
    max-height: 100%;
    }

    #main-text {
    margin: 0;
    padding-left: 1rem;
    border-left-style: solid;
    border-width: 0.25rem;
    border-color: var(--colour5);
    /*border-image: linear-gradient(to bottom, var(--colour6), var(--colour7));*/
    border-image-slice: 1;
    max-width: 80%;
    max-height: 100%;
    }
    
    #main-text-container #dot-top {
        position: absolute;
        top: 3vmax;
        right: 7.5vw;
        z-index: 10;
    }
    
    #main-text-container #dot-bottom {
        position: absolute;
        bottom: 45px;
        right: 7.5vw;
        z-index: 10;
    }
    
    #main-buttons {
        position: relative;
        top: 2vmax;
        width: 100%;
        max-height: 15%;
    }
    
    #main-buttons a {
        line-height: 150%;
        font-size: 150%;
        font-family: "Inter";
        font-weight: 400;
        text-decoration: none;
        color: var(--colour1);
    }
    
    #timestamp {
        font-size: 2vmin;
        font-family: "Inter";
        font-weight: 400;
        text-decoration: none;
        color: var(--colour1);
        right: 0vmin;
        position: absolute;
        width: 25%;
        bottom: 2vmin;
    }
    
    #timestamp p {
        font-size: 2vmin;
        font-family: "Inter";
        font-weight: 400;
        text-decoration: none;
        color: var(--colour1);
    }
    
    #timestamp ul {
        list-style-type: none;
    }
    
    #timestamp li {
        padding-left: 1.25rem;
        float: left;
        display: inline;
    }


/*
MAIN BUTTON SIZES
*/

#main-buttons a {
    padding-bottom: 2%;
    padding-top: 2%;
    font-size: 1.5rem;
}

#main-buttons ul {
    color: var(--colour1);
    display: flex;
}
    
#main-buttons li {
    display: inline-block;
    width: 50%;
    margin: 0%;
    padding: 0%;
    text-align: center;
}

/*
MAIN BUTTON COLOURS
*/

#main-buttons .button-about {
    border-top-left-radius: 0.5rem;
    border-bottom-left-radius: 0.5rem;
    background-color: var(--colour5TL);
    transition: background-color 0.5s;
}

#main-buttons .button-about:hover {
    background-color: var(--colour5);
}

#main-buttons .button-services {
    border-top-right-radius: 0.5rem;
    border-bottom-right-radius: 0.5rem;
    background-color: var(--colour1TL);
    color: var(--colour1);
    transition: background-color 0.5s;
}

#main-buttons .button-services:hover {
    background-color: var(--colour1TL2);
}

/*GRIDS*/
.grid-line {
    -webkit-mask-image: -webkit-gradient(linear, left top, right top, 
    from(rgba(0,0,0,0)), to(rgba(0,0,0,0.25)));
    pointer-events: none;
}

#grid-line-top {
    -webkit-mask-image: -webkit-gradient(linear, left top, right top, 
    from(rgba(0,0,0,0)), to(rgba(0,0,0,0.25)));
    pointer-events: none;
}

#grid-line-bottom {
    position: relative;
    bottom: -3vmax;
    -webkit-mask-image: -webkit-gradient(linear, left top, right top, 
    from(rgba(0,0,0,0)), to(rgba(0,0,0,0.25)));
    pointer-events: none;
}

#grid-container {
    top: 10vmin;
    right: 0vmin;
    width: 100vw;
    position: absolute;
}

.grid {
    margin-left: 50vmin;
    margin-right: 2vmin;
    position: relative;
    display: grid;
    grid-row-gap: 2.5vmin;
    grid-template-columns: 100%;
    padding-bottom: 1rem;
}

.grid-item {
    box-shadow: 0px 0px 5px var(--colour1);
    background-size: cover;
    aspect-ratio: 16 / 9;
    border-radius: 16px;
    border-color: var(--colour1);
    border-width: 2px;
    border-style: solid;
    transition: filter 0.2s;
}

.grid-item:hover {
    filter: blur(2px) brightness(75%);
    color: white;
}

#grid-item-1 {
    background-image: url("shoeboxdenoised.png");
}

#grid-item-2 {
    background-image: url("CassetteRender3.webp");
}

#grid-item-3 {
    background-image: url("pyrite3.webp");
}

#grid-item-4 {
    background-image: url("KarasuRenderNoise.webp");
}

#grid-item-5 {
    background-image: url("temp.webp");
}

/*
    404
*/

    #404 {
        width: 100vw;
        height: 100vh;
        -ms-transform: translateY(-50%);
        transform: translateY(-50%);
    }
    
    #404 h1 {
        font-size: 20vmin;
        color: var(--colour6);
        font-family: "Orbitron";
        font-weight: 500;
        text-decoration: none;
    }
    
    #404 h2 {
        font-size: 10vmin;
        color: var(--colour6);
        font-family: "Orbitron";
        font-weight: 500;
        text-decoration: none;
    }