/* =========================================================
   WORKSHOP REFORMA QUE FATURA — Landing Page
   Design system + section styles
   ========================================================= */

/* ---------- RESET ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-body);
  color: var(--text-on-light);
  background: var(--paper);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
button { font-family: inherit; cursor: pointer; }
a { color: inherit; text-decoration: none; }
h1, h2, h3, h4, p { margin: 0; }
::selection { background: var(--gold); color: var(--ink); }

/* ---------- PALETTE: HIT (Azul Tributário + Dourado Brasileiro) — default ---------- */
/* Official brand: #002855 / #004CA3 / #1A1A1A / #F2F2F2 / #FFA700 */
:root,
[data-palette="hit"] {
  --ink:            #001a3a;   /* deepest navy */
  --surface-dark:   #002855;   /* Azul Tributário (primary) */
  --surface-dark-2: #013a72;   /* between tributário & tecnologia */
  --line-dark:      rgba(255,167,0,.24);

  --gold:           #ffa700;   /* Dourado Brasileiro (accent) */
  --gold-2:         #ffbe45;
  --gold-soft:      rgba(255,167,0,.15);

  --tech:           #2f7ad6;   /* Azul Tecnologia, lightened for dark bg */

  --cream:          #f2f2f2;   /* Branco Clareza */
  --paper:          #f7f7f6;
  --paper-2:        #e9ebee;
  --line-light:     rgba(0,40,85,.14);

  --text-on-dark:   #eaf1f9;
  --muted-on-dark:  #9cb2cd;
  --text-on-light:  #15202e;
  --muted-on-light: #57636f;

  --accent-warm:    #cf5a2a; /* burnt signal for negatives/objections */
}

/* ---------- PALETTE: NOIR (Preto Autoridade + Dourado) ---------- */
[data-palette="noir"] {
  --ink:            #0c0c0c;
  --surface-dark:   #161616;
  --surface-dark-2: #232323;
  --line-dark:      rgba(255,167,0,.24);

  --gold:           #ffa700;
  --gold-2:         #ffc24f;
  --gold-soft:      rgba(255,167,0,.13);

  --tech:           #3f8ae0;

  --cream:          #f2f2f2;
  --paper:          #f6f6f5;
  --paper-2:        #e9e9e7;
  --line-light:     rgba(20,20,20,.13);

  --text-on-dark:   #f0f0ef;
  --muted-on-dark:  #a3a3a0;
  --text-on-light:  #161616;
  --muted-on-light: #565654;

  --accent-warm:    #d8623a;
}

/* ---------- PALETTE: TECH (Azul Tecnologia-forward, blue CTA) ---------- */
[data-palette="tech"] {
  --ink:            #001226;
  --surface-dark:   #002855;
  --surface-dark-2: #013a72;
  --line-dark:      rgba(64,138,224,.30);

  --gold:           #2f86e6;   /* signal blue acts as the accent/CTA */
  --gold-2:         #5aa3f0;
  --gold-soft:      rgba(47,134,230,.16);

  --tech:           #ffa700;   /* amber becomes the secondary pop */

  --cream:          #eef3f9;
  --paper:          #f5f8fc;
  --paper-2:        #e6edf6;
  --line-light:     rgba(0,40,85,.14);

  --text-on-dark:   #e8f0fb;
  --muted-on-dark:  #95b0d2;
  --text-on-light:  #0f1c2e;
  --muted-on-light: #54627a;

  --accent-warm:    #cf5a2a;
}

/* ---------- TYPE SYSTEMS ---------- */
/* Brand font is Degular Display — substituted with Hanken Grotesk (closest free geometric-humanist) */
[data-type="brand"] {
  --font-display: "Hanken Grotesk", system-ui, sans-serif;
  --font-body:    "Hanken Grotesk", system-ui, sans-serif;
  --font-eyebrow: "Hanken Grotesk", system-ui, sans-serif;
  --display-wght: 800;
  --display-stretch: 100%;
  --display-tracking: -0.025em;
}
[data-type="editorial"] {
  --font-display: "Newsreader", Georgia, serif;
  --font-body:    "Hanken Grotesk", system-ui, sans-serif;
  --font-eyebrow: "Hanken Grotesk", system-ui, sans-serif;
  --display-wght: 600;
  --display-stretch: 100%;
  --display-tracking: -0.01em;
}
[data-type="tech"] {
  --font-display: "Space Grotesk", system-ui, sans-serif;
  --font-body:    "Hanken Grotesk", system-ui, sans-serif;
  --font-eyebrow: "Space Grotesk", system-ui, sans-serif;
  --display-wght: 700;
  --display-stretch: 100%;
  --display-tracking: -0.02em;
}

/* ---------- LAYOUT PRIMITIVES ---------- */
.wrap { width: 100%; max-width: 1140px; margin: 0 auto; padding-inline: clamp(20px, 5vw, 48px); }
.wrap-narrow { max-width: 880px; }
.section { padding-block: clamp(60px, 9vh, 120px); position: relative; }
.section--dark { background: var(--surface-dark); color: var(--text-on-dark); }
.section--ink  { background: var(--ink); color: var(--text-on-dark); }
.section--light { background: var(--paper); color: var(--text-on-light); }
.section--cream { background: var(--cream); color: var(--text-on-light); }

/* ---------- TYPOGRAPHY HELPERS ---------- */
.display {
  font-family: var(--font-display);
  font-weight: var(--display-wght);
  font-stretch: var(--display-stretch);
  letter-spacing: var(--display-tracking);
  line-height: 1.02;
  text-wrap: balance;
}
.eyebrow {
  font-family: var(--font-eyebrow);
  font-weight: 700;
  font-size: clamp(11px, 1.1vw, 13px);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  white-space: nowrap;
}
.lead { font-size: clamp(17px, 1.5vw, 20px); line-height: 1.6; }
.body-lg { font-size: clamp(16px, 1.35vw, 18.5px); line-height: 1.66; }
.muted-d { color: var(--muted-on-dark); }
.muted-l { color: var(--muted-on-light); }
.gold-txt { color: var(--gold); }

.kicker-rule {
  display: inline-flex; align-items: center; gap: 12px;
  color: var(--gold);
}
.kicker-rule::before { content:""; width: 28px; height: 2px; background: var(--gold); }

/* ---------- BUTTONS ---------- */
.btn {
  --btn-bg: var(--gold);
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  font-family: var(--font-eyebrow);
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-size: clamp(14px, 1.3vw, 16px);
  color: var(--ink);
  background: var(--btn-bg);
  border: none;
  padding: 20px 34px;
  border-radius: 4px;
  line-height: 1;
  position: relative;
  transition: transform .18s cubic-bezier(.2,.8,.2,1), box-shadow .25s, background .2s;
  box-shadow: 0 10px 0 -2px color-mix(in srgb, var(--gold) 55%, #000 45%),
              0 18px 40px -12px color-mix(in srgb, var(--gold) 60%, transparent);
}
.btn:hover { transform: translateY(-2px); background: var(--gold-2); }
.btn:active { transform: translateY(2px); box-shadow: 0 4px 0 -2px color-mix(in srgb, var(--gold) 55%, #000 45%); }
.btn .arrow { font-size: 1.1em; transition: transform .2s; }
.btn:hover .arrow { transform: translateX(4px); }
.btn--block { width: 100%; }
.btn--lg { padding: 24px 40px; font-size: clamp(15px, 1.5vw, 18px); }

.support-line { font-size: 14px; line-height: 1.5; }

/* ---------- HERO ---------- */
.hero { position: relative; overflow: hidden; background: var(--ink); color: var(--text-on-dark); }
.hero__bg {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(120% 90% at 80% -10%, var(--gold-soft), transparent 55%),
    radial-gradient(90% 70% at 0% 110%, color-mix(in srgb, var(--surface-dark-2) 70%, transparent), transparent 60%);
}
.hero__grid-lines {
  position: absolute; inset: 0; z-index: 0; opacity: .5;
  background-image:
    linear-gradient(to right, var(--line-dark) 1px, transparent 1px);
  background-size: 25% 100%;
  -webkit-mask-image: linear-gradient(to bottom, transparent, #000 40%);
          mask-image: linear-gradient(to bottom, transparent, #000 40%);
}
.hero__inner { position: relative; z-index: 2; padding-block: clamp(28px, 5vh, 56px) clamp(60px, 9vh, 110px); }

.topbar { display: flex; align-items: center; justify-content: space-between; gap: 20px; padding-block: 22px; margin-bottom: clamp(24px, 4.5vh, 48px); }
.topbar__brand { display: flex; align-items: center; gap: 12px; font-family: var(--font-display); font-weight: 800; letter-spacing: .02em; }
.brand-logo { height: clamp(26px, 3vw, 34px); width: auto; display: block; }
.topbar__brand .mark {
  width: 38px; height: 38px; border-radius: 8px; display: grid; place-items: center;
  background: var(--gold); color: var(--ink); font-weight: 900; font-size: 18px;
}
.topbar__meta { font-size: 13px; color: var(--muted-on-dark); }

.chapeu {
  display: inline-flex; flex-wrap: wrap; align-items: center; gap: 8px 12px;
  padding: 9px 16px; border: 1px solid var(--line-dark); border-radius: 100px;
  background: color-mix(in srgb, var(--surface-dark-2) 55%, transparent);
  color: var(--gold-2);
  font-size: clamp(10px, 1vw, 12.5px); letter-spacing: .1em; font-weight: 700; text-transform: uppercase;
}
.chapeu .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--gold); box-shadow: 0 0 0 4px var(--gold-soft); animation: pulse 2.4s infinite; flex: none; }
.chapeu__seg { white-space: nowrap; }
.chapeu__sep { opacity: .45; }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.35} }

.hero-headline {
  font-size: clamp(30px, 4vw, 52px);
  margin-top: clamp(18px, 3vh, 28px);
  max-width: 21ch;
}
.hero-headline .hl { color: var(--gold); }
.hero-sub { margin-top: clamp(20px, 3vh, 30px); max-width: 56ch; color: var(--muted-on-dark); font-size: clamp(15px, 1.3vw, 18px); }
.hero-sub strong { color: var(--text-on-dark); font-weight: 600; }
.hero-cta-row { margin-top: clamp(22px, 3vh, 32px); display: flex; flex-wrap: wrap; align-items: center; gap: 18px 24px; }
.hero-support { margin-top: 18px; color: var(--muted-on-dark); max-width: 48ch; }
.hero-support b { color: var(--gold-2); }

/* split layout */
.hero--split .hero-cols { display: grid; grid-template-columns: 1.15fr 0.85fr; gap: clamp(32px, 5vw, 72px); align-items: start; }
.hero--centered .hero-cols { display: block; text-align: center; }
.hero--centered .hero-headline,
.hero--centered .hero-sub { margin-inline: auto; }
.hero--centered .hero-cta-row,
.hero--centered .chapeu-wrap { justify-content: center; display: flex; }
.hero--centered .hero-support { margin-inline: auto; }
.hero--centered .hero-aside { max-width: 460px; margin: 36px auto 0; text-align: left; }

/* hero aside card (countdown + lote) */
.hero-aside {
  background: color-mix(in srgb, var(--surface-dark-2) 75%, #000 25%);
  border: 1px solid var(--line-dark);
  border-radius: 14px;
  padding: clamp(22px, 2.4vw, 30px);
  position: relative;
}
.hero-aside::before {
  content: ""; position: absolute; inset: 0; border-radius: 14px; padding: 1px;
  background: linear-gradient(160deg, var(--gold), transparent 40%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude; pointer-events: none; opacity: .5;
}
.aside-label { font-size: 12px; letter-spacing: .14em; text-transform: uppercase; color: var(--gold-2); font-weight: 700; }

/* ---------- COUNTDOWN ---------- */
.countdown { display: flex; gap: 10px; margin-top: 14px; }
.cd-cell { flex: 1; text-align: center; background: var(--ink); border: 1px solid var(--line-dark); border-radius: 8px; padding: 12px 6px; }
.cd-num { font-family: var(--font-display); font-weight: 800; font-size: clamp(24px, 3vw, 34px); line-height: 1; color: var(--text-on-dark); font-variant-numeric: tabular-nums; }
.cd-lab { font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--muted-on-dark); margin-top: 6px; }

/* ---------- LOTE PROGRESS ---------- */
.lote { margin-top: 22px; }
.lote__head { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; font-size: 13px; margin-bottom: 8px; }
.lote__head .lname { font-weight: 700; color: var(--text-on-dark); white-space: nowrap; }
.lote__head .lrem { color: var(--gold-2); font-weight: 700; white-space: nowrap; }
.lote__track { height: 9px; border-radius: 100px; background: color-mix(in srgb, var(--ink) 70%, #fff 8%); overflow: hidden; border: 1px solid var(--line-dark); }
.lote__fill { height: 100%; border-radius: 100px; background: linear-gradient(90deg, var(--gold), var(--gold-2)); width: 0; transition: width 1.4s cubic-bezier(.2,.8,.2,1); }
.lote__note { font-size: 12px; color: var(--muted-on-dark); margin-top: 8px; }

/* ---------- CREDIBILITY BAR ---------- */
.cred { background: var(--surface-dark-2); color: var(--text-on-dark); padding-block: clamp(34px, 5vh, 56px); border-top: 1px solid var(--line-dark); }
.cred__intro { text-align: center; max-width: 60ch; margin: 0 auto clamp(22px, 3vh, 32px); color: var(--muted-on-dark); font-size: clamp(14px, 1.3vw, 16px); line-height: 1.6; }
.cred__intro b { color: var(--gold-2); }
.logos { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: clamp(14px, 2.4vw, 32px); }
.logo-slot {
  height: 54px; min-width: 120px; padding: 0 18px;
  border: 1px dashed var(--line-dark); border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  color: var(--muted-on-dark); font-size: 12px; letter-spacing: .04em;
  background: color-mix(in srgb, var(--ink) 35%, transparent);
}
.logo-slot img { width: 100%; height: 100%; }
.logo-slot--brand { border: none; background: none; padding: 0; height: 48px; }
.logo-slot--brand img { height: 100%; width: auto; display: block; }
.cred__eco { text-align: center; margin-top: 18px; font-size: 12.5px; color: var(--muted-on-dark); letter-spacing: .03em; }
.cred__eco span { color: var(--text-on-dark); }

/* ---------- SECTION HEADING ---------- */
.sec-head { max-width: 600px; }
.sec-head--center { max-width: 760px; margin-inline: auto; text-align: center; }
.sec-title { font-size: clamp(28px, 4.2vw, 50px); margin-top: 16px; text-wrap: balance; }
.sec-title .hl { color: var(--gold); }
.sec-lede { margin-top: 22px; max-width: 64ch; }
.sec-lede--center { margin-inline: auto; text-align: center; }

/* prose */
.prose p { margin-top: 18px; }
.prose p:first-child { margin-top: 0; }
.prose strong { font-weight: 700; }

/* big duo statement (contexto) — two-column editorial layout */
.ctx-cols { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px, 5vw, 72px); align-items: start; }
.ctx-stat { margin-top: 18px; display: flex; flex-direction: column; gap: 10px; font-size: clamp(30px, 3.6vw, 50px); }
.ctx-stat .hl { color: var(--gold); }
.ctx-line--muted { color: var(--muted-on-light); opacity: .55; }
.ctx-right p:first-child { margin-top: 0; }
@media (max-width: 860px){ .ctx-cols { grid-template-columns: 1fr; } }

/* ---------- PAIN LIST ---------- */
.pain-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-top: 38px; }
.pain-item { display: flex; gap: 14px; padding: 22px; border: 1px solid var(--line-dark); border-radius: 12px; background: color-mix(in srgb, var(--surface-dark-2) 40%, transparent); }
.pain-item .x { flex: none; width: 28px; height: 28px; border-radius: 7px; display: grid; place-items: center; background: color-mix(in srgb, var(--accent-warm) 22%, transparent); color: var(--accent-warm); font-weight: 800; }
.pain-item p { font-size: clamp(15px, 1.3vw, 17px); line-height: 1.55; }
@media (max-width: 760px){ .pain-grid { grid-template-columns: 1fr; } }

/* ---------- HIGHLIGHT BOX ---------- */
.callout {
  margin-top: 38px; border-radius: 14px; padding: clamp(24px, 3vw, 36px);
  background: linear-gradient(120deg, var(--gold), var(--gold-2));
  color: var(--ink); position: relative; overflow: hidden;
}
.callout__tag { font-weight: 800; letter-spacing: .14em; text-transform: uppercase; font-size: 12px; opacity: .8; }
.callout__txt { font-family: var(--font-display); font-weight: 700; font-size: clamp(20px, 2.6vw, 30px); line-height: 1.18; margin-top: 12px; letter-spacing: -.01em; }

/* ---------- DELIVERABLE NUMBERED ---------- */
.deliver-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; margin-top: 40px; counter-reset: dl; }
.deliver-item { display: flex; gap: 18px; padding: 24px; border-radius: 12px; background: color-mix(in srgb, var(--surface-dark-2) 55%, transparent); border: 1px solid var(--line-dark); }
.deliver-item .n { flex: none; counter-increment: dl; font-family: var(--font-display); font-weight: 800; font-size: 28px; color: var(--gold); width: 44px; line-height: 1; }
.deliver-item .n::before { content: "0" counter(dl); }
.deliver-item h4 { font-size: clamp(16px, 1.5vw, 19px); font-weight: 700; }
.deliver-item p { font-size: 14.5px; line-height: 1.5; color: var(--muted-on-dark); margin-top: 6px; }
@media (max-width: 760px){ .deliver-grid { grid-template-columns: 1fr; } }

/* ---------- NIGHTS ---------- */
.nights { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; margin-top: 44px; }
.night-card { border: 1px solid var(--line-light); border-radius: 16px; padding: clamp(26px, 3vw, 38px); background: #fff; position: relative; overflow: hidden; }
.night-card::after { content: ""; position: absolute; top: 0; left: 0; width: 6px; height: 100%; background: linear-gradient(var(--gold), var(--gold-2)); }
.night-card .nn { font-family: var(--font-display); font-weight: 800; font-size: clamp(40px, 5vw, 64px); color: var(--paper-2); line-height: 1; -webkit-text-stroke: 1px var(--line-light); }
.night-tag { display: inline-block; margin-top: 10px; font-weight: 700; font-size: 13px; letter-spacing: .08em; text-transform: uppercase; color: var(--gold); }
.night-card h3 { font-family: var(--font-display); font-weight: 700; font-size: clamp(20px, 2.4vw, 27px); margin-top: 8px; letter-spacing: -.01em; }
.night-card .ntime { font-size: 13.5px; color: var(--muted-on-light); margin-top: 4px; font-weight: 600; }
.night-card p { margin-top: 16px; line-height: 1.6; color: var(--text-on-light); }
.night-card .nout { margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--line-light); font-size: 14.5px; }
.night-card .nout b { color: var(--text-on-light); }
.nights-foot { margin-top: 28px; text-align: center; font-family: var(--font-display); font-weight: 700; font-size: clamp(18px, 2.2vw, 26px); letter-spacing: -.01em; }
@media (max-width: 820px){ .nights { grid-template-columns: 1fr; } }

/* ---------- FOR / NOT FOR ---------- */
.forwho { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.who-card { border-radius: 16px; padding: clamp(26px, 3vw, 38px); }
.who-card--yes { background: var(--surface-dark); color: var(--text-on-dark); border: 1px solid var(--line-dark); }
.who-card--no { background: var(--paper-2); color: var(--text-on-light); border: 1px solid var(--line-light); }
.who-card h3 { font-family: var(--font-display); font-weight: 800; font-size: clamp(20px, 2.4vw, 28px); letter-spacing: -.01em; }
.who-list { list-style: none; padding: 0; margin: 24px 0 0; display: flex; flex-direction: column; gap: 14px; }
.who-list li { display: flex; gap: 13px; line-height: 1.5; font-size: clamp(15px, 1.3vw, 16.5px); }
.who-list .ico { flex: none; width: 24px; height: 24px; border-radius: 50%; display: grid; place-items: center; font-size: 13px; font-weight: 800; margin-top: 1px; }
.who-card--yes .ico { background: var(--gold); color: var(--ink); }
.who-card--no .ico { background: color-mix(in srgb, var(--accent-warm) 18%, transparent); color: var(--accent-warm); }
.who-list b { font-weight: 700; }
@media (max-width: 820px){ .forwho { grid-template-columns: 1fr; } }

/* ---------- SPEAKERS ---------- */
.speakers { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 46px; }
.sp-card { background: color-mix(in srgb, var(--surface-dark-2) 50%, transparent); border: 1px solid var(--line-dark); border-radius: 16px; overflow: hidden; }
.sp-photo { width: 100%; aspect-ratio: 4/5; position: relative; background:
  repeating-linear-gradient(135deg, color-mix(in srgb, var(--surface-dark-2) 70%, #fff 4%) 0 14px, color-mix(in srgb, var(--surface-dark-2) 55%, #000 10%) 14px 28px); }
.sp-photo img { width: 100%; height: 100%; }
.sp-body { padding: 22px; }
.sp-body h4 { font-family: var(--font-display); font-weight: 700; font-size: clamp(18px, 1.8vw, 22px); }
.sp-role { font-size: 12.5px; letter-spacing: .06em; text-transform: uppercase; color: var(--gold); font-weight: 700; margin-top: 6px; }
.sp-body p { font-size: 14px; line-height: 1.55; color: var(--muted-on-dark); margin-top: 12px; }
.speakers-foot { margin-top: 30px; text-align: center; font-family: var(--font-display); font-weight: 700; font-size: clamp(18px, 2.2vw, 26px); color: var(--gold); letter-spacing: -.01em; }
@media (max-width: 880px){ .speakers { grid-template-columns: 1fr; max-width: 420px; margin-inline: auto; } }

/* ---------- INCLUDED ---------- */
.incl-layout { display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(28px, 4vw, 56px); align-items: start; }
.incl-list { list-style: none; padding: 0; margin: 28px 0 0; display: flex; flex-direction: column; gap: 16px; }
.incl-list li { display: flex; gap: 14px; line-height: 1.5; font-size: clamp(15px, 1.4vw, 17.5px); }
.incl-list .ck { flex: none; width: 26px; height: 26px; border-radius: 7px; background: var(--gold); color: var(--ink); display: grid; place-items: center; font-weight: 900; font-size: 14px; }
.incl-list b { font-weight: 700; }
.bumps { display: flex; flex-direction: column; gap: 14px; }
.bumps-title { font-size: 13px; letter-spacing: .12em; text-transform: uppercase; color: var(--muted-on-light); font-weight: 700; }
.bump { border: 1px solid var(--line-light); border-radius: 12px; padding: 20px; background: #fff; }
.bump__top { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; }
.bump h4 { font-weight: 700; font-size: 16px; line-height: 1.25; }
.bump .price { font-family: var(--font-display); font-weight: 800; color: var(--gold); white-space: nowrap; margin-top: 1px; }
.bump p { font-size: 13.5px; line-height: 1.5; color: var(--muted-on-light); margin-top: 12px; }
.bump .opt { font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--muted-on-light); }
@media (max-width: 880px){ .incl-layout { grid-template-columns: 1fr; } }

/* ---------- PRICING ---------- */
.price-wrap { display: grid; grid-template-columns: 1fr .85fr; gap: clamp(28px, 4vw, 60px); align-items: center; }
.price-card {
  background: var(--ink); border: 1px solid var(--line-dark); border-radius: 18px;
  padding: clamp(28px, 3.4vw, 44px); text-align: center; position: relative; overflow: hidden;
}
.price-card::before { content: ""; position: absolute; inset: 0; background: radial-gradient(80% 60% at 50% 0%, var(--gold-soft), transparent 70%); }
.price-card > * { position: relative; }
.price-lote { display: inline-block; padding: 8px 20px; border-radius: 100px; background: var(--gold); color: var(--ink); font-weight: 800; letter-spacing: .1em; text-transform: uppercase; font-size: 12px; white-space: nowrap; }
.price-from { color: var(--muted-on-dark); margin-top: 22px; font-size: 16px; }
.price-from s { opacity: .8; }
.price-now { display: flex; align-items: baseline; justify-content: center; gap: 6px; margin-top: 4px; }
.price-now .cur { font-size: clamp(20px, 2vw, 26px); color: var(--gold); font-weight: 700; font-family: var(--font-display); }
.price-now .val { font-family: var(--font-display); font-weight: 900; font-size: clamp(56px, 9vw, 96px); line-height: .9; color: var(--text-on-dark); letter-spacing: -.03em; }
.price-install { color: var(--muted-on-dark); font-size: 14px; margin-top: 8px; }
.price-card .btn { margin-top: 26px; }
.price-guard { margin-top: 16px; font-size: 12.5px; color: var(--muted-on-dark); }

/* ticket style variant */
.price-card--ticket { border-style: dashed; }
.price-card--ticket::after {
  content: ""; position: absolute; left: -14px; top: 50%; transform: translateY(-50%);
  width: 28px; height: 28px; border-radius: 50%; background: var(--surface-dark);
  box-shadow: calc(100% + 28px) 0 0 var(--surface-dark);
}

.scarcity-side .eyebrow { color: var(--gold); }
.scarcity-side .sc-title { font-family: var(--font-display); font-weight: 800; font-size: clamp(24px, 3.4vw, 40px); letter-spacing: -.01em; margin-top: 14px; }
.scarcity-side p { margin-top: 18px; line-height: 1.6; color: var(--muted-on-dark); }
.scarcity-side .sc-note { font-size: 12.5px; opacity: .8; margin-top: 18px; }
@media (max-width: 880px){ .price-wrap { grid-template-columns: 1fr; } }

/* ---------- GUARANTEE ---------- */
.guarantee { display: grid; grid-template-columns: auto 1fr; gap: clamp(24px, 4vw, 48px); align-items: center; }
.guard-badge { width: clamp(150px, 19vw, 200px); flex: none; }
.guard-badge img { width: 100%; height: auto; aspect-ratio: 1 / 1; display: block; filter: drop-shadow(0 16px 30px var(--gold-soft)); }
.seal { width: 100%; height: auto; display: block; transform: rotate(-8deg); filter: drop-shadow(0 16px 30px var(--gold-soft)); animation: sealIn .8s cubic-bezier(.2,.9,.3,1) both; }
@keyframes sealIn { from { transform: rotate(-26deg) scale(.85); } to { transform: rotate(-8deg) scale(1); } }
.seal-bumps circle, .seal-disc { fill: var(--gold); }
.seal-disc { stroke: color-mix(in srgb, var(--gold) 60%, #000 18%); stroke-width: 1; }
.seal-ring { fill: none; stroke: color-mix(in srgb, var(--ink) 70%, transparent); stroke-width: 1.4; stroke-dasharray: 1.5 4.5; stroke-linecap: round; }
.seal-text { fill: var(--ink); font-family: var(--font-eyebrow); font-weight: 800; font-size: 10.5px; letter-spacing: 1.4px; }
.seal-100 { fill: var(--ink); font-family: var(--font-display); font-weight: 900; font-size: 44px; letter-spacing: -1px; }
.seal-sub { fill: color-mix(in srgb, var(--ink) 72%, transparent); font-family: var(--font-eyebrow); font-weight: 800; font-size: 9px; letter-spacing: 1.3px; }
.seal-check { stroke: var(--ink); stroke-width: 5; stroke-linecap: round; stroke-linejoin: round; opacity: .9; transform-box: fill-box; }
.guard-txt h3 { font-family: var(--font-display); font-weight: 800; font-size: clamp(24px, 3.2vw, 38px); letter-spacing: -.01em; }
.guard-txt p { margin-top: 16px; line-height: 1.65; max-width: 58ch; }
@media (max-width: 680px){ .guarantee { grid-template-columns: 1fr; text-align: center; justify-items: center; } }

/* ---------- FAQ ---------- */
.faq-list { margin-top: 40px; border-top: 1px solid var(--line-light); }
.faq-item { border-bottom: 1px solid var(--line-light); }
.faq-q { width: 100%; background: none; border: none; text-align: left; display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 24px 4px; font-family: var(--font-display); font-weight: 700; font-size: clamp(16px, 1.8vw, 21px); color: var(--text-on-light); letter-spacing: -.01em; }
.faq-q .pm { flex: none; width: 30px; height: 30px; border-radius: 50%; border: 1.5px solid var(--line-light); display: grid; place-items: center; transition: .25s; position: relative; }
.faq-q .pm::before, .faq-q .pm::after { content: ""; position: absolute; background: var(--gold); border-radius: 2px; }
.faq-q .pm::before { width: 13px; height: 2px; }
.faq-q .pm::after { width: 2px; height: 13px; transition: transform .25s; }
.faq-item[data-open="true"] .pm { background: var(--gold); border-color: var(--gold); }
.faq-item[data-open="true"] .pm::before, .faq-item[data-open="true"] .pm::after { background: var(--ink); }
.faq-item[data-open="true"] .pm::after { transform: scaleY(0); }
.faq-a { overflow: hidden; max-height: 0; transition: max-height .35s ease; }
.faq-a__inner { padding: 0 4px 26px; max-width: 70ch; line-height: 1.65; color: var(--muted-on-light); font-size: clamp(15px, 1.3vw, 16.5px); }

/* ---------- FINAL CTA ---------- */
.final-cta { text-align: center; position: relative; overflow: hidden; }
.final-cta__bg { position: absolute; inset: 0; background: radial-gradient(100% 80% at 50% 0%, var(--gold-soft), transparent 60%); pointer-events: none; }
.final-cta .display { font-size: clamp(30px, 5.4vw, 64px); max-width: 20ch; margin-inline: auto; position: relative; }
.final-cta .display .hl { color: var(--gold); }
.final-cta__body { margin-top: 24px; max-width: 58ch; margin-inline: auto; color: var(--muted-on-dark); position: relative; }
.final-cta .btn { margin-top: 36px; position: relative; }
.final-cta .fin-line { margin-top: 20px; font-size: 13.5px; color: var(--muted-on-dark); position: relative; }

/* ---------- FOOTER ---------- */
.foot { background: var(--ink); color: var(--muted-on-dark); padding-block: 40px; border-top: 1px solid var(--line-dark); }
.foot__row { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 16px; font-size: 13px; }
.foot__brand { display: flex; align-items: center; gap: 10px; color: var(--text-on-dark); font-family: var(--font-display); font-weight: 700; }
.foot__link { color: var(--gold-2); font-size: 13px; font-weight: 600; text-decoration: underline; text-underline-offset: 3px; }
.foot__link:hover { color: var(--gold); }

/* ---------- STICKY HEADER (slim, post-hero) ---------- */
.shead {
  position: fixed; left: 0; right: 0; top: 0; z-index: 60;
  background: color-mix(in srgb, var(--ink) 90%, transparent);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--line-dark);
  transform: translateY(-110%); transition: transform .35s cubic-bezier(.2,.8,.2,1);
  padding: 9px 0;
}
.shead[data-show="true"] { transform: translateY(0); }
.shead__row { display: flex; align-items: center; gap: clamp(14px, 2.5vw, 28px); }
.shead__logo { height: 24px; width: auto; flex: none; }
.shead__count { display: flex; align-items: baseline; gap: 10px; color: var(--text-on-dark); min-width: 0; }
.shead__cd { font-family: var(--font-display); font-weight: 800; font-size: 17px; letter-spacing: .01em; font-variant-numeric: tabular-nums; white-space: nowrap; }
.shead__cd i { font-style: normal; font-weight: 700; font-size: 11px; color: var(--gold-2); margin-left: 1px; }
.shead__cdlab { font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--muted-on-dark); white-space: nowrap; }
.shead__lote { margin-left: auto; font-size: 12.5px; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; color: var(--gold-2); white-space: nowrap; }
.shead__btn { padding: 12px 22px; font-size: 13px; box-shadow: none; flex: none; }
.shead__btn:active { transform: none; }
@media (max-width: 760px){
  .shead__cdlab, .shead__lote { display: none; }
  .shead__row { justify-content: space-between; }
  .shead__btn { padding: 12px 16px; font-size: 12px; }
}
@media (max-width: 420px){
  .shead__logo { display: none; }
}

/* ---------- ENTRANCE ANIMATION ---------- */
/* Opacity stays 1 at all times so content is ALWAYS visible (screenshots,
   PDF/print, throttled/offscreen rendering). Only the transform slides in,
   so a frozen timeline just leaves content gently offset but readable. */
.reveal { opacity: 1; }
@media (prefers-reduced-motion: no-preference) {
  .reveal:not(.in) { transform: translateY(20px); }
  .reveal.in { animation: revealIn .6s cubic-bezier(.2,.8,.2,1) both; }
}
@keyframes revealIn {
  from { transform: translateY(20px); }
  to   { transform: none; }
}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 900px){
  .hero--split .hero-cols { grid-template-columns: 1fr; }
  .hero-aside { max-width: 460px; }
  .topbar__meta { display: none; }
}
@media (max-width: 520px){
  .btn { padding: 17px 24px; }
  .topbar { padding-block: 16px; }
  .pain-item, .deliver-item { padding: 18px; }
}

/* =========================================================
   ENHANCERS — mesh, timeline, tool mockups
   ========================================================= */

/* ---------- BRAND NETWORK MESH ---------- */
.mesh-bg { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; pointer-events: none; }
.mesh-bg .mesh-lines line { stroke: var(--gold); stroke-width: 0.12; opacity: .22; }
.mesh-bg .mesh-nodes circle { fill: var(--muted-on-dark); opacity: .5; }
.mesh-bg .mesh-nodes .mn-gold { fill: var(--gold); opacity: .9; }
.hero-mesh { opacity: .55; -webkit-mask-image: radial-gradient(120% 100% at 75% 10%, #000 30%, transparent 75%); mask-image: radial-gradient(120% 100% at 75% 10%, #000 30%, transparent 75%); }
.sec-mesh { opacity: .4; -webkit-mask-image: radial-gradient(100% 80% at 50% 0%, #000, transparent 70%); mask-image: radial-gradient(100% 80% at 50% 0%, #000, transparent 70%); }
.speakers-section, .final-cta { position: relative; }
.speakers-section > .wrap, .final-cta > .wrap { position: relative; z-index: 2; }

/* ---------- REFORM TIMELINE ---------- */
.timeline { margin-top: clamp(40px, 6vh, 64px); position: relative; }
.tl-rail { position: absolute; top: 9px; left: 8%; right: 8%; height: 3px; border-radius: 100px; background: var(--paper-2); overflow: hidden; }
.tl-rail__fill { position: absolute; inset: 0; width: 16%; background: linear-gradient(90deg, var(--gold), color-mix(in srgb, var(--gold) 40%, transparent)); }
.tl-marks { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(18px, 3vw, 40px); }
.tl-mark { text-align: center; padding-top: 30px; position: relative; }
.tl-node { position: absolute; top: 2px; left: 50%; transform: translateX(-50%); width: 18px; height: 18px; border-radius: 50%; background: var(--paper); border: 3px solid var(--paper-2); }
.tl-mark.is-active .tl-node { border-color: var(--gold); background: var(--gold); box-shadow: 0 0 0 6px var(--gold-soft); }
.tl-year { font-family: var(--font-display); font-weight: 800; font-size: clamp(30px, 4.6vw, 52px); letter-spacing: -.02em; line-height: 1; color: var(--text-on-light); }
.tl-mark.is-active .tl-year { color: var(--gold); }
.tl-tag { display: inline-block; white-space: nowrap; margin-top: 10px; font-size: 11px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; padding: 5px 12px; border-radius: 100px; background: var(--paper-2); color: var(--muted-on-light); }
.tl-mark.is-active .tl-tag { background: var(--gold); color: var(--ink); }
.tl-title { font-family: var(--font-display); font-weight: 700; font-size: clamp(17px, 1.9vw, 21px); margin-top: 14px; letter-spacing: -.01em; }
.tl-text { margin-top: 8px; font-size: 14.5px; line-height: 1.55; color: var(--muted-on-light); max-width: 30ch; margin-inline: auto; }
.tl-span { margin-top: clamp(34px, 5vh, 52px); text-align: center; font-size: 13px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--muted-on-light); padding-top: 22px; border-top: 1px solid var(--line-light); }
@media (max-width: 720px){
  .tl-rail { display: none; }
  .tl-marks { grid-template-columns: 1fr; gap: 0; text-align: left; }
  .tl-mark { padding: 22px 0 22px 40px; text-align: left; border-left: 2px solid var(--paper-2); }
  .tl-mark.is-active { border-left-color: var(--gold); }
  .tl-node { left: -10px; top: 24px; transform: none; }
  .tl-text { margin-inline: 0; }
}

/* ---------- TOOL MOCKUPS ---------- */
.tools-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin-top: clamp(40px, 6vh, 60px); }
.tool-card { background: #fff; border: 1px solid var(--line-light); border-radius: 16px; padding: 20px; display: flex; flex-direction: column; }
.tool-card__mock { background: var(--surface-dark); border-radius: 12px; padding: 16px; aspect-ratio: 4/3; display: flex; }
.tool-card__title { font-family: var(--font-display); font-weight: 700; font-size: clamp(17px, 1.8vw, 20px); margin-top: 18px; }
.tool-card__desc { font-size: 14px; line-height: 1.5; color: var(--muted-on-light); margin-top: 8px; }
@media (max-width: 880px){ .tools-grid { grid-template-columns: 1fr; max-width: 440px; margin-inline: auto; } }

/* shared "window" chrome */
.mock { background: var(--paper); border-radius: 9px; width: 100%; overflow: hidden; display: flex; flex-direction: column; box-shadow: 0 10px 26px -14px rgba(0,0,0,.5); }
.mock__bar { display: flex; gap: 5px; padding: 8px 10px; background: var(--paper-2); }
.mock__bar span { width: 7px; height: 7px; border-radius: 50%; background: color-mix(in srgb, var(--muted-on-light) 40%, transparent); }

/* matriz */
.mtx { padding: 12px 12px 8px; display: grid; grid-template-columns: auto 1fr; grid-template-rows: 1fr auto; gap: 6px; flex: 1; }
.mtx__ylab { writing-mode: vertical-rl; transform: rotate(180deg); font-size: 8px; letter-spacing: .04em; color: var(--muted-on-light); text-align: center; font-weight: 700; }
.mtx__grid { grid-column: 2; display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; gap: 5px; }
.mtx__cell { position: relative; background: #fff; border: 1px solid var(--line-light); border-radius: 6px; min-height: 38px; }
.mtx__cell.hot { background: var(--gold-soft); border-color: var(--gold); }
.mtx__cell.hot b { position: absolute; top: 5px; left: 6px; font-size: 8px; font-weight: 800; color: color-mix(in srgb, var(--gold) 70%, #000 30%); text-transform: uppercase; letter-spacing: .03em; }
.mtx__cell .d { position: absolute; width: 6px; height: 6px; border-radius: 50%; background: var(--surface-dark-2); }
.mtx__cell.hot .d { background: var(--gold); }
.d1{ right: 8px; bottom: 8px; } .d2{ right: 16px; bottom: 13px; } .d3{ right: 11px; bottom: 18px; }
.d4{ left: 10px; top: 12px; } .d5{ left: 14px; bottom: 10px; } .d6{ right: 12px; top: 14px; } .d7{ left: 18px; top: 9px; }
.mtx__xlab { grid-column: 2; font-size: 8px; letter-spacing: .04em; color: var(--muted-on-light); font-weight: 700; text-align: right; }

/* planilha */
.sheet { padding: 8px; display: flex; flex-direction: column; gap: 3px; flex: 1; justify-content: center; }
.sheet__row { display: grid; grid-template-columns: 1.5fr .8fr 1fr; gap: 6px; font-size: 9px; padding: 5px 7px; border-radius: 4px; color: var(--text-on-light); align-items: center; }
.sheet__row span:last-child { text-align: right; font-variant-numeric: tabular-nums; font-weight: 700; }
.sheet__row--head { background: var(--surface-dark); color: var(--text-on-dark); font-weight: 700; text-transform: uppercase; letter-spacing: .04em; font-size: 8px; }
.sheet__row:nth-child(odd):not(.sheet__row--head):not(.sheet__row--total) { background: var(--paper-2); }
.sheet__row--total { background: var(--gold); color: var(--ink); font-weight: 800; margin-top: 3px; }
.sheet__row--total span:last-child { color: var(--ink); }

/* roteiro */
.chat { padding: 10px; display: flex; flex-direction: column; gap: 6px; flex: 1; justify-content: center; }
.chat__email { background: #fff; border: 1px solid var(--line-light); border-radius: 5px; padding: 6px 8px; font-size: 8.5px; color: var(--text-on-light); }
.chat__email .cl { color: var(--muted-on-light); font-weight: 700; text-transform: uppercase; font-size: 7px; letter-spacing: .06em; margin-right: 4px; }
.bubble { font-size: 9px; line-height: 1.35; padding: 7px 9px; border-radius: 9px; max-width: 88%; }
.bubble--in { background: #fff; border: 1px solid var(--line-light); color: var(--text-on-light); align-self: flex-start; border-bottom-left-radius: 2px; }
.bubble--out { background: color-mix(in srgb, var(--gold) 88%, #fff); color: var(--ink); align-self: flex-end; border-bottom-right-radius: 2px; }
.chat__meta { font-size: 7.5px; letter-spacing: .06em; text-transform: uppercase; color: var(--muted-on-dark); text-align: center; margin-top: 2px; font-weight: 700; }

/* =========================================================
   REGISTRATION MODAL (lead capture)
   ========================================================= */
.reg-overlay {
  position: fixed; inset: 0; z-index: 200;
  background: color-mix(in srgb, var(--ink) 72%, transparent);
  backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
  animation: regFade .2s ease both;
}
@keyframes regFade { from { opacity: 0; } to { opacity: 1; } }
.reg-modal {
  position: relative;
  width: 100%; max-width: 440px;
  background: var(--paper); color: var(--text-on-light);
  border-radius: 20px;
  padding: clamp(24px, 4vw, 36px);
  box-shadow: 0 30px 80px -20px rgba(0,0,0,.6);
  animation: regPop .32s cubic-bezier(.2,.9,.3,1) both;
  max-height: calc(100dvh - 40px); overflow-y: auto;
}
@keyframes regPop { from { transform: translateY(16px) scale(.97); opacity: 0; } to { transform: none; opacity: 1; } }
.reg-close {
  position: absolute; top: 14px; right: 14px;
  width: 38px; height: 38px; border-radius: 50%;
  border: none; background: var(--paper-2); color: var(--text-on-light);
  font-size: 22px; line-height: 1; display: grid; place-items: center;
}
.reg-close:hover { background: color-mix(in srgb, var(--paper-2) 70%, var(--ink) 12%); }

.reg-head { text-align: center; margin-bottom: 22px; }
.reg-badge {
  display: inline-flex; align-items: center; gap: 8px; white-space: nowrap;
  background: var(--ink); color: var(--gold-2);
  font-weight: 800; font-size: 12px; letter-spacing: .06em; text-transform: uppercase;
  padding: 7px 14px; border-radius: 100px;
}
.reg-badge__dot { width: 7px; height: 7px; border-radius: 50%; background: var(--gold); box-shadow: 0 0 0 3px var(--gold-soft); }
.reg-head h3 { font-family: var(--font-display); font-weight: 800; font-size: clamp(24px, 5vw, 30px); letter-spacing: -.02em; margin-top: 14px; }
.reg-head p { color: var(--muted-on-light); font-size: 14px; margin-top: 6px; }

.reg-form { display: flex; flex-direction: column; gap: 14px; }
.reg-field { display: flex; flex-direction: column; gap: 6px; }
.reg-field label { font-size: 13px; font-weight: 700; color: var(--text-on-light); }
.reg-field input {
  width: 100%; height: 54px; /* big touch target */
  padding: 0 16px;
  font-family: inherit; font-size: 16px; /* 16px prevents iOS zoom */
  color: var(--text-on-light);
  background: #fff;
  border: 1.5px solid var(--line-light); border-radius: 12px;
  transition: border-color .15s, box-shadow .15s;
  -webkit-appearance: none; appearance: none;
}
.reg-field input::placeholder { color: color-mix(in srgb, var(--muted-on-light) 70%, transparent); }
.reg-field input:focus { outline: none; border-color: var(--gold); box-shadow: 0 0 0 3px var(--gold-soft); }
.reg-field input[aria-invalid="true"] { border-color: var(--accent-warm); }
.reg-err { font-size: 12.5px; color: var(--accent-warm); font-weight: 600; }
.reg-err--lgpd { margin-top: -6px; }

.reg-check {
  display: grid; grid-template-columns: auto 1fr; gap: 11px; align-items: start;
  margin-top: 4px; cursor: pointer; user-select: none;
}
.reg-check input { position: absolute; opacity: 0; width: 0; height: 0; }
.reg-check__box {
  width: 24px; height: 24px; border-radius: 7px; margin-top: 1px;
  border: 1.5px solid var(--line-light); background: #fff;
  display: grid; place-items: center; transition: .15s; flex: none;
}
.reg-check__box::after { content: "✓"; color: var(--ink); font-size: 14px; font-weight: 900; opacity: 0; transform: scale(.5); transition: .15s; }
.reg-check input:checked + .reg-check__box { background: var(--gold); border-color: var(--gold); }
.reg-check input:checked + .reg-check__box::after { opacity: 1; transform: none; }
.reg-check input:focus-visible + .reg-check__box { box-shadow: 0 0 0 3px var(--gold-soft); }
.reg-check__txt { font-size: 13px; line-height: 1.45; color: var(--muted-on-light); }
.reg-check__txt a { color: var(--text-on-light); text-decoration: underline; font-weight: 600; }
.reg-check.is-err .reg-check__box { border-color: var(--accent-warm); }

.reg-submit { margin-top: 6px; white-space: nowrap; box-shadow: 0 10px 0 -2px color-mix(in srgb, var(--gold) 55%, #000 45%), 0 18px 40px -12px var(--gold-soft); }
.reg-submit:disabled { opacity: .7; cursor: default; }
.reg-trust { display: flex; flex-wrap: wrap; gap: 7px; justify-content: center; font-size: 12px; color: var(--muted-on-light); margin-top: 4px; }

/* success state */
.reg-success { text-align: center; padding: 8px 0; }
.reg-success__ico {
  width: 64px; height: 64px; border-radius: 50%; margin: 0 auto 18px;
  background: var(--gold); color: var(--ink);
  display: grid; place-items: center; font-size: 32px; font-weight: 900;
  box-shadow: 0 0 0 8px var(--gold-soft);
}
.reg-success h3 { font-family: var(--font-display); font-weight: 800; font-size: 26px; letter-spacing: -.02em; }
.reg-success p { color: var(--muted-on-light); margin-top: 12px; line-height: 1.6; }
.reg-success__next {
  text-align: left; background: var(--paper-2); border-radius: 12px; padding: 16px;
  margin: 20px 0; font-size: 14px; line-height: 1.5; color: var(--text-on-light);
}
.reg-success__next span { display: block; font-size: 11px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; color: var(--gold); margin-bottom: 5px; }

/* MOBILE — bottom sheet for thumb reach */
@media (max-width: 540px) {
  .reg-overlay { align-items: flex-end; padding: 0; }
  .reg-modal {
    max-width: none; border-radius: 22px 22px 0 0;
    max-height: 94dvh; padding: 26px 20px calc(22px + env(safe-area-inset-bottom));
    animation: regSheet .34s cubic-bezier(.2,.9,.3,1) both;
  }
  @keyframes regSheet { from { transform: translateY(100%); } to { transform: none; } }
  .reg-modal::before {
    content: ""; position: absolute; top: 9px; left: 50%; transform: translateX(-50%);
    width: 40px; height: 4px; border-radius: 100px; background: var(--line-light);
  }
  .reg-head { margin-top: 6px; }
}

/* =========================================================
   PRODUÇÃO — imagens reais nos antigos slots de protótipo
   ========================================================= */
.sp-photo img { object-fit: cover; }
.logo-slot img { object-fit: contain; }
.guard-badge img { object-fit: contain; }
.reg-overlay[hidden] { display: none; }
