:root {
  /* Colors */
  --color-yellow: hsl(47, 88%, 63%);
  --color-white: hsl(0, 0%, 100%);
  --color-gray-500: hsl(0, 0%, 42%);
  --color-gray-950: hsl(0, 0%, 7%);

  /* Typography Base */
  --font-family: "Figtree", sans-serif;
  --line-height: 150%;
  --letter-spacing: 0px;

  /* Font Weights */
  --fw-medium: 500;
  --fw-black: 800;
  
  /* Text Presets (Typography Values) */
  /* Preset 1 - Main Title */
  --fs-preset-1: 1.5rem;   /* 24px */
  --fw-preset-1: var(--fw-black);

  /* Preset 2 - Body Text */
  --fs-preset-2: 1rem;     /* 16px */
  --fw-preset-2: var(--fw-medium);

  /* Preset 3 - Small Text (Date/Author) */
  --fs-preset-3: 0.875rem; /* 14px */
  --fw-preset-3: var(--fw-medium);
  --fw-preset-3-bold: var(--fw-black);

  /* Spacing Scale */
  --space-50: 0.25rem;  /* 4px */
  --space-100: 0.5rem;  /* 8px */
  --space-150: 0.75rem; /* 12px */
  --space-200: 1rem;    /* 16px */
  --space-300: 1.5rem;  /* 24px */
  --space-400: 2rem;    /* 32px */

  /* Utils */
  --radius-lg: 1.25rem; /* 20px */
  --radius-sm: 0.25rem; /* 4px */
  --shadow: 8px 8px 0px var(--color-gray-950);

  /* Animation & Motion */
  --transition-duration: 0.2s;
  --transition-easing: ease;
  --transform-lift: translate(-4px, -4px);
  --shadow-hover: 12px 12px 0px var(--color-gray-950);
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  min-height: 100vh;
  font-family: var(--font-family);
  font-size: var(--fs-preset-2);
  background-color: var(--color-yellow);
  line-height: var(--line-height);
}

a {
  text-decoration: none;
  color: inherit;
}

img {
  max-width: 100%;
  display: block; 
}

ul {
  list-style: none;
}

/* Typography Utility Classes */
.text-preset-1 {
  font-size: var(--fs-preset-1);
  font-weight: var(--fw-preset-1);
  letter-spacing: var(--letter-spacing);
  color: var(--color-gray-950);
}

.text-preset-2 {
  font-size: var(--fs-preset-2);
  font-weight: var(--fw-preset-2);
  color: var(--color-gray-500);
}

.text-preset-3 {
  font-size: var(--fs-preset-3);
  font-weight: var(--fw-preset-3);
  color: var(--color-gray-950);
}

.text-preset-3-bold {
  font-size: var(--fs-preset-3);
  font-weight: var(--fw-preset-3-bold);
  color: var(--color-gray-950);
}

.wrapper {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  min-height: 100dvh;
  padding: var(--space-300);
}

.card {
  background-color: var(--color-white);
  width: min(100%, 24rem);
  padding: var(--space-300);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-gray-950);
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
  gap: var(--space-300);
}

.card:hover {
  transform: var(--transform-lift);
  box-shadow: var(--shadow-hover);
}

.card__image a {
  display: block;
  overflow: hidden;
  border-radius: var(--radius-sm);
}

.card__image img {
  width: 100%;
  display: block;
  border-radius: var(--radius-sm);
}

.card__image a:hover img {
  transform: scale(1.05);
  filter: brightness(1.05);
}

.card__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-150);
}

.badge {
  background-color: var(--color-yellow);
  border-radius: var(--radius-sm);
  display: inline-block;
  width: fit-content;
  overflow: hidden;
}

.badge a {
  display: block;
  padding: var(--space-50) var(--space-150);
}

.badge a:hover,
.badge a:focus {
  transform: translateY(-1px);
  opacity: 0.8;
}

.title a {
  display: block;
}

.title a:hover,
.title a:focus {
  color: var(--color-yellow);
}

.title a:focus-visible {
  outline: 2px dashed var(--color-gray-950);
  outline-offset: 4px;
  border-radius: 2px;
}

.card__author {
  display: flex;
  align-items: center;
  gap: var(--space-150);
}

.card__author img {
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  display: block;
}

.card__author-name {
  line-height: 1;
}

.card__author-name a:hover {
  color: var(--color-yellow);
}

.author__link {
  display: flex;
  border-radius: 50%;
  outline: none;
}

.author__link:hover,
.author__link:focus {
  filter: brightness(1.1);
  transform: scale(1.05);
}

.author__link:focus-visible {
  outline: 2px dashed var(--color-gray-950);
  outline-offset: 4px;
}

@media (prefers-reduced-motion: no-preference) {
  * {
    transition-duration: var(--transition-duration);
    transition-timing-function: var(--transition-easing);
  }

  a, .card, .badge a {
    transition-property: color, transform, box-shadow, opacity, filter;
  }

  .card__image img {
    transition: transform 0.3s ease;
  }
}
