@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700;800;900&family=Montserrat:wght@600;700;800;900&family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@500;700&family=Caveat:wght@600;700&display=swap');

:root {
  --azul: #153a63;
  --azul-2: #0e2f52;
  --azul-claro: #6fa8d8;
  --verde: #2f7d5c;
  --papel: #f4ebd8;
  --card: #fff9ee;
  --linha: #ded4bc;
  --texto: #17304a;
  --muted: #667381;
  --shadow: 0 28px 70px -42px rgba(21, 58, 99, .55);
  --max: 1160px;
  --gutter: clamp(18px, 4vw, 48px);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--papel);
  color: var(--texto);
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 17px;
  line-height: 1.62;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
p, h1, h2, h3 { margin-top: 0; }
h1, h2, h3 { font-family: Montserrat, Inter, sans-serif; color: var(--azul-2); letter-spacing: -.07em; line-height: .94; }
h1 { max-width: 760px; margin-bottom: 26px; font-size: clamp(3.2rem, 7vw, 6.1rem); font-weight: 800; }
h2 { margin-bottom: 24px; font-size: clamp(2.5rem, 5vw, 4.7rem); font-weight: 800; }
h3 { margin-bottom: 10px; font-size: 1.25rem; font-weight: 850; letter-spacing: -.045em; line-height: 1.08; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 18px var(--gutter);
  background: rgba(244, 235, 216, .82);
  border-bottom: 1px solid rgba(222, 212, 188, .72);
  backdrop-filter: blur(18px);
}
.brand { display: flex; align-items: center; gap: 10px; color: var(--azul); line-height: .9; }
.brand img { width: 38px; height: 42px; object-fit: contain; }
.brand span { display: grid; }
.brand b { color: var(--azul-claro); font-family: "Playfair Display", serif; font-size: 1.3rem; font-weight: 900; letter-spacing: -.055em; }
.brand strong { color: var(--azul); font-family: Montserrat, sans-serif; font-size: 1rem; font-weight: 900; letter-spacing: -.055em; }
.nav { display: flex; align-items: center; gap: 30px; margin-left: auto; }
.nav a { color: rgba(23,48,74,.76); font-size: .82rem; font-weight: 800; }
.nav a:hover { color: var(--azul); }

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 56px;
  padding: 0 28px;
  border: 1px solid var(--azul);
  border-radius: 7px;
  background: var(--azul);
  color: #fff;
  cursor: pointer;
  font-family: Montserrat, sans-serif;
  font-size: .95rem;
  font-weight: 850;
  letter-spacing: -.02em;
  box-shadow: 0 18px 38px rgba(21, 58, 99, .18);
  transition: transform .18s ease, background .18s ease, box-shadow .18s ease;
}
.button:hover { transform: translateY(-2px); background: var(--azul-2); box-shadow: 0 22px 50px rgba(21, 58, 99, .28); }
.button-small { min-height: 42px; padding: 0 18px; font-size: .8rem; }
.button-ghost, .button-outline { background: rgba(255,249,238,.62); color: var(--azul); border-color: rgba(21,58,99,.18); box-shadow: none; }
.button-outline { background: transparent; border-color: rgba(255,255,255,.22); color: var(--card); }
.button.green { background: var(--verde); border-color: var(--verde); }

.section-shell {
  position: relative;
  overflow: hidden;
  padding: clamp(86px, 11vh, 136px) max(var(--gutter), calc((100vw - var(--max)) / 2));
  border-bottom: 1px solid rgba(222,212,188,.75);
  scroll-margin-top: 82px;
}
.paper-map {
  background: linear-gradient(90deg, rgba(244,235,216,.98), rgba(244,235,216,.90)), url('./assets/pattern-mapa-creme.png') center / 760px auto repeat;
}
.hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(370px, 520px);
  align-items: center;
  gap: clamp(30px, 5vw, 62px);
  min-height: calc(100vh - 78px);
  padding-top: clamp(54px, 8vh, 84px);
  padding-bottom: clamp(66px, 9vh, 106px);
}
.script { margin-bottom: 12px; color: var(--verde); font-family: Caveat, cursive; font-size: clamp(2rem, 3.6vw, 3.1rem); font-weight: 700; line-height: 1; transform: rotate(-1deg); }
.lead { max-width: 680px; margin-bottom: 0; color: rgba(23,48,74,.79); font-size: clamp(1.05rem, 1.6vw, 1.25rem); }
.actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 32px; }
.trust-line { display: flex; flex-wrap: wrap; gap: 13px; margin-top: 18px; color: rgba(23,48,74,.68); font-size: .82rem; font-weight: 700; }
.trust-line span { display: inline-flex; align-items: center; gap: 7px; }
.trust-line span::before { content: ''; width: 5px; height: 5px; border-radius: 999px; background: var(--verde); }
.hero-metrics { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 14px; max-width: 640px; margin-top: 34px; }
.hero-metrics div { padding: 16px 18px; border: 1px solid rgba(222,212,188,.8); border-radius: 10px; background: rgba(255,249,238,.58); box-shadow: 0 10px 24px rgba(21,58,99,.045); }
.hero-metrics strong { display: block; color: var(--azul); font-family: Montserrat, sans-serif; font-size: 1.45rem; font-weight: 900; line-height: 1; letter-spacing: -.05em; }
.hero-metrics span { display: block; margin-top: 5px; color: rgba(23,48,74,.65); font-size: .78rem; font-weight: 800; }
.hero-visual { position: relative; min-height: 600px; }
.book { position: absolute; z-index: 2; top: 10px; right: -96px; width: min(690px, 58vw); filter: drop-shadow(0 24px 30px rgba(21,58,99,.14)); }
.book-shadow { z-index: 1; opacity: .28; filter: brightness(0) saturate(0) blur(8px); transform: translate(-13px, 18px); }
.receive-float { position: absolute; right: 2px; bottom: 38px; z-index: 4; width: 250px; padding: 18px 20px; border: 1px solid rgba(222,212,188,.92); border-radius: 10px; background: rgba(255,249,238,.92); box-shadow: var(--shadow); backdrop-filter: blur(10px); }
.receive-float h3 { color: var(--azul); }
.receive-float ol { display: grid; gap: 8px; margin: 0; padding: 0; list-style: none; counter-reset: item; }
.receive-float li { counter-increment: item; color: rgba(23,48,74,.78); font-size: .78rem; font-weight: 800; }
.receive-float li::before { content: counter(item); display: inline-grid; width: 18px; height: 18px; margin-right: 8px; place-items: center; border-radius: 5px; background: rgba(47,125,92,.12); color: var(--verde); }

.section-number { display: flex; align-items: center; gap: 18px; margin-bottom: 48px; color: var(--azul-claro); font-family: "Playfair Display", serif; font-size: 1.75rem; font-weight: 900; }
.section-number::after { content: ''; width: 76px; height: 1px; background: rgba(21,58,99,.22); order: 1; }
.section-number span { order: 2; color: rgba(23,48,74,.62); font-family: 'JetBrains Mono', monospace; font-size: .67rem; letter-spacing: .28em; text-transform: uppercase; }
.section-number.light span { color: rgba(255,249,238,.6); }
.section-number.light::after { background: rgba(255,255,255,.22); }
.split-grid { display: grid; grid-template-columns: minmax(0, .95fr) minmax(360px, 1fr); gap: clamp(42px, 7vw, 82px); align-items: center; }
.problem, .fit, .offer, .faq { background: linear-gradient(115deg, #fff9ee 0%, #f4ebd8 58%, #eadfc9 100%); }
.note-card { margin-top: 34px; padding: 22px 24px; border-left: 4px solid var(--verde); border-radius: 8px; background: rgba(255,249,238,.8); box-shadow: 0 18px 44px -36px rgba(21,58,99,.45); color: rgba(23,48,74,.8); font-weight: 700; }
.accent { font-family: Montserrat, sans-serif; color: var(--azul); font-size: 1.08rem; letter-spacing: -.035em; }
.decision-map { position: relative; min-height: 460px; }
.decision-map::before { content: ''; position: absolute; inset: 66px 70px; border: 1px dashed rgba(21,58,99,.18); border-radius: 22px; }
.center-card, .mini-card { position: absolute; border: 1px solid rgba(222,212,188,.84); border-radius: 10px; box-shadow: var(--shadow); }
.center-card { left: 32%; top: 28%; width: 255px; padding: 26px; background: var(--azul); color: #fff; font-family: Montserrat, sans-serif; font-size: 1.55rem; font-weight: 900; line-height: 1.02; letter-spacing: -.05em; }
.center-card small { display: block; margin-top: 14px; color: rgba(255,255,255,.72); font-family: Inter, sans-serif; font-size: .82rem; font-weight: 500; letter-spacing: 0; line-height: 1.5; }
.mini-card { width: 175px; padding: 18px; background: rgba(255,249,238,.9); }
.mini-card b { display: block; color: var(--azul); font-family: Montserrat, sans-serif; font-weight: 900; }
.mini-card span { display: block; color: rgba(23,48,74,.66); font-size: .76rem; font-weight: 700; line-height: 1.35; }
.c1 { left: 12%; top: 7%; } .c2 { right: 0; top: 12%; } .c3 { left: 8%; bottom: 20%; } .c4 { right: 3%; bottom: 20%; } .c5 { left: 43%; bottom: 0; }

.dark { background: var(--azul); background-image: linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px); background-size: 42px 42px; color: rgba(255,249,238,.78); }
.dark h2, .dark h3 { color: var(--card); }
.light-script { color: #d9e8f5; }
.receive-grid { display: grid; grid-template-columns: minmax(0, .95fr) minmax(380px, 1fr); gap: clamp(42px, 7vw, 86px); align-items: center; }
.table-stack { width: min(520px, 92%); margin-top: 48px; filter: drop-shadow(0 28px 28px rgba(0,0,0,.18)); }
.materials-badge { width: 190px; margin: -34px 0 0 auto; padding: 16px; border-radius: 10px; background: var(--card); color: var(--azul); box-shadow: var(--shadow); }
.materials-badge strong { display: block; font-family: Montserrat, sans-serif; font-size: 1.45rem; font-weight: 900; }
.materials-badge span { color: rgba(23,48,74,.72); font-size: .78rem; font-weight: 700; }
.dark-copy { max-width: 570px; margin-bottom: 28px; color: rgba(255,249,238,.74); font-size: 1.08rem; }
.material-list { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.material-list article, .result-cards article, .faq-grid article { position: relative; padding: 22px; border: 1px solid rgba(222,212,188,.84); border-radius: 10px; background: var(--card); color: var(--texto); box-shadow: 0 14px 38px -34px rgba(21,58,99,.5); }
.material-list i, .result-cards i, .faq-grid i { position: absolute; top: 16px; right: 18px; color: var(--azul-claro); font-family: "Playfair Display", serif; font-size: 1.55rem; font-weight: 900; font-style: normal; opacity: .75; }
.material-list b { display: block; max-width: 78%; color: var(--azul); font-family: Montserrat, sans-serif; font-weight: 900; line-height: 1.08; }
.material-list span { display: block; margin-top: 9px; color: rgba(23,48,74,.68); font-size: .82rem; line-height: 1.42; }
.inline-cta { display: flex; justify-content: space-between; gap: 16px; align-items: center; margin-top: 16px; padding: 16px 20px; border: 1px solid rgba(255,255,255,.15); border-radius: 10px; background: rgba(255,255,255,.06); }
.inline-cta a, .question-bar a, .faq-bar a { flex: 0 0 auto; padding: 12px 20px; border-radius: 7px; background: var(--card); color: var(--azul); font-family: Montserrat, sans-serif; font-weight: 900; }

.fit-columns { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.fit-card { padding: 30px; border-radius: 10px; background: rgba(255,249,238,.8); border: 1px solid rgba(222,212,188,.86); box-shadow: var(--shadow); }
.fit-card h3 { margin-bottom: 20px; }
.fit-card ul, .included ul, .compare ul, .receipt-card ul { display: grid; gap: 18px; margin: 0; padding: 0; list-style: none; }
.fit-card li, .included li, .compare li, .receipt-card li { position: relative; padding-left: 18px; }
.fit-card li::before, .included li::before, .compare li::before, .receipt-card li::before { content: ''; position: absolute; left: 0; top: .72em; width: 6px; height: 6px; border-radius: 999px; background: var(--verde); }
.fit-card.no li::before, .compare.bad li::before { background: #aa6d55; }
.yes { border-top: 4px solid var(--verde); } .no { border-top: 4px solid #aa6d55; }
.question-bar, .faq-bar { grid-column: 1 / -1; padding: 24px 28px; border-radius: 10px; background: var(--azul); color: #fff; font-weight: 700; box-shadow: var(--shadow); }
.question-bar { display: flex; align-items: center; justify-content: space-between; gap: 16px; }

.result-head { display: grid; grid-template-columns: 1fr .92fr; gap: 70px; align-items: end; }
.result-head p { color: rgba(255,249,238,.75); font-size: 1.12rem; }
.result-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 44px; }
.result-cards h3 { color: var(--azul); }
.result-cards p, .faq-grid p { margin: 0; color: rgba(23,48,74,.7); }
.compare-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; margin-top: 28px; }
.compare { padding: 28px; border: 1px solid rgba(255,255,255,.18); border-radius: 10px; background: rgba(255,255,255,.05); }
.compare h3 { margin-bottom: 20px; }
.compare li { color: rgba(255,249,238,.72); }

.offer .split-grid { align-items: start; }
.included { margin-top: 34px; padding: 22px 24px; border: 1px solid rgba(222,212,188,.84); border-radius: 10px; background: rgba(255,249,238,.72); }
.included b { display: block; margin-bottom: 16px; color: var(--verde); font-family: 'JetBrains Mono', monospace; font-size: .72rem; letter-spacing: .2em; text-transform: uppercase; }
.included ul { grid-template-columns: 1fr 1fr; gap: 10px 22px; }
.checkout-card { padding: 34px; border-radius: 12px; background: var(--azul); color: rgba(255,249,238,.8); box-shadow: var(--shadow); }
.checkout-card img { width: 92px; margin-bottom: 26px; }
.checkout-card h3 { color: #fff; font-size: 1.65rem; }
.price-box { display: grid; grid-template-columns: 1fr auto; gap: 4px 20px; align-items: center; margin: 26px 0 22px; padding: 24px; border-radius: 10px; background: var(--card); color: var(--azul); }
.price-box span { grid-column: 1 / -1; color: var(--verde); font-family: 'JetBrains Mono', monospace; font-size: .68rem; letter-spacing: .2em; text-transform: uppercase; }
.price-box strong { font-family: Montserrat, sans-serif; font-size: 3.7rem; line-height: .9; letter-spacing: -.07em; }
.price-box small { max-width: 170px; color: rgba(23,48,74,.68); text-align: right; }
.checkout-card .button { width: 100%; }
.safe, .after-buy { margin: 14px 0 0; text-align: center; color: rgba(255,249,238,.62); font-size: .82rem; }
.checkout-features { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-top: 24px; }
.checkout-features span { padding: 16px 12px; border: 1px solid rgba(255,255,255,.15); border-radius: 8px; color: #fff; font-size: .82rem; font-weight: 800; }

.faq-intro { display: grid; grid-template-columns: 1fr .95fr; gap: 70px; align-items: end; margin-bottom: 34px; }
.faq-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.faq-grid article { padding-left: 50px; }
.faq-grid i { left: 20px; right: auto; top: 20px; font-family: 'JetBrains Mono', monospace; font-size: .82rem; }
.faq-bar { display: flex; justify-content: space-between; align-items: center; gap: 18px; margin-top: 24px; }
.faq-bar a { background: var(--verde); color: #fff; }

.closing { padding-bottom: 44px; }
.receipt-card { padding: 34px; border-radius: 12px; background: var(--card); color: var(--texto); box-shadow: var(--shadow); }
.receipt-card img { width: 96px; margin-bottom: 26px; }
.receipt-card span { color: var(--verde); font-family: 'JetBrains Mono', monospace; font-size: .72rem; letter-spacing: .2em; text-transform: uppercase; }
.receipt-card strong { display: block; margin: 10px 0 28px; color: var(--azul); font-family: Montserrat, sans-serif; font-size: 4rem; line-height: 1; letter-spacing: -.08em; }
.footer { display: flex; justify-content: space-between; gap: 28px; align-items: end; margin-top: 82px; padding-top: 32px; border-top: 1px solid rgba(255,255,255,.16); }
.footer p { max-width: 720px; margin: 0; color: rgba(255,249,238,.52); font-size: .78rem; }
.footer nav { display: flex; gap: 28px; color: rgba(255,249,238,.72); font-size: .82rem; font-weight: 800; }

.js-ready [data-reveal], .js-ready .material-list article, .js-ready .result-cards article, .js-ready .faq-grid article, .js-ready .fit-card, .js-ready .checkout-card {
  opacity: 0;
  transform: translate3d(0, 26px, 0) scale(.99);
  transition: opacity .72s cubic-bezier(.22,1,.36,1), transform .72s cubic-bezier(.22,1,.36,1), box-shadow .25s ease;
  transition-delay: var(--delay, 0ms);
}
.js-ready .is-visible, .js-ready .is-visible .material-list article, .js-ready .is-visible .result-cards article, .js-ready .is-visible .faq-grid article, .js-ready .is-visible .fit-card, .js-ready .is-visible .checkout-card { opacity: 1; transform: translate3d(0,0,0) scale(1); }
.material-list article:hover, .result-cards article:hover, .faq-grid article:hover, .fit-card:hover { transform: translateY(-3px); box-shadow: 0 24px 54px -38px rgba(21,58,99,.7); }

@media (max-width: 980px) {
  .nav { display: none; }
  .site-header { padding: 10px 12px; }
  .hero, .split-grid, .receive-grid, .result-head, .faq-intro { grid-template-columns: 1fr; }
  .hero { gap: 18px; min-height: auto; padding-top: 46px; }
  .hero-visual { min-height: 520px; }
  .book { width: 520px; max-width: 118vw; right: auto; left: 50%; transform: translateX(-50%); top: 16px; }
  .book-shadow { transform: translate(calc(-50% - 12px), 16px); }
  .receive-float { right: 4px; bottom: 30px; width: min(230px, 58vw); }
  .decision-map { min-height: auto; display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
  .decision-map::before { display: none; }
  .center-card, .mini-card { position: static; width: auto; }
  .center-card { grid-column: 1 / -1; }
  .fit-columns, .material-list, .result-cards, .compare-grid, .faq-grid, .checkout-features { grid-template-columns: 1fr; }
  .question-bar, .faq-bar, .footer { flex-direction: column; align-items: stretch; }
  .included ul { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  body { font-size: 15px; }
  .section-shell { padding: 64px 14px; scroll-margin-top: 68px; }
  .site-header .button-small { min-height: 34px; padding: 0 12px; font-size: .72rem; }
  .brand img { width: 28px; height: 32px; }
  .brand b { font-size: .9rem; } .brand strong { font-size: .72rem; }
  h1 { font-size: clamp(3rem, 14.5vw, 4rem); }
  h2 { font-size: clamp(2.4rem, 11vw, 3.25rem); }
  .hero-metrics { grid-template-columns: repeat(3, 1fr); gap: 8px; }
  .hero-metrics div { padding: 13px 9px; }
  .hero-metrics strong { font-size: 1.15rem; }
  .hero-metrics span { font-size: .68rem; }
  .actions .button { width: 100%; }
  .trust-line { display: grid; gap: 4px; }
  .table-stack { width: 105%; margin-left: -12%; }
  .materials-badge { margin-right: 8px; }
  .price-box { grid-template-columns: 1fr; }
  .price-box small { max-width: none; text-align: left; }
  .faq-grid article { padding-left: 42px; }
  .footer nav { gap: 16px; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
  .js-ready [data-reveal], .js-ready .material-list article, .js-ready .result-cards article, .js-ready .faq-grid article, .js-ready .fit-card, .js-ready .checkout-card { opacity: 1; transform: none; }
}
