:root {
  --black: #07050a;
  --black-2: #0d0912;
  --panel: #13101a;
  --violet: #8b3dff;
  --violet-2: #c47aff;
  --violet-dark: #4a168c;
  --white: #f8f4ff;
  --muted: #a99eb5;
  --line: rgba(196, 122, 255, .18);
  --serif: "Playfair Display", Georgia, serif;
  --sans: "DM Sans", Arial, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--white);
  background:
    radial-gradient(circle at 72% 18%, rgba(107, 28, 205, .22), transparent 30%),
    radial-gradient(circle at 10% 65%, rgba(85, 17, 130, .14), transparent 28%),
    var(--black);
  font-family: var(--sans);
  overflow-x: hidden;
}
body.locked { overflow: hidden; }
a { color: inherit; text-decoration: none; }
button, input { font: inherit; }

header, footer, .hero, .packs, .steps, .preview { max-width: 1240px; margin: auto; }
header {
  height: 90px;
  padding: 0 30px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid var(--line);
}
.brand { display: flex; align-items: center; gap: 10px; font-weight: 700; letter-spacing: .22em; font-size: 13px; }
.brand > i { width: 10px; height: 10px; border-radius: 50%; background: var(--violet-2); box-shadow: 0 0 22px var(--violet); }
.brand b { color: var(--violet-2); font-size: 8px; letter-spacing: .17em; padding: 5px 7px; border: 1px solid var(--line); }
.private { display: flex; align-items: center; gap: 8px; color: #c5b8d2; font-size: 9px; text-transform: uppercase; letter-spacing: .2em; }
.private i { width: 6px; height: 6px; border-radius: 50%; background: #72ffb6; box-shadow: 0 0 10px #72ffb6; }

.hero {
  min-height: 760px;
  padding: 78px 30px 110px;
  display: grid;
  grid-template-columns: 1.04fr .96fr;
  gap: 76px;
  align-items: center;
}
.eyebrow, .section-title span {
  display: block;
  color: var(--violet-2);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .23em;
  text-transform: uppercase;
}
.eyebrow { margin-bottom: 24px; }
h1, h2, h3, p { margin-top: 0; }
h1 {
  max-width: 690px;
  margin-bottom: 28px;
  font: 600 clamp(55px, 6.4vw, 94px)/.91 var(--serif);
  letter-spacing: -.055em;
}
em { color: var(--violet-2); }
.lead { max-width: 540px; color: var(--muted); font-size: 16px; line-height: 1.75; }
.hero-action { display: flex; align-items: center; gap: 27px; margin-top: 38px; }
.button {
  min-height: 56px;
  padding: 0 25px;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 34px;
  border: 1px solid rgba(196, 122, 255, .45);
  background: linear-gradient(135deg, #6a20ce, #9a42ff);
  color: white;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 18px 55px rgba(102, 28, 207, .28);
  transition: .2s ease;
}
.button:hover { transform: translateY(-3px); filter: brightness(1.12); }
.hero-action small { color: var(--muted); font-size: 9px; line-height: 1.7; letter-spacing: .11em; text-transform: uppercase; }
.hero-action small b { color: var(--violet-2); }
.hero-proof { margin-top: 42px; display: flex; align-items: center; gap: 10px; color: #71677b; font-size: 9px; text-transform: uppercase; letter-spacing: .12em; }
.hero-proof span { color: #d9cceb; font-weight: 700; }
.hero-proof i { width: 3px; height: 3px; border-radius: 50%; background: var(--violet); }

.visual { position: relative; width: 100%; max-width: 485px; min-height: 590px; justify-self: end; }
.visual-glow { position: absolute; inset: 10% -12% 0 15%; background: #6c20ce; filter: blur(90px); opacity: .28; }
.outline { position: absolute; inset: 30px -18px -18px 40px; border: 1px solid rgba(196, 122, 255, .45); }
.visual figure { position: absolute; inset: 0 18px 24px 0; margin: 0; overflow: hidden; background: #1a1121; }
.visual figure:after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(7,5,10,.02) 40%, rgba(7,5,10,.95)); }
.visual img { width: 100%; height: 100%; object-fit: cover; object-position: 58% 42%; filter: saturate(.9) contrast(1.08) hue-rotate(4deg); }
.visual figcaption { position: absolute; z-index: 2; left: 28px; right: 28px; bottom: 24px; display: flex; justify-content: space-between; align-items: end; }
.visual figcaption span { color: #c7b9d2; font-size: 8px; text-transform: uppercase; letter-spacing: .2em; }
.visual figcaption b { font: italic 600 30px var(--serif); }
.seal { position: absolute; z-index: 3; right: -27px; top: 42px; width: 124px; height: 124px; border-radius: 50%; display: grid; place-content: center; text-align: center; background: linear-gradient(145deg, #8d35f5, #46107e); border: 1px solid #d0a2ff; box-shadow: 0 20px 60px rgba(94, 24, 181, .45); font-size: 8px; text-transform: uppercase; letter-spacing: .15em; transform: rotate(8deg); }
.seal em { color: white; font: italic 600 17px var(--serif); text-transform: none; letter-spacing: 0; }
.exclusive-tag { position: absolute; z-index: 3; left: -40px; bottom: 62px; padding: 13px 17px; background: rgba(7,5,10,.85); border: 1px solid var(--line); backdrop-filter: blur(12px); color: #c8b9d4; font-size: 8px; line-height: 1.6; text-transform: uppercase; letter-spacing: .2em; }

.manifesto { padding: 105px 24px; text-align: center; color: white; background: linear-gradient(135deg, #2a0b4b, #5715a0 54%, #24083e); border-block: 1px solid rgba(196,122,255,.3); }
.manifesto small { color: #d8b8f8; font-size: 9px; text-transform: uppercase; letter-spacing: .24em; }
.manifesto h2, .closing h2 { margin: 18px 0 0; font: 600 clamp(42px, 5vw, 70px)/1.03 var(--serif); letter-spacing: -.04em; }
.manifesto em { color: #fff; text-shadow: 0 0 30px rgba(219,172,255,.4); }

.preview { padding: 120px 30px; display: grid; grid-template-columns: .72fr 1.28fr; gap: 85px; align-items: center; }
.preview-copy h2 { margin: 0 0 24px; font: 600 clamp(44px, 5vw, 68px)/1 var(--serif); letter-spacing: -.04em; }
.preview-copy p { max-width: 400px; color: var(--muted); font-size: 14px; line-height: 1.75; }
.preview-copy > a { display: inline-flex; gap: 45px; margin-top: 16px; padding-bottom: 9px; border-bottom: 1px solid var(--violet); color: #d7c1eb; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .12em; }
.preview-grid { position: relative; height: 575px; display: grid; grid-template-columns: 1.15fr .85fr; grid-template-rows: 1fr 1fr; gap: 12px; }
.preview-grid figure { position: relative; margin: 0; overflow: hidden; border: 1px solid var(--line); background: var(--panel); }
.preview-grid figure:after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 50%, rgba(29,9,50,.52)); }
.preview-grid .preview-main { grid-row: 1 / 3; }
.preview-grid img { width: 100%; height: 100%; object-fit: cover; }
.preview-main img { object-position: center 48%; }
.preview-grid figure:nth-child(2) img { object-position: center 25%; }
.preview-grid figure:nth-child(3) img { object-position: center 35%; }
.preview-lock { position: absolute; right: -28px; bottom: 32px; z-index: 3; display: flex; gap: 12px; align-items: center; padding: 17px 20px; background: rgba(14,9,19,.92); border: 1px solid rgba(196,122,255,.4); backdrop-filter: blur(15px); color: #cbbbd8; font-size: 8px; line-height: 1.6; text-transform: uppercase; letter-spacing: .14em; }
.preview-lock span { width: 30px; height: 30px; border-radius: 50%; display: grid; place-items: center; background: var(--violet); color: #fff; font-size: 18px; }

.packs, .steps { padding: 110px 30px; }
.packs { border-top: 1px solid var(--line); }
.section-title { display: flex; align-items: end; justify-content: space-between; gap: 30px; margin-bottom: 40px; padding-bottom: 25px; border-bottom: 1px solid var(--line); }
.section-title p { max-width: 340px; margin: 0; color: var(--muted); font-size: 12px; }
.grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 15px; }
.grid article { position: relative; min-height: 465px; padding: 35px; display: flex; flex-direction: column; border: 1px solid var(--line); background: linear-gradient(145deg, #131018, #0c0910); transition: .25s; }
.grid article:hover { transform: translateY(-7px); border-color: rgba(196,122,255,.55); box-shadow: 0 25px 80px rgba(74,22,140,.18); }
.grid article.featured { background: linear-gradient(145deg, #50128e, #24083e); border-color: rgba(196,122,255,.55); }
.featured > label { position: absolute; right: 22px; top: 0; transform: translateY(-50%); padding: 9px 13px; background: #c27cff; color: #160721; font-size: 8px; font-weight: 800; text-transform: uppercase; letter-spacing: .15em; }
.number { color: #a885bd; font-size: 8px; text-transform: uppercase; letter-spacing: .18em; }
.grid h3 { margin: 68px 0 14px; font: 600 36px var(--serif); }
.grid p { max-width: 250px; color: var(--muted); font-size: 13px; line-height: 1.7; }
.grid strong { margin-top: auto; font: 600 50px var(--serif); }
.grid strong small { position: relative; top: 10px; margin-right: 4px; color: #ba9acb; font: 500 12px var(--sans); vertical-align: top; }
.grid sup { position: relative; top: -.9em; font-size: 20px; }
.grid button { min-height: 52px; margin-top: 22px; padding: 0 18px; display: flex; align-items: center; justify-content: space-between; border: 1px solid rgba(196,122,255,.35); background: rgba(255,255,255,.025); color: white; font-size: 11px; font-weight: 700; cursor: pointer; }
.grid button:hover, .featured button { background: white; color: #35105b; }

.steps { padding-top: 30px; }
.step-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); }
.step-grid article { padding: 38px; background: var(--black); }
.step-grid i { width: 34px; height: 34px; display: grid; place-items: center; border: 1px solid var(--violet); border-radius: 50%; color: var(--violet-2); font-style: normal; font-size: 10px; }
.step-grid h3 { margin: 42px 0 10px; font: 600 27px var(--serif); }
.step-grid p { color: var(--muted); font-size: 13px; line-height: 1.6; }

.closing { position: relative; max-width: 1180px; margin: 10px auto 110px; padding: 76px 72px; display: flex; justify-content: space-between; align-items: end; gap: 40px; overflow: hidden; background: linear-gradient(120deg, #25083e, #6317b5); border: 1px solid rgba(196,122,255,.4); }
.closing:after { content: ""; position: absolute; width: 380px; height: 380px; right: -120px; top: -230px; border: 1px solid rgba(255,255,255,.2); border-radius: 50%; }
.closing .eyebrow { color: #dcbaff; }
.light { position: relative; z-index: 1; min-width: 205px; background: white; color: #35105b; box-shadow: 0 18px 60px rgba(20,4,35,.35); }
.light:hover { background: #f5eaff; }

footer { padding: 40px 30px; display: flex; align-items: center; justify-content: space-between; border-top: 1px solid var(--line); color: #766c80; font-size: 9px; letter-spacing: .1em; text-transform: uppercase; }
footer p { margin: 0; }
footer nav { display: flex; gap: 24px; }

.modal { position: fixed; inset: 0; z-index: 20; display: grid; place-items: center; padding: 20px; visibility: hidden; opacity: 0; transition: .2s; }
.modal.open { visibility: visible; opacity: 1; }
.backdrop { position: absolute; inset: 0; background: rgba(4,2,7,.88); backdrop-filter: blur(14px); }
.panel { position: relative; width: min(100%, 500px); max-height: calc(100vh - 40px); overflow: auto; padding: 45px; color: var(--white); background: linear-gradient(145deg, #18101f, #0b080f); border: 1px solid rgba(196,122,255,.35); box-shadow: 0 35px 120px rgba(0,0,0,.7); }
.close { position: absolute; right: 17px; top: 13px; border: 0; background: transparent; color: #a995b8; font-size: 28px; cursor: pointer; }
.panel h2 { margin: 10px 0 5px; font: 600 44px var(--serif); }
.panel > #form-view > p { margin-bottom: 26px; color: #9b8ca7; font-size: 13px; }
form { display: grid; gap: 14px; }
form label { display: grid; gap: 7px; color: #ad9cba; font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; }
input { width: 100%; height: 50px; padding: 0 14px; border: 1px solid #3a2d43; outline: 0; background: rgba(255,255,255,.045); color: white; }
input:focus { border-color: var(--violet); box-shadow: 0 0 0 3px rgba(139,61,255,.1); }
.check { display: grid !important; grid-template-columns: auto 1fr; align-items: start; line-height: 1.5; letter-spacing: 0 !important; text-transform: none !important; }
.check input { width: 16px; height: 16px; accent-color: var(--violet); }
.submit { width: 100%; margin-top: 5px; }
.submit:disabled { opacity: .6; }
.error { min-height: 17px; margin: 0; color: #ff7da8; font-size: 11px; }
.privacy { color: #766a80; text-align: center; }
.payment { text-align: center; }
.payment > i { width: 50px; height: 50px; margin: 0 auto 18px; border-radius: 50%; display: grid; place-items: center; background: var(--violet); color: white; font-style: normal; font-size: 22px; }
.payment > p { color: var(--muted); }
.pix { margin: 20px 0; display: grid; grid-template-columns: 1fr auto; border: 1px solid #3a2d43; background: rgba(255,255,255,.05); }
.pix span { padding: 13px; overflow: hidden; text-align: left; text-overflow: ellipsis; white-space: nowrap; font: 11px monospace; }
.pix button { padding: 0 14px; border: 0; background: #2f1748; color: #d8baff; font-size: 11px; font-weight: 700; }
.payment .button { width: 100%; }
.legal-page { max-width: 760px; margin: auto; padding: 80px 24px; }
.legal-page > a { color: var(--violet-2); font-size: 10px; text-transform: uppercase; letter-spacing: .15em; }
.legal-page h1 { margin-top: 65px; }
.legal-page p { color: var(--muted); font-size: 16px; line-height: 1.8; }

@media (max-width: 940px) {
  .hero { grid-template-columns: 1fr; }
  .visual { justify-self: center; height: 610px; }
  .preview { grid-template-columns: 1fr; }
  .preview-copy { max-width: 600px; }
  .grid { grid-template-columns: 1fr; }
  .grid article { min-height: 400px; }
  .step-grid { grid-template-columns: 1fr; }
  .closing { margin-left: 24px; margin-right: 24px; }
}

@media (max-width: 640px) {
  header { height: 74px; padding: 0 20px; }
  .brand { font-size: 11px; }
  .brand b { display: none; }
  .private { display: none; }
  .hero { min-height: 0; padding: 58px 20px 82px; gap: 58px; }
  h1 { max-width: 100%; font-size: 43px; line-height: .96; }
  h1 em { display: inline; }
  .lead { font-size: 14px; }
  .hero-action { align-items: stretch; flex-direction: column; }
  .hero-action .button { width: 100%; }
  .hero-proof { flex-wrap: wrap; }
  .visual { width: calc(100% - 22px); min-height: 500px; height: 500px; justify-self: start; margin-left: 6px; }
  .visual img { object-position: 58% 40%; }
  .seal { right: -5px; width: 92px; height: 92px; font-size: 7px; }
  .exclusive-tag { left: -8px; bottom: 45px; }
  .manifesto { padding: 78px 20px; }
  .preview, .packs, .steps { padding: 82px 20px; }
  .preview { gap: 45px; }
  .preview-grid { height: 510px; grid-template-columns: 1fr 1fr; grid-template-rows: 1.2fr .8fr; }
  .preview-main { grid-column: 1 / 3; grid-row: auto !important; }
  .preview-lock { right: -8px; bottom: 18px; }
  .section-title { display: block; }
  .section-title p { margin-top: 16px; }
  .grid article { min-height: 420px; padding: 28px; }
  .closing { display: block; margin: 0 20px 80px; padding: 48px 28px; }
  .closing .button { width: 100%; margin-top: 32px; }
  footer { padding: 32px 20px; display: grid; justify-items: center; gap: 20px; text-align: center; }
  .panel { padding: 40px 22px 28px; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  * { transition: none !important; }
}
