/*
COLOR PALETTE

Dark green    #3c8453
Sandy beige   #bcaa96
Dark gray     #222222
Light gray    #d3d4d6
Off-white     #f6f6f6
*/
/*Custom Properties*/
:root {
  /*Base neutral color*/
  --color-neutral: oklch(85% 0.01 240); /*Light gray base*/

  /*9 shades using relative color*/
  --color-neutral-100: oklch(from var(--color-neutral) 98% c h);
  --color-neutral-200: oklch(from var(--color-neutral) 95% c h);
  --color-neutral-300: oklch(from var(--color-neutral) 90% c h);
  --color-neutral-400: oklch(from var(--color-neutral) 85% c h);
  --color-neutral-500: oklch(from var(--color-neutral) 70% c h);
  --color-neutral-600: oklch(from var(--color-neutral) 55% c h);
  --color-neutral-700: oklch(from var(--color-neutral) 40% c h);
  --color-neutral-800: oklch(from var(--color-neutral) 25% c h);
  --color-neutral-900: oklch(from var(--color-neutral) 12% c h);

  /* Accent colors */
  --color-green: oklch(55.37% 0.1053 151.92);
  --color-beige: oklch(74.8% 0.0349 70.19);

  /*Custom Properties-Typography*/

  --font-body: "Open Sans", sans-serif;
  --font-heading: "Caveat", Cursive;
}

/* GLOBAL STYLES - MOBILE FIRST (0-34.313 rem)
------------------------------------*/
/* 
  https://www.paulirish.com/2012/box-sizing-border-box-ftw/
*/
html {
  box-sizing: border-box;
}
*,
*:before,
*:after {
  box-sizing: inherit;
}
html,
body {
  block-size: 100%;
}
/*Mobile first body styles*/
body {
  background: var(--color-neutral-100);
  margin: 0;
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.5rem;
}
/*Mobile first heading styles*/
h1,
h2,
h3 {
  font-family: var(--font-heading);
  font-weight: 400;
  margin-block: 0;
  margin-inline: 0;
}

/*Mobile first headings*/
h1 {
  font-size: 1.8rem;
  line-height: 1.1;
  font-weight: 700;
}
h2 {
  font-size: 1.5rem;
  line-height: 1.3;
  color: var(--color-green);
}
h3 {
  font-size: 1.5rem;
  line-height: 1.2;
}

/* links */
a {
  color: var(--color-green);
}

a:hover {
  color: var(--color-beige);
  text-decoration: none;
}
footer a {
  color: var(--color-beige);
}
footer a:hover {
  color: var(--color-green);
}

.btn {
  background: var(--color-green);
  color: var(--color-neutral-100);
  text-decoration: none;
  text-transform: uppercase;
  font-size: 1.2rem;
  display: inline-block;
  padding: 0.38rem;
  letter-spacing: 0.1em;
  line-height: 1;
  border-radius: 5px;
  transition: all 0.3s ease; /*Add smooth transiton*/
  transform-style: preserve-3d; /*Add 3d capability*/
}

.btn:hover {
  background: var(--color-beige);
  color: var(--color-neutral-900);
  transform: perspective(37.5rem) rotateX(10deg) translateY(-0.1875rem);
  box-shadow: 0 0.5rem 1rem oklch(55.37% 0.1053 151.92 / 0.3),
    0 0.25rem 0.5rem oklch(12% 0.01 240 / 0.2);
}

/*Mobile first content wrapper*/

.content-wrapper {
  margin-inline: auto;
  padding: 0.625rem;
  max-inline-size: 56.25rem;
}
/* Navigation Menu Styles - MOBILE FIRST */

.logo {
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--color-neutral-100);
  text-decoration: none;
  max-inline-size: 9rem;
  display: inline-block;
  animation: logoEntrance 0.8s ease-out;
  transition: all 0.3s ease;
}

.navWrap {
  position: sticky;
  inset-block-start: 0;
  z-index: 99;
  block-size: 3rem;
  inline-size: 100%;
  background-color: var(--color-neutral-900);
  border-block-end: 1px solid var(--color-neutral-300);
  box-shadow: 0 0.0625rem 0.5rem var(--color-neutral-800);
  padding-inline: 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

input#navToggle {
  display: none;
}

input#navToggle ~ label {
  position: relative;
  padding: 0.25rem;
  inline-size: 2rem;
  block-size: 2rem;
}

input#navToggle ~ label > span,
input#navToggle ~ label > span::before,
input#navToggle ~ label > span::after {
  content: "";
  display: block;
  position: absolute;
  inset-block-start: 0.75rem;
  block-size: 0.125rem;
  inline-size: 1.75rem;
  opacity: 1;
  background: var(--color-neutral-100);
  transition: 0.14s ease-in-out;
}

input#navToggle ~ label > span::before {
  inset-block-start: -0.5rem;
}

input#navToggle ~ label > span::after {
  inset-block-start: 0.5rem;
}

#navToggle:checked ~ label > span {
  inline-size: 0;
  background: transparent;
}

#navToggle:checked ~ label > span::before {
  transform: rotateZ(45deg);
  inset-block-start: 0;
}

#navToggle:checked ~ label > span::after {
  transform: rotateZ(-45deg);
  inset-block-start: 0;
}

#navToggle:checked ~ nav {
  inset-inline-start: 0;
}

nav {
  position: absolute;
  z-index: -1;
  inset-block-start: 3rem;
  inset-inline-start: -110%;
  inline-size: 100%;
  transition: 0.22s ease-in-out;
}

nav::after {
  content: "";
  position: absolute;
  inset-block-start: 0;
  z-index: -1;
  block-size: 100vh;
  inline-size: 100vw;
  background-color: var(--color-green);
  background-size: cover;
}

nav ul {
  list-style-type: none;
  padding-block: 0;
  padding-inline: 0;
  margin-block: 0;
  margin-inline: 0;
}

nav ul li a {
  display: inline-block;
  text-decoration: none;
  inline-size: 100%;
  padding: 0.75rem 1rem;
  color: var(--color-neutral-100);
  border-block-end: solid 1px oklch(from var(--color-neutral-100) l c h / 0.5);
  position: relative;
  transition: color 0.3s ease;
}

nav ul li a:hover {
  color: var(--color-beige);
  background: var(--color-neutral-300);
}

/*new slider underline effect*/
nav ul li a::after {
  content: "";
  position: absolute;
  inset-block-end: 0;
  inset-inline-start: 0;
  inline-size: 0;
  block-size: 0.125rem;
  background: var(--color-beige);
  transition: inline-size 0.3s ease;
}

nav ul li a:hover::after {
  inline-size: 100%;
}

nav ul li:last-of-type::before {
  content: "";
  display: block;
  padding-block: 0.5rem;
  padding-inline: 0.5rem;
}

nav .btn {
  background: var(--color-green);
  color: var(--color-neutral-100);
  border-block-end: none;
  border-radius: 0.25rem;
  padding: 0.75rem 1rem;
  inline-size: 100%;
  text-align: center;
  display: block;
  text-transform: none;
  font-size: inherit;
  letter-spacing: normal;
}

nav .btn:hover {
  background-color: var(--color-beige);
  color: var(--color-neutral-900);
}

/* Active page link */
nav ul li a.active {
  color: var(--color-beige);
  font-weight: 700;
}

/* TABLET/DESKTOP - Large screen navigation - 68rem and up */

@media (min-width: 68rem) {
  .navWrap {
    display: grid;
    grid-template-columns: 6.25rem minmax(auto, 68.75rem);
    justify-content: center;
    block-size: auto;
  }

  .navToggleLabel {
    display: none;
  }

  nav {
    position: initial;
  }

  nav ul {
    display: flex;
    justify-content: flex-end;
    align-items: center;
  }

  nav ul li a {
    border-block-end: none;
  }

  nav ul li a:hover {
    background: transparent;
  }

  nav::after,
  nav ul li:last-of-type::before {
    display: none;
    padding: initial;
  }

  nav .btn {
    inline-size: auto;
    padding: 0.5rem 1.5rem;
    anchor-name: --contact-anchor; /*creating contact popover anchor*/
  }

  nav .btn:hover {
    background-color: var(--color-beige);
    color: var(--color-neutral-900);
  }
  nav button.btn {
    background: var(--color-green);
    color: var(--color-neutral-100);
    font-family: inherit;
    border: none;
    cursor: pointer;
  }

  nav button.btn:hover {
    background-color: var(--color-beige);
    color: var(--color-neutral-900);
  }
}
/* HOME mobile first
------------------------------------*/
.home {
  background: url(../images/bg-creative-bw.jpg) no-repeat;
  background-size: cover;
  display: flex;
  flex-direction: column;
}
.home .content-wrapper {
  flex: 1 0 auto;
  padding: 0.625rem; /*mobile padding*/
}
.content-bg {
  background: oklch(from var(--color-neutral-100) l c h / 0.9);
  padding: 1.25rem; /*mobile padding*/
}

/* RESUME
------------------------------------*/
.resume header::before {
  background: url(../images/bg-creative-bw.jpg) center;
  background-size: cover;
  content: "";
  display: block;
  block-size: 12.5rem; /*mobile height*/
}
.resume-section {
  margin-block-end: 3.125rem;
}
.resume-section h2 {
  border-block-end: 2px dashed var(--color-neutral-300);
}

/* Profile */
/* No additional styles needed - uses resume-section base styles */

/*Projects
------------------------------------*/

.projects-grid {
  display: grid;
  grid-template-columns: 1fr; /*Mobile:1 column*/
  grid-auto-rows: min-content;
  gap: 1.5rem;
  margin-block-start: 2rem;
}

.project-card {
  display: grid;
  grid-template-rows: subgrid; /* Add subgrid */
  grid-row: span 5; /* Span 5 rows: img, h3, p, p, button */
  align-content: start;
  background: var(--color-neutral-100);
  padding: 1.5rem;
  border-radius: 0.5rem;
  border: 1px solid var(--color-neutral-300);
  box-shadow: 0 0.125rem 0.25rem
    oklch(from var(--color-neutral-900) l c h / 0.1);
}

.project-card h3 {
  margin-block-start: 0;
  margin-block-end: 0;
  color: var(--color-neutral-800);
}

.project-card img {
  inline-size: 100%;
  block-size: auto;
  margin-block-end: 0;
  border-radius: 0.25rem;
}

.project-card p {
  margin-block-end: 0;
  color: var(--color-neutral-800);
}

.project-card p:last-of-type {
  margin-block-end: 0;
}

/* Tablet Styles - 34rem and up (550px+) */
@media (min-width: 34rem) {
  .projects-grid {
    grid-template-columns: repeat(2, 1fr); /*2 columns on tablet*/
    grid-template-rows: repeat(auto-fill, auto); /* Auto rows */
    gap: 2rem;
  }
}

/* Laptop Styles - 68rem and up (1100px+) */
@media (min-width: 68rem) {
  .projects-grid {
    grid-template-columns: repeat(3, 1fr); /*3 columns on desktop*/
    grid-template-rows: repeat(auto-fill, auto); /* Auto rows */
    gap: 2rem;
  }
}
/* Work Experience */
.work-item {
  margin-block: 1.875rem 0;
}

.work-details p {
  margin-block: 0;
  margin-inline: 0;
}

/* Education */
.education-item {
  margin-block: 1.875rem 0;
}
.education-item p {
  margin-block: 0;
  margin-inline: 0;
}

/* FOOTER - MOBILE FIRST
------------------------------------*/
footer {
  background: var(--color-neutral-900);
  color: var(--color-neutral-300);
  text-align: center; /*mobile default*/
  padding: 0.625rem; /*mobile padding*/
}
.socials {
  list-style-type: none;
  padding-block: 0;
  padding-inline: 0;
}
.socials li {
  display: inline-block;
  margin-inline-start: 0.625rem;
}
.socials img {
  inline-size: 2.188rem;
}
.socials img:hover {
  opacity: 0.5;
}

/* CONTACT-POPOVER
------------------------------------*/
/*Base Styles*/
#contact-popover {
  position: fixed;
  inset-block-start: 50%;
  inset-inline-start: 50%;
  translate: -50% -50%;
  margin-block: 0;
  margin-inline: 0;

  /*Query Setup*/
  container-type: inline-size;
  container-name: contact-card;

  /*Responsive Width Setup_asked AI for help with this*/
  inline-size: clamp(18.75rem, 45vw, 33.3vw);
  max-inline-size: 93vw;

  /*Style to Match Site*/
  background-color: var(--color-neutral-100);
  border: 2px solid var(--color-green);
  border-radius: 1rem;
  box-shadow: 0 0.625rem 2rem oklch(from var(--color-neutral-900) l c h / 0.4),
    0 0.125rem 0.5rem oklch(from var(--color-green) l c h / 0.2); /*Layered shadow effect*/
  padding-block: 0;
  padding-inline: 0;
  overflow: hidden;
}

/*Backdrop*/
#contact-popover::backdrop {
  background-color: oklch(from var(--color-neutral-900) l c h / 0.75);
  backdrop-filter: blur(5px); /*I use px as blur radius is based on its radius*/
}

/* Popover Content Container */
.popover-content {
  display: grid;
  gap: 1.25rem;
  padding: 2.5rem 1.75rem 2rem;
}

/*Close button*/
.popover-close-btn {
  position: absolute;
  inset-block-start: 0.875rem;
  inset-inline-end: 0.875rem;
  background-color: var(--color-beige);
  color: var(--color-neutral-900);
  border: 2px solid var(--color-green);
  border-radius: 0.375rem;
  inline-size: 2.25rem;
  block-size: 2.25rem;
  cursor: pointer;
  font-size: 1.375rem;
  font-weight: 700;
  font-family: var(--font-heading);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.25s ease;
  z-index: 1;
}

.popover-close-btn:hover {
  background-color: var(--color-green);
  color: var(--color-neutral-100);
  transform: rotate(90deg);
}

/*Profile image_had trouble used some AI help to explain it*/
.popover-profile-img {
  inline-size: 100%;
  block-size: auto;
  aspect-ratio: 1 / 1;
  border-radius: 0.625rem;
  border: 4px solid var(--color-beige);
  object-fit: cover;
  box-shadow: 0 0.25rem 0.75rem
    oklch(from var(--color-neutral-800) l c h / 0.25);
}

.popover-image-container {
  display: flex;
  justify-content: center;
  align-items: flex-start;
}

/*Profile content*/
.popover-text-content h2 {
  font-family: var(--font-heading);
  color: var(--color-green);
  margin-block-end: 0.625rem;
  font-size: 2.25rem;
  line-height: 1.2;
}

.popover-bio {
  margin-block: 0.875rem 1.25rem;
  line-height: 1.65;
  color: var(--color-neutral-800);
  font-size: 0.9375rem;
}

.popover-contact-info {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  margin-block-start: 1.125rem;
  padding-block-start: 1rem;
  border-block-start: 2px dashed var(--color-neutral-300);
}

.popover-contact-info a {
  color: var(--color-green);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 0.625rem;
  font-size: 0.9375rem;
  transition: color 0.2s ease;
}

.popover-contact-info a:hover {
  color: var(--color-beige);
}

/*Container Query: Large (two columns with bio) - Over 540px*/
@container contact-card (inline-size > 33.75rem) {
  .popover-content {
    grid-template-columns: 2fr 3fr;
    align-items: flex-start;
    gap: 2rem;
    padding: 2.5rem 2rem;
  }

  .popover-profile-img {
    max-inline-size: 13.75rem;
  }

  .popover-bio {
    display: block;
  }

  .popover-text-content h2 {
    font-size: 2.5rem;
  }
}

/*Container Query: Medium (two columns without bio) - 380px to 540px*/
@container contact-card (inline-size > 23.75rem) and (inline-size <= 33.75rem) {
  #contact-popover {
    inline-size: clamp(22rem, 55vw, 30rem);
  }

  .popover-content {
    grid-template-columns: 2fr 3fr;
    align-items: flex-start;
    gap: 1.25rem;
    padding: 2rem 1.5rem;
  }

  .popover-profile-img {
    max-inline-size: 10rem;
  }

  .popover-bio {
    display: none;
  }

  .popover-text-content h2 {
    font-size: 1.875rem;
  }
}

/*Container Query: Small (stacked, full viewport) - Under 380px*/
@container contact-card (inline-size <= 23.75rem) {
  #contact-popover {
    inline-size: 100vw;
    block-size: 100vh;
    max-inline-size: 100vw;
    inset: 0;
    translate: 0;
    border-radius: 0;
    border-inline: none;
  }

  .popover-content {
    grid-template-columns: 1fr;
    block-size: 100%;
    padding: 3.5rem 1.25rem 2rem;
    overflow-y: auto;
    gap: 1.5rem;
  }

  .popover-profile-img {
    max-inline-size: 13.75rem;
  }

  .popover-bio {
    display: block;
  }

  .popover-close-btn {
    inset-block-start: 1rem;
    inset-inline-end: 1rem;
    inline-size: 2.75rem;
    block-size: 2.75rem;
    font-size: 1.5rem;
  }

  .popover-text-content h2 {
    font-size: 2rem;
  }
}

/*Logo animation on page load*/
@keyframes logoEntrance {
  0% {
    opacity: 0;
  }
  60% {
    transform: translateY(0.3125rem) scale(1.05);
  }
  100% {
    opacity: 1;
    transform: none;
  }
}

/* Logo Hover 3d effect - found example on prismic site */
.logo:hover {
  color: var(--color-beige);
  background: var(--color-green);
  padding: 0.25rem 0.5rem;
  border-radius: 0.25rem;
  transform: perspective(15rem) rotateY(25deg) scale(1.2);
}

/* PROJECT MANAGEMENT ANIMATIONS
------------------------------------*/

/* Animations Base Styles */
.animations-grid {
  display: grid;
  grid-template-columns: 1fr; /*mobile first 1 column*/
  gap: 2rem;
  margin-block-start: 2rem;
  margin-block-end: 3rem;
}

.animation-cell {
  background: var(--color-neutral-300);
  border-radius: 0.5rem;
  padding: 2rem;
  min-block-size: 18.75rem;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  position: relative;
}

/* Animation 1 - Progress tracking bars using clip path- based on chartscss code site*/
.pm-animation-1 {
  inline-size: 100%;
  max-inline-size: 18.75rem;
  block-size: 12.5rem;
  display: flex;
  flex-direction: column;
  justify-content: space-around;
  gap: 0.625rem;
}

.progress-bar {
  inline-size: 100%;
  block-size: 1.875em;
  background: var(--color-neutral-300);
  border-radius: 0.5rem;
  position: relative;
  overflow: hidden;
}
/* Using clip path to reveal progress */
.progress-bar::before {
  content: "";
  position: absolute;
  inset-block-start: 0;
  inset-inline-start: 0;
  inline-size: 100%;
  block-size: 100%;
  background: linear-gradient(90deg, var(--color-green), var(--color-beige));
  clip-path: inset(0 100% 0 0);
  animation: fillProgress 3s ease-in-out infinite;
}

.bar-1::before {
  animation-delay: 0s;
}

.bar-2::before {
  animation-delay: 0.3s;
}

.bar-3::before {
  animation-delay: 0.6s;
}

.bar-4::before {
  animation-delay: 0.9s;
}

@keyframes fillProgress {
  0%,
  100% {
    clip-path: inset(0 100% 0 0);
  }
  50% {
    clip-path: inset(0 0 0 0);
  }
}

/* ANIMATION 2: Workflow Transition (Filter)*/
.pm-animation-2 {
  inline-size: 12.5rem;
  block-size: 12.5rem;
  position: relative;
}

.workflow-shape {
  inline-size: 6.25rem;
  block-size: 6.25rem;
  background: var(--color-green);
  position: absolute;
  border-radius: 1rem;
  animation: workflowMove 5s ease-in-out infinite;
}

@keyframes workflowMove {
  0% {
    inset-block-start: 0;
    inset-inline-start: 0;
    border-radius: 1rem;
    filter: blur(0) brightness(1) hue-rotate(0deg);
    transform: rotate(0deg);
  }

  25% {
    inset-block-start: 0;
    inset-inline-start: 6.25rem;
    border-radius: 50%;
    filter: blur(0.125rem) brightness(1.2) hue-rotate(45deg);
    transform: rotate(90deg);
  }

  50% {
    inset-block-start: 6.25rem;
    inset-inline-start: 6.25rem;
    border-radius: 1rem;
    filter: blur(0.25rem) brightness(0.8) hue-rotate(90deg);
    transform: rotate(180deg);
  }

  75% {
    inset-block-start: 6.25rem;
    inset-inline-start: 0;
    border-radius: 50%;
    filter: blur(00.125rem) brightness(1.2) hue-rotate(135deg);
    transform: rotate(270deg);
  }

  100% {
    inset-block-start: 0;
    inset-inline-start: 0;
    border-radius: 1rem;
    filter: blur(0) brightness(1) hue-rotate(0deg);
    transform: rotate(360deg);
  }
}

/* ANIMATION 3: Team Collaboration (Blend Mode)*/
.pm-animation-3 {
  inline-size: 12.5rem;
  block-size: 12.5rem;
  position: relative;
}

.team-shape {
  position: absolute;
  inline-size: 6.25rem;
  block-size: 6.25rem;
  border-radius: 50%;
  mix-blend-mode: multiply;
}

.shape-1 {
  background: var(--color-green);
  inset-block-start: 0;
  inset-inline-start: 1.875rem;
  animation: teamMove1 4s ease-in-out infinite;
}

.shape-2 {
  background: var(--color-beige);
  inset-block-start: 3.125rem;
  inset-inline-start: 0;
  animation: teamMove2 4s ease-in-out infinite;
}

.shape-3 {
  background: oklch(65% 0.08 151.92);
  inset-block-start: 3.125rem;
  inset-inline-start: 4.375rem;
  animation: teamMove3 4s ease-in-out infinite;
}

@keyframes teamMove1 {
  0%,
  100% {
    transform: translate(0, 0) scale(1);
  }
  50% {
    transform: translate(1.25rem, 2.5rem) scale(1.1);
  }
}

@keyframes teamMove2 {
  0%,
  100% {
    transform: translate(0, 0) scale(1);
  }
  50% {
    transform: translate(2.5rem, -1.25rem) scale(0.9);
  }
}

@keyframes teamMove3 {
  0%,
  100% {
    transform: translate(0, 0) scale(1);
  }
  50% {
    transform: translate(-1.875rem, 0) scale(1.05);
  }
}

/* Tablet Styles - 34rem and up */
@media (min-width: 34rem) {
  .animations-grid {
    grid-template-columns: repeat(2, 1fr); /* 2 columns on tablet */
  }
}

/* Desktop Styles - 68rem and up */
@media (min-width: 68rem) {
  .animations-grid {
    grid-template-columns: repeat(3, 1fr); /* 3 columns on desktop */
  }
}

/* ===================================
   SVG PROJECT PAGE STYLES
   Original SVG by Jordan Wade
   https://codepen.io/jordanwade/pen/JjVEwP
   Adapted and modified for educational purposes
   =================================== */

/* SVG animation container */
.animation-container {
  background-color: var(--color-neutral-100);
  border-radius: 0.75rem;
  padding-block: 3rem;
  padding-inline: 2rem;
  box-shadow: 0 0.25rem 0.375rem
    oklch(from var(--color-neutral-900) l c h / 0.1);
  margin-block-end: 2rem;
  min-block-size: 25rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.svg-wrapper {
  position: relative;
  inline-size: 100%;
  max-inline-size: 41.875rem; /*670px*/
}

.svg-wrapper svg {
  inline-size: 100%;
  block-size: auto;
  display: block;
}

/* Individual Path Animations with Delays */
/* Left bracket top */
#path-1 {
  stroke: var(--color-green);
  animation: draw 4s ease-in-out 0.5s infinite;
}

/* Left bracket bottom */
#path-2 {
  stroke: var(--color-green);
  animation: draw 4s ease-in-out 1s infinite;
}

/* Right bracket top */
#path-3 {
  stroke: var(--color-green);
  animation: draw 4s ease-in-out 1.5s infinite;
}

/*Right bracket bottom*/
#path-4 {
  stroke: var(--color-beige);
  animation: draw 4s ease-in-out 2s infinite;
}

/* Outer circle */
#path-5 {
  stroke: var(--color-neutral-800);
  animation: draw 4.5s ease-in-out 12.5s infinite;
}

/* Inner circle */
#path-6 {
  stroke: var(--color-neutral-700);
  animation: draw 3s ease-in-out 2s infinite;
}

/* Draw Animation Keyframes */
@keyframes draw {
  0% {
    stroke-dashoffset: 300;
    opacity: 0;
  }
  50% {
    stroke-dashoffset: 0;
    opacity: 1;
  }
  100% {
    stroke-dashoffset: -300;
    opacity: 0;
  }
}

.svg-description .credit {
  font-size: 0.9rem;
  color: var(--color-neutral-600);
  font-style: italic;
  margin-block-start: 2rem;
}

.svg-description .credit a {
  color: var(--color-green);
  text-decoration: none;
}

.svg-description .credit a:hover {
  color: var(--color-beige);
  text-decoration: underline;
}

/* Responsive Adjustments */
@media (min-width: 34rem) {
  .animation-container {
    padding-block: 4rem;
    padding-inline: 3rem;
  }
}

@media (min-width: 68rem) {
  .animation-container {
    padding-block: 5rem;
    padding-inline: 4rem;
  }
} /* <-- This closes the media query */

/* BACK TO TOP BUTTON
------------------------------------*/
.back-to-top {
  position: fixed;
  inset-block-end: 1rem;
  inset-inline-end: 1rem;
  inline-size: 3rem;
  block-size: 3rem;
  background: var(--color-green);
  color: var(--color-neutral-100);
  border: none;
  border-radius: 50%;
  cursor: pointer;
  opacity: 0;
  visibility: hidden;
  transform: translateY(1.25rem);
  transition: all 0.3s ease;
  z-index: 98;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.75rem;
  font-weight: 700;
  box-shadow: 0 0.25rem 0.75rem oklch(from var(--color-neutral-900) l c h / 0.3);
}

.back-to-top.visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.back-to-top:hover {
  background: var(--color-beige);
  color: var(--color-neutral-900);
  transform: translateY(-0.25rem) scale(1.1);
  box-shadow: 0 0.5rem 1rem oklch(from var(--color-green) l c h / 0.4);
}

.back-to-top:active {
  transform: translateY(0) scale(0.95);
}

/* Arrow icon */
.back-to-top::before {
  content: "↑";
  line-height: 1;
}

/* Larger spacing on bigger screens */
@media (min-width: 48rem) {
  .back-to-top {
    inset-block-end: 2rem;
    inset-inline-end: 2rem;
  }
}
