/*
  Dayane Amaral — Landing page institucional premium
  Revamp clean/mobile-first: leitura fácil, menos ruído visual, foco em soluções financeiras.
*/

:root{
  --bg: #ffffff;
  --bg-soft: #f6f8fc;
  --surface: #ffffff;
  --surface-2: #f3f6ff;
  --border: rgba(15, 23, 42, 0.10);
  --border-2: rgba(15, 23, 42, 0.14);

  --text: #0b1220;
  --muted: rgba(11, 18, 32, 0.72);
  --muted-2: rgba(11, 18, 32, 0.55);

  --navy: #0b1f4b;
  --primary: #0b1f4b;
  --primary-2: #1d4ed8;
  --ink: #ffffff;

  --shadow: 0 18px 50px rgba(2, 6, 23, 0.10);
  --shadow-2: 0 10px 28px rgba(2, 6, 23, 0.08);

  --radius: 18px;
  --radius-sm: 12px;

  --container: 1120px;
  --reading: 72ch;

  /* Densidade/ritmo */
  --section-y: 62px;
  --section-y-compact: 44px;
  --grid-gap: 14px;
}

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin: 0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  color: var(--text);
  background:
    radial-gradient(900px 420px at 18% 6%, rgba(11, 31, 75, 0.07), transparent 60%),
    radial-gradient(900px 420px at 84% 0%, rgba(29, 78, 216, 0.07), transparent 60%),
    linear-gradient(180deg, #ffffff, var(--bg-soft));
  line-height: 1.58;
}

a{ color: inherit; text-decoration: none; }
a:hover{ opacity: .92; }
img{ max-width: 100%; display:block; }

.container{
  width: min(100% - 40px, var(--container));
  margin: 0 auto;
}

.skip{
  position:absolute;
  left:-999px;
  top:auto;
  width:1px;
  height:1px;
  overflow:hidden;
}
.skip:focus{
  left: 18px;
  top: 18px;
  width: auto;
  height: auto;
  padding: 10px 12px;
  border-radius: 10px;
  background: #ffffff;
  border: 1px solid var(--border);
  z-index: 9999;
}

/* Header */
.site-header{
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(15, 23, 42, 0.08);
}
.header-grid{
  display:flex;
  align-items:center;
  justify-content: space-between;
  padding: 12px 0;
  gap: 14px;
}

.brand{
  display:flex;
  align-items:center;
  gap: 12px;
  min-width: 280px;
}
.brand__mark{
  width: 56px;
  height: 56px;
  border-radius: 16px;
  border: 1px solid rgba(11,31,75,0.18);
  box-shadow: 0 14px 34px rgba(2,6,23,0.10);
  background: #fff;
  object-fit: contain;
}

.logo{
  display:flex;
  flex-direction: column;
  gap: 2px;
  letter-spacing: 0.2px;
}
.logo__name{
  font-weight: 850;
  font-size: 17px;
  letter-spacing: -0.01em;
  color: var(--navy);
}
.logo__desc{
  font-size: 12.5px;
  color: var(--muted);
}

.nav{
  display:flex;
  align-items:center;
  gap: 10px;
}
.nav a{
  font-size: 13px;
  color: var(--muted);
  padding: 8px 10px;
  border-radius: 10px;
  transition: background .15s ease, color .15s ease;
}
.nav a:hover{ background: rgba(15, 23, 42, 0.04); color: var(--text); }
.nav a.is-active{
  color: rgba(29, 78, 216, 0.98);
  background: rgba(29, 78, 216, 0.08);
  border: 1px solid rgba(29, 78, 216, 0.18);
}

.nav__cta{
  color: var(--ink) !important;
  background: linear-gradient(135deg, var(--primary), var(--primary-2));
  box-shadow: 0 12px 26px rgba(11,31,75,0.14);
  border: 1px solid rgba(11,31,75,0.16);
}

.nav-toggle{
  display:none;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: rgba(15, 23, 42, 0.03);
}
.nav-toggle span{
  display:block;
  height:2px;
  background: rgba(11, 18, 32, 0.78);
  margin: 7px 10px;
  border-radius: 2px;
}

/* Footer logo grande */
.footer-brand{ display:flex; align-items:center; gap: 14px; }
.footer-brand__mark{
  width: 92px;
  height: 92px;
  border-radius: 24px;
  border: 1px solid rgba(11,31,75,0.18);
  box-shadow: 0 18px 44px rgba(2,6,23,0.10);
  background: #fff;
  object-fit: contain;
}

/* Common */
.section{ padding: var(--section-y) 0; }
.section--compact{ padding: var(--section-y-compact) 0; }
.section--alt{ background: linear-gradient(180deg, rgba(15, 23, 42, 0.02), rgba(255,255,255,0)); }
.section-head{ max-width: 900px; }
.section-head h2{
  margin: 0;
  font-size: clamp(22px, 1.7vw + 14px, 34px);
  letter-spacing: -0.03em;
  color: var(--navy);
}
.section-head p{ margin: 10px 0 0; color: var(--muted); max-width: var(--reading); }

.eyebrow{
  display:inline-flex;
  gap: 10px;
  align-items:center;
  margin: 0 0 10px;
  font-size: 12px;
  color: rgba(11, 18, 32, 0.62);
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.grid{ display:grid; gap: var(--grid-gap); margin-top: 22px; }
.grid--2{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid--3{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid--4{ grid-template-columns: repeat(4, minmax(0, 1fr)); }

.panel{
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 18px 18px 16px;
  box-shadow: 0 8px 18px rgba(2,6,23,0.05);
}
.panel h3{ margin: 0 0 8px; font-size: 16px; letter-spacing: -0.01em; color: var(--navy); }
.panel p{ margin: 0; color: var(--muted); font-size: 14px; max-width: 62ch; }

.panel--big{ padding: 22px; border-radius: 22px; }
.panel--wide{ margin-top: 18px; padding: 20px; }

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid var(--border-2);
  font-weight: 750;
  font-size: 13px;
  letter-spacing: 0.01em;
  transition: transform .15s ease, background .15s ease, border-color .15s ease;
  background: #fff;
}
.btn:hover{ transform: translateY(-1px); }
.btn--primary{
  color: var(--ink);
  background: linear-gradient(135deg, var(--primary), var(--primary-2));
  border-color: rgba(11,31,75,0.18);
}
.btn--full{ width: 100%; }

.btn--ghost{
  background: rgba(255,255,255,0.80);
  border-color: rgba(11,31,75,0.20);
  color: rgba(11,31,75,0.95);
}

/* Hero */
.hero{ position: relative; padding: 64px 0 42px; overflow:hidden; }
.hero-grid{
  display:grid;
  grid-template-columns: 1.1fr 0.9fr;
  grid-template-areas:
    "copy aside"
    "below below";
  gap: 22px;
  align-items: start;
}
.hero-copy{ grid-area: copy; }
.hero-aside{ grid-area: aside; }

/* alinha a caixa da foto com o topo do conteúdo da esquerda (remove o "buraco" vermelho) */
.hero-aside{
  align-self: start;
  margin-top: 0;
}

/* faz os dois cards abaixo ficarem lado a lado, mesma largura e mesma altura */
.hero-metrics{
  grid-area: below;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  align-items: stretch;
}

.hero-metrics > .panel{
  height: 100%;
  display:flex;
  flex-direction: column;
}

/* garante que os mini-gráficos "empurrem" para baixo e equalizem alturas */
.hero-metrics .mini-metrics{
  margin-top: auto;
}

.hero-copy h1{
  margin: 0;
  font-size: clamp(28px, 2.5vw + 16px, 46px);
  letter-spacing: -0.04em;
  line-height: 1.08;
  color: var(--navy);
}
.subheadline{ margin: 12px 0 0; color: var(--muted); font-size: 16px; max-width: var(--reading); }
.hero-actions{ display:flex; gap: 12px; flex-wrap: wrap; margin-top: 16px; align-items:center; }

.badge-row{
  display:flex;
  gap: 10px;
  align-items:center;
  flex-wrap: wrap;
  margin-top: 14px;
}
.pill{
  display:inline-flex;
  align-items:center;
  height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,0.10);
  background: rgba(255,255,255,0.92);
  color: rgba(11,18,32,0.78);
  font-size: 12.5px;
  box-shadow: 0 8px 16px rgba(2,6,23,0.04);
}

.rating{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(29, 78, 216, 0.18);
  background: rgba(29, 78, 216, 0.06);
  color: rgba(11,31,75,0.95);
  box-shadow: 0 8px 16px rgba(2,6,23,0.04);
}
.rating__stars{ letter-spacing: 1px; font-size: 12.5px; }
.rating__text{ font-size: 12.5px; font-weight: 850; }

.scarcity{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(239, 68, 68, 0.22);
  background: rgba(239, 68, 68, 0.06);
  color: rgba(127, 29, 29, 0.95);
  font-weight: 850;
  font-size: 12.5px;
}

.hero-experience{
  margin-top: 0;
  border-radius: 24px;
  background:
    radial-gradient(520px 160px at 12% 8%, rgba(29,78,216,0.12), transparent 55%),
    radial-gradient(520px 160px at 86% 0%, rgba(11,31,75,0.12), transparent 52%),
    #ffffff;
  border: 1px solid rgba(29, 78, 216, 0.12);
}

.hero-experience h3{ margin: 0 0 8px; font-size: 16px; color: var(--navy); letter-spacing: -0.01em; }
.hero-experience p{ color: var(--muted); }

.hero-points{
  margin-top: 12px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.hero-point{
  border-radius: 16px;
  border: 1px solid rgba(15,23,42,0.08);
  background: rgba(11,31,75,0.03);
  padding: 10px;
}
.hero-point__kpi{ display:block; font-weight: 950; font-size: 12px; color: rgba(11,31,75,0.92); }
.hero-point__txt{ display:block; margin-top: 6px; font-size: 12.5px; color: rgba(11, 18, 32, 0.72); line-height: 1.35; }

/* Deixar os botões "Ver 4E / Ver elogios / Ver soluções" maiores e preenchendo a linha */
.hero-jump{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-top: 14px;
}
.hero-jump .btn{
  width: 100%;
  padding: 13px 16px;
  border-radius: 14px;
  font-size: 13.5px;
  justify-content: center;
}

/* Unified 4E section */
.section--4e{ padding-top: 22px; }
.grid--4e{ grid-template-columns: repeat(4, minmax(0, 1fr)); margin-top: 18px; }

/* Photo */
.photo{
  margin: 0;
  border-radius: 26px;
  overflow:hidden;
  border: 1px solid var(--border);
  background: #fff;
  box-shadow: var(--shadow-2);
}
.photo img{ width: 100%; height: auto; aspect-ratio: 4/5; object-fit: cover; }

/* Testimonials */
.grid--cards{ align-items: stretch; }
.panel--quote{ padding: 20px; border-radius: 24px; }
.quote-head{ display:flex; justify-content: space-between; align-items:center; gap: 10px; margin-bottom: 12px; }
.quote-stars{ color: rgba(245, 158, 11, 0.95); font-size: 13px; letter-spacing: 1px; }
.quote-tag{
  font-size: 12px;
  font-weight: 850;
  color: rgba(11,31,75,0.92);
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(11,31,75,0.12);
  background: rgba(11,31,75,0.06);
}
.quote{ margin: 0; color: rgba(11,18,32,0.86); font-size: 14px; line-height: 1.6; }
.quote-author{ margin: 12px 0 0; color: var(--muted); font-size: 12.5px; }

/* Timeline */
.timeline{ list-style: none; padding: 0; margin: 22px 0 0; display:grid; gap: 12px; }
.timeline__item{
  display:grid;
  grid-template-columns: 110px 1fr;
  gap: 14px;
  align-items: start;
  padding: 16px;
  border-radius: 20px;
  border: 1px solid var(--border);
  background: #fff;
  box-shadow: 0 8px 18px rgba(2,6,23,0.05);
}
.timeline__badge{
  display:inline-flex;
  justify-content:center;
  align-items:center;
  height: 34px;
  border-radius: 999px;
  font-weight: 850;
  font-size: 12px;
  background: rgba(11, 31, 75, 0.08);
  border: 1px solid rgba(11, 31, 75, 0.12);
  color: rgba(11, 31, 75, 0.95);
}
.timeline__content h3{ margin: 0; font-size: 16px; color: var(--navy); }
.timeline__content p{ margin: 6px 0 0; color: var(--muted); font-size: 14px; max-width: var(--reading); }

/* Form */
.contact-grid{ display:grid; grid-template-columns: 0.92fr 1.08fr; gap: 22px; align-items:start; }
.contact-note{
  margin-top: 14px;
  padding: 14px;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: #fff;
  box-shadow: 0 8px 16px rgba(2,6,23,0.04);
}
.contact-note p{ margin:0; color: var(--muted); max-width: var(--reading); }

.form{
  border-radius: 26px;
  border: 1px solid var(--border);
  background: #fff;
  padding: 18px;
  box-shadow: var(--shadow-2);
}
.form-head{ margin-bottom: 14px; }
.form-head h3{ margin: 0; color: var(--navy); letter-spacing: -0.02em; }
.form-head p{ margin: 6px 0 0; max-width: var(--reading); }

.field{ margin-bottom: 12px; }
label{ display:block; font-size: 12.5px; color: rgba(11, 18, 32, 0.72); margin-bottom: 8px; }
input{
  width: 100%;
  padding: 12px;
  border-radius: 14px;
  border: 1px solid var(--border-2);
  background: #ffffff;
  color: var(--text);
  outline: none;
}
input:focus{
  border-color: rgba(11, 31, 75, 0.28);
  box-shadow: 0 0 0 5px rgba(11, 31, 75, 0.10);
}

.field--choice{ padding-top: 4px; }
.choice{ display:flex; gap: 10px; align-items:flex-start; font-size: 13px; color: rgba(11,18,32,0.84); }
.choice input{ width: 18px; height: 18px; margin-top: 2px; }

.muted{ color: var(--muted); }

.error{ display:block; min-height: 16px; margin-top: 6px; color: #b91c1c; font-size: 12px; }
.form-fineprint{ margin: 10px 0 0; color: var(--muted-2); font-size: 12px; }
.form-success{
  margin-top: 12px;
  padding: 12px;
  border-radius: 16px;
  border: 1px solid rgba(11, 31, 75, 0.16);
  background: rgba(11, 31, 75, 0.06);
  color: rgba(11, 31, 75, 0.94);
  font-size: 12.5px;
}

/* Footer */
.site-footer{ padding: 40px 0; border-top: 1px solid rgba(15, 23, 42, 0.08); background: #ffffff; }
.footer-grid{ display:grid; grid-template-columns: 1.1fr 0.6fr 0.9fr; gap: 18px; align-items:start; }
.logo--footer .logo__name{ font-size: 15px; }
.footer-p{ margin: 10px 0 0; color: var(--muted); font-size: 13px; max-width: var(--reading); }
.footer-links{ display:flex; flex-direction: column; gap: 10px; }
.footer-links a{ color: var(--muted); font-size: 13px; padding: 8px 10px; border-radius: 12px; }
.footer-links a:hover{ background: rgba(15, 23, 42, 0.04); color: var(--text); }
.footer-small p{ margin: 0; color: var(--muted-2); font-size: 12.5px; }
.footer-small .muted{ margin-top: 8px; }

/* Responsive */
@media (max-width: 980px){
  .grid--4{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .grid--3{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .hero-grid{ grid-template-columns: 1fr; grid-template-areas: "copy" "aside" "below"; }
  .hero-metrics{ grid-template-columns: 1fr; }
  .hero-points{ grid-template-columns: 1fr; }
  .hero-jump{ grid-template-columns: 1fr; }
  .grid--4e{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .contact-grid{ grid-template-columns: 1fr; }
  .footer-grid{ grid-template-columns: 1fr; }
}

@media (max-width: 760px){
  :root{ --section-y: 54px; --section-y-compact: 40px; }
  .hero{ padding: 58px 0 40px; }
  .grid--2{ grid-template-columns: 1fr; }
  .grid--3{ grid-template-columns: 1fr; }
  .grid--4e{ grid-template-columns: 1fr; }

  .nav{
    position: fixed;
    right: 18px;
    top: 78px;
    width: min(360px, calc(100% - 36px));
    display:none;
    flex-direction: column;
    align-items: stretch;
    gap: 6px;
    padding: 12px;
    border-radius: 18px;
    background: rgba(255,255,255,0.97);
    border: 1px solid var(--border);
    box-shadow: var(--shadow-2);
    max-height: calc(100vh - 110px);
    overflow: auto;
  }
  .nav.is-open{ display:flex; }
  .nav a{ padding: 12px; }
  .nav-toggle{ display:inline-block; }

  .timeline__item{ grid-template-columns: 1fr; }
  .timeline__badge{ justify-content:flex-start; padding: 0 12px; }
}

@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior: auto; }
  .btn{ transition: none; }
  .nav a{ transition: none; }
}

/* Interactive (hover + reveal) */
.panel{ transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.panel:hover{
  transform: translateY(-3px);
  border-color: rgba(29, 78, 216, 0.22);
  box-shadow: 0 18px 44px rgba(2,6,23,0.12);
}

/* 4E com tilt leve (premium) */
.section--4e .panel--big:hover{
  transform: perspective(900px) rotateX(2deg) rotateY(-2deg) translateY(-4px) scale(1.01);
}

/* Fundo “financeiro” leve no hero */
.hero:before{
  content:"";
  position:absolute;
  inset: -120px -120px auto -120px;
  height: 520px;
  background:
    radial-gradient(320px 200px at 18% 40%, rgba(29,78,216,0.16), transparent 60%),
    radial-gradient(360px 220px at 70% 35%, rgba(11,31,75,0.16), transparent 62%),
    repeating-linear-gradient(135deg, rgba(11,31,75,0.06), rgba(11,31,75,0.06) 1px, transparent 1px, transparent 10px);
  pointer-events:none;
  opacity: 0.9;
}

/* Reveal on scroll */
.reveal{ opacity: 0; transform: translateY(14px); transition: opacity .55s ease, transform .55s ease; }
.reveal.is-in{ opacity: 1; transform: translateY(0); }
.reveal-delay-1{ transition-delay: .06s; }
.reveal-delay-2{ transition-delay: .12s; }
.reveal-delay-3{ transition-delay: .18s; }

/* Mini gráficos (Sobre Dayane) — cards mais “premium” */
.mini-metrics{ display:grid; grid-template-columns: 1fr; gap: 12px; margin-top: 14px; }

.metric-card{
  position: relative;
  padding: 14px 14px 12px;
  border-radius: 18px;
  border: 1px solid rgba(29, 78, 216, 0.12);
  background:
    radial-gradient(520px 160px at 12% 8%, rgba(29,78,216,0.16), transparent 55%),
    radial-gradient(520px 160px at 86% 0%, rgba(11,31,75,0.14), transparent 52%),
    rgba(255,255,255,0.92);
  box-shadow: 0 12px 26px rgba(2,6,23,0.06);
  overflow: hidden;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.metric-card:before{
  content:"";
  position:absolute;
  inset: 0;
  background:
    repeating-linear-gradient(135deg, rgba(11,31,75,0.06), rgba(11,31,75,0.06) 1px, transparent 1px, transparent 10px);
  opacity: .22;
  pointer-events:none;
}

.metric-card:hover{
  transform: translateY(-3px);
  border-color: rgba(29, 78, 216, 0.22);
  box-shadow: 0 22px 52px rgba(2,6,23,0.14);
}

.metric-head{ position: relative; display:flex; justify-content: space-between; gap: 10px; align-items: baseline; }
.metric-title{ font-weight: 900; font-size: 12.5px; color: rgba(11,31,75,0.92); }
.metric-value{ font-weight: 950; font-size: 12.5px; color: rgba(29,78,216,0.98); }

.mini-chart{ position: relative; width: 100%; height: 64px; margin-top: 10px; }
.mini-chart .gridline{ stroke: rgba(15,23,42,0.10); stroke-width: 1; }

.mini-chart path{
  stroke: rgba(29,78,216,0.95);
  stroke-width: 3;
  fill: none;
  stroke-linecap: round;
  stroke-dasharray: 260;
  stroke-dashoffset: 260;
  animation: chartDraw 1.2s ease forwards;
}

/* Hover: dá vida sem exagero */
.metric-card:hover .mini-chart path{
  transform-origin: 50% 50%;
  animation: chartWiggle .55s ease-in-out;
}

@keyframes chartDraw{ to{ stroke-dashoffset: 0; } }
@keyframes chartWiggle{
  0%{ transform: translateY(0) scale(1); }
  40%{ transform: translateY(-1px) scale(1.01); }
  100%{ transform: translateY(0) scale(1); }
}

@media (prefers-reduced-motion: reduce){
  .panel{ transition: none; }
  .panel:hover{ transform: none; }
  .reveal{ opacity: 1; transform: none; transition: none; }
  .metric-card{ transition: none; }
  .metric-card:hover{ transform: none; }
  .mini-chart path{ animation: none; stroke-dashoffset: 0; }
  .metric-card:hover .mini-chart path{ animation: none; }
}
