*{
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

:root{
    /* ==================== FONTS ==================== */
    font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;

    /* ==================== PALLETTE ==================== */
    
    /* HUES */
    --hue-neutral: 265;
    --hue-accent: 256;
    --hue-success: 155;
    --hue-warning: 38;
    --hue-danger: 355;


    /* SATURATION */
    --sat-neutral: 6%;
    --sat-muted: 10%;
    --sat-accent: 65%;

    /* SCALES (light - dark)*/
    --n-0: hsl(var(--hue-neutral), var(--sat-neutral), 100%);
    --n-50: hsl(var(--hue-neutral), var(--sat-neutral), 95%);
    --n-100: hsl(var(--hue-neutral), var(--sat-neutral), 90%);
    --n-200: hsl(var(--hue-neutral), var(--sat-neutral), 80%);
    --n-300: hsl(var(--hue-neutral), var(--sat-neutral), 70%);
    --n-400: hsl(var(--hue-neutral), var(--sat-neutral), 60%);
    --n-500: hsl(var(--hue-neutral), var(--sat-neutral), 50%);
    --n-600: hsl(var(--hue-neutral), var(--sat-neutral), 40%);
    --n-700: hsl(var(--hue-neutral), var(--sat-neutral), 30%);
    --n-800: hsl(var(--hue-neutral), var(--sat-neutral), 20%);
    --n-900: hsl(var(--hue-neutral), var(--sat-neutral), 10%);

    --a-400:hsl(var(--hue-accent), var(--sat-accent), 65%);
    --a-500: hsl(var(--hue-accent), var(--sat-accent), 55%);
    --a-600: hsl(var(--hue-accent), var(--sat-accent), 45%);

    /* ==================== ROLES ====================*/
    /* Surfaces */
    --color-bg: var(--n-50);
    --color-surface: var(--n-0);
    --color-surface-elevated: var(--n-100);

    /* Text */
    --color-text-primary: var(--n-900);
    --color-text-secondary: var(--n-700);
    --color-text-tertiary: var(--n-500);

    /* Accent */
    --color-accent: var(--a-600);
    --color-accent-contrast: var(--n-0);
}

@media(prefers-color-scheme: dark){
    :root{
        /* Surfaces */
        --color-bg: var(--n-900);
        --color-surface: var(--n-800);
        --color-surface-elevated: var(--n-700);

        /* Text */
        --color-text-primary: var(--n-50);
        --color-text-secondary: var(--n-200);
        --color-text-tertiary: var(--n-400);
        
        /* Accent */
        --color-accent: var(--a-400);
        --color-accent-contrast: var(--n-900);
    }
}

body{
    background-color: var(--color-bg);
    color: var(--color-text-primary);
}

main{
    min-height: 100vh;

    display: grid;
    grid-template-columns: 300px 1fr;
    grid-template-rows: min-content 1fr;
    gap: 16px;
}

.sidebar{
    background-color: var(--color-surface);
    border-top-right-radius: 32px;

    grid-row: 2 / -1;

    display: flex;
    flex-direction: column;
}

.sidebar nav ul{
    display: flex;
    flex-direction: column;
    gap: 12px;
    
    font-size: 1.2rem;
    list-style-type: none;
    align-items: stretch;
    padding: 1rem;
}

.menu .tab{
    border-radius: 8px;
    padding: 8px 16px;
}

.menu .tab.selected{
    background-color: var(--color-accent);
    color: var(--color-accent-contrast);
}

.icon-button{
    display: flex;
    align-items: center;
    gap: 8px;
}

.icon{
    width: 20px;
    height: 20px;
    stroke: var(--color-text-secondary);
    fill: none;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.sidebar .tab.selected .icon{
    stroke: var(--color-accent-contrast);
}



.header{
    grid-column: 1 / -1;

    background-color: var(--color-surface);
    padding: 16px;

    display: grid;
    grid-template-columns: subgrid;

    font-size: 1.2rem;
}


.header .logo{
    display: flex;
    justify-content: flex-start;
    align-items: center;
    
    font-size: 1rem;

    border-right: 2px solid var(--color-bg);
}

.header .logo rect{
    fill: var(--color-text-primary);
}

.header .logo rect:last-of-type{
    fill: var(--color-accent);
}

.header .tools{
    display: flex;
    align-items: center;
    gap: 16px;
}

.header .tools .search{
    margin-left: auto;

    flex: 1;
    max-width: 500px;
    display: flex;
    align-items: center;
    gap: 16px;
}

input[type="search"]{
    border-radius: 32px;
    flex: 1;

    padding: 16px;

    border: 0;
    background-color: var(--color-bg);
    color: var(--color-text-primary);
}

.pfp{
    border-radius: 50%;
    padding: 6px;
    width: 50px;
    height: auto;

    border: 1px solid var(--color-accent);
    background-color: var(--color-bg);
}


.content{
    display: grid;
    grid-template-columns: 1fr 300px;
    grid-template-rows: repeat(2, 1fr);
    gap: 16px;
    padding: 0 16px 16px 0;
}

.content h2{
    margin-bottom: 16px;
}

.projects{
    grid-row: 1 / -1;
}

.card-container{
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 16px;
}

.card{
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;

    background-color: var(--color-surface);
    color: var(--color-text-secondary);
    border-radius: 32px;

    font-size: 1rem;

    padding: 16px;

    box-shadow: 0 4px 8px 4px rgba(0, 0, 0, 0.12);
}

.card .thumbnail{
    width: 100%;
    border-bottom: 1px solid var(--color-bg);
}

.card .description{
    padding: 16px;
}
.card a{
    align-self: flex-end;
    width: min(50%, 100px);
    padding: 8px;
    text-align: center;
    text-decoration: none;

    border: 0;
    background-color: var(--color-bg);
    color: var(--color-text-primary);
    border-radius: 16px;

    margin-top: auto;
}

.card a:hover{
    outline: 1px solid var(--color-text-primary);
}

.card a:active{
    background-color: var(--color-surface-elevated);
}

.card .title{
    align-self: start;
    padding: 0 16px;
}

.announcement .description{
    color: var(--color-text-tertiary);
}

.announcement:not(:last-of-type){
    border-bottom: 1px solid var(--color-bg);
}

.trending .card{
    align-items: flex-start;
}

.trend-embed{
    display: flex;
    justify-content: flex-start;
    align-items: center;

    gap: 16px;

    padding: 0 16px;
}


@media only screen and (max-width: 1300px) {

    .logo h1{
        display: none;
    }
    main{
        grid-template-columns: 100px 1fr;
    }

    .sidebar .menu .tab{
        justify-content: center;
    }
    .sidebar .menu .tab span{
        display: none;
    }

    .greeting{
        display: none;
    }

    .content{
        grid-template-columns: 1fr;
    }
}