:root {
  --purchase-blue: #0867ef;
  --purchase-blue-2: #08a7ff;
  --purchase-navy: #06184c;
  --purchase-muted: #607393;
  --purchase-line: #c8d9ee;
  --purchase-soft: #eaf6ff;
  --purchase-shadow: 0 14px 34px rgba(7, 94, 221, 0.14);
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  color: var(--purchase-navy);
  background: #eef8ff;
  font-family: "Noto Sans JP", system-ui, sans-serif;
  line-height: 1.65;
  overflow-x: hidden;
}

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

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

button,
input {
  font: inherit;
}

body.purchase-page {
  background: #eef8ff;
}

.purchase-header {
  position: sticky;
  top: 0;
  z-index: 80;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 46px;
  gap: 12px;
  width: min(100%, 430px);
  margin: 0 auto;
  padding: 16px 18px 0;
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 10px 28px rgba(0, 87, 190, 0.06);
}

.purchase-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  color: var(--purchase-navy);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.15;
  white-space: nowrap;
}

.purchase-brand img {
  flex: 0 0 auto;
  width: 38px;
  height: auto;
}

.purchase-menu-button {
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 6px;
  width: 42px;
  height: 38px;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
}

.purchase-menu-button span {
  width: 28px;
  height: 3px;
  border-radius: 999px;
  background: var(--purchase-blue);
}

.purchase-tabs {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  width: calc(100% + 36px);
  margin: 4px -18px 0;
  padding: 0 6px 14px;
}

.purchase-tabs a {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0 4px;
  color: var(--purchase-navy);
  font-size: 0.9rem;
  font-weight: 700;
  line-height: 1;
}

.purchase-tabs a + a {
  border-left: 1px solid var(--purchase-line);
}

.purchase-lp {
  width: min(100%, 430px);
  margin: 0 auto;
  overflow: hidden;
  background:
    radial-gradient(circle at 94% 2%, rgba(8, 103, 239, 0.1), transparent 22%),
    linear-gradient(180deg, #f4fbff 0%, #fff 20%, #eef8ff 100%);
}

.purchase-section {
  position: relative;
  overflow: hidden;
}

.purchase-inner {
  position: relative;
  z-index: 2;
  width: min(360px, calc(100% - 30px));
  margin: 0 auto;
}

.purchase-deco {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.purchase-deco::before {
  content: "";
  position: absolute;
  width: 72px;
  height: 72px;
  background-image: radial-gradient(#7bb6f6 2px, transparent 2.5px);
  background-size: 13px 13px;
  opacity: 0.75;
}

.purchase-deco::after {
  content: "";
  position: absolute;
  width: 22px;
  height: 22px;
  border: 1.5px solid #69b7ff;
  transform: rotate(15deg);
  opacity: 0.7;
}

.purchase-deco-hero::before,
.purchase-deco-flow::before,
.purchase-deco-confirm::before {
  top: 18px;
  right: 26px;
}

.purchase-deco-hero::after {
  top: 34px;
  right: 126px;
}

.purchase-deco-flow::after {
  top: 28px;
  left: 25px;
  width: 36px;
  height: 36px;
}

.purchase-deco-assurance::before {
  top: 18px;
  right: 20px;
}

.purchase-deco-assurance::after,
.purchase-deco-bottom::after {
  border: 0;
  background: rgba(8, 167, 255, 0.65);
}

.purchase-deco-bottom::before {
  bottom: 14px;
  left: 18px;
}

.purchase-deco-bottom::after {
  right: 20px;
  bottom: 42px;
}

.purchase-hero {
  padding: 22px 0 18px;
  background:
    linear-gradient(180deg, rgba(235, 247, 255, 0.98), rgba(255, 255, 255, 0.96) 42%, rgba(231, 246, 255, 0.92)),
    #f7fbff;
}

.purchase-pill,
.purchase-center-pill,
.purchase-small-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  min-height: 32px;
  margin: 0;
  padding: 0 18px 0 8px;
  color: var(--purchase-blue);
  border-radius: 999px;
  background: #e6f2ff;
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1;
}

.purchase-pill > img {
  width: 44px;
  height: 44px;
  margin-left: -8px;
  object-fit: contain;
}

.purchase-center-pill {
  display: flex;
  width: fit-content;
  min-height: 34px;
  margin: 0 auto 18px;
  padding: 0 20px;
}

.purchase-small-pill {
  min-height: 30px;
  padding: 0 14px;
  font-size: 0.82rem;
}

.purchase-hero-title,
.purchase-section-title,
.purchase-bottom-card h2,
.purchase-assurance-hero h2 {
  margin: 18px 0 0;
  color: var(--purchase-navy);
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.18;
}

.purchase-hero-title {
  font-size: clamp(1.98rem, 8.8vw, 2.46rem);
}

.purchase-hero-title span,
.purchase-section-title span,
.purchase-bottom-card h2 span,
.purchase-assurance-hero h2 span {
  display: block;
}

.purchase-hero-title span:nth-child(2) {
  font-size: 0.92em;
  white-space: nowrap;
}

.purchase-hero-title em,
.purchase-section-title em,
.purchase-bottom-card h2 em,
.purchase-assurance-hero h2 em {
  color: var(--purchase-blue);
  font-style: normal;
}

.purchase-lead {
  margin: 16px 0 14px;
  color: var(--purchase-navy);
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.65;
}

.purchase-entry-card,
.purchase-summary-card,
.purchase-timeline article,
.purchase-confirm-grid article,
.purchase-assurance-grid article,
.purchase-bottom-card {
  border: 1px solid rgba(173, 203, 236, 0.92);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: var(--purchase-shadow);
}

.purchase-entry-card {
  padding: 16px;
}

.purchase-code-form {
  display: grid;
  gap: 12px;
  margin: 0;
}

.purchase-field {
  display: grid;
  gap: 6px;
}

.purchase-field label,
.purchase-icon-field label {
  color: var(--purchase-navy);
  font-weight: 700;
  line-height: 1.2;
}

.purchase-field label span {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  margin-left: 6px;
  padding: 0 8px;
  color: #fff;
  border-radius: 6px;
  background: var(--purchase-blue);
  font-size: 0.72rem;
}

.purchase-field label small,
.purchase-icon-field label small {
  font-size: 0.78em;
  font-weight: 600;
}

.purchase-page input {
  width: 100%;
  min-height: 48px;
  padding: 0 12px;
  border: 1.5px solid var(--purchase-line);
  border-radius: 8px;
  color: var(--purchase-navy);
  background: #fff;
  font-weight: 700;
}

.purchase-page input::placeholder {
  color: #9aa8bd;
  opacity: 1;
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 56px;
  border-radius: 8px;
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: 0;
}

.purchase-main-button {
  gap: 14px;
  margin-top: 6px;
  color: #fff;
  border: 0;
  background: linear-gradient(110deg, #09a8ff, #0755ed 78%);
  box-shadow: 0 14px 24px rgba(8, 103, 239, 0.24);
}

.purchase-sub-button {
  gap: 12px;
  color: var(--purchase-blue);
  border: 2px solid var(--purchase-blue);
  background: #fff;
  box-shadow: none;
}

.button i,
.purchase-home-link i {
  flex: 0 0 auto;
  width: 14px;
  height: 14px;
  border-top: 4px solid currentColor;
  border-right: 4px solid currentColor;
  transform: rotate(45deg);
}

.purchase-example {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin: 6px 0 0;
  color: #5a6c8c;
  font-size: 0.86rem;
  font-weight: 700;
  line-height: 1.35;
}

.purchase-example img {
  width: 22px;
  height: 22px;
  object-fit: contain;
}

.purchase-summary-card {
  margin-top: 16px;
  padding: 16px;
}

.purchase-summary-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 92px;
  gap: 8px;
  align-items: center;
  padding-bottom: 14px;
  border-bottom: 2px dotted #add2f5;
}

.purchase-summary-head > img {
  width: 92px;
  height: 92px;
  object-fit: contain;
}

.purchase-price {
  display: flex;
  align-items: baseline;
  gap: 4px;
  margin-top: 8px;
  color: var(--purchase-blue);
  font-weight: 700;
  line-height: 0.95;
}

.purchase-price span {
  font-size: 3.18rem;
}

.purchase-price small {
  color: var(--purchase-blue);
  font-size: 1.28rem;
}

.purchase-tax {
  margin: 4px 0 0;
  color: var(--purchase-navy);
  font-size: 1.15rem;
  font-weight: 700;
  line-height: 1;
}

.purchase-tax b {
  color: var(--purchase-blue);
  font-size: 1.42em;
}

.purchase-summary-body {
  position: relative;
  min-height: 122px;
  padding-top: 14px;
}

.purchase-check-list {
  display: grid;
  gap: 11px;
  width: calc(100% - 84px);
  margin: 0;
  padding: 0;
  list-style: none;
}

.purchase-check-list li {
  position: relative;
  min-height: 25px;
  padding: 0 0 10px 34px;
  border-bottom: 2px dotted #c5e0f8;
  color: var(--purchase-navy);
  font-size: 0.96rem;
  font-weight: 700;
  line-height: 1.35;
}

.purchase-check-list li:last-child {
  border-bottom: 0;
}

.purchase-check-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: -1px;
  width: 25px;
  height: 25px;
  border-radius: 999px;
  background: var(--purchase-blue);
}

.purchase-check-list li::after {
  content: "";
  position: absolute;
  left: 7px;
  top: 6px;
  width: 11px;
  height: 7px;
  border-bottom: 3px solid #fff;
  border-left: 3px solid #fff;
  transform: rotate(-45deg);
}

.purchase-check-list small {
  display: block;
  color: var(--purchase-blue);
  font-size: 0.78rem;
}

.purchase-gift-illust {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 80px;
  opacity: 0.95;
}

.purchase-flow,
.purchase-confirm,
.purchase-assurance,
.purchase-bottom {
  padding: 42px 0;
  border-top: 1px solid #d7e8f8;
  background:
    radial-gradient(circle at 9% 34%, rgba(8, 167, 255, 0.08), transparent 22%),
    #f8fcff;
}

.purchase-section-title {
  margin: 0 0 24px;
  text-align: center;
  font-size: clamp(2.02rem, 8.6vw, 2.58rem);
}

.purchase-flow .purchase-section-title {
  font-size: clamp(1.9rem, 8.2vw, 2.32rem);
}

.purchase-timeline {
  display: grid;
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.purchase-timeline li {
  position: relative;
  display: grid;
  grid-template-columns: 46px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
}

.purchase-timeline li:not(:last-child)::after {
  content: "";
  position: absolute;
  left: 22px;
  top: 52px;
  height: calc(100% - 24px);
  border-left: 3px dotted #0b79f6;
}

.purchase-step-number {
  position: relative;
  z-index: 2;
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  border-radius: 999px;
  color: #fff;
  background: linear-gradient(180deg, #0aa6ff, #0754e8);
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1;
}

.purchase-timeline article {
  display: grid;
  grid-template-columns: 80px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  min-height: 106px;
  padding: 14px 16px;
  overflow: hidden;
}

.purchase-timeline article > img {
  justify-self: center;
  align-self: center;
  width: 78px;
  height: 70px;
  object-fit: contain;
  object-position: center;
}

.purchase-timeline h3,
.purchase-timeline p {
  margin: 0;
}

.purchase-timeline h3 {
  color: var(--purchase-navy);
  font-size: 1.12rem;
  font-weight: 700;
  line-height: 1.28;
}

.purchase-timeline p {
  margin-top: 4px;
  color: var(--purchase-navy);
  font-size: 0.88rem;
  font-weight: 700;
  line-height: 1.55;
}

.purchase-confirm-title {
  font-size: clamp(1.8rem, 7.6vw, 2.34rem);
}

.purchase-confirm-grid,
.purchase-assurance-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.purchase-confirm-grid article,
.purchase-assurance-grid article {
  position: relative;
  min-width: 0;
  padding: 16px 9px 14px;
  text-align: center;
}

.purchase-card-number {
  position: absolute;
  top: 12px;
  left: 10px;
  display: grid;
  place-items: center;
  width: 27px;
  height: 27px;
  border-radius: 999px;
  color: var(--purchase-blue);
  background: #e6f2ff;
  font-size: 1rem;
  font-weight: 700;
}

.purchase-confirm-grid img {
  width: 72px;
  height: 72px;
  margin: 4px auto 0;
  object-fit: contain;
  object-position: center;
}

.purchase-assurance-grid img {
  width: 58px;
  height: 58px;
  margin: 4px auto 0;
  object-fit: contain;
  object-position: center;
}

.purchase-confirm-grid h3,
.purchase-assurance-grid h3 {
  margin: 10px 0 0;
  color: var(--purchase-navy);
  font-size: 0.96rem;
  font-weight: 700;
  line-height: 1.42;
}

.purchase-confirm-grid p,
.purchase-assurance-grid p {
  margin: 12px 0 0;
  padding-top: 11px;
  border-top: 2px dotted #b9dcf8;
  color: var(--purchase-navy);
  font-size: 0.68rem;
  font-weight: 700;
  line-height: 1.72;
}

.purchase-confirm-grid p span {
  color: var(--purchase-blue);
  font-weight: 700;
}

.purchase-assurance {
  padding-top: 32px;
}

.purchase-assurance-hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 60%) minmax(0, 40%);
  align-items: start;
  min-height: 214px;
  overflow: visible;
}

.purchase-assurance-hero::after {
  content: none;
}

.purchase-assurance-copy {
  position: relative;
  z-index: 2;
  width: 100%;
  padding-top: 10px;
}

.purchase-shield-pill {
  min-height: 38px;
  padding-right: 16px;
}

.purchase-shield-pill > img {
  width: 27px;
  height: 30px;
  margin-left: 0;
}

.purchase-assurance-hero h2 {
  margin-top: 18px;
  font-size: clamp(1.42rem, 5.4vw, 1.48rem);
  line-height: 1.25;
}

.purchase-assurance-hero h2 span {
  white-space: nowrap;
}

.purchase-assurance-hero p:not(.purchase-pill) {
  margin: 14px 0 0;
  color: var(--purchase-navy);
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1.48;
  white-space: nowrap;
}

.purchase-woman-box {
  position: relative;
  z-index: 0;
  width: 100%;
  height: 214px;
  margin: 0;
  overflow: visible;
}

.purchase-woman {
  position: absolute;
  top: -16px;
  right: -16px;
  width: 196px;
  max-width: none;
  opacity: 0.98;
  pointer-events: none;
}

.purchase-assurance-grid article {
  min-height: 184px;
  padding-top: 18px;
}

.purchase-bottom {
  padding-top: 18px;
}

.purchase-bottom-card {
  padding: 16px;
}

.purchase-bottom-card > .purchase-pill {
  display: flex;
  width: fit-content;
  margin: 0 auto;
}

.purchase-bottom-card h2 {
  margin: 16px 0 16px;
  text-align: center;
  font-size: clamp(1.58rem, 7.1vw, 2rem);
}

.purchase-icon-field {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  min-height: 64px;
  padding: 7px 12px 7px 10px;
  border: 1.5px solid var(--purchase-line);
  border-radius: 8px;
  background: #fff;
}

.purchase-icon-field > img {
  width: 34px;
  height: 34px;
  object-fit: contain;
  justify-self: center;
}

.purchase-icon-field > div {
  min-width: 0;
  padding-left: 10px;
  border-left: 1px solid #d6e2ef;
}

.purchase-icon-field label {
  display: block;
  margin-bottom: 2px;
  font-size: 0.9rem;
}

.purchase-icon-field input {
  min-height: 26px;
  padding: 0;
  border: 0;
  border-radius: 0;
}

.purchase-home-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  min-height: 52px;
  margin-top: 12px;
  color: var(--purchase-navy);
  font-size: 1.04rem;
  font-weight: 700;
}

.purchase-home-link img {
  width: 28px;
  height: 28px;
  object-fit: contain;
}

.purchase-result[hidden] {
  display: none;
}

.purchase-result {
  margin-top: 12px;
  padding: 12px;
  border: 1px solid var(--purchase-line);
  border-radius: 10px;
  background: rgba(235, 247, 255, 0.94);
}

.purchase-result p {
  margin: 0 0 8px;
  color: var(--purchase-navy);
  font-size: 0.88rem;
  font-weight: 600;
  line-height: 1.55;
}

.purchase-result .hero-actions {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}

.purchase-result .button {
  min-height: 46px;
  font-size: 0.9rem;
}

.button-primary {
  color: #fff;
  border: 0;
  background: linear-gradient(110deg, #09a8ff, #0755ed 78%);
  box-shadow: 0 12px 22px rgba(8, 103, 239, 0.22);
}

.button-outline {
  color: var(--purchase-blue);
  border: 2px solid var(--purchase-blue);
  background: #fff;
}

body.thanks-preview-page {
  background: #eef8ff;
}

.thanks-lp {
  width: min(100%, 430px);
  margin: 0 auto;
  overflow: hidden;
  background:
    radial-gradient(circle at 92px 158px, rgba(8, 167, 255, 0.08), transparent 28%),
    linear-gradient(180deg, #fbfdff 0%, #eef8ff 56%, #f9fdff 100%);
}

.thanks-hero {
  position: relative;
  min-height: 458px;
  padding: 18px 0;
  overflow: hidden;
  background:
    radial-gradient(circle at 86% 33%, rgba(192, 228, 255, 0.72), transparent 26%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(241, 249, 255, 0.94));
}

.thanks-hero-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 142px;
  align-items: start;
  min-height: 420px;
}

.thanks-hero-copy {
  position: relative;
  z-index: 3;
  max-width: 252px;
  min-width: 0;
  padding-top: 0;
}

.thanks-hero h1 {
  margin: 0;
  max-width: 252px;
  color: var(--purchase-navy);
  font-size: clamp(1.58rem, 6.6vw, 1.86rem);
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.18;
}

.thanks-hero h1 span {
  display: block;
  white-space: nowrap;
}

.thanks-sub {
  margin: 18px 0 0;
  max-width: 178px;
  color: var(--purchase-navy);
  font-size: 0.96rem;
  font-weight: 700;
  line-height: 1.45;
}

.thanks-deadline {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-height: 38px;
  margin: 14px 0 0;
  padding: 0 8px 0 7px;
  color: #fff;
  border-radius: 999px;
  background: linear-gradient(110deg, #0aa8ff, #0754ed 78%);
  box-shadow: 0 12px 22px rgba(8, 103, 239, 0.22);
  font-size: 0.74rem;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
}

.thanks-deadline b {
  color: #fff35c;
  font-size: 1.34em;
}

.thanks-clock {
  position: relative;
  flex: 0 0 auto;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: #fff;
}

.thanks-clock::before,
.thanks-clock::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 31%;
  width: 3px;
  height: 36%;
  border-radius: 999px;
  background: var(--purchase-blue);
  transform-origin: 50% 100%;
  transform: translateX(-50%);
}

.thanks-clock::after {
  height: 32%;
  transform: translateX(-50%) rotate(90deg);
}

.thanks-note {
  max-width: 160px;
  margin: 18px 0 0;
  color: var(--purchase-navy);
  font-size: 0.86rem;
  font-weight: 600;
  line-height: 1.7;
}

.thanks-woman {
  position: absolute;
  right: -4px;
  top: 190px;
  z-index: 1;
  width: 185px;
  margin: 0;
  pointer-events: none;
}

.thanks-woman::before {
  content: "";
  position: absolute;
  inset: 16px 10px 48px 6px;
  z-index: -1;
  border-radius: 50%;
  background: rgba(221, 242, 255, 0.9);
}

.thanks-woman img {
  width: 100%;
  max-width: none;
  filter: drop-shadow(0 12px 24px rgba(8, 103, 239, 0.08));
}

@media (min-width: 390px) {
  .thanks-sub {
    max-width: 190px;
  }

  .thanks-deadline {
    gap: 6px;
    min-height: 40px;
    padding: 0 10px 0 8px;
    font-size: 0.82rem;
  }

  .thanks-clock {
    width: 26px;
    height: 26px;
  }

  .thanks-note {
    max-width: 170px;
  }

  .thanks-woman {
    right: -4px;
    top: 168px;
    width: 214px;
  }
}

.thanks-deco-hero::before {
  top: 34px;
  right: 26px;
}

.thanks-deco-hero::after {
  top: 82px;
  left: 19px;
  width: 19px;
  height: 19px;
  background: rgba(8, 167, 255, 0.42);
  border: 0;
}

.thanks-section {
  position: relative;
  padding: 20px 0;
}

.thanks-card,
.thanks-mail-card {
  border: 1px solid rgba(173, 203, 236, 0.92);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: var(--purchase-shadow);
}

.thanks-confirm-status {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}

.thanks-status-card {
  padding: 18px 14px 16px;
}

.thanks-card h2,
.thanks-mail-card h2 {
  margin: 0;
  color: var(--purchase-navy);
  text-align: center;
  font-size: 1.48rem;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.2;
}

.thanks-card h2::before,
.thanks-card h2::after {
  content: "";
  display: inline-block;
  width: 32px;
  height: 5px;
  margin: 0 12px 4px;
  background-image: radial-gradient(var(--purchase-blue) 2.5px, transparent 3px);
  background-size: 11px 5px;
  background-repeat: repeat-x;
}

.thanks-status-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 22px minmax(0, 1fr) 22px minmax(0, 1fr);
  gap: 8px;
  align-items: stretch;
  margin-top: 18px;
}

.thanks-status-grid article {
  display: grid;
  grid-template-rows: 56px minmax(0, 1fr);
  align-items: center;
  justify-items: center;
  box-sizing: border-box;
  height: 136px;
  min-width: 0;
  padding: 12px 5px 10px;
  overflow: hidden;
  border: 1px solid rgba(190, 216, 240, 0.92);
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 10px 20px rgba(8, 103, 239, 0.08);
}

.thanks-status-grid article.is-current {
  border-color: rgba(8, 103, 239, 0.42);
  background: linear-gradient(180deg, #fff, #f0f8ff);
}

.thanks-status-grid img {
  display: block;
  width: 62px;
  height: 56px;
  max-width: 100%;
  object-fit: contain;
}

.thanks-status-grid p {
  display: flex;
  align-items: center;
  min-height: 48px;
  margin: 6px 0 0;
  color: var(--purchase-navy);
  text-align: center;
  font-size: 0.82rem;
  font-weight: 700;
  line-height: 1.34;
}

.thanks-arrow {
  position: relative;
  display: grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border: 1px solid #b9d8f5;
  border-radius: 999px;
  background: #fff;
  box-shadow: 0 5px 12px rgba(8, 103, 239, 0.12);
}

.thanks-arrow::before {
  content: "";
  width: 7px;
  height: 7px;
  border-top: 2px solid var(--purchase-blue);
  border-right: 2px solid var(--purchase-blue);
  transform: rotate(45deg);
}

.thanks-deco-flow::before {
  top: 22px;
  right: 24px;
}

.thanks-deco-flow::after {
  left: 22px;
  bottom: 24px;
}

.thanks-flow-card {
  padding: 18px 22px 20px;
}

.thanks-flow-list {
  display: grid;
  gap: 0;
  margin: 20px 0 0;
  padding: 0;
  list-style: none;
}

.thanks-flow-list li {
  position: relative;
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  min-height: 54px;
}

.thanks-flow-list li:not(:last-child) {
  border-bottom: 2px dotted #bee0fa;
}

.thanks-flow-list li:not(:last-child)::before {
  content: "";
  position: absolute;
  left: 21px;
  top: 44px;
  height: 28px;
  border-left: 3px dotted var(--purchase-blue);
}

.thanks-flow-list span {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  width: 40px;
  height: 40px;
  border-radius: 999px;
  color: #fff;
  background: linear-gradient(180deg, #0aa6ff, #0754e8);
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1;
}

.thanks-flow-list p {
  margin: 0;
  color: var(--purchase-navy);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.45;
}

.thanks-flow-list b {
  color: var(--purchase-blue);
  font-size: 1.12em;
}

.thanks-mail-section {
  padding-top: 8px;
}

.thanks-mail-card {
  display: grid;
  grid-template-columns: 74px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  padding: 18px 16px;
  background:
    radial-gradient(circle at 42px 46px, rgba(8, 103, 239, 0.16), transparent 44px),
    rgba(242, 249, 255, 0.96);
}

.thanks-mail-card > img {
  width: 64px;
  height: 64px;
  padding: 14px;
  border-radius: 999px;
  background: linear-gradient(180deg, #9bd3ff, #0b67ef);
  object-fit: contain;
}

.thanks-mail-card h2 {
  text-align: left;
  color: var(--purchase-blue);
  font-size: 1.18rem;
}

.thanks-mail-card ul {
  display: grid;
  gap: 7px;
  margin: 12px 0 0;
  padding: 0;
  list-style: none;
}

.thanks-mail-card li {
  position: relative;
  padding-left: 24px;
  color: var(--purchase-navy);
  font-size: 0.84rem;
  font-weight: 600;
  line-height: 1.55;
}

.thanks-mail-card li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.38em;
  width: 15px;
  height: 15px;
  border-radius: 999px;
  background: var(--purchase-blue);
}

.thanks-mail-card li::after {
  content: "";
  position: absolute;
  left: 4px;
  top: calc(0.38em + 4px);
  width: 7px;
  height: 4px;
  border-bottom: 2px solid #fff;
  border-left: 2px solid #fff;
  transform: rotate(-45deg);
}

.thanks-nowrap {
  white-space: nowrap;
}

.thanks-cta-section {
  padding: 10px 0 26px;
}

.thanks-actions {
  display: grid;
  gap: 10px;
}

.thanks-cta {
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr) 18px;
  gap: 10px;
  align-items: center;
  min-height: 60px;
  padding: 0 18px;
  border-radius: 8px;
  font-size: 1.14rem;
  font-weight: 700;
  letter-spacing: 0;
}

.thanks-cta img {
  justify-self: center;
  width: 31px;
  height: 31px;
  object-fit: contain;
}

.thanks-cta i {
  width: 13px;
  height: 13px;
  border-top: 4px solid currentColor;
  border-right: 4px solid currentColor;
  transform: rotate(45deg);
}

.thanks-cta-primary {
  color: #fff;
  background: linear-gradient(110deg, #09a8ff, #0755ed 78%);
  box-shadow: 0 14px 24px rgba(8, 103, 239, 0.24);
}

.thanks-cta-primary img {
  filter: brightness(0) invert(1);
}

.thanks-cta-secondary {
  color: var(--purchase-blue);
  border: 2px solid var(--purchase-blue);
  background: #fff;
}

.thanks-secure-note {
  margin: 14px 0 0;
  color: var(--purchase-navy);
  text-align: center;
  font-size: 0.78rem;
  font-weight: 600;
  line-height: 1.45;
}

.thanks-secure-note::before {
  content: "";
  display: inline-block;
  width: 14px;
  height: 14px;
  margin-right: 6px;
  border-radius: 3px;
  background: var(--purchase-blue);
  vertical-align: -2px;
}

@media (max-width: 374px) {
  .purchase-brand {
    font-size: 0.92rem;
  }

  .purchase-inner {
    width: min(348px, calc(100% - 24px));
  }

  .purchase-hero-title {
    font-size: 2.02rem;
  }

  .purchase-price span {
    font-size: 2.86rem;
  }

  .purchase-timeline article {
    grid-template-columns: 68px minmax(0, 1fr);
    padding-inline: 12px;
  }

  .purchase-timeline article > img {
    width: 66px;
    height: 64px;
  }

  .purchase-confirm-grid,
  .purchase-assurance-grid {
    gap: 6px;
  }

  .purchase-confirm-grid article,
  .purchase-assurance-grid article {
    padding-inline: 7px;
  }
}
