@import url('https://fonts.googleapis.com/css2?family=Oxanium:wght@200;300;400;500;600;700;800&display=swap');

:root {
  /* CSS DARK THEME PRIMARY COLORS */
  --color-primary-100: #eed6e0;
  --color-primary-200: #f0dbe3;
  --color-primary-300: #f2dfe7;
  --color-primary-400: #f4e4ea;
  --color-primary-500: #f6e8ee;
  --color-primary-600: #f8edf1;

  /* CSS DARK THEME SURFACE COLORS */
  --color-surface-100: #25395e;
  --color-surface-200: #3d4c6f;
  --color-surface-300: #546080;
  --color-surface-400: #6b7591;
  --color-surface-500: #828ba3;
  --color-surface-600: #9aa1b4;

  /* CSS DARK THEME MIXED SURFACE COLORS */
  --color-surface-mixed-100: #39476a;
  --color-surface-mixed-200: #4e597a;
  --color-surface-mixed-300: #636c89;
  --color-surface-mixed-400: #788099;
  --color-surface-mixed-500: #8d94aa;
  --color-surface-mixed-600: #a3a8ba;

  /* FONT SIZES */
  --font-size-sm: 0.875rem;
  --line-height-sm: 1.25rem;
  --font-size-md: 1rem;
  --line-height-md: 1.5rem;
  --font-size-lg: 1.125rem;
  --line-height-lg: 1.75rem;
  --font-size-xl: 1.25rem;
  --line-height-xl: 1.75rem;
  --font-size-2x: 1.5rem;
  --line-height-2x: 2rem;
}

html {
  height: 100%;
  background: rgb(37,57,94);
  background: linear-gradient(0deg, 
                              var(--color-surface-100) 20%, 
                              var(--color-surface-300) 100%);
  font-family: Oxanium;
}

body {
  margin: 0;
  min-height: 75vh;
  display: flex;
  justify-content: center;
  align-items: center;
}

.app-container {
  width: 80%;
}

.output-container {
  margin: 0px 25px;
  display: flex;
  flex-direction: column;
}

input#pw-input {
  --input-background-color: black;
  width: 100%;
  height: 60px;
  padding: 5px 25px;
  font-size: var(--font-size-2x);
  font-family: inherit;
  font-weight: 700;
  color: white;
  border: 4px solid var(--input-background-color);
  border-radius: 30px;
  outline: none;
  background-color: var(--color-surface-mixed-500);
  box-shadow: -6px 10px 0px var(--input-background-color);
  box-sizing: border-box;
}

p {
  color: var(--color-primary-100);
}

p.pw-stat {
  font-size: var(--font-size-lg);
  font-family: inherit;
  font-weight: 500;
  line-height: var(--line-height-lg);
}

p#pw-output {
  min-height: var(--line-height-2x);
  font-size: var(--font-size-2x);
  font-family: inherit;
  font-weight: 800;
  line-height: var(--line-height-2x);
  display: block;
}

button {
  font-size: var(--font-size-lg);
  font-family: inherit;
  font-weight: 600;
  color: var(--color-surface-100);
  padding: 15px;
  border: 4px solid black;
  border-radius: 0;
  text-align: center;
  background-color: var(--color-primary-300);
  display: inline-block;
  cursor: pointer;
  outline: none;
}

button:hover {
  background-color: var(--color-primary-600);
}

@media (min-width: 640px) {
  .app-container {
    width: 70%;
  }
}

@media (min-width: 768px) {
  .app-container {
    width: 480px;
  }
}


@media (min-width: 1024px) {

}


@media (min-width: 1280px) {

}


@media (min-width: 1536px) {

}
