@font-face {
    font-family: 'Archivo';
    src: url('../f/Archivo-SemiBold.woff2') format('woff2'),
        url('../fArchivo-SemiBold.woff') format('woff');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Archivo';
    src: url('../f/Archivo-Regular.woff2') format('woff2'),
        url('../f/Archivo-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

:root {
--base:#fff;
--accent:#048665; /* teal */
--accent-2:#037185; /* blue */
--width: 840px;
}

body {
background: var(--base);
font-family: 'Archivo',Roboto,Helvetica,Arial,sans-serif,apple color emoji,segoe ui emoji,segoe ui symbol;
font-size: 135%;
margin: 0;
padding: 0;
line-height: 1.4;
}

:focus-visible {
outline: 4px solid black;
box-shadow: 0 0 0 6px white;
}

a { 
text-decoration: underline;
color: var(--accent);
}

a:hover, a:focus { 
color: var(--accent-2);
text-decoration: underline;
}

a:active { 
color: #000;
text-decoration: underline;
}

/* header and footer */

header, footer, .content, .fullwidthinner {
max-width: var(--width);
margin-left: auto;
margin-right: auto;
padding: 0 1em;
}

body.page .banner {
height: 6em;
}

body.headerbanner .banner, body.topbanner .banner {
min-height: 1.5em;
}

.banner {
background-color: var(--accent);
background-image: linear-gradient(45deg, rgb(20, 222, 124) 0%, rgb(20, 222, 124) 21%,rgb(25, 190, 119) 21%, rgb(25, 190, 119) 37%,rgb(30, 158, 113) 37%, rgb(30, 158, 113) 46%,rgb(35, 126, 108) 46%, rgb(35, 126, 108) 53%,rgb(39, 94, 103) 53%, rgb(39, 94, 103) 59%,rgb(44, 62, 97) 59%, rgb(44, 62, 97) 77%,rgb(49, 30, 92) 77%, rgb(49, 30, 92) 100%);
box-shadow: 0 0 20px rgb(0 0 0 / 80%) inset;
}

header {
text-align: center;
margin-top: 2em;
margin-bottom: 2em;
}

.banner header {
margin-top: 0;
margin-bottom: 0;
padding-top: 3em;
padding-bottom: 3em;
}

body.page header {
width: 90%;
max-width: 70em;
margin-top: 1.5em;
display: flex;
justify-content: space-between;
}

body.page #logo {
font-family: 'Archivo', sans-serif;
font-weight: 600;
text-transform: uppercase;
font-size: 150%;
}

body.page #logo span {
color: var(--accent-2);
}

body.page #logo a {
text-decoration: none;
}

body.page #logo img {
vertical-align: middle;
height: 1.5em;
width: auto;
margin-right: .3em;
}

footer {
text-align: center;
margin-top: 6em;
margin-bottom: 6em;
font-size: 70%;
}

/* navigation */

nav {
margin: auto 0;
text-align: center;
}

nav ul {
margin: 0;
}

nav li {
text-align: left;
display: inline;
background: none;
vertical-align: super; /* middle on full image logo */
margin: 0; /* margin: 0 0 .5em 1em;*/
padding: 0;
}

nav li a {
font-family: 'Archivo', sans-serif;
font-weight: 600;
text-transform: uppercase;
color: var(--accent-2);
font-size: 70%; /* 85% */
text-decoration: none;
padding: 0 .7em;
line-height: 3.5em;
display: inline-block;
}

nav li a:hover, nav li a:focus {
text-decoration: underline;
}

nav a.active {
color: var(--accent);
}

nav li a img {
vertical-align: middle;
}

nav.navbar {
background: var(--accent-2);
padding: 0 1em;
}

nav.navbar a {
color: #fff;
}

nav.navbar a:hover, nav.navbar a:focus {
text-decoration: underline;
color: #fff;
}

nav.navbar li a.active {
background: var(--accent);
}

/* general */

h1, h2, h3 {
font-family: 'Archivo', sans-serif;
font-weight: 600;
text-align: center;
}

h1 {
text-align: center;
}

h2, h3 {
text-align: left;
}

body.privacypage h2, body.privacypage h3 {
text-align: left;
}

h1 {
font-size: 300%;
color: var(--accent);
margin-bottom: .5em;
}

h1 span {
color: var(--accent-2);
}

h1 img {
margin: 0;
vertical-align: middle;
}

body.page h1 {
font-size: 225%;
}

h2 {
margin-top: 1em;
font-size: 180%;
color: var(--accent);
}

h3 {
margin-top: 1.5em;
font-size: 130%;
color: var(--accent);
}

p {
margin: 1.2em 0;
}

.small {
font-size: 80%;
}

.lead {
font-family: 'Archivo', sans-serif;
font-weight: 600;
font-size: 100%;
}

#back-to-top {
background: rgba(0,0,0,.6);
transition: all 200ms linear;
}

#back-to-top:hover, #back-to-top:focus {
background: rgba(0,0,0,9);
}

/* header in banner */

.banner header h1, .banner header h1 span, .banner header p {
color: var(--base);
}

.banner header h1 {
text-shadow: 0.05em 0.05em 0 rgba(0,0,0,.5);
}

.banner header h1 img {
filter: drop-shadow(0.05em 0.05em 0 rgb(0 0 0 / .5));
}

.banner header .lead {
text-shadow: 0.1em 0.1em 0 rgba(0,0,0,.5);
}

/* fullwidth background and panels */

.fullwidth {
margin-top: 4em;
margin-bottom: 3em;
margin-left: calc(-100vw / 2 + 100% / 2);
margin-right: calc(-100vw / 2 + 100% / 2);
max-width: 100vw;
width: auto;
padding-top: 6em;
padding-bottom: 6em;

background: #000 url(../images/datacentre.jpg) no-repeat center center;
background-size: cover;
background-attachment: fixed;
color: #fff;
box-shadow: 0 0 20px rgb(0 0 0 / 80%) inset;
}


/*
.fullwidth::after {
content: '';
background: url(../images/downarrow.svg) no-repeat top center;
background-size: 100% auto;
width: 80px;
height: 50px;
display: block;
margin: 0 auto;
}
*/

.widewidth {
margin-top: -1em;
margin-bottom: 2em;
margin-left: -1.5em;
width: calc(90% + 8em);
}

#fullwidthback {
background: #000 url(../images/chips.jpg) no-repeat center center;
background-size: cover;
box-shadow: 0 0 20px rgb(0 0 0 / 80%) inset;
}

.blackpanel {
background: rgba(0,0,0,.7);
margin: 2em 0;
padding: 1em 2em;
color: #fff;
width: 50%;
border-radius: 5px;
}

.blackpanel h2, .blackpanel h3, .blackpanel strong, .blackpanel a {
color: #fff;
margin-top: .5em;
}


/* misc */

ul {
padding-left: 1em;
}

li {
margin-bottom: 1em; 
list-style: square;
}

.cols {
column-width: 10em;
column-gap: 5em;
}

.cols section {
display: inline-block;
margin-bottom: 1em;
}

.cols h3 {
margin: 0;
}

.cols li {
margin-bottom: .5em; 
list-style: none;
background: none;
padding: 0;
}

p strong, li strong {
color: var(--accent-2);
}

main img {
display: block;
margin: 0 auto;
max-width: 100%;
height: auto;
border-radius: 20px;
box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px;
}

main img.noshadow {
box-shadow: none;
}

main img.imgc {
display: block;
margin: auto;
}

blockquote {
background: #eee;
margin: 0;
padding: 0.1em 1em 1em 1em;
font-style: italic;
font-size: 120%;
}

blockquote cite {
font-size: 80%;
}

hr {
border: 0;
border-top: .1em solid var(--accent);
margin: 2em;
}


/* Features */

.features {
display: flex;
flex-wrap: wrap;
justify-content: center;
width: calc(100% + 2em);
margin: 3em 0 3em -2em;
padding: 0;
list-style: none;
}

.features li {
width: calc(33.33333% - 2em);
margin-left: 2em;
margin-top: 3em;
padding: 0;
background: none;
text-align: center;
}

.features li:nth-child(1), .features li:nth-child(2), .features li:nth-child(3) {
margin-top: 0;
}

.features li > :last-child {
margin-bottom: 0;
}

.features li img {
width: 65%;
border-radius: 0;
box-shadow: none;
}

.features li h3 {
margin: 0.5em 0 -.5em 0;
}

.features li p {
font-size: 90%;
}

/* gallery */

.gallery {
display: flex;
flex-wrap: wrap;
margin: 2em 0 0 -1.25rem;
width: calc(100% + 1.25rem);
list-style: none;
padding-left: 0;
}

.gallery li {
display: block;
margin: 1.25rem 0 0 1.25rem;
width: calc(50% - 1.25rem);
background: none;
padding: 0;
}

.gallery.threeimages li {
width: calc(33.3% - 1.25rem);
}

/* infobox */

.infobox {
display: flex;
flex-flow: row wrap;
margin-bottom: 2em;
}

.imgarea {
flex: 3;
}

.imgarea.imgsml {
flex: 2;
}

.imgarea.imgxsml {
flex: 1;
}

.infoarea {
flex: 4;
margin: auto auto auto 2em;
}

.infoarea.infowide {
flex: 5;
}

.infoarea h2 {
text-align: left;
margin-top: 0;
font-size: 150%;
}

.infoarea h3 {
text-align: left;
margin-top: 0;
}



/* tables */

table {
width: 100%;
border-collapse: collapse;
border-width: 0px;
border-color: var(--accent);
border-style: solid;
}

table thead {
background-color: var(--accent);
color: var(--base);
text-align: left;
font-family: 'Archivo', sans-serif;
font-weight: 600;
text-transform: uppercase;
}

table td, table th {
border-width: 0px;
border-color: var(--accent);
border-style: solid;
padding: .5rem;
}

tr:nth-child(even) {
background-color: #efefef;
}


/* form */

button, input, select, textarea {
font-family: inherit;
}

label {
margin:0 0 3px 0;
padding:0px;
display:block;
font-weight: bold!important;
color: var(--accent-2)!important;
}
input[type=text], 
input[type=date],
input[type=datetime],
input[type=number],
input[type=search],
input[type=time],
input[type=url],
input[type=email],
input[type=tel],
textarea, select{
box-sizing: border-box;
border: 0;
background: var(--base);
color: #111;
padding: 10px 15px;
margin:0px;
border: 1px solid var(--accent);
outline: none;	
font-size: inherit;
}
input[type=text]:focus, 
input[type=date]:focus,
input[type=datetime]:focus,
input[type=number]:focus,
input[type=search]:focus,
input[type=time]:focus,
input[type=url]:focus,
input[type=email]:focus,
input[type=tel]:focus,
textarea:focus, 
select:focus{
border: 1px solid var(--accent-2);
}
input[type="checkbox"],input[type='radio'] {
width: 1.5em;
height: 1.5em;
margin-right: 0.5em;
vertical-align: text-top;
}
select{
width: 100%;
}
textarea{
min-height: 150px!important;
}
button, input[type=submit], input[type=button], .button{
background: var(--accent-2);
color: #fff;
padding: 12px 18px;
border: none;
font-size: inherit;
text-decoration: none;
border-radius: 5px;
}
button:hover, input[type=submit]:hover, input[type=button]:hover, .button:hover, button:focus, input[type=submit]:focus, input[type=button]:focus, .button:focus {
background: var(--accent);
color: #fff;
text-decoration: none;
}

a.button {
display: inline-block;
}

.cog-abuse {display: none;}
.cog-abuse li {
background: none;
padding: auto;
}

/* mailchimp */

.mc-field-group input {
width: 100%;
}

.mc-field-group {
margin: .5em 0;
}

.mc_embed_shell .nope {
display: none!important;
}

.blackpanel label {
color: #fff!important;
}


/* media queries */

@media only screen and (max-width: 1080px) {

.widewidth {
margin-left: 0;
margin-right: 0;
width: 100%;
}

body.page header {
display: block;
margin-bottom: 1em;
}

body.page h1 {
text-align: center;
margin-bottom: .5em;
}

}


@media only screen and (max-width: 900px) {

header, footer, .content, .fullwidthinner, #logo img {
max-width: 85%;
}

}

@media only screen and (max-width: 800px) {

.banner, body.topbanner .banner {
min-height: 1.5em;
}

header {
margin-top: 3em;
margin-bottom: 1.5em;
}

.banner header {
margin-top: 0;
padding-top: 2.5em;
padding-bottom: 2.5em;
}

body.page #logo {
font-size: 125%;
margin-bottom: .5em;
}

body.page #logo img {
height: 1.3em;
}

nav li a {
line-height: 3em;
}

footer {
margin-top: 4em;
margin-bottom: 4em;
}

h1 {
font-size: 250%;
}

body.page h1 {
font-size: 180%;
}

h2 {
font-size: 150%;
}

h3 {
font-size: 120%;
}

.features {
width: 100%;
margin: 0 0 2em 0;
}

.features li {
width: 100%;
margin-left: 0;
margin-top: 2em;
}

.features li:nth-child(2), .features li:nth-child(3) {
margin-top: 2em;
}

.gallery {
margin-top: -1em;
}

.gallery img {
display: block;
margin: 1em 0 0 0;
width: 100%;
}

.imgarea, .imgarea.imgsml, .imgarea.imgxsml {
flex: 1 100%;
}

.infoarea, .infoarea.infowide {
flex: 1 100%;
margin-top: 1.5em;
margin-left: 0;
}

.infoarea h3 {
text-align: center;
margin-top: 1em;
}

.blackpanel {
width: auto;
}

}


@media only screen and (max-width: 500px) {

body {
font-size: 120%;
}

.banner, body.topbanner .banner {
min-height: 1.5em;
}

header {
margin-top: 2.5em;
margin-bottom: 1.25em;
}

.banner header {
margin-top: 0;
padding-top: 2em;
padding-bottom: 2em;
}

nav.navbar {
padding: 0;
}

body.page nav {
margin-left: calc(-100vw / 2 + 100% / 2);
margin-right: calc(-100vw / 2 + 100% / 2);
max-width: 100vw;
width: auto;
}

h1, body.page h1 {
font-size: 140%;
}

h1 img {
width: 80%;
height: auto;
}

h2 {
text-align: left;
font-size: 120%;
}

h3 {
text-align: left;
font-size: 110%;
}

.lead {
font-size: 105%;
}

.blackpanel {
margin: 1em 0;
padding: 1em 1.5em;
}

blockquote {
font-size: 100%;
}

.widewidth {
max-width: auto;
}

.gallery {
display: block;
width: 100%;
margin-left: 0;
}

.gallery li {
margin: 1.25rem 0 0 0;
width: 100%;
}

.gallery.threeimages li {
width: 100%;
}

.gallery img {
display: block;
margin: 2em 0 0 0;
width: 100%;
}

}


html {
scroll-behavior: smooth;
}

@media screen and (prefers-reduced-motion: reduce) {
html {
scroll-behavior: auto;
}
}