*,
*::before,
*::after {
box-sizing: border-box;
}

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, menu, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
main, nav, output, ruby, section, summary,
time, mark, audio, video {
margin: 0;
padding: 0;
border: 0;
font: inherit;
vertical-align: baseline;
background: transparent;
color: inherit;
}

body {
line-height: 1.5;
background: #fff;
color: #333;
}

h1, h2, h3, h4, h5, h6 {
font-weight: 600;
line-height: 1.2;
}

p {
margin-bottom: 1rem;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, main, nav, section {
display: block;
}

ol, ul {
list-style: none;
}

blockquote, q {
quotes: none;
}
blockquote::before, blockquote::after,
q::before, q::after {
content: "";
content: none;
}

table {
border-collapse: collapse;
border-spacing: 0;
}

img {
max-width: 100%;
display: block;
height: auto;
}

button, input, select, textarea {
font-family: inherit;
font-size: 100%;
line-height: inherit;
color: inherit;
margin: 0;
}

button, [type="button"], [type="submit"] {
cursor: pointer;
}

:focus {
outline: 2px solid #4c90ff;
outline-offset: 2px;
}

html:focus-within {
scroll-behavior: smooth;
}