/* 1. Use a more-intuitive box-sizing model */
*, *::before, *::after {
    box-sizing: border-box;
}

/* 2. Remove default margin */
* {
    margin: 0;
}

/* 3. Enable keyword animations */
@media (prefers-reduced-motion: no-preference) {
    html {
        interpolate-size: allow-keywords;
    }
}

body {
    /* 4. Add accessible line-height */
    line-height: 1.5;
    /* 5. Improve text rendering */
    -webkit-font-smoothing: antialiased;
}

/* 6. Improve media defaults */
img, picture, video, canvas, svg {
    display: block;
    max-width: 100%;
}

/* 7. Inherit fonts for form controls */
input, button, textarea, select {
    font: inherit;
}

/* 8. Avoid text overflows */
p, h1, h2, h3, h4, h5, h6 {
    overflow-wrap: break-word;
}

/* 9. Improve line wrapping */
p {
    text-wrap: pretty;
}

h1, h2, h3, h4, h5, h6 {
    text-wrap: balance;
}

/*
  10. Create a root stacking context
*/
#root, #__next {
    isolation: isolate;
}


:root {
    --bg-color: #f5f4eb;
}

@font-face {
    font-family: "Bogue";
    src: local("Bogue Thin"), url("/font/Bogue Thin.ttf") format("truetype");
    font-weight: 1 100;
}

@font-face {
    font-family: "Bogue";
    src: local("Bogue Thin"), url("/font/Bogue Thin.ttf") format("truetype");
    font-style: italic;
    font-weight: 1 100;
}

@font-face {
    font-family: "Bogue";
    src: local("Bogue Light"), url("/font/Bogue Light.ttf") format("truetype");
    font-weight: 100 300;
}

@font-face {
    font-family: "Bogue";
    src: local("Bogue Light"), url("/font/Bogue Light Italic.ttf") format("truetype");
    font-style: italic;
    font-weight: 100 300;
}

@font-face {
    font-family: "Bogue";
    src: local("Bogue Regular"), url("/font/Bogue Regular.ttf") format("truetype");
    font-weight: 300 400;
}

@font-face {
    font-family: "Bogue";
    src: local("Bogue Regular"), url("/font/Bogue Italic.ttf") format("truetype");
    font-style: italic;
    font-weight: 300 400;
}

@font-face {
    font-family: "Bogue";
    src: local("Bogue Medium"), url("/font/Bogue Medium.ttf") format("truetype");
    font-weight: 400 500;
}

@font-face {
    font-family: "Bogue";
    src: local("Bogue Medium"), url("/font/Bogue Medium Italic.ttf") format("truetype");
    font-style: italic;
    font-weight: 400 500;
}

@font-face {
    font-family: "Bogue";
    src: local("Bogue Semibold"), url("/font/Bogue Semibold.ttf") format("truetype");
    font-weight: 500 600;
}

@font-face {
    font-family: "Bogue";
    src: local("Bogue Semibold"), url("/font/Bogue Semibold Italic.ttf") format("truetype");
    font-style: italic;
    font-weight: 500 600;
}

@font-face {
    font-family: "Bogue";
    src: local("Bogue Bold"), url("/font/Bogue Bold.ttf") format("truetype");
    font-weight: 600 700;
}

@font-face {
    font-family: "Bogue";
    src: local("Bogue Bold"), url("/font/Bogue Bold Italic.ttf") format("truetype");
    font-style: italic;
    font-weight: 600 700;
}

@font-face {
    font-family: "Bogue";
    src: local("Bogue Extrabold"), url("/font/Bogue Extrabold.ttf") format("truetype");
    font-weight: 700 800;
}

@font-face {
    font-family: "Bogue";
    src: local("Bogue Extrabold"), url("/font/Bogue Extrabold Italic.ttf") format("truetype");
    font-style: italic;
    font-weight: 700 800;
}

@font-face {
    font-family: "Bogue";
    src: local("Bogue Black"), url("/font/Bogue Black.ttf") format("truetype");
    font-weight: 800 1000;
}

@font-face {
    font-family: "Bogue";
    src: local("Bogue Black"), url("/font/Bogue Black Italic.ttf") format("truetype");
    font-style: italic;
    font-weight: 800 1000;
}

@font-face {
    font-family: "Facundo";
    src: local("Facundo"), url("/font/Facundo-Thin.ttf") format("truetype");
    font-weight: 1 100;
}

@font-face {
    font-family: "Facundo";
    src: local("Facundo"), url("/font/Facundo-ThinIt.ttf") format("truetype");
    font-style: italic;
    font-weight: 1 100;
}

@font-face {
    font-family: "Facundo";
    src: local("Facundo"), url("/font/Facundo-ExtraLight.ttf") format("truetype");
    font-weight: 100 200;
}

@font-face {
    font-family: "Facundo";
    src: local("Facundo"), url("/font/Facundo-ExtraLightIt.ttf") format("truetype");
    font-style: italic;
    font-weight: 100 200;
}

@font-face {
    font-family: "Facundo";
    src: local("Facundo"), url("/font/Facundo-Light.ttf") format("truetype");
    font-weight: 200 300;
}

@font-face {
    font-family: "Facundo";
    src: local("Facundo"), url("/font/Facundo-LightIt.ttf") format("truetype");
    font-style: italic;
    font-weight: 200 300;
}

@font-face {
    font-family: "Facundo";
    src: local("Facundo"), url("/font/Facundo-Regular.ttf") format("truetype");
    font-weight: 300 400;
}

@font-face {
    font-family: "Facundo";
    src: local("Facundo"), url("/font/Facundo-RegularIt.ttf") format("truetype");
    font-style: italic;
    font-weight: 300 500;
}

@font-face {
    font-family: "Facundo";
    src: local("Facundo"), url("/font/Facundo-SemiBold.ttf") format("truetype");
    font-weight: 500 600;
}

@font-face {
    font-family: "Facundo";
    src: local("Facundo"), url("/font/Facundo-SemiBoldIt.ttf") format("truetype");
    font-style: italic;
    font-weight: 500 600;
}

@font-face {
    font-family: "Facundo";
    src: local("Facundo"), url("/font/Facundo-Bold.ttf") format("truetype");
    font-weight: 600 800;
}

@font-face {
    font-family: "Facundo";
    src: local("Facundo"), url("/font/Facundo-BoldIt.ttf") format("truetype");
    font-style: italic;
    font-weight: 600 800;
}

@font-face {
    font-family: "Facundo";
    src: local("Facundo"), url("/font/Facundo-Black.ttf") format("truetype");
    font-weight: 800 1000;
}

@font-face {
    font-family: "Facundo";
    src: local("Facundo"), url("/font/Facundo-BlackIt.ttf") format("truetype");
    font-style: italic;
    font-weight: 800 1000;
}

html {
    height: 100%;
}

body {
    font-family: Facundo, sans-serif;
    background-color: var(--bg-color);
    margin: 0;
    color: #000;
}


h1, h2, h3 {
    font-family: Bogue, sans-serif;
    text-transform: uppercase;
    margin: 0;
}

a {
    color: #000;
    text-decoration: none;
}

a:hover, a:active, a:focus {
    text-decoration: underline;
}

.front {
    min-height: 100vh;
}

.top {
    display: flex;
    padding: 1.5em;
    font-size: 1.5em;
    text-transform: uppercase;
    margin-bottom: 6.5em;
    justify-content: space-between;
    line-height: 1.375;
}

.top .right {
    text-align: right;
}

.titles {
    display: flex;
    justify-content: center;
    list-style: none;
    padding: 0;
    margin: 1em 0;
}

.titles li {
    font-family: Bogue, sans-serif;
    display: inline-block;
    line-height: 1;
    font-size: 2em;
    margin: 0;
    padding: 0 .5em .15em;
}

.titles li:not(:last-child) {
    border-right: 2px solid black;
}

.title {
    max-width: fit-content;
    font-weight: 500;
    font-size: 13em;
    line-height: 1;
    margin: 0 auto .25em;
    padding: 0;
}

.title span, .title-container h2 span {
    font-weight: 100;
}

.navs {
    display: flex;
    flex-flow: wrap;
    justify-content: center;
    list-style: none;
    padding: .75em 0 0;
    text-transform: uppercase;
}

.navs li {
    margin: 0 .5em;
    line-height: 3.5em;
}

.navs li .entry {
    font-size: 1.25em;
    padding: .25em 1em;
    line-height: 1;
}

.navs li a {
    font-size: 1.375em;
    padding: .25em 1em;
    border: 1px solid black;
    border-radius: 1em;
    line-height: 1;
    transition: background-color .15s linear, color .15s ease-in-out;
}

.navs li a:hover, .navs li a:active, .navs li a:focus {
    text-decoration: none;
    background-color: #000;
    color: #fff;
}

.works {
    min-height: 100vh;
}

.page {
    min-height: 100vh;
    padding: 6em 8em;
}

.about {
    column-count: 3;
    column-gap: 3em;
}

.about h3 {
    margin-bottom: .5em;
}

.about img {
    margin: 0 auto;
}

.about .item {
    padding: 0 2em 1em;
    max-width: 30em;
    display: inline-block;
    min-width: 25vw;
}

.about .item p {
    margin-bottom: 1em;
}

.about .lighter p {
    color: #5a595d;
    font-weight: 500;
}

.about .lighter strong {
    color: #272927;
}

.about p, .about li {
    line-height: 1.75;
    font-size: 1.25em;
}

.about h3 {
    font-weight: 500;
    font-size: 2.5em;
    border-bottom: 2px solid black;
    line-height: 1.25;
    padding-bottom: .25em;
    padding-top: .125em;
}

.about .socials h3 {
    font-weight: 550;
}

.about .socials ul {
    list-style: none;
    padding: 0;
}

.about .socials a {
    line-height: 2.5em;
}

.about .socials .icon {
    display: inline-block;
    width: 2em;
    height: 2em;
    border-radius: 50%;
    background-color: #000;
    color: #fff;
    text-align: center;
    line-height: 2em;
    margin-right: .5em;
    user-select: none;
    vertical-align: middle;
}

.about .socials .icon.youpic {
    font-weight: 500;
    margin-top: -.125em;
}

.about .socials .icon.gmail img, .about .socials .icon.instagram img {
    vertical-align: middle;
    margin-top: .45em;
}

.about .socials a:hover .icon, .about .socials a:active .icon, .about .socials a:focus .icon {
    text-decoration: none;
}

.index {
    min-height: 100vh;
}

.index ol {
    padding-top: 4em;
    font-family: Bogue, sans-serif;
    list-style-type: decimal-leading-zero;
}

.index li {
    font-size: 1.5em;
    line-height: 1.75;
    text-transform: uppercase;
    font-weight: 500;
}

.index li::marker {
    font-size: 1.5em;
    padding-right: .25em;
}

.title-container {
    display: flex;
    align-items: center;
    flex-direction: column;
    max-width: fit-content;
    margin: 0 auto;
}

.title-container h3 {
    text-transform: unset;
    font-weight: 400;
    font-size: 1.5em;
    line-height: 1;
    display: flex;
    flex-direction: row;
    width: 100%;
}

.title-container h2 {
    font-size: 9em;
    margin: 0;
    border-bottom: 2px solid black;
    line-height: 1;
    padding-bottom: .4em;
}

.title-container h3 span.middle {
    min-width: fit-content;
}

.title-container h3 span.start, .title-container h3 span.end {
    border-bottom: 2px solid black;
    display: block;
    width: 100%;
    transform: translateY(-35%);
}

.title-container h3 span.start {
    margin-right: .375em;
}

.title-container h3 span.end {
    margin-left: .375em;
}

.index li a {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
}

.index li a .line {
    flex-grow: 1;
    background: black;
    display: inline-block;
    height: 2px;
    margin: 0 1em;
}

.index li a .description {
    font-family: Facundo, sans-serif;
    font-weight: 300;
    font-size: .75em;
}

@media (max-width: 1440px) {
    .title {
        font-size: 11em;
    }

    .title-container h2 {
        font-size: 8em;
    }

    .page {
        padding: 5em 6em;
    }

    .index {
        padding: 5em 6em;
    }
}

@media (max-width: 1200px) {
    .title {
        font-size: 8em;
    }

    .title-container h2 {
        font-size: 7em;
    }

    .page {
        padding: 2em 3em;
    }

    .about {
        column-count: 2;
    }

    .about .item {
        min-width: 40vw;
    }

    .index {
        padding: 2em 4em;
    }
}

@media (max-width: 992px) {
    .title {
        font-size: 7em;
    }

    .title-container h2 {
        font-size: 6em;
    }

    .page {
        padding: 2em 2em;
    }

    .index {
        padding: 2em 4em;
    }
}

@media (max-width: 768px) {
    .titles li {
        font-size: 1.5em;
    }

    .title {
        font-size: 5em;
    }

    .title-container h2 {
        font-size: 4em;
    }

    .page {
        padding: 2em 1em;
    }

    .about {
        column-count: unset;
    }

    .index {
        padding: 2em 4em;
    }

    .about .item {
        display: block;
    }

    .about .item:first-child {
        text-align: center;
    }

    .index li a {
        flex-direction: column;
        align-items: flex-start;
    }

    .index li a .line {
        display: none
    }
}

@media (max-width: 600px) {
    .title {
        font-size: 4em;
    }

    .title-container h2 {
        font-size: 3em;
    }
}
