* {
  box-sizing: border-box;
}

body.adoption-plan-body {
  margin: 0;
  min-width: 1068px;
  overflow-x: auto;
  background: #f3efe7;
  font-family: "Community Pro", sans-serif;
}

.adoption-plan-stage {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-height: calc(100vh - var(--landing-topbar-height, 64px));
  padding: var(--landing-stage-padding-block, clamp(14px, 2.2vh, 24px)) var(--landing-stage-padding-inline, clamp(16px, 3vw, 40px));
  gap: var(--landing-stage-gap, clamp(14px, 2.2vh, 24px));
}

.adoption-plan-canvas {
  position: relative;
  width: 1024px;
  height: 754px;
}

.adoption-page-title {
  position: absolute;
  left: 36px;
  top: 4px;
  margin: 0;
  color: #000;
  font-size: 39px;
  line-height: 1;
  letter-spacing: -0.05em;
  font-weight: 700;
}

.adoption-page-kicker {
  position: absolute;
  top: 18px;
  right: 17px;
  margin: 0;
  color: rgba(0, 0, 0, 0.5);
  font-size: clamp(11px, 1.05vw, 18px);
  line-height: 1.15;
  text-align: right;
  font-weight: 700;
  white-space: nowrap;
}

.adoption-hero-panel,
.adoption-certificate-panel,
.adoption-share-panel {
  position: absolute;
  overflow: hidden;
}

.adoption-hero-panel,
.adoption-certificate-panel {
  transition: transform 180ms ease;
}

.adoption-hero-panel:hover,
.adoption-hero-panel:focus-within,
.adoption-certificate-panel:hover,
.adoption-certificate-panel:focus-within {
  transform: translateY(-2px);
}

.adoption-hero-panel {
  left: 21px;
  top: 88px;
  width: 986px;
  height: 280px;
  border-radius: 27px;
  background: #2d64bc;
}

.adoption-hero-copy {
  position: absolute;
  left: 44px;
  top: 30px;
  z-index: 2;
  color: #fff;
}

.adoption-hero-copy h2 {
  margin: 0;
  font-size: 39px;
  line-height: 0.95;
  letter-spacing: -0.05em;
  font-weight: 700;
}

.adoption-hero-copy p {
  margin: 14px 0 0;
  font-size: 19px;
  line-height: 1.08;
  font-weight: 700;
}

.adoption-hero-button {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 36px;
  padding: 6px 8px 6px 14px;
  border-radius: 999px;
  background: #fff;
  color: #17407e;
  text-decoration: none;
  font-size: 15px;
  line-height: 1;
  font-weight: 700;
}

.adoption-hero-button img {
  width: 32px;
  height: 32px;
  display: block;
}

.adoption-hero-art {
  position: absolute;
  inset: 0;
}

.adoption-hero-art-image {
  position: absolute;
  right: 0;
  top: 0;
  width: 510px;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: right center;
}

.adoption-certificate-panel {
  left: 21px;
  top: 390px;
  width: 482px;
  height: 305px;
  border-radius: 27px;
  border: 9px solid #0a66c2;
  background: #70b5f9;
}

.adoption-certificate-copy {
  position: absolute;
  left: 34px;
  top: 45px;
  z-index: 2;
  color: #004182;
}

.adoption-certificate-copy h3 {
  margin: 0;
  font-size: 35px;
  line-height: 0.92;
  letter-spacing: -0.05em;
  font-weight: 700;
}

.adoption-certificate-copy p {
  width: 252px;
  margin: 16px 0 0;
  font-size: 18px;
  line-height: 1.18;
  font-weight: 700;
}

.adoption-pill-link {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  margin-top: 34px;
  padding: 4px 8px 4px 17px;
  border-radius: 999px;
  background: #fff;
  color: #17407e;
  text-decoration: none;
  font-size: 18px;
  font-weight: 700;
  white-space: nowrap;
}

.adoption-pill-link img {
  width: 38px;
  height: 38px;
  display: block;
}

.adoption-certificate-panel .adoption-pill-link {
  font-size: 14px;
}

.adoption-certificate-panel .adoption-pill-link img {
  width: 34px;
  height: 34px;
}

.adoption-certificate-badge {
  position: absolute;
  right: 26px;
  top: 26px;
  width: 171px;
  height: auto;
  display: block;
  z-index: 1;
}

.adoption-share-panel {
  left: 525px;
  top: 390px;
  width: 482px;
  height: 305px;
  border-radius: 27px;
  background: #f6cf46;
}

.adoption-share-panel-bubble {
  position: absolute;
  left: 36px;
  top: 33px;
  width: 410px;
  height: 236px;
  padding: 34px 26px 75px;
  border-radius: 28px;
  background: #fff;
}

.adoption-share-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 22px;
  padding: 0 8px;
  border-radius: 4px;
  background: #e9e9e9;
  color: #16407d;
  font-size: 10px;
  line-height: 1;
  font-weight: 700;
}

.adoption-share-copy p {
  margin: 14px 0 0;
  color: #000;
  font-size: 13px;
  line-height: 1.24;
  font-weight: 500;
}

.adoption-share-tags {
  color: #2d64bc;
}

.adoption-copy-button {
  position: absolute;
  right: 18px;
  bottom: 14px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  border: 0;
  border-radius: 999px;
  background: #f3efe7;
  color: #000;
  font-size: 14px;
  line-height: 1;
  font-family: inherit;
  font-weight: 700;
  cursor: pointer;
}

.adoption-copy-button img {
  width: 18px;
  height: 18px;
  display: block;
}

.adoption-share-tail {
  position: absolute;
  left: 168px;
  bottom: 28px;
  width: 57px;
  height: 14px;
}

.adoption-share-float {
  position: absolute;
  display: block;
}

.adoption-share-float-top {
  top: 17px;
  right: 64px;
  width: 30px;
  height: 30px;
}

.adoption-share-float-left {
  left: 18px;
  top: 154px;
  width: 34px;
  height: 34px;
}

.adoption-share-float-right {
  top: 79px;
  right: 13px;
  width: 52px;
  height: 52px;
}

.adoption-copy-status {
  position: absolute;
  left: 35px;
  bottom: 15px;
  color: rgba(0, 0, 0, 0.55);
  font-size: 11px;
  line-height: 1;
  font-weight: 700;
}

.page-topbar {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
}

.page-logo {
  width: clamp(66px, 5.7vw, 109px);
  max-width: 100%;
  display: block;
  height: auto;
}
