:root {
    --color-text: #36291a;
    --color-primary: #144e46;
    --color-secondary: #e27857;
    --color-background: #faf0de;
    --color-background2: #f8e9ce;
    
    font: normal 18px/1.4 sans-serif;
    color: var(--color-text);
}

@media (width < 600px) {
    h1, h2,  p {
        text-align: center;
    }
}

@font-face {
  font-display: swap;
  font-family: 'Rubik';
  font-style: normal;
  font-weight: 500;
  src: url('../font/rubik-v31-latin-500.woff2') format('woff2'); 
}

@font-face {
  font-display: swap;
  font-family: 'Rubik';
  font-style: normal;
  font-weight: 700;
  src: url('../font/rubik-v31-latin-700.woff2') format('woff2');
}

html, body, h1, h2, h3, h4, h5, h6 {
    margin: 0;
    padding: 0;
}

body {
    background: var(--color-background);
}

a {
    color: var(--color-secondary);
    text-decoration: none;
    
    &:hover {
        text-decoration: underline;
    }
}

h1, h2, h3, h4, h5, h6 {
    font: 700 1rem/1 'Rubik';
    color: var(--color-primary);
    overflow-wrap: break-word;
}

h1 {
    font-size: 2.5rem;
    text-transform: uppercase;
}

h2 {
    font-size: 2rem;
    text-transform: uppercase;
    margin-bottom: 1.5rem;
    padding-bottom: .5rem;
    border-bottom: 3px solid var(--color-secondary); 
}

h5 {
    font-size: 1.25rem;
    padding-top: 1rem;
}

li + li {
    padding-top: .2rem;
}

li::marker {
    color: var(--color-primary);
    font-size: 1.2rem;
}

table {
    margin: 1em 0;
    border-collapse: collapse;
}

tr:not(:first-child) {
    border-top: 1px solid var(--color-primary);
}

th {
    vertical-align: top;
    text-align: left;
    padding: .5rem .5rem .5rem 0;
    width: 25%;
}

td {
    padding: .5rem 0 .5rem .5rem;
}

p {
    &.text-small {
        font-size: .9rem;
    }
}

.Banner {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 1rem;
    margin: 2rem 0;
}

.Hero {
    display: flex;
    gap: 3rem;
    align-items: center;
    
    & .Logo {
        height: 250px;
        width: auto;
        display: block;
    }
}

@media (width < 800px) {
    .Hero {
        flex-direction: column;
        gap: 2rem;
        text-align: center;
    
        & .Logo {
            height: clamp(100px, 40vw, 200px);
        }
    }
}

.Footer {
    font-size: .9rem;
    padding: 1rem 0;
    background: var(--color-primary);
    color: var(--color-background);
    text-align: center;
}

.Header {
    padding: 1rem 0;
    background: var(--color-primary);
    
    & .Menu {
        display: flex;
        align-items: center;
        flex-direction: column;

        & .CollapseButton {
            display: none;
            border: none;
            padding: 0;
            margin: 0;
            background: transparent;
            color: var(--color-secondary);
            font-size: 1.4rem;
        }
        
        & .Collapsible {
            & .CollapsibleContent {
                & ul {
                    margin: 0;
                    padding: 0;
                    display: flex;
                    flex-direction: row;
                    gap: 2rem;
                }
            
                & li {
                    padding: 0;
                    list-style: none;
                }
                
                & a {
                    font: 500 1rem/1 'Rubik';
                    color: var(--color-background);
                    text-decoration: none;
                    letter-spacing: 2px;
                }
                
                & a:hover, & a.active {
                    color: var(--color-secondary);
                }
            }
        }
    }
}

@media (width < 600px) {
    .Header {
        
        & .Menu {
            & .CollapseButton {
                display: block;
            }
            
            & .Collapsible {
                display: grid;
                grid-template-rows: 0fr;
                transition: grid-template-rows 0.25s ease-out;
                
                &.open {
                     grid-template-rows: 1fr;
                }
                
                & .CollapsibleContent {
                    min-height: 0;
                    overflow: hidden;
                    
                    & ul {
                        padding: 2rem 0 1rem 0;
                        flex-direction: column;
                        align-items: center;
                        gap: 1rem;
                    }        
                    
                    & a {
                        font-size: 1.4rem;
                    }
                }
            }
        }
    }
}

.Section {
    padding: 4rem 0;
    
    &.hero {
        padding: 4rem 0;
        margin-bottom: 2rem;
        background: var(--color-background2);
        border-bottom: 1px solid var(--color-primary);
    }
    
    &:not(.hero) + .Section {
        padding-top: 0;
    }
}


.Column {
    margin: 0 auto;
    padding: 0 2rem;
    max-width: 1000px;
    
    & + .Column {
        padding-top: 2rem;
    }
}

.CardGrid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
    gap: 1.5rem;
    
    & .Card {
        border-radius: 1rem;
        background: var(--color-background2);
        overflow: hidden;
        
        & img {
            width: 100%;
            height: auto;
            object-fit: cover;
            display: block;
        }
        
        & .Card-Content {
            border-top: 2px solid var(--color-secondary);
            padding: 1rem 1.5rem;
            display: flex;
            flex-direction: column;
            font-size: .9rem;
        }
    }
}

@media (width < 600px) {
    .CardGrid {
        grid-template-columns: 1fr;
    }
}