:root {
  --ink: #17251e;
  --forest: #315b48;
  --sage: #76a08a;
  --moss: #9ca85a;
  --gold: #e7b858;
  --clay: #df8f66;
  --paper: #fbf5e7;
  --cream: #fff9ec;
  --shadow: rgba(38, 54, 43, 0.16);
}

* {
  box-sizing: border-box;
}

html {
  background: var(--paper);
  color: var(--ink);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  scroll-behavior: smooth;
}

body {
  margin: 0;
}

main {
  overflow: hidden;
}

.section {
  min-height: 100vh;
  position: relative;
  isolation: isolate;
  overflow: hidden;
}

h1,
h2 {
  font-family: Georgia, "Times New Roman", serif;
  font-weight: 500;
  letter-spacing: 0;
  margin: 0;
}

h1 {
  color: var(--forest);
  font-size: clamp(4.8rem, 11vw, 11rem);
  line-height: 0.82;
}

h2 {
  color: #161b17;
  font-size: clamp(3rem, 6vw, 6.6rem);
  line-height: 0.95;
}

h2 span {
  color: #6e9d82;
}

p {
  color: #354239;
  font-size: clamp(1rem, 1.3vw, 1.25rem);
  line-height: 1.65;
  margin: 0;
}

.hero-section {
  align-items: center;
  background:
    linear-gradient(rgba(255, 249, 236, 0.05), rgba(255, 249, 236, 0.05)),
    url("assets/hero image.png") center / cover no-repeat;
  display: grid;
  min-height: 100svh;
  place-items: center;
  text-align: center;
}

.hero-section .tree,
.hero-section .mountain,
.hero-section .lake,
.hero-section .terrace,
.hero-section .bonsai,
.hero-section .leaf,
.hero-section .companion {
  display: none;
}

.hero-copy {
  display: grid;
  gap: 1.6rem;
  justify-items: center;
  margin-top: -5vh;
  max-width: 47rem;
  padding: 2rem;
  position: relative;
  z-index: 5;
}

.tagline {
  color: #17261f;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.45rem, 2.4vw, 2.25rem);
  line-height: 1.1;
}

.intro {
  max-width: 28rem;
}

.bn46 {
  display: block;
  height: 3.4rem;
  width: auto;
}

.mountain {
  background: linear-gradient(135deg, rgba(95, 135, 127, 0.2), rgba(255, 255, 255, 0.5));
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
  filter: blur(0.2px);
  position: absolute;
}

.m1 {
  height: 46vh;
  left: 0;
  opacity: 0.58;
  top: 26vh;
  width: 37vw;
}

.m2 {
  height: 58vh;
  opacity: 0.62;
  right: 14vw;
  top: 20vh;
  width: 34vw;
}

.m3 {
  height: 44vh;
  opacity: 0.45;
  right: -7vw;
  top: 28vh;
  width: 30vw;
}

.lake {
  background:
    radial-gradient(ellipse at center, rgba(255, 255, 255, 0.72), transparent 44%),
    linear-gradient(90deg, rgba(113, 171, 178, 0.38), rgba(255, 255, 255, 0.62), rgba(116, 166, 172, 0.34));
  border-radius: 50%;
  bottom: 13vh;
  height: 24vh;
  left: 12vw;
  position: absolute;
  width: 76vw;
}

.terrace {
  background:
    linear-gradient(90deg, rgba(83, 55, 31, 0.22) 1px, transparent 1px) 0 0 / 7rem 100%,
    linear-gradient(180deg, #efd49d, #b48654);
  bottom: 0;
  box-shadow: 0 -1rem 3rem rgba(98, 80, 44, 0.18);
  height: 16vh;
  position: absolute;
  width: 100%;
}

.tree {
  position: absolute;
  z-index: 3;
}

.tree-left {
  height: 52vh;
  left: -4vw;
  top: -5vh;
  transform: rotate(11deg);
  width: 34vw;
}

.tree-right {
  height: 34vh;
  right: -3vw;
  top: 2vh;
  width: 24vw;
}

.tree::before {
  background: linear-gradient(80deg, #4b3326, #80613c);
  border-radius: 48% 30% 40% 40%;
  content: "";
  height: 78%;
  left: 10%;
  position: absolute;
  top: -4%;
  transform: rotate(26deg);
  width: 11%;
}

.tree span {
  background: radial-gradient(circle, #7f944f 0 38%, #405a32 78%);
  border-radius: 50%;
  display: block;
  filter: blur(0.2px);
  height: 42%;
  position: absolute;
  width: 38%;
}

.tree span:nth-child(1) { left: 6%; top: 0; }
.tree span:nth-child(2) { left: 24%; top: 5%; }
.tree span:nth-child(3) { left: 39%; top: 0; }
.tree span:nth-child(4) { left: 16%; top: 17%; }

.bonsai {
  background: radial-gradient(circle at 40% 35%, #75873e 0 20%, transparent 21%), radial-gradient(circle at 60% 42%, #506a38 0 18%, transparent 19%), #7b573b;
  border-radius: 40% 40% 12% 12%;
  bottom: 6.5vh;
  height: 8rem;
  left: 8vw;
  opacity: 0.85;
  position: absolute;
  width: 10rem;
  z-index: 2;
}

.leaf {
  background: #79a96c;
  border-radius: 100% 0;
  height: 1.1rem;
  position: absolute;
  transform: rotate(24deg);
  width: 2.2rem;
  z-index: 6;
}

.leaf-a { right: 27vw; top: 26vh; }
.leaf-b { left: 18vw; top: 43vh; transform: rotate(-36deg); }

.companion {
  height: 16rem;
  position: absolute;
  width: 15rem;
  z-index: 6;
}

.companion-meditating {
  bottom: 13vh;
  right: 21vw;
}

.body {
  background:
    radial-gradient(circle at 50% 20%, #fff0d2 0 20%, transparent 21%),
    radial-gradient(circle at 30% 64%, #6e9177 0 8%, transparent 9%),
    radial-gradient(circle at 72% 58%, #6e9177 0 8%, transparent 9%),
    linear-gradient(150deg, #b9d0ad, #59836e);
  border-radius: 46% 46% 38% 38%;
  bottom: 1.6rem;
  box-shadow: inset 0 -1.4rem 2rem rgba(42, 70, 54, 0.22), 0 1rem 2rem var(--shadow);
  height: 11.5rem;
  left: 2.2rem;
  position: absolute;
  width: 10.2rem;
}

.face {
  background: #fff1d8;
  border-radius: 48% 48% 42% 42%;
  height: 6.2rem;
  left: 3.9rem;
  position: absolute;
  top: 2.6rem;
  width: 7.1rem;
  z-index: 3;
}

.face::after {
  background: #8c6b4b;
  border-radius: 0 0 2rem 2rem;
  content: "";
  height: 0.24rem;
  left: 3rem;
  position: absolute;
  top: 3.85rem;
  width: 1.05rem;
}

.face.happy::after {
  height: 0.75rem;
  left: 2.72rem;
  top: 3.7rem;
  width: 1.55rem;
}

.face i {
  background: #28362b;
  border-radius: 50%;
  height: 0.72rem;
  position: absolute;
  top: 2.55rem;
  width: 0.72rem;
}

.face i:first-child { left: 2.1rem; }
.face i:last-child { right: 2.1rem; }

.ear {
  background: linear-gradient(140deg, #7fa48d, #496e5d);
  border-radius: 80% 0 80% 20%;
  height: 3.6rem;
  position: absolute;
  top: 3.2rem;
  width: 4.8rem;
  z-index: 1;
}

.ear-left { left: 1rem; transform: rotate(-18deg); }
.ear-right { right: 1rem; transform: scaleX(-1) rotate(-18deg); }

.horn {
  border: solid #dba652;
  border-width: 0.42rem 0.42rem 0 0;
  height: 3.8rem;
  position: absolute;
  top: 0.7rem;
  width: 2.3rem;
  z-index: 5;
}

.horn-left {
  border-radius: 0 100% 0 0;
  left: 4rem;
  transform: rotate(-36deg);
}

.horn-right {
  border-radius: 0 100% 0 0;
  right: 4rem;
  transform: scaleX(-1) rotate(-36deg);
}

.feet {
  background: radial-gradient(circle, #fff0d2 0 45%, transparent 47%) 1rem 0 / 4rem 2.5rem no-repeat, radial-gradient(circle, #fff0d2 0 45%, transparent 47%) 7.5rem 0 / 4rem 2.5rem no-repeat;
  bottom: 0.5rem;
  height: 2.5rem;
  left: 1.6rem;
  position: absolute;
  width: 12rem;
  z-index: 7;
}

.app-section,
.nutrition-section,
.progress-section {
  background:
    radial-gradient(circle at 58% 38%, rgba(255, 255, 255, 0.92), transparent 21rem),
    linear-gradient(135deg, #fff8ea, #f5eedf);
  display: grid;
  grid-template-columns: minmax(18rem, 0.8fr) minmax(30rem, 1.4fr);
  gap: 4vw;
  min-height: 100svh;
  padding: clamp(3rem, 7vw, 8rem);
}

.app-section {
  background:
    linear-gradient(rgba(255, 249, 236, 0.04), rgba(255, 249, 236, 0.04)),
    url("assets/section 3 image.png") center / cover no-repeat;
}

.nutrition-section {
  background:
    linear-gradient(rgba(255, 249, 236, 0.04), rgba(255, 249, 236, 0.04)),
    url("assets/section 2 image.png") center / cover no-repeat;
}

.progress-section {
  background:
    linear-gradient(rgba(255, 249, 236, 0.04), rgba(255, 249, 236, 0.04)),
    url("assets/section 4 image.png") center / cover no-repeat;
}

.app-section .phone-wrap,
.nutrition-section .nutrition-art,
.progress-section .sun,
.progress-section .range,
.progress-section .path,
.progress-section .companion {
  display: none;
}

.copy-panel {
  align-self: center;
  display: grid;
  gap: 2rem;
  max-width: 36rem;
  position: relative;
  z-index: 5;
}

.copy-panel p {
  max-width: 25rem;
}

.scribble {
  color: #446759;
  font-family: "Bradley Hand", "Segoe Print", cursive;
  transform: rotate(-7deg);
}

.phone-wrap {
  align-self: center;
  min-height: 42rem;
  position: relative;
}

.phone {
  background: #171713;
  border: 0.55rem solid #25241f;
  border-radius: 3rem;
  box-shadow: 0 2.2rem 5rem rgba(49, 45, 34, 0.27);
  height: clamp(34rem, 47vw, 50rem);
  left: 24%;
  padding: 1rem;
  position: absolute;
  top: 0;
  transform: rotate(8deg);
  width: clamp(18rem, 24vw, 24rem);
  z-index: 4;
}

.speaker {
  background: #050505;
  border-radius: 1rem;
  height: 1.3rem;
  left: 50%;
  position: absolute;
  top: 1rem;
  transform: translateX(-50%);
  width: 6.8rem;
  z-index: 8;
}

.phone-screen {
  background: linear-gradient(180deg, #fffaf0, #f0e7d7);
  border-radius: 2.2rem;
  height: 100%;
  overflow: hidden;
  padding: 4.3rem 1.25rem 1rem;
  position: relative;
}

.phone-screen::before {
  background: linear-gradient(150deg, #e8d5bd, #fff5e5 45%, #cfe0d5);
  border-radius: 0 0 50% 50%;
  content: "";
  height: 10.5rem;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}

.phone-greeting {
  font-size: 0.85rem;
  line-height: 1.3;
  position: relative;
  z-index: 2;
}

.score-card {
  align-items: center;
  background: rgba(255, 255, 255, 0.68);
  border: 1px solid rgba(70, 88, 71, 0.12);
  border-radius: 1.4rem;
  box-shadow: 0 1rem 2rem rgba(54, 50, 40, 0.08);
  display: grid;
  justify-items: center;
  margin: 4.7rem auto 1rem;
  padding: 1rem;
  position: relative;
  width: 78%;
}

.score-card::before {
  border: 0.75rem solid rgba(102, 160, 136, 0.35);
  border-top-color: #5b9e87;
  border-radius: 50%;
  content: "";
  height: 8rem;
  position: absolute;
  top: -4rem;
  width: 8rem;
}

.score-card strong {
  font-family: Georgia, serif;
  font-size: 3.3rem;
  margin-top: 1.9rem;
}

.score-card span,
.metric em,
.macro span,
.milestone small {
  color: #58635b;
  font-size: 0.8rem;
  font-style: normal;
}

.metric {
  background: rgba(255, 255, 255, 0.72);
  border-radius: 0.8rem;
  display: grid;
  gap: 0.3rem;
  margin-top: 0.6rem;
  padding: 0.75rem;
}

.metric span {
  font-size: 0.85rem;
  font-weight: 700;
}

.metric b {
  background: linear-gradient(90deg, #6fa48c, #e7b858);
  border-radius: 1rem;
  display: block;
  height: 0.28rem;
}

.phone-nav {
  align-items: center;
  bottom: 1rem;
  display: flex;
  justify-content: space-around;
  left: 1rem;
  position: absolute;
  right: 1rem;
}

.phone-nav span {
  border: 1.5px solid #6f7a72;
  border-radius: 50%;
  height: 1rem;
  opacity: 0.65;
  width: 1rem;
}

.phone-nav .active {
  background: #6b9b82;
  border-color: #6b9b82;
  height: 2.6rem;
  opacity: 1;
  width: 2.6rem;
}

.mini-creature {
  background: #a7c5a7;
  border-radius: 48% 48% 40% 40%;
  height: 3.1rem;
  position: relative;
  width: 3.4rem;
  z-index: 2;
}

.mini-creature::before,
.mini-creature::after {
  background: #d79c42;
  border-radius: 50% 50% 0 0;
  content: "";
  height: 1.3rem;
  position: absolute;
  top: -0.85rem;
  width: 0.35rem;
}

.mini-creature::before { left: 0.95rem; transform: rotate(-22deg); }
.mini-creature::after { right: 0.95rem; transform: rotate(22deg); }

.companion-leaping {
  right: 2%;
  top: 9rem;
  transform: scale(1.55) rotate(9deg);
}

.companion-leaping .body::before {
  background: #fff0d2;
  border-radius: 2rem;
  content: "";
  height: 2rem;
  left: -2rem;
  position: absolute;
  top: 5rem;
  transform: rotate(-28deg);
  width: 4rem;
}

.companion-leaping .body::after {
  background: #fff0d2;
  border-radius: 2rem;
  content: "";
  height: 2rem;
  position: absolute;
  right: -2.2rem;
  top: 4.2rem;
  transform: rotate(24deg);
  width: 4rem;
}

.line-icon {
  border: 2px solid #7b9f8b;
  border-bottom: 0;
  border-right: 0;
  height: 2.4rem;
  transform: rotate(-35deg);
  width: 1.6rem;
}

.nutrition-art {
  align-self: center;
  aspect-ratio: 1 / 1;
  min-height: 34rem;
  position: relative;
}

.orbit {
  border: 0.24rem solid rgba(217, 165, 72, 0.44);
  border-left-color: transparent;
  border-radius: 50%;
  height: 78%;
  left: 10%;
  position: absolute;
  top: 10%;
  width: 78%;
}

.orbit-two {
  border-color: rgba(114, 155, 126, 0.32);
  border-bottom-color: transparent;
  height: 66%;
  left: 16%;
  top: 16%;
  width: 66%;
}

.bowl {
  background:
    radial-gradient(circle at 22% 60%, #5f914b 0 12%, transparent 13%),
    radial-gradient(circle at 38% 45%, #b9d676 0 13%, transparent 14%),
    radial-gradient(circle at 55% 48%, #ead7a4 0 15%, transparent 16%),
    radial-gradient(circle at 72% 55%, #7d2f56 0 14%, transparent 15%),
    radial-gradient(circle at 58% 70%, #d86f44 0 15%, transparent 16%),
    #f1dec4;
  border: 0.75rem solid #7e654e;
  border-radius: 50%;
  box-shadow: inset 0 -2rem 4rem rgba(79, 48, 30, 0.16), 0 2.5rem 4rem var(--shadow);
  height: 48%;
  left: 26%;
  position: absolute;
  top: 26%;
  width: 48%;
  z-index: 3;
}

.peeking {
  left: 50%;
  position: absolute;
  top: -3.1rem;
  transform: translateX(-50%) scale(1.7);
}

.food {
  border-radius: 50%;
  position: absolute;
}

.macro {
  align-items: center;
  background: rgba(255, 255, 255, 0.76);
  border: 2px solid rgba(142, 169, 104, 0.45);
  border-radius: 50%;
  box-shadow: 0 1rem 2rem rgba(49, 57, 42, 0.08);
  display: grid;
  height: 7.4rem;
  justify-items: center;
  padding: 1.35rem 1rem;
  position: absolute;
  width: 7.4rem;
  z-index: 5;
}

.macro strong {
  font-size: 1.6rem;
}

.macro-cal { left: 18%; top: 6%; border-color: rgba(226, 132, 72, 0.42); }
.macro-protein { right: 14%; top: 18%; border-color: rgba(127, 166, 89, 0.48); }
.macro-carbs { bottom: 15%; left: 16%; border-color: rgba(224, 178, 77, 0.48); }
.macro-fat { bottom: 12%; right: 16%; border-color: rgba(132, 166, 134, 0.48); }

.sun {
  background: radial-gradient(circle, #e99167, #f3b07c);
  border-radius: 50%;
  height: clamp(15rem, 22vw, 26rem);
  opacity: 0.9;
  position: absolute;
  right: 12vw;
  top: 11vh;
  width: clamp(15rem, 22vw, 26rem);
  z-index: -1;
}

.range {
  clip-path: polygon(0 82%, 16% 58%, 28% 70%, 40% 42%, 56% 68%, 70% 36%, 88% 62%, 100% 42%, 100% 100%, 0 100%);
  position: absolute;
  right: -2vw;
  width: 72vw;
}

.range-back {
  background: #d8ded7;
  bottom: 17vh;
  height: 44vh;
}

.range-mid {
  background: #bdccc0;
  bottom: 8vh;
  height: 43vh;
  opacity: 0.82;
  transform: translateX(-7vw);
}

.range-front {
  background: #93a78f;
  bottom: 0;
  height: 34vh;
  opacity: 0.88;
}

.path {
  background:
    linear-gradient(115deg, transparent 0 42%, #e7d7ba 43% 56%, transparent 57%),
    linear-gradient(115deg, transparent 0 49%, rgba(255, 255, 255, 0.74) 50% 54%, transparent 55%);
  bottom: 0;
  height: 55vh;
  position: absolute;
  right: 0;
  width: 70vw;
  z-index: 3;
}

.path::after {
  background: linear-gradient(115deg, transparent 0 46%, #fff0cf 47% 53%, transparent 54%);
  content: "";
  inset: 0;
  position: absolute;
}

.milestone {
  background: rgba(255, 255, 255, 0.7);
  border-radius: 1.25rem;
  box-shadow: 0 1rem 2rem rgba(49, 57, 42, 0.1);
  color: #68715f;
  font-size: 1.05rem;
  font-weight: 700;
  padding: 0.85rem 1.05rem;
  position: absolute;
  z-index: 4;
}

.m-day { bottom: 7%; left: 45%; }
.m-week { bottom: 25%; left: 60%; }
.m-month { bottom: 43%; left: 72%; }
.m-year { bottom: 61%; left: 78%; }

.stamp {
  border: 3px solid #e48e6d;
  border-radius: 1rem;
  height: 4rem;
  position: relative;
  width: 4rem;
}

.stamp::after {
  border: solid #d97b59;
  border-width: 0 0 2px 2px;
  content: "";
  height: 1.7rem;
  left: 1.25rem;
  position: absolute;
  top: 0.9rem;
  transform: rotate(-35deg);
  width: 1.05rem;
}

.companion-walking {
  bottom: 11vh;
  right: 43vw;
  transform: scale(0.9);
  z-index: 5;
}

.backpack {
  background: #8c6440;
  border-radius: 1rem;
  height: 4rem;
  left: 1.7rem;
  position: absolute;
  top: 7.5rem;
  transform: rotate(-15deg);
  width: 3.4rem;
  z-index: 6;
}

.footer-bar {
  align-items: center;
  background: #10241b;
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 2rem;
  justify-content: center;
  min-height: 4.5rem;
  padding: 1.25rem;
}

.footer-bar a {
  color: rgba(255, 255, 255, 0.82);
  font-size: 0.95rem;
  text-decoration: none;
}

.footer-bar a:hover {
  color: white;
}

.legal-page main {
  background:
    radial-gradient(circle at 85% 12%, rgba(231, 184, 88, 0.18), transparent 22rem),
    linear-gradient(180deg, var(--cream), var(--paper));
  min-height: 100vh;
  overflow: visible;
}

.legal-hero {
  display: grid;
  gap: 1rem;
  margin: 0 auto;
  max-width: 58rem;
  padding: clamp(3rem, 8vw, 6rem) 1.5rem 2rem;
}

.legal-hero h1 {
  color: var(--forest);
  font-size: clamp(3rem, 7vw, 6.8rem);
  line-height: 0.92;
}

.legal-hero p {
  max-width: 42rem;
}

.back-link,
.legal-content a {
  color: var(--forest);
  font-weight: 700;
  text-decoration-thickness: 0.08em;
  text-underline-offset: 0.22em;
}

.back-link {
  justify-self: start;
  text-decoration: none;
}

.legal-kicker {
  color: var(--clay);
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.legal-content {
  display: grid;
  gap: 2.5rem;
  margin: 0 auto;
  max-width: 58rem;
  padding: 1rem 1.5rem clamp(4rem, 8vw, 6rem);
}

.legal-content section {
  border-top: 1px solid rgba(49, 91, 72, 0.18);
  display: grid;
  gap: 0.85rem;
  padding-top: 1.5rem;
}

.legal-content h2,
.legal-content h3 {
  color: var(--ink);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  letter-spacing: 0;
  margin: 0;
}

.legal-content h2 {
  font-size: clamp(1.45rem, 2.4vw, 2rem);
  line-height: 1.2;
}

.legal-content h3 {
  color: var(--forest);
  font-size: 1rem;
  line-height: 1.35;
  margin-top: 0.45rem;
}

.legal-content p,
.legal-content li,
.legal-content dd {
  color: #354239;
  font-size: 1rem;
  line-height: 1.7;
}

.legal-content ul {
  margin: 0;
  padding-left: 1.25rem;
}

.legal-content li + li {
  margin-top: 0.35rem;
}

.legal-content dl {
  display: grid;
  gap: 0.75rem;
  margin: 0;
}

.legal-content dl div {
  display: grid;
  gap: 0.15rem;
}

.legal-content dt {
  color: var(--forest);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.legal-content dd {
  margin: 0;
}

@media (max-width: 980px) {
  .app-section,
  .nutrition-section,
  .progress-section {
    grid-template-columns: 1fr;
    min-height: auto;
    padding: 4rem 1.5rem;
  }

  .copy-panel {
    max-width: 100%;
  }

  .phone-wrap {
    min-height: 39rem;
  }

  .phone {
    left: 10%;
  }

  .companion-leaping {
    right: 8%;
    transform: scale(1.05) rotate(9deg);
  }

  .nutrition-art {
    min-height: 30rem;
  }

  .progress-section {
    min-height: 52rem;
  }

  .range,
  .path {
    width: 100vw;
  }

  .companion-walking {
    right: 44vw;
  }
}

@media (max-width: 640px) {
  h1 {
    font-size: clamp(4rem, 22vw, 6rem);
  }

  h2 {
    font-size: clamp(2.8rem, 13vw, 4rem);
  }

  .hero-copy {
    margin-top: -16vh;
  }

  .tree-left {
    height: 34vh;
    width: 58vw;
  }

  .tree-right,
  .bonsai {
    display: none;
  }

  .companion-meditating {
    bottom: 10vh;
    right: 5vw;
    transform: scale(0.72);
  }

  .phone-wrap {
    min-height: 34rem;
  }

  .phone {
    height: 31rem;
    left: 0;
    width: 17rem;
  }

  .companion-leaping {
    right: -3rem;
    top: 8rem;
    transform: scale(0.72) rotate(9deg);
  }

  .nutrition-art {
    min-height: 25rem;
  }

  .macro {
    height: 5.7rem;
    width: 5.7rem;
  }

  .macro strong {
    font-size: 1.2rem;
  }

  .macro span {
    font-size: 0.7rem;
  }

  .progress-section {
    min-height: 48rem;
  }

  .sun {
    right: -4rem;
    top: 16rem;
  }

  .path {
    height: 36rem;
    width: 130vw;
  }

  .milestone {
    font-size: 0.86rem;
  }

  .m-day { left: 35%; }
  .m-week { left: 54%; }
  .m-month,
  .m-year { left: 66%; }

  .companion-walking {
    bottom: 8rem;
    right: 45vw;
    transform: scale(0.62);
  }

  .footer-bar {
    align-content: center;
    flex-direction: column;
    gap: 0.75rem;
  }
}
