/*
 * This is a manifest file that'll be compiled into application.css.
 *
 * With Propshaft, assets are served efficiently without preprocessing steps. You can still include
 * application-wide styles in this file, but keep in mind that CSS precedence will follow the standard
 * cascading order, meaning styles declared later in the document or manifest will override earlier ones,
 * depending on specificity.
 *
 * Consider organizing styles into separate files for maintainability.
 */

:root {
     --unit: 8px;
     
     --color-black: #323637;
     --color-gray: #ccc;
     --color-dark-gray: #999;
     --color-light-green: #d6e8e3;
     --color-white: #FFF;
     --color-light-gray: #EDF1F2;
     --color-green: #5FA99A;
     --color-yellow: #F3DE8A;
     --color-dark-yellow: #8c7721;
     --color-blue: #1C6EE1;
     --color-orange: #E4572E;
     
     --color-site: var(--color-white);
     
     --size-xs: 36rem;
     --size-sm: 40rem;
     --size-md: 48rem;
     --size-lg: 64rem;
     --size-xl: 80rem;
     --thin:       200;
     --light:      300;
     --normal:     400;
     --semibold:   600;
     --bold:       700;
     --ultrabold:  900;
 }
 
 html, body, div, span, applet, object, iframe,
 h1, h2, h3, h4, h5, h6, p, blockquote, pre,
 a, abbr, acronym, address, big, cite, code,
 del, dfn, em, img, ins, kbd, q, s, samp,
 small, strike, strong, sub, sup, tt, var,
 b, u, i, center,
 dl, dt, dd, ol, ul, li,
 fieldset, form, label, legend,
 table, caption, tbody, tfoot, thead, tr, th, td,
 article, aside, canvas, details, embed, 
 figure, figcaption, footer, header, hgroup, 
 menu, nav, output, ruby, section, summary,
 time, mark, audio, video {
     margin: 0;
     padding: 0;
     border: 0;
     font-size: 100%;
     font: inherit;
     vertical-align: baseline;
 }
 /* HTML5 display-role reset for older browsers */
 article, aside, details, figcaption, figure, 
 footer, header, hgroup, menu, nav, section {
     display: block;
 }
 body {
     line-height: 1;
 }
 ol, ul {
     list-style: none;
 }
 blockquote, q {
     quotes: none;
 }
 blockquote:before, blockquote:after,
 q:before, q:after {
     content: '';
     content: none;
 }
 table {
     border-collapse: collapse;
     border-spacing: 0;
 }
 
 *, ::after, ::before {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
  }
  
  html, body {
    font-size: 16px;
    line-height: 1.5;
  }
  
  body {
    background: var(--color-site);
    color: var(--color-black);
    -webkit-font-smoothing: antialiased;
    font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica",
      "Arial", sans-serif, "Apple Color Emoji", "Segoe UI Emoji",
      "Segoe UI Symbol";
    overflow-x: hidden;
    text-rendering: optimizeLegibility;
  }
  
  table {
    border-collapse: collapse;
    border-spacing: 0;
  }
  
  th {
  }
  
  td  {
    padding-left: calc(var(--unit) / 1.5);
    padding-right: calc(var(--unit) / 1.5);
    padding-top: calc(var(--unit) / 2);
    padding-bottom: calc(var(--unit) / 2);
  }
  
  .bt {
    border-top-width: 1px;
    border-top-style: solid;
  }
  
  .br {
    border-right-width: 1px;
    border-right-style: solid;
  }
  
  .bb {
    border-bottom-width: 1px;
    border-bottom-style: solid;
  }
  
  .bl {
    border-left-width: 1px;
    border-left-style: solid;
  }
  
  .b  {
    border-width: 1px;
    border-style: solid;
  }
  
  .b-light-gray  { border-color: var(--color-light-gray); }

  .b2 {
    border-width: 2px;
  }
  
  .r-sm {
    border-radius: calc(var(--unit) / 2);
    overflow: hidden;
  }
  
  .r-md {
    border-radius: var(--unit);
    overflow: hidden;
  }
  
  .r-lg {
    border-radius: calc(var(--unit) * 2);
    overflow: hidden;
  }
  
  .circle {
    border-radius: 100%;
    overflow: hidden;
  }
  
  .b-gray {
      border-color: var(--color-gray);
  }
  
  h1,h2,h3,h4,h5,h6 {
      font-weight: var(--bold);
      -webkit-font-smoothing: initial;
      line-height: 1.25;
      margin-top: 0;
      margin-bottom: var(--unit);
  }
  
  .h1, h1 { font-size: 2rem; }
  .h2, h2 { font-size: 1.5rem; }
  .h3, h3 { font-size: 1.17rem; }
  .h4, h4 { font-size: 1rem; }
  .h5, h5 { font-size: 0.88rem; }
  .h6, h6 { font-size: 0.67rem; }
  
  .h1, .h2, .h3, .h4, .h5, .h6 {
    -webkit-font-smoothing: initial;
    line-height: 1.25;
  }
  
  .text-center {
    text-align: center;
  }
  
  .text-left {
    text-align: left;
  }
  
  .light {
    font-weight: var(--light);
  }
  
  .normal {
    font-weight: var(--normal);
  }
  
  .semi-bold {
    font-weight: var(--semibold);
  }
  
  .bold {
    font-weight: var(--bold);
  }
  
  .ultra-bold {
    font-weight: var(--ultrabold);
  }
  
  .uppercase {
    text-transform: uppercase;
  }
  
  .black {
    color: var(--color-black);
  }
  
  .dark-gray {
    color: var(--color-dark-gray);
  }
  
  .gray {
    color: var(--color-gray);
  }
  
  .dark-gray {
    color: var(--color-dark-gray);
  }
  
  .no-underline {
    text-decoration: none;
  }
  
  .p1 {
    padding: var(--unit);
  }
  
  .p2 {
    padding: calc(var(--unit) * 2);
  }
  
  .p3 {
    padding: calc(var(--unit) * 3);
  }
  
  .p4 {
    padding: calc(var(--unit) * 4);
  }
  
  .p5 {
    padding: calc(var(--unit) * 5);
  }
  
  .p6 {
    padding: calc(var(--unit) * 6);
  }
  
  .pb1 {
    padding-bottom: var(--unit);
  }
  
  .pb2 {
    padding-bottom: calc(var(--unit) * 2);
  }
  
  .pb3 {
    padding-bottom: calc(var(--unit) * 3);
  }
  
  .pb4 {
    padding-bottom: calc(var(--unit) * 4);
  }
  
  .pb5 {
    padding-bottom: calc(var(--unit) * 5);
  }
  
  .pb6 {
    padding-bottom: calc(var(--unit) * 6);
  }
  
  .pt1 {
    padding-top: var(--unit);
  }
  
  .pt2 {
    padding-top: calc(var(--unit) * 2);
  }
  
  .pt3 {
    padding-top: calc(var(--unit) * 3);
  }
  
  .pt4 {
    padding-top: calc(var(--unit) * 4);
  }
  
  .pt5 {
    padding-top: calc(var(--unit) * 5);
  }
  
  .pt6 {
    padding-top: calc(var(--unit) * 6);
  }
  
  .px1 {
    padding-left: calc(var(--unit) * 1);
    padding-right: calc(var(--unit) * 1);
  }
  
  .px2 {
    padding-left: calc(var(--unit) * 2);
    padding-right: calc(var(--unit) * 2);
  }
  
  .px3 {
    padding-left: calc(var(--unit) * 3);
    padding-right: calc(var(--unit) * 3);
  }
  
  .py0\.25 {
    padding-top: calc(var(--unit) * 0.25);
    padding-bottom: calc(var(--unit) * 0.25);
  }
    
  .py0\.5 {
    padding-top: calc(var(--unit) * 0.5);
    padding-bottom: calc(var(--unit) * 0.5);
  }
  
  .py2 {
    padding-top: calc(var(--unit) * 2);
    padding-bottom: calc(var(--unit) * 2);
  }
  
  .ml0\.25 { margin-left: calc(var(--unit) * 0.25); }
  
  .ml0\.5 { margin-left: calc(var(--unit) * 0.5); }
  
  .ml1 { margin-left: var(--unit); }
  .ml2 { margin-left: calc(var(--unit) * 2); }
  .ml3 { margin-left: calc(var(--unit) * 3); }
  .ml4 { margin-left: calc(var(--unit) * 4); }
  .ml5 { margin-left: calc(var(--unit) * 5); }
  .ml6 { margin-left: calc(var(--unit) * 6); }
  
  .mr1 { margin-right: var(--unit); }
  .mr2 { margin-right: calc(var(--unit) * 2); }
  .mr3 { margin-right: calc(var(--unit) * 3); }
  .mr4 { margin-right: calc(var(--unit) * 4); }
  .mr5 { margin-right: calc(var(--unit) * 5); }
  .mr6 { margin-right: calc(var(--unit) * 6); }
  
  .mb1 { margin-bottom: var(--unit); }
  .mb2 { margin-bottom: calc(var(--unit) * 2); }
  .mb3 { margin-bottom: calc(var(--unit) * 3); }
  .mb4 { margin-bottom: calc(var(--unit) * 4); }
  .mb5 { margin-bottom: calc(var(--unit) * 5); }
  .mb6 { margin-bottom: calc(var(--unit) * 6); }
  
  .mt1 {
    margin-top: var(--unit);
  }
  
  .mt2 {
    margin-top: calc(var(--unit) * 2);
  }
  
  .mt3 {
    margin-top: calc(var(--unit) * 3);
  }
  
  .mt4 {
    margin-top: calc(var(--unit) * 4);
  }
  
  .mt5 {
    margin-top: calc(var(--unit) * 5);
  }
  
  .mt6 {
    margin-top: calc(var(--unit) * 6);
  }
  
  .mxauto {
    margin-left: auto;
    margin-right: auto;
  }

  .-mx1 {
    margin-left: calc(var(--unit) * -1);
    margin-right: calc(var(--unit) * -1);
  }
  
  .-mx2 {
    margin-left: calc(var(--unit) * -2);
    margin-right: calc(var(--unit) * -2);
  }
  
  .-ml1 {
    margin-left: calc(var(--unit) * -1);
  }
  
  .-ml2 {
    margin-left: calc(var(--unit) * -2);
  }
  
  .-ml3 {
    margin-left: calc(var(--unit) * -3);
  }
  
  .-ml4\.5 {
    margin-left: calc(var(--unit) * -4.5);
  }
  
  .-ml4 {
    margin-left: calc(var(--unit) * -4);
  }
  
  .-ml5 {
    margin-left: calc(var(--unit) * -5);
  }
  
  .-ml6 {
    margin-left: calc(var(--unit) * -6);
  }

  .rg1 {
    row-gap: var(--unit);
  }
  
  .cg1 {
    column-gap: var(--unit);
  }

  .lh0 {
      line-height: 0;
  }
  
  .flex {
      display: flex;
  }
  
  .flex-column {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    flex-direction: column;
  }
  
  .flex-row {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
  }
  
  .flex-grow1 {
    flex-grow: 1;
  }
  
  @media (min-width: 48rem) {
    .md\:flex-column {
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
      flex-direction: column;
    }
    
    .md\:flex-row {
      -webkit-box-orient: horizontal;
      -webkit-box-direction: normal;
      -ms-flex-direction: row;
      flex-direction: row;
    }
  }
  
  .flex-wrap {
      flex-wrap: wrap;
  }
  
  .flex-start {
    justify-content: flex-start;
  }
  
  .flex-space-between {
    justify-content: space-between;
  }
  
  .justify-center {
      justify-content: center;
  }
  
  .align-items-start {
    align-items: flex-start;
  }
  
  .align-center {
    align-items: center;
  }
  
  .container-xs { max-width: var(--size-xs); }
  .container-sm { max-width: var(--size-sm); }
  .container-md { max-width: var(--size-md); }
  .container-lg { max-width: var(--size-lg); }
  .container-xl { max-width: var(--size-xl); }
  
  @media (min-width: var(--size-xs)) {
    .xs\:container-xs { max-width: var(--size-xs); }
    .xs\:container-sm { max-width: var(--size-sm); }
    .xs\:container-md { max-width: var(--size-md); }
    .xs\:container-lg { max-width: var(--size-lg); }
    .xs\:container-xl { max-width: var(--size-xl); }
  }
  
  @media (min-width: 40rem) {
    .sm\:container-xs { max-width: var(--size-xs); }
    .sm\:container-sm { max-width: var(--size-sm); }
    .sm\:container-md { max-width: var(--size-md); }
    .sm\:container-lg { max-width: var(--size-lg); }
    .sm\:container-xl { max-width: var(--size-xl); }
  }
  
  @media (min-width: 48rem) {
    .md\:container-xs { max-width: var(--size-xs); }
    .md\:container-sm { max-width: var(--size-sm); }
    .md\:container-md { max-width: var(--size-md); }
    .md\:container-lg { max-width: var(--size-lg); }
    .md\:container-xl { max-width: var(--size-xl); }
  }
  
  @media (min-width: var(--size-lg)) {
    .lg\:container-xs { max-width: var(--size-xs); }
    .lg\:container-sm { max-width: var(--size-sm); }
    .lg\:container-md { max-width: var(--size-md); }
    .lg\:container-lg { max-width: var(--size-lg); }
    .lg\:container-xl { max-width: var(--size-xl); }
  }
  
  @media (min-width: var(--size-xl)) {
    .xl\:container-xs { max-width: var(--size-xs); }
    .xl\:container-sm { max-width: var(--size-sm); }
    .xl\:container-md { max-width: var(--size-md); }
    .xl\:container-lg { max-width: var(--size-lg); }
    .xl\:container-xl { max-width: var(--size-xl); }
  }
  
  .col-2 {
      flex: 0 0 16.66666667%;
      max-width: 16.66666667%;
  }
  
  .col-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
  
  .col-4 {
      flex: 0 0 33.33333333%;
      max-width: 33.33333333%;
  }
  
  .col-6 {
      flex: 0 0 50%;
      max-width: 50%;
  }
  
  .col-8 {
      flex: 0 0 66.666667%;
      max-width: 66.666667%;
  }
  
  .col-9 {
      flex: 0 0 75%;
      max-width: 75%;
  }
  
  .col-12 {
      flex: 0 0 100%;
      max-width: 100%;
  }
  
  @media (min-width: 40rem) {
    .sm-col-6 {
        flex: 0 0 50%;
        max-width: 50%;
    }
  }
  
  @media (min-width: 48rem) {
    .md-col-3 {
      flex: 0 0 25%;
      max-width: 25%;
    }
    
    .md-col-4 {
      flex: 0 0 33.33333333%;
      max-width: 33.33333333%;
    }
    
    .md-col-6 {
        flex: 0 0 50%;
        max-width: 50%;
    }
    
    .md-col-8 {
        flex: 0 0 66.666667%;
        max-width: 66.666667%;
    }
    
    .md-col-12 {
        flex: 0 0 50%;
        max-width: 50%;
    }
  }
  
  .bg-yellow {
    background-color: var(--color-yellow);
  }
  
  .bg-gray {
    background-color: var(--color-gray);
  }
  
  .bg-light-gray {
    background-color: var(--color-light-gray);
  }
  
  .dark-yellow {
        color: var(--color-dark-yellow);
    }
  
  .centerer-x {
    left: 50%;
    transform: translateX(-50%);
  }
  
  .GoalBtn {
    background: var(--color-white);
    font-size: 0.95rem;
    font-weight: var(--bold);
    border: 2px solid var(--color-gray);
    border-radius: calc(var(--unit)/2);
    text-decoration: none;
    cursor: pointer;
    height: calc(var(--unit) * 3);
    width: calc(var(--unit) * 3);
    -webkit-appearance: none;
    white-space: nowrap;
    padding: 0;
  }
  
  .GoalBtn .IconCheck {
    height: calc(var(--unit) * 2);
    width: calc(var(--unit) * 2);
  }
  
  .GoalBtn .IconCheck path {
    fill: var(--color-light-green);
    transition: fill ease-in-out 0.2s;
  }
    
  .GoalBtnComplete.GoalBtn {
    background: var(--color-green);
    border-color: var(--color-green);
  }  
  
  .GoalBtnComplete.GoalBtn .IconCheck path {
    fill: var(--color-white);
  }
  
  .IconX {
      height: calc(var(--unit) * 3);
      width: calc(var(--unit) * 3);
  }
  
  .IconStar {
    height: calc(var(--unit) * 2);
    width: calc(var(--unit) * 2);
  }
  
  .is_beginning .IconStar {
    height: calc(var(--unit) * 1.25);
    width: calc(var(--unit) * 1.25);
  }
  
  .is_beginning .IconStar path {
    fill: var(--color-green);
  }
  
  .completed.is_beginning .IconStar path {
    fill: var(--color-white);
  }
  
  .IconPlus {
    height: calc(var(--unit) * 1.75);
    width: calc(var(--unit) * 1.75);
  }
  
  .IconPlus line {
   stroke: var(--color-black);
  }

.GoalNote {
  visibility: hidden;
}

.GoalNote-Container:hover .GoalNote {
  visibility: visible;
}
  
.GoalNote .IconNote {
  height: calc(var(--unit) * 3.5);
  width: calc(var(--unit) * 3.5);
}

.GoalNote .IconNote path {
 stroke: var(--color-gray);
}
  
.IconFlame {
  height: calc(var(--unit) * 1.75);
  width: calc(var(--unit) * 1.75);
}

.IconArrowLeft {
  height: calc(var(--unit) * 1.75);
  width: calc(var(--unit) * 1.75);
}

.IconArrowLeft path {
 stroke: var(--color-dark-gray);
}

.IconFlame path {
 stroke: var(--color-dark-gray);
}

.Notifications {
  background: var(--color-light-gray);
  color: var(--color-black);
  padding: var(--unit);
  position: fixed;
  bottom: calc(var(--unit) * -20);
}

.Notifications.is-active {
  bottom: var(--unit);
  transition: bottom ease-in-out 0.2s;
}

.GoalChart .GoalChart-Day {
  height: calc(var(--unit) * 2);
  width: calc(var(--unit) * 2);
  border-radius: calc(var(--unit));
  background-color: var(--color-light-gray);
  margin: 2px;
}

.GoalChart .GoalChart-Day.completed {
  background-color: var(--color-green);
}
  
.FooterLogo .IconLogoColor {
  height: calc(var(--unit) * 6);
  width: calc(var(--unit) * 6);
}

.Btn {
  background: var(--color-green);
  border: none;
  color: var(--color-white);
  font-size: 0.95rem;
  font-weight: var(--bold);
  border-radius: calc(var(--unit)/2);
  text-decoration: none;
  cursor: pointer;
  -webkit-appearance: none;
  white-space: nowrap;
  padding: var(--unit) calc(var(--unit) * 2);
}

.Input {
  background: rgba(255,255,255, 0.9);
  border: 1px solid var(--color-gray);
  font-family: inherit;
  font-size: inherit;
  display: block;
  width: 100%;
  padding: var(--unit);
  box-sizing: border-box;
  border-radius: var(--unit);
  transition: border-color 0.25s ease-in;
}

.Input:focus{
  border-color: var(--color-blue);
  outline: none;
}