:root {
  --burgundy: #4b1021;
  --wine: #721936;
  --cream: #fbf7ef;
  --paper: #fffdf8;
  --ink: #26191d;
  --muted: #6f6265;
  --sage: #6f7c63;
  --gold: #b89455;
  --ring: rgba(184, 148, 85, 0.38);
}

* {
  box-sizing: border-box;
}

html {
  min-height: 100%;
}

body {
  min-height: 100vh;
  min-height: 100svh;
  margin: 0;
  display: grid;
  place-items: center;
  padding: clamp(1.5rem, 5vw, 4rem);
  color: var(--ink);
  font-family:
    Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI",
    sans-serif;
  background:
    linear-gradient(120deg, rgba(75, 16, 33, 0.08) 0 1px, transparent 1px 72px),
    linear-gradient(160deg, rgba(111, 124, 99, 0.08), transparent 42%),
    var(--cream);
}

.corner-art {
  position: fixed;
  z-index: 0;
  width: 8.2rem;
  aspect-ratio: 1;
  pointer-events: none;
}

.corner-art svg {
  display: block;
  width: 100%;
  height: 100%;
  overflow: visible;
}

.corner-art-cat {
  top: -2.4rem;
  right: -2.5rem;
  transform: rotate(-14deg);
}

.corner-art-dog {
  bottom: -2.8rem;
  left: -2.6rem;
  transform: rotate(13deg);
}

.comic-line {
  fill: none;
  stroke: var(--gold);
  stroke-linecap: round;
  stroke-width: 7;
}

.cat-head,
.cat-body {
  fill: #fff8ed;
  stroke: var(--burgundy);
  stroke-linejoin: round;
  stroke-width: 4;
}

.cat-tail {
  fill: none;
  stroke: var(--burgundy);
  stroke-linecap: round;
  stroke-width: 13;
}

.cat-ear {
  fill: #e9cbb8;
  stroke: var(--burgundy);
  stroke-linejoin: round;
  stroke-width: 3;
}

.cat-eye,
.dog-eye {
  fill: var(--paper);
  stroke: var(--burgundy);
  stroke-width: 3;
}

.cat-pupil,
.dog-pupil,
.cat-nose,
.dog-nose {
  fill: var(--burgundy);
}

.cat-smile,
.cat-whisker,
.dog-smile {
  fill: none;
  stroke: var(--burgundy);
  stroke-linecap: round;
  stroke-width: 3;
}

.dog-body,
.dog-head {
  fill: #c99a6b;
  stroke: var(--burgundy);
  stroke-linejoin: round;
  stroke-width: 4;
}

.dog-leg {
  fill: #b47d55;
  stroke: var(--burgundy);
  stroke-linejoin: round;
  stroke-width: 4;
}

.dog-tail {
  fill: #c99a6b;
  stroke: var(--burgundy);
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 4;
}

.dog-ear {
  fill: #8c4a39;
  stroke: var(--burgundy);
  stroke-linejoin: round;
  stroke-width: 4;
}

.dog-muzzle {
  fill: #ffe8c8;
  stroke: var(--burgundy);
  stroke-width: 4;
}

.dog-patch {
  fill: rgba(75, 16, 33, 0.28);
}

.dog-mouth {
  fill: none;
  stroke: var(--burgundy);
  stroke-linecap: round;
  stroke-width: 3;
}

.dog-tongue {
  fill: #d96b6b;
  stroke: var(--burgundy);
  stroke-linejoin: round;
  stroke-width: 3;
}

.dog-collar {
  fill: none;
  stroke: var(--wine);
  stroke-linecap: round;
  stroke-width: 7;
}

body::before,
body::after {
  position: fixed;
  left: clamp(1rem, 4vw, 3rem);
  right: clamp(1rem, 4vw, 3rem);
  height: 1px;
  content: "";
  pointer-events: none;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  opacity: 0.55;
}

body::before {
  top: clamp(1rem, 4vw, 3rem);
}

body::after {
  bottom: clamp(1rem, 4vw, 3rem);
}

.landing {
  position: relative;
  z-index: 1;
  width: min(100%, 42rem);
  text-align: center;
}

.mark {
  width: clamp(4.75rem, 18vw, 6.5rem);
  aspect-ratio: 1;
  margin: 0 auto 1.45rem;
  color: var(--wine);
}

.mark svg {
  display: block;
  width: 100%;
  height: 100%;
  overflow: visible;
}

.vine {
  fill: none;
  stroke: var(--gold);
  stroke-width: 4;
  stroke-linecap: round;
}

.leaf {
  fill: var(--sage);
}

.grape {
  fill: var(--wine);
  stroke: var(--paper);
  stroke-width: 2;
}

.grape-two,
.grape-four,
.grape-seven {
  fill: var(--burgundy);
}

.domain {
  margin: 0 0 0.8rem;
  color: var(--gold);
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
}

h1 {
  margin: 0;
  color: var(--burgundy);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 6.25rem;
  font-weight: 500;
  line-height: 0.95;
}

.message {
  margin: clamp(1.5rem, 4vw, 2.2rem) 0 0;
  color: var(--ink);
  font-size: 1.6rem;
  font-weight: 650;
  line-height: 1.35;
}

.support {
  max-width: 31rem;
  margin: 0.7rem auto 0;
  color: var(--muted);
  font-size: 1.08rem;
  line-height: 1.75;
}

.contact-link {
  display: inline-block;
  margin-top: clamp(1.75rem, 4vw, 2.5rem);
  color: var(--burgundy);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.5;
  text-decoration-color: rgba(75, 16, 33, 0.42);
  text-decoration-thickness: 1px;
  text-underline-offset: 0.34em;
  transition:
    color 160ms ease,
    text-decoration-color 160ms ease;
}

.contact-link:hover {
  color: var(--wine);
  text-decoration-color: var(--gold);
}

.contact-link:focus-visible {
  outline: 4px solid var(--ring);
  outline-offset: 4px;
}

@media (max-width: 48rem) {
  .corner-art {
    width: 6.2rem;
    opacity: 0.9;
  }

  .corner-art-cat {
    top: -2rem;
    right: -2rem;
  }

  .corner-art-dog {
    bottom: -2.3rem;
    left: -2.2rem;
  }

  h1 {
    font-size: 4.75rem;
  }

  .message {
    font-size: 1.38rem;
  }
}

@media (max-width: 38rem) {
  body {
    padding: 2rem 1.2rem;
  }

  .corner-art {
    width: 5.1rem;
  }

  .corner-art-cat {
    top: -1.75rem;
    right: -1.75rem;
  }

  .corner-art-dog {
    bottom: -2rem;
    left: -1.85rem;
  }

  h1 {
    font-size: 3.75rem;
  }

  .contact-link {
    overflow-wrap: anywhere;
  }
}

@media (max-width: 22rem) {
  h1 {
    font-size: 3.2rem;
  }
}
