.dino-cat-hub {
  --dino-bg: #fffaf1;
  --dino-bg-soft: #f7efe1;
  --dino-ink: #23180f;
  --dino-muted: #6f5b47;
  --dino-accent: #c46a2f;
  --dino-accent-dark: #7d3517;
  --dino-border: rgba(80, 48, 22, 0.16);

  color: var(--dino-ink);
  margin: 0 0 2rem;
}

.dino-cat-hub * {
  box-sizing: border-box;
}

.dino-cat-hero {
  position: relative;
  overflow: hidden;
  padding: clamp(1.25rem, 3vw, 2.5rem);
  margin: 0 0 1.5rem;
  border: 1px solid var(--dino-border);
  border-radius: 1.25rem;
  background:
    radial-gradient(circle at top left, rgba(196, 106, 47, 0.18), transparent 34rem),
    linear-gradient(135deg, #fffaf1 0%, #f2e1c8 100%);
  box-shadow: 0 18px 50px rgba(70, 42, 19, 0.08);
}

.dino-cat-kicker {
  display: inline-flex;
  width: fit-content;
  margin: 0 0 0.9rem;
  padding: 0.35rem 0.7rem;
  border-radius: 999px;
  background: rgba(196, 106, 47, 0.12);
  color: var(--dino-accent-dark);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.dino-cat-lead {
  font-size: clamp(1.05rem, 2vw, 1.25rem);
  line-height: 1.7;
  color: var(--dino-ink);
}

.dino-cat-hero p {
  max-width: 72ch;
  line-height: 1.75;
}

.dino-cat-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1.25rem;
}

.dino-cat-actions a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.65rem;
  padding: 0.7rem 1rem;
  border-radius: 999px;
  background: var(--dino-ink);
  color: #fff;
  font-weight: 800;
  text-decoration: none;
  box-shadow: 0 10px 24px rgba(35, 24, 15, 0.16);
  transition: transform 0.18s ease, background 0.18s ease;
}

.dino-cat-actions a:hover {
  transform: translateY(-2px);
  background: var(--dino-accent-dark);
}

.dino-cat-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  margin: 0 0 1.5rem;
}

.dino-cat-card {
  padding: 1.25rem;
  border: 1px solid var(--dino-border);
  border-radius: 1.1rem;
  background: #fff;
  box-shadow: 0 12px 30px rgba(70, 42, 19, 0.07);
}

.dino-cat-card span {
  display: inline-block;
  margin: 0 0 0.6rem;
  color: var(--dino-accent-dark);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.dino-cat-card h2 {
  margin: 0 0 0.75rem;
  font-size: clamp(1.15rem, 2vw, 1.45rem);
  line-height: 1.2;
}

.dino-cat-card p {
  color: var(--dino-muted);
  line-height: 1.65;
}

.dino-cat-card a {
  display: inline-flex;
  margin-top: 0.35rem;
  color: var(--dino-accent-dark);
  font-weight: 900;
  text-decoration-thickness: 0.08em;
  text-underline-offset: 0.18em;
}

.dino-cat-section {
  padding: clamp(1rem, 2.5vw, 1.6rem);
  margin: 0 0 1.5rem;
  border: 1px solid var(--dino-border);
  border-radius: 1.1rem;
  background: #fff;
}

.dino-cat-section h2 {
  margin-top: 0;
  margin-bottom: 0.75rem;
  font-size: clamp(1.25rem, 2.2vw, 1.75rem);
  line-height: 1.2;
}

.dino-cat-section p {
  line-height: 1.75;
  color: var(--dino-muted);
}

.dino-cat-section a {
  color: var(--dino-accent-dark);
  font-weight: 900;
  text-decoration-thickness: 0.08em;
  text-underline-offset: 0.18em;
}

.dino-cat-highlight {
  background:
    linear-gradient(135deg, rgba(196, 106, 47, 0.08), transparent 55%),
    var(--dino-bg);
}

.dino-cat-info-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.85rem;
}

.dino-cat-info-grid div {
  padding: 1rem;
  border: 1px solid var(--dino-border);
  border-radius: 0.9rem;
  background: rgba(255, 255, 255, 0.74);
}

.dino-cat-info-grid strong {
  display: block;
  margin-bottom: 0.35rem;
  color: var(--dino-ink);
  font-size: 1rem;
}

.dino-cat-info-grid p {
  margin: 0;
  font-size: 0.95rem;
}

@media (max-width: 900px) {
  .dino-cat-grid,
  .dino-cat-info-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 640px) {
  .dino-cat-hero,
  .dino-cat-section,
  .dino-cat-card {
    border-radius: 0.9rem;
  }

  .dino-cat-grid,
  .dino-cat-info-grid {
    grid-template-columns: 1fr;
  }

  .dino-cat-actions a {
    width: 100%;
  }
}

.dino-cat-hub--carnivore {
  --dino-bg: #fff6f1;
  --dino-bg-soft: #f7dfd3;
  --dino-ink: #24110d;
  --dino-muted: #6d4f45;
  --dino-accent: #b84022;
  --dino-accent-dark: #7f2114;
  --dino-border: rgba(127, 33, 20, 0.18);
}

.dino-cat-hub--carnivore .dino-cat-hero {
  background:
    radial-gradient(circle at top left, rgba(184, 64, 34, 0.22), transparent 34rem),
    linear-gradient(135deg, #fff7f1 0%, #efd1c2 100%);
}

.dino-carnivore-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
}

.dino-carnivore-list a {
  display: block;
  min-height: 100%;
  padding: 1rem;
  border: 1px solid var(--dino-border);
  border-radius: 0.95rem;
  background:
    linear-gradient(135deg, rgba(184, 64, 34, 0.08), transparent 60%),
    #fff;
  color: var(--dino-ink);
  text-decoration: none;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.dino-carnivore-list a:hover {
  transform: translateY(-2px);
  border-color: rgba(127, 33, 20, 0.34);
  box-shadow: 0 12px 28px rgba(80, 28, 18, 0.1);
}

.dino-carnivore-list strong {
  display: block;
  margin-bottom: 0.35rem;
  color: var(--dino-accent-dark);
  font-size: 1.05rem;
}

.dino-carnivore-list span {
  display: block;
  color: var(--dino-muted);
  line-height: 1.55;
}

.dino-cat-section h3 {
  margin: 1.15rem 0 0.35rem;
  color: var(--dino-ink);
  font-size: clamp(1.05rem, 1.7vw, 1.25rem);
  line-height: 1.3;
}

@media (max-width: 700px) {
  .dino-carnivore-list {
    grid-template-columns: 1fr;
  }
}

.dino-cat-hub--herbivore {
  --dino-bg: #f6fbf1;
  --dino-bg-soft: #e4efd8;
  --dino-ink: #162315;
  --dino-muted: #526448;
  --dino-accent: #6f8f32;
  --dino-accent-dark: #3f621f;
  --dino-border: rgba(63, 98, 31, 0.18);
}

.dino-cat-hub--herbivore .dino-cat-hero {
  background:
    radial-gradient(circle at top left, rgba(111, 143, 50, 0.22), transparent 34rem),
    linear-gradient(135deg, #f8fff1 0%, #dcebcf 100%);
}

.dino-herbivore-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
}

.dino-herbivore-list a {
  display: block;
  min-height: 100%;
  padding: 1rem;
  border: 1px solid var(--dino-border);
  border-radius: 0.95rem;
  background:
    linear-gradient(135deg, rgba(111, 143, 50, 0.08), transparent 60%),
    #fff;
  color: var(--dino-ink);
  text-decoration: none;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.dino-herbivore-list a:hover {
  transform: translateY(-2px);
  border-color: rgba(63, 98, 31, 0.34);
  box-shadow: 0 12px 28px rgba(35, 70, 20, 0.1);
}

.dino-herbivore-list strong {
  display: block;
  margin-bottom: 0.35rem;
  color: var(--dino-accent-dark);
  font-size: 1.05rem;
}

.dino-herbivore-list span {
  display: block;
  color: var(--dino-muted);
  line-height: 1.55;
}

@media (max-width: 700px) {
  .dino-herbivore-list {
    grid-template-columns: 1fr;
  }
}

.dino-cat-hub--omnivore {
  --dino-bg: #f7f4ff;
  --dino-bg-soft: #e7ddf7;
  --dino-ink: #20172b;
  --dino-muted: #5f536d;
  --dino-accent: #7a56a4;
  --dino-accent-dark: #56327f;
  --dino-border: rgba(86, 50, 127, 0.18);
}

.dino-cat-hub--omnivore .dino-cat-hero {
  background:
    radial-gradient(circle at top left, rgba(122, 86, 164, 0.22), transparent 34rem),
    linear-gradient(135deg, #fbf8ff 0%, #e5d8f2 100%);
}

.dino-omnivore-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
}

.dino-omnivore-list a {
  display: block;
  min-height: 100%;
  padding: 1rem;
  border: 1px solid var(--dino-border);
  border-radius: 0.95rem;
  background:
    linear-gradient(135deg, rgba(122, 86, 164, 0.08), transparent 60%),
    #fff;
  color: var(--dino-ink);
  text-decoration: none;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.dino-omnivore-list a:hover {
  transform: translateY(-2px);
  border-color: rgba(86, 50, 127, 0.34);
  box-shadow: 0 12px 28px rgba(55, 28, 82, 0.1);
}

.dino-omnivore-list strong {
  display: block;
  margin-bottom: 0.35rem;
  color: var(--dino-accent-dark);
  font-size: 1.05rem;
}

.dino-omnivore-list span {
  display: block;
  color: var(--dino-muted);
  line-height: 1.55;
}

@media (max-width: 700px) {
  .dino-omnivore-list {
    grid-template-columns: 1fr;
  }
}