:root {
  color-scheme: dark;
  --ink: #111111;
  --ink-soft: #242424;
  --paper: #fff8ed;
  --paper-clean: #ffffff;
  --muted: #bdb7c7;
  --purple: #7227e8;
  --purple-deep: #42108e;
  --orange: #ff9f1c;
  --orange-soft: #ffd08a;
  --green: #19b37b;
  --line: rgba(255, 255, 255, 0.14);
  --shadow: 0 24px 80px rgba(0, 0, 0, 0.24);
  --radius: 8px;
  font-family:
    Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  letter-spacing: 0;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background: var(--ink);
  color: var(--paper-clean);
  min-width: 320px;
}

body::selection {
  background: var(--orange);
  color: var(--ink);
}

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

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

button,
input,
textarea {
  font: inherit;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
  min-height: 78px;
  padding: 12px clamp(18px, 4vw, 56px);
  background: rgba(17, 17, 17, 0.84);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(18px);
}

.brand {
  display: inline-flex;
  align-items: center;
  width: clamp(118px, 16vw, 164px);
}

.header-nav {
  display: flex;
  align-items: center;
  gap: clamp(14px, 2vw, 28px);
  color: rgba(255, 255, 255, 0.74);
  font-size: 0.92rem;
  font-weight: 700;
}

.header-nav a,
.footer-links a {
  transition:
    color 0.18s ease,
    transform 0.18s ease;
}

.header-nav a:hover,
.footer-links a:hover {
  color: var(--orange);
  transform: translateY(-1px);
}

.header-cta,
.button {
  border: 0;
  border-radius: var(--radius);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 22px;
  font-weight: 900;
  text-align: center;
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease,
    background 0.18s ease;
}

.header-cta {
  background: var(--orange);
  color: #17120a;
  box-shadow: 0 12px 28px rgba(255, 159, 28, 0.22);
}

.button-primary {
  background: linear-gradient(135deg, var(--orange), #ffbd4a);
  color: #17120a;
  box-shadow: 0 18px 42px rgba(255, 159, 28, 0.28);
}

.button-secondary {
  background: rgba(255, 255, 255, 0.1);
  color: var(--paper-clean);
  border: 1px solid rgba(255, 255, 255, 0.18);
}

.header-cta:hover,
.button:hover {
  transform: translateY(-2px);
}

.button-primary:hover {
  box-shadow: 0 22px 52px rgba(255, 159, 28, 0.34);
}

.hero {
  position: relative;
  min-height: 84svh;
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(320px, 0.82fr);
  align-items: center;
  gap: clamp(24px, 5vw, 72px);
  overflow: hidden;
  padding: clamp(64px, 8vw, 118px) clamp(18px, 5vw, 70px) clamp(42px, 6vw, 74px);
  background:
    linear-gradient(115deg, rgba(255, 159, 28, 0.16), transparent 36%),
    linear-gradient(245deg, rgba(114, 39, 232, 0.22), transparent 42%),
    #101010;
}

.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.035) 1px, transparent 1px);
  background-size: 42px 42px;
  mask-image: linear-gradient(90deg, #000 0%, transparent 82%);
}

.hero::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 7px;
  background: linear-gradient(90deg, var(--orange) 0 30%, #ffffff 30% 44%, var(--purple) 44% 64%, var(--orange) 64% 100%);
}

.hero-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, transparent 0%, rgba(17, 17, 17, 0.34) 70%, #111111 100%),
    radial-gradient(circle at 74% 30%, rgba(114, 39, 232, 0.24), transparent 34%);
  pointer-events: none;
}

.hero-content {
  position: relative;
  z-index: 2;
  max-width: 700px;
}

.eyebrow {
  margin: 0 0 14px;
  color: var(--orange);
  font-size: clamp(0.78rem, 1.8vw, 0.9rem);
  text-transform: uppercase;
  font-weight: 950;
}

.eyebrow.dark {
  color: var(--purple);
}

h1,
h2,
h3,
p {
  margin-top: 0;
}

h1 {
  margin-bottom: 20px;
  max-width: 780px;
  font-size: clamp(2.9rem, 8vw, 6.8rem);
  line-height: 0.9;
  text-transform: uppercase;
  text-wrap: balance;
}

h2 {
  margin-bottom: 18px;
  color: inherit;
  font-size: clamp(2rem, 5vw, 4.4rem);
  line-height: 1;
  text-wrap: balance;
}

h3 {
  margin-bottom: 12px;
  font-size: clamp(1.18rem, 2vw, 1.48rem);
  line-height: 1.08;
}

.hero-copy,
.economy-copy p,
.app-copy p,
.japan-copy p,
.checkout-copy p,
.benefit-card p,
.venue-card p,
.faq-list p {
  color: rgba(255, 255, 255, 0.74);
  font-size: 1.03rem;
  line-height: 1.68;
}

.hero-copy {
  max-width: 610px;
  font-size: clamp(1.06rem, 2vw, 1.34rem);
}

.hero-offer {
  display: inline-grid;
  grid-template-columns: auto auto;
  align-items: center;
  gap: 4px 14px;
  margin: 0 0 24px;
  padding: 14px 16px;
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.09);
  border: 1px solid rgba(255, 255, 255, 0.16);
  backdrop-filter: blur(14px);
}

.hero-offer span,
.hero-offer small {
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.84rem;
  font-weight: 850;
}

.hero-offer strong {
  grid-row: span 2;
  color: var(--orange);
  font-size: clamp(1.8rem, 4vw, 3rem);
  line-height: 0.9;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin: 30px 0 34px;
}

.hero-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  max-width: 720px;
}

.hero-metrics div {
  min-height: 112px;
  padding: 18px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(12px);
}

.hero-metrics strong {
  display: block;
  margin-bottom: 8px;
  color: var(--paper-clean);
  font-size: clamp(1.45rem, 3vw, 2.35rem);
  line-height: 1;
}

.hero-metrics span {
  color: rgba(255, 255, 255, 0.68);
  font-size: 0.9rem;
  font-weight: 800;
}

.hero-visual {
  position: relative;
  z-index: 2;
  align-self: center;
}

.hero-visual::before {
  content: "";
  position: absolute;
  z-index: -1;
  inset: 12% 4% 8% 12%;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(255, 159, 28, 0.95), rgba(114, 39, 232, 0.52));
  filter: blur(4px);
  opacity: 0.86;
}

.hero-visual img {
  width: min(560px, 100%);
  margin-inline: auto;
  filter: drop-shadow(0 34px 68px rgba(0, 0, 0, 0.38));
  animation: float-visual 5s ease-in-out infinite;
}

.hero-visual-badge {
  position: absolute;
  right: 0;
  bottom: clamp(8px, 4vw, 46px);
  padding: 12px 14px;
  border-radius: var(--radius);
  background: var(--purple);
  box-shadow: 0 18px 42px rgba(114, 39, 232, 0.28);
}

.hero-visual-badge strong,
.hero-visual-badge span {
  display: block;
}

.hero-visual-badge strong {
  color: #ffffff;
  font-size: 1.12rem;
  line-height: 1;
}

.hero-visual-badge span {
  margin-top: 4px;
  color: rgba(255, 255, 255, 0.78);
  font-size: 0.78rem;
  font-weight: 850;
}

.hero-note {
  position: absolute;
  right: clamp(18px, 5vw, 64px);
  bottom: 34px;
  z-index: 2;
  max-width: 360px;
  padding: 14px 16px;
  border-left: 4px solid var(--orange);
  color: rgba(255, 255, 255, 0.78);
  background: rgba(17, 17, 17, 0.72);
  backdrop-filter: blur(12px);
  border-radius: 0 var(--radius) var(--radius) 0;
  font-weight: 800;
}

.ticker {
  overflow: hidden;
  background: var(--purple);
  border-block: 1px solid rgba(255, 255, 255, 0.16);
}

.ticker-track {
  display: flex;
  width: max-content;
  gap: 28px;
  padding: 16px 0;
  animation: ticker 26s linear infinite;
}

.ticker-track span {
  display: inline-flex;
  min-width: max-content;
  color: #ffffff;
  font-weight: 950;
  text-transform: uppercase;
}

.ticker-track span::after {
  content: "";
  width: 8px;
  height: 8px;
  align-self: center;
  margin-left: 28px;
  background: var(--orange);
  transform: rotate(45deg);
}

.section {
  padding: clamp(68px, 9vw, 124px) clamp(18px, 5vw, 70px);
  background: var(--ink);
}

.section-light {
  background: var(--paper);
  color: var(--ink);
}

.section-inner {
  width: min(1160px, 100%);
  margin: 0 auto;
}

.section-heading {
  max-width: 820px;
  margin-bottom: 38px;
}

.tour-story-section {
  background:
    linear-gradient(180deg, #111111 0%, #171717 100%);
  padding-top: clamp(56px, 7vw, 96px);
}

.tour-story-layout {
  display: grid;
  grid-template-columns: minmax(280px, 0.95fr) minmax(0, 1fr);
  align-items: center;
  gap: clamp(24px, 5vw, 66px);
}

.tour-story-media {
  position: relative;
}

.tour-story-media::before {
  content: "";
  position: absolute;
  inset: 9% 9% 2% 18%;
  z-index: 0;
  border-radius: 999px;
  background: var(--orange);
}

.tour-story-media img {
  position: relative;
  z-index: 1;
  width: min(520px, 100%);
  margin-inline: auto;
  filter: drop-shadow(0 28px 58px rgba(0, 0, 0, 0.34));
}

.tour-story-card {
  padding: clamp(26px, 5vw, 46px);
  border-radius: var(--radius);
  background: linear-gradient(145deg, var(--purple), var(--purple-deep));
  color: #ffffff;
  box-shadow: var(--shadow);
}

.tour-story-card h2 {
  font-size: clamp(2rem, 4.5vw, 3.7rem);
}

.tour-story-card p {
  color: rgba(255, 255, 255, 0.78);
  font-size: 1.06rem;
  line-height: 1.68;
}

.story-points {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 24px;
}

.story-points span {
  padding: 9px 11px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.14);
  color: #ffffff;
  font-size: 0.84rem;
  font-weight: 900;
}

.benefit-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.benefit-card,
.venue-card,
.checkout-card,
.economy-panel {
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}

.benefit-card {
  min-height: 270px;
  padding: 26px;
  background: #ffffff;
  border: 1px solid rgba(17, 17, 17, 0.08);
}

.benefit-card p,
.venue-card p {
  color: rgba(17, 17, 17, 0.68);
}

.card-number {
  display: inline-flex;
  margin-bottom: 32px;
  color: var(--purple);
  font-size: 0.86rem;
  font-weight: 950;
}

.split-section {
  background:
    linear-gradient(135deg, rgba(114, 39, 232, 0.2), transparent 42%),
    #151515;
}

.split-layout,
.app-layout,
.checkout-layout,
.faq-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.9fr);
  align-items: center;
  gap: clamp(34px, 6vw, 78px);
}

.economy-copy {
  max-width: 590px;
}

.economy-panel {
  padding: 28px;
  background: #ffffff;
  color: var(--ink);
}

.saving-row {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 0;
  border-bottom: 1px solid rgba(17, 17, 17, 0.12);
}

.saving-row span {
  color: rgba(17, 17, 17, 0.62);
  font-weight: 800;
}

.saving-row strong {
  white-space: nowrap;
  font-size: 1.25rem;
}

.saving-row.highlight {
  color: var(--purple);
  border-bottom: 0;
}

.progress-shell {
  position: relative;
  height: 14px;
  margin-top: 18px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(17, 17, 17, 0.08);
}

.progress-fill {
  position: absolute;
  inset: 0 auto 0 0;
  width: 86%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--purple), var(--orange));
  animation: pulse-width 2.8s ease-in-out infinite;
}

.app-section {
  background:
    linear-gradient(115deg, rgba(255, 159, 28, 0.12), transparent 36%),
    linear-gradient(180deg, #151515 0%, #101010 100%);
  overflow: hidden;
}

.phone-asset-wrap {
  position: relative;
  min-height: 680px;
  display: grid;
  align-items: center;
  justify-items: center;
}

.phone-asset {
  width: min(420px, 88vw);
  filter: drop-shadow(0 36px 72px rgba(0, 0, 0, 0.48));
  transform: rotate(-4deg);
  transform-origin: center;
  animation: float-visual 5.4s ease-in-out infinite;
}

.phone-float {
  position: absolute;
  z-index: 2;
  min-width: 172px;
  padding: 14px 16px;
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.94);
  color: var(--ink);
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.2);
}

.phone-float strong,
.phone-float span {
  display: block;
}

.phone-float strong {
  color: var(--purple);
  font-size: 1.15rem;
  line-height: 1;
}

.phone-float span {
  margin-top: 4px;
  color: rgba(17, 17, 17, 0.62);
  font-size: 0.8rem;
  font-weight: 850;
}

.phone-float-top {
  top: 88px;
  right: 0;
}

.phone-float-bottom {
  left: 0;
  bottom: 104px;
}

.phone-mock {
  position: relative;
  width: min(360px, 100%);
  margin-inline: auto;
  padding: 14px;
  border-radius: 38px;
  background: linear-gradient(135deg, #2d2d2d, #0a0a0a);
  border: 1px solid rgba(255, 255, 255, 0.22);
  box-shadow: 0 34px 80px rgba(0, 0, 0, 0.42);
  transform: rotate(-4deg);
}

.phone-top {
  position: absolute;
  top: 22px;
  left: 50%;
  width: 96px;
  height: 24px;
  border-radius: 0 0 18px 18px;
  background: #080808;
  transform: translateX(-50%);
  z-index: 2;
}

.phone-screen {
  min-height: 610px;
  padding: 54px 18px 20px;
  overflow: hidden;
  border-radius: 28px;
  background:
    linear-gradient(180deg, rgba(255, 159, 28, 0.18), transparent 34%),
    #141414;
  border: 1px solid rgba(255, 255, 255, 0.12);
}

.phone-screen img {
  width: 132px;
  margin-bottom: 22px;
}

.app-badge {
  display: inline-flex;
  margin-bottom: 18px;
  padding: 8px 12px;
  border-radius: 999px;
  background: var(--purple);
  color: #ffffff;
  font-size: 0.82rem;
  font-weight: 950;
  text-transform: uppercase;
}

.coupon {
  padding: 18px;
  border-radius: var(--radius);
  background: linear-gradient(135deg, var(--orange), #ffd36d);
  color: #15110a;
}

.coupon span,
.coupon small {
  display: block;
  font-weight: 900;
}

.coupon strong {
  display: block;
  margin: 8px 0;
  font-size: 1.4rem;
  line-height: 1.05;
}

.coupon-list {
  display: grid;
  gap: 10px;
  margin-top: 18px;
}

.coupon-list div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 14px;
  border-radius: var(--radius);
  color: rgba(255, 255, 255, 0.86);
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.coupon-list b {
  color: var(--orange);
}

.app-copy {
  max-width: 590px;
}

.app-mini-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 28px;
}

.app-mini-stats div {
  padding: 16px;
  border-radius: var(--radius);
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.08);
}

.app-mini-stats strong,
.app-mini-stats span {
  display: block;
}

.app-mini-stats strong {
  color: var(--orange);
  font-size: 1.24rem;
}

.app-mini-stats span {
  margin-top: 4px;
  color: rgba(255, 255, 255, 0.64);
  font-size: 0.86rem;
  font-weight: 820;
}

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

.check-list li {
  position: relative;
  padding-left: 30px;
  color: rgba(255, 255, 255, 0.78);
  font-weight: 800;
}

.check-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.34em;
  width: 16px;
  height: 16px;
  border-radius: 4px;
  background: var(--green);
  box-shadow: inset 0 0 0 4px rgba(255, 255, 255, 0.34);
}

.venue-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.venue-card {
  min-height: 240px;
  padding: 24px;
  background: #ffffff;
  border: 1px solid rgba(17, 17, 17, 0.08);
}

.venue-card span {
  display: inline-flex;
  margin-bottom: 44px;
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(114, 39, 232, 0.1);
  color: var(--purple);
  font-size: 0.82rem;
  font-weight: 950;
}

.japan-section {
  position: relative;
  min-height: 620px;
  display: grid;
  align-items: end;
  overflow: hidden;
  padding: clamp(68px, 9vw, 124px) clamp(18px, 5vw, 70px);
  background: #111111;
}

.japan-backdrop {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(17, 17, 17, 0.98) 0%, rgba(17, 17, 17, 0.7) 46%, rgba(17, 17, 17, 0.24) 100%),
    url("/assets/japan-campaign.png") center right / min(820px, 70vw) no-repeat,
    #111111;
  transform: scale(1.03);
}

.japan-content {
  position: relative;
  z-index: 2;
}

.japan-copy {
  max-width: 620px;
}

.checkout-section {
  background:
    linear-gradient(160deg, rgba(255, 159, 28, 0.12), transparent 42%),
    linear-gradient(20deg, rgba(114, 39, 232, 0.16), transparent 48%),
    #111111;
}

.final-cta-section {
  background:
    linear-gradient(135deg, rgba(255, 159, 28, 0.2), transparent 45%),
    linear-gradient(20deg, rgba(114, 39, 232, 0.22), transparent 48%),
    #111111;
}

.final-cta-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 0.5fr);
  align-items: center;
  gap: clamp(28px, 5vw, 68px);
}

.final-cta-copy {
  max-width: 720px;
}

.final-cta-copy p {
  max-width: 610px;
  color: rgba(255, 255, 255, 0.74);
  font-size: 1.08rem;
  line-height: 1.68;
}

.final-cta-panel {
  padding: clamp(22px, 4vw, 32px);
  border-radius: var(--radius);
  background: #ffffff;
  color: var(--ink);
  box-shadow: var(--shadow);
}

.final-cta-panel span,
.final-cta-panel small {
  display: block;
  color: rgba(17, 17, 17, 0.62);
  font-weight: 850;
}

.final-cta-panel strong {
  display: block;
  margin: 10px 0;
  color: var(--purple);
  font-size: clamp(2.4rem, 6vw, 4.4rem);
  line-height: 1;
}

.checkout-standalone {
  min-height: calc(100svh - 78px);
  display: grid;
  align-items: center;
  padding-top: clamp(52px, 8vw, 96px);
}

.checkout-page h1 {
  margin-bottom: 18px;
  max-width: 620px;
  font-size: clamp(2.2rem, 5vw, 4.4rem);
  line-height: 0.95;
}

.checkout-layout {
  align-items: start;
}

.checkout-copy {
  position: sticky;
  top: 110px;
  max-width: 540px;
}

.price-box {
  margin-top: 28px;
  padding: 22px;
  border-radius: var(--radius);
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: rgba(255, 255, 255, 0.08);
}

.price-box span,
.price-box small {
  display: block;
  color: rgba(255, 255, 255, 0.68);
  font-weight: 800;
}

.price-box strong {
  display: block;
  margin: 8px 0;
  color: var(--orange);
  font-size: clamp(2.2rem, 5vw, 4.2rem);
  line-height: 1;
}

.checkout-card {
  padding: clamp(20px, 4vw, 30px);
  background: var(--paper-clean);
  color: var(--ink);
}

.field {
  display: grid;
  gap: 8px;
  margin-bottom: 16px;
}

.field-group {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

label {
  font-size: 0.88rem;
  font-weight: 900;
  color: rgba(17, 17, 17, 0.74);
}

input,
textarea {
  width: 100%;
  border: 1px solid rgba(17, 17, 17, 0.14);
  border-radius: var(--radius);
  background: #fafafa;
  color: var(--ink);
  outline: none;
  transition:
    border-color 0.18s ease,
    box-shadow 0.18s ease,
    background 0.18s ease;
}

input {
  min-height: 48px;
  padding: 0 14px;
}

textarea {
  resize: vertical;
  padding: 12px 14px;
  line-height: 1.45;
}

input:focus,
textarea:focus {
  background: #ffffff;
  border-color: var(--purple);
  box-shadow: 0 0 0 4px rgba(114, 39, 232, 0.12);
}

.accept-line {
  display: grid;
  grid-template-columns: 18px 1fr;
  align-items: start;
  gap: 10px;
  margin: 8px 0 18px;
  color: rgba(17, 17, 17, 0.68);
  font-size: 0.86rem;
  line-height: 1.45;
}

.accept-line input {
  width: 18px;
  min-height: 18px;
  margin-top: 2px;
  accent-color: var(--purple);
}

.checkout-button {
  width: 100%;
}

.checkout-button[disabled] {
  cursor: wait;
  opacity: 0.72;
  transform: none;
}

.form-message {
  min-height: 24px;
  margin: 14px 0 0;
  color: var(--purple-deep);
  font-weight: 800;
}

.form-message.error {
  color: #bf2525;
}

.pix-result {
  margin-top: 24px;
  padding-top: 24px;
  border-top: 1px solid rgba(17, 17, 17, 0.1);
}

.pix-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
}

.pix-header h3 {
  margin: 0;
}

.pix-header span {
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(255, 159, 28, 0.16);
  color: #8a4b00;
  font-size: 0.78rem;
  font-weight: 950;
  text-transform: uppercase;
}

#pix-qrcode {
  width: min(260px, 100%);
  margin: 0 auto 16px;
  border: 10px solid #ffffff;
  border-radius: var(--radius);
  box-shadow: 0 10px 28px rgba(17, 17, 17, 0.12);
}

#copy-pix {
  width: 100%;
  margin-top: 12px;
  color: var(--ink);
  background: rgba(17, 17, 17, 0.08);
  border-color: rgba(17, 17, 17, 0.12);
}

.faq-section {
  background: var(--paper);
  color: var(--ink);
}

.faq-layout {
  align-items: start;
}

.faq-list {
  display: grid;
  gap: 12px;
}

details {
  border-radius: var(--radius);
  background: #ffffff;
  border: 1px solid rgba(17, 17, 17, 0.08);
  box-shadow: 0 18px 48px rgba(17, 17, 17, 0.08);
}

summary {
  cursor: pointer;
  padding: 20px;
  color: var(--ink);
  font-weight: 950;
  list-style: none;
}

summary::-webkit-details-marker {
  display: none;
}

summary::after {
  content: "+";
  float: right;
  color: var(--purple);
}

details[open] summary::after {
  content: "-";
}

.faq-list details p {
  margin: 0;
  padding: 0 20px 20px;
  color: rgba(17, 17, 17, 0.68);
}

.site-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 34px clamp(18px, 5vw, 70px);
  background: #0c0c0c;
  border-top: 1px solid var(--line);
}

.site-footer p {
  margin: 8px 0 0;
  color: rgba(255, 255, 255, 0.56);
  font-size: 0.86rem;
}

.footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  color: rgba(255, 255, 255, 0.68);
  font-weight: 800;
}

.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition:
    opacity 0.7s ease,
    transform 0.7s ease;
}

.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@keyframes ticker {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}

@keyframes pulse-width {
  0%,
  100% {
    width: 78%;
  }
  50% {
    width: 92%;
  }
}

@keyframes float-visual {
  0%,
  100% {
    transform: translateY(0) rotate(-4deg);
  }
  50% {
    transform: translateY(-12px) rotate(-3deg);
  }
}

@media (max-width: 980px) {
  .header-nav {
    display: none;
  }

  .hero {
    min-height: 78svh;
    grid-template-columns: minmax(0, 1fr) minmax(260px, 0.66fr);
    padding-top: 52px;
    padding-bottom: 36px;
    background:
      linear-gradient(145deg, rgba(255, 159, 28, 0.16), transparent 46%),
      linear-gradient(235deg, rgba(114, 39, 232, 0.22), transparent 48%),
      #101010;
  }

  .hero h1 {
    font-size: clamp(2.2rem, 5.25vw, 3.45rem);
  }

  .hero-content {
    padding-top: 0;
  }

  .hero-visual {
    order: 0;
    width: auto;
    margin: 0;
  }

  .hero-visual img {
    width: min(420px, 42vw);
  }

  .hero-note {
    position: relative;
    right: auto;
    bottom: auto;
    margin-top: 28px;
  }

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

  .split-layout,
  .app-layout,
  .tour-story-layout,
  .checkout-layout,
  .faq-layout,
  .final-cta-layout {
    grid-template-columns: 1fr;
  }

  .phone-asset-wrap {
    min-height: 620px;
    order: 2;
  }

  .checkout-copy {
    position: static;
  }

  .japan-backdrop {
    background:
      linear-gradient(180deg, rgba(17, 17, 17, 0.26) 0%, rgba(17, 17, 17, 0.96) 64%, #111111 100%),
      url("/assets/japan-campaign.png") top center / min(760px, 110vw) no-repeat,
      #111111;
  }

  .japan-content {
    padding-top: min(58vw, 390px);
  }
}

@media (max-width: 760px) {
  .hero {
    min-height: auto;
    grid-template-columns: 1fr;
    padding-top: 44px;
  }

  .hero-visual {
    order: -1;
    width: min(560px, 100%);
    margin: 0 auto 4px;
  }

  .hero-visual img {
    width: min(360px, 84vw);
  }

  .hero-metrics,
  .hero-note {
    display: none;
  }
}

@media (min-width: 761px) and (max-width: 980px) {
  .app-layout {
    grid-template-columns: minmax(240px, 0.68fr) minmax(0, 1fr);
    gap: 28px;
  }

  .phone-asset-wrap {
    min-height: 620px;
    order: 0;
  }

  .phone-asset {
    width: min(300px, 30vw);
  }

  .phone-float {
    min-width: 150px;
    padding: 12px;
  }

  .phone-float-top {
    top: 116px;
    right: -8px;
  }

  .phone-float-bottom {
    left: -8px;
    bottom: 126px;
  }
}

@media (max-width: 640px) {
  .site-header {
    min-height: 66px;
    gap: 10px;
    padding-inline: 14px;
  }

  .brand {
    width: 106px;
  }

  .header-cta {
    min-height: 42px;
    padding-inline: 14px;
    font-size: 0.86rem;
  }

  .hero {
    padding-inline: 16px;
  }

  .hero-offer {
    width: 100%;
    grid-template-columns: 1fr;
  }

  .hero-offer strong {
    grid-row: auto;
  }

  h1 {
    font-size: clamp(2.15rem, 10vw, 3.45rem);
    line-height: 0.94;
  }

  h2 {
    font-size: clamp(1.8rem, 10vw, 3rem);
  }

  .hero-actions,
  .hero-metrics {
    grid-template-columns: 1fr;
  }

  .hero-copy {
    font-size: 0.98rem;
    line-height: 1.52;
  }

  .hero-actions {
    margin: 18px 0 0;
  }

  .hero-metrics,
  .hero-note {
    display: none;
  }

  .hero-actions .button {
    width: 100%;
  }

  .benefit-grid,
  .venue-grid,
  .field-group {
    grid-template-columns: 1fr;
  }

  .benefit-card,
  .venue-card {
    min-height: auto;
  }

  .phone-mock {
    transform: none;
  }

  .phone-screen {
    min-height: 520px;
  }

  .phone-asset-wrap {
    min-height: 520px;
  }

  .phone-asset {
    width: min(330px, 92vw);
  }

  .phone-float {
    position: relative;
    inset: auto;
    width: 100%;
    min-width: 0;
    max-width: 280px;
    margin-top: -30px;
  }

  .phone-float-top {
    justify-self: end;
  }

  .phone-float-bottom {
    justify-self: start;
  }

  .app-mini-stats {
    grid-template-columns: 1fr;
  }

  .japan-section {
    min-height: auto;
  }

  .pix-header {
    align-items: flex-start;
    flex-direction: column;
  }

  .site-footer {
    align-items: flex-start;
    flex-direction: column;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
  }

  .reveal {
    opacity: 1;
    transform: none;
  }
}

/* ============================== APP SHELL ============================== */
.app-shell{min-height:100vh;background:#2a2724;color:#fff;display:flex;flex-direction:column;max-width:520px;margin:0 auto;position:relative;padding-bottom:78px}
.app-header{display:flex;flex-direction:column;align-items:center;gap:14px;padding:18px 20px 14px;background:#34302c}
.app-brand img{height:38px;width:auto;display:block;object-fit:contain;border-radius:6px}
.app-login-btn{display:block;background:#ff9f1c;color:#fff;font-weight:600;padding:13px 24px;border-radius:999px;text-decoration:none;font-size:15px;width:78%;text-align:center;border:none;cursor:pointer;font-family:inherit}
.app-main{flex:1;padding:14px 16px 20px;background:#2a2724}
.app-tabbar{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:520px;display:grid;grid-template-columns:repeat(4,1fr);background:#34302c;border-top:1px solid #3d3833;padding:10px 4px calc(10px + env(safe-area-inset-bottom));z-index:50}
.app-tab{display:flex;flex-direction:column;align-items:center;gap:4px;color:#8a817a;text-decoration:none;font-size:11px;font-weight:500;padding:4px 0}
.app-tab.is-active{color:#ff9f1c}

/* Banner carousel */
.banner-card{position:relative;border-radius:18px;overflow:hidden;background:linear-gradient(135deg,#1f1715,#2a1d18);border:1.5px solid #ff9f1c;padding:18px;display:grid;grid-template-columns:1.1fr 1fr;gap:10px;align-items:center;min-height:160px}
.banner-card .b-title{font-family:Georgia,serif;color:#fff;font-size:24px;line-height:1;letter-spacing:.5px;margin:0}
.banner-card .b-edicao{font-family:Georgia,serif;color:#ff9f1c;font-size:32px;line-height:1;margin:4px 0 10px;font-style:italic}
.banner-card .b-copy{font-size:11px;color:#e9d9c9;margin:0 0 12px;line-height:1.35}
.banner-card .b-copy b{color:#ff9f1c}
.banner-card .b-cta{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,#8a3df0,#5b1ec4);color:#fff;font-weight:800;font-size:12px;padding:10px 16px;border-radius:999px;text-decoration:none;border:1.5px dashed rgba(255,255,255,.4);letter-spacing:.5px}
.banner-card .b-emoji{position:absolute;font-size:28px}
.banner-dots{display:flex;justify-content:center;gap:6px;margin:10px 0}
.banner-dots span{width:7px;height:7px;border-radius:50%;background:#4a3d34}
.banner-dots span.on{background:#9b8a7c}

.hero-strip{position:relative;border-radius:16px;overflow:hidden;margin:14px 0 0;height:140px;background:linear-gradient(135deg,#3a1f14,#5c2818);display:flex;align-items:center;justify-content:center;font-size:60px}
.hero-strip::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 60%,rgba(255,159,28,.25),transparent 60%)}
.hero-strip-badge{position:absolute;top:14px;left:0;background:rgba(20,15,12,.85);color:#fff;font-weight:800;font-size:12px;padding:8px 14px 8px 14px;border-radius:0 8px 8px 0;letter-spacing:.5px;line-height:1.2}
.hero-strip-badge::after{content:"👑";margin-left:6px}

.access-cta{display:flex;align-items:center;gap:12px;background:#3a2e26;border-radius:12px;padding:14px 18px;margin-top:14px;text-decoration:none;color:#fff}
.access-cta .ic{width:34px;height:34px;border-radius:8px;background:#fff;color:#1a120c;display:grid;place-items:center;font-size:18px;font-weight:900}
.access-cta .tx{flex:1;font-weight:600;font-size:14px;letter-spacing:.3px}
.access-cta .tx b{color:#ff9f1c}
.access-cta .ar{color:#fff;font-size:20px}

.section-head{display:flex;align-items:center;justify-content:space-between;margin:22px 4px 12px}
.section-head h2{font-size:15px;font-weight:800;letter-spacing:.5px;margin:0;color:#fff;text-transform:uppercase}
.section-head .pill{background:linear-gradient(135deg,#8a3df0,#5b1ec4);color:#fff;font-size:11px;padding:5px 10px;border-radius:999px}

.coupon-rail{display:flex;gap:12px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:6px;margin:0 -16px;padding-left:16px;padding-right:16px;scrollbar-width:none}
.coupon-rail::-webkit-scrollbar{display:none}
.coupon-card{position:relative;flex:0 0 260px;background:#2a221d;border-radius:14px;overflow:hidden;scroll-snap-align:start;color:inherit;text-decoration:none;display:block}
.coupon-card .img{height:140px;background:linear-gradient(135deg,#4a2f1f,#2a1810);display:flex;align-items:center;justify-content:center;font-size:60px;position:relative;overflow:hidden}
.coupon-card .bonus{position:absolute;top:10px;left:-30px;transform:rotate(-30deg);background:#ff9f1c;color:#1a120c;font-weight:900;font-size:11px;padding:4px 36px;letter-spacing:.5px}
.coupon-card .body{padding:14px;position:relative}
.coupon-card .logo{position:absolute;top:-22px;left:14px;width:44px;height:44px;border-radius:50%;background:#fff;color:#1a120c;font-weight:900;display:grid;place-items:center;border:3px solid #2a221d;font-size:14px}
.coupon-card h3{margin:0 0 4px 50px;font-size:15px;color:#fff}
.coupon-card .desc{margin:0 0 0 50px;font-size:12px;color:#bdb0a3;line-height:1.35}
.coupon-card .heart{position:absolute;top:10px;right:10px;color:#fff;opacity:.85}
.coupon-card.locked .img,.coupon-card.locked .body{filter:blur(3px) brightness(.6)}
.coupon-card .lock{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#fff;background:rgba(20,15,12,.55);z-index:2}
.coupon-card .lock .ic{font-size:34px}
.coupon-card .lock .tx{font-size:12px;font-weight:700;letter-spacing:.5px;text-align:center;padding:0 12px}

/* CUPONS PAGE */
.search-bar{display:flex;align-items:center;gap:10px;background:#1a120c;border:1px solid #3a2e26;border-radius:999px;padding:12px 18px;margin:10px 0}
.search-bar input{flex:1;background:none;border:none;outline:none;color:#fff;font-size:14px}
.search-bar input::placeholder{color:#7a6b5f}

.cat-rail{display:flex;gap:18px;overflow-x:auto;padding:14px 4px 8px;margin:0 -16px 8px;padding-left:16px;padding-right:16px;scrollbar-width:none}
.cat-rail::-webkit-scrollbar{display:none}
.cat-item{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:6px;color:#9b8c80;font-size:11px;font-weight:600;background:none;border:none;cursor:pointer;padding:0}
.cat-item .ico{width:46px;height:46px;border-radius:10px;background:#2a221d;display:grid;place-items:center;font-size:22px;border:2px solid transparent}
.cat-item.is-active{color:#ff9f1c}
.cat-item.is-active .ico{border-color:#ff9f1c;background:#3a2e26}

.coupon-list{display:flex;flex-direction:column;gap:14px;margin-top:6px}
.coupon-row{position:relative;background:#2a221d;border-radius:16px;overflow:hidden;display:flex;min-height:130px;color:inherit;text-decoration:none}
.coupon-row .img{flex:0 0 130px;background:linear-gradient(135deg,#4a2f1f,#2a1810);display:flex;align-items:center;justify-content:center;font-size:42px;position:relative}
.coupon-row .bonus{position:absolute;top:10px;left:-30px;transform:rotate(-30deg);background:#ff9f1c;color:#1a120c;font-weight:900;font-size:10px;padding:3px 36px;letter-spacing:.5px}
.coupon-row .body{flex:1;padding:14px 14px 14px 56px;position:relative;display:flex;flex-direction:column;justify-content:center}
.coupon-row .logo{position:absolute;top:50%;left:-22px;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:#fff;color:#1a120c;font-weight:900;display:grid;place-items:center;border:3px solid #2a221d;font-size:13px}
.coupon-row h3{margin:0 0 4px;font-size:15px;color:#fff}
.coupon-row .desc{margin:0;font-size:12px;color:#bdb0a3;line-height:1.35}
.coupon-row .neigh{margin-top:6px;font-size:11px;color:#7a6b5f}
.coupon-row .heart{position:absolute;top:12px;right:12px;color:#fff;opacity:.7}
.coupon-row.locked .img,.coupon-row.locked .body{filter:blur(3px) brightness(.55)}
.coupon-row .lock-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;background:rgba(20,15,12,.6);z-index:2;text-align:center;padding:10px}
.coupon-row .lock-overlay .ic{font-size:28px}
.coupon-row .lock-overlay .tx{font-size:11px;font-weight:700;letter-spacing:.4px;color:#fff;line-height:1.3}

.unlock-banner{display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,#ff9f1c,#ff6a3d);color:#1a120c;padding:14px 16px;border-radius:14px;margin:12px 0 4px;text-decoration:none}
.unlock-banner .ic{font-size:26px}
.unlock-banner .tx{flex:1;font-weight:800;font-size:13px;line-height:1.25}
.unlock-banner .tx small{display:block;font-weight:600;opacity:.85;font-size:11px;margin-top:2px}
.unlock-banner .ar{font-size:22px;font-weight:900}

/* SPLASH */
.splash{position:fixed;inset:0;background:#222222;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;z-index:9999;animation:splashFade .4s ease forwards;animation-delay:1.6s}
.splash img{width:200px;height:auto;border-radius:14px;animation:splashPop .6s cubic-bezier(.2,1.4,.4,1) both}
.splash .bar{width:140px;height:3px;border-radius:3px;background:#3a3a3a;overflow:hidden;position:relative}
.splash .bar::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,#ff9f1c,transparent);animation:splashSlide 1.2s linear infinite}
@keyframes splashFade{to{opacity:0;visibility:hidden}}
@keyframes splashPop{from{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}
@keyframes splashSlide{from{transform:translateX(-100%)}to{transform:translateX(100%)}}

/* Simple pages */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:60px 20px;gap:14px;color:#bdb0a3}
.empty-state .em{font-size:54px}
.empty-state h2{margin:0;color:#fff;font-size:18px}
.empty-state p{margin:0;font-size:13px;max-width:280px;line-height:1.4}

.profile-card{background:#2a221d;border-radius:16px;padding:20px;margin-top:14px}
.profile-card h2{margin:0 0 8px;font-size:18px;color:#fff}
.profile-card p{margin:0;color:#bdb0a3;font-size:13px;line-height:1.4}
.profile-card .actions{display:flex;flex-direction:column;gap:10px;margin-top:18px}
.profile-card .btn{display:block;text-align:center;padding:13px;border-radius:10px;font-weight:700;text-decoration:none;font-size:14px}
.profile-card .btn-primary{background:linear-gradient(135deg,#ff9f1c,#ff6a3d);color:#1a120c}
.profile-card .btn-ghost{background:#3a2e26;color:#fff}

/* === Image banners + Auth modal (v2) === */
.app-header{padding:14px 20px 10px;background:#1f1a17;align-items:center}
.app-login-btn{border:none;cursor:pointer;font-family:inherit}
.banner-image{display:block;border-radius:16px;overflow:hidden;margin-top:6px;background:#000}
.banner-image img{width:100%;height:auto;display:block}
.hero-banner{margin-top:14px;border-radius:0;margin-left:-16px;margin-right:-16px}
.banner-dots{display:flex;gap:6px;justify-content:center;margin:10px 0 4px}
.banner-dots span{width:7px;height:7px;border-radius:50%;background:#4a3e35}
.banner-dots span.on{background:#fff}

.auth-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:flex-end;justify-content:center;z-index:100;padding:0}
.auth-modal{background:#2a221d;width:100%;max-width:520px;border-radius:20px 20px 0 0;padding:22px 20px 28px;position:relative;animation:slideUp .25s ease}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.auth-close{position:absolute;top:14px;right:14px;background:transparent;border:none;color:#9b8c80;cursor:pointer;padding:6px}
.auth-tabs{display:flex;gap:8px;margin-bottom:18px;background:#1f1a17;padding:4px;border-radius:10px}
.auth-tabs button{flex:1;background:transparent;border:none;color:#9b8c80;padding:10px;font-weight:600;border-radius:8px;cursor:pointer;font-size:14px}
.auth-tabs button.is-active{background:#ff9f1c;color:#1a120c}
.auth-form{display:flex;flex-direction:column;gap:10px}
.auth-form input{background:#1f1a17;border:1px solid #3a2e26;border-radius:10px;padding:14px 16px;color:#fff;font-size:15px;outline:none;font-family:inherit}
.auth-form input:focus{border-color:#ff9f1c}
.auth-submit{margin-top:6px;background:linear-gradient(180deg,#ffb247,#ff9f1c);color:#1a120c;font-weight:800;border:none;padding:14px;border-radius:10px;font-size:15px;cursor:pointer}
.auth-hint{text-align:center;color:#9b8c80;font-size:12px;margin:6px 0 0}

/* === Palette align v3 (match print) === */
.app-header{padding:14px 20px 18px}
.app-main{background:#2a2724}
.coupon-card{background:#34302c}
.coupon-card .logo{border-color:#34302c}
.auth-modal{background:#34302c}
.auth-form input{background:#2a2724;border-color:#3d3833}
.auth-tabs{background:#2a2724}
.access-cta{background:#34302c}
.section-head h2{color:#fff}

/* === VSL section === */
.vsl-frame{margin:18px 0 4px;background:linear-gradient(180deg,#3a342f,#2e2a26);border:1.5px solid #ff9f1c;border-radius:18px;padding:16px;box-shadow:0 10px 30px rgba(0,0,0,.35)}
.vsl-head{text-align:center;margin-bottom:12px}
.vsl-head h2{margin:0;font-size:16px;font-weight:800;color:#fff;letter-spacing:.5px;line-height:1.25}
.vsl-head h2 span{display:inline-block;margin-left:4px}
.vsl-head p{margin:4px 0 0;font-size:12px;color:#bdb0a3}
.vsl-player{position:relative;border-radius:12px;overflow:hidden;background:#000;aspect-ratio:9/16;max-height:520px;margin:0 auto;display:flex;align-items:center;justify-content:center}
.vsl-player video{width:100%;height:100%;object-fit:contain;display:block;background:#000;margin:0 auto}
.vsl-play{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:rgba(0,0,0,.35);border:none;cursor:pointer;color:#fff}
.vsl-play .circle{width:72px;height:72px;border-radius:50%;background:#ff9f1c;display:grid;place-items:center;box-shadow:0 0 0 8px rgba(255,159,28,.25);animation:vslPulse 1.6s ease-in-out infinite}
.vsl-play .lbl{background:rgba(0,0,0,.6);color:#fff;font-weight:800;font-size:12px;padding:8px 14px;border-radius:999px;letter-spacing:.5px}
@keyframes vslPulse{0%,100%{box-shadow:0 0 0 8px rgba(255,159,28,.25)}50%{box-shadow:0 0 0 16px rgba(255,159,28,.05)}}
.vsl-cta{display:block;margin-top:14px;background:linear-gradient(180deg,#ffb247,#ff9f1c);color:#1a120c;font-weight:900;text-align:center;padding:16px;border-radius:12px;text-decoration:none;font-size:15px;letter-spacing:.5px;box-shadow:0 8px 24px rgba(255,159,28,.35);animation:ctaIn .35s ease both}
@keyframes ctaIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ============ NEW CHECKOUT (Bemol-inspired, orange theme) ============ */
.ck-page{min-height:100vh;background:#eef0f3;color:#1a1a1a;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;padding-bottom:24px}
.ck-page *{box-sizing:border-box}
.ck-header{background:#fff;padding:14px 18px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #e5e7eb}
.ck-logo img{height:42px;width:auto;border-radius:8px;display:block}
.ck-secure{display:flex;align-items:center;gap:6px;color:#1aa84e}
.ck-secure svg{flex-shrink:0}
.ck-secure strong{display:block;font-size:11px;font-weight:800;color:#1aa84e;line-height:1}
.ck-secure span{display:block;font-size:11px;font-weight:700;color:#1aa84e;line-height:1.2}

.ck-alert{background:linear-gradient(180deg,#ffb247,#ff9f1c);color:#fff;text-align:center;padding:18px 18px;font-size:14px;line-height:1.45;font-weight:500}

.ck-main{padding:16px;display:flex;flex-direction:column;gap:14px;max-width:520px;margin:0 auto}
.ck-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px rgba(0,0,0,.06);overflow:hidden}

.ck-cart-head{width:100%;display:flex;align-items:center;justify-content:space-between;padding:18px;background:none;border:none;cursor:pointer;font-size:16px;font-weight:700;color:#1a1a1a}
.ck-cart-right{display:flex;align-items:center;gap:10px;color:#6b7280}
.ck-badge{background:#ff9f1c;color:#fff;width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-size:12px;font-weight:800}
.ck-cart-body{padding:0 18px 18px}
.ck-item{display:flex;align-items:center;gap:12px;padding:8px 0 16px;border-bottom:1px solid #f1f1f1;margin-bottom:14px}
.ck-item-thumb{width:56px;height:56px;border-radius:8px;overflow:hidden;background:#fff7eb;flex-shrink:0;border:1px solid #f1e4cf}
.ck-item-thumb img{width:100%;height:100%;object-fit:cover}
.ck-item-info{flex:1;min-width:0}
.ck-item-info strong{display:block;font-size:14px;font-weight:700;color:#1a1a1a;line-height:1.3}
.ck-item-info span{display:block;font-size:12px;color:#6b7280;margin-top:2px}
.ck-qty{display:flex;align-items:center;border:1px solid #e5e7eb;border-radius:999px;padding:2px;gap:2px}
.ck-qty button{width:24px;height:24px;border-radius:50%;border:none;background:none;display:grid;place-items:center;color:#ff5a3c;cursor:pointer}
.ck-qty button:last-child{color:#1aa84e}
.ck-qty button:disabled{opacity:.5;cursor:not-allowed}
.ck-qty span{min-width:20px;text-align:center;font-size:14px;font-weight:600}
.ck-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:14px;color:#374151}
.ck-row.ck-total{padding-top:10px;border-top:1px solid #f1f1f1;margin-top:4px;font-size:16px}
.ck-row.ck-total strong{font-size:18px;font-weight:800;color:#1a1a1a}

.ck-steps-card{padding:0}
.ck-steps{display:flex;align-items:center;justify-content:space-around;padding:20px 18px 16px;gap:8px}
.ck-step{display:flex;flex-direction:column;align-items:center;gap:8px;color:#9ca3af;font-size:13px;font-weight:600}
.ck-step.active{color:#1a1a1a;font-weight:800}
.ck-step-num{width:34px;height:34px;border-radius:50%;background:#e5e7eb;color:#9ca3af;display:grid;place-items:center;font-weight:800;font-size:14px}
.ck-step.active .ck-step-num{background:#ff9f1c;color:#fff}

.ck-timer{background:linear-gradient(180deg,#ffb247,#ff9f1c);color:#fff;padding:12px 18px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.ck-timer>span{font-size:13px;font-weight:600;opacity:.95}
.ck-clock{display:flex;align-items:center;gap:6px;font-weight:800}
.ck-clock>div{display:flex;flex-direction:column;align-items:center;line-height:1}
.ck-clock strong{font-size:18px;letter-spacing:1px}
.ck-clock small{font-size:9px;font-weight:700;letter-spacing:.5px;margin-top:2px;opacity:.95}
.ck-clock>span{font-size:18px;font-weight:800;padding-bottom:8px}

.ck-form{padding:20px 18px 22px;display:flex;flex-direction:column;gap:14px}
.ck-field label{display:block;font-size:14px;font-weight:700;color:#1a1a1a;margin-bottom:6px}
.ck-field input{width:100%;padding:13px 14px;border:1px solid #e5e7eb;border-radius:8px;font-size:15px;background:#fff;color:#1a1a1a;outline:none;transition:border-color .15s}
.ck-field input::placeholder{color:#cfd3da}
.ck-field input:focus{border-color:#ff9f1c;box-shadow:0 0 0 3px rgba(255,159,28,.15)}

.ck-trust{border:1.5px dashed #d1d5db;border-radius:10px;padding:14px 14px 12px;margin-top:4px}
.ck-trust strong{display:block;font-size:13.5px;color:#1a1a1a;line-height:1.4;margin-bottom:10px;font-weight:700}
.ck-trust ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.ck-trust li{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:#374151;line-height:1.4}
.ck-trust li svg{color:#1aa84e;flex-shrink:0;margin-top:1px}

.ck-msg{margin:0;padding:10px 12px;border-radius:8px;font-size:13px;background:#fef3c7;color:#92400e}
.ck-msg.err{background:#fee2e2;color:#b91c1c}

.ck-cta{margin-top:6px;width:100%;background:linear-gradient(180deg,#ffb247,#ff9f1c);color:#fff;border:none;padding:16px;border-radius:8px;font-size:15px;font-weight:800;letter-spacing:.5px;cursor:pointer;box-shadow:0 6px 18px rgba(255,159,28,.35);transition:transform .12s}
.ck-cta:active{transform:translateY(1px)}
.ck-cta:disabled{opacity:.7;cursor:not-allowed}

.ck-footer{margin-top:18px;padding:20px 16px 24px;display:flex;flex-direction:column;align-items:center;gap:10px;color:#6b7280;font-size:13px}
.ck-footer p{margin:0;font-weight:600;color:#374151}
.ck-pix-badge{background:#3eb6a5;width:44px;height:44px;border-radius:8px;display:grid;place-items:center}
.ck-footer small{font-size:12px;color:#6b7280}
.ck-safe{background:#fff;border:1px solid #e5e7eb;border-radius:999px;padding:8px 16px;display:flex;align-items:center;gap:6px;font-size:12px;color:#1aa84e;font-weight:700;box-shadow:0 1px 3px rgba(0,0,0,.04)}

@media (min-width:600px){
  .ck-header{padding:18px 32px}
  .ck-logo img{height:48px}
}

/* Checkout step 2 - Pagamento */
.ck-step.done .ck-step-num{background:#ff9f1c;color:#fff}
.ck-pay{padding:20px 18px 22px}
.ck-pay-title{margin:0 0 14px;font-size:18px;font-weight:800;color:#1a1a1a}
.ck-method-card{display:flex;justify-content:center;margin-bottom:14px}
.ck-pix-logo{border:2px solid #ff9f1c;border-radius:10px;padding:14px 28px;display:flex;align-items:center;gap:8px;background:#fff;min-width:160px;justify-content:center}
.ck-pix-logo span{font-size:22px;font-weight:800;color:#3eb6a5;letter-spacing:.5px;font-family:-apple-system,BlinkMacSystemFont,sans-serif}
.ck-pay-info{border:1px solid #e5e7eb;border-radius:10px;padding:18px;text-align:center;color:#6b7280;font-size:14px;line-height:1.5;margin-bottom:16px}
.ck-back{margin-top:12px;width:100%;background:none;border:none;color:#9ca3af;font-size:14px;font-weight:600;cursor:pointer;padding:10px}
.ck-back:hover{color:#6b7280}
.ck-back:disabled{opacity:.5;cursor:not-allowed}
.ck-pix-img{display:block;width:90px;height:60px;border-radius:8px}
.ck-method-card{padding:6px 0}
.ck-method-card .ck-pix-img{box-shadow:0 0 0 2px #ff9f1c;border-radius:10px}
.ck-pix-footer{display:block;width:64px;height:auto;border-radius:6px}
