:root {
  color-scheme: light;
  --ink: #243424;
  --soft-ink: #52634d;
  --leaf: #315f38;
  --moss: #6f9c43;
  --grass: #9abc4d;
  --sky: #89d8ef;
  --paper: #fff8df;
  --paper-2: #fffdf0;
  --honey: #f0a33f;
  --gold: #ffd765;
  --bloom: #f36f9b;
  --line: rgba(48, 85, 45, .18);
  --shadow: 0 18px 42px rgba(37, 60, 28, .12);
  --inner-shadow: inset 0 0 0 1px rgba(255, 255, 255, .46);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }

html {
  min-height: 100%;
  scroll-behavior: smooth;
  background: #e9f3d2;
}

body {
  margin: 0;
  min-height: 100%;
  color: var(--ink);
  background:
    linear-gradient(180deg, rgba(137, 216, 239, .45), rgba(255, 248, 223, .74) 330px, rgba(230, 239, 197, .88)),
    radial-gradient(circle at 14% 13%, rgba(255, 215, 101, .36), transparent 32%),
    radial-gradient(circle at 86% 12%, rgba(106, 174, 78, .24), transparent 28%);
}

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

a,
button,
summary {
  -webkit-tap-highlight-color: transparent;
}

button {
  font: inherit;
}

a:focus-visible,
button:focus-visible,
summary:focus-visible {
  outline: 3px solid rgba(240, 163, 63, .7);
  outline-offset: 3px;
}

h1,
h2,
h3,
h4,
p,
a,
button,
summary,
strong,
span,
li {
  overflow-wrap: anywhere;
}

img {
  max-width: 100%;
  display: block;
  -webkit-user-drag: none;
  pointer-events: none;
  user-select: none;
}

code {
  display: inline-block;
  max-width: 100%;
  padding: 4px 6px;
  border-radius: 7px;
  background: #315f38;
  color: #fff8df;
  font: 900 13px/1.25 ui-monospace, SFMono-Regular, Menlo, monospace;
  overflow-wrap: anywhere;
  white-space: normal;
}

.page {
  width: min(1220px, calc(100% - 22px));
  min-height: 100svh;
  margin: 0 auto;
  padding: 14px 0 28px;
  display: grid;
  gap: 12px;
}

.site-banner {
  min-height: 92px;
  border: 2px solid rgba(39, 74, 39, .18);
  border-radius: 8px;
  overflow: hidden;
  box-shadow: var(--shadow);
  background: #87d8ee;
}

.site-banner a,
.site-banner img {
  width: 100%;
  height: 100%;
  min-height: 92px;
}

.site-banner img {
  object-fit: cover;
  object-position: center;
  transition: filter .18s ease, transform .18s ease;
}

.site-banner a:hover img,
.site-banner a:focus-visible img {
  filter: saturate(1.08) brightness(1.04);
  transform: scale(1.01);
}

.layout {
  display: grid;
  gap: 12px;
}

.content {
  display: grid;
  gap: 12px;
  container-type: inline-size;
}

.mobile-menu {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 253, 240, .92);
  box-shadow: 0 10px 20px rgba(50, 80, 36, .08);
  overflow: hidden;
}

.mobile-menu summary,
.nav-group summary {
  min-height: 46px;
  padding: 0 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: var(--leaf);
  font-weight: 950;
  list-style: none;
  cursor: pointer;
  transition: background .16s ease, color .16s ease;
}

.mobile-menu summary::-webkit-details-marker,
.nav-group summary::-webkit-details-marker { display: none; }

.mobile-menu summary::after,
.nav-group summary::after {
  content: "+";
  color: rgba(49, 95, 56, .62);
  font-weight: 1000;
}

.mobile-menu[open] > summary::after,
.nav-group[open] > summary::after { content: "-"; }

.mobile-menu summary:hover,
.mobile-menu summary:focus-visible,
.nav-group summary:hover,
.nav-group summary:focus-visible {
  background: rgba(255, 215, 101, .18);
  color: #244f2c;
}

.side { display: none; }

.nav-list {
  display: grid;
  gap: 8px;
  padding: 0 10px 12px;
}

.nav-group {
  border: 1px solid rgba(48, 85, 45, .14);
  border-radius: 8px;
  overflow: hidden;
  background: rgba(255, 253, 240, .78);
}

.nav-links {
  display: grid;
  gap: 5px;
  padding: 0 8px 9px;
}

.nav-links a {
  min-height: 32px;
  padding: 8px 9px;
  border-radius: 7px;
  background: rgba(111, 156, 67, .1);
  color: #435938;
  font-size: 13px;
  font-weight: 850;
  transition: transform .16s ease, background .16s ease, color .16s ease, box-shadow .16s ease;
}

.nav-links a[aria-current="page"],
.nav-links a[aria-current="location"] {
  background: #315f38;
  color: #fff8df;
}

.nav-links a:hover,
.nav-links a:focus-visible {
  transform: translateY(-1px) scale(1.015);
  background: rgba(255, 215, 101, .28);
  color: #244f2c;
  box-shadow: 0 8px 14px rgba(49, 95, 56, .1);
}

.nav-links a[aria-current="page"]:hover,
.nav-links a[aria-current="page"]:focus-visible,
.nav-links a[aria-current="location"]:hover,
.nav-links a[aria-current="location"]:focus-visible {
  background: #244f2c;
  color: #fff8df;
}

.side-brand {
  display: none;
}

.article {
  border: 1px solid var(--line);
  border-radius: 8px;
  background:
    linear-gradient(90deg, rgba(255, 253, 240, .96), rgba(255, 253, 240, .9)),
    url("/assets/backgrounds/garden-glow-selected.jpg") center / cover;
  box-shadow: var(--shadow);
  overflow: hidden;
}

.article-hero {
  padding: clamp(20px, 5vw, 42px);
  border-bottom: 1px solid rgba(48, 85, 45, .14);
}

.eyebrow,
.page-kicker {
  width: max-content;
  max-width: 100%;
  padding: 6px 9px;
  border-radius: 7px;
  background: rgba(49, 95, 56, .1);
  color: var(--leaf);
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}

h1,
h2,
h3,
h4 {
  letter-spacing: 0;
}

h1 {
  max-width: 820px;
  margin: 12px 0 10px;
  color: var(--leaf);
  font-size: 2.25rem;
  line-height: .96;
}

.lead {
  max-width: 820px;
  margin: 0;
  color: var(--soft-ink);
  font-size: 1.0625rem;
  line-height: 1.45;
  font-weight: 760;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 20px;
}

.pill {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 14px;
  border: 1px solid rgba(48, 85, 45, .16);
  border-radius: 8px;
  background: rgba(255, 253, 240, .92);
  color: var(--leaf);
  font-weight: 950;
  box-shadow: var(--inner-shadow), 0 8px 18px rgba(48, 79, 36, .08);
  transform: scale(1);
  transition: transform .16s ease, background .16s ease, border-color .16s ease, box-shadow .16s ease;
}

.pill:hover,
.pill:focus-visible {
  transform: scale(1.04);
  border-color: rgba(49, 95, 56, .36);
  background: linear-gradient(180deg, #fffdf0, #fff1bd);
  outline: none;
}

.article-body {
  padding: clamp(16px, 4vw, 34px);
  display: grid;
  gap: 14px;
}

.wiki-section,
.guide-shell,
.simple-card,
.guide-card,
.quick-card {
  border: 1px solid rgba(48, 85, 45, .14);
  border-radius: 8px;
  background: rgba(255, 253, 240, .92);
  box-shadow: var(--inner-shadow), 0 10px 20px rgba(48, 79, 36, .08);
  overflow: hidden;
}

.section-head,
.guide-card-title {
  padding: 15px 16px;
  display: grid;
  gap: 7px;
  border-bottom: 1px solid rgba(85, 58, 32, .14);
  background:
    linear-gradient(180deg, rgba(200, 135, 53, .24), rgba(255, 248, 223, .78)),
    rgba(255, 248, 223, .9);
}

.section-head h2,
.guide-card h3,
.quick-card h3,
.simple-card h2 {
  margin: 0;
  color: var(--leaf);
  line-height: 1.1;
}

.section-head h2 {
  font-size: 1.65rem;
}

.guide-card h3,
.quick-card h3 {
  font-size: 1.5rem;
}

.section-head p,
.guide-card-title p,
.simple-card p,
.guide-card p {
  margin: 0;
  color: #435938;
  line-height: 1.48;
  font-weight: 750;
}

.guide-shell {
  border-left: 8px solid var(--honey);
  background:
    linear-gradient(135deg, rgba(255, 215, 101, .22), rgba(255, 253, 240, .94)),
    rgba(255, 253, 240, .94);
}

.guide-list {
  display: grid;
  gap: 14px;
  padding: 14px;
}

.quick-card {
  padding: 16px;
  display: grid;
  gap: 14px;
  background:
    linear-gradient(135deg, rgba(137, 216, 239, .16), rgba(255, 215, 101, .16)),
    rgba(255, 253, 240, .92);
}

.quick-steps,
.step-list {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.quick-steps li,
.step-card {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  padding: 12px;
  border: 1px solid rgba(48, 85, 45, .12);
  border-radius: 8px;
  background: rgba(255, 253, 240, .82);
}

.quick-steps b,
.step-card b {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #8d5a2a;
  color: #fff8df;
  font-weight: 1000;
  box-shadow: inset 0 -3px 0 rgba(67, 39, 20, .22);
}

.quick-steps strong,
.step-card strong {
  display: block;
  color: var(--leaf);
  line-height: 1.18;
}

.quick-steps span,
.step-card span {
  display: block;
  margin-top: 4px;
  color: #435938;
  line-height: 1.42;
  font-weight: 740;
}

.guide-card {
  scroll-margin-top: 18px;
}

.guide-card-body {
  padding: 15px;
  display: grid;
  gap: 14px;
}

.guide-split {
  display: grid;
  gap: 14px;
  align-items: start;
}

.image-header {
  margin: 0;
  border-bottom: 1px solid rgba(48, 85, 45, .12);
  background: #1c261b;
}

.image-header img {
  width: 100%;
  max-height: 340px;
  object-fit: contain;
  background: #1c261b;
}

.image-header figcaption {
  padding: 10px 12px;
  background: rgba(255, 253, 240, .94);
  color: #435938;
  font-size: 13px;
  line-height: 1.42;
  font-weight: 820;
}

.note {
  padding: 12px 14px;
  border-left: 7px solid var(--honey);
  border-radius: 8px;
  background: rgba(255, 215, 101, .2);
  color: #4f4328;
  line-height: 1.48;
  font-weight: 780;
  box-shadow: var(--inner-shadow), 0 8px 18px rgba(48, 79, 36, .07);
}

.note.warning {
  border-left-color: var(--bloom);
  background: rgba(243, 111, 155, .14);
}

.note strong {
  color: var(--leaf);
}

.command-group {
  display: grid;
  gap: 9px;
}

.command-group h4 {
  margin: 0;
  color: var(--leaf);
  font-size: 18px;
  line-height: 1.15;
}

.command-row {
  display: grid;
  grid-template-columns: minmax(160px, 230px) minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  padding: 11px;
  border: 1px solid rgba(48, 85, 45, .12);
  border-left: 6px solid var(--moss);
  border-radius: 8px;
  background:
    linear-gradient(90deg, rgba(111, 156, 67, .14), rgba(255, 253, 240, .92));
}

.command-row > *,
.quick-card,
.guide-card,
.quick-steps li > div,
.step-card > div {
  min-width: 0;
}

.command-row span {
  color: #435938;
  line-height: 1.45;
  font-weight: 760;
  min-width: 0;
  overflow-wrap: anywhere;
}

.command-row small {
  display: block;
  margin-top: 4px;
  color: #65745d;
  font-size: 12px;
  line-height: 1.35;
  font-weight: 780;
}

.card-grid {
  display: grid;
  gap: 10px;
  padding: 14px;
}

.simple-card {
  padding: 15px;
  display: grid;
  gap: 8px;
  min-width: 0;
  transition: transform .16s ease, background .16s ease, border-color .16s ease, box-shadow .16s ease;
}

.simple-card strong {
  color: var(--leaf);
  font-size: 18px;
}

a.simple-card:hover,
a.simple-card:focus-visible {
  transform: translateY(-2px) scale(1.012);
  border-color: rgba(49, 95, 56, .32);
  background: linear-gradient(180deg, rgba(255, 253, 240, .98), rgba(255, 241, 189, .78));
  box-shadow: var(--inner-shadow), 0 14px 24px rgba(48, 79, 36, .12);
}

.vote-shell,
.rules-shell {
  border: 1px solid rgba(48, 85, 45, .14);
  border-radius: 8px;
  background: rgba(255, 253, 240, .92);
  box-shadow: var(--inner-shadow), 0 10px 20px rgba(48, 79, 36, .08);
  overflow: hidden;
}

.vote-reminder,
.rule-intro,
.rule-footer-note {
  margin: 14px;
  padding: 14px;
  border: 1px solid rgba(48, 85, 45, .13);
  border-left: 7px solid var(--honey);
  border-radius: 8px;
  background: rgba(255, 215, 101, .16);
  color: #435938;
  line-height: 1.48;
  font-weight: 780;
}

.vote-reminder {
  display: grid;
  gap: 5px;
}

.vote-reminder strong {
  color: var(--leaf);
  font-size: 1.05rem;
}

.vote-reminder p,
.rule-intro p {
  margin: 0;
}

.rule-intro {
  display: grid;
  gap: 8px;
}

.vote-list,
.rule-groups {
  display: grid;
  gap: 10px;
  padding: 0 14px 14px;
}

@media (min-width: 900px) {
  .vote-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.vote-link {
  min-height: 58px;
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid rgba(48, 85, 45, .13);
  border-left: 6px solid var(--moss);
  border-radius: 8px;
  background:
    linear-gradient(90deg, rgba(111, 156, 67, .14), rgba(255, 253, 240, .94));
  color: var(--leaf);
  box-shadow: var(--inner-shadow), 0 8px 16px rgba(48, 79, 36, .07);
  transition: transform .16s ease, border-color .16s ease, background .16s ease, box-shadow .16s ease;
}

.vote-link:hover,
.vote-link:focus-visible {
  transform: translateY(-2px) scale(1.012);
  border-color: rgba(49, 95, 56, .32);
  background:
    linear-gradient(90deg, rgba(255, 215, 101, .28), rgba(255, 253, 240, .98));
  box-shadow: var(--inner-shadow), 0 14px 24px rgba(48, 79, 36, .12);
}

.vote-index {
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #315f38;
  color: #fff8df;
  font-size: 12px;
  font-weight: 1000;
}

.vote-label {
  min-width: 0;
  font-weight: 950;
}

.vote-action {
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(240, 163, 63, .22);
  color: #7b4b14;
  font-size: 12px;
  font-weight: 1000;
  text-transform: uppercase;
}

.rule-group {
  scroll-margin-top: 18px;
  border: 1px solid rgba(48, 85, 45, .13);
  border-radius: 8px;
  background: rgba(255, 253, 240, .86);
  overflow: hidden;
}

.rule-group-head {
  padding: 14px;
  display: grid;
  gap: 7px;
  border-bottom: 1px solid rgba(48, 85, 45, .12);
  background:
    linear-gradient(180deg, rgba(137, 216, 239, .16), rgba(255, 248, 223, .74));
}

.rule-group h3 {
  margin: 0;
  color: var(--leaf);
  font-size: 1.35rem;
  line-height: 1.12;
}

.rule-group p {
  margin: 0;
  color: #435938;
  line-height: 1.45;
  font-weight: 760;
}

.rule-list {
  margin: 0;
  padding: 8px 14px 14px;
  display: grid;
  gap: 8px;
  list-style: none;
}

.rule-list li {
  position: relative;
  padding: 10px 10px 10px 28px;
  border-radius: 8px;
  background: rgba(111, 156, 67, .09);
  color: #40593a;
  line-height: 1.45;
  font-weight: 760;
}

.rule-list li::before {
  content: "";
  position: absolute;
  top: 17px;
  left: 12px;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--honey);
  box-shadow: 0 0 0 3px rgba(240, 163, 63, .18);
}

.page-pager {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.pager-link {
  min-height: 78px;
  display: grid;
  gap: 5px;
  align-content: center;
  padding: 15px;
  border: 1px solid rgba(48, 85, 45, .16);
  border-radius: 8px;
  background: rgba(255, 253, 240, .92);
  color: var(--leaf);
  box-shadow: var(--inner-shadow), 0 10px 20px rgba(48, 79, 36, .08);
  transition: transform .16s ease, background .16s ease, border-color .16s ease, box-shadow .16s ease;
}

.pager-link:hover,
.pager-link:focus-visible {
  transform: translateY(-2px) scale(1.012);
  border-color: rgba(49, 95, 56, .32);
  background: linear-gradient(180deg, #fffdf0, #fff1bd);
  box-shadow: var(--inner-shadow), 0 14px 24px rgba(48, 79, 36, .12);
}

.pager-link small {
  color: #66745d;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.legal-footer {
  width: min(1260px, calc(100% - 32px));
  margin: 0 auto 16px;
  padding: 0 2px;
  color: #5f6c58;
  font-size: 11px;
  line-height: 1.35;
  font-weight: 850;
  text-align: left;
}

.legal-footer span {
  display: block;
  color: #77806f;
  font-weight: 760;
}

.home-fab {
  position: fixed;
  right: 14px;
  bottom: 14px;
  z-index: 90;
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(48, 85, 45, .2);
  border-radius: 999px;
  background: rgba(255, 253, 240, .94);
  color: var(--leaf);
  box-shadow: 0 12px 24px rgba(37, 60, 28, .16);
  backdrop-filter: blur(8px);
  transition: transform .16s ease, background .16s ease, color .16s ease, box-shadow .16s ease, border-color .16s ease;
}

.home-fab:hover,
.home-fab:focus-visible {
  transform: translateY(-3px) scale(1.08);
  border-color: rgba(255, 215, 101, .65);
  background: #315f38;
  color: #fff8df;
  box-shadow: 0 16px 30px rgba(37, 60, 28, .24), 0 0 0 5px rgba(255, 215, 101, .2);
}

.home-fab svg {
  width: 21px;
  height: 21px;
  stroke: currentColor;
  stroke-width: 2.35;
  stroke-linecap: round;
  stroke-linejoin: round;
  fill: none;
}

.home-hero {
  position: relative;
  height: 100svh;
  min-height: 620px;
  display: grid;
  place-items: center;
  overflow: clip;
  padding: clamp(14px, 2vw, 22px);
  background:
    linear-gradient(180deg, rgba(29, 40, 23, .08), rgba(29, 40, 23, .46)),
    url("/assets/backgrounds/garden-glow-selected.jpg") center / cover;
  animation: homeBackdrop 18s ease-in-out infinite alternate;
}

.home-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(137, 216, 239, .16), transparent 30%, transparent 70%, rgba(255, 215, 101, .18)),
    linear-gradient(180deg, rgba(255, 253, 240, .06), transparent 38%, rgba(37, 60, 28, .18));
  pointer-events: none;
}

.home-portal {
  position: relative;
  z-index: 1;
  width: min(720px, 100%);
  display: grid;
  justify-items: center;
  gap: clamp(12px, 2.2vh, 18px);
}

.home-logo {
  width: min(390px, 66vw, 42svh);
  max-height: min(390px, 42svh);
  height: auto;
  aspect-ratio: 627 / 635;
  object-fit: contain;
  filter: drop-shadow(0 0 30px rgba(255, 215, 101, .68)) drop-shadow(0 16px 28px rgba(20, 31, 18, .32));
  animation: logoFloat 4.8s ease-in-out infinite, logoGlow 3.6s ease-in-out infinite;
}

.home-status {
  position: absolute;
  z-index: 2;
  top: clamp(82px, 18svh, 152px);
  width: min(226px, calc(50vw - 34px));
  min-height: 0;
  padding: 10px 12px;
  display: grid;
  gap: 5px;
  border: 1px solid rgba(255, 253, 240, .22);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(255, 253, 240, .08), rgba(255, 253, 240, .02)),
    rgba(18, 31, 17, .14);
  color: #fffdf0;
  text-align: left;
  text-shadow: 0 2px 9px rgba(14, 24, 13, .58);
  box-shadow: 0 12px 24px rgba(14, 24, 13, .1), inset 0 0 0 1px rgba(255, 255, 255, .05);
  backdrop-filter: blur(2px);
  cursor: pointer;
  transition: transform .16s ease, background .16s ease, border-color .16s ease, box-shadow .16s ease;
}

.home-status:hover,
.home-status:focus-visible {
  transform: translateY(-3px) scale(1.025);
  border-color: rgba(255, 215, 101, .46);
  background:
    linear-gradient(135deg, rgba(255, 253, 240, .14), rgba(255, 253, 240, .04)),
    rgba(18, 31, 17, .24);
  box-shadow: 0 18px 34px rgba(14, 24, 13, .2), 0 0 0 4px rgba(255, 215, 101, .13);
}

.home-status-server {
  left: clamp(16px, 6vw, 92px);
}

.home-status-discord {
  right: clamp(16px, 6vw, 92px);
}

.home-status-kicker {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: rgba(255, 253, 240, .86);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
}

.minecraft-mark,
.discord-mark {
  position: relative;
  width: 16px;
  height: 16px;
  flex: 0 0 16px;
}

.minecraft-mark {
  border-radius: 3px;
  background:
    linear-gradient(180deg, #75bd4f 0 42%, #8a5b33 42% 100%);
  box-shadow:
    inset 0 -2px 0 rgba(42, 25, 12, .26),
    0 0 0 3px rgba(113, 185, 76, .18);
}

.minecraft-mark::before {
  content: "";
  position: absolute;
  left: 3px;
  top: 4px;
  width: 3px;
  height: 3px;
  background: rgba(255, 253, 240, .42);
  box-shadow: 6px -1px 0 rgba(255, 253, 240, .28), 7px 6px 0 rgba(42, 25, 12, .18);
}

.discord-mark {
  border-radius: 50%;
  background: #71b94c;
  box-shadow: 0 0 0 3px rgba(113, 185, 76, .18);
}

[data-server-state="offline"] .minecraft-mark {
  background:
    linear-gradient(180deg, #cf7b45 0 42%, #78432b 42% 100%);
  box-shadow: 0 0 0 3px rgba(207, 95, 69, .16);
}

.home-status strong {
  color: #fffdf0;
  font-size: clamp(1.45rem, 2.45vw, 2.05rem);
  line-height: .95;
}

.home-status strong small {
  margin-left: 4px;
  color: rgba(255, 253, 240, .78);
  font-size: .38em;
  font-weight: 950;
}

.home-status-lines {
  display: grid;
  gap: 3px;
  color: rgba(255, 253, 240, .86);
  font-size: 11px;
  line-height: 1.28;
  font-weight: 820;
}

.copy-hint {
  width: max-content;
  max-width: 100%;
  padding: 6px 8px;
  border-radius: 7px;
  background: rgba(255, 253, 240, .16);
  color: #fffdf0;
  font-size: 11px;
  font-weight: 950;
}

.home-links {
  width: min(520px, 100%);
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(8px, 1.7vw, 14px);
}

.home-links a {
  min-width: 0;
  display: grid;
  justify-items: center;
  gap: 7px;
  color: #fffdf0;
  font-weight: 1000;
  text-align: center;
  text-shadow: 0 2px 7px rgba(24, 34, 21, .48);
  transition: transform .16s ease, filter .16s ease;
}

.home-links a:hover,
.home-links a:focus-visible {
  transform: translateY(-5px) scale(1.04);
  filter: saturate(1.08) brightness(1.05);
}

.home-link-media {
  width: clamp(72px, 10vw, 98px);
  height: clamp(72px, 10vw, 98px);
  display: grid;
  place-items: center;
  border: 1px solid rgba(255, 253, 240, .42);
  border-radius: 8px;
  background: rgba(255, 253, 240, .9);
  box-shadow: 0 14px 24px rgba(24, 34, 21, .24), var(--inner-shadow);
  overflow: hidden;
}

.home-link-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.home-link-media img[src*="logo"] {
  object-fit: contain;
  padding: 8px;
}

.home-link-vote {
  background:
    linear-gradient(135deg, rgba(255, 215, 101, .94), rgba(111, 156, 67, .92)),
    url("/assets/backgrounds/garden-glow-selected.jpg") center / cover;
  color: #315f38;
  font-size: clamp(2rem, 4vw, 3rem);
  text-shadow: none;
}

.home-links strong {
  font-size: clamp(.95rem, 1.8vw, 1.15rem);
  line-height: 1;
}

.home-hero .legal-footer {
  position: absolute;
  left: 16px;
  bottom: 12px;
  width: min(196px, calc(100% - 32px));
  margin: 0;
  color: rgba(255, 253, 240, .88);
  text-shadow: 0 2px 7px rgba(24, 34, 21, .42);
}

.home-hero .legal-footer span {
  color: rgba(255, 253, 240, .72);
}

@keyframes logoFloat {
  0%, 100% { transform: translateY(0) rotate(-.2deg); }
  50% { transform: translateY(-10px) rotate(.3deg); }
}

@keyframes logoGlow {
  0%, 100% { filter: drop-shadow(0 0 26px rgba(255, 215, 101, .6)) drop-shadow(0 16px 28px rgba(20, 31, 18, .32)); }
  50% { filter: drop-shadow(0 0 42px rgba(137, 216, 239, .72)) drop-shadow(0 20px 32px rgba(20, 31, 18, .34)); }
}

@keyframes homeBackdrop {
  from { background-position: center center; }
  to { background-position: center 48%; }
}

@media (min-width: 680px) {
  h1 {
    font-size: 3.15rem;
  }

  .lead {
    font-size: 1.18rem;
  }

  .section-head h2 {
    font-size: 2.05rem;
  }

  .guide-card h3,
  .quick-card h3,
  .rule-group h3 {
    font-size: 1.85rem;
  }

  .card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .quick-steps {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (min-width: 760px) {
  .page {
    width: min(1260px, calc(100% - 32px));
    padding-top: 18px;
    gap: 16px;
  }

  .site-banner,
  .site-banner a,
  .site-banner img {
    min-height: 118px;
  }

  .mobile-menu { display: none; }

  .layout {
    grid-template-columns: 286px minmax(0, 1fr);
    align-items: start;
    gap: 16px;
  }

  .side {
    position: sticky;
    top: 16px;
    display: block;
    max-height: calc(100svh - 32px);
    overflow: auto;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background:
      linear-gradient(180deg, rgba(255, 253, 240, .94), rgba(239, 246, 210, .94));
    box-shadow: var(--shadow);
  }

  .side .nav-list { padding: 0; }

  .side-brand {
    display: grid;
    grid-template-columns: 54px minmax(0, 1fr);
    align-items: center;
    gap: 10px;
    margin-bottom: 14px;
  }

  .side-brand img {
    width: 54px;
    height: 54px;
    object-fit: contain;
    aspect-ratio: 1;
    filter: drop-shadow(0 8px 12px rgba(38, 62, 28, .16));
  }

  .side-brand strong {
    display: block;
    color: var(--leaf);
    font-size: 17px;
    line-height: 1;
  }

  .side-brand small {
    display: block;
    margin-top: 4px;
    color: #66745d;
    font-size: 12px;
    font-weight: 850;
  }

  .guide-split {
    grid-template-columns: minmax(260px, .9fr) minmax(0, 1.1fr);
  }
}

@media (min-width: 1100px) {
  h1 {
    font-size: 5.125rem;
  }

  .lead {
    font-size: 1.3125rem;
  }

  .section-head h2 {
    font-size: 2.5rem;
  }

  .guide-card h3,
  .quick-card h3,
  .rule-group h3 {
    font-size: 2.25rem;
  }

  .site-banner,
  .site-banner a,
  .site-banner img {
    min-height: 142px;
  }
}

@media (max-width: 640px) {
  .page-pager {
    grid-template-columns: 1fr;
  }

  .legal-footer {
    width: calc(100% - 24px);
    margin-bottom: 12px;
  }
}

@media (max-width: 760px) {
  .home-hero {
    min-height: 0;
    padding: 12px;
  }

  .home-status {
    top: 12px;
    width: calc(50% - 18px);
    min-height: 0;
    padding: 9px;
    gap: 4px;
  }

  .home-status-server {
    left: 12px;
  }

  .home-status-discord {
    right: 12px;
  }

  .home-status strong {
    font-size: 1.2rem;
  }

  .home-status strong small {
    display: block;
    margin: 2px 0 0;
  }

  .home-status-lines {
    font-size: 10px;
  }

  .copy-hint {
    padding: 5px 6px;
    font-size: 10px;
  }

  .home-portal {
    margin-top: 62px;
    gap: 10px;
  }

  .home-logo {
    width: min(230px, 58vw, 27svh);
    max-height: min(235px, 28svh);
    height: auto;
  }

  .home-links {
    width: min(300px, 100%);
    gap: 8px;
  }

  .home-link-media {
    width: clamp(58px, 17vw, 72px);
    height: clamp(58px, 17vw, 72px);
  }

  .home-links strong {
    font-size: .92rem;
  }
}

@container (max-width: 720px) {
  .card-grid,
  .page-pager {
    grid-template-columns: 1fr;
  }

  .quick-steps,
  .guide-split,
  .command-row,
  .quick-steps li,
  .step-card {
    grid-template-columns: 1fr;
  }
}

@container (max-width: 440px) {
  .vote-link {
    grid-template-columns: 40px minmax(0, 1fr);
  }

  .vote-action {
    grid-column: 2;
    justify-self: start;
  }
}
