*, *::before, *::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: auto;
    text-size-adjust: none;
    scrollbar-width: thin;
}

img, picture, video, canvas, svg {
    display: block;
    max-width: 100%;
    height: auto;
    object-fit: cover;
}

input, button, textarea, select {
    font: inherit;
    color: inherit;
    background: transparent;
    border: none;
    box-shadow: none;
}

button, input[type='button'], input[type='submit'] { cursor: pointer; }

h1, h2, h3, h4, h5, h6 {
    overflow-wrap: break-word;
    margin: 0;
}

ul[role="list"], ol[role="list"] { list-style: none; }

iframe {
    outline: 0;
    border: 1px solid #000;
    border-radius: 5px;
    box-shadow: 0 0 5px rgba(0,0,0,.5);
}

fieldset {
    border: 0;
    padding: 0;
    margin: 0;
    width: 100%;
}

legend { 
    padding: 0;
    width: auto;
}

button, textarea, select {
    appearance: none;
    background: none;
    border: none;
    margin: 0;
    padding: 0;
}

:target { scroll-margin-top: 5ex; }

[hidden] { display: none !important; }
