@import url('https://fonts.googleapis.com/css2?family=Crimson+Text:ital,wght@0,400;0,600;0,700;1,400;1,600;1,700&family=Lato:ital,wght@0,100;0,300;0,400;0,700;0,900;1,100;1,300;1,400;1,700;1,900&display=swap" rel="stylesheet');
@import url('https://fonts.googleapis.com/css2?family=Crimson+Text:ital,wght@0,400;0,600;0,700;1,400;1,600;1,700&family=Lato:ital,wght@0,100;0,300;0,400;0,700;0,900;1,100;1,300;1,400;1,700;1,900&display=swap" rel="stylesheet');

body{
    font-family: 'Lato', sans-serif;
}
h1,h2,button{
    font-family: 'Crimson Text', serif;
}


body{
    background-color: #CCC;
    width: 80%;
    margin: auto;
    margin-bottom: 40px;
    margin-top: 40px;
}

_main{
    width: 80dvw;
    height: 80dvh;
    max-width: fit-content;
    overflow: auto;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 0.5rem;
    padding: 2rem;
    background-color: #FFF;
    border-radius: 8px;
    box-shadow: 0px 1px 1px rgba(3, 7, 18, 0.02),
        0px 5px 4px rgba(3, 7, 18, 0.03),
        0px 12px 9px rgba(3, 7, 18, 0.05),
        0px 20px 15px rgba(3, 7, 18, 0.06),
        0px 32px 24px rgba(3, 7, 18, 0.08);

    > section{
        max-height: 100%;
    }

    > div{
        display: flex;
        justify-content: space-between;
        align-items: center;
        gap: 0.5rem;
    }
}

main{
    width:fit-content;
    margin: auto;
    padding: 2rem;
    background-color: #FFF;
    border-radius: 8px;
    box-shadow: 0px 1px 1px rgba(3, 7, 18, 0.02),
        0px 5px 4px rgba(3, 7, 18, 0.03),
        0px 12px 9px rgba(3, 7, 18, 0.05),
        0px 20px 15px rgba(3, 7, 18, 0.06),
        0px 32px 24px rgba(3, 7, 18, 0.08);
}

h1{
    text-align: center;
    font-size: 40px;
    margin: 0px;
}


input{
    padding: 0.5rem;
    border: 1px solid #000;
    border-radius: 0.25rem;
}

button{
    padding: 0.5rem;
    border: 1px solid #000;
    border-radius: 0.25rem;
    background-color: #000;
    color: #FFF;
    cursor: pointer;
}

form#registration,
section.registration-summary{
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1rem;
    column-gap: 2rem;
}

form#registration label{
    display: block;
    font-size: .85em;
    font-weight: 600;
    font-style: italic;
}
form#registration input{
    width: 350px;
    margin-left: auto;
}

form#registration >div >div{
    margin-bottom: 10px;
}

section.registration-summary{
    margin-top: 20px;;
}

form#frm button{
    min-width: 250px;
    max-width: 450px;
    margin: auto
}

.flex-col{
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 0.5rem;
}

.flex-row{
    display: flex;
    flex-direction: row;
}

.justify-end{
    justify-content: flex-end;
}

.grid-cols-2{
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 1rem;
}

.w-full{
    width: 100%
}

.text-center{
    text-align:center;
}

sup.required{
    font-weight: 600;
    color: #F00;
}

.alert{
    padding: 1rem 2rem;
    border-radius: 8px;
    border-width: 2px;
    border-style: solid;
    margin: 20px auto;
    width: fit-content;
}
.alert-success{
    background-color: #7bf1a8;
    color: #00a63e;
    border-color: #00a63e;
}
.alert-warning{
    background-color: #fed7aa;
    color: #f97316;
    border-color: #f97316;
}
.alert-error{
    background-color: #ffa2a2;
    color: #e7000b;
    border-color: #e7000b;
}