/* ####################################################### */

html, body {
  height: 100%;
  width: 100%;
  margin: 0px;
  padding: 0px;
  font-family: Arial, Helvetica, sans-serif;
  font-size: 16px;
  -moz-text-size-adjust: none;
  -webkit-text-size-adjust: none;
}

html {
  box-sizing: border-box;
}

/* ################## font declarations ################## */

@font-face {
  font-family: 'Open Sans';
  src: url("fonts/OpenSans-ExtraBold.eot");
  src: url("fonts/OpenSans-ExtraBold.eot?#iefix") format("embedded-opentype"),
     url("fonts/OpenSans-ExtraBold.woff") format("woff"),
     url("fonts/OpenSans-ExtraBold.ttf") format("truetype"),
     url("fonts/OpenSans-ExtraBold.svg#OpenSansBold") format("svg");
  font-weight: 800;
  font-style: normal;
}

@font-face {
  font-family: 'Open Sans';
  src: url("fonts/OpenSans-Semibold.eot");
  src: url("fonts/OpenSans-Semibold.eot?#iefix") format("embedded-opentype"),
     url("fonts/OpenSans-Semibold.woff") format("woff"),
     url("fonts/OpenSans-Semibold.ttf") format("truetype"),
     url("fonts/OpenSans-Semibold.svg#OpenSansBold") format("svg");
  font-weight: 600;
  font-style: normal;
}

@font-face {
  font-family: 'Open Sans';
  src: url("fonts/OpenSans-Bold.eot");
  src: url("fonts/OpenSans-Bold.eot?#iefix") format("embedded-opentype"),
     url("fonts/OpenSans-Bold.woff") format("woff"),
     url("fonts/OpenSans-Bold.ttf") format("truetype"),
     url("fonts/OpenSans-Bold.svg#OpenSansBold") format("svg");
  font-weight: bold;
  font-style: normal;
}

@font-face {
  font-family: 'Open Sans';
  src: url("fonts/OpenSans-Light.eot");
  src: url("fonts/OpenSans-Light.eot?#iefix") format("embedded-opentype"),
     url("fonts/OpenSans-Light.woff") format("woff"),
     url("fonts/OpenSans-Light.ttf") format("truetype"),
     url("fonts/OpenSans-Light.svg#OpenSansBold") format("svg");
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'Courgette';
  src: url('fonts/Courgette-Regular.eot');
  src: url('fonts/Courgette-Regular.eot?#iefix') format('embedded-opentype'),
     url('fonts/Courgette-Regular.woff') format('woff'),
     url('fonts/Courgette-Regular.ttf') format('truetype'),
     url('fonts/Courgette-Regular.svg') format('svg');
  font-weight: 400;
  font-style: normal;
}

@font-face {
  font-family: 'novecento_sans_widemedium';
  src: url('fonts/Novecentosanswide-Medium-webfont.woff2') format('woff2'),
       url('fonts/Novecentosanswide-Medium-webfont.woff') format('woff');
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'Montserrat SemiBold';
  font-style: normal;
  font-weight: normal;
  src: url('fonts/Montserrat-SemiBold.woff') format('woff');
}

@font-face {
  font-family: 'Calibri';
  src: url('fonts/Calibri-Light.woff2') format('woff2'),
       url('fonts/Calibri-Light.woff') format('woff');
  font-weight: 300;
  font-style: normal;
}

@font-face {
  font-family: 'Calibri';
  src: url('fonts/Calibri.woff2') format('woff2'),
       url('fonts/Calibri.woff') format('woff');
  font-weight: normal;
  font-style: normal;
}

/* ####################### general ####################### */

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

div, span, a {
  -webkit-appearance: none;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

img {
  border: 0px;
}

b {
  font-weight: 600;
}

a {
  color: inherit;
  text-decoration: underline;
}

a:hover {
  color: inherit;
  text-decoration: none;
}

a[href^="tel"] {
  color: inherit;
  text-decoration: none;
}

textarea:focus, input:focus {
  outline: none;
}

textarea {
  resize: none;
}

.quote {
  padding-left: 5px;
  font-family: 'Courgette', Arial, Helvetica, sans-serif;
  font-weight: 400;
  font-size: 24px;
  color: #25bcd7;
}

.shadow {
  -webkit-box-shadow: 0px 0px 8px 0px rgba(0,0,0,0.9);
  
-moz-box-shadow: 0px 0px 8px 0px rgba(0,0,0,0.9);
  
box-shadow: 0px 0px 8px 0px rgba(0,0,0,0.9);
}

/* ####################### headings ###################### */

h1 {
  margin: 0;
  padding: 0;
  font-family: 'Open Sans', Arial, Helvetica, sans-serif;
  font-weight: normal;
  font-size: 48px;
  color: #575757;
}

h2 {
  margin: 0;
  padding: 0;
  font-family: 'Open Sans', Arial, Helvetica, sans-serif;
  font-weight: normal;
  font-size: 48px;
  color: #575757;
}

/* ###################### main menu ###################### */

.menu_wrapper {
  position: absolute;
  z-index: 100;
  top: 0;
  left: 0;
  width: 100%;
  height: 50px;
}

.menu_cell {
  margin: 0 auto;
  width: 92%;
  max-width: 1500px;
  height: 50px;
  font-family: Arial, Helvetica, sans-serif;
  font-size: 16px;
  color: #fff;
  padding-top: 30px;
  text-align: right;
}

#mainmenu {
  display: block;
}

#mainmenu-mobile {
  display: none;
}

#fixedmenu-container {
  position: fixed;
  top: 0px;
  left: 0px;
  width: 100%;
  padding: 0px
  margin: 0px;
  vertical-align: top;
  z-index: 999;
}

#fixedmenu, #fixedmenu-mobile, #fixedmenu-phone {
  background: #000;
  width: 100%;
  padding: 0px
  margin: 0px;
  display: none;
}

.fixed_menu_outer {
  margin: 0 auto;
  width: 92%;
  max-width: 1500px;
  padding: 0px
  margin: 0px;
  display: table;
}

.fixed_cell1 {
  width: 50%;
  display: table-cell;
  padding: 0px
  margin: 0px;
  text-align: left;
  vertical-align: middle;
}

.fixed_cell2 {
  width: 50%;
  display: table-cell;
  padding: 0px
  margin: 0px;
  font-family: Arial, Helvetica, sans-serif;
  font-size: 16px;
  color: #fff;
  text-align: right;
  vertical-align: middle;
}

.sep {
  padding: 0px 15px 0px 15px;
}

a.menu {
  color: #fff;
  text-decoration: none;
}

a.menu:hover {
  color: #fff;
  text-decoration: underline;
}

/* ##################### mobile menu ##################### */

#darkoverlay {
  position: fixed;
  z-index: 9999;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  background: #151515;
  display: none;
}

#mobileoverlay {
  position: fixed;
  top: 0px;
  left: 0px;
  z-index: 99999;
  display: none;
  width: 100%;
  height: 100%;
  background: #151515;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.mobileoverlay_outerwrapper {
  width: 100%;
  height: 100%;
  display: table;
  table-layout: fixed;
}

.mobileoverlay_innerwrapper {
  width: 100%;
  height: 100%;
  display: table-cell;
  vertical-align: top;
  margin: 0px;
  padding: 0px;
}

.mobileoverlay_content {
  margin: 0px;
  padding: 0px;
  margin-top: 50px;
  color: #fff;
  -moz-transform: scale(1.5);
  -ms-transform: scale(1.5);
  -webkit-transform: scale(1.5);
  transform: scale(1.5);
  -moz-transition-property: -moz-transform;
  -o-transition-property: -o-transform;
  -webkit-transition-property: -webkit-transform;
  transition-property: transform;
  -moz-transition-duration: 0.4s;
  -o-transition-duration: 0.4s;
  -webkit-transition-duration: 0.4s;
  transition-duration: 0.4s;
}

.mobileoverlay_content.active {
  -moz-transform: scale(1.0);
  -ms-transform: scale(1.0);
  -webkit-transform: scale(1.0);
  transform: scale(1.0);
}

.menublock {
  width: 170px;
  height: 150px;
  padding: 0px;
  margin: 25px 20px 10px 20px;
  display: inline-block;
  background: #0074bc;
  color: #fff;
  cursor: pointer;
  vertical-align: top;
}

.menublock-inner {
  padding-top: 30px;
}

#mobileoverlay_close {
  position: fixed;
  top: 15px;
  z-index: 999999;
  display: none;
  width: 100px;
  height: 25px;
}

/* ################ main logo and captions ############### */

#logo-container {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  min-height: 535px;
  padding: 0;
  margin: 0;
  overflow: hidden;
}

#dark-overlay {
  position: absolute;
  z-index: 10;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  min-height: 535px;
  background-color:rgba(0, 0, 0, 0.6); /* 0 is transparent, 1 is black */
}

#logo-main {
  position: absolute;
  z-index: 100;
  top: 50%;
  left: 50%;
  width: 370px;
  height: 305px;
  margin-top: -195px;
  margin-left: -185px;
}

#photo-captions {
  position: absolute;
  z-index: 100;
  top: 50%;
  left: 50%;
  width: 370px;
  height: 90px;
  margin-top: 145px;
  margin-left: -185px;
}

.captionsvg {
  width: 370px;
  height: 90px;
}

#arrow {
  position: absolute;
  z-index: 100;
  bottom: 25px;
  left: 50%;
  margin-left: -25px;
  width: 50px;
  height: 19px;
}

#photo-area {
  position: absolute;
  top: 0;
  left: 0;
  padding: 0;
  margin: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  z-index: 0;
}

#photo-area div {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

#photo-area div.active {
  z-index: 3;
}

.caption {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
}

.initial {
  opacity: 1;
  margin-top: -5px;
}

/* ########## main logo and captions (inner page) ######### */

#logo-container-inner {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 505px;
  padding: 0;
  margin: 0;
  overflow: hidden;
}

#dark-overlay-inner {
  position: absolute;
  z-index: 10;
  top: 0;
  left: 0;
  width: 100%;
  height: 505px;
  background-color:rgba(0, 0, 0, 0.6); /* 0 is transparent, 1 is black */
}

#logo-main-inner {
  position: absolute;
  z-index: 100;
  top: 50%;
  left: 50%;
  width: 340px;
  height: 280px;
  margin-top: -175px;
  margin-left: -170px;
}

#photo-captions-inner {
  position: absolute;
  z-index: 100;
  top: 50%;
  left: 50%;
  width: 370px;
  height: 90px;
  margin-top: 135px;
  margin-left: -185px;
}

#photo-area-inner {
  position: absolute;
  top: 0;
  left: 0;
  padding: 0;
  margin: 0;
  width: 100%;
  height: 505px;
  overflow: hidden;
  z-index: 0;
}

#photo-area-inner div {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

#photo-area-inner div.active {
  z-index: 3;
}

/* ##################### quotes area ##################### */

#quotebg {
  position: relative;
  width: 100%;
  background: url(home_bg_testimonials.jpg) 100% 50% no-repeat;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
  color: white;
  height: 425px;
  min-height: 425px;
  margin: 0 auto;
  overflow: hidden;
  padding: 0;
}

#quotes {
  position: relative;
  top: 40%;
  width: 80%;
  max-width: 1000px;
  margin: 0 auto;
  transform: translateY(-50%);
  -moz-transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  text-align: center;
}

.textItem {
  font-family: 'Open Sans', Arial, Helvetica, sans-serif;
  font-size: 24px;
  line-height: 38px;
  font-weight: 600;
  text-align: center;
  color: #fff;
  padding: 30px;
  padding-bottom: 70px;
  background-color: rgba(0, 0, 0, 0.45);
  border: 1px solid transparent;
  border-radius: 20px;
  display: none;
}

#feedbacklink {
  position: absolute;
  bottom: 50px;
  left: 50%;
  width: 250px;
  height: 45px;
  margin-left: -125px;
  background: #0074bc;
  color: #fff;
  text-align: center;
  cursor: pointer;
}

#feedbacklinktext {
  text-align: center;
  padding: 9px;
  font-family: 'Open Sans', Arial, Helvetica, sans-serif;
  font-size: 18px;
}

#allpostslink {
  width: 250px;
  height: 45px;
  margin: 0 auto;
  background: #0074bc;
  color: #fff;
  text-align: center;
  cursor: pointer;
}

#allpostslinktext {
  text-align: center;
  padding: 9px;
  font-family: 'Open Sans', Arial, Helvetica, sans-serif;
  font-size: 18px;
}

/* #################### content area ##################### */

.content {
  font-family: 'Open Sans', Arial, Helvetica, sans-serif;
  font-weight: normal;
  font-size: 18px;
  color: #575757;
}

.content-padding {
  padding-left: 50px;
  padding-right: 50px;
}

@supports(padding: max(0px)) {
  .content-padding {
    padding-left: max(50px, env(safe-area-inset-left));
    padding-right: max(50px, env(safe-area-inset-right));
  }
}

.content a:hover {
  color: #0074bc;
}

.content a.bluebglink:hover {
  color: #fff;
}

.servicesblock {
  width: 130px;
  height: 120px;
  margin: 15px;
  display: inline-block;
  background: #fff;
  color: #575757;
  font-size: 16px;
  line-height: 28px;
  cursor: pointer;
}

.latestposttable {
  display: table;
  width: 90%;
  max-width: 800px;
  margin: 0 auto;
}

.latestpostrow {
  display: table-row;
  color: #575757;
  background: #fff;
}

.latestpostcell {
  display: table-cell;
  width: 75%;
  font-size: 16px;
  text-align: left;
  padding: 15px;
  vertical-align: middle;
  border-bottom: 1px solid #575757;
  cursor: pointer;
}

.postdatecell {
  display: table-cell;
  width: 25%;
  font-size: 14px;
  text-align: right;
  padding: 15px;
  vertical-align: middle;
  border-bottom: 1px solid #575757;
  cursor: pointer;
}

.latestpostrow:hover {
  color: #fff;
  background: #0074bc;
}

.separator {
  width: 100%;
  background: #0074bc;
}

.video {
  width: 640px;
  height: auto;
}

.feedbacklogo300 {
  width: 300px;
}

.feedbacklogo350 {
  width: 350px;
}

.feedbacklogo375 {
  width: 385px;
}

.londonlogowrapper {
  width: 405px;
  height: 295px;
  margin: 20px;
  display: inline-block;
}

.londonlogo {
  width: 385px;
  height: 275px;
  margin: 10px;
}

.contentlist {
  text-align: justify;
  margin-top: 5px;
  margin-bottom: 35px;
  line-height: 30px;
}

div.g-recaptcha {
  width: 304px;
}

.animatedgif {
  height: 150px;
}

.designfail {
  width: 90%;
  max-width: 605px;
}

.designfail2 {
  width: 90%;
  max-width: 400px;
}

.button-fb {
  color: #fff;
  font-family: 'novecento_sans_widemedium', Arial, Helvetica, sans-serif;
  font-weight: normal;
  font-style: normal;
  font-size: 18px;
  background: #3b579d;
  padding: 10px 18px 10px 18px;
  border: 1px solid #3b579d;
  text-decoration: none;
}

.button-fb:hover {
  color: #fff;
  background: #414042;
  border: 1px solid #414042;
}

.button-tw {
  color: #fff;
  font-family: 'novecento_sans_widemedium', Arial, Helvetica, sans-serif;
  font-weight: normal;
  font-style: normal;
  font-size: 18px;
  background: #2caae1;
  padding: 10px 25px 10px 25px;
  border: 1px solid #2caae1;
  text-decoration: none;
}

.button-tw:hover {
  color: #fff;
  background: #414042;
  border: 1px solid #414042;
}

/* ##################### footer area ##################### */

#fallbacklinks {
  display: none;
}

#footer-left {
  width: 48%;
  height: 100px;
  display: inline-block;
  border-right: 1px solid #fff;
  text-align: right;
  padding-right: 40px;
}

#footer-right {
  width: 48%;
  height: 100px;
  display: inline-block;
  text-align: left;
  padding-left: 40px;
  color: #fff;
}

.footer-center {
  width: 100%;
  height: 65px;
  text-align: center;
}

#fullfooter {
  display: block;
}

#midfooter, #mobilefooter, #iphone5footer {
  display: none;
}

a.footer {
  font-family: 'Open Sans', Arial, Helvetica, sans-serif;
  color: #fff;
  text-decoration: none;
}

a.footer:hover {
  font-family: 'Open Sans', Arial, Helvetica, sans-serif;
  color: #fff;
  text-decoration: underline;
}

.footersep {
  padding: 0px 8px 0px 8px;
}

.footersep2 {
  padding: 0px 5px 0px 5px;
}

/* ################### tables and forms ################## */

.tablewidth {
  width: 750px;
}

.inputwidth {
  width: 740px;
}

.tablewidth2 {
  width: 690px;
}

.inputwidth2 {
  width: 680px;
}

form {
  margin: 0px;
  padding: 0px;
  border: 0px;
}

.formtitle {
  font-family: 'Open Sans', Arial, Helvetica, sans-serif;
  font-weight: bold;
  font-size: 14px;
  text-transform: uppercase;
  color: #151515;
}

.forminput {
  font-family: 'Open Sans', Arial, Helvetica, sans-serif;
  font-weight: 300;
  font-size: 20px;
  color: #151515;
  background: transparent;
  border: 0px;
  border-radius: 0px;
  padding: 0px;
  margin: 0px;
}

.formtextarea {
  overflow: auto;
  font-family: 'Open Sans', Arial, Helvetica, sans-serif;
  font-weight: 300;
  font-size: 20px;
  color: #151515;
  background: transparent;
  border: 0px;
  border-radius: 0px;
  padding: 0px;
  margin: 0px;
}

.form-btn, .form-btn:hover {
  font-family: 'Open Sans', Arial, Helvetica, sans-serif;
  font-weight: 300;
  font-size: 16px;
  color: #151515;
  background: #fff;
  border: 0px;
  border-radius: 0px;
  display: inline-block;
  padding: 0px;
  margin: 0px;
  cursor: pointer;
  -webkit-appearance: none;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

.newstyletable-heading {
  margin-bottom: 4px;
  font-family: "Montserrat", Arial, Helvetica, sans-serif;
  font-weight: bold;
  font-style: normal;
  text-transform: uppercase;
  font-size: 12px;
}

.newstyletable-btn {
  margin-bottom: 4px;
  font-family: "Montserrat", Arial, Helvetica, sans-serif;
  font-weight: bold;
  font-style: normal;
  text-transform: uppercase;
  font-size: 16px;
  background: #8cc63f;
  color: #fff;
  border: 0px;
  border-radius: 0px;
  padding: 0px;
  margin: 0px;
  cursor: pointer;
  -webkit-appearance: none;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

.newstyletable-tablewidth {
  width: 600px;
}

.newstyletable-inputwidth {
  width: 590px;
}

.newstyletable-forminput {
  font-family: 'Open Sans', Arial, Helvetica, sans-serif;
  font-weight: 300;
  font-size: 16px;
  color: #1a1a1a;
  background: #f5f5f5;
  border: 0px;
  border-radius: 0px;
  padding: 2px;
  margin: 0px;
}

.newstyletable-formtextarea {
  overflow: auto;
  font-family: 'Open Sans', Arial, Helvetica, sans-serif;
  font-weight: 300;
  font-size: 16px;
  color: #1a1a1a;
  background: #f5f5f5;
  border: 0px;
  border-radius: 0px;
  padding: 0px;
  margin: 0px;
}

label {
  font-family: 'Calibri', Calibri, Arial, Helvetica, sans-serif;
  font-weight: 700;
  font-size: 19px;
  line-height: 1.3;
  color: #575757;
  display: block;
  margin-bottom: 8px;
}

.form-input-pink {
  width: 100%;
  min-height: 44px;
  font-family: 'Calibri', Calibri, Arial, Helvetica, sans-serif;
  font-weight: 200;
  font-size: 24px;
  color: #333;
  border: 2px dotted #ec3e97;
  border-radius: 0px;
  padding: 5px;
  margin: 0px;
}

.form-button-pink {
  height: 50px;
  font-family: 'Montserrat SemiBold', Arial, Helvetica, sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 18px;
  color: #fff;
  background: #ec3e97;
  border: 2px solid #ec3e97;
  border-radius: 4px;
  padding: 8px 25px 8px 25px;
  margin: 0px;
  cursor: pointer;
  -webkit-appearance: none;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  transition: background-color .25s ease-out, color .25s ease-out;
}

.form-button-pink:hover {
  color: #ec3e97;
  background: #fff;
  transition: background-color .25s ease-out, color .25s ease-out;
}

/* #################### media queries #################### */

@media screen and (min-width:901px) {
  h1, h2 { font-size:48px; }
  #fixedmenu { display:block; }
  #fixedmenu-mobile { display:none; }
  #fixedmenu-phone { display:none; }
  #mainmenu { display:block; }
  #mainmenu-mobile { display:none; }
  #logo-main { width:370px; height:305px; margin-top:-195px; margin-left:-185px; }
  #photo-captions { width:370px; height:90px; margin-top:145px; margin-left:-185px; }
  #logo-container-inner, #dark-overlay-inner, #photo-area-inner { height:505px; }
  #logo-main-inner { width:340px; height:280px; margin-top:-175px; margin-left:-170px; }
  #photo-captions-inner { width:370px; height:90px; margin-top:135px; margin-left:-185px; }
  .captionsvg { width:370px; height:90px; }
  .homephone { font-size:48px; }
  .textItem { font-size:24px; line-height:38px; padding:30px; padding-bottom:70px; }
  .video { width:640px; height:auto; }
  .video-large { display: block; }
  .video-medium { display: none; }
  .video-small { display: none; }
  .latestpostcell { display:table-cell; width:75%; padding:15px; }
  .postdatecell { display:table-cell; width:25%; padding:15px; }
  .hideonmobile { display:block; }
  .londonlogowrapper { width:405px; height:295px; }
  .londonlogo { width:385px; height:275px; margin:10px; }
  .appiconwrapper { width:250px; }
  .appicon { width:220px; height:220px; }
  .appstorebutton { width:260px; }
  #fullfooter { display:block; }
  #midfooter { display:none; }
  #mobilefooter { display:none; }
  #iphone5footer { display:none; }
  .content-padding { padding-left:50px; padding-right:50px; }
  @supports(padding: max(0px)) { .content-padding { padding-left: max(50px, env(safe-area-inset-left)); padding-right: max(50px, env(safe-area-inset-right)); } }
}

@media screen and (min-width:701px) and (max-width:900px) {
  h1, h2 { font-size:48px; }
  #fixedmenu { display:none; }
  #fixedmenu-mobile { display:block; }
  #fixedmenu-phone { display:none; }
  #mainmenu { display:block; }
  #mainmenu-mobile { display:none; }
  #logo-main { width:320px; height:263px; margin-top:-185px; margin-left:-160px; }
  #photo-captions { width:320px; height:77px; margin-top:115px; margin-left:-160px; }
  #logo-container-inner, #dark-overlay-inner, #photo-area-inner { height:475px; }
  #logo-main-inner { width:300px; height:247px; margin-top:-150px; margin-left:-150px; }
  #photo-captions-inner { width:320px; height:77px; margin-top:130px; margin-left:-160px; }
  .captionsvg { width:320px; height:77px; }
  .homephone { font-size:48px; }
  .textItem { font-size:24px; line-height:38px; padding:30px; padding-bottom:70px; }
  .video { width:600px; height:auto; }
  .video-large { display: none; }
  .video-medium { display: block; }
  .video-small { display: none; }
  .latestpostcell { display:table-cell; width:70%; padding:10px; }
  .postdatecell { display:table-cell; width:30%; padding:10px; }
  .hideonmobile { display:block; }
  .tablewidth { width:620px; }
  .inputwidth { width:610px; }
  .tablewidth2 { width:560px; }
  .inputwidth2 { width:550px; }
  .londonlogowrapper { width:405px; height:295px; }
  .londonlogo { width:385px; height:275px; margin:10px; }
  .appiconwrapper { width:230px; }
  .appicon { width:200px; height:200px; }
  .appstorebutton { width:260px; }
  #fullfooter { display:none; }
  #midfooter { display:block; }
  #mobilefooter { display:none; }
  #iphone5footer { display:none; }
  .content-padding { padding-left:50px; padding-right:50px; }
  @supports(padding: max(0px)) { .content-padding { padding-left: max(50px, env(safe-area-inset-left)); padding-right: max(50px, env(safe-area-inset-right)); } }
}

@media screen and (min-width:651px) and (max-width:700px) {
  h1, h2 { font-size:48px; }
  #fixedmenu { display:none; }
  #fixedmenu-mobile { display:block; }
  #fixedmenu-phone { display:none; }
  #mainmenu { display:block; }
  #mainmenu-mobile { display:none; }
  #logo-main { width:320px; height:263px; margin-top:-185px; margin-left:-160px; }
  #photo-captions { width:320px; height:77px; margin-top:115px; margin-left:-160px; }
  #logo-container-inner, #dark-overlay-inner, #photo-area-inner { height:475px; }
  #logo-main-inner { width:300px; height:247px; margin-top:-150px; margin-left:-150px; }
  #photo-captions-inner { width:320px; height:77px; margin-top:130px; margin-left:-160px; }
  .captionsvg { width:320px; height:77px; }
  .homephone { font-size:48px; }
  .textItem { font-size:24px; line-height:38px; padding:30px; padding-bottom:70px; }
  .video { width:600px; height:auto; }
  .video-large { display: none; }
  .video-medium { display: block; }
  .video-small { display: none; }
  .latestpostcell { display:table-cell; width:70%; padding:10px; }
  .postdatecell { display:table-cell; width:30%; padding:10px; }
  .hideonmobile { display:block; }
  .tablewidth { width:620px; }
  .inputwidth { width:610px; }
  .tablewidth2 { width:560px; }
  .inputwidth2 { width:550px; }
  .londonlogowrapper { width:405px; height:295px; }
  .londonlogo { width:385px; height:275px; margin:10px; }
  .appiconwrapper { width:230px; }
  .appicon { width:200px; height:200px; }
  .appstorebutton { width:260px; }
  #fullfooter { display:none; }
  #midfooter { display:block; }
  #mobilefooter { display:none; }
  #iphone5footer { display:none; }
  .content-padding { padding-left:35px; padding-right:35px; }
  @supports(padding: max(0px)) { .content-padding { padding-left: max(35px, env(safe-area-inset-left)); padding-right: max(35px, env(safe-area-inset-right)); } }
}

@media screen and (min-width:636px) and (max-width:650px) {
  h1, h2 { font-size:42px; }
  #fixedmenu { display:none; }
  #fixedmenu-mobile { display:block; }
  #fixedmenu-phone { display:none; }
  #mainmenu { display:none; }
  #mainmenu-mobile { display:block; }
  #logo-main { width:320px; height:263px; margin-top:-185px; margin-left:-160px; }
  #photo-captions { width:320px; height:77px; margin-top:115px; margin-left:-160px; }
  #logo-container-inner, #dark-overlay-inner, #photo-area-inner { height:475px; }
  #logo-main-inner { width:300px; height:247px; margin-top:-155px; margin-left:-150px; }
  #photo-captions-inner { width:320px; height:77px; margin-top:130px; margin-left:-160px; }
  .captionsvg { width:320px; height:77px; }
  .homephone { font-size:42px; }
  .textItem { font-size:22px; line-height:34px; padding:25px; padding-bottom:60px; }
  .video { width:480px; height:auto; }
  .video-large { display: none; }
  .video-medium { display: block; }
  .video-small { display: none; }
  .latestpostcell { display:table-cell; width:100%; padding:15px; }
  .postdatecell { display:none; }
  .hideonmobile { display:block; }
  .tablewidth { width:440px; }
  .inputwidth { width:430px; }
  .tablewidth2 { width:380px; }
  .inputwidth2 { width:370px; }
  .londonlogowrapper { width:405px; height:295px; }
  .londonlogo { width:385px; height:275px; margin:10px; }
  .appiconwrapper { width:210px; }
  .appicon { width:180px; height:180px; }
  .appstorebutton { width:260px; }
  #fullfooter { display:none; }
  #midfooter { display:block; }
  #mobilefooter { display:none; }
  #iphone5footer { display:none; }
  .content-padding { padding-left:35px; padding-right:35px; }
  @supports(padding: max(0px)) { .content-padding { padding-left: max(35px, env(safe-area-inset-left)); padding-right: max(35px, env(safe-area-inset-right)); } }
}

@media screen and (min-width:401px) and (max-width:635px) {
  h1, h2 { font-size:32px; }
  #fixedmenu { display:none; }
  #fixedmenu-mobile { display:none; }
  #fixedmenu-phone { display:block; }
  #mainmenu { display:none; }
  #mainmenu-mobile { display:block; }
  #logo-main { width:270px; height:222px; margin-top:-175px; margin-left:-135px; }
  #photo-captions { width:270px; height:65px; margin-top:90px; margin-left:-135px; }
  #logo-container-inner, #dark-overlay-inner, #photo-area-inner { height:415px; }
  #logo-main-inner { width:250px; height:205px; margin-top:-125px; margin-left:-125px; }
  #photo-captions-inner { width:270px; height:65px; margin-top:110px; margin-left:-135px; }
  .captionsvg { width:270px; height:65px; }
  .homephone { font-size:38px; }
  .textItem { font-size:18px; line-height:30px; padding:20px; padding-bottom:50px; }
  .video { width:320px; height:auto; }
  .video-large { display: none; }
  .video-medium { display: none; }
  .video-small { display: block; }
  .latestpostcell { display:table-cell; width:100%; padding:15px; }
  .postdatecell { display:none; }
  .hideonmobile { display:none; }
  .tablewidth { width:320px; }
  .inputwidth { width:310px; }
  .tablewidth2 { width:260px; }
  .inputwidth2 { width:250px; }
  .feedbacklogo300 { width:270px; }
  .feedbacklogo350 { width:290px; }
  .feedbacklogo375 { width:300px; }
  .londonlogowrapper { width:296px; height:213px; }
  .londonlogo { width:290px; height:207px; margin:3px; }
  .appiconwrapper { width:200px; }
  .appicon { width:160px; height:160px; }
  .appstorebutton { width:240px; }
  #fullfooter { display:none; }
  #midfooter { display:none; }
  #mobilefooter { display:block; }
  #iphone5footer { display:none; }
  .animatedgif { height:120px; }
  .content-padding { padding-left:35px; padding-right:35px; }
  @supports(padding: max(0px)) { .content-padding { padding-left: max(35px, env(safe-area-inset-left)); padding-right: max(35px, env(safe-area-inset-right)); } }
}

@media screen and (min-width:351px) and (max-width:400px) {
  h1, h2 { font-size:32px; }
  #fixedmenu { display:none; }
  #fixedmenu-mobile { display:none; }
  #fixedmenu-phone { display:block; }
  #mainmenu { display:none; }
  #mainmenu-mobile { display:block; }
  #logo-main { width:270px; height:222px; margin-top:-175px; margin-left:-135px; }
  #photo-captions { width:270px; height:65px; margin-top:90px; margin-left:-135px; }
  #logo-container-inner, #dark-overlay-inner, #photo-area-inner { height:415px; }
  #logo-main-inner { width:250px; height:205px; margin-top:-125px; margin-left:-125px; }
  #photo-captions-inner { width:270px; height:65px; margin-top:110px; margin-left:-135px; }
  .captionsvg { width:270px; height:65px; }
  .homephone { font-size:38px; }
  .textItem { font-size:18px; line-height:30px; padding:20px; padding-bottom:50px; }
  .video { width:320px; height:auto; }
  .video-large { display: none; }
  .video-medium { display: none; }
  .video-small { display: block; }
  .latestpostcell { display:table-cell; width:100%; padding:15px; }
  .postdatecell { display:none; }
  .hideonmobile { display:none; }
  .tablewidth { width:320px; }
  .inputwidth { width:310px; }
  .tablewidth2 { width:260px; }
  .inputwidth2 { width:250px; }
  .feedbacklogo300 { width:270px; }
  .feedbacklogo350 { width:290px; }
  .feedbacklogo375 { width:300px; }
  .londonlogowrapper { width:296px; height:213px; }
  .londonlogo { width:290px; height:207px; margin:3px; }
  .appiconwrapper { width:200px; }
  .appicon { width:160px; height:160px; }
  .appstorebutton { width:240px; }
  #fullfooter { display:none; }
  #midfooter { display:none; }
  #mobilefooter { display:block; }
  #iphone5footer { display:none; }
  .animatedgif { height:120px; }
  .content-padding { padding-left:25px; padding-right:25px; }
  @supports(padding: max(0px)) { .content-padding { padding-left: max(25px, env(safe-area-inset-left)); padding-right: max(25px, env(safe-area-inset-right)); } }
}

@media screen and (max-width:350px) {
  h1, h2 { font-size:28px; }
  #fixedmenu { display:none; }
  #fixedmenu-mobile { display:none; }
  #fixedmenu-phone { display:block; }
  #mainmenu { display:none; }
  #mainmenu-mobile { display:block; }
  #logo-main { width:250px; height:205px; margin-top:-170px; margin-left:-125px; }
  #photo-captions { width:250px; height:60px; margin-top:87px; margin-left:-125px; }
  #logo-container-inner, #dark-overlay-inner, #photo-area-inner { height:400px; }
  #logo-main-inner { width:250px; height:205px; margin-top:-125px; margin-left:-125px; }
  #photo-captions-inner { width:270px; height:65px; margin-top:110px; margin-left:-135px; }
  .captionsvg { width:250px; height:60px; }
  .homephone { font-size:32px; }
  .textItem { font-size:16px; line-height:28px; padding:20px; padding-bottom:40px; }
  .video { width:300px; height:auto; }
  .video-large { display: none; }
  .video-medium { display: none; }
  .video-small { display: block; }
  .latestpostcell { display:table-cell; width:100%; padding:15px; }
  .postdatecell { display:none; }
  .hideonmobile { display:none; }
  .tablewidth { width:300px; }
  .inputwidth { width:290px; }
  .tablewidth2 { width:240px; }
  .inputwidth2 { width:230px; }
  .feedbacklogo300 { width:250px; }
  .feedbacklogo350 { width:270px; }
  .feedbacklogo375 { width:280px; }
  .londonlogowrapper { width:276px; height:198px; }
  .londonlogo { width:270px; height:192px; margin:3px; }
  .appiconwrapper { width:180px; }
  .appicon { width:140px; height:140px; }
  .appstorebutton { width:220px; }
  #fullfooter { display:none; }
  #midfooter { display:none; }
  #mobilefooter { display:none; }
  #iphone5footer { display:block; }
  .animatedgif { height:100px; }
  .content-padding { padding-left:25px; padding-right:25px; }
  @supports(padding: max(0px)) { .content-padding { padding-left: max(25px, env(safe-area-inset-left)); padding-right: max(25px, env(safe-area-inset-right)); } }
}

/* ######################################################### */

@media screen and (min-height:751px) {
  #mobilelogo { display:block; }
  .menublock { width: 170px; height: 150px; margin: 15px 20px 15px 20px; }
  .menublock-inner { padding-top:30px; }
}

@media screen and (min-height:501px) and (max-height:750px) {
  #mobilelogo { display:none; }
  .menublock { width: 145px; height: 130px; margin: 5px 12px 12px 12px; }
  .menublock-inner { padding-top:30px; }
}

@media screen and (max-height:500px) and (min-width:601px) {
  #mobilelogo { display:none; }
  .menublock { width: 145px; height: 130px; margin: 5px 12px 12px 12px; }
  .menublock-inner { padding-top:23px; }
}

@media screen and (max-height:500px) and (max-width:600px) {
  #mobilelogo { display:none; }
  .menublock { width: 130px; height: 125px; margin: 5px 10px 12px 10px; }
  .menublock-inner { padding-top:23px; }
}

/* ######################################################### */
