/* ====== Base ====== */
:root {
  --ink:#0f172a; --muted:#6b7280; --brand:#0ea5e9; --ok:#10b981; --err:#ef4444;
  --bg:#f6f7f9; --card:#ffffff; --line:#e5e7eb;
}
*{box-sizing:border-box} body{margin:0;font-family:Inter,system-ui,Segoe UI,Roboto,Arial,sans-serif;color:var(--ink);background:var(--bg)}
.wrap{max-width:1100px;margin:0 auto;padding:20px}

/* ====== Header ====== */
.topbar{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--line)}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between}

.brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--ink);font-weight:800}
.brand .brand-icon{
  width:36px;height:36px;display:grid;place-items:center;border-radius:12px;
  background: radial-gradient(100% 100% at 50% 0%, #42b7ff 0%, #0ea5e9 60%, #0673b7 100%);
  color:#fff;font-weight:900;letter-spacing:0.5px;transition:transform .35s ease, filter .35s ease;
  box-shadow: 0 6px 20px rgba(14,165,233,.35);
}
.brand:hover .brand-icon{ transform: rotate(8deg) scale(1.06); filter: brightness(1.08) saturate(1.1); }
.brand .brand-text{font-size:18px}

.nav{display:flex;gap:16px}
.nav a{color:var(--ink);text-decoration:none;padding:10px 8px;border-radius:8px}
.nav a:hover{background:#f1f5f9}

.nav-toggle{
  display:none;background:none;border:0;padding:8px;border-radius:8px;cursor:pointer;
}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0;border-radius:2px;transition:transform .25s ease, opacity .25s ease}

/* ====== HERO NOVO ====== */
.hero{
  position:relative; overflow:hidden; color:#e6f1ff;
  background:radial-gradient(120% 150% at 80% -20%, #0ea5e9 0%, #0b1220 45%, #0b0d10 100%);
  padding:78px 0 64px;
}
.hero-bg{
  position:absolute; inset:-20% -10% auto -10%; height:120%;
  background:
    radial-gradient(60% 60% at 85% 10%, rgba(56,189,248,.25) 0%, rgba(56,189,248,0) 60%),
    radial-gradient(30% 30% at 10% 20%, rgba(14,165,233,.18) 0%, rgba(14,165,233,0) 70%);
  animation: floatGlow 12s ease-in-out infinite alternate;
  pointer-events:none;
  filter: blur(18px);
}
.hero-noise{
  position:absolute; inset:0; opacity:.06; pointer-events:none;
  background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="140" height="140" viewBox="0 0 140 140"><filter id="n"><feTurbulence type="fractalNoise" baseFrequency="0.8" numOctaves="2" stitchTiles="stitch"/></filter><rect width="100%" height="100%" filter="url(%23n)"/></svg>');
  mix-blend-mode: soft-light;
}

.hero-grid{position:relative; z-index:2; display:grid; grid-template-columns:1.35fr 1fr; gap:28px; align-items:center}
.eyebrow{letter-spacing:.12em; text-transform:uppercase; font-size:12px; color:#93c5fd; margin:0 0 8px}
.hero h1{font-size:42px; line-height:1.12; margin:0 0 10px; color:#fff}
.hero h1 .glow{
  background: linear-gradient(90deg,#93c5fd 0%, #38bdf8 50%, #a5b4fc 100%);
  -webkit-background-clip: text; background-clip: text; color:transparent;
  text-shadow: 0 0 28px rgba(56,189,248,.25);
}
.hero .sub{color:#cfe6ff; margin:0 0 18px; max-width:56ch}

.hero-ctas{display:flex; gap:12px; flex-wrap:wrap}
.hero .btn{padding:12px 18px}
.hero .btn.ghost{border-color:rgba(255,255,255,.28); color:#e6f1ff}

.trust-badges{display:flex; gap:14px; flex-wrap:wrap; padding:0; margin:18px 0 0; list-style:none; color:#cde3ff}
.trust-badges li{background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); padding:8px 10px; border-radius:999px; font-size:13px}

.hero-side{display:grid; gap:14px}
.hero-card{
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14);
  border-radius:16px; padding:16px;
  display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px;
  box-shadow: 0 10px 30px rgba(2,6,23,.25);
}
.kpi{background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.16); border-radius:12px; padding:14px; text-align:center}
.kpi strong{display:block; font-size:24px; color:#fff}
.kpi span{font-size:12px; color:#d2e8ff}

.hero-note{
  display:flex; align-items:flex-start; gap:10px; font-size:13px;
  color:#cfe6ff; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14);
  border-radius:12px; padding:12px 14px;
}
.hero-note svg{flex:0 0 auto; color:#93c5fd}

/* animação sutil do glow */
@keyframes floatGlow{
  0%{transform: translateY(-6px) translateX(0)}
  100%{transform: translateY(6px) translateX(8px)}
}

/* ====== RESPONSIVO ====== */
/* ===== AJUSTES PARA SUBIR O HERO NO MOBILE ===== */

/* tablets e celulares */
@media (max-width: 980px){
  .hero{
    /* sobe o conteúdo: menos respiro em cima e embaixo */
    padding-top: calc(env(safe-area-inset-top, 0px) + 28px);
    padding-bottom: 36px;
    min-height: unset; /* não estica demais */
  }
  .hero-grid{
    grid-template-columns: 1fr;
    gap: 18px;       /* gap menor */
  }
  .hero h1{
    font-size: 32px; /* já estava 34px, reduz levemente */
    line-height: 1.15;
    margin: 2px 0 8px;
  }
  .hero .sub{
    font-size: 15px;
    line-height: 1.45;
    margin-bottom: 14px;
    max-width: 38ch;
  }

  /* CTAs mais compactas e alinhadas */
  .hero-ctas{
    gap: 10px;
    margin-top: 6px;
    flex-wrap: wrap;
  }
  .hero .btn{ padding: 11px 14px; }

  /* cartões à direita: layout mais enxuto */
  .hero-side{ gap: 10px; }
  .hero-card{
    grid-template-columns: repeat(2, minmax(0,1fr));
    gap: 10px;
    padding: 12px;
    border-radius: 14px;
  }
  .kpi{ padding: 12px; }
  .kpi strong{ font-size: 22px; }
  .kpi span{ font-size: 12px; }
}

/* celulares estreitos */
@media (max-width: 560px){
  .hero{
    padding-top: calc(env(safe-area-inset-top, 0px) + 18px); /* sobe ainda mais */
    padding-bottom: 28px;
  }
  .eyebrow{ margin-bottom: 6px; }
  .hero h1{
    font-size: 28px;          /* de 30 → 28 melhora quebra de linha */
    line-height: 1.14;
    margin: 0 0 8px;
  }
  .hero .sub{
    font-size: 14.5px;
    margin-bottom: 12px;
    max-width: 34ch;
  }

  /* CTAs lado a lado; se faltar espaço quebram bonito */
  .hero-ctas{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }
  .hero .btn{ padding: 10px 12px; }

  /* chips/badges mais enxutas e com menos margem inferior */
  .trust-badges{
    gap: 8px;
    margin: 10px 0 6px;
  }
  .trust-badges li{
    padding: 6px 10px;
    font-size: 12px;
  }

  /* bloco de números mais próximo e baixo */
  .hero-card{
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    padding: 10px;
  }
  .kpi{ padding: 10px; border-radius: 10px; }
  .kpi strong{ font-size: 20px; }
  .kpi span{ font-size: 11.5px; }
}

/* micro-ajuste para aparelhos muito estreitos (≤ 360px) */
@media (max-width: 360px){
  .hero h1{ font-size: 26px; }
  .hero-ctas{ grid-template-columns: 1fr; } /* empilha os botões */
}


.kpi{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:14px;text-align:center}
.kpi strong{display:block;font-size:24px}
.kpi span{color:#cbd5e1;font-size:12px}

/* ====== Buttons/Cards/Forms ====== */
.btn{background:var(--brand);color:#fff;padding:12px 18px;border-radius:10px;border:0;text-decoration:none;display:inline-block}
.btn.ghost{background:transparent;border:1px solid #94a3b8;color:#e2e8f0}

.card{background:#fff;padding:20px;border:1px solid var(--line);border-radius:12px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* ===== Footer ===== */
.footer{background:#0b0d10;color:#9ca3af;margin-top:30px}
.footer a{color:#cbd5e1;text-decoration:none}
.footer a:hover{color:#fff}
.footer-cta{background:linear-gradient(90deg,#0f172a,#111827);color:#e5e7eb;border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06)}
.cta-grid{display:grid;grid-template-columns:1.4fr .6fr;gap:16px;align-items:center}
.cta-actions{display:flex;gap:10px;justify-content:flex-end}
.footer-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr 1fr;gap:22px;padding:28px 20px}
.footer h4{color:#e5e7eb;margin:6px 0 10px}
.footer ul{list-style:none;margin:0;padding:0}
.footer-logo{height:32px;display:block;filter:brightness(1.1);transition:transform .3s ease; margin-bottom:8px}
.brand.mini:hover .footer-logo{transform:scale(1.05)}
.social{display:flex;gap:10px;margin-top:10px}
.social a{width:36px;height:36px;display:grid;place-items:center;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:10px}
.social a:hover{background:rgba(255,255,255,.12)}
.newsletter{display:flex;gap:8px;margin:8px 0}
.newsletter input{flex:1;padding:11px;border-radius:10px;border:1px solid #334155;background:#0f172a;color:#e2e8f0}
.newsletter input::placeholder{color:#94a3b8}
.newsletter .btn{padding:11px 14px}
.contact li{margin:6px 0}
.footer-copy{border-top:1px solid rgba(255,255,255,.07);padding:12px 0;display:flex;align-items:center;justify-content:space-between}
.footer-copy a{color:#cbd5e1}
.to-top{background:transparent;border:1px solid rgba(255,255,255,.25);color:#e5e7eb;border-radius:10px;padding:6px 10px;cursor:pointer}
.to-top:hover{background:rgba(255,255,255,.08)}

@media (max-width:900px){
  .cta-grid{grid-template-columns:1fr}
  .cta-actions{justify-content:flex-start;flex-wrap:wrap}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:600px){
  .footer-grid{grid-template-columns:1fr}
  .newsletter{flex-direction:column}
  .footer-copy{flex-direction:column;gap:10px}
}


/* ====== Mobile ====== */
@media (max-width: 900px){
  .hero-grid{grid-template-columns:1fr}
}
@media (max-width: 760px){
  .nav{position:fixed;inset:60px 0 auto 0;background:#fff;border-bottom:1px solid var(--line);
       padding:12px 20px;display:none;flex-direction:column;gap:6px}
  .nav.open{display:flex}
  .nav-toggle{display:block}
  .footer-grid{grid-template-columns:1fr}
}
/* Logo */
.brand .logo {
  height: 40px;
  display: block;
  transition: transform .35s ease, filter .35s ease;
}
.brand:hover .logo {
  transform: scale(1.05) rotate(-2deg);
  filter: brightness(1.1) saturate(1.2);
}





/* ===== Auth ===== */
.auth-bg{background:linear-gradient(180deg,#0f172a 0%, #111827 100%)}
.auth-wrap{min-height:70vh;display:grid;place-items:center}
.auth-card{
  width:100%;max-width:980px;display:grid;grid-template-columns:1.2fr 1fr;gap:0;
  background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;
  box-shadow:0 30px 80px rgba(2,6,23,.25)
}
.auth-card.small{max-width:560px;grid-template-columns:1fr}
.auth-side{
  background: radial-gradient(120% 140% at 0% 0%, #0ea5e9 0%, #0369a1 45%, #0b1220 100%);
  color:#e2e8f0;padding:28px;
}
.auth-logo{height:34px;margin-bottom:10px;filter:brightness(1.1)}
.auth-side h1{margin:6px 0 8px;color:#fff}
.auth-bullets{list-style:none;padding:0;margin:12px 0 0}
.auth-bullets li{margin:6px 0;color:#dbeafe}

.auth-form{padding:28px;background:#fff}
.auth-form form label{display:block;margin-bottom:12px}
.auth-actions{display:flex;align-items:center;gap:12px;justify-content:space-between;margin-top:8px}
.link{color:var(--brand);text-decoration:none}
.link:hover{text-decoration:underline}

@media (max-width:900px){
  .auth-card{grid-template-columns:1fr}
  .auth-side{display:none}
}


/* ===== SECTIONS BASE ===== */
.sec{padding:56px 0}
.sec-title{margin:0 0 6px; font-size:28px; color:#0f172a}
.sec-sub{margin:0 0 22px; color:#475569}
.center{text-align:center}
.mt-14{margin-top:14px}

/* ===== COMO FUNCIONA ===== */
.how-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:14px}
.how-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px}
.how-card .step{
  display:inline-grid; place-items:center; width:32px; height:32px; border-radius:10px;
  background:#e0f2fe; color:#0369a1; font-weight:700; margin-bottom:8px;
}

/* ===== DIFERENCIAIS ===== */
.features{background:#f8fafc}
.feat-grid{display:grid; grid-template-columns:repeat(6,1fr); gap:14px}
.feat{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px}
.feat .ico{font-size:22px; line-height:1; margin-bottom:8px}
.feat h3{margin:0 0 6px; font-size:16px}
.feat p{margin:0; color:#475569; font-size:14px}

/* ===== ESTATÍSTICAS / PROVA SOCIAL ===== */
.stats-grid{display:grid; grid-template-columns:1fr 1fr; gap:20px; align-items:center}
.stats-kpis{display:grid; grid-template-columns:repeat(3,1fr); gap:12px}
.kpi2{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px;text-align:center}
.kpi2 strong{font-size:26px;display:block}
.kpi2 span{color:#475569;font-size:13px}
.testimonial{background:#0f172a; color:#e5e7eb; border-radius:14px; padding:18px; border:1px solid #1f2937}
.testimonial .who{margin-top:8px; color:#93c5fd; font-size:13px}

/* ===== CTA BOXES ===== */
.cta{background:linear-gradient(180deg,#f8fafc,#f1f5f9)}
.cta-box{display:flex; align-items:center; justify-content:space-between; gap:16px}
.cta-copy h2{margin:0 0 6px}
.cta-copy p{margin:0; color:#475569}
.pill-list{list-style:none; padding:0; margin:10px 0 0; display:flex; gap:8px; flex-wrap:wrap}
.pill-list li{background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 10px;font-size:13px;color:#0f172a}

/* ===== BLOG ===== */
.blog .sec-head{display:flex; align-items:center; justify-content:space-between}
.link-more{color:var(--brand); text-decoration:none}
.link-more:hover{text-decoration:underline}
.blog-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:10px}
.post{background:#fff;border:1px solid var(--line); border-radius:14px; padding:16px}
.post h3{margin:0 0 6px; font-size:18px}
.post p{margin:0 0 10px; color:#475569}
.post .link{color:var(--brand); text-decoration:none}
.post .link:hover{text-decoration:underline}

/* ===== BANNER FINAL ===== */
.final-band{background:linear-gradient(90deg,#0f172a,#111827); color:#e5e7eb}
.final-grid{display:flex; align-items:center; justify-content:space-between; gap:16px}
.final-band h2{margin:0 0 6px; color:#fff}
.final-band p{margin:0; color:#cbd5e1}

/* ===== RESPONSIVO ===== */
@media (max-width:1100px){
  .feat-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:900px){
  .how-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:1fr}
  .stats-kpis{grid-template-columns:repeat(3,1fr)}
  .cta-box,.final-grid{flex-direction:column; align-items:flex-start}
}
@media (max-width:700px){
  .feat-grid{grid-template-columns:repeat(2,1fr)}
  .blog-grid{grid-template-columns:1fr}
}
@media (max-width:480px){
  .how-grid{grid-template-columns:1fr}
  .feat-grid{grid-template-columns:1fr}
  .stats-kpis{grid-template-columns:1fr}
}

/* ===== Page Hero ===== */
.page-hero{background:linear-gradient(180deg,#0f172a,#111827); color:#e6f1ff; padding:64px 0 42px}
.page-hero h1{margin:6px 0 8px; color:#fff; font-size:34px}
.page-sub{color:#cfe6ff; max-width:70ch}
.page-hero .hero-ctas{margin-top:12px; display:flex; gap:12px; flex-wrap:wrap}

/* ===== Pillars ===== */
.pillars{display:grid; grid-template-columns:repeat(4,1fr); gap:14px}
.pillar{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px}
.pillar .ico{font-size:22px;margin-bottom:8px}

/* ===== Twocol + notes ===== */
.twocol{display:grid; grid-template-columns:1.4fr .8fr; gap:18px; align-items:start}
.note-card{background:#eef2ff;border:1px solid #c7d2fe;color:#1e293b;border-radius:14px;padding:16px}
.check-list, .dash-list{padding-left:18px}
.check-list li{margin:8px 0; list-style:"✔  "}
.dash-list li{margin:8px 0; list-style:"—  "}

/* ===== Flow ===== */
.flow-steps{display:grid; grid-template-columns:repeat(5,1fr); gap:12px}
.flow-step{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px}
.badge{display:inline-grid;place-items:center;width:28px;height:28px;border-radius:10px;background:#e0f2fe;color:#0369a1;font-weight:700;margin-bottom:6px}

/* ===== Roles ===== */
.roles{display:grid; grid-template-columns:repeat(3,1fr); gap:14px}
.role{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px}

/* ===== FAQ ===== */
.faq .faq-item{background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:10px; padding:10px 14px}
.faq .faq-item summary{cursor:pointer; font-weight:600; outline:none}
.faq .faq-item div{margin-top:8px; color:#475569}

/* Alternância suave de fundo nas seções */
.sec-alt{background:#f8fafc}

/* ===== Responsivo ===== */
@media (max-width:1100px){ .pillars{grid-template-columns:repeat(2,1fr)} .flow-steps{grid-template-columns:repeat(3,1fr)} }
@media (max-width:900px){ .twocol{grid-template-columns:1fr} .roles{grid-template-columns:1fr} }
@media (max-width:640px){ .pillars{grid-template-columns:1fr} .flow-steps{grid-template-columns:1fr} }


/* timeline compacta */
.timeline{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:12px}
.timeline li{display:flex;gap:12px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px}
.t-num{flex:0 0 32px;height:32px;border-radius:10px;background:#e0f2fe;color:#0369a1;display:grid;place-items:center;font-weight:700}
.t-content h3{margin:0 0 4px;font-size:16px}
.t-content p{margin:0;color:#475569}

/* cards de fluxos */
.cards{gap:18px}
.flow-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px}
.flow-card .steps{margin:10px 0 14px;padding-left:18px}
.flow-card .steps li{margin:6px 0}

/* NDA box */
.nda-box{display:grid;grid-template-columns:1.3fr .7fr;gap:18px;align-items:start}

/* status semáforo */
.status-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.status-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px}
.status-card small{display:block;color:#475569}
.dot{display:inline-block;width:10px;height:10px;border-radius:999px;margin-right:6px;vertical-align:middle}
.dot.green{background:#22c55e}.dot.yellow{background:#f59e0b}.dot.red{background:#ef4444}

/* FAQ */
.faq .faq-item{background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:10px;padding:10px 14px}
.faq .faq-item summary{cursor:pointer;font-weight:600}
.faq .faq-item div{margin-top:8px;color:#475569}

/* responsivo */
@media (max-width:1000px){
  .timeline{grid-template-columns:1fr}
  .nda-box{grid-template-columns:1fr}
}
@media (max-width:800px){
  .status-grid{grid-template-columns:1fr}
}
