/* ============================================================
   Seu Elias — Cortes do Nosso Brasil · LP de Pré-Lançamento
   Pré-lançamento AO VIVO no YouTube · 09/07 · 20:30
   Tokens: brands/seu-elias-cortes-do-nosso-brasil.md
   ============================================================ */

:root {
  --preto:        #000000;
  --preto-quente: #0f0e0a;
  --grafite:      #16150f;
  --card:         #1c1c1c;

  --cream:        #e7e6e4;
  --cream-dim:    #969594;

  --amarelo:      #ffbb1f;
  --amarelo-esc:  #e0a51c;

  --verde:        #1b9050;
  --verde-esc:    #09321c;

  --vermelho:     #ff3b30;

  --maxw: 1120px;
  --radius: 14px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  font-family: 'Space Mono', ui-monospace, 'SFMono-Regular', Menlo, monospace;
  background: var(--preto);
  color: var(--cream);
  line-height: 1.6;
  overflow-x: hidden;
  background-image: radial-gradient(rgba(231,230,228,.045) 1px, transparent 1.4px);
  background-size: 26px 26px;
}

.container { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 22px; }

/* ---------- Tipografia base ---------- */
.display {
  font-family: 'Anton', 'Oswald', sans-serif;
  text-transform: uppercase;
  letter-spacing: -.01em;
  line-height: .92;
  font-weight: 400;
}
.amarelo { color: var(--amarelo); }
.verde   { color: var(--verde); }

.eyebrow {
  font-size: 12px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--amarelo);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.eyebrow::before { content: '▶'; color: var(--verde); font-size: 10px; }

.section-head { max-width: 720px; margin: 0 auto 46px; text-align: center; }
.section-head h2 {
  font-family: 'Anton', sans-serif;
  text-transform: uppercase;
  letter-spacing: -.01em;
  line-height: .95;
  font-size: clamp(30px, 6vw, 54px);
  margin: 14px 0 12px;
}
.section-head p { color: var(--cream-dim); font-size: 15px; }

section { padding: 84px 0; position: relative; }

/* ============================================================
   LOGO (PNG fiel ao PDF) — usado no hero e footer
   ============================================================ */
.brand-logo { display: block; width: auto; height: auto; }
.brand-logo--footer { margin: 0 auto; }

/* ============================================================
   HERO — foto real do palco no BG + logo fiel + form de captura
   ============================================================ */
.hero {
  min-height: 100svh;
  display: flex; align-items: center;
  padding: 118px 0 72px;
  position: relative; overflow: hidden;
  background: #050403;
}
.hero__bg {
  position: absolute; inset: 0; z-index: 0;
  background: url('/cortes-do-nosso-brasil/assets/hero-palco.jpg') center center / cover no-repeat;
}
.hero__bg::after {
  content: ''; position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.55) 0%, rgba(0,0,0,.32) 42%, rgba(0,0,0,.82) 100%),
    linear-gradient(90deg, rgba(0,0,0,.78) 0%, rgba(0,0,0,.28) 56%, rgba(0,0,0,.55) 100%);
}
.hero .container { position: relative; z-index: 2; }
.hero__grid { display: grid; grid-template-columns: 1.08fr .92fr; gap: 46px; align-items: center; }

.hero .brand-logo { width: min(400px, 78%); margin-bottom: 26px; filter: drop-shadow(0 6px 24px rgba(0,0,0,.55)); }

.live-badge {
  display: inline-flex; align-items: center; gap: 9px;
  background: rgba(255,59,48,.14); border: 1px solid rgba(255,59,48,.55);
  color: #ffd7d4; padding: 8px 15px; border-radius: 999px;
  font-size: 11.5px; letter-spacing: .2em; text-transform: uppercase; font-weight: 700;
}
.live-badge .rec {
  width: 9px; height: 9px; border-radius: 50%; background: var(--vermelho);
  box-shadow: 0 0 0 0 rgba(255,59,48,.7); animation: pulse 1.6s infinite;
}
@keyframes pulse {
  0%   { box-shadow: 0 0 0 0 rgba(255,59,48,.6); }
  70%  { box-shadow: 0 0 0 9px rgba(255,59,48,0); }
  100% { box-shadow: 0 0 0 0 rgba(255,59,48,0); }
}

.hero__event {
  font-family: 'Anton', sans-serif; text-transform: uppercase; line-height: .92;
  font-size: clamp(34px, 8vw, 74px); margin: 20px 0 8px; letter-spacing: -.01em;
  text-shadow: 0 4px 30px rgba(0,0,0,.7);
}
.hero__event .amarelo { display: block; }
.hero__where {
  color: var(--cream); font-size: clamp(13px, 1.7vw, 16px); max-width: 40ch; margin-bottom: 24px;
}
.hero__where b { color: var(--amarelo); }

/* Contagem regressiva */
.countdown { display: flex; gap: 10px; margin: 6px 0 26px; flex-wrap: wrap; }
.countdown .cd {
  background: rgba(0,0,0,.5); border: 1px solid rgba(231,230,228,.18);
  border-radius: 10px; padding: 10px 14px; min-width: 64px; text-align: center;
  backdrop-filter: blur(4px);
}
.countdown .cd b { font-family: 'Anton', sans-serif; font-size: 26px; display: block; line-height: 1; color: var(--amarelo); }
.countdown .cd span { font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--cream-dim); }

.hero__cta { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }
.hero__note { color: var(--cream-dim); font-size: 12.5px; display: flex; align-items: center; gap: 8px; margin-top: 14px; }

/* Card do formulário no hero */
.formcard {
  background: rgba(11,10,7,.86);
  border: 1px solid rgba(231,230,228,.15);
  border-radius: 16px; padding: 30px 28px;
  backdrop-filter: blur(7px);
  box-shadow: 0 24px 64px rgba(0,0,0,.55);
}
.formcard h3 { font-family: 'Anton', sans-serif; text-transform: uppercase; font-size: 23px; letter-spacing: 0; }
.formcard .formcard__sub { color: var(--cream-dim); font-size: 12.5px; margin: 5px 0 20px; }
.formcard .field { margin-bottom: 13px; }

/* ============================================================
   BOTÕES
   ============================================================ */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  font-family: 'Space Mono', monospace; font-weight: 700;
  text-transform: uppercase; letter-spacing: .06em; font-size: 15px;
  padding: 17px 30px; border-radius: 999px; border: 0; cursor: pointer;
  text-decoration: none; transition: transform .15s ease, box-shadow .15s ease, background .15s;
}
.btn--primary {
  background: var(--amarelo); color: #1a1400;
  box-shadow: 0 10px 34px rgba(255,187,31,.28);
}
.btn--primary:hover { background: var(--amarelo-esc); transform: translateY(-2px); box-shadow: 0 14px 40px rgba(255,187,31,.42); }
.btn--primary::after { content: '▶'; font-size: .72em; color: var(--verde-esc); }
.btn--ghost { background: transparent; color: var(--cream); border: 1px solid rgba(231,230,228,.28); }
.btn--ghost:hover { border-color: var(--cream); transform: translateY(-2px); }
.btn--block { width: 100%; }

/* ============================================================
   FITINHAS — tiras horizontais (identidade do PDF)
   ============================================================ */
.ribbons { background: var(--preto); padding: 4px 0; }
.ribbon { padding: 12px 0; white-space: nowrap; overflow: hidden; }
.ribbon + .ribbon { margin-top: 4px; }
.ribbon__track { display: inline-block; will-change: transform; }
.ribbon__track span {
  font-family: 'Anton', sans-serif; text-transform: uppercase; font-size: 22px;
  letter-spacing: .03em; padding: 0 16px; vertical-align: middle;
}
.ribbon__track .sep { font-size: 13px; padding: 0 4px; }
.ribbon--yellow { background: var(--amarelo); }
.ribbon--yellow span { color: #12100a; }
.ribbon--yellow .sep { color: var(--verde); }
.ribbon--green  { background: var(--verde); }
.ribbon--green span  { color: var(--amarelo); }
.ribbon--green .sep  { color: var(--cream); }
.ribbon--yellow .ribbon__track { animation: ribbon-l 30s linear infinite; }
.ribbon--green  .ribbon__track { animation: ribbon-r 34s linear infinite; }
@keyframes ribbon-l { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@keyframes ribbon-r { from { transform: translateX(-50%); } to { transform: translateX(0); } }
@media (prefers-reduced-motion: reduce) {
  .ribbon__track { animation: none !important; }
}

/* ============================================================
   MANIFESTO (bloco cream)
   ============================================================ */
.manifesto { background: var(--cream); color: var(--preto-quente); }
.manifesto .quote-mark { color: var(--amarelo); font-family: 'Anton', sans-serif; font-size: 64px; line-height: .6; }
.manifesto h2 {
  font-family: 'Anton', sans-serif; text-transform: uppercase;
  letter-spacing: -.01em; line-height: .96;
  font-size: clamp(26px, 4.6vw, 46px); margin: 8px 0 30px; max-width: 22ch;
}
.manifesto__cols { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; border-top: 1px solid rgba(15,14,10,.2); padding-top: 26px; }
.manifesto__cols p { font-size: 14.5px; color: #2a2a26; }

/* ============================================================
   BENEFÍCIOS
   ============================================================ */
.perks__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.perk {
  background: linear-gradient(180deg, var(--card), var(--preto-quente));
  border: 1px solid rgba(231,230,228,.09);
  border-radius: var(--radius); padding: 30px 26px;
  transition: transform .18s ease, border-color .18s ease;
}
.perk:hover { transform: translateY(-5px); border-color: rgba(255,187,31,.4); }
.perk__ico {
  width: 46px; height: 46px; border-radius: 12px; display: grid; place-items: center;
  background: rgba(27,144,80,.14); color: var(--verde); margin-bottom: 18px;
  font-family: 'Anton', sans-serif; font-size: 22px;
}
.perk h3 { font-family: 'Anton', sans-serif; text-transform: uppercase; letter-spacing: 0; font-size: 20px; margin-bottom: 8px; }
.perk p { color: var(--cream-dim); font-size: 13.5px; }

/* ============================================================
   TURNÊ / DATAS
   ============================================================ */
.tour { background: var(--preto-quente); }
.tour__list { display: grid; gap: 14px; max-width: 760px; margin: 0 auto; }
.date {
  display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 22px;
  background: var(--preto); border: 1px solid rgba(231,230,228,.09);
  border-left: 4px solid var(--amarelo);
  border-radius: 12px; padding: 22px 26px;
}
.date__num { font-family: 'Anton', sans-serif; font-size: clamp(30px, 6vw, 46px); color: var(--amarelo); line-height: 1; }
.date__city strong { display: block; font-family: 'Anton', sans-serif; text-transform: uppercase; font-size: 18px; letter-spacing: .02em; }
.date__city span { color: var(--cream-dim); font-size: 12.5px; letter-spacing: .12em; text-transform: uppercase; }
.date__tag {
  font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--verde);
  border: 1px solid rgba(27,144,80,.5); padding: 6px 12px; border-radius: 999px; white-space: nowrap;
}
.tour__disclaimer { text-align: center; color: var(--cream-dim); font-size: 12.5px; margin-top: 26px; }

/* ============================================================
   CAPTURA / FORM
   ============================================================ */
.capture { background: var(--preto); position: relative; overflow: hidden; }
.capture__wrap {
  max-width: 940px; margin: 0 auto;
  display: grid; grid-template-columns: 1.05fr .95fr;
  border: 1px solid rgba(231,230,228,.1); border-radius: 18px; overflow: hidden;
  background: var(--grafite);
}
.capture__aside {
  padding: 44px 40px; position: relative;
  background: url('/cortes-do-nosso-brasil/assets/seu-elias-corte.jpg') center/cover no-repeat;
  min-height: 100%;
}
.capture__aside::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(9,50,28,.55), rgba(0,0,0,.85));
}
.capture__aside > * { position: relative; z-index: 1; }
.capture__aside h2 {
  font-family: 'Anton', sans-serif; text-transform: uppercase; line-height: .95;
  font-size: clamp(28px, 4vw, 42px); margin: 16px 0 14px;
}
.capture__aside ul { list-style: none; display: grid; gap: 12px; margin-top: 22px; }
.capture__aside li { font-size: 13.5px; display: flex; gap: 10px; align-items: flex-start; }
.capture__aside li::before { content: '▶'; color: var(--amarelo); font-size: 10px; margin-top: 5px; }

.form { padding: 44px 40px; }
.form h3 { font-family: 'Anton', sans-serif; text-transform: uppercase; font-size: 24px; margin-bottom: 6px; }
.form > p { color: var(--cream-dim); font-size: 13px; margin-bottom: 24px; }
.field { margin-bottom: 16px; }
.field label { display: block; font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--cream-dim); margin-bottom: 7px; }
.field input, .field select {
  width: 100%; background: var(--preto); color: var(--cream);
  border: 1px solid rgba(231,230,228,.16); border-radius: 10px;
  padding: 14px 15px; font-family: 'Space Mono', monospace; font-size: 14px;
  transition: border-color .15s;
}
.field input:focus, .field select:focus { outline: none; border-color: var(--amarelo); }
.field input::placeholder { color: #5a5a57; }
.form__consent { display: flex; gap: 9px; align-items: flex-start; margin: 6px 0 18px; }
.form__consent input { margin-top: 3px; accent-color: var(--amarelo); }
.form__consent label { font-size: 11.5px; color: var(--cream-dim); letter-spacing: 0; text-transform: none; }
.form__msg { font-size: 12.5px; margin-top: 14px; min-height: 18px; }
.form__msg.err { color: #ff6b6b; }

.form--done { text-align: center; display: flex; flex-direction: column; justify-content: center; }
.form--done .check {
  width: 66px; height: 66px; border-radius: 50%; margin: 0 auto 20px;
  background: rgba(27,144,80,.16); color: var(--verde); display: grid; place-items: center;
  font-size: 32px; border: 1px solid rgba(27,144,80,.5);
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer { padding: 54px 0; text-align: center; border-top: 1px solid rgba(231,230,228,.08); }
.footer .brand-logo { width: 240px; }
.footer p { color: var(--cream-dim); font-size: 12px; margin-top: 16px; }
.footer .credit { margin-top: 12px; font-size: 11px; letter-spacing: .1em; }

/* ============================================================
   RESPONSIVO
   ============================================================ */
@media (max-width: 860px) {
  .hero { padding: 104px 0 60px; }
  .hero__grid { grid-template-columns: 1fr; gap: 30px; }

  /* Hero centralizado no mobile */
  .hero__lead { display: flex; flex-direction: column; align-items: center; text-align: center; }
  .hero .brand-logo { width: min(320px, 82%); margin-left: auto; margin-right: auto; }
  .hero__where { margin-left: auto; margin-right: auto; }
  .countdown { justify-content: center; }

  .perks__grid { grid-template-columns: 1fr; }
  .manifesto__cols { grid-template-columns: 1fr; gap: 22px; }
  .capture__wrap { grid-template-columns: 1fr; }
  .capture__aside { min-height: 240px; }
  .date { grid-template-columns: auto 1fr; }
  .date__tag { grid-column: 1 / -1; justify-self: start; }
}
@media (max-width: 480px) {
  section { padding: 62px 0; }
  .form, .capture__aside { padding: 32px 24px; }
  .countdown .cd { min-width: 56px; padding: 8px 10px; }
}
