.ocr-tools-content,
.ocr-tool,
.ocr-tool-teaser {
  --ocr-ink: #151b22;
  --ocr-muted: #55616d;
  --ocr-line: #d8e1e8;
  --ocr-soft: #f4f7f8;
  --ocr-paper: #ffffff;
  --ocr-navy: #04384c;
  --ocr-felt: #0b584c;
  --ocr-felt-dark: #07333a;
  --ocr-blue: #2b63d9;
  --ocr-green: #0b985f;
  --ocr-line-green: #00b900;
  --ocr-red: #e44141;
  --ocr-gold: #bc8427;
  --ocr-shadow: 0 20px 54px rgba(4, 56, 76, .12);
  color: var(--ocr-ink);
}

.ocr-tools-page #content {
  padding-top: clamp(28px, 5vw, 58px);
}

.ocr-tools-route .l-mainContent__inner {
  max-width: 1120px;
}

.ocr-tools-content a {
  text-underline-offset: .18em;
}

.ocr-tools-index,
.ocr-tool {
  color: var(--ocr-ink);
}

.ocr-tool [hidden] {
  display: none !important;
}

.ocr-tools-index {
  padding: 0 0 58px;
}

.ocr-tools-index__hero,
.ocr-tool__hero {
  background:
    linear-gradient(135deg, rgba(4, 56, 76, .98), rgba(11, 88, 76, .96));
  border: 1px solid rgba(255, 255, 255, .16);
  border-radius: 10px;
  box-shadow: var(--ocr-shadow);
  color: #fff;
  overflow: hidden;
  position: relative;
}

.ocr-tools-index__hero::before,
.ocr-tool__hero::before {
  background:
    linear-gradient(90deg, rgba(255, 255, 255, .09) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255, 255, 255, .07) 1px, transparent 1px);
  background-size: 34px 34px;
  content: "";
  inset: 0;
  opacity: .28;
  pointer-events: none;
  position: absolute;
}

.ocr-tools-index__hero {
  align-items: stretch;
  display: grid;
  gap: 28px;
  grid-template-columns: minmax(0, 1fr) 340px;
  min-height: 310px;
  padding: clamp(28px, 4.5vw, 46px);
}

.ocr-tools-index__hero-copy,
.ocr-tools-index__hero-panel,
.ocr-tool__hero-copy,
.ocr-tool__status {
  position: relative;
}

.ocr-tools-index__eyebrow,
.ocr-tool__eyebrow,
.ocr-tool-teaser__eyebrow {
  color: inherit;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0;
  line-height: 1.3;
  margin: 0 0 10px;
  text-transform: uppercase;
}

.ocr-tools-index__eyebrow,
.ocr-tool__eyebrow {
  color: #cfe6ff;
}

.ocr-tools-index h1,
.ocr-tool h1 {
  color: inherit;
  font-size: clamp(30px, 4vw, 44px);
  font-weight: 800;
  letter-spacing: 0;
  line-height: 1.23;
  margin: 0;
  max-width: 760px;
  overflow-wrap: anywhere;
}

.ocr-tools-content .ocr-tool h1 {
  font-size: clamp(30px, 4vw, 44px) !important;
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.ocr-tools-index__lead,
.ocr-tool__lead {
  color: rgba(255, 255, 255, .84);
  font-size: 16px;
  line-height: 1.85;
  margin: 16px 0 0;
  max-width: 760px;
  overflow-wrap: anywhere;
}

.ocr-tools-index__stats {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 24px;
}

.ocr-tools-index__stats span {
  align-items: center;
  background: rgba(255, 255, 255, .11);
  border: 1px solid rgba(255, 255, 255, .2);
  border-radius: 8px;
  color: rgba(255, 255, 255, .76);
  display: inline-flex;
  font-size: 12px;
  font-weight: 700;
  gap: 8px;
  line-height: 1.25;
  min-height: 42px;
  padding: 9px 12px;
}

.ocr-tools-index__stats strong {
  color: #fff;
  font-size: 17px;
}

.ocr-tools-index__hero-panel {
  align-self: center;
  background: rgba(255, 255, 255, .1);
  border: 1px solid rgba(255, 255, 255, .18);
  border-radius: 10px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .12);
  display: grid;
  gap: 16px;
  padding: 18px;
}

.ocr-tools-index__deck {
  display: flex;
  min-height: 118px;
  position: relative;
}

.ocr-tools-index__deck span,
.ocr-tool__card-stack span,
.ocr-tool-teaser__visual span {
  align-items: center;
  background: #fff;
  border: 1px solid rgba(4, 56, 76, .18);
  border-radius: 8px;
  color: var(--ocr-navy);
  display: inline-flex;
  font-weight: 900;
  justify-content: center;
  line-height: 1;
}

.ocr-tools-index__deck span {
  box-shadow: 0 18px 30px rgba(0, 0, 0, .16);
  font-size: 31px;
  height: 112px;
  position: absolute;
  top: 3px;
  width: 84px;
}

.ocr-tools-index__deck span:first-child {
  left: 56px;
  transform: rotate(-7deg);
}

.ocr-tools-index__deck span:last-child {
  color: var(--ocr-red);
  left: 136px;
  transform: rotate(6deg);
}

.ocr-tools-index__summary {
  display: grid;
  gap: 8px;
}

.ocr-tools-index__summary span {
  align-items: center;
  background: rgba(255, 255, 255, .9);
  border-radius: 8px;
  color: var(--ocr-ink);
  display: flex;
  font-size: 14px;
  font-weight: 800;
  gap: 10px;
  justify-content: space-between;
  line-height: 1.35;
  min-height: 42px;
  padding: 10px 12px;
}

.ocr-tools-index__summary strong {
  color: var(--ocr-blue);
  font-size: 12px;
}

.ocr-tools-index__section-head {
  align-items: end;
  border-bottom: 2px solid var(--ocr-navy);
  display: grid;
  gap: 16px;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 440px);
  margin-top: 34px;
  padding-bottom: 16px;
}

.ocr-tools-content .ocr-tools-index__section-head h2,
.ocr-tools-content .ocr-tool-teaser h2,
.ocr-tools-content .ocr-tool__calculator h2,
.ocr-tools-content .ocr-tool__scratch h2,
.ocr-tools-content .ocr-tool__result h2,
.ocr-tools-content .ocr-tool__result h3,
.ocr-tools-content .ocr-promo-section h2,
.ocr-tools-content .ocr-promo-section h3,
.ocr-tools-content .ocr-tools-managed-content h2 {
  background: none !important;
  border: 0 !important;
  box-shadow: none !important;
  color: var(--ocr-ink);
  padding: 0 !important;
}

.ocr-tools-content .ocr-tools-index__section-head h2::before,
.ocr-tools-content .ocr-tools-index__section-head h2::after,
.ocr-tools-content .ocr-tool-teaser h2::before,
.ocr-tools-content .ocr-tool-teaser h2::after,
.ocr-tools-content .ocr-tool__calculator h2::before,
.ocr-tools-content .ocr-tool__calculator h2::after,
.ocr-tools-content .ocr-tool__scratch h2::before,
.ocr-tools-content .ocr-tool__scratch h2::after,
.ocr-tools-content .ocr-tool__result h2::before,
.ocr-tools-content .ocr-tool__result h2::after,
.ocr-tools-content .ocr-tool__result h3::before,
.ocr-tools-content .ocr-tool__result h3::after,
.ocr-tools-content .ocr-promo-section h2::before,
.ocr-tools-content .ocr-promo-section h2::after,
.ocr-tools-content .ocr-promo-section h3::before,
.ocr-tools-content .ocr-promo-section h3::after,
.ocr-tools-content .ocr-tools-managed-content h2::before,
.ocr-tools-content .ocr-tools-managed-content h2::after {
  content: none !important;
}

.ocr-tools-index__section-head h2 {
  font-size: 25px;
  line-height: 1.35;
  margin: 0;
}

.ocr-tools-index__section-head p {
  color: var(--ocr-muted);
  font-size: 14px;
  line-height: 1.75;
  margin: 0;
}

.ocr-tools-index__grid {
  display: grid;
  gap: 18px;
  margin-top: 22px;
}

.ocr-tools-index__note,
.ocr-tool__disclaimer {
  color: var(--ocr-muted);
  font-size: 12px;
  line-height: 1.7;
  margin-top: 18px;
}

.ocr-tools-page #scrollDivFixedTop,
.ocr-tools-page #scrollDivFixedBottom,
.ocr-tools-page #exitPopup {
  display: none !important;
}

.ocr-tools-eligibility {
  align-items: center;
  background: #fffaf0;
  border: 1px solid rgba(188, 132, 39, .42);
  border-left: 6px solid var(--ocr-gold);
  border-radius: 10px;
  display: grid;
  gap: 18px;
  grid-template-columns: minmax(0, 1fr) minmax(240px, .72fr);
  margin-top: 18px;
  padding: 18px 20px;
}

.ocr-tools-eligibility strong {
  color: var(--ocr-ink);
  display: block;
  font-size: 16px;
  line-height: 1.4;
  margin-bottom: 6px;
}

.ocr-tools-eligibility p {
  color: var(--ocr-muted);
  font-size: 13px;
  line-height: 1.75;
  margin: 0;
}

.ocr-tools-eligibility ul {
  display: grid;
  gap: 8px;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.ocr-tools-eligibility li {
  background: #fff;
  border: 1px solid rgba(188, 132, 39, .22);
  border-radius: 999px;
  color: var(--ocr-ink);
  font-size: 12px;
  font-weight: 900;
  line-height: 1.3;
  margin: 0 !important;
  padding: 8px 11px;
}

.ocr-tools-managed-content {
  border-top: 1px solid var(--ocr-line);
  color: var(--ocr-ink);
  margin-top: 34px;
  padding-top: 28px;
}

.ocr-tools-managed-content > :first-child {
  margin-top: 0;
}

.ocr-tools-managed-content h2 {
  border-left: 5px solid var(--ocr-navy) !important;
  font-size: 23px;
  line-height: 1.45;
  margin: 0 0 14px;
  padding-left: 14px !important;
}

.ocr-tools-managed-content p {
  color: var(--ocr-muted);
  line-height: 1.9;
}

.ocr-tool {
  padding: 0 0 56px;
}

.ocr-tool__hero {
  align-items: stretch;
  display: grid;
  gap: 28px;
  grid-template-columns: minmax(0, 1fr) 310px;
  padding: clamp(28px, 4.4vw, 44px);
}

.ocr-tool--compact {
  padding: 0;
}

.ocr-tool--compact .ocr-tool__hero {
  grid-template-columns: 1fr;
  padding: 20px;
}

.ocr-tool--compact .ocr-tool__status,
.ocr-tool--compact .ocr-tool__hero-tags {
  display: none;
}

.ocr-tool__hero-copy {
  min-width: 0;
}

.ocr-tool__hero-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 22px;
}

.ocr-tool__hero-tags span {
  background: rgba(255, 255, 255, .12);
  border: 1px solid rgba(255, 255, 255, .2);
  border-radius: 999px;
  color: rgba(255, 255, 255, .88);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.2;
  padding: 8px 11px;
}

.ocr-tool__status {
  align-self: center;
  display: grid;
  gap: 12px;
  min-height: 0;
}

.ocr-tool__status-visual {
  overflow: hidden;
  position: relative;
}

.ocr-tool__status-visual img {
  border-radius: 12px;
  box-shadow: 0 22px 42px rgba(3, 29, 40, .24);
  display: block;
  height: auto;
  width: 100%;
}

.ocr-tool__table-badge {
  align-items: center;
  background: rgba(188, 132, 39, .96);
  border-radius: 999px;
  box-shadow: 0 10px 24px rgba(3, 29, 40, .18);
  color: #fff;
  display: inline-flex;
  font-size: 12px;
  font-weight: 900;
  left: 18px;
  line-height: 1.2;
  padding: 8px 12px;
  position: absolute;
  top: 18px;
  z-index: 1;
}

.ocr-tool__card-stack {
  height: 116px;
  position: relative;
}

.ocr-tool__card-stack span {
  box-shadow: 0 18px 30px rgba(0, 0, 0, .18);
  font-size: 30px;
  height: 106px;
  position: absolute;
  top: 4px;
  width: 82px;
}

.ocr-tool__card-stack span:first-child {
  left: 52px;
  transform: rotate(-7deg);
}

.ocr-tool__card-stack span:last-child {
  color: var(--ocr-red);
  left: 126px;
  transform: rotate(7deg);
}

.ocr-tool__status-list {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ocr-tool__status-list span {
  align-items: center;
  background: rgba(255, 255, 255, .14);
  border: 1px solid rgba(255, 255, 255, .16);
  border-radius: 10px;
  color: rgba(255, 255, 255, .8);
  display: grid;
  gap: 2px;
  font-size: 12px;
  font-weight: 800;
  line-height: 1.25;
  min-height: 54px;
  padding: 10px 12px;
}

.ocr-tool__status-list strong {
  color: #fff;
  font-size: 13px;
}

.ocr-tool__form {
  display: grid;
  gap: 18px;
  margin-top: 22px;
}

.ocr-tool__fieldset {
  background: var(--ocr-paper);
  border: 1px solid var(--ocr-line);
  border-radius: 10px;
  box-shadow: 0 12px 32px rgba(4, 56, 76, .07);
  margin: 0;
  padding: 20px;
}

.ocr-tool__fieldset legend {
  align-items: center;
  color: var(--ocr-ink);
  display: flex;
  font-size: 18px;
  font-weight: 900;
  gap: 10px;
  line-height: 1.45;
  margin: 0 0 14px;
  padding: 0;
}

.ocr-tool__fieldset legend span {
  align-items: center;
  background: var(--ocr-navy);
  border-radius: 999px;
  color: #fff;
  display: inline-flex;
  flex: 0 0 auto;
  font-size: 12px;
  height: 30px;
  justify-content: center;
  width: 30px;
}

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

.ocr-tool__option {
  background: linear-gradient(180deg, #fff, #f7fafb);
  border: 1px solid var(--ocr-line);
  border-radius: 8px;
  cursor: pointer;
  display: grid;
  gap: 12px;
  grid-template-columns: 22px minmax(0, 1fr);
  min-height: 104px;
  padding: 15px;
  transition: border-color .18s ease, background-color .18s ease, box-shadow .18s ease, transform .18s ease;
}

.ocr-tool__option:hover {
  border-color: rgba(4, 56, 76, .38);
  transform: translateY(-1px);
}

.ocr-tool__option:has(input:checked) {
  background: #f0f7ff;
  border-color: var(--ocr-blue);
  box-shadow: inset 0 0 0 1px rgba(43, 99, 217, .12), 0 12px 24px rgba(43, 99, 217, .1);
}

.ocr-tool__option input {
  accent-color: var(--ocr-blue);
  height: 18px;
  margin: 3px 0 0;
  width: 18px;
}

.ocr-tool__option-body {
  display: grid;
  gap: 6px;
  min-width: 0;
}

.ocr-tool__option-title {
  color: var(--ocr-ink);
  font-size: 15px;
  font-weight: 900;
  line-height: 1.45;
}

.ocr-tool__option-hint {
  color: var(--ocr-muted);
  font-size: 13px;
  line-height: 1.6;
}

.ocr-tool__calculator {
  background:
    linear-gradient(90deg, rgba(228, 193, 118, .1), transparent 42%),
    linear-gradient(135deg, #083137 0%, #075244 54%, #061c26 100%);
  border: 1px solid rgba(228, 193, 118, .22);
  border-radius: 10px;
  box-shadow: 0 18px 42px rgba(4, 35, 38, .15);
  color: #fff;
  display: grid;
  gap: 18px 24px;
  grid-template-columns: minmax(210px, .36fr) minmax(0, .64fr);
  overflow: hidden;
  padding: 20px;
  position: relative;
  scroll-margin-top: 96px;
}

.ocr-tool__calculator::before {
  background:
    linear-gradient(90deg, rgba(255, 255, 255, .08) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255, 255, 255, .06) 1px, transparent 1px);
  background-size: 30px 30px;
  content: "";
  inset: 0;
  opacity: .14;
  pointer-events: none;
  position: absolute;
}

.ocr-tool__calculator::after {
  background: linear-gradient(180deg, rgba(255, 255, 255, .1), transparent);
  content: "";
  height: 1px;
  inset: 0 20px auto;
  opacity: .44;
  pointer-events: none;
  position: absolute;
  width: auto;
}

.ocr-tool__calculator-head,
.ocr-tool__calculator-grid {
  position: relative;
  z-index: 1;
}

.ocr-tool__calculator-head {
  align-content: start;
  align-items: start;
  display: grid;
  gap: 12px;
  grid-template-columns: 34px minmax(0, 1fr);
  max-width: none;
  min-width: 0;
}

.ocr-tool__calculator-head > span {
  align-items: center;
  background: #e4c176;
  border: 1px solid rgba(255, 255, 255, .32);
  border-radius: 50%;
  color: #062f34;
  display: inline-flex;
  flex: 0 0 auto;
  font-size: 14px;
  font-weight: 900;
  height: 34px;
  justify-content: center;
  line-height: 1;
  width: 34px;
}

.ocr-tools-content .ocr-tool__calculator h2 {
  background: none !important;
  border: 0 !important;
  box-shadow: none !important;
  color: #fff;
  font-size: clamp(20px, 2vw, 26px);
  letter-spacing: 0;
  line-height: 1.18;
  margin: 0 !important;
  overflow-wrap: anywhere;
  padding: 0 !important;
}

.ocr-tool__calculator-head p {
  color: rgba(235, 250, 246, .76);
  font-size: 12px;
  line-height: 1.6;
  margin: 8px 0 0;
  max-width: 32ch;
}

.ocr-tool__calculator-grid {
  align-self: stretch;
  background: rgba(1, 23, 28, .18);
  border: 1px solid rgba(255, 255, 255, .1);
  border-radius: 10px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .06);
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  overflow: visible;
  padding: 10px;
}

.ocr-tool__calculator-field {
  background: rgba(255, 255, 255, .055);
  border: 1px solid rgba(255, 255, 255, .09);
  border-radius: 8px;
  display: grid;
  gap: 8px;
  min-width: 0;
  padding: 12px;
}

.ocr-tool__calculator-field:focus-within {
  border-color: rgba(228, 193, 118, .72);
  box-shadow: 0 0 0 2px rgba(228, 193, 118, .16);
}

.ocr-tool__calculator-label {
  color: rgba(235, 250, 246, .78);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.ocr-tool__calculator-control {
  align-items: center;
  background: rgba(2, 22, 28, .58);
  border: 1px solid rgba(228, 193, 118, .24);
  border-radius: 8px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .06);
  color: #fff;
  display: flex;
  min-height: 46px;
  overflow: hidden;
}

.ocr-tool__calculator-control em {
  color: #e4c176;
  flex: 0 0 auto;
  font-size: 15px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  padding: 0 10px;
}

.ocr-tool__calculator-input {
  background: transparent;
  border: 0;
  color: #fff;
  font-size: 19px;
  font-weight: 900;
  line-height: 1.2;
  min-width: 0;
  outline: 0;
  padding: 9px 10px;
  width: 100%;
}

.ocr-tool__calculator-input[type="range"] {
  accent-color: #e4c176;
  appearance: none;
  cursor: pointer;
  height: 32px;
  padding: 0;
}

.ocr-tool__calculator-input[type="range"]::-webkit-slider-runnable-track {
  background:
    linear-gradient(90deg, rgba(255, 255, 255, .22) 1px, transparent 1px) 0 50% / 11.111% 14px repeat-x,
    linear-gradient(90deg, #e4c176 0%, #e4c176 var(--ocr-range-progress, 50%), rgba(255, 255, 255, .2) var(--ocr-range-progress, 50%), rgba(255, 255, 255, .2) 100%);
  border: 1px solid rgba(255, 255, 255, .18);
  border-radius: 999px;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, .28);
  height: 10px;
}

.ocr-tool__calculator-input[type="range"]::-webkit-slider-thumb {
  appearance: none;
  background:
    radial-gradient(circle at 50% 50%, #ffe3a3 0 22%, #e4c176 23% 58%, #b9791f 59% 100%);
  border: 3px solid #062f34;
  border-radius: 999px;
  box-shadow: 0 0 0 2px rgba(228, 193, 118, .35), 0 8px 18px rgba(1, 18, 23, .45);
  height: 26px;
  margin-top: -9px;
  width: 26px;
}

.ocr-tool__calculator-input[type="range"]::-moz-range-track {
  background: rgba(255, 255, 255, .2);
  border: 1px solid rgba(255, 255, 255, .18);
  border-radius: 999px;
  height: 10px;
}

.ocr-tool__calculator-input[type="range"]::-moz-range-progress {
  background: #e4c176;
  border-radius: 999px;
  height: 10px;
}

.ocr-tool__calculator-input[type="range"]::-moz-range-thumb {
  background: #e4c176;
  border: 3px solid #062f34;
  border-radius: 999px;
  box-shadow: 0 0 0 2px rgba(228, 193, 118, .35), 0 8px 18px rgba(1, 18, 23, .45);
  height: 22px;
  width: 22px;
}

.ocr-tool__calculator-input:focus-visible {
  box-shadow: none;
}

.ocr-tool__calculator-input option {
  color: var(--ocr-ink);
}

.ocr-tool__calculator-input[type="number"] {
  appearance: textfield;
}

.ocr-tool--comparison .ocr-tool__scratch {
  display: none;
}

.ocr-tool__calculator-checkbox {
  accent-color: #e4c176;
  cursor: pointer;
  flex: 0 0 auto;
  height: 22px;
  margin: 0 12px;
  padding: 0;
  width: 22px;
}

.ocr-tool__calculator-field:has(.ocr-tool__calculator-checkbox) {
  grid-column: 1 / -1;
}

.ocr-tool__calculator-field:has(.ocr-tool__calculator-checkbox) .ocr-tool__calculator-control {
  justify-content: flex-start;
  min-height: 42px;
}

.ocr-tool__calculator-input[type="number"]::-webkit-outer-spin-button,
.ocr-tool__calculator-input[type="number"]::-webkit-inner-spin-button {
  appearance: none;
  margin: 0;
}

.ocr-tool__calculator-output {
  color: #e4c176;
  font-size: 19px;
  font-weight: 900;
  line-height: 1.2;
}

.ocr-tool__calculator-field:has(.ocr-tool__calculator-input[type="range"]) {
  align-items: center;
  grid-template-columns: minmax(0, 1fr) auto;
}

.ocr-tool__calculator-field:has(.ocr-tool__calculator-input[type="range"]) .ocr-tool__calculator-label {
  grid-column: 1;
  grid-row: 1;
}

.ocr-tool__calculator-field:has(.ocr-tool__calculator-input[type="range"]) .ocr-tool__calculator-control {
  grid-column: 1 / -1;
  grid-row: 2;
  min-height: 54px;
  overflow: visible;
  padding: 0 16px;
}

.ocr-tool__calculator-field:has(.ocr-tool__calculator-input[type="range"]) .ocr-tool__calculator-control em {
  display: none;
}

.ocr-tool__calculator-field:has(.ocr-tool__calculator-input[type="range"]) .ocr-tool__calculator-output {
  background: #e4c176;
  border: 1px solid rgba(255, 255, 255, .24);
  border-radius: 999px;
  color: #062f34;
  font-size: 14px;
  grid-column: 2;
  grid-row: 1;
  justify-self: end;
  min-width: 54px;
  padding: 6px 10px;
  text-align: center;
}

.ocr-tool__actions {
  align-items: center;
  background: #f8fbfa;
  border: 1px solid rgba(4, 56, 76, .14);
  border-radius: 12px;
  box-shadow: 0 14px 34px rgba(4, 56, 76, .07);
  display: grid;
  gap: 14px;
  grid-template-columns: auto auto minmax(0, 1fr);
  justify-content: start;
  padding: 14px;
}

.ocr-tool__saved-note {
  color: var(--ocr-muted);
  font-size: 13px;
  font-weight: 800;
  line-height: 1.5;
  margin: 0;
}

.ocr-tool__submit,
.ocr-tool__reset,
.ocr-tool__button,
.ocr-tool-teaser__button {
  align-items: center;
  background: var(--ocr-navy);
  border: 1px solid var(--ocr-navy);
  border-radius: 8px;
  color: #fff !important;
  cursor: pointer;
  display: inline-flex;
  font-size: 15px;
  font-weight: 900;
  justify-content: center;
  line-height: 1.25;
  min-height: 48px;
  padding: 12px 22px;
  text-decoration: none !important;
  transition: background-color .24s cubic-bezier(.16, 1, .3, 1), border-color .24s cubic-bezier(.16, 1, .3, 1), transform .24s cubic-bezier(.16, 1, .3, 1);
  will-change: transform;
}

.ocr-tool__reset {
  background: #fff;
  color: var(--ocr-navy) !important;
}

.ocr-tool__submit:hover,
.ocr-tool__reset:hover,
.ocr-tool__button:hover,
.ocr-tool-teaser__button:hover {
  background: var(--ocr-felt);
  border-color: var(--ocr-felt);
  transform: translateY(-1px);
}

.ocr-tool__submit:active,
.ocr-tool__reset:active,
.ocr-tool__button:active,
.ocr-tool-teaser__button:active {
  transform: translateY(1px) scale(.99);
}

.ocr-tool__error {
  color: var(--ocr-red);
  font-size: 14px;
  font-weight: 800;
  margin: 0;
}

.ocr-tool__scratch {
  align-items: stretch;
  background:
    radial-gradient(circle at 13% 20%, rgba(228, 193, 118, .2), transparent 27%),
    radial-gradient(circle at 86% 16%, rgba(255, 255, 255, .07), transparent 24%),
    linear-gradient(135deg, #082d32 0%, #075849 48%, #051d28 100%);
  border: 1px solid rgba(228, 193, 118, .24);
  border-radius: 12px;
  box-shadow: 0 26px 58px rgba(4, 35, 38, .18);
  color: #fff;
  display: grid;
  gap: clamp(22px, 4vw, 46px);
  grid-template-columns: minmax(300px, .8fr) minmax(360px, 1.2fr);
  margin-top: 28px;
  overflow: hidden;
  padding: clamp(26px, 4vw, 42px);
  position: relative;
  scroll-margin-top: 96px;
}

.ocr-tool__scratch::before {
  background:
    linear-gradient(90deg, rgba(255, 255, 255, .08) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255, 255, 255, .06) 1px, transparent 1px);
  background-size: 30px 30px;
  content: "";
  inset: 0;
  opacity: .25;
  pointer-events: none;
  position: absolute;
}

.ocr-tool__scratch-copy,
.ocr-tool__scratch-card-wrap {
  min-width: 0;
  position: relative;
  z-index: 1;
}

.ocr-tool__scratch-copy {
  align-content: center;
  display: grid;
  gap: 14px;
}

.ocr-tool__scratch-kicker {
  color: #e4c176;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0;
  line-height: 1.2;
  margin: 0;
  text-transform: uppercase;
}

.ocr-tools-content .ocr-tool__scratch h2 {
  background: none !important;
  border: 0 !important;
  box-shadow: none !important;
  color: #fff;
  font-size: clamp(34px, 3.7vw, 46px);
  letter-spacing: 0;
  line-height: 1.04;
  margin: 0 !important;
  max-width: 100%;
  overflow-wrap: anywhere;
  padding: 0 !important;
}

.ocr-tool__scratch-status {
  color: rgba(235, 250, 246, .8);
  font-size: 15px;
  line-height: 1.85;
  margin: 0;
  max-width: 34ch;
}

.ocr-tool__scratch-card-wrap {
  align-content: center;
  display: grid;
  gap: 16px;
}

.ocr-tool__scratch-card {
  aspect-ratio: 16 / 7.5;
  background:
    radial-gradient(circle at 18% 18%, rgba(228, 193, 118, .24), transparent 24%),
    linear-gradient(135deg, #fff8df 0%, #ffffff 46%, #e9d095 100%);
  border: 1px solid rgba(228, 193, 118, .78);
  border-radius: 14px;
  box-shadow: 0 26px 58px rgba(3, 29, 40, .34);
  cursor: pointer;
  min-height: 210px;
  overflow: hidden;
  position: relative;
  touch-action: none;
  transform: translateZ(0);
}

.ocr-tool__scratch[data-scratch-state="locked"] .ocr-tool__scratch-card {
  cursor: default;
  opacity: .72;
}

.ocr-tool__scratch-card::after {
  background: linear-gradient(110deg, transparent 8%, rgba(255, 255, 255, .42) 42%, transparent 64%);
  content: "";
  inset: 0 auto 0 -55%;
  opacity: .28;
  pointer-events: none;
  position: absolute;
  transform: skewX(-18deg);
  transition: opacity .28s cubic-bezier(.16, 1, .3, 1), transform .28s cubic-bezier(.16, 1, .3, 1);
  width: 38%;
  z-index: 3;
}

.ocr-tool__scratch-card:hover::after {
  opacity: .5;
  transform: translateX(220%) skewX(-18deg);
}

.ocr-tool__scratch-prize,
.ocr-tool__scratch-canvas {
  inset: 0;
  position: absolute;
}

.ocr-tool__scratch-prize {
  align-content: center;
  background:
    radial-gradient(circle at 50% 42%, rgba(255, 242, 178, .62), transparent 34%),
    linear-gradient(135deg, #fff5c2 0%, #d6a51f 52%, #8f6209 100%);
  color: #1f1500;
  display: grid;
  gap: 12px;
  justify-items: center;
  padding: 26px;
  text-align: center;
}

.ocr-tool__scratch-prize::before,
.ocr-tool__scratch-prize::after {
  border: 1px solid rgba(198, 13, 18, .2);
  border-radius: 999px;
  content: "";
  height: 54px;
  position: absolute;
  top: calc(50% - 27px);
  width: 54px;
}

.ocr-tool__scratch-prize::before {
  left: -27px;
}

.ocr-tool__scratch-prize::after {
  right: -27px;
}

.ocr-tool__scratch-prize-label {
  background: rgba(6, 47, 52, .92);
  border-radius: 999px;
  color: #f4d890;
  display: inline-flex;
  font-size: 12px;
  font-weight: 900;
  line-height: 1.2;
  padding: 8px 14px;
}

.ocr-tool__scratch-prize strong {
  color: #1f1500;
  font-size: clamp(38px, 5vw, 60px);
  font-weight: 900;
  line-height: .95;
}

.ocr-tool__scratch-prize small {
  color: rgba(31, 21, 0, .68);
  font-size: 13px;
  font-weight: 800;
  line-height: 1.4;
  max-width: 28ch;
}

.ocr-tool__scratch-canvas {
  height: 100%;
  width: 100%;
  z-index: 2;
}

.ocr-tool__scratch[data-scratch-state="locked"] .ocr-tool__scratch-canvas,
.ocr-tool__scratch[data-scratch-state="revealed"] .ocr-tool__scratch-canvas {
  pointer-events: none;
}

.ocr-tool__scratch-reveal {
  align-items: center;
  background: rgba(255, 255, 255, .06);
  border: 1px solid rgba(228, 193, 118, .42);
  border-radius: 999px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .08);
  color: #f1d58d;
  cursor: pointer;
  display: inline-flex;
  font-size: 13px;
  font-weight: 900;
  justify-content: center;
  justify-self: end;
  line-height: 1.25;
  min-height: 38px;
  min-width: 0;
  padding: 9px 16px;
  transition: background-color .24s cubic-bezier(.16, 1, .3, 1), border-color .24s cubic-bezier(.16, 1, .3, 1), transform .24s cubic-bezier(.16, 1, .3, 1);
  will-change: transform;
}

.ocr-tool__scratch-reveal:hover {
  background: rgba(228, 193, 118, .14);
  border-color: rgba(228, 193, 118, .72);
  transform: translateY(-1px);
}

.ocr-tool__scratch-reveal:active {
  transform: translateY(1px) scale(.99);
}

.ocr-tool__scratch-reveal:disabled {
  cursor: not-allowed;
  opacity: .58;
  transform: none;
}

.ocr-tool__scratch[data-scratch-state="revealed"] .ocr-tool__scratch-reveal {
  display: none;
}

.ocr-tool__result {
  background: #fff;
  border: 2px solid var(--ocr-navy);
  border-radius: 10px;
  box-shadow: var(--ocr-shadow);
  margin-top: 24px;
  overflow: hidden;
  padding: 0;
  scroll-margin-top: 148px;
}

.ocr-tool__result-label {
  background: var(--ocr-navy);
  color: #fff;
  font-size: 13px;
  font-weight: 900;
  margin: 0;
  padding: 12px 18px;
}

.ocr-tool__result-body {
  padding: 22px;
}

.ocr-tool__result h2 {
  font-size: 25px;
  line-height: 1.35;
  margin: 0;
}

.ocr-tool__result-summary {
  color: var(--ocr-muted);
  font-size: 15px;
  line-height: 1.8;
  margin: 10px 0 0;
}

.ocr-tool__bonus-ticket {
  align-items: center;
  background:
    linear-gradient(135deg, #fff7e9 0%, #fff 54%, #f7dfaa 100%);
  border: 1px solid rgba(188, 132, 39, .46);
  border-radius: 10px;
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(120px, .32fr) minmax(160px, .38fr) minmax(0, 1fr);
  margin-top: 16px;
  overflow: hidden;
  padding: 14px 16px;
  position: relative;
}

.ocr-tool__bonus-ticket::before,
.ocr-tool__bonus-ticket::after {
  background: #fff;
  border: 1px solid rgba(188, 132, 39, .34);
  border-radius: 999px;
  content: "";
  height: 34px;
  position: absolute;
  top: calc(50% - 17px);
  width: 34px;
}

.ocr-tool__bonus-ticket::before {
  left: -18px;
}

.ocr-tool__bonus-ticket::after {
  right: -18px;
}

.ocr-tool__bonus-ticket span {
  color: #9b5a13;
  font-size: 12px;
  font-weight: 900;
  line-height: 1.3;
  text-transform: uppercase;
}

.ocr-tool__bonus-ticket strong {
  color: #c60d12;
  font-size: clamp(24px, 3vw, 34px);
  font-weight: 900;
  line-height: 1.1;
}

.ocr-tool__bonus-ticket small {
  color: var(--ocr-muted);
  font-size: 12px;
  line-height: 1.55;
}

.ocr-tool__boost {
  background: #071f29;
  border: 1px solid rgba(4, 56, 76, .18);
  border-radius: 10px;
  color: #fff;
  margin-top: 16px;
  overflow: hidden;
  padding: 18px;
}

.ocr-tools-content .ocr-tool__boost h3 {
  background: none !important;
  border: 0 !important;
  box-shadow: none !important;
  color: #fff;
  font-size: clamp(20px, 2.5vw, 28px);
  font-weight: 900;
  letter-spacing: 0;
  line-height: 1.35;
  margin: 0 !important;
  padding: 0 !important;
}

.ocr-tool__boost-inputs {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-top: 12px;
}

.ocr-tool__boost-inputs span {
  background: rgba(255, 255, 255, .075);
  border: 1px solid rgba(255, 255, 255, .13);
  border-radius: 999px;
  display: flex;
  gap: 8px;
  justify-content: space-between;
  min-width: 0;
  padding: 8px 10px;
}

.ocr-tool__boost-inputs small {
  color: rgba(255, 255, 255, .66);
  font-size: 11px;
  font-weight: 900;
  line-height: 1.25;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ocr-tool__boost-inputs strong {
  color: #f5d68c;
  flex: 0 0 auto;
  font-size: 12px;
  font-weight: 900;
  line-height: 1.25;
}

.ocr-tool__boost-summary {
  align-items: stretch;
  display: grid;
  gap: 8px;
  grid-template-columns: minmax(0, 1fr) 28px minmax(0, 1fr) 28px minmax(0, 1fr);
  margin-top: 16px;
}

.ocr-tool__boost-card {
  background: rgba(255, 255, 255, .08);
  border: 1px solid rgba(255, 255, 255, .14);
  border-radius: 10px;
  display: grid;
  gap: 6px;
  min-width: 0;
  padding: 14px;
}

.ocr-tool__boost-card span {
  color: rgba(255, 255, 255, .7);
  font-size: 12px;
  font-weight: 900;
  line-height: 1.25;
}

.ocr-tool__boost-card strong {
  color: #fff;
  font-size: clamp(28px, 4vw, 44px);
  font-weight: 900;
  letter-spacing: 0;
  line-height: 1;
}

.ocr-tool__boost-card--boosted {
  background: rgba(228, 193, 118, .15);
  border-color: rgba(228, 193, 118, .42);
}

.ocr-tool__boost-card--extra {
  background: linear-gradient(135deg, rgba(198, 13, 18, .26), rgba(93, 21, 36, .7));
  border-color: rgba(228, 193, 118, .42);
}

.ocr-tool__boost-card--extra strong {
  color: #f5d68c;
}

.ocr-tool__boost-arrow {
  align-items: center;
  color: #f5d68c;
  display: flex;
  font-size: 23px;
  font-weight: 900;
  justify-content: center;
}

.ocr-tool__boost-compare,
.ocr-tool__boost-breakdown {
  background: rgba(255, 255, 255, .065);
  border: 1px solid rgba(255, 255, 255, .11);
  border-radius: 12px;
  display: grid;
  gap: 12px;
  margin-top: 14px;
  padding: 14px;
}

.ocr-tool__boost-line {
  align-items: center;
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(118px, .28fr) minmax(0, 1fr) minmax(70px, auto);
}

.ocr-tool__boost-line > span {
  color: rgba(255, 255, 255, .78);
  font-size: 12px;
  font-weight: 900;
  line-height: 1.3;
}

.ocr-tool__boost-line strong {
  color: #fff;
  font-size: 14px;
  font-weight: 900;
  justify-self: end;
  line-height: 1.2;
}

.ocr-tool__boost-track {
  background: rgba(255, 255, 255, .14);
  border-radius: 999px;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, .25);
  display: block;
  height: 18px;
  overflow: hidden;
}

.ocr-tool__boost-track i {
  background: rgba(255, 255, 255, .72);
  border-radius: inherit;
  display: block;
  height: 100%;
}

.ocr-tool__boost-line--boosted .ocr-tool__boost-track i {
  background: linear-gradient(90deg, #f5d68c, #e54b32, #c60d12);
}

.ocr-tool__boost-breakdown-head {
  align-items: center;
  display: flex;
  gap: 12px;
  justify-content: space-between;
}

.ocr-tool__boost-breakdown-head span {
  color: rgba(255, 255, 255, .82);
  font-size: 13px;
  font-weight: 900;
}

.ocr-tool__boost-breakdown-head strong {
  color: #f5d68c;
  font-size: 18px;
  font-weight: 900;
}

.ocr-tool__boost-segment-track {
  background: rgba(255, 255, 255, .12);
  border-radius: 999px;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, .28);
  display: flex;
  height: 30px;
  overflow: hidden;
}

.ocr-tool__boost-segment {
  display: block;
  min-width: 10px;
}

.ocr-tool__boost-segment + .ocr-tool__boost-segment {
  border-left: 2px solid rgba(5, 28, 34, .72);
}

.ocr-tool__boost-legend {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ocr-tool__boost-legend-item {
  align-items: center;
  background: rgba(255, 255, 255, .06);
  border: 1px solid rgba(255, 255, 255, .1);
  border-radius: 9px;
  display: grid;
  gap: 8px;
  grid-template-columns: 12px minmax(0, 1fr) auto;
  min-width: 0;
  padding: 10px;
}

.ocr-tool__boost-legend-item i {
  border-radius: 999px;
  height: 12px;
  width: 12px;
}

.ocr-tool__boost-legend-item span {
  color: rgba(255, 255, 255, .78);
  font-size: 12px;
  font-weight: 900;
  line-height: 1.3;
  min-width: 0;
  overflow-wrap: anywhere;
}

.ocr-tool__boost-legend-item strong {
  color: #fff;
  font-size: 13px;
  font-weight: 900;
  justify-self: end;
}

.ocr-tool__boost-segment--registration,
.ocr-tool__boost-legend-item--registration i {
  background: #f3d28d;
}

.ocr-tool__boost-segment--deposit,
.ocr-tool__boost-legend-item--deposit i {
  background: #2b63d9;
}

.ocr-tool__boost-segment--rakeback,
.ocr-tool__boost-legend-item--rakeback i {
  background: #0b985f;
}

.ocr-tool__boost-segment--club,
.ocr-tool__boost-legend-item--club i {
  background: #c60d12;
}

.ocr-tool__boost-note {
  color: rgba(255, 255, 255, .7);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.45;
  margin: 14px 0 0;
}

.ocr-tool__result-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 18px;
}

.ocr-tool__result-panel {
  background: var(--ocr-soft);
  border: 1px solid var(--ocr-line);
  border-radius: 8px;
  padding: 16px;
}

.ocr-tool__result-panel h3 {
  font-size: 16px;
  line-height: 1.4;
  margin: 0 0 10px;
}

.ocr-tool__checklist,
.ocr-tool__watchlist {
  display: grid;
  gap: 8px;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.ocr-tool__checklist li,
.ocr-tool__watchlist li {
  color: var(--ocr-ink);
  font-size: 14px;
  line-height: 1.65;
  margin: 0 !important;
  padding-left: 22px;
  position: relative;
}

.ocr-tool__checklist li::before,
.ocr-tool__watchlist li::before {
  border-radius: 999px;
  content: "";
  height: 8px;
  left: 0;
  position: absolute;
  top: 9px;
  width: 8px;
}

.ocr-tool__checklist li::before {
  background: var(--ocr-green);
}

.ocr-tool__watchlist li::before {
  background: var(--ocr-red);
}

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

.ocr-tool__button {
  background: #fff;
  color: var(--ocr-navy) !important;
}

.ocr-tool__button:hover {
  color: #fff !important;
}

.ocr-tool__button--primary {
  background: var(--ocr-blue);
  border-color: var(--ocr-blue);
  color: #fff !important;
}

.ocr-tool__button--line {
  background: var(--ocr-line-green);
  border-color: var(--ocr-line-green);
  color: #fff !important;
}

.ocr-tool__button--affiliate {
  background: var(--ocr-gold);
  border-color: var(--ocr-gold);
  color: #fff !important;
}

.ocr-tool__offer-card {
  align-items: stretch;
  background: #fffaf0;
  border: 1px solid rgba(188, 132, 39, .36);
  border-radius: 12px;
  color: var(--ocr-ink) !important;
  display: grid;
  gap: 0;
  grid-template-columns: minmax(180px, 280px) minmax(0, 1fr);
  margin-top: 18px;
  overflow: hidden;
  text-decoration: none !important;
  transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}

.ocr-tool__offer-card:hover {
  border-color: rgba(198, 13, 18, .34);
  box-shadow: 0 16px 36px rgba(4, 56, 76, .1);
  transform: translateY(-1px);
}

.ocr-tool__offer-card-media {
  background: #fff;
  display: block;
  min-height: 148px;
}

.ocr-tool__offer-card-media img {
  display: block;
  height: 100%;
  min-height: 148px;
  object-fit: cover;
  width: 100%;
}

.ocr-tool__offer-card-body {
  align-content: center;
  display: grid;
  gap: 7px;
  padding: 18px;
}

.ocr-tool__offer-card-body strong {
  color: var(--ocr-ink);
  font-size: 19px;
  line-height: 1.35;
}

.ocr-tool__offer-card-meta {
  color: var(--ocr-muted);
  font-size: 13px;
  line-height: 1.45;
}

.ocr-tool__offer-card-code {
  background: #fff;
  border: 1px solid rgba(198, 13, 18, .2);
  border-radius: 999px;
  color: #c60d12;
  display: inline-flex;
  font-size: 13px;
  font-weight: 900;
  justify-self: start;
  line-height: 1.2;
  padding: 8px 11px;
}

.ocr-tool__code-helper {
  align-items: center;
  background: #f8fbfc;
  border: 1px solid var(--ocr-line);
  border-radius: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
  padding: 11px 12px;
}

.ocr-tool__code-helper-label {
  color: var(--ocr-muted);
  font-size: 13px;
  font-weight: 800;
  line-height: 1.4;
}

.ocr-tool__code-helper-value {
  background: #fff;
  border: 1px solid rgba(198, 13, 18, .2);
  border-radius: 999px;
  color: #c60d12;
  display: inline-flex;
  font-size: 13px;
  font-weight: 900;
  line-height: 1.2;
  padding: 8px 11px;
}

.ocr-tool__code-helper-button {
  margin-left: auto;
}

.ocr-tools-content .ocr-tool__repeat {
  border-top: 1px solid var(--ocr-line);
  margin-top: 24px;
  padding-top: 22px;
}

.ocr-tools-content .ocr-tool__repeat-head {
  align-items: flex-start;
  display: flex;
  gap: 18px;
  justify-content: space-between;
}

.ocr-tools-content .ocr-tool__repeat h3,
.ocr-tools-content .ocr-tool__repeat h4 {
  background: none !important;
  border: 0 !important;
  box-shadow: none !important;
  color: var(--ocr-ink);
  margin: 0 !important;
  padding: 0 !important;
}

.ocr-tools-content .ocr-tool__repeat h3 {
  font-size: 21px !important;
  line-height: 1.35 !important;
}

.ocr-tools-content .ocr-tool__repeat h4 {
  color: var(--ocr-navy);
  font-size: 12px !important;
  font-weight: 900;
  letter-spacing: 0;
  line-height: 1.35 !important;
}

.ocr-tools-content .ocr-tool__repeat-head p {
  color: var(--ocr-muted);
  font-size: 13px;
  line-height: 1.65;
  margin: 0;
  max-width: 520px;
}

.ocr-tools-content .ocr-tool__repeat-grid {
  background: #fff;
  border: 1px solid var(--ocr-line);
  border-radius: 10px;
  display: grid;
  gap: 0;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 14px;
  overflow: hidden;
}

.ocr-tools-content .ocr-tool__repeat-panel {
  background: #fbfdfe;
  border: 0;
  border-bottom: 1px solid var(--ocr-line);
  border-radius: 0;
  display: grid;
  gap: 8px;
  padding: 13px 15px;
}

.ocr-tools-content .ocr-tool__repeat-panel:nth-child(odd) {
  border-right: 1px solid var(--ocr-line);
}

.ocr-tools-content .ocr-tool__repeat-panel:nth-last-child(-n+2) {
  border-bottom: 1px solid var(--ocr-line);
}

.ocr-tools-content .ocr-tool__repeat-panel:last-child {
  border-bottom: 0;
}

.ocr-tools-content .ocr-tool__repeat-panel:last-child:nth-child(odd) {
  border-right: 0;
  grid-column: 1 / -1;
}

.ocr-tools-content .ocr-tool__repeat-item {
  align-items: center;
  color: var(--ocr-muted);
  cursor: pointer;
  display: flex;
  font-size: 13px;
  gap: 8px;
  line-height: 1.45;
  min-height: 26px;
}

.ocr-tool__repeat-item input {
  accent-color: var(--ocr-green);
  height: 15px;
  margin: 2px 0 0;
  width: 15px;
}

.ocr-tool__repeat-item:has(input:checked) span {
  color: var(--ocr-ink);
  text-decoration: line-through;
  text-decoration-color: rgba(11, 152, 95, .44);
}

.ocr-tools-content .ocr-tool__share {
  align-items: center;
  background:
    linear-gradient(135deg, #fffdfa 0%, #fff7ea 100%);
  border: 1px solid rgba(188, 132, 39, .34);
  border-radius: 12px;
  box-shadow: 0 14px 32px rgba(4, 56, 76, .08);
  display: grid;
  gap: 0;
  grid-template-columns: minmax(0, 1.38fr) minmax(250px, .62fr);
  margin-top: 22px;
  overflow: hidden;
}

.ocr-tool__share-visual {
  min-width: 0;
  padding: 18px 0 18px 18px;
}

.ocr-tool__share-banner-media {
  background: #082f34;
  border-radius: 10px 0 0 10px;
  min-height: 218px;
  overflow: hidden;
  position: relative;
}

.ocr-tool__share-banner-media::after {
  background: none;
  content: "";
  inset: 0;
  position: absolute;
}

.ocr-tool__share-banner-media img {
  display: block;
  height: 100%;
  min-height: 218px;
  object-fit: cover;
  width: 100%;
}

.ocr-tool__share-banner-highlights {
  bottom: 16px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  left: 16px;
  position: absolute;
  right: 16px;
  z-index: 1;
}

.ocr-tool__share-banner-highlight {
  background: rgba(4, 56, 76, .88);
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: 999px;
  color: #fff;
  display: inline-flex;
  font-size: 11px;
  font-weight: 900;
  line-height: 1.2;
  padding: 8px 10px;
  text-shadow: 0 2px 8px rgba(0, 0, 0, .22);
}

.ocr-tool__share-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
  padding: 24px 26px;
  position: relative;
}

.ocr-tool__share-copy::before {
  background: linear-gradient(180deg, var(--ocr-gold), rgba(188, 132, 39, 0));
  border-radius: 999px;
  content: "";
  height: 46px;
  left: 26px;
  position: absolute;
  top: 22px;
  width: 3px;
}

.ocr-tool__share-kicker {
  color: var(--ocr-blue);
  display: inline-flex;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .04em;
  line-height: 1.2;
  margin-bottom: 12px;
  text-transform: uppercase;
}

.ocr-tools-content .ocr-tool__share-copy h3 {
  background: none !important;
  border: 0 !important;
  box-shadow: none !important;
  color: var(--ocr-ink);
  font-size: clamp(15px, 1.6vw, 17px) !important;
  line-height: 1.4 !important;
  margin: 0 !important;
  max-width: 13ch;
  padding: 0 !important;
}

.ocr-tools-content .ocr-tool__share-copy p {
  color: var(--ocr-muted);
  font-size: 12px;
  line-height: 1.65;
  margin: 10px 0 0;
  max-width: 28ch;
}

.ocr-tool__share-benefits-title {
  color: var(--ocr-ink);
  font-size: 12px;
  font-weight: 900;
  line-height: 1.3;
  margin: 14px 0 0;
}

.ocr-tool__share-benefits {
  display: grid;
  gap: 7px;
  list-style: none;
  margin: 10px 0 0;
  max-width: 32ch;
  padding: 0;
}

.ocr-tool__share-benefits li {
  color: var(--ocr-ink);
  font-size: 12px;
  line-height: 1.55;
  margin: 0;
  padding-left: 16px;
  position: relative;
}

.ocr-tool__share-benefits li::before {
  background: var(--ocr-green);
  border-radius: 999px;
  content: "";
  height: 6px;
  left: 0;
  position: absolute;
  top: 7px;
  width: 6px;
}

.ocr-tool__share-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 18px;
}

.ocr-tool__share-button {
  align-items: center;
  background: #fff;
  border: 1px solid rgba(188, 132, 39, .7);
  border-radius: 999px;
  color: var(--ocr-navy) !important;
  cursor: pointer;
  display: inline-flex;
  font-size: 13px;
  font-weight: 900;
  justify-content: center;
  line-height: 1.25;
  min-height: 36px;
  padding: 8px 14px;
  text-decoration: none !important;
  transition: background-color .18s ease, border-color .18s ease, box-shadow .18s ease, color .18s ease, transform .18s ease;
}

.ocr-tool__share-button--primary {
  background: var(--ocr-navy);
  border-color: var(--ocr-navy);
  color: #fff !important;
}

.ocr-tool__share-button--download {
  background: rgba(4, 56, 76, .04);
  border-color: rgba(4, 56, 76, .14);
}

.ocr-tool__share-button:disabled,
.ocr-tool__share-button[aria-disabled="true"] {
  cursor: progress;
  opacity: .68;
  pointer-events: none;
}

.ocr-tool__share-button:hover {
  background: var(--ocr-navy);
  border-color: var(--ocr-navy);
  box-shadow: 0 10px 22px rgba(4, 56, 76, .14);
  color: #fff !important;
  transform: translateY(-1px);
}

.ocr-tool__share-button--native {
  background: var(--ocr-line-green);
  border-color: var(--ocr-line-green);
  color: #fff !important;
}

.ocr-tool-teaser {
  align-items: center;
  background: #fff;
  border: 1px solid var(--ocr-line, #d8e1e8);
  border-left: 6px solid var(--ocr-navy);
  border-radius: 10px;
  box-shadow: 0 16px 42px rgba(4, 56, 76, .08);
  display: grid;
  gap: 18px;
  grid-template-columns: minmax(0, 1fr) 112px auto;
  margin: 20px 0;
  padding: 22px;
}

.ocr-tool-teaser--full {
  margin: 0;
  padding: 26px;
}

.ocr-tool-teaser__eyebrow {
  color: var(--ocr-blue);
}

.ocr-tool-teaser h2 {
  color: var(--ocr-ink, #151b22);
  font-size: 24px;
  line-height: 1.38;
  margin: 0;
}

.ocr-tool-teaser p {
  color: var(--ocr-muted, #55616d);
  font-size: 14px;
  line-height: 1.75;
  margin: 9px 0 0;
}

.ocr-tool-teaser__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}

.ocr-tool-teaser__chips span {
  background: var(--ocr-soft);
  border: 1px solid var(--ocr-line);
  border-radius: 999px;
  color: var(--ocr-ink);
  font-size: 12px;
  font-weight: 900;
  line-height: 1.2;
  padding: 7px 10px;
}

.ocr-tool-teaser__visual {
  height: 92px;
  position: relative;
  width: 112px;
}

.ocr-tool-teaser__visual span {
  box-shadow: 0 12px 24px rgba(4, 56, 76, .12);
  height: 82px;
  position: absolute;
  top: 4px;
  width: 60px;
}

.ocr-tool-teaser__visual span:first-child {
  font-size: 22px;
  left: 12px;
  transform: rotate(-7deg);
}

.ocr-tool-teaser__visual span:last-child {
  color: var(--ocr-red);
  font-size: 15px;
  left: 50px;
  transform: rotate(7deg);
}

.ocr-tool-teaser__button {
  justify-self: end;
  white-space: nowrap;
}

.ocr-promo-section {
  margin-top: 28px;
}

.ocr-promo-section--tool {
  margin-top: 24px;
}

.ocr-promo-section__banner {
  align-items: stretch;
  background: linear-gradient(135deg, #feeed4 0%, #fff7e9 48%, #ffffff 100%);
  border: 1px solid #efcf99;
  border-radius: 10px;
  box-shadow: 0 16px 42px rgba(188, 132, 39, .13);
  display: grid;
  gap: 20px;
  grid-template-columns: minmax(0, 1fr) 245px;
  overflow: hidden;
  padding: 24px;
  position: relative;
}

.ocr-promo-section__banner::before {
  background: rgba(198, 13, 18, .12);
  content: "";
  height: 180px;
  position: absolute;
  right: -74px;
  top: -80px;
  transform: rotate(18deg);
  width: 220px;
}

.ocr-promo-section__copy,
.ocr-promo-offer {
  position: relative;
}

.ocr-promo-section__eyebrow {
  color: #a15a0b;
  font-size: 12px;
  font-weight: 900;
  line-height: 1.3;
  margin: 0 0 8px;
  text-transform: uppercase;
}

.ocr-promo-section h2 {
  color: var(--ocr-ink);
  font-size: 25px;
  line-height: 1.38;
  margin: 0;
}

.ocr-promo-section__copy p {
  color: var(--ocr-muted);
  font-size: 14px;
  line-height: 1.8;
  margin: 10px 0 0;
}

.ocr-promo-section__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 16px;
}

.ocr-promo-section__button {
  align-items: center;
  background: #fff;
  border: 1px solid #d8b16f;
  border-radius: 999px;
  color: var(--ocr-navy) !important;
  display: inline-flex;
  font-size: 13px;
  font-weight: 900;
  justify-content: center;
  line-height: 1.25;
  min-height: 40px;
  padding: 10px 14px;
  text-decoration: none !important;
  transition: background-color .18s ease, border-color .18s ease, color .18s ease, transform .18s ease;
}

.ocr-promo-section__button:hover {
  background: var(--ocr-navy);
  border-color: var(--ocr-navy);
  color: #fff !important;
  transform: translateY(-1px);
}

.ocr-promo-section__button--primary {
  background: #c60d12;
  border-color: #c60d12;
  color: #fff !important;
}

.ocr-promo-section__button--offer {
  background: var(--ocr-gold);
  border-color: var(--ocr-gold);
  color: #fff !important;
}

.ocr-promo-offer {
  align-self: center;
  background: #fff;
  border: 1px solid rgba(198, 13, 18, .22);
  border-radius: 10px;
  box-shadow: 0 14px 28px rgba(198, 13, 18, .1);
  display: grid;
  gap: 10px;
  justify-items: center;
  padding: 12px;
  text-align: center;
  text-decoration: none !important;
  transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}

.ocr-promo-offer:hover {
  border-color: rgba(198, 13, 18, .45);
  box-shadow: 0 18px 34px rgba(198, 13, 18, .14);
  transform: translateY(-1px);
}

.ocr-promo-offer img {
  border-radius: 7px;
  display: block;
  height: auto;
  width: 100%;
}

.ocr-promo-offer span {
  background: #c60d12;
  border-radius: 999px;
  color: #fff;
  display: inline-flex;
  font-size: 13px;
  font-weight: 900;
  line-height: 1.25;
  padding: 10px 14px;
}

.ocr-promo-offer em {
  background: #fff7e9;
  border: 1px solid rgba(198, 13, 18, .16);
  border-radius: 999px;
  color: #c60d12;
  display: inline-flex;
  font-size: 12px;
  font-style: normal;
  font-weight: 900;
  line-height: 1.25;
  padding: 7px 10px;
}

.ocr-promo-offer small {
  color: var(--ocr-muted);
  font-size: 11px;
  line-height: 1.45;
}

@media (max-width: 900px) {
  .ocr-tools-index__hero,
  .ocr-tools-index__section-head,
  .ocr-tools-eligibility,
	  .ocr-tool__hero,
	  .ocr-tool__options,
	  .ocr-tool__calculator,
	  .ocr-tool__scratch,
	  .ocr-tool__bonus-ticket,
	  .ocr-tool__result-grid,
	  .ocr-tool__share,
  .ocr-tool__offer-card,
  .ocr-tool__repeat-head,
  .ocr-promo-section__banner,
  .ocr-tool-teaser {
    grid-template-columns: 1fr;
  }

  .ocr-tool__status {
    min-height: 0;
  }

  .ocr-tools-route .l-mainContent__inner,
  .ocr-tools-content,
  .ocr-tool {
    max-width: calc(100vw - 40px) !important;
    min-width: 0 !important;
  }

  .ocr-tool__hero,
  .ocr-tool__form,
  .ocr-tool__scratch,
  .ocr-tool__result {
    box-sizing: border-box;
    max-width: calc(100vw - 40px) !important;
    min-width: 0 !important;
  }

  .ocr-tools-content .ocr-tool h1 {
    font-size: 26px !important;
    line-height: 1.28 !important;
    max-width: calc(100vw - 84px) !important;
  }

  .ocr-tool__hero-copy,
  .ocr-tool__lead,
  .ocr-tool__status,
  .ocr-tool__status-visual,
  .ocr-tool__status-list,
  .ocr-tool__hero-tags {
    max-width: calc(100vw - 84px) !important;
    min-width: 0;
    overflow-wrap: anywhere;
    width: 100%;
  }

  .ocr-tool__card-stack,
  .ocr-tools-index__deck,
  .ocr-tool-teaser__visual {
    display: none;
  }

  .ocr-tool__status-list,
  .ocr-tools-index__summary {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

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

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

  .ocr-tool__calculator-field {
    grid-column: span 1;
  }

  .ocr-tool__actions {
    grid-template-columns: auto auto;
  }

  .ocr-tool__saved-note,
  .ocr-tool__error {
    grid-column: 1 / -1;
  }

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

  .ocr-tool__share-visual {
    order: 1;
    padding: 14px 14px 0;
  }

  .ocr-tool__share-copy {
    order: 2;
    padding: 18px 18px 18px;
  }

  .ocr-tool__share-copy::before {
    left: 18px;
    top: 18px;
  }

  .ocr-tool__share-banner-media {
    border-radius: 8px;
    min-height: 188px;
  }

  .ocr-tool__share-banner-media img {
    min-height: 188px;
  }

	  .ocr-tool__share-banner-highlights {
	    bottom: 12px;
	    left: 12px;
	    right: 12px;
	  }

	  .ocr-tool__scratch-status {
	    max-width: none;
	  }

	  .ocr-tool__scratch-card {
	    min-height: 188px;
	  }
	}

@media (max-width: 600px) {
  .ocr-tools-page #content {
    padding-top: 18px;
  }

  .ocr-tools-route .l-mainContent__inner,
  .ocr-tools-content,
  .ocr-tool {
    max-width: calc(100vw - 40px) !important;
    min-width: 0 !important;
    width: calc(100vw - 40px) !important;
  }

  .ocr-tools-index__hero,
  .ocr-tool__hero {
    border-radius: 8px;
    grid-template-columns: minmax(0, 1fr) !important;
    margin-left: auto;
    margin-right: auto;
    max-width: calc(100vw - 40px) !important;
    padding: 22px;
    width: calc(100vw - 40px) !important;
  }

  .ocr-tools-index h1,
  .ocr-tool h1 {
    font-size: 26px;
    line-height: 1.28;
  }

  .ocr-tools-content .ocr-tool h1 {
    font-size: 26px !important;
    line-height: 1.28 !important;
    max-width: calc(100vw - 84px);
  }

  .ocr-tool__hero-copy,
  .ocr-tool__lead,
  .ocr-tool__status,
  .ocr-tool__status-visual,
  .ocr-tool__status-list,
  .ocr-tool__hero-tags {
    max-width: calc(100vw - 84px);
    min-width: 0;
    width: 100%;
  }

  .ocr-tools-index__stats,
  .ocr-tool__hero-tags {
    gap: 7px;
  }

  .ocr-tools-index__stats span,
  .ocr-tool__hero-tags span {
    font-size: 11px;
  }

	  .ocr-tool__fieldset,
	  .ocr-tool__calculator,
	  .ocr-tool__scratch,
	  .ocr-tool__result-body,
	  .ocr-tools-eligibility,
  .ocr-promo-section__banner,
  .ocr-tool-teaser {
    padding: 16px;
  }

  .ocr-tool__share {
    padding: 0;
  }

  .ocr-tool__share-visual {
    padding: 12px 12px 0;
  }

  .ocr-tool__share-copy {
    padding: 18px 16px 16px;
  }

  .ocr-tool__share-copy::before {
    left: 16px;
    top: 16px;
  }

  .ocr-tool__share-banner-media,
  .ocr-tool__share-banner-media img {
    min-height: 164px;
  }

  .ocr-tool__share-banner-highlights {
    gap: 6px;
  }

  .ocr-tool__share-banner-highlight {
    font-size: 10px;
    padding: 7px 9px;
  }

  .ocr-tools-content .ocr-tool__share-copy h3 {
    max-width: none;
  }

  .ocr-tools-index__summary,
  .ocr-tool__status-list,
  .ocr-tool__repeat-grid,
  .ocr-tool__calculator-grid,
  .ocr-tool__boost-inputs,
  .ocr-tool__boost-summary,
  .ocr-tool__boost-legend {
    grid-template-columns: 1fr;
  }

  .ocr-tool__boost-inputs span {
    border-radius: 10px;
  }

  .ocr-tool__boost-arrow {
    display: none;
  }

  .ocr-tool__boost-line {
    align-items: start;
    gap: 7px;
    grid-template-columns: 1fr;
  }

  .ocr-tool__boost-line strong {
    justify-self: start;
  }

	  .ocr-tool__option {
	    min-height: 0;
	  }

	  .ocr-tool__scratch-card {
	    aspect-ratio: 16 / 9.2;
	    min-height: 0;
	    width: 100%;
	  }

	  .ocr-tool__scratch-prize {
	    padding: 18px;
	  }

	  .ocr-tool__actions {
	    align-items: stretch;
    display: grid;
    grid-template-columns: 1fr;
  }

  .ocr-tool__calculator {
    gap: 14px;
    grid-template-columns: 1fr;
    padding: 16px;
  }

  .ocr-tool__calculator-head {
    grid-template-columns: 32px minmax(0, 1fr);
  }

  .ocr-tool__calculator-head > span {
    font-size: 13px;
    height: 32px;
    width: 32px;
  }

  .ocr-tools-content .ocr-tool__calculator h2 {
    font-size: 22px !important;
  }

  .ocr-tool__calculator-head p {
    max-width: none;
  }

  .ocr-tool__calculator-field {
    grid-column: span 1;
    padding: 12px;
  }

  .ocr-tool__calculator-input {
    font-size: 19px;
  }

  .ocr-tool__scratch-reveal {
    min-width: 0;
  }

  .ocr-tool__submit,
  .ocr-tool__reset,
	  .ocr-tool__button,
	  .ocr-tool__scratch-reveal,
	  .ocr-tool__share-button,
  .ocr-promo-section__button,
  .ocr-tool-teaser__button {
    justify-self: stretch;
    width: 100%;
  }
}

/* ==========================================================================
   和ポーカー — Japanese Poker / Lacquer Skin
   Site-aligned redesign on top of the base styles. Uses Swell tokens
   (#04384c urushi teal, #e44141 vermilion accent) and adds restrained
   asanoha + seigaiha textures, hanko-stamp accents, mincho display type
   for the headline numerals, and brush-stroke underlines.
   ========================================================================== */

.ocr-tools-content,
.ocr-tool,
.ocr-tool-teaser {
  /* Re-tune base palette to site tokens + lacquer accents */
  --ocr-navy: #04384c;          /* Swell --color_main */
  --ocr-ink-deep: #021c26;      /* deeper urushi for chart card */
  --ocr-felt: #073142;
  --ocr-felt-dark: #021c26;
  --ocr-vermilion: #c1272d;     /* lacquer/印鑑 red */
  --ocr-vermilion-bright: #e44141; /* Swell --color_deep01 */
  --ocr-gold-leaf: #c8a45c;     /* aged gold leaf */
  --ocr-gold-hi: #f0d27a;       /* highlight */
  --ocr-sumi: #1a1a1f;          /* ink black */
  --ocr-washi: #fdf9ee;         /* Swell --color_pale04 cream */
  --ocr-washi-edge: #efe4c9;
  --ocr-shadow: 0 22px 58px rgba(2, 28, 38, .18);
  --ocr-shadow-lacquer: 0 18px 38px -16px rgba(2, 28, 38, .55), 0 2px 0 rgba(255, 255, 255, .08) inset;

  /* Pattern: 麻の葉 (asanoha) — sparse hemp-leaf overlay for dark surfaces */
  --pat-asanoha: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 80 92' width='80' height='92'><g fill='none' stroke='rgba(232,206,140,0.10)' stroke-width='0.7'><polygon points='40,0 80,23 80,69 40,92 0,69 0,23'/><line x1='40' y1='0' x2='40' y2='92'/><line x1='0' y1='23' x2='80' y2='69'/><line x1='80' y1='23' x2='0' y2='69'/><line x1='0' y1='46' x2='80' y2='46'/></g></svg>");

  /* Pattern: 青海波 (seigaiha) — overlapping wave arcs */
  --pat-seigaiha: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 60 30' width='60' height='30'><g fill='none' stroke='rgba(232,206,140,0.09)' stroke-width='0.8'><circle cx='0' cy='30' r='18'/><circle cx='0' cy='30' r='12'/><circle cx='0' cy='30' r='6'/><circle cx='30' cy='30' r='18'/><circle cx='30' cy='30' r='12'/><circle cx='30' cy='30' r='6'/><circle cx='60' cy='30' r='18'/><circle cx='60' cy='30' r='12'/><circle cx='60' cy='30' r='6'/></g></svg>");

  /* Pattern: 和紙 (washi paper) — fine grain for cream surfaces (very subtle) */
  --pat-washi: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 220 220' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' seed='3'/><feColorMatrix values='0 0 0 0 0.62  0 0 0 0 0.55  0 0 0 0 0.36  0 0 0 0.05 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");

  /* Display serif (Mincho) ONLY for headlines + big numerals.
     Body labels keep the inherited gothic stack for legibility. */
  --ocr-mincho: "Yu Mincho", "Hiragino Mincho ProN", "Noto Serif JP", "游明朝", "Times New Roman", serif;
}

/* ---- Hero: urushi lacquer + asanoha micro-pattern ---- */
.ocr-tool__hero {
  background:
    var(--pat-asanoha),
    radial-gradient(120% 90% at 0% 0%, rgba(232, 206, 140, .10), transparent 55%),
    linear-gradient(135deg, #04384c 0%, #021c26 100%);
  background-size: 80px 92px, auto, auto;
  border: 1px solid rgba(232, 206, 140, .14);
  box-shadow: var(--ocr-shadow);
  border-radius: 14px;
}

.ocr-tool__hero::before {
  background:
    radial-gradient(110% 60% at 100% 0%, rgba(193, 39, 45, .22), transparent 60%);
  opacity: 1;
  background-size: auto;
}

.ocr-tool__eyebrow {
  align-items: center;
  color: var(--ocr-gold-hi) !important;
  display: inline-flex;
  font-size: 11px !important;
  font-weight: 800;
  gap: 10px;
  letter-spacing: .14em !important;
  text-transform: uppercase;
}

.ocr-tool__eyebrow::before {
  background: var(--ocr-vermilion);
  border-radius: 50%;
  box-shadow: 0 0 0 2px rgba(232, 206, 140, .45);
  color: #fff8e7;
  content: "印";
  display: inline-grid;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", "Noto Serif JP", "Times New Roman", serif;
  font-size: 14px;
  font-weight: 600;
  height: 28px;
  letter-spacing: 0;
  line-height: 1;
  place-items: center;
  text-transform: none;
  text-shadow: 0 1px 0 rgba(0, 0, 0, .25);
  transform: rotate(-6deg);
  width: 28px;
}

.ocr-tool h1 {
  color: #fffaf0 !important;
  font-family: var(--ocr-mincho);
  font-weight: 700 !important;
  letter-spacing: -.005em;
  line-height: 1.18 !important;
  text-shadow: 0 1px 0 rgba(0, 0, 0, .55);
}

.ocr-tool__lead {
  color: #f5ecd6 !important;
  line-height: 1.85;
}

.ocr-tool__hero-tags span {
  background: rgba(232, 206, 140, .14);
  border: 1px solid rgba(232, 206, 140, .45);
  color: #fff8e7;
  font-weight: 800;
}

/* ---- Fieldset legends: hanko-numbered cards ---- */
.ocr-tool__fieldset {
  background: var(--ocr-washi);
  background-image: var(--pat-washi);
  background-size: 220px 220px;
  border: 1px solid var(--ocr-washi-edge);
  border-radius: 12px;
  box-shadow: 0 1px 0 rgba(255, 255, 255, .6) inset, 0 14px 30px -22px rgba(2, 28, 38, .35);
}

.ocr-tool__fieldset legend {
  color: var(--ocr-navy);
  font-family: var(--ocr-mincho);
  font-size: 19px !important;
  font-weight: 700 !important;
  letter-spacing: .005em;
}

.ocr-tool__fieldset legend > span,
.ocr-tool__calculator-head > span {
  background: var(--ocr-vermilion);
  background-image: radial-gradient(120% 100% at 30% 20%, rgba(255, 255, 255, .22), transparent 60%);
  border: 1.5px solid var(--ocr-vermilion-bright);
  border-radius: 50%;
  box-shadow: 0 2px 0 rgba(2, 28, 38, .25), 0 0 0 3px rgba(193, 39, 45, .12);
  color: #fff8e7 !important;
  display: inline-grid !important;
  font-family: var(--ocr-mincho) !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  height: 36px;
  letter-spacing: 0 !important;
  line-height: 1 !important;
  margin-right: 12px;
  place-items: center;
  transform: rotate(-4deg);
  width: 36px;
}

/* ---- Calculator section: deep ink with gold-leaf trim ---- */
.ocr-tool__calculator {
  background:
    var(--pat-seigaiha),
    linear-gradient(180deg, var(--ocr-felt) 0%, var(--ocr-ink-deep) 100%);
  background-size: 60px 30px, auto;
  border: 1px solid rgba(232, 206, 140, .18);
  border-radius: 14px;
  box-shadow: var(--ocr-shadow-lacquer);
  color: var(--ocr-washi);
}

.ocr-tool__calculator h2 {
  color: #fffaf0 !important;
  font-family: var(--ocr-mincho) !important;
  font-weight: 700 !important;
}

.ocr-tool__calculator p {
  color: #efe4c9;
}

.ocr-tool__calculator-label {
  color: #fff8e7;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
  font-size: 11px;
}

.ocr-tool__calculator-control {
  background: #fffdf6;
  border: 1px solid rgba(232, 206, 140, .55);
  border-radius: 10px;
  box-shadow: 0 1px 0 rgba(255, 255, 255, .9) inset;
}

.ocr-tool__calculator-control em {
  color: var(--ocr-vermilion);
  font-style: normal;
  font-weight: 800;
}

.ocr-tool__calculator-input {
  color: var(--ocr-sumi);
  font-weight: 700;
}

.ocr-tool__calculator-input[type="range"] {
  accent-color: var(--ocr-vermilion);
}

.ocr-tool__calculator-output {
  color: var(--ocr-gold-hi);
  font-weight: 800;
}

.ocr-tool__calculator-note {
  color: #f0e6cc;
  display: block;
  font-size: 13px;
  font-style: normal;
  line-height: 1.6;
  margin-top: 10px;
  padding-left: 12px;
  position: relative;
}

.ocr-tool__calculator-note::before {
  background: var(--ocr-vermilion-bright);
  border-radius: 1px;
  content: "";
  height: calc(100% - 4px);
  left: 0;
  position: absolute;
  top: 2px;
  width: 2px;
}

/* ---- Radio options: washi cards ---- */
.ocr-tool__option {
  background: #fff;
  background-image: var(--pat-washi);
  background-size: 220px 220px;
  border: 1px solid var(--ocr-washi-edge);
  transition: border-color .25s cubic-bezier(.2, .8, .25, 1), transform .25s cubic-bezier(.2, .8, .25, 1), box-shadow .25s cubic-bezier(.2, .8, .25, 1);
}

.ocr-tool__option:hover {
  border-color: rgba(193, 39, 45, .42);
  box-shadow: 0 14px 32px -22px rgba(193, 39, 45, .55);
  transform: translateY(-1px);
}

.ocr-tool__option:has(input:checked) {
  background-color: #fff;
  border-color: var(--ocr-vermilion);
  box-shadow: 0 14px 28px -18px rgba(193, 39, 45, .55), 0 0 0 1px var(--ocr-vermilion) inset;
}

.ocr-tool__option-title {
  color: var(--ocr-sumi);
  font-weight: 800;
}

/* ---- Submit / primary buttons: lacquer-stamp red ---- */
.ocr-tool__submit,
.ocr-tool__button {
  background:
    radial-gradient(120% 100% at 20% 15%, rgba(255, 255, 255, .18), transparent 55%),
    linear-gradient(180deg, #d83339 0%, var(--ocr-vermilion) 55%, #9d1f24 100%);
  border: 1px solid #8a1b1f;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, .22) inset,
    0 -2px 0 rgba(0, 0, 0, .25) inset,
    0 14px 28px -14px rgba(193, 39, 45, .65),
    0 0 0 1px rgba(232, 206, 140, .45) inset;
  color: #fff8e7;
  font-weight: 800;
  letter-spacing: .04em;
  position: relative;
  text-shadow: 0 1px 0 rgba(0, 0, 0, .45);
}

.ocr-tool__submit::before,
.ocr-tool__button::before {
  background: var(--ocr-gold-leaf);
  border-radius: 1px;
  content: "";
  height: 10px;
  left: 14px;
  opacity: .85;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 2px;
}

.ocr-tool__submit:hover,
.ocr-tool__button:hover {
  box-shadow:
    0 1px 0 rgba(255, 255, 255, .28) inset,
    0 -2px 0 rgba(0, 0, 0, .28) inset,
    0 18px 32px -14px rgba(193, 39, 45, .75),
    0 0 0 1px rgba(232, 206, 140, .55) inset;
  transform: translateY(-1px);
}

/* ---- Result label "Boost unlocked" → hanko banner ---- */
.ocr-tool__result-label {
  align-items: center;
  background:
    linear-gradient(180deg, var(--ocr-ink-deep), #03293a);
  border: 1px solid rgba(232, 206, 140, .35);
  border-radius: 10px 10px 0 0;
  color: var(--ocr-gold-hi);
  display: flex;
  font-weight: 800;
  gap: 12px;
  letter-spacing: .08em;
}

.ocr-tool__result-label::before {
  background: var(--ocr-vermilion);
  border-radius: 4px;
  box-shadow: 0 0 0 1px rgba(232, 206, 140, .5);
  color: #fff8e7;
  content: "解";
  display: inline-grid;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", "Noto Serif JP", serif;
  font-size: 13px;
  font-weight: 700;
  height: 22px;
  line-height: 1;
  place-items: center;
  text-shadow: 0 1px 0 rgba(0, 0, 0, .25);
  transform: rotate(-4deg);
  width: 22px;
}

/* ---- "Standard start vs boosted start" chart card ---- */
.ocr-tool__boost-compare,
.ocr-tool__boost {
  background:
    var(--pat-seigaiha),
    linear-gradient(160deg, var(--ocr-ink-deep) 0%, #04384c 100%) !important;
  background-size: 60px 30px, auto !important;
  border: 1px solid rgba(232, 206, 140, .18) !important;
  border-radius: 12px !important;
  box-shadow: var(--ocr-shadow-lacquer) !important;
  color: var(--ocr-washi);
}

.ocr-tools-content .ocr-tool__result .ocr-tool__boost-compare h3,
.ocr-tools-content .ocr-tool__result .ocr-tool__boost h3,
.ocr-tools-content .ocr-tool__boost-compare h3,
.ocr-tools-content .ocr-tool__boost h3,
.ocr-tool__boost-compare h3,
.ocr-tool__boost h3,
.ocr-tool__boost-compare-title {
  color: #fffaf0 !important;
  font-family: var(--ocr-mincho) !important;
  font-weight: 700 !important;
  letter-spacing: .01em;
}

/* Mincho display numerals for the three big amounts only */
.ocr-tool__boost-compare .ocr-tool__boost-amount,
.ocr-tool__boost-compare-value,
.ocr-tool__boost-card-value {
  color: #fffaf0;
  font-family: var(--ocr-mincho);
  font-feature-settings: "tnum" 1;
  font-weight: 700;
  letter-spacing: -.02em;
}

/* Inside the chart card: bump body legibility */
.ocr-tool__boost-compare,
.ocr-tool__boost {
  color: #f5ecd6;
}

.ocr-tool__boost-compare p,
.ocr-tool__boost-compare span,
.ocr-tool__boost-compare li,
.ocr-tool__boost p,
.ocr-tool__boost span:not(.ocr-tool__boost-amount),
.ocr-tool__boost li {
  color: #f0e6cc;
}

/* Stat-cell labels ("Standard start", "Boosted path", "Extra value unlocked") */
.ocr-tool__boost-card-label,
.ocr-tool__boost-compare .ocr-tool__boost-label {
  color: #efe4c9 !important;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
  font-size: 11px;
}

/* Input-summary chips at top of chart card ("First deposit $100" etc.) */
.ocr-tool__boost-compare .ocr-tool__boost-input,
.ocr-tool__boost-compare-input,
.ocr-tool__boost-input {
  background: rgba(255, 248, 231, .08) !important;
  border: 1px solid rgba(232, 206, 140, .30) !important;
  color: #fff8e7 !important;
}

.ocr-tool__boost-input strong,
.ocr-tool__boost-compare-input strong {
  color: var(--ocr-gold-hi) !important;
}

/* Highlight cell ("Extra value unlocked") gets gold-leaf treatment */
.ocr-tool__boost-card--extra,
.ocr-tool__boost-extra {
  background:
    radial-gradient(100% 80% at 50% 10%, rgba(232, 206, 140, .14), transparent 60%),
    linear-gradient(180deg, rgba(193, 39, 45, .22), rgba(193, 39, 45, .08)) !important;
  border: 1px solid rgba(232, 206, 140, .35) !important;
  color: var(--ocr-gold-hi) !important;
}

.ocr-tool__boost-card--extra .ocr-tool__boost-amount,
.ocr-tool__boost-extra strong {
  color: var(--ocr-gold-hi) !important;
}

/* Value-breakdown bar segments — lacquer red + leaf gold split */
.ocr-tool__boost-segment--rakeback,
.ocr-tool__boost-segment--registration,
.ocr-tool__boost-segment--deposit {
  background: linear-gradient(90deg, var(--ocr-gold-leaf), var(--ocr-gold-hi)) !important;
}

.ocr-tool__boost-segment--club {
  background: linear-gradient(90deg, var(--ocr-vermilion), #9d1f24) !important;
}

.ocr-tool__boost-bar,
.ocr-tool__boost-track {
  background: rgba(253, 249, 238, .12) !important;
  border: 1px solid rgba(232, 206, 140, .25) !important;
}

/* ---- Boost stack / Power moves: paper-cream cards with brush underline ---- */
.ocr-tool__checklist,
.ocr-tool__result-grid > * {
  background: var(--ocr-washi) !important;
  background-image: var(--pat-washi) !important;
  background-size: 220px 220px !important;
  border: 1px solid var(--ocr-washi-edge) !important;
  border-radius: 12px !important;
}

.ocr-tools-content .ocr-tool__result h3 {
  color: var(--ocr-navy) !important;
  font-family: var(--ocr-mincho) !important;
  font-weight: 700 !important;
  padding-bottom: 8px;
  position: relative;
}

.ocr-tools-content .ocr-tool__result h2 {
  color: var(--ocr-navy) !important;
  font-family: var(--ocr-mincho) !important;
  font-weight: 700 !important;
}

/* Boost stack / Power moves bullets — sumi ink on washi */
.ocr-tool__checklist,
.ocr-tool__checklist li,
.ocr-tool__result-grid li,
.ocr-tool__result-grid p {
  color: var(--ocr-sumi);
  line-height: 1.7;
}

.ocr-tools-content .ocr-tool__result h3::after {
  background:
    linear-gradient(90deg, var(--ocr-vermilion) 0%, var(--ocr-vermilion) 38%, transparent 100%);
  border-radius: 1px;
  bottom: 0;
  content: "" !important;
  height: 2px;
  left: 0;
  position: absolute;
  width: 56px;
}

/* ---- Extra value unlocked banner (cream) ---- */
.ocr-tool__bonus-ticket {
  background:
    var(--pat-washi),
    linear-gradient(180deg, #fdf9ee 0%, #f6ead0 100%) !important;
  background-size: 220px 220px, auto !important;
  border: 1px solid var(--ocr-washi-edge) !important;
  border-left: 4px solid var(--ocr-vermilion) !important;
  color: var(--ocr-sumi) !important;
}

.ocr-tool__bonus-ticket strong,
.ocr-tool__bonus-ticket-value {
  color: var(--ocr-vermilion) !important;
  font-family: var(--ocr-mincho) !important;
}

.ocr-tool__bonus-ticket p,
.ocr-tool__bonus-ticket span,
.ocr-tool__bonus-ticket small {
  color: var(--ocr-sumi);
}

/* ---- Invite-code chip + copy box ---- */
.ocr-tool__code-row,
.ocr-tool__share-code {
  background: var(--ocr-washi);
  background-image: var(--pat-washi);
  background-size: 220px 220px;
  border: 1px solid var(--ocr-washi-edge);
  border-radius: 10px;
}

.ocr-tool__share-code-value,
.ocr-tool__code-row strong {
  background: rgba(193, 39, 45, .08);
  border: 1px dashed rgba(193, 39, 45, .65);
  border-radius: 6px;
  color: var(--ocr-vermilion);
  font-weight: 800;
  letter-spacing: .12em;
  padding: 4px 10px;
}

/* ---- "Current KKPoker bonus link" offer card ---- */
.ocr-tool__offer-card {
  background: var(--ocr-washi) !important;
  background-image: var(--pat-washi) !important;
  background-size: 220px 220px !important;
  border: 1px solid var(--ocr-washi-edge) !important;
  border-radius: 12px !important;
  position: relative;
}

.ocr-tool__offer-card::before {
  background:
    linear-gradient(180deg, var(--ocr-gold-leaf), var(--ocr-gold-hi));
  border-radius: 2px 0 0 2px;
  content: "";
  height: 60%;
  left: 0;
  position: absolute;
  top: 20%;
  width: 3px;
}

.ocr-tool__offer-card h4,
.ocr-tool__offer-card strong,
.ocr-tool__offer-title {
  color: var(--ocr-navy) !important;
  font-family: var(--ocr-mincho) !important;
  font-weight: 700 !important;
}

.ocr-tool__offer-card p,
.ocr-tool__offer-card span,
.ocr-tool__offer-card small {
  color: var(--ocr-sumi);
}

/* ---- Scratch card frame: black lacquer ---- */
.ocr-tool__scratch {
  background:
    var(--pat-asanoha),
    linear-gradient(160deg, #073142 0%, #021c26 100%) !important;
  background-size: 80px 92px, auto !important;
  border: 1px solid rgba(232, 206, 140, .22) !important;
  border-radius: 14px !important;
  box-shadow: var(--ocr-shadow-lacquer);
}

.ocr-tool__scratch h2 {
  color: #fffaf0 !important;
  font-family: var(--ocr-mincho) !important;
}

.ocr-tool__scratch-kicker {
  color: var(--ocr-gold-hi) !important;
  font-family: var(--ocr-mincho) !important;
  letter-spacing: .14em;
}

.ocr-tool__scratch p,
.ocr-tool__scratch-status {
  color: #f0e6cc !important;
}

/* ---- Secondary button (Read the guide) ---- */
.ocr-tool__reset,
.ocr-tool__scratch-reveal,
.ocr-tool__share-button {
  background: #fff;
  background-image: var(--pat-washi);
  background-size: 220px 220px;
  border: 1.5px solid var(--ocr-vermilion);
  color: var(--ocr-vermilion);
  font-weight: 800;
}

.ocr-tool__reset:hover,
.ocr-tool__scratch-reveal:hover,
.ocr-tool__share-button:hover {
  background-color: rgba(193, 39, 45, .06);
  border-color: var(--ocr-vermilion);
  color: var(--ocr-vermilion);
}

/* ---- Status badge / "Bonus boost" pill on hero image ---- */
.ocr-tool__table-badge {
  background:
    linear-gradient(180deg, var(--ocr-vermilion), #9d1f24) !important;
  border: 1px solid var(--ocr-vermilion-bright);
  box-shadow: 0 4px 14px -6px rgba(193, 39, 45, .8), 0 0 0 1px rgba(232, 206, 140, .35) inset;
  color: #fff8e7;
  font-weight: 800;
  letter-spacing: .08em;
  text-shadow: 0 1px 0 rgba(0, 0, 0, .35);
}

/* Quietly suppress legacy gradient-text shimmers, if any */
.ocr-tool [class*="gradient-text"],
.ocr-tool h1,
.ocr-tool h2,
.ocr-tool h3 {
  background-clip: initial !important;
  -webkit-background-clip: initial !important;
  -webkit-text-fill-color: initial !important;
}

/* =========================================================================
   v2 additions: Casino Record Special badge, equal-sized months dropdown,
   animated SVG line chart, coin pop-out, Chip-kun mascot, post-scratch
   deposit re-slider, scratch headline overlay, FX rate footnote.
   ========================================================================= */

/* ---- Casino Record Special badge (replaces the rate note) ---- */
.ocr-tool__calculator-badge {
  align-items: center;
  background: linear-gradient(180deg, rgba(232, 206, 140, .18), rgba(193, 39, 45, .12));
  border: 1px solid rgba(232, 206, 140, .45);
  border-radius: 999px;
  color: #fff8e7;
  display: inline-flex;
  font-size: 11px;
  font-weight: 800;
  gap: 8px;
  letter-spacing: .05em;
  margin-top: 8px;
  padding: 5px 10px 5px 8px;
  text-transform: uppercase;
  width: fit-content;
  box-shadow: 0 1px 0 rgba(255, 255, 255, .08) inset, 0 6px 14px -10px rgba(193, 39, 45, .6);
}

.ocr-tool__calculator-badge-icon {
  color: var(--ocr-gold-hi);
  filter: drop-shadow(0 1px 0 rgba(193, 39, 45, .35));
  flex: 0 0 auto;
}

.ocr-tool__calculator-badge-label {
  letter-spacing: .06em;
}

.ocr-tool__calculator-badge-hint {
  color: rgba(253, 249, 238, .72);
  font-weight: 600;
  letter-spacing: .03em;
  text-transform: none;
  font-size: 10.5px;
}

/* ---- Equal-size months dropdown (was wider/taller than the other inputs) ---- */
.ocr-tool__calculator-input,
select.ocr-tool__calculator-input,
input.ocr-tool__calculator-input {
  appearance: none;
  -webkit-appearance: none;
  background: transparent;
  border: 0;
  box-sizing: border-box;
  font-size: 18px;
  height: 28px;
  line-height: 1.2;
  min-width: 0;
  padding: 0;
  width: 100%;
}

/* Native select dropdown styling normalized to match number/range inputs */
select.ocr-tool__calculator-input {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' width='12' height='8'><path d='M1 1.5L6 6.5L11 1.5' fill='none' stroke='%23c1272d' stroke-width='1.6' stroke-linecap='round'/></svg>");
  background-position: right 4px center;
  background-repeat: no-repeat;
  background-size: 10px 7px;
  padding-right: 18px;
}

/* Each input cell uses identical box-sizing so the grid renders flush */
.ocr-tool__calculator-field {
  align-items: stretch;
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.ocr-tool__calculator-control {
  align-items: center;
  display: flex;
  gap: 6px;
  height: 48px;
  padding: 0 12px;
}

/* ---- Animated SVG line chart ---- */
.ocr-tool__line-chart {
  background:
    var(--pat-seigaiha),
    linear-gradient(180deg, var(--ocr-felt) 0%, var(--ocr-ink-deep) 100%);
  background-size: 60px 30px, auto;
  border: 1px solid rgba(232, 206, 140, .22);
  border-radius: 14px;
  box-shadow: var(--ocr-shadow-lacquer);
  color: var(--ocr-washi);
  margin-top: 18px;
  overflow: hidden;
  padding: 18px clamp(14px, 2.4vw, 22px) 14px;
}

.ocr-tool__line-chart-head {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: space-between;
  margin-bottom: 8px;
}

.ocr-tools-content .ocr-tool__line-chart h3,
.ocr-tool__line-chart h3 {
  color: #fffaf0 !important;
  font-family: var(--ocr-mincho) !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  margin: 0 !important;
}

.ocr-tool__line-chart-total {
  align-items: center;
  background: rgba(232, 206, 140, .12);
  border: 1px solid rgba(232, 206, 140, .35);
  border-radius: 999px;
  color: #fff8e7;
  display: inline-flex;
  font-size: 12px;
  font-weight: 700;
  gap: 8px;
  padding: 4px 12px;
}

.ocr-tool__line-chart-total strong {
  color: var(--ocr-gold-hi);
  font-family: var(--ocr-mincho);
  font-size: 15px;
  font-weight: 800;
}

.ocr-tool__line-chart-svg {
  display: block;
  height: auto;
  width: 100%;
}

.ocr-tool__line-chart-fx {
  color: rgba(253, 249, 238, .58);
  font-size: 11px;
  letter-spacing: .04em;
  margin: 8px 0 0;
  text-align: right;
}

/* ---- Scratch headline overlay + coin pop-out ---- */
.ocr-tool__scratch {
  position: relative;
  overflow: visible !important;
}

.ocr-tool__scratch--revealed .ocr-tool__scratch-canvas {
  opacity: 0;
  transition: opacity .35s ease-out;
}

.ocr-tool__scratch-amount {
  align-items: center;
  animation: ocr-pop 700ms cubic-bezier(.2, .8, .25, 1) both;
  background:
    radial-gradient(120% 90% at 30% 20%, rgba(232, 206, 140, .25), transparent 55%),
    linear-gradient(180deg, #c1272d 0%, #8a1b1f 100%);
  border: 2px solid var(--ocr-gold-hi);
  border-radius: 14px;
  box-shadow: 0 18px 48px -16px rgba(193, 39, 45, .8), 0 0 0 4px rgba(232, 206, 140, .25) inset;
  color: #fff8e7;
  display: flex;
  flex-direction: column;
  gap: 4px;
  inset: auto;
  padding: 14px 22px;
  pointer-events: none;
  position: absolute;
  z-index: 4;
  text-align: center;
  /* Anchor over the scratch card content */
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}

.ocr-tool__scratch-amount-eyebrow {
  color: var(--ocr-gold-hi);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.ocr-tool__scratch-amount-value {
  color: #fff8e7;
  font-family: var(--ocr-mincho);
  font-size: clamp(28px, 5vw, 42px);
  font-weight: 800;
  letter-spacing: -.01em;
  line-height: 1;
  text-shadow: 0 2px 0 rgba(0, 0, 0, .35);
}

@keyframes ocr-pop {
  0%   { transform: translate(-50%, -50%) scale(.4); opacity: 0; }
  60%  { transform: translate(-50%, -50%) scale(1.08); opacity: 1; }
  100% { transform: translate(-50%, -50%) scale(1); opacity: 1; }
}

.ocr-tool__scratch-coins {
  inset: 0;
  pointer-events: none;
  position: absolute;
  z-index: 5;
}

.ocr-tool__coin {
  align-items: center;
  background:
    radial-gradient(circle at 30% 30%, var(--ocr-gold-hi), var(--ocr-gold-leaf) 60%, #8a6b22 100%);
  border: 1.5px solid var(--ocr-gold-hi);
  border-radius: 50%;
  box-shadow: 0 6px 12px -4px rgba(0, 0, 0, .4), 0 0 0 1px rgba(255, 255, 255, .25) inset;
  color: #6b3a06;
  display: inline-flex;
  font-family: var(--ocr-mincho);
  font-size: 16px;
  font-weight: 800;
  height: 28px;
  justify-content: center;
  left: 50%;
  opacity: 0;
  position: absolute;
  text-shadow: 0 1px 0 rgba(255, 255, 255, .35);
  top: 50%;
  transform: translate(-50%, -50%);
  width: 28px;
  animation: ocr-coin-fly 1.6s cubic-bezier(.2, .8, .35, 1) forwards;
}

@keyframes ocr-coin-fly {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%) rotate(0);
  }
  10% {
    opacity: 1;
  }
  80% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    transform: translate(calc(-50% + var(--dx)), calc(-50% + var(--dy))) rotate(var(--rot));
  }
}

@media (prefers-reduced-motion: reduce) {
  .ocr-tool__coin,
  .ocr-tool__scratch-amount { animation: none; }
}

/* ---- Chip-kun mascot + post-scratch deposit re-slider ---- */
.ocr-tool__resimulate {
  background: var(--ocr-washi);
  background-image: var(--pat-washi);
  background-size: 220px 220px;
  border: 1px solid var(--ocr-washi-edge);
  border-radius: 14px;
  margin-top: 18px;
  padding: clamp(16px, 2.8vw, 22px);
  position: relative;
}

.ocr-tool__resimulate::before {
  background: linear-gradient(180deg, var(--ocr-vermilion), var(--ocr-gold-leaf));
  border-radius: 2px 0 0 2px;
  content: "";
  height: 70%;
  left: 0;
  position: absolute;
  top: 15%;
  width: 3px;
}

.ocr-tool__resimulate-inner {
  align-items: flex-start;
  display: grid;
  gap: 18px;
  grid-template-columns: minmax(120px, 180px) 1fr;
}

.ocr-tool__mascot {
  align-items: flex-start;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.ocr-tool__mascot img {
  background: #fff;
  border: 2px solid var(--ocr-gold-hi);
  border-radius: 50%;
  box-shadow: 0 8px 18px -6px rgba(2, 28, 38, .3);
  height: 80px;
  object-fit: cover;
  width: 80px;
  transition: transform .35s cubic-bezier(.2, .8, .25, 1);
}

.ocr-tool__mascot--pulse img {
  animation: ocr-mascot-bounce .5s cubic-bezier(.2, .8, .25, 1);
}

@keyframes ocr-mascot-bounce {
  0%   { transform: translateY(0) scale(1); }
  50%  { transform: translateY(-6px) scale(1.04); }
  100% { transform: translateY(0) scale(1); }
}

.ocr-tool__mascot-bubble {
  background: #fff;
  border: 1.5px solid var(--ocr-vermilion);
  border-radius: 10px;
  color: var(--ocr-sumi);
  font-size: 13px;
  font-weight: 600;
  line-height: 1.5;
  padding: 10px 12px;
  position: relative;
}

.ocr-tool__mascot-bubble::before {
  background: #fff;
  border-bottom: 1.5px solid var(--ocr-vermilion);
  border-left: 1.5px solid var(--ocr-vermilion);
  content: "";
  height: 10px;
  left: 18px;
  position: absolute;
  top: -6px;
  transform: rotate(135deg);
  width: 10px;
}

.ocr-tool__resimulate-controls {
  display: grid;
  gap: 12px;
}

.ocr-tool__resimulate-row {
  align-items: center;
  display: grid;
  gap: 8px 14px;
  grid-template-columns: 1fr auto;
}

.ocr-tool__resimulate-label {
  color: var(--ocr-sumi);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.ocr-tool__resimulate-value {
  color: var(--ocr-vermilion);
  font-family: var(--ocr-mincho);
  font-size: 16px;
  font-weight: 800;
}

.ocr-tool__resimulate-range {
  appearance: none;
  -webkit-appearance: none;
  background: linear-gradient(90deg, var(--ocr-vermilion) 0%, var(--ocr-gold-leaf) 100%);
  border-radius: 999px;
  cursor: pointer;
  grid-column: 1 / -1;
  height: 6px;
  margin: 4px 0;
  outline: none;
  width: 100%;
}

.ocr-tool__resimulate-range::-webkit-slider-thumb {
  appearance: none;
  -webkit-appearance: none;
  background: var(--ocr-vermilion);
  border: 2px solid var(--ocr-gold-hi);
  border-radius: 50%;
  box-shadow: 0 4px 8px -2px rgba(193, 39, 45, .6);
  height: 22px;
  width: 22px;
}

.ocr-tool__resimulate-range::-moz-range-thumb {
  background: var(--ocr-vermilion);
  border: 2px solid var(--ocr-gold-hi);
  border-radius: 50%;
  height: 22px;
  width: 22px;
}

/* ---- Mobile fitness ---- */
@media (max-width: 640px) {
  .ocr-tool__line-chart {
    padding: 14px 12px 10px;
  }
  .ocr-tool__line-chart-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
  .ocr-tool__line-chart-fx {
    text-align: left;
  }

  .ocr-tool__resimulate-inner {
    grid-template-columns: 1fr;
  }
  .ocr-tool__mascot {
    align-items: center;
    flex-direction: row;
    gap: 12px;
  }
  .ocr-tool__mascot img {
    height: 64px;
    width: 64px;
  }
  .ocr-tool__mascot-bubble {
    flex: 1;
    font-size: 12.5px;
  }
  .ocr-tool__mascot-bubble::before {
    border-bottom: 0;
    border-left: 1.5px solid var(--ocr-vermilion);
    border-top: 1.5px solid var(--ocr-vermilion);
    left: -6px;
    top: 18px;
    transform: rotate(-45deg);
  }
  .ocr-tool__scratch-amount {
    padding: 10px 16px;
  }
  .ocr-tool__scratch-amount-value {
    font-size: clamp(24px, 7vw, 36px);
  }

  /* Stack input fields on small screens */
  .ocr-tool__calculator-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 420px) {
  .ocr-tool__calculator-grid {
    grid-template-columns: 1fr;
  }
  .ocr-tool__line-chart-svg {
    /* SVG viewBox already responsive; ensure visible labels not clipped */
    min-height: 200px;
  }
}

/* ==========================================================================
   v3 Monochrome reskin
   Replaces the urushi/vermilion/gold palette with pure black + white.
   Fixes cramped hierarchy on the "Boost unlocked" and "Reveal my numbers"
   sections, hides pre-scratch chrome after reveal, fades the form once a
   result is active, gives every primary section one focal point.
   ========================================================================== */

.ocr-tools-content,
.ocr-tool,
.ocr-tool-teaser {
  /* Hard monochrome tokens — black surfaces, white text */
  --mono-black:       #0a0a0a;
  --mono-near-black:  #141414;
  --mono-ink:         #1c1c1c;
  --mono-gray-900:    #262626;
  --mono-gray-700:    #4a4a4a;
  --mono-gray-500:    #7a7a7a;
  --mono-gray-300:    #c8c8c8;
  --mono-gray-100:    #ededed;
  --mono-paper:       #fafafa;
  --mono-white:       #ffffff;

  /* Override the previous palette so existing rules using --ocr-* tokens
     resolve to monochrome without me having to rewrite each one. */
  --ocr-ink-deep:        var(--mono-black);
  --ocr-felt:            var(--mono-near-black);
  --ocr-felt-dark:       var(--mono-black);
  --ocr-navy:            var(--mono-black);
  --ocr-vermilion:       var(--mono-ink);
  --ocr-vermilion-bright:var(--mono-gray-900);
  --ocr-gold-leaf:       var(--mono-white);
  --ocr-gold-hi:         var(--mono-white);
  --ocr-sumi:            var(--mono-black);
  --ocr-washi:           var(--mono-paper);
  --ocr-washi-edge:      var(--mono-gray-100);
  --ocr-shadow:          0 22px 58px rgba(0, 0, 0, .14);
  --ocr-shadow-lacquer:  0 14px 36px -18px rgba(0, 0, 0, .55), 0 1px 0 rgba(255, 255, 255, .06) inset;

  /* Patterns: drop in favor of clean monochrome surfaces */
  --pat-asanoha: none;
  --pat-seigaiha: none;
  --pat-washi: none;
}

/* ---- Hero: black with white type ---- */
.ocr-tool__hero {
  align-items: end !important;
  background: var(--mono-black) !important;
  border: 1px solid var(--mono-gray-900) !important;
  border-radius: 12px;
  overflow: hidden !important;
  padding: clamp(28px, 4.8vw, 56px) clamp(20px, 3.5vw, 56px) 0 clamp(28px, 4.8vw, 56px) !important;
}
.ocr-tool__hero-copy {
  padding-bottom: clamp(28px, 4.8vw, 56px);
}
.ocr-tool__status,
.ocr-tool__status-visual {
  align-self: end !important;
  margin: 0 !important;
  padding: 0 !important;
}
.ocr-tool__status-visual img {
  border-radius: 0 !important;
  box-shadow: none !important;
  display: block;
  margin: 0 !important;
  /* Let her actually "stand" on the card's bottom edge */
  width: 100%;
  height: auto;
}
.ocr-tool__table-badge {
  display: none !important;
}
.ocr-tool__hero::before {
  background: none !important;
  opacity: 0 !important;
}
.ocr-tool h1 {
  color: var(--mono-white) !important;
  font-family: var(--ocr-mincho) !important;
  font-size: clamp(28px, 4vw, 44px) !important;
  letter-spacing: -.01em !important;
  margin: 0 !important;
  text-shadow: none !important;
}
/* Hide the eyebrow inside the hero — keep only the H1 */
.ocr-tool__hero .ocr-tool__eyebrow {
  display: none !important;
}

/* ---- Exclusive Bonus badge above the H1 (animated sheen) ---- */
.ocr-tool__hero-badge {
  align-items: center;
  background: var(--mono-white);
  border: 0;
  border-radius: 999px;
  box-shadow: 0 0 0 1px rgba(255, 255, 255, .14), 0 8px 20px -8px rgba(0, 0, 0, .55);
  color: var(--mono-black);
  display: inline-flex;
  font-size: 11px;
  font-weight: 800;
  gap: 8px;
  isolation: isolate;
  letter-spacing: .26em;
  line-height: 1;
  margin: 0 0 18px;
  overflow: hidden;
  padding: 8px 14px 8px 12px;
  position: relative;
  text-transform: uppercase;
  white-space: nowrap;
}
.ocr-tool__hero-badge::before {
  /* Pulsing dot to the left */
  background: var(--mono-black);
  border-radius: 50%;
  content: "";
  height: 6px;
  width: 6px;
  animation: ocr-pulse 1.6s ease-in-out infinite;
}
.ocr-tool__hero-badge::after {
  /* Diagonal sheen sweep */
  background: linear-gradient(
    115deg,
    transparent 30%,
    rgba(0, 0, 0, .12) 47%,
    rgba(0, 0, 0, .22) 50%,
    rgba(0, 0, 0, .12) 53%,
    transparent 70%
  );
  content: "";
  inset: 0;
  pointer-events: none;
  position: absolute;
  transform: translateX(-110%);
  animation: ocr-sheen 3.6s cubic-bezier(.4, 0, .2, 1) infinite;
  z-index: 1;
}
.ocr-tool__hero-badge-text {
  position: relative;
  z-index: 2;
}
@keyframes ocr-sheen {
  0%, 35%  { transform: translateX(-110%); }
  60%      { transform: translateX(110%); }
  100%     { transform: translateX(110%); }
}
@keyframes ocr-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: .35; transform: scale(.75); }
}
@media (prefers-reduced-motion: reduce) {
  .ocr-tool__hero-badge::before,
  .ocr-tool__hero-badge::after { animation: none; }
}
.ocr-tool__eyebrow {
  color: var(--mono-gray-300) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .2em !important;
}
.ocr-tool__eyebrow::before {
  background: var(--mono-white);
  border-radius: 2px;
  box-shadow: none;
  color: var(--mono-black);
  font-family: var(--ocr-mincho);
  transform: none;
}
.ocr-tool__lead {
  color: var(--mono-gray-300) !important;
  font-size: 15px !important;
  line-height: 1.85 !important;
  margin-top: 18px !important;
  max-width: 60ch !important;
}
.ocr-tool__hero-tags span {
  background: transparent !important;
  border: 1px solid var(--mono-gray-700) !important;
  color: var(--mono-gray-100) !important;
  font-weight: 700 !important;
}
.ocr-tool__table-badge {
  background: var(--mono-white) !important;
  border: 0 !important;
  box-shadow: 0 4px 14px -6px rgba(0,0,0,.6) !important;
  color: var(--mono-black) !important;
  font-weight: 800 !important;
  letter-spacing: .12em !important;
  text-shadow: none !important;
}

/* ---- Fieldsets: white paper with sumi text, hairline edge ---- */
.ocr-tool__fieldset {
  background: var(--mono-white) !important;
  border: 1px solid var(--mono-gray-100) !important;
  border-radius: 12px !important;
  box-shadow: none !important;
  padding: clamp(20px, 2.6vw, 28px) !important;
}
.ocr-tool__fieldset legend {
  color: var(--mono-black) !important;
}
.ocr-tool__fieldset legend > span,
.ocr-tool__calculator-head > span {
  background: var(--mono-black) !important;
  background-image: none !important;
  border: 0 !important;
  box-shadow: none !important;
  color: var(--mono-white) !important;
  font-family: var(--ocr-mincho) !important;
  transform: none !important;
}

/* ---- Radio option cards: monochrome ---- */
.ocr-tool__option {
  background: var(--mono-white) !important;
  background-image: none !important;
  border: 1px solid var(--mono-gray-100) !important;
}
.ocr-tool__option:hover {
  border-color: var(--mono-black) !important;
  box-shadow: 0 8px 22px -16px rgba(0,0,0,.55) !important;
}
.ocr-tool__option:has(input:checked) {
  background-color: var(--mono-white) !important;
  border-color: var(--mono-black) !important;
  box-shadow: 0 0 0 1px var(--mono-black) inset !important;
}
.ocr-tool__option-title {
  color: var(--mono-black) !important;
  font-weight: 800 !important;
}
.ocr-tool__option-hint {
  color: var(--mono-gray-500) !important;
}

/* ---- Calculator card ---- */
.ocr-tool__calculator {
  background: var(--mono-black) !important;
  background-image: none !important;
  border: 1px solid var(--mono-gray-900) !important;
  border-radius: 12px !important;
  box-shadow: none !important;
  padding: clamp(22px, 3vw, 32px) !important;
}
.ocr-tool__calculator h2 {
  color: var(--mono-white) !important;
}
.ocr-tool__calculator p {
  color: var(--mono-gray-300) !important;
}
.ocr-tool__calculator-label {
  color: var(--mono-gray-300) !important;
  font-weight: 700 !important;
  letter-spacing: .14em !important;
}
.ocr-tool__calculator-control {
  background: var(--mono-white) !important;
  border: 1px solid var(--mono-gray-100) !important;
  box-shadow: none !important;
}
.ocr-tool__calculator-control em {
  color: var(--mono-black) !important;
  font-weight: 800 !important;
}
.ocr-tool__calculator-input {
  color: var(--mono-black) !important;
}
.ocr-tool__calculator-input[type="range"] {
  accent-color: var(--mono-white);
}
.ocr-tool__calculator-output {
  color: var(--mono-white) !important;
  font-family: var(--ocr-mincho) !important;
  font-weight: 800 !important;
}

/* Casino Record Special badge: tag-over-caption pattern, monochrome */
.ocr-tool__calculator-badge {
  align-items: flex-start !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  color: var(--mono-white) !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  margin-top: 12px !important;
  padding: 0 !important;
  text-transform: none !important;
}
.ocr-tool__calculator-badge-icon {
  display: none !important;
}
.ocr-tool__calculator-badge-label {
  align-items: center;
  background: var(--mono-white) !important;
  border-radius: 4px !important;
  color: var(--mono-black) !important;
  display: inline-flex;
  font-size: 10.5px !important;
  font-weight: 800 !important;
  gap: 6px;
  letter-spacing: .22em !important;
  line-height: 1;
  padding: 5px 9px !important;
  text-transform: uppercase !important;
}
.ocr-tool__calculator-badge-label::before {
  background: var(--mono-black);
  content: "";
  display: inline-block;
  height: 8px;
  width: 8px;
  transform: rotate(45deg);
}
.ocr-tool__calculator-badge-hint {
  color: var(--mono-gray-300) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  letter-spacing: .02em !important;
  line-height: 1.45 !important;
  text-transform: none !important;
}

/* Equalize the months <select> visually with number inputs */
select.ocr-tool__calculator-input {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' width='12' height='8'><path d='M1 1.5L6 6.5L11 1.5' fill='none' stroke='%230a0a0a' stroke-width='1.6' stroke-linecap='round'/></svg>");
}

/* Submit button: solid black, white text */
.ocr-tool__submit,
.ocr-tool__button {
  background: var(--mono-black) !important;
  border: 1px solid var(--mono-black) !important;
  box-shadow: 0 18px 32px -16px rgba(0, 0, 0, .6) !important;
  color: var(--mono-white) !important;
  font-family: var(--ocr-mincho) !important;
  font-weight: 800 !important;
  letter-spacing: .04em !important;
  padding: 16px 24px !important;
  text-shadow: none !important;
  transition: transform .25s cubic-bezier(.2,.8,.25,1), background .25s, color .25s !important;
}
.ocr-tool__submit::before,
.ocr-tool__button::before { display: none !important; }
.ocr-tool__submit:hover,
.ocr-tool__button:hover {
  background: var(--mono-white) !important;
  color: var(--mono-black) !important;
  transform: translateY(-1px);
}
.ocr-tool__reset,
.ocr-tool__scratch-reveal,
.ocr-tool__share-button {
  background: var(--mono-white) !important;
  background-image: none !important;
  border: 1px solid var(--mono-black) !important;
  color: var(--mono-black) !important;
  font-weight: 800 !important;
  min-height: 44px;
}
.ocr-tool__reset:hover,
.ocr-tool__scratch-reveal:hover,
.ocr-tool__share-button:hover {
  background: var(--mono-black) !important;
  color: var(--mono-white) !important;
}

/* ---- Scratch card section ---- */
.ocr-tool__scratch {
  background: var(--mono-black) !important;
  background-image: none !important;
  border: 1px solid var(--mono-gray-900) !important;
  border-radius: 12px !important;
  padding: clamp(36px, 5vw, 56px) clamp(20px, 3vw, 32px) !important;
}
.ocr-tool__scratch h2 {
  color: var(--mono-white) !important;
  font-size: clamp(24px, 3.4vw, 32px) !important;
  letter-spacing: -.01em !important;
}
.ocr-tool__scratch-kicker {
  color: var(--mono-gray-300) !important;
  letter-spacing: .22em !important;
}
.ocr-tool__scratch p,
.ocr-tool__scratch-status {
  color: var(--mono-gray-300) !important;
}

/* After reveal: hide the pre-scratch chrome so the +$ value is THE focal point */
.ocr-tool__scratch--revealed .ocr-tool__scratch-copy,
.ocr-tool__scratch--revealed .ocr-tool__scratch-card,
.ocr-tool__scratch--revealed .ocr-tool__scratch-reveal {
  opacity: 0 !important;
  pointer-events: none !important;
  transition: opacity .35s ease-out;
  visibility: hidden;
  height: 0;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden;
}
.ocr-tool__scratch--revealed {
  display: block !important;
  min-height: 0 !important;
  padding: clamp(20px, 3vw, 28px) !important;
  position: relative;
}

/* The pop-out amount overlay: monochrome — black surface, white type */
.ocr-tool__scratch-amount {
  background: var(--mono-black) !important;
  border: 2px solid var(--mono-white) !important;
  box-shadow: 0 22px 60px -18px rgba(0, 0, 0, .7), 0 0 0 6px rgba(255, 255, 255, .08) inset !important;
  color: var(--mono-white) !important;
  margin: 0 auto !important;
  max-width: 660px !important;
  padding: 20px 32px !important;
  position: static !important;
  transform: none !important;
}
.ocr-tool__scratch-amount-eyebrow {
  color: var(--mono-gray-300) !important;
  letter-spacing: .22em !important;
}
.ocr-tool__scratch-amount-value {
  color: var(--mono-white) !important;
  font-size: clamp(34px, 6vw, 56px) !important;
  text-shadow: none !important;
}
/* Helper pointing the user to scroll for more */
.ocr-tool__scratch--revealed::after {
  color: var(--mono-gray-500);
  content: "↓ see your earnings over time";
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .16em;
  margin-top: 16px;
  text-align: center;
  text-transform: uppercase;
  display: block;
}

.ocr-tool__scratch--revealed .ocr-tool__scratch-card-wrap {
  display: none !important;
}

/* Coins → silver/white */
.ocr-tool__coin {
  background: radial-gradient(circle at 30% 30%, #ffffff, #d6d6d6 60%, #6a6a6a 100%) !important;
  border-color: #ffffff !important;
  color: var(--mono-black) !important;
  text-shadow: 0 1px 0 rgba(255, 255, 255, .35) !important;
}

/* Once a result is active, fade the form and scratch's leftover chrome
   so the visual hierarchy lands on the result body below. */
.ocr-tool--result-active .ocr-tool__form {
  opacity: 1;
  pointer-events: auto;
  transition: opacity .5s ease-out;
}
.ocr-tool--result-active .ocr-tool__form:focus-within {
  opacity: 1;
  pointer-events: auto;
}

/* ---- Result label "Boost unlocked": more breathing room, mono ---- */
.ocr-tool__result-label {
  background: var(--mono-black) !important;
  border: 0 !important;
  border-radius: 12px 12px 0 0 !important;
  color: var(--mono-white) !important;
  font-family: var(--ocr-mincho) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: .22em !important;
  padding: 16px 22px !important;
  text-transform: uppercase !important;
}
.ocr-tool__result-label::before {
  background: var(--mono-white) !important;
  border-radius: 2px !important;
  box-shadow: none !important;
  color: var(--mono-black) !important;
  height: 18px !important;
  width: 18px !important;
}

/* Result body itself: white paper, generous padding, no card-in-card noise */
.ocr-tool__result {
  background: var(--mono-white) !important;
  border: 1px solid var(--mono-gray-100) !important;
  border-radius: 0 0 12px 12px !important;
  overflow: hidden;
}
.ocr-tool__result-body {
  background: var(--mono-white) !important;
  display: grid;
  gap: clamp(20px, 3vw, 32px) !important;
  padding: clamp(24px, 3.5vw, 40px) !important;
}
.ocr-tools-content .ocr-tool__result h2 {
  color: var(--mono-black) !important;
  font-family: var(--ocr-mincho) !important;
  font-size: clamp(22px, 2.6vw, 30px) !important;
  font-weight: 700 !important;
  letter-spacing: -.005em !important;
  margin: 0 !important;
}
.ocr-tools-content .ocr-tool__result h3 {
  color: var(--mono-black) !important;
  font-family: var(--ocr-mincho) !important;
}
.ocr-tools-content .ocr-tool__result h3::after {
  background: var(--mono-black) !important;
}
.ocr-tool__result-summary {
  color: var(--mono-gray-700) !important;
  font-size: 15px !important;
  line-height: 1.8 !important;
  max-width: 64ch !important;
}

/* Bonus ticket: paper white, thick black accent line */
.ocr-tool__bonus-ticket {
  background: var(--mono-white) !important;
  background-image: none !important;
  border: 1px solid var(--mono-gray-100) !important;
  border-left: 4px solid var(--mono-black) !important;
  border-radius: 8px !important;
  color: var(--mono-black) !important;
  column-gap: clamp(10px, 1.8vw, 22px) !important;
  grid-template-columns: minmax(170px, .32fr) minmax(200px, .34fr) minmax(0, 1fr) !important;
  align-items: center !important;
  padding: 20px 24px !important;
}
.ocr-tool__bonus-ticket strong,
.ocr-tool__bonus-ticket-value {
  color: var(--mono-black) !important;
  font-size: clamp(28px, 3.2vw, 36px) !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  word-break: keep-all !important;
  overflow-wrap: normal !important;
}
.ocr-tool__bonus-ticket span,
.ocr-tool__bonus-ticket small {
  color: var(--mono-gray-500) !important;
}
.ocr-tool__bonus-ticket span {
  white-space: normal !important;
  line-height: 1.2 !important;
}
.ocr-tool[data-locale="en"] .ocr-tool__bonus-ticket {
  grid-template-columns: minmax(200px, .36fr) minmax(170px, .3fr) minmax(0, 1fr) !important;
}
.ocr-tool[data-locale="ja"] .ocr-tool__bonus-ticket {
  grid-template-columns: minmax(128px, .26fr) minmax(220px, .4fr) minmax(0, 1fr) !important;
}
.ocr-tool[data-locale="ja"] .ocr-tool__bonus-ticket span {
  white-space: nowrap !important;
}

/* Hide the old snapshot chart card via JS class we set */
.ocr-tool__boost--hidden,
.ocr-tool__boost-compare--hidden {
  display: none !important;
}

/* ---- Line chart: black bg, white line ---- */
.ocr-tool__line-chart {
  background: var(--mono-black) !important;
  background-image: none !important;
  border: 1px solid var(--mono-gray-900) !important;
  border-radius: 12px !important;
  color: var(--mono-white) !important;
  padding: clamp(20px, 2.8vw, 28px) !important;
}
.ocr-tools-content .ocr-tool__line-chart h3,
.ocr-tool__line-chart h3 {
  color: var(--mono-white) !important;
}
.ocr-tool__line-chart-total {
  background: transparent !important;
  border: 1px solid var(--mono-gray-700) !important;
  color: var(--mono-white) !important;
}
.ocr-tool__line-chart-total strong {
  color: var(--mono-white) !important;
}
.ocr-tool__line-chart-fx {
  color: var(--mono-gray-500) !important;
}

/* Repaint the SVG via attribute overrides (CSS can recolor stroke + fill) */
.ocr-tool__line-chart-path  { stroke: var(--mono-white) !important; }
.ocr-tool__line-chart-area  { fill: rgba(255, 255, 255, .08) !important; }
.ocr-tool__line-chart-dot   { fill: var(--mono-white) !important; stroke: var(--mono-black) !important; }
.ocr-tool__line-chart-bubble       { fill: var(--mono-white) !important; stroke: var(--mono-black) !important; }
.ocr-tool__line-chart-bubble-text  { fill: var(--mono-black) !important; }
.ocr-tool__line-chart-mark         { stroke: rgba(255, 255, 255, .35) !important; }
.ocr-tool__line-chart-grid line    { stroke: rgba(255, 255, 255, .08) !important; }
.ocr-tool__line-chart-grid text    { fill: var(--mono-gray-500) !important; }

/* ---- Mascot panel ---- */
.ocr-tool__resimulate {
  background: var(--mono-white) !important;
  background-image: none !important;
  border: 1px solid var(--mono-gray-100) !important;
  padding: clamp(22px, 3vw, 30px) !important;
}
.ocr-tool__resimulate::before {
  background: var(--mono-black) !important;
}
.ocr-tool__mascot img {
  border: 2px solid var(--mono-black) !important;
  background: var(--mono-white) !important;
  box-shadow: none !important;
  object-fit: contain !important;
}
.ocr-tool__mascot-bubble {
  background: var(--mono-white) !important;
  border: 1.5px solid var(--mono-black) !important;
  color: var(--mono-black) !important;
}
.ocr-tool__mascot-bubble::before {
  background: var(--mono-white) !important;
  border-bottom: 1.5px solid var(--mono-black) !important;
  border-left: 1.5px solid var(--mono-black) !important;
}
.ocr-tool__resimulate-label {
  color: var(--mono-gray-700) !important;
}
.ocr-tool__resimulate-value {
  color: var(--mono-black) !important;
  font-family: var(--ocr-mincho) !important;
}
.ocr-tool__resimulate-range {
  background: var(--mono-black) !important;
  box-sizing: border-box !important;
  height: 4px !important;
  margin: 4px 12px !important;
  width: calc(100% - 24px) !important;
}
.ocr-tool__resimulate-range::-webkit-slider-thumb {
  background: var(--mono-white) !important;
  border: 2px solid var(--mono-black) !important;
}
.ocr-tool__resimulate-range::-moz-range-thumb {
  background: var(--mono-white) !important;
  border: 2px solid var(--mono-black) !important;
}

/* ---- Boost stack / Power moves cards: white with thin border ---- */
.ocr-tool__checklist,
.ocr-tool__result-grid > * {
  background: var(--mono-white) !important;
  background-image: none !important;
  border: 1px solid var(--mono-gray-100) !important;
  padding: clamp(20px, 2.6vw, 26px) !important;
}
.ocr-tool__result-grid {
  display: grid;
  gap: clamp(12px, 2vw, 18px);
  grid-template-columns: 1fr 1fr;
}

.ocr-tool__result-panel .ocr-tool__checklist,
.ocr-tool__result-panel .ocr-tool__watchlist {
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
}

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

/* ---- Invite-code chip + offer card ---- */
.ocr-tool__code-row,
.ocr-tool__share-code {
  background: var(--mono-white) !important;
  background-image: none !important;
  border: 1px solid var(--mono-gray-100) !important;
}
.ocr-tool__share-code-value,
.ocr-tool__code-row strong {
  background: var(--mono-black) !important;
  border: 0 !important;
  color: var(--mono-white) !important;
  padding: 6px 14px !important;
}
.ocr-tool__offer-card {
  background: var(--mono-white) !important;
  background-image: none !important;
  border: 1px solid var(--mono-gray-100) !important;
}
.ocr-tool__offer-card::before {
  background: var(--mono-black) !important;
}
.ocr-tool__offer-card h4,
.ocr-tool__offer-card strong,
.ocr-tool__offer-title {
  color: var(--mono-black) !important;
}

/* ---- Result actions: primary CTA is solid black, full width on mobile ---- */
.ocr-tool__result-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.ocr-tool__result-actions .ocr-tool__button--primary,
.ocr-tool__result-actions a[class*="primary"] {
  background: var(--mono-black);
  border: 1px solid var(--mono-black);
  color: var(--mono-white);
  flex: 1 1 220px;
  font-weight: 800;
  letter-spacing: .04em;
  padding: 16px 22px;
  text-align: center;
}

/* ---- Tighten "Boost unlocked" + "Reveal my numbers" hierarchy ---- */
.ocr-tool__scratch {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.ocr-tool__scratch-copy {
  display: flex;
  flex-direction: column;
  gap: 8px;
  text-align: center;
}
.ocr-tool__scratch-kicker {
  margin: 0 !important;
}
.ocr-tool__scratch-card-wrap {
  margin-top: 8px !important;
}

/* Big breathing room on result section spacing — collapses neatly on mobile */
@media (max-width: 640px) {
  .ocr-tool__result-body {
    padding: 20px !important;
  }
  .ocr-tool__bonus-ticket {
    grid-template-columns: 1fr !important;
    row-gap: 8px !important;
    padding: 16px 18px !important;
  }
  .ocr-tool__bonus-ticket strong {
    font-size: 26px !important;
  }
  .ocr-tool__resimulate-range {
    margin: 4px 10px !important;
    width: calc(100% - 20px) !important;
  }
  .ocr-tool__scratch-amount {
    padding: 16px 22px !important;
  }
  .ocr-tool__scratch-amount-value {
    font-size: clamp(28px, 8vw, 40px) !important;
  }
}

/* Force layout consistency for the months select vs number inputs */
.ocr-tool__calculator-input,
select.ocr-tool__calculator-input,
input.ocr-tool__calculator-input {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  width: 100% !important;
}

/* ---- The affiliate button IS the primary CTA — make it unmissable ---- */
.ocr-tool__button--affiliate {
  background: var(--mono-black) !important;
  background-image: none !important;
  border: 1.5px solid var(--mono-black) !important;
  box-shadow: 0 22px 38px -18px rgba(0, 0, 0, .7) !important;
  color: var(--mono-white) !important;
  display: block !important;
  font-family: var(--ocr-mincho) !important;
  font-size: 17px !important;
  font-weight: 800 !important;
  letter-spacing: .04em !important;
  padding: 18px 26px !important;
  text-align: center !important;
  text-decoration: none !important;
  width: 100% !important;
}
.ocr-tool__button--affiliate::before { display: none !important; }
.ocr-tool__button--affiliate:hover {
  background: var(--mono-white) !important;
  color: var(--mono-black) !important;
}

/* Secondary + LINE buttons in the follow-actions row */
.ocr-tool__result-actions--follow {
  border-top: 1px solid var(--mono-gray-100);
  display: flex !important;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 10px;
  padding-top: 18px;
}
.ocr-tool__result-actions--follow .ocr-tool__button {
  background: var(--mono-white) !important;
  border: 1px solid var(--mono-black) !important;
  color: var(--mono-black) !important;
  flex: 1 1 200px;
  text-align: center;
}
.ocr-tool__result-actions--follow .ocr-tool__button:hover {
  background: var(--mono-black) !important;
  color: var(--mono-white) !important;
}

/* Code-helper chip ("Invite code: 82237 [Copy code]") */
.ocr-tool__code-helper {
  align-items: center;
  background: var(--mono-white);
  border: 1px solid var(--mono-gray-100);
  border-radius: 10px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: space-between;
  padding: 14px 18px;
}
.ocr-tool__code-helper > * { color: var(--mono-black); }
.ocr-tool__code-helper strong,
.ocr-tool__code-helper [class*="code-value"],
.ocr-tool__share-code-value,
.ocr-tool__code-row strong {
  background: var(--mono-black) !important;
  border: 0 !important;
  border-radius: 4px;
  color: var(--mono-white) !important;
  font-family: var(--ocr-mincho) !important;
  font-weight: 800;
  letter-spacing: .12em;
  padding: 4px 12px !important;
}
.ocr-tool__code-helper button,
.ocr-tool__code-copy {
  background: var(--mono-white) !important;
  border: 1px solid var(--mono-black) !important;
  border-radius: 999px !important;
  color: var(--mono-black) !important;
  cursor: pointer;
  font-weight: 700;
  padding: 8px 16px !important;
}
.ocr-tool__code-helper button:hover,
.ocr-tool__code-copy:hover {
  background: var(--mono-black) !important;
  color: var(--mono-white) !important;
}

/* Offer card at the bottom: monochrome with thumbnail */
.ocr-tool__offer-card {
  align-items: center;
  background: var(--mono-white) !important;
  background-image: none !important;
  border: 1px solid var(--mono-gray-100) !important;
  border-radius: 12px !important;
  display: flex !important;
  flex-wrap: wrap;
  gap: 18px;
  padding: 16px !important;
  position: relative;
}
.ocr-tool__offer-card img {
  border-radius: 8px;
  flex: 0 0 auto;
  max-width: 180px;
}
.ocr-tool__offer-card::before {
  background: var(--mono-black) !important;
  height: 70% !important;
  top: 15% !important;
  width: 3px !important;
}
.ocr-tool__offer-card a[class*="code"],
.ocr-tool__offer-card [class*="promo-code"] {
  background: var(--mono-black) !important;
  border: 0 !important;
  color: var(--mono-white) !important;
  font-family: var(--ocr-mincho) !important;
  padding: 4px 12px !important;
}

/* On mobile let everything stack with full width */
@media (max-width: 640px) {
  .ocr-tool__offer-card {
    flex-direction: column;
    text-align: left;
  }
  .ocr-tool__offer-card img {
    max-width: 100%;
    width: 100%;
  }
  .ocr-tool__result-actions--follow .ocr-tool__button {
    flex: 1 1 100%;
  }
}

.ocr-tool__calculator-field[data-bonus-active="0"] .ocr-tool__calculator-badge {
  display: none !important;
}

.ocr-tool__calculator-field[data-bonus-active="1"] .ocr-tool__calculator-badge {
  display: grid !important;
  gap: 8px !important;
  max-width: 100% !important;
}

.ocr-tool__calculator-field[data-bonus-active="1"] .ocr-tool__calculator-badge-label {
  align-items: center;
  display: inline-flex;
  font-size: 12px !important;
  letter-spacing: .12em !important;
  line-height: 1.15 !important;
  max-width: 100%;
  padding: 8px 10px !important;
  white-space: normal;
  width: max-content;
}

.ocr-tool__calculator-field[data-bonus-active="1"] .ocr-tool__calculator-badge-hint {
  max-width: 32ch;
}

.ocr-tool__actions {
  align-items: center !important;
  display: flex !important;
  flex-wrap: wrap;
  gap: 12px !important;
  justify-content: center !important;
  text-align: center !important;
}

.ocr-tool__saved-note,
.ocr-tool__error {
  flex: 1 1 100%;
  margin: 0 !important;
  text-align: center;
}

.ocr-tool__scratch-copy {
  justify-items: center !important;
  text-align: center !important;
}

.ocr-tool__scratch-logos {
  align-items: center;
  display: inline-flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}

.ocr-tool__scratch-logo {
  align-items: center;
  background: rgba(255, 255, 255, .96);
  border: 1px solid rgba(230, 199, 108, .72);
  border-radius: 999px;
  color: var(--mono-black);
  display: inline-flex;
  height: 40px;
  justify-content: center;
  min-width: 132px;
  padding: 7px 16px;
  white-space: nowrap;
}

.ocr-tool__scratch-logo img {
  display: block;
  height: 100%;
  max-width: 170px;
  object-fit: contain;
  width: auto;
}

.ocr-tool__scratch-logo--kk {
  background: rgba(255, 255, 255, .96);
  border-color: #e6c76c;
  min-width: 150px;
}

.ocr-tool__scratch-logo--ocr {
  min-width: 190px;
}

.ocr-tool__scratch-logo-x {
  color: #e6c76c;
  font-family: var(--ocr-mincho);
  font-size: 18px;
  font-weight: 900;
  line-height: 1;
}

.ocr-tool__scratch-status {
  display: inline-flex !important;
  justify-content: center;
  max-width: none !important;
  text-align: center !important;
  white-space: nowrap;
}

.ocr-tool__scratch-card,
.ocr-tool__scratch[data-scratch-state="locked"] .ocr-tool__scratch-card {
  background:
    linear-gradient(135deg, #fff8d0 0%, #d7a722 52%, #8f6209 100%) !important;
  border: 1px solid rgba(230, 199, 108, .88) !important;
  border-radius: 18px !important;
  box-shadow:
    0 28px 70px -30px rgba(0, 0, 0, .9),
    inset 0 1px 0 rgba(255, 255, 255, .18),
    inset 0 -1px 0 rgba(230, 199, 108, .26) !important;
  opacity: 1 !important;
}

.ocr-tool__scratch:not(.ocr-tool__scratch--revealed) .ocr-tool__scratch-canvas {
  opacity: 1 !important;
}

.ocr-tool__scratch-amount {
  background: linear-gradient(135deg, #fff4bd 0%, #d8a929 48%, #8f6209 100%) !important;
  border-color: #fff1a8 !important;
  box-shadow: 0 24px 70px -22px rgba(168, 116, 7, .85), 0 0 0 6px rgba(255, 241, 168, .22) inset !important;
  color: #1f1500 !important;
}

.ocr-tool__scratch-amount-eyebrow,
.ocr-tool__scratch-amount-value {
  color: #1f1500 !important;
}

.ocr-tool__coin-burst {
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  position: fixed;
  z-index: 2147483000;
}

.ocr-tool__coin-burst .ocr-tool__coin {
  background:
    radial-gradient(circle at 30% 24%, #fff8c9 0 18%, #f5c845 42%, #c99016 70%, #7b4d05 100%) !important;
  border-color: #fff0a3 !important;
  box-shadow: 0 10px 24px -10px rgba(0, 0, 0, .55), 0 0 0 2px rgba(255, 255, 255, .3) inset !important;
  color: transparent !important;
  height: 26px !important;
  left: var(--start-x) !important;
  top: -10vh !important;
  width: 26px !important;
  animation-name: ocr-coin-rain !important;
  animation-timing-function: cubic-bezier(.18, .72, .26, 1) !important;
  animation-fill-mode: forwards !important;
  will-change: transform, opacity;
}

.ocr-tool__coin-burst .ocr-tool__coin::after {
  border: 2px solid rgba(98, 59, 0, .45);
  border-radius: 50%;
  content: "";
  inset: 7px;
  position: absolute;
}

@keyframes ocr-coin-rain {
  0% {
    opacity: 0;
    transform: translate3d(0, -12vh, 0) rotate(0deg) scale(.82);
  }
  8% {
    opacity: 1;
  }
  78% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    transform: translate3d(var(--drift), var(--fall), 0) rotate(var(--rot)) scale(1.08);
  }
}

.ocr-tool__line-chart-total small {
  color: rgba(253, 249, 238, .6);
  display: block;
  font-size: 11px;
  font-weight: 700;
  line-height: 1.25;
  margin-top: 3px;
}

@media (max-width: 640px) {
  .ocr-tool__scratch-status {
    white-space: normal;
  }
}

/* ---- Rakeback comparison cleanup --------------------------------------- */
.ocr-tool--comparison .ocr-tool__form {
  gap: 16px;
}

.ocr-tool--comparison .ocr-tool__calculator {
  background: #070808 !important;
  border: 1px solid #202326 !important;
  border-radius: 8px !important;
  box-shadow: 0 22px 52px -32px rgba(0, 0, 0, .62) !important;
  gap: clamp(22px, 3vw, 34px) !important;
  grid-template-columns: minmax(220px, .34fr) minmax(0, .66fr) !important;
  padding: clamp(22px, 3.2vw, 34px) !important;
}

.ocr-tool--comparison .ocr-tool__calculator::before {
  opacity: .1 !important;
}

.ocr-tool--comparison .ocr-tool__calculator-head {
  grid-template-columns: 36px minmax(0, 1fr) !important;
}

.ocr-tool--comparison .ocr-tool__calculator-head > span {
  background: transparent !important;
  border: 0 !important;
  color: #ffffff !important;
  font-family: var(--ocr-mincho) !important;
  font-size: 18px !important;
  height: auto !important;
  line-height: 1.1 !important;
  width: auto !important;
}

.ocr-tool--comparison .ocr-tools-content .ocr-tool__calculator h2,
.ocr-tools-content .ocr-tool--comparison .ocr-tool__calculator h2 {
  color: #ffffff !important;
  font-size: clamp(24px, 2.7vw, 34px) !important;
  line-height: 1.18 !important;
}

.ocr-tool--comparison .ocr-tool__calculator-head p {
  color: rgba(255, 255, 255, .76) !important;
  font-size: 14px !important;
  line-height: 1.75 !important;
  max-width: 28em !important;
}

.ocr-tool--comparison .ocr-tool__calculator-grid {
  background: #15191a !important;
  border: 1px solid #32383a !important;
  border-radius: 8px !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .04) !important;
  gap: 12px !important;
  padding: 14px !important;
}

.ocr-tool--comparison .ocr-tool__calculator-field {
  background: #1b2021 !important;
  border: 1px solid #3a4245 !important;
  border-radius: 8px !important;
  gap: 10px !important;
  padding: 14px !important;
}

.ocr-tool--comparison .ocr-tool__calculator-label {
  color: rgba(255, 255, 255, .74) !important;
  font-size: 13px !important;
  letter-spacing: 0 !important;
}

.ocr-tool--comparison .ocr-tool__calculator-control {
  background: #ffffff !important;
  border: 1px solid #d7dcde !important;
  border-radius: 8px !important;
  color: #070808 !important;
  min-height: 60px !important;
}

.ocr-tool--comparison .ocr-tool__calculator-control em,
.ocr-tool--comparison .ocr-tool__calculator-input,
.ocr-tool--comparison select.ocr-tool__calculator-input {
  color: #070808 !important;
}

.ocr-tool--comparison .ocr-tool__calculator-control em {
  font-size: 18px !important;
  padding-left: 18px !important;
}

.ocr-tool--comparison .ocr-tool__calculator-input {
  font-size: 24px !important;
  min-height: 58px !important;
  padding: 10px 14px !important;
}

.ocr-tool--comparison .ocr-tool__calculator-field--checkbox {
  grid-column: 1 / -1 !important;
}

.ocr-tool--comparison .ocr-tool__calculator-field--checkbox .ocr-tool__calculator-label {
  align-items: center;
  display: flex;
  justify-content: space-between;
}

.ocr-tool--comparison .ocr-tool__calculator-field--checkbox .ocr-tool__calculator-control {
  background: transparent !important;
  border: 0 !important;
  min-height: 46px !important;
  overflow: visible !important;
}

.ocr-tool--comparison input.ocr-tool__calculator-checkbox {
  appearance: none !important;
  clip-path: inset(50%) !important;
  height: 1px !important;
  margin: 0 !important;
  opacity: 0 !important;
  pointer-events: none !important;
  position: absolute !important;
  width: 1px !important;
}

.ocr-tool__toggle-ui {
  align-items: center;
  color: #ffffff;
  display: inline-flex;
  gap: 12px;
  width: 100%;
}

.ocr-tool__toggle-track {
  background: #ffffff;
  border: 1px solid #cfd5d7;
  border-radius: 999px;
  display: inline-flex;
  flex: 0 0 auto;
  height: 30px;
  padding: 3px;
  transition: background-color .18s ease, border-color .18s ease;
  width: 56px;
}

.ocr-tool__toggle-knob {
  background: #070808;
  border-radius: 999px;
  display: block;
  height: 22px;
  transform: translateX(0);
  transition: transform .18s ease, background-color .18s ease;
  width: 22px;
}

.ocr-tool__toggle-text {
  color: rgba(255, 255, 255, .86);
  font-size: 13px;
  font-weight: 900;
  line-height: 1.3;
}

.ocr-tool--comparison .ocr-tool__calculator-checkbox:checked + .ocr-tool__toggle-ui .ocr-tool__toggle-track {
  background: #f0d589;
  border-color: #f0d589;
}

.ocr-tool--comparison .ocr-tool__calculator-checkbox:checked + .ocr-tool__toggle-ui .ocr-tool__toggle-knob {
  background: #070808;
  transform: translateX(26px);
}

.ocr-tool--comparison .ocr-tool__actions {
  background: #ffffff !important;
  border: 1px solid #dce2e4 !important;
  border-radius: 8px !important;
  box-shadow: none !important;
  margin-top: 8px !important;
  padding: 16px !important;
}

.ocr-tool--comparison .ocr-tool__submit,
.ocr-tool--comparison .ocr-tool__reset {
  border-radius: 8px !important;
  min-height: 52px !important;
  padding: 13px 28px !important;
}

.ocr-tool--comparison .ocr-tool__result {
  border-radius: 8px !important;
  margin-top: 22px !important;
}

.ocr-tool--comparison .ocr-tool__result-body {
  gap: clamp(18px, 2.4vw, 28px) !important;
}

.ocr-tool--comparison .ocr-tool__savings-hero {
  background:
    radial-gradient(circle at 96% 8%, rgba(244, 217, 142, .22), transparent 34%),
    linear-gradient(135deg, #080909 0%, #0d1719 52%, #071114 100%) !important;
  border: 1px solid #202a2d !important;
  border-radius: 8px !important;
  color: #ffffff !important;
  display: grid !important;
  gap: 14px !important;
  overflow: hidden !important;
  padding: clamp(24px, 3.4vw, 42px) !important;
  position: relative !important;
}

.ocr-tool--comparison .ocr-tool__savings-hero::before {
  background:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size: 26px 26px;
  content: "";
  inset: 0;
  opacity: .38;
  pointer-events: none;
  position: absolute;
}

.ocr-tool--comparison .ocr-tool__savings-label,
.ocr-tool--comparison .ocr-tool__savings-title,
.ocr-tool--comparison .ocr-tool__savings-value,
.ocr-tool--comparison .ocr-tool__savings-text,
.ocr-tool--comparison .ocr-tool__savings-facts {
  position: relative;
  z-index: 1;
}

.ocr-tool--comparison .ocr-tool__savings-label {
  color: #f4d98e !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  line-height: 1.35 !important;
}

.ocr-tools-content .ocr-tool--comparison .ocr-tool__savings-title,
.ocr-tool--comparison .ocr-tool__savings-title {
  color: #ffffff !important;
  font-size: clamp(25px, 3.2vw, 42px) !important;
  line-height: 1.16 !important;
  margin: 0 !important;
  max-width: 18em !important;
  padding: 0 !important;
}

.ocr-tool--comparison .ocr-tool__savings-value {
  color: #f4d98e !important;
  display: block !important;
  font-family: var(--ocr-mincho) !important;
  font-size: clamp(46px, 7vw, 88px) !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  overflow-wrap: anywhere !important;
}

.ocr-tool--comparison .ocr-tool__savings-text {
  color: rgba(255, 255, 255, .78) !important;
  font-size: 15px !important;
  line-height: 1.75 !important;
  margin: 0 !important;
  max-width: 48em !important;
}

.ocr-tool--comparison .ocr-tool__savings-facts {
  display: grid !important;
  gap: 10px !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  margin-top: 6px !important;
}

.ocr-tool--comparison .ocr-tool__savings-facts span {
  background: rgba(255, 255, 255, .08) !important;
  border: 1px solid rgba(255, 255, 255, .14) !important;
  border-radius: 8px !important;
  display: grid !important;
  gap: 5px !important;
  min-width: 0 !important;
  padding: 12px 14px !important;
}

.ocr-tool--comparison .ocr-tool__savings-facts small {
  color: rgba(255, 255, 255, .62) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  line-height: 1.25 !important;
}

.ocr-tool--comparison .ocr-tool__savings-facts b {
  color: #ffffff !important;
  font-size: 17px !important;
  line-height: 1.2 !important;
  overflow-wrap: anywhere !important;
}

.ocr-tool.ocr-tool--comparison .ocr-tool__bonus-ticket,
.ocr-tool.ocr-tool--comparison[data-locale="ja"] .ocr-tool__bonus-ticket,
.ocr-tool.ocr-tool--comparison[data-locale="en"] .ocr-tool__bonus-ticket {
  align-items: center !important;
  background: #ffffff !important;
  border: 1px solid #dfe4e6 !important;
  border-left: 4px solid #070808 !important;
  border-radius: 8px !important;
  column-gap: clamp(16px, 2.4vw, 30px) !important;
  display: grid !important;
  grid-template-columns: minmax(96px, .16fr) minmax(300px, .36fr) minmax(260px, 1fr) !important;
  overflow: hidden !important;
  padding: 20px 24px !important;
}

.ocr-tool.ocr-tool--comparison .ocr-tool__bonus-ticket span,
.ocr-tool.ocr-tool--comparison[data-locale="ja"] .ocr-tool__bonus-ticket span,
.ocr-tool.ocr-tool--comparison[data-locale="en"] .ocr-tool__bonus-ticket span {
  color: #667176 !important;
  font-size: 13px !important;
  line-height: 1.35 !important;
  white-space: normal !important;
}

.ocr-tool.ocr-tool--comparison .ocr-tool__bonus-ticket strong {
  color: #070808 !important;
  font-size: clamp(30px, 3.2vw, 42px) !important;
  line-height: 1.08 !important;
  min-width: 0 !important;
  white-space: normal !important;
  word-break: keep-all !important;
}

.ocr-tool.ocr-tool--comparison .ocr-tool__bonus-ticket small {
  color: #6e777b !important;
  font-size: 13px !important;
  line-height: 1.65 !important;
  min-width: 0 !important;
  overflow-wrap: anywhere !important;
}

.ocr-tool--comparison .ocr-tool__boost {
  background:
    radial-gradient(circle at 98% 0%, rgba(240, 213, 137, .16), transparent 34%),
    linear-gradient(180deg, #071114 0%, #041014 100%) !important;
  border: 1px solid #253034 !important;
  border-radius: 8px !important;
  box-shadow: none !important;
  margin-top: 0 !important;
  padding: clamp(26px, 3.2vw, 42px) !important;
}

.ocr-tool--comparison .ocr-tools-content .ocr-tool__boost h3,
.ocr-tools-content .ocr-tool--comparison .ocr-tool__boost h3 {
  font-size: clamp(24px, 2.6vw, 34px) !important;
  line-height: 1.3 !important;
  max-width: 24em !important;
}

.ocr-tool--comparison .ocr-tool__boost-inputs {
  gap: 10px !important;
  grid-template-columns: repeat(3, minmax(0, auto)) !important;
  justify-content: start !important;
}

.ocr-tool--comparison .ocr-tool__boost-inputs span {
  background: rgba(255, 255, 255, .1) !important;
  border: 1px solid rgba(255, 255, 255, .16) !important;
  border-radius: 999px !important;
  min-width: 0 !important;
}

.ocr-tool--comparison .ocr-tool__boost-summary {
  align-items: stretch !important;
  gap: clamp(18px, 2.4vw, 28px) !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  margin-top: clamp(26px, 3vw, 40px) !important;
}

.ocr-tool--comparison .ocr-tool__boost-card {
  background: rgba(255, 255, 255, .08) !important;
  border: 1px solid rgba(255, 255, 255, .18) !important;
  border-radius: 8px !important;
  align-content: space-between !important;
  gap: clamp(24px, 3.2vw, 44px) !important;
  min-height: clamp(170px, 18vw, 220px) !important;
  padding: clamp(24px, 3vw, 40px) !important;
}

.ocr-tool--comparison .ocr-tool__boost-card-label {
  align-items: center !important;
  background: rgba(244, 217, 142, .12) !important;
  border: 1px solid rgba(244, 217, 142, .34) !important;
  border-radius: 999px !important;
  color: #f4d98e !important;
  display: inline-flex !important;
  font-size: clamp(15px, 1.35vw, 20px) !important;
  font-weight: 900 !important;
  justify-self: start !important;
  letter-spacing: 0 !important;
  line-height: 1.25 !important;
  padding: 8px 14px !important;
  text-transform: none !important;
}

.ocr-tool--comparison .ocr-tool__boost-card--standard .ocr-tool__boost-card-label {
  background: rgba(255, 255, 255, .1) !important;
  border-color: rgba(255, 255, 255, .22) !important;
  color: rgba(255, 255, 255, .88) !important;
}

.ocr-tool--comparison .ocr-tool__boost-card--extra .ocr-tool__boost-card-label {
  background: rgba(244, 217, 142, .18) !important;
  border-color: rgba(244, 217, 142, .52) !important;
  color: #ffe39d !important;
}

.ocr-tool--comparison .ocr-tool__boost-card-value {
  color: #ffffff !important;
  display: block !important;
  font-size: clamp(34px, 3.15vw, 58px) !important;
  line-height: 1.04 !important;
  max-width: 100% !important;
  overflow-wrap: normal !important;
  white-space: nowrap !important;
  word-break: keep-all !important;
}

.ocr-tool--comparison .ocr-tool__boost-card--extra .ocr-tool__boost-card-value {
  font-size: clamp(36px, 3.2vw, 62px) !important;
}

.ocr-tool--comparison .ocr-tool__boost-card--extra .ocr-tool__boost-card-value {
  color: #f4d98e !important;
}

.ocr-tool--comparison .ocr-tool__boost-card--extra {
  grid-column: 1 / -1 !important;
  min-height: clamp(150px, 14vw, 190px) !important;
}

.ocr-tool--comparison .ocr-tool__boost-arrow {
  display: none !important;
}

.ocr-tool--comparison .ocr-tool__boost-compare,
.ocr-tool--comparison .ocr-tool__boost-breakdown {
  background: rgba(255, 255, 255, .07) !important;
  border: 1px solid rgba(255, 255, 255, .14) !important;
  border-radius: 8px !important;
}

.ocr-tool--comparison .ocr-tool__boost-line {
  grid-template-columns: minmax(140px, .28fr) minmax(160px, 1fr) minmax(88px, auto) !important;
}

.ocr-tool--comparison .ocr-tool__boost-line > span {
  color: rgba(255, 255, 255, .82) !important;
  overflow-wrap: anywhere !important;
}

.ocr-tool--comparison .ocr-tool__boost-note {
  color: rgba(255, 255, 255, .72) !important;
  font-size: 13px !important;
}

@media (max-width: 900px) {
  .ocr-tool--comparison .ocr-tool__calculator {
    grid-template-columns: 1fr !important;
  }

  .ocr-tool--comparison .ocr-tool__calculator-head p {
    max-width: 100% !important;
  }

  .ocr-tool.ocr-tool--comparison .ocr-tool__bonus-ticket,
  .ocr-tool.ocr-tool--comparison[data-locale="ja"] .ocr-tool__bonus-ticket,
  .ocr-tool.ocr-tool--comparison[data-locale="en"] .ocr-tool__bonus-ticket {
    grid-template-columns: 1fr !important;
  }

  .ocr-tool--comparison .ocr-tool__boost-summary {
    grid-template-columns: 1fr !important;
  }

  .ocr-tool--comparison .ocr-tool__savings-facts {
    grid-template-columns: 1fr !important;
  }

  .ocr-tool--comparison .ocr-tool__boost-arrow {
    display: none !important;
  }
}

@media (max-width: 640px) {
  .ocr-tool--comparison .ocr-tool__calculator-grid,
  .ocr-tool--comparison .ocr-tool__boost-inputs,
  .ocr-tool--comparison .ocr-tool__boost-line,
  .ocr-tool--comparison .ocr-tool__boost-legend {
    grid-template-columns: 1fr !important;
  }

  .ocr-tool--comparison .ocr-tool__calculator-input {
    font-size: 22px !important;
  }

  .ocr-tool--comparison .ocr-tool__boost-line strong {
    justify-self: start !important;
  }
}

.ocr-tool__share-card {
  align-items: stretch;
  background: #050607;
  border: 1px solid rgba(230, 199, 108, .34);
  border-radius: 12px;
  box-shadow: 0 26px 70px -34px rgba(0, 0, 0, .82);
  display: grid;
  gap: 0;
  grid-template-columns: minmax(280px, 1.18fr) minmax(240px, .82fr);
  margin-top: 22px;
  overflow: hidden;
}

.ocr-tool__share-credit {
  align-content: space-between;
  background:
    linear-gradient(115deg, rgba(255,255,255,0) 0 32%, rgba(255,255,255,.15) 43%, rgba(230,199,108,.18) 50%, rgba(255,255,255,0) 62%),
    repeating-linear-gradient(135deg, rgba(255,255,255,.045) 0 1px, transparent 1px 18px),
    linear-gradient(135deg, #181c22 0%, #050607 43%, #20242b 72%, #08090b 100%);
  border-right: 1px solid rgba(230, 199, 108, .26);
  color: #fff;
  display: grid;
  min-height: 290px;
  padding: clamp(22px, 3vw, 34px);
  position: relative;
}

.ocr-tool__share-credit::after {
  border: 1px solid rgba(230, 199, 108, .56);
  border-radius: 18px;
  content: "";
  inset: 16px;
  pointer-events: none;
  position: absolute;
}

.ocr-tool__share-credit-top,
.ocr-tool__share-credit-code {
  color: rgba(230, 199, 108, .92);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .14em;
  line-height: 1.2;
  position: relative;
  text-transform: uppercase;
  z-index: 1;
}

.ocr-tool__share-credit-code {
  color: rgba(255, 255, 255, .62);
  letter-spacing: .1em;
  text-align: right;
}

.ocr-tool__share-credit-logos {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
  position: relative;
  text-align: center;
  z-index: 1;
}

.ocr-tool__share-credit-logo {
  color: #fff;
  font-family: var(--ocr-mincho);
  font-size: clamp(22px, 3.2vw, 38px);
  font-weight: 900;
  line-height: 1;
  white-space: nowrap;
}

.ocr-tool__share-credit-logo--kk {
  color: #e6c76c;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ocr-tool__share-credit-x {
  color: rgba(255,255,255,.72);
  font-family: var(--ocr-mincho);
  font-size: clamp(20px, 2.5vw, 30px);
  font-weight: 900;
  line-height: 1;
}

.ocr-tool__share-card-copy {
  align-content: center;
  background: #fff;
  display: grid;
  gap: 12px;
  padding: clamp(24px, 3vw, 34px);
}

.ocr-tools-content .ocr-tool__share-card-copy h3 {
  background: none !important;
  border: 0 !important;
  box-shadow: none !important;
  color: var(--mono-black) !important;
  font-size: clamp(22px, 2.4vw, 30px) !important;
  letter-spacing: 0 !important;
  line-height: 1.1 !important;
  margin: 0 !important;
  padding: 0 !important;
}

.ocr-tool__share-card-copy p {
  color: var(--mono-gray-500);
  font-size: 14px;
  line-height: 1.6;
  margin: 0;
}

.ocr-tool__share-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 8px;
}

.ocr-tool__share-card-claim {
  align-items: center;
  background: var(--mono-black);
  border: 1px solid var(--mono-black);
  border-radius: 999px;
  color: var(--mono-white) !important;
  display: inline-flex;
  font-family: var(--ocr-mincho);
  font-size: 15px;
  font-weight: 900;
  justify-content: center;
  line-height: 1.2;
  min-height: 44px;
  padding: 11px 20px;
  text-decoration: none !important;
}

.ocr-tool__share-card-claim:hover {
  background: #e6c76c;
  border-color: #e6c76c;
  color: var(--mono-black) !important;
}

/* Keep native document scrolling. Horizontal clipping must not turn the tool
   wrappers into nested vertical scroll surfaces. */
.ocr-tools-page,
.ocr-tools-page #body_wrap,
.ocr-tools-page #content,
.ocr-tools-page .l-mainContent__inner,
.ocr-tools-page .post_content,
.ocr-tools-page .ocr-tool {
  height: auto !important;
  max-height: none !important;
  overscroll-behavior-y: auto !important;
}

body.ocr-tools-page,
.ocr-tools-page #body_wrap,
.ocr-tools-page .l-mainContent__inner,
.ocr-tools-page .post_content,
.ocr-tools-page .ocr-tool {
  overflow: visible !important;
  overflow-x: visible !important;
  overflow-y: visible !important;
}

@media (max-width: 760px) {
  .ocr-tool__share-card {
    grid-template-columns: 1fr;
  }
  .ocr-tool__share-credit {
    border-right: 0;
    min-height: 240px;
  }
}
