html {
  line-height: 1.15;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
}

article,
aside,
footer,
header,
nav,
section {
  display: block;
}

h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

figcaption,
figure,
main {
  display: block;
}

figure {
  margin: 1em 40px;
}

hr {
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  height: 0;
  overflow: visible;
}

pre {
  font-family: monospace, monospace;
  font-size: 1em;
}

a {
  background-color: transparent;
  -webkit-text-decoration-skip: objects;
}

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}

b,
strong {
  font-weight: inherit;
}

b,
strong {
  font-weight: bolder;
}

code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

dfn {
  font-style: italic;
}

mark {
  background-color: #ff0;
  color: #000;
}

small {
  font-size: 80%;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

audio,
video {
  display: inline-block;
}

audio:not([controls]) {
  display: none;
  height: 0;
}

img {
  border-style: none;
}

svg:not(:root) {
  overflow: hidden;
}

button,
input,
optgroup,
select,
textarea {
  font-family: sans-serif;
  font-size: 100%;
  line-height: 1.15;
  margin: 0;
}

button,
input {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

button,
html [type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

fieldset {
  padding: 0.35em 0.75em 0.625em;
}

legend {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal;
}

progress {
  display: inline-block;
  vertical-align: baseline;
}

textarea {
  overflow: auto;
}

[type=checkbox],
[type=radio] {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding: 0;
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

[type=search]::-webkit-search-cancel-button,
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

details,
menu {
  display: block;
}

summary {
  display: list-item;
}

canvas {
  display: inline-block;
}

template {
  display: none;
}

[hidden] {
  display: none;
}

.clearfix:after {
  visibility: hidden;
  display: block;
  font-size: 0;
  content: "";
  clear: both;
  height: 0;
}

html {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

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

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  border: 0;
  padding: 0;
  white-space: nowrap;
  -webkit-clip-path: inset(100%);
          clip-path: inset(100%);
  clip: rect(0 0 0 0);
  overflow: hidden;
}

h1 {
  font-size: 3.7rem;
  font-family: "Bubblegum Sans";
}

h2 {
  font-size: 2rem;
  font-family: "Quando";
  color: white;
  text-shadow: 1px 1px #b6a64c;
}
h2 span {
  font-size: 1.7rem;
}

h3 {
  font-size: 1.6rem;
  font-family: "Quando";
}

h4 {
  font-size: 1rem;
  font-family: "Red Hat Display";
  color: #FEEA7E;
  text-transform: uppercase;
  line-height: 1.2;
  letter-spacing: 1.5px;
}

li,
p,
input {
  font-size: 1rem;
  font-family: "Red Hat Display";
  line-height: 1.4;
  color: #4C4C4C;
}

li {
  color: white;
}

label {
  color: black;
  text-align: center;
  line-height: 1.4;
  font-size: 1.2rem;
  font-family: "Quando";
}

button {
  font-family: "Red Hat Display";
  color: #4C4C4C;
  font-weight: 600;
}

body {
  background-color: #20B5D8;
  font-size: 125%;
}

.wrapper {
  max-width: 1000px;
  width: 90%;
  margin: 0 auto;
}

a {
  text-decoration: none;
  color: #4C4C4C;
}
a:hover, a:focus {
  color: #ffb36a;
}

button {
  padding: 15px 20px;
  border: none;
  background-color: #FEEA7E;
  text-transform: uppercase;
  letter-spacing: 0.1rem;
}

img {
  display: block;
}

ul {
  padding: 0;
}
ul li {
  list-style: square;
  line-height: 1.2;
}

header {
  position: relative;
  overflow: hidden;
}

.greycurve {
  border-bottom-right-radius: 40%;
  max-width: 1200px;
  background-color: #4C4C4C;
  height: 300px;
  padding: 45px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.greycurve div {
  width: 100%;
  position: absolute;
  bottom: 0;
  left: -10%;
  width: 110%;
  overflow: hidden;
}
.greycurve div img {
  width: 270%;
}

h1 {
  color: #FEEA7E;
  text-align: center;
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  z-index: 10;
  width: 90%;
}
h1 span {
  font-size: 2.5rem;
  display: block;
  opacity: 0.7;
}

/* loading page styling */
.displayLoading {
  height: 100%;
  width: 100%;
  background-color: #20B5D8;
  display: none;
  z-index: 10;
  position: absolute;
  -webkit-transition: 2s;
  transition: 2s;
}
.displayLoading .loadingAnimation {
  width: 200px;
  height: 200px;
  position: absolute;
  top: calc(50% - 100px);
  left: calc(50% - 100px);
  border-radius: 50%;
  background-image: -webkit-gradient(linear, left bottom, left top, color-stop(25%, #FEEA7E), color-stop(95%, rgba(243, 243, 243, 0.4)));
  background-image: linear-gradient(0deg, #FEEA7E 25%, rgba(243, 243, 243, 0.4) 95%);
  -webkit-animation: spin 1s infinite linear;
          animation: spin 1s infinite linear;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.displayLoading .loadingAnimation .innerLoading {
  width: 160px;
  height: 160px;
  margin: 0 auto;
  border-radius: 50%;
  background-color: #20B5D8;
}

@-webkit-keyframes spin {
  from {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  to {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}

@keyframes spin {
  from {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  to {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
.display {
  display: block;
}

.response {
  min-height: 35vh;
  position: relative;
}

.sectionsBackground {
  background-color: #4C4C4C;
  border-radius: 40px;
  margin-bottom: 45px;
  border: 20px solid #82e8ff;
  -webkit-box-shadow: 5px 5px 8px #4C4C4C;
          box-shadow: 5px 5px 8px #4C4C4C;
}

form {
  margin: 20px auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
form div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
form div input {
  width: 235px;
  margin: 20px 0;
  padding: 10px;
}
form div button {
  width: 235px;
  border: 5px solid #FEEA7E;
  -webkit-box-shadow: 5px 5px 8px #4C4C4C;
          box-shadow: 5px 5px 8px #4C4C4C;
}
form div button:hover, form div button:focus {
  border: 5px solid #ffb36a;
  -webkit-transition: 1s;
  transition: 1s;
}
form div button:active {
  -webkit-box-shadow: none;
          box-shadow: none;
  -webkit-transition: 1s;
  transition: 1s;
}

.whatToWear {
  max-width: 470px;
}
.whatToWear .clothingFlexContainer {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.whatToWear .clothingFlexContainer img {
  width: 50%;
  max-width: 170px;
  padding-top: 15px;
}
.whatToWear .clothingFlexContainer h2 {
  padding-left: 25px;
}
.whatToWear ul {
  padding: 15px;
  margin: 0 auto;
}
.whatToWear ul h3 {
  text-align: center;
  margin: 0 auto;
  padding-bottom: 15px;
}
.whatToWear ul li {
  width: 120px;
  margin: 0 auto;
}
.whatToWear .treadmillRec {
  margin: 15px;
  color: #FEEA7E;
  font-size: 0.8rem;
}

.column {
  -webkit-column-count: 2;
     -moz-column-count: 2;
          column-count: 2;
  -webkit-column-gap: 1;
     -moz-column-gap: 1;
          column-gap: 1;
}

/* 'not the right city?' section */
.location {
  margin: 45px auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-radius: 30px;
}
.location h3 {
  margin: 8px 0 0 0;
  padding: 0 10px;
  color: #FEEA7E;
  text-align: center;
}

.locationBackground {
  background-color: #4C4C4C;
  max-width: 450px;
}

.errorHandling {
  margin: 5px;
  color: transparent;
  font-size: 0.1rem;
  -webkit-transition: all 1200ms ease-out;
  transition: all 1200ms ease-out;
}
.errorHandling span {
  display: block;
}

.visuallyShow {
  color: white;
  font-size: 1rem;
}

.displayNone {
  display: none;
}

.currentConditions {
  max-width: 470px;
}
.currentConditions .flexContainer {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding-top: 15px;
}

.iconContainer {
  width: 55%;
}
.iconContainer img {
  width: 100%;
  max-width: 300px;
}

.forecastHighlights {
  width: 40%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding-left: 15px;
}
.forecastHighlights h2 {
  margin: 10px 0;
}
.forecastHighlights h2 span {
  display: block;
  margin: 5px 0;
}
.forecastHighlights h4 {
  margin: 0;
}

.additionalInfo {
  padding: 15px 0 15px 5%;
}

footer {
  background-color: #4C4C4C;
  padding: 10px;
}
footer p {
  text-align: center;
  margin: 0;
  color: #d9d9d9;
}
footer p a {
  color: #fffbe3;
  font-weight: 600;
}

@media (min-width: 480px) {
  .greycurve div {
    left: -7%;
    width: 107%;
  }
  .greycurve div img {
    width: 220%;
  }

  h2 {
    font-size: 2.3rem;
  }
  h2 span {
    font-size: 2rem;
  }

  li {
    font-size: 1.5rem;
    line-height: 1.2;
  }
}
@media (min-width: 560px) {
  h1 {
    font-size: 4.2rem;
    top: 25%;
  }

  .greycurve {
    height: 350px;
  }
  .greycurve div {
    bottom: -50px;
  }
  .greycurve div img {
    width: 180%;
  }
}
@media (min-width: 750px) {
  h1 {
    font-size: 5.5rem;
  }
  h1 span {
    font-size: 3rem;
  }

  .greycurve {
    border-bottom-right-radius: 300px;
  }
  .greycurve div {
    left: -4%;
    width: 104%;
    bottom: -40px;
  }
  .greycurve div img {
    width: 160%;
  }
}
@media (min-width: 1100px) {
  h1 {
    top: 10%;
    font-size: 7rem;
  }
  h1 span {
    font-size: 3.5rem;
  }

  .greycurve {
    border-bottom-right-radius: 400px;
  }
  .greycurve div {
    bottom: -90px;
  }
  .greycurve div img {
    width: 100%;
    max-width: 1200px;
  }

  form label {
    margin-bottom: 15px;
  }
  form div {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    width: 550px;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  form div input {
    width: 270px;
  }
  form div button {
    width: 270px;
    font-size: 0.8rem;
    padding: 10px;
  }

  .results {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    max-width: 1100px;
    margin: 0 auto;
  }

  .locationBackground {
    max-width: 600px;
  }

  .errorHandling span {
    display: inline;
  }
}
@media (min-width: 1450px) {
  .greycurve {
    max-width: 1450px;
  }
  .greycurve div {
    bottom: -115px;
  }
  .greycurve div img {
    max-width: 1300px;
  }
}