*,
*::before,
*::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    background-color: var(--clrBG);
}

body {
    width: 100%;
}


/*
=======================================
Base Container
=======================================
*/

.base-container {
    width: 100%;
    min-height: 100vh;

    display: grid;
    margin-inline: auto;
    position: relative;
    align-content: start;
}


/*
=======================================
Base Header
=======================================
*/

.base-header {
    width: 100%;

    text-align: center;
    position: relative;
}

.base-banner {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.badge-25 {
    max-width: 3rem;
    position: absolute;
    top: -10px;
    right: 15%;
    transition: transform 250ms ease-in-out;
}

.badge-25:hover {
    transform: scale(1.1) translateY(2%);
}


/*
=======================================
Base Main
=======================================
*/

.base-main {
    display: grid;
    grid-template-columns: 3fr 1fr;
    max-width: 1200px;
    margin: 0 auto;
    width: 100%;
}

/* === Wrappers === */

.wrapper__content, .wrapper__sidebar {
    display: grid;
    grid-auto-flow: row;
    row-gap: 1.5rem;
    margin: 2rem;
    align-content: start;
    min-height: 80lvh;
    height: 100%;
}

.wrapper__sidebar {
    border-left: 1px solid var(--clrBorder);
    padding-left: 2rem;
    height: 90%;
}

.main-para, .main-header, .main-para__list {
    margin-bottom: 1.35rem;
}

.page-header {
    margin-top: 2rem;
    margin-bottom: 1rem;
}

/* === Sidebar / Main Menu === */

.main-menu {
    display: flex;
    flex-direction: column;
    row-gap: 1rem;
}

.sub-menu {
    margin-top: 1rem;
    margin-left: 1rem;
    
    display: flex;
    flex-direction: column;
    align-items: start;

    row-gap: 0.5rem;
    border-left: 1px solid var(--clrBorder);
    padding-left: 1rem;
    font-size: 12pt;
}

.main-logo {
    width: 500px;
}

.sb-nav-item {
    text-decoration: none;
    font-family: 'Montserrat', sans-serif;
    font-weight: bold;
    color: var(--clrAccentText);
    transition: all 250ms ease-in-out;
    cursor:pointer;
    font-size: 1rem;
}

.sb-nav-item:hover {
    color: var(--clrText);
    text-shadow: rgba(255,255,255,0.57) 0px 0px 14px;
}

details[open] .sub-menu .page-highlight {
    color: white;
    text-shadow: rgba(255,255,255,0.57) 0px 0px 14px;
}

/* === Page - Portfolio === */

.wrapper__content.portfolio {
    margin: 2rem;
    max-width: 100%;
}

.wrapper__table {
    display: flex;
    width: 100%;
    flex-wrap: wrap;
    gap: 1rem;
    align-content: start;
}


/*
=======================================
Base Footer
=======================================
*/

.base-footer {
    width: 100%;
    max-height: 10vh;
    background-image: url("/assets/images/header-bg.svg");
    background-size: cover;
    background-position: center;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 2rem;
    position: relative;
    border-top: 3px solid;
    border-image: linear-gradient(45deg, var(--clrBorder), var(--clrHeading), var(--clrAccent)) 1;
    margin-top: 2rem;
}

.copyR {
    font-size: 10pt;
}