:root{
  /* Identidade mais clara e "enterprise" */
  --bg0:#f8fafc;          /* slate-50 */
  --bg1:#eef2ff;          /* indigo-50 */
  --card:#ffffff;
  --stroke: rgba(15,23,42,.10);
  --text:#0f172a;
  --muted: rgba(15,23,42,.70);
  --brand:#1e3a8a;        /* azul médio */
  --accent:#06b6d4;       /* ciano */

  /* Forma (menos arredondado) */
  --r-lg: 14px;
  --r-md: 12px;
  --r-sm: 10px;
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
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(1100px 520px at 20% 10%, rgba(6,182,212,.10), transparent 60%),
    radial-gradient(900px 520px at 80% 0%, rgba(30,58,138,.10), transparent 55%),
    linear-gradient(180deg, var(--bg0), var(--bg1));
  position: relative;
}

/* Fundo sutil estilo “grid/engineering” */
body::before{
  content:"";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -1;
  opacity: .55;
  background-image:
    linear-gradient(to right, rgba(15,23,42,.06) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(15,23,42,.06) 1px, transparent 1px);
  background-size: 44px 44px;
  transform: translate3d(0,0,0);
  animation: grid-pan 18s linear infinite;
}
@keyframes grid-pan{
  from{ background-position: 0 0, 0 0; }
  to  { background-position: 44px 22px, 22px 44px; }
}

@media (prefers-reduced-motion: reduce){
  body::before{ animation:none; }
}

a{ color: inherit; }
.container{
  width:min(1080px, calc(100% - 40px));
  margin:0 auto;
}

.topbar{
  padding:14px 0;
  position:sticky;
  top:0;
  backdrop-filter: blur(10px);
  background: rgba(248,250,252,.75);
  border-bottom:1px solid var(--stroke);
}

.brand{
  display:flex; align-items:center; justify-content:space-between; gap:14px;
}
.brand .logo{
  display:flex; align-items:center; gap:10px;
  font-weight:900;
  letter-spacing:-.02em;
}
.badge{
  font-size:12px;
  color: var(--muted);
  border:1px solid var(--stroke);
  padding:6px 10px;
  border-radius:999px;
  background: rgba(255,255,255,.65);
}

.hero{ padding: 38px 0 18px; }
.hero-grid{
  display:grid;
  grid-template-columns: 1.25fr .75fr;
  gap: 14px;
}
@media (max-width: 900px){
  .hero-grid{ grid-template-columns: 1fr; }
}

.h1{
  font-size: clamp(28px, 4.2vw, 44px);
  line-height:1.08;
  margin: 0 0 10px;
  font-weight: 950;
  letter-spacing:-.03em;
}
.lead{
  color: var(--muted);
  font-size: 16px;
  line-height: 1.6;
  margin: 0 0 16px;
}

.cta{ display:flex; gap:10px; flex-wrap:wrap; }

/* CTA em duas colunas */
.cta-grid{ display:grid; grid-template-columns: 1fr 1fr; gap:10px; }
.span-2{ grid-column: 1 / -1; }

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding: 12px 14px;
  border-radius: var(--r-sm);
  border:1px solid var(--stroke);
  text-decoration:none;
  background: rgba(255,255,255,.85);
  color: var(--text);
  font-weight: 850;
}
.btn.primary{
  border-color: rgba(30,58,138,.25);
  background: linear-gradient(90deg, rgba(30,58,138,.10), rgba(6,182,212,.10));
}
.btn:hover{ transform: translateY(-1px); transition: .15s ease; }

.card{
  border: 1px solid var(--stroke);
  background: rgba(255,255,255,.90);
  border-radius: var(--r-lg);
  padding: 16px;
  box-shadow: 0 8px 28px rgba(15,23,42,.06);
}

.kpis{ display:grid; grid-template-columns: 1fr 1fr; gap:10px; }
.kpi{
  border: 1px solid var(--stroke);
  border-radius: var(--r-md);
  padding: 12px;
  background: rgba(248,250,252,.90);
}
.kpi .t{ font-size:12px; color: var(--muted); }
.kpi .v{ font-size:18px; font-weight:950; }

.section{ padding: 16px 0; }
.section h2{ margin: 0 0 10px; font-size: 18px; letter-spacing:-.01em; }
.grid3{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
@media (max-width: 900px){ .grid3{ grid-template-columns: 1fr; } }

.item-title{ font-weight: 950; margin:0 0 6px; }
.item-text{ margin:0; color: var(--muted); font-size: 14px; line-height:1.6; }

.pills{ display:flex; flex-wrap:wrap; gap:8px; }
.pill{
  font-size: 12px;
  color: rgba(15,23,42,.85);
  padding: 7px 10px;
  border-radius: 999px;
  border:1px solid var(--stroke);
  background: rgba(255,255,255,.85);
}

.footer{
  padding: 18px 0 46px;
  color: var(--muted);
  font-size: 13px;
  border-top:1px solid var(--stroke);
  margin-top: 18px;
  background: rgba(248,250,252,.92); /* evita “duas cores” no fim */
}
.small{ font-size: 12px; color: var(--muted); }
.hr{ height:1px; background: var(--stroke); border:0; margin:14px 0; }

/* Avatar */
.avatar-row{ display:flex; gap:14px; align-items:center; margin: 6px 0 14px; }
.avatar{
  width: 76px; height: 76px;
  border-radius: 14px; /* menos arredondado */
  object-fit: cover;
  border: 1px solid var(--stroke);
  box-shadow: 0 10px 24px rgba(15,23,42,.10);
}
@media (max-width: 520px){
  .avatar{ width:64px; height:64px; border-radius:12px; }
}

/* Linha digitando */
.type-line{
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size: 13px;
  color: rgba(15,23,42,.75);
  background: rgba(255,255,255,.75);
  border: 1px solid var(--stroke);
  border-radius: 999px;
  padding: 8px 12px;
  display: inline-flex;
  gap: 8px;
  align-items:center;
}
.type-caret{
  display:inline-block;
  width: 8px;
  height: 16px;
  border-right: 2px solid rgba(30,58,138,.85);
  margin-left: 2px;
  animation: caret-blink 1s steps(1) infinite;
}
@keyframes caret-blink{ 50% { opacity: 0; } }
@media (prefers-reduced-motion: reduce){
  .type-caret{ animation:none; }
}

/* Modal do currículo */
.modal-backdrop{
  position: fixed; inset: 0;
  background: rgba(15,23,42,.55);
  display:none;
  align-items: center;
  justify-content: center;
  padding: 18px;
  z-index: 9999;
}
.modal{
  width: min(980px, 100%);
  height: min(80vh, 720px);
  background: rgba(255,255,255,.96);
  border: 1px solid var(--stroke);
  border-radius: var(--r-lg);
  box-shadow: 0 24px 70px rgba(15,23,42,.25);
  display:flex;
  flex-direction: column;
  overflow:hidden;
}
.modal-top{
  display:flex; align-items:center; justify-content:space-between;
  padding: 12px 14px;
  border-bottom:1px solid var(--stroke);
  background: rgba(248,250,252,.92);
}
.modal-title{ font-weight: 950; }
.modal-close{ cursor:pointer; }
.modal-body{ position:relative; flex:1; overflow:auto; }
.modal-iframe{ width:100%; height:100%; border:0; background:#fff; }

.cv-pages{ padding: 12px; }
.cv-page{
  width: 100%;
  height: auto;
  display:block;
  border: 1px solid var(--stroke);
  border-radius: 12px;
  background:#fff;
  margin: 0 0 12px;
}

.preloader{
  position:absolute; inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  color: var(--muted);
  background: rgba(255,255,255,.85);
}
.spinner{
  width: 18px; height: 18px;
  border-radius: 50%;
  border: 2px solid rgba(30,58,138,.20);
  border-top-color: rgba(30,58,138,.85);
  animation: spin .8s linear infinite;
}
@keyframes spin{ to { transform: rotate(360deg); } }

/* Layout “cartão” */
.hero-center{ padding-top: 26px; }
.hero-card{ max-width: 860px; margin: 0 auto; }
.grid2{ display:grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.list{ margin: 10px 0 0; padding-left: 18px; color: var(--muted); line-height: 1.65; }

.btn.big{ padding: 12px 14px; min-height: 44px; }

/* Ajustes de responsividade para celular */
@media (max-width: 520px){
  .container{ width: calc(100% - 28px); }
  .badge{ display:none; }
  .topbar{ padding: 10px 0; }
  .btn{ padding: 11px 12px; border-radius: 10px; }
  .cta{ gap:8px; }
  .kpis{ grid-template-columns: 1fr; }
  .hero{ padding-top: 18px; }
  .grid2{ grid-template-columns: 1fr; }
  .cta-grid{ grid-template-columns: 1fr 1fr; }
}
