body {
  width: 95%;
  max-width: 1400px;
  margin: 0 auto;
}

html {
  /* darker background background: #4e7198; */
  background: #375c82;
  background-repeat: repeat;
  background-size: contain;
}

main {
  background: #fff;
}

h1,h2,h3,h4,h5,h6 {
    font-family: bodoni-urw, serif;
    font-weight: 500;

}

h1{
  font-size: 3rem;
}

h2{
  font-size: 2.5rem;
}

p, a, ul, li, button, input {
  font-family: century-gothic, sans-serif;
  font-weight: 400;
  font-size: 1.5rem;
}

a {
  color: #304962;
}

button {
  background: #304962;
  color: #fff;
  font-size: 1.3rem;
  border-radius: 50px;
  border: none;
  transform: translateY(0px);
  transition: all .1s linear;
  padding: 10px;
}

button:hover {
background-color: #d0dddd;
transform: translateY(-2px);
transition: all .1s linear;
}

button a {
  color: #fff;
  padding: 10px;
  font-weight: bold;
}

button a:hover {
  color: #304962;
}

main {
  box-shadow: 0px 0px 10px rgba(0,0,0,.2);
}


/* Header Styles */

.navbar {
  padding: 2px 10px;
  height: 100px;
  border-bottom: solid 5px #304962;
  /*font-family: filson-pro, sans-serif;*/
  font-family: century-gothic, sans-serif;
  font-weight: 400;
  margin-top: 50px;

}

.navbar-brand .logo {
  z-index: 999999 !important;
}

.current-menu-item {
  font-weight: bold;
  font-size: 1.7rem;
  color: #304962;

}

.navbar .button {
  background: #304962;
  color: #fff;
  font-size: 1.3rem;
  border-radius: 50px;
  border: none;
  transform: translateY(0px);
  transition: all .1s linear;
}

.navbar .button:hover {
background-color: #fafafa;
color: #f2f2f2;
transform: translateY(-2px);
transition: all .1s linear;
}



.navbar-menu {
  font-size: 1.2rem;
}

a.navbar-item, .navbar .button {
transform: translateY(0px);
transition: all .1s linear;
}

a.navbar-item:hover {
  color: #304962;
}

a.navbar-item:hover, .navbar .button:hover {
background-color: #fafafa;
transform: translateY(-2px);
transition: all .1s linear;
}

.navbar .button:hover, #services-intro .card button:hover {
background: #3d91b9;
transition: all .1s linear;
}

/* End Header Styles */


/* Home Page Styles */

#welcome {
  margin-bottom: 50px;
}

.welcome-blurb {
  margin: -80px auto 50px;
  z-index: 999;
  background: transparent;
  position: absolute;
  left: 10%;
  width: 80%;
  box-shadow: 0px 0px 30px rgba(0,0,0,.2);
  background: #fff;
}

.colored-title {
  color: #fff;
  font-family: bodoni-urw, serif;
  font-style: normal;
  line-height: 3rem;
  height: 100%;
  padding: 0;
  background: #3d91b9;
}

.colored-title h2 {
  font-weight: 500 !important;
  padding: 10% 30px;
  font-size: 3rem;
}

.white-title-description {
  font-size: 1.2rem;
  line-height: 1.8rem;
  background: #fff;
}

.white-title-description p {
  padding: 3% 30px 0;
}


#services-intro, #contact-form {
  padding: 120px 0px;
  width: 90%;
  margin: 0 auto;
}

#services-intro .card {
  transform: translateY(0px);
  transition: all .2s linear;
  border: none !important;
  border-radius: 10px;
  box-shadow: 0px 10px 20px rgba(0,0,0,.2);
  padding: 30px 10px;
}

#services-intro .card:hover {
  transform: translateY(5px);
  transition: all .2s linear;
  box-shadow: 0px 10px 10px rgba(0,0,0,.3);
}

.card button {
    background: #304962;
    color: #fff !important;
    font-size: 1.3rem;
    border-radius: 50px;
    border: none;
    margin-top: 15px;
    padding: 10px;
    transition: all .1s linear;
}

.card button a {
  color: #fff !important;
  padding: 10px;
  font-weight: bold;
}

.card button a:hover {
  color: #f2f2f2 !important;
}

#services-intro .card img {
  width: 50%;
  max-width: 100px;
  margin: 0 auto;
}

#services-intro .card .content {
  font-size: 1.3rem;
  margin: 0 auto;
}


.section-title {
  padding: 3rem 0;
  max-width: 1000px;
  margin: 0 auto;
}

.section-title h2 {
  font-size: 3.5rem;
  line-height: 3.5rem;
  color: #304962;
}


.section-title .subtitle {
  font-size: 2rem;
  font-weight: 600;
}


.inner-page .section-title {
  padding-bottom: 0px;
}

.inner-page .inner-page-title .colored-title h2 {
  padding: 20px;
  box-shadow: 0px 0px 20px rgba(0,0,0,.2);
}

.inner-page .white-title-description {
  background: transparent;
}

.inner-page .welcome-blurb.inner-page-title {
  background: transparent;
  box-shadow: none;
}

.inner-page .welcome-blurb {
  background: transparent;
  box-shadow: 0px 0px 20px rgba(0,0,0,.3);
}

.specials-page .card figure.image {
  display: none;
}

.specials-page .card button {
  background: #f2f2f2;
  color: #3d91b9;
  box-shadow: 0px 10px 10px rgba(0,0,0,.4);
}

.specials-page .card button a {
  color: #304962 !important;

}

.specials-page .card button a:hover {
  color: #f9f9f9 !important;
}

.specials-page .title {
  font-size: 2.5rem;
  font-weight: bold;
}

.teeth-extraction {
  background: url(../img/tooth-removal.jpg);
  background-size: cover;
  background-repeat: no-repeat;
}

.teeth-extraction p {
  color: #fff;
}

.dental-implants {
  background: url(../img/dental-implants.jpg);
  background-size: cover;
  background-repeat: no-repeat;
}



.cta-btns {
  padding: 50px 0;
  margin: 0 auto;
}

.cta-btns button {
  background: transparent;
  border: solid 3px #304962;
}

.cta-btns button:hover {
  background: #304962;
  border: solid 3px transparent;
}

.cta-btns button a {
    color: #304962;
  }

.cta-btns button a:hover {
    color: #f2f2f2;
}

#pre-footer .white-title-description p {
  padding: 20px 30px 0;
  font-size: 1.6rem;
}


#contact-form form {
  margin: 100px auto 0;
  width: 90%;
  text-align: center;
}

#contact-form form input {
  margin: 10px 1%;
  border: solid 2px #aaa;
  width: 40%;
  height: 60px;
  padding: 5px 20px;
  font-size: 1.6rem;
}

#contact-form form textarea {
  margin: 10px auto;
  border: solid 2px #aaa;
  width: 83%;
  padding: 20px;
  font-size: 1.6rem;
  color: #333;
}

#contact-form ::placeholder {
  color: #777;
  font-family: century-gothic, sans-serif;
}

#contact-form button {
  padding: 0px;
  display: block;
  margin: 0px 78% 20px;
  right: 0;
  background: #304962;
  color: #fff;
  font-size: 1.3rem;
  border-radius: 50px;
  border: none;
  transform: translateY(0px);
  transition: all .1s linear;
  }

  #contact-form button:hover {
  background-color: #3d91b9;
  transform: translateY(-2px);
  transition: all .1s linear;
}

#submit-form {
  background: transparent;
  border: none !important;
  color: #fff;
  font-weight: bold;
  width: 100% !important;
  display: block;
  padding: 0px 30px !important;
  margin: 0px !important;
}

#submit-form:hover {
  color: #f2f2f2;
}







/* END Home Page Styles */


footer {
  padding: 0;
  position: absolute;
  left: 0;
  width: 100%;
  z-index: -1;
  margin-top: -60px;
}


.footer-nav  {
  line-height: 3rem;
}

.footer-nav li, .footer-nav li a {
  font-size: 2rem;
  width: auto;
}

.footer-left {
  background-color: #234062;
  padding: 250px 50px;
}


.footer-right {
  background-color: #3D91B9;
  padding: 250px 50px;
}

.home-page .footer-left {
  background-color: #234062;
  padding: 150px 50px;
}


.home-page .footer-right {
  background-color: #3D91B9;
  padding: 150px 50px;
}




.footer-left hr {
  background-color: rgba(255, 255, 255, 0.1);

}





.footer-right p {
  font-weight: 400;
}

footer a {
  color: #fff;
}

footer a:hover {
  color: #eee;
}

footer .columns {
  margin: 0;
}

.download-forms {
  background: #fff;
  color: #304962;
  padding: 5px 30px;
  border-radius: 50px;
  margin: 20px 0;
  margin-right: -20px;
  font-weight: bold;
}


.footer-logo {
  width: 100%;
  filter: opacity(.8);
  margin-top: 20px;
}

.footer-logo img {
  max-width: 400px;
}

.footer-creds {
  display: block;
  width: 100%;
  color: #f2f2f2;
  font-size: 1.4rem;
}

.footer-creds a {
  color: #fff;
}



/************************* Media Queries ********************/


@media (min-width: 1050px) {

  #hamburgericonmenuwrapper {
    display: none !important;
  }

  .cta-btns .column {
    display: flex;
    padding: 0 10px;
}


  .cta-btns .cta-1 {
    align-content: flex-end;
    justify-content: flex-end;
  }

  .cta-btns .cta-2 {
    align-content: flex-start;
    justify-content: flex-start;

  }

  .inner-page  .cta-btns .cta-1 {
      align-content: flex-start;
      justify-content: flex-start;
    }

  .inner-page .cta-btns {
    max-width: 800px;
    padding-left: 2%;
    margin: 0;
  }


  .inner-page #services-intro {
    padding-top: 50px;
  }

  .inner-page #pre-footer {
    margin-top: 100px;
  }

  .contact-page #services-intro {
    padding-bottom: 0px;
    margin-bottom: 0px;
  }



  .inner-page #contact-form {
    padding-top: 0px;
  }

  .inner-page.contact-page .cta-btns {
    padding: 0px 20px;
  }

  .inner-page.contact-page #contact-form form {
    width: 100%;
  }


  .inner-page.contact-page #contact-form input {
    width: 45%;
  }

  .inner-page.contact-page #contact-form textarea {
    width: 92%;
  }

  .inner-page.contact-page #contact-form button {
padding: 0px;
display: block;
margin: 20px 83% 20px;
}


  .specials .columns {
    padding-top: 100px;
  }



  .inner-page main {
    padding-bottom: 300px;
  }

  .specials-page main {
    padding-bottom: 50px;
  }

  .contact-page main {
    padding-bottom: 0px;
  }



  .navbar-menu {
    font-size: 1.4rem;
  }


  .navbar-item img {
  max-height: 100%;
  }

  .navbar-brand {
    margin-left: 1%;
    max-width: 30%;
    transform: none !important;
  }

  .navbar-brand .navbar-item:hover {
    transform: none !important;
  }

  .navbar-brand img {
    width: 100%;
  }

  .navbar-brand .navbar-item {
    width: 100%;
  }


}



@media (min-width: 1324px) {

  .navbar-brand img {
    width: 70%;
  }

  .inner-page .cta-btns {
    max-width: 800px;
    padding-left: 5%;
  }

  .navbar-brand {
    max-width: 30%;
    transform: none !important;
  }

  .navbar-menu {
    font-size: 1.7rem;
  }

  .welcome-blurb {
    justify-content: center;
    align-items: center;
  }



  h1{
    font-size: 3.5rem;
  }

  h2{
    font-size: 3rem;
  }

  p {
    font-family: century-gothic, sans-serif;
    font-weight: 400;
    font-size: 1.7rem;
  }


}


@media (min-width: 1524px) {

  .welcome-blurb {
    position: absolute;
    left: 20%;
    width: 60%;
}

.inner-page .cta-btns {
  max-width: 800px;
  padding-left: 10%;
}

    footer .columns {
      max-width: 1400px;
      margin: 0 auto;
    }
}



/* MOBILE MEDIA QUERIES */





@media (max-width: 1049px) {



  .navbar {
    padding: 2px 10px;
    height: 60px;
    border-bottom: solid 5px #304962;
    /*font-family: filson-pro, sans-serif;*/
    font-family: century-gothic, sans-serif;
    font-weight: 700;

}

#hamburgericonmenuwrapper.open #fullscreenmenu ul {
margin-top: 15%;
}

a.atoggler {
  float: right !important;
}

.media-content {
overflow: hidden;
}

.footer-logo img {
  width: 100%;
  max-width: 100%;
  margin: 0 auto;
}

.download-forms {
  font-size: 1.2rem;
}

.footer-nav, .footer-creds, .footer-left {
  text-align: center;
}

.page-content {
  padding-left: 30px;
  padding-right: 30px;
}

#contact-form form input {
  margin: 10px auto;
  border: solid 2px #aaa;
  width: 100%;
  height: 60px;
  padding: 5px 20px;
  font-size: 1.4rem;
}

#contact-form form textarea {
  margin: 10px auto;
  border: solid 2px #aaa;
  width: 100%;
  padding: 20px;
  font-size: 1.4rem;
  color: #333;
}

#contact-form button {
  padding: 0px;
  display: block;
  margin: 0px 65% 20px;
}


.home-page #services-intro {
  padding: 0px 20px;
}

.home-page #contact-form form {
  margin: 0px auto 0;
  width: 90%;
  text-align: center;
}

.contact-page #services-intro {
  padding-bottom: 0px;
}

.contact-page #contact-form  {
  padding-top: 20px;
}


#contact-form form {
  margin: 50px auto 0;
  width: 90%;
  text-align: center;
}

.contact-page #contact-form form {
  margin: 50px auto 0;
  width: 90%;
  text-align: center;
}

.welcome-blurb {
  margin: 50px auto 0;
  position: relative;
  left: 0;
  display: block;
  z-index: 0;
}

.welcome-blurb.faq {
  margin-top: 0px;
}

.white-title-description p {
  padding: 50px 20px;
}

#services-intro {
  padding: 20px 0px;
  width: 90%;
  margin: 0 auto;
}

.inner-page .faq .white-title-description {
  background: #fff;
  padding: 30px 20px;
}

.inner-page .faq .white-title-description p {
  padding: 50px 20px;
}

.inner-page #pre-footer {
  padding-bottom: 100px;
}


.footer-creds {
  font-size: 1.2rem;
}


}



/************************* END Media Queries ********************/
