:root {
    font-size: 0.8rem;
    box-sizing: border-box;
}

*, ::before, ::after {
    box-sizing: inherit;
    margin: 0;
    border: 0;
    padding: 0;
    z-index: 1;
}

body {
    margin: 0;
    border: 0;
    padding: 0;
    color: rgb(90, 90, 90);
    font-family: Aptos, Calibri, Arial, Helvetica, sans-serif;
    line-height: 1.3;
}

/* Lobotomised Owl - this causes problems when leaflet is used for a map. */
body * + * {
    margin-top: 0.5em;
}

.clear-both {
    clear: both;
}

h1 {
    font-size: 1.7rem;
}
h2 {
    font-size: 1.3rem;
}
h3 {
    font-size: 1.1rem;
}
h4 {
    font-size: 1.1rem;
}
p {
    font-size: 1.2rem;
}
li {
    font-size: 1.2rem;
}

@media screen and (min-width: 480px) {
    body {
        line-height: 1.3;
    }
    body * + * {
        margin-top: 0.6em;
    } 
    h1 {
        font-size: 1.9em;
    }
    h2 {
        font-size: 1.5rem;
    }
    h3 {
        font-size: 1.2rem;
    }
    h4 {
        font-size: 1.2rem;
    }
    p {
        font-size: 1.35rem;
    }
    li {
        font-size: 1.35rem;
    }
}

@media screen and (min-width: 768px) {
    body {
        line-height: 1.4;
    }

    body * + * {
        margin-top: 0.7em;
    } 

    h1 {
        font-size: 2.1rem;
    }
    h2 {
        font-size: 1.7rem;
    }
    h3 {
        font-size: 1.3rem;
    }
    h4 {
        font-size: 1.3em;
    }
    p {
        font-size: 1.5rem;
    }
    li {
        font-size: 1.5rem;
    }
}

a:link {
    color: green;
    text-decoration: none;
}
a:visited {
    color: green;
    text-decoration: none;
}
a:hover {
    color: green;
    text-decoration: underline;
}
a:active {
    color:  green;
    text-decoration: none;
}

ul {
    list-style-type: disc;
    list-style-position: outside;
    padding-left: 1.1em;
}

ul > li {
    margin: .5em 0 0 0;
    padding: 0 0 0 0.15em;
}

@media screen and (min-width: 480px) {    
    ul {
        padding-left: 1.25em;
    }
}

@media screen and (min-width: 768px) {    
    ul {
        padding-left: 1.5em;
    }
}

ol {
    list-style-type: number;
    list-style-position: outside;
    padding-left: 1.1em;
}

ol > li {
    margin: .5em 0 0 0;
    padding: 0 0 0 0.15em;
}

@media screen and (min-width: 480px) {    
    ol {
        padding-left: 1.25em;
    }
}

@media screen and (min-width: 768px) {    
    ol {
        padding-left: 1.5em;
    }
}

/* -------------------------------------------------------------------------------------- */

.container {
    display: flex;
    flex-direction: column;
    min-height: 98vh;
    margin: 0 0.2em 0 0.2em;
    border: 0;
    padding: 0;
}
@media screen and (min-width: 480px) {
    .container {
        margin: 0 0.3em 0 0.3em;
    }
}
@media screen and (min-width: 768px) {
    .container {
        margin: 0 0.4em 0 0.4em;
    }
}

.container .header-area {
    flex: 0 0 auto;
    margin: 0;
    border: 0;
    padding: 0;
    width: 100%;
}

.container .main-area {
    flex: 1 0 auto;
    max-width: 1000px;
    margin: 0.8em auto 3em auto;
    border: 0;
    padding: 0;
    width: 100%;
    display: flex;
    flex-direction: column;
}

.container .footer-area {
    flex: 0 0 auto;
    margin: 0;
    border: 0;
    border-top: 1px solid black;
    padding: 0;
    background-color: rgb(230, 230, 230);
    width: 100%;
}

/* -------------------------------------------------------------------------------------- */

.header-title {
    margin: 0;
    border: 0;
    Border-bottom: 1px solid black;
    padding:  0;
    text-align: center;
    background-color: rgb(240, 240, 240);
}
.header-title .provisional {
    color: blue;
    font-weight: bold;
    font-size: 1.0rem;
    margin: 0;
    border: 0;
    padding: 0.25em 0 0 0;
}
.header-title .title {
    font-weight: bold;
    font-size: 1.25rem;
    line-height: 1;
    margin: 0;
    border: 0;
    padding: 0.25em 0 0.5em 0;
}
@media screen and (min-width: 480px) {    
    .header-title .provisional {
        color: green;
        font-size: 1.1rem;
    }
    .header-title .title {
        font-size: 1.5rem;
    }
}
@media screen and (min-width: 768px) {  
    .header-title .provisional {
        color: red;
        font-size: 1.2rem;
    }
    .header-title .title {
        font-size: 1.75rem;
    }
}

.header-nav {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin: 0;
    border: 0;
    padding:  0;
    text-align: center;
}
.header-nav .item {
    flex: 0 0 auto;
    margin: 0 0.15em 0 0.15em;
    border: 0;
    padding: 0;
    line-height: 1.25;
}
.header-nav .current {
    font-weight: bold;
}
@media screen and (min-width: 480px) {
    .header-nav {
        margin-top: 0.25em;
    }
    .header-nav .item{
        margin: 0 0.25em 0 0.25em;
        line-height: 1;
    }
}

@media screen and (min-width: 768px) {
    .header-nav {
        margin-top: 0.35em;
    }
    .header-nav .item{
        margin: 0 0.25em 0 0.25em;
        line-height: 1;
    }
}

/* -------------------------------------------------------------------------------------- */

.foot-nav {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    clear: both;
    margin: 0.25em 0 1em 0;
}

.foot-nav .item {
    flex: 0 0 auto; 
    margin: 0 0.15em 0 0.15em;
    padding: 0;
    line-height: 1.3;
    font-size: 1.1rem;
}

.foot-nav .current {
    font-weight: bold;
}

@media screen and (min-width: 480px) {
    .foot-nav {
        margin-top: 0.25em;
    }
    
    .foot-nav .item {
        padding: 0 0.25em 0 0.25em;
        line-height: 1;
        font-size: 1.2rem;
    }
}

@media screen and (min-width: 768px) {
    .foot-nav {
        margin-top: 0.35em;
    }

    .foot-nav .item {
        padding: 0 0.25em 0 0.25em;
        line-height: 1;
        font-size: 1.3rem;
    }
}

.foot-text {
    width: 100%;
    margin: 0 0 0.5em 0;
    border: 0;
    padding: 0;
}

.foot-text > p {
    margin: 0;
    border: 0;
    padding: 0;
    line-height: 1.3;
    font-size: 1.1rem;
}

.foot-text > .centre {
    text-align: center;
}

@media screen and (min-width: 480px) {
    .foot-text > p {
        font-size: 1.2rem;
    }  
}

@media screen and (min-width: 768px) {
    .foot-text > p {
        font-size: 1.3rem;
    }    
}

/* -------------------------------------------------------------------------------------- */

.md-provisional-message {
    color:red;
    font-size: 1.0rem;
}
@media screen and (min-width: 480px) {    
    .md-provisional-message {
        font-size: 1.1rem;
    }
}
@media screen and (min-width: 768px) {  
    .md-provisional-message {
        font-size: 1.2rem;
    }
}

/* -------------------------------------------------------------------------------------- */

.image-as-list-icon {
    float: left;
    max-width: 32px;
    margin: 0.3em 1em 0.25em 0;
    border: 1px solid black;
    padding: 0;
}

/* -------------------------------------------------------------------------------------- */


