/* ProspereJá — styles.css */
:root {
  --bg:#080c18; --s1:#0e1525; --s2:#141d30; --s3:#1a2540;
  --bd:#1e2d45; --bd2:#243350;
  --gr:#00e5a0; --gr2:#00c98a;
  --or:#ff6b35; --bl:#4f8ef7; --yl:#ffd166;
  --rd:#ef4444; --pu:#a78bfa;
  --tx:#e2e8f5; --mu:#5a6e8a; --mu2:#8499b8;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body {
  font-family: 'DM Sans', sans-serif;
  background: var(--bg); color: var(--tx);
  min-height: 100vh; overflow-x: hidden;
}
body::after {
  content: ''; position: fixed; inset: 0;
  pointer-events: none; z-index: 0;
  background:
    radial-gradient(ellipse 60% 40% at 15% 10%, rgba(0,229,160,.04), transparent 60%),
    radial-gradient(ellipse 50% 35% at 85% 85%, rgba(79,142,247,.04), transparent 60%);
}

/* ── NAV (FEITO SOB MEDIDA) ── */
nav {
  position: sticky; top: 0; z-index: 999;
  background: rgba(8,12,24,.95); backdrop-filter: blur(24px);
  border-bottom: 1px solid var(--bd);
  height: 64px; width: 100%;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 1.5rem;
}
.logo { 
  font-family: 'Syne', sans-serif; font-weight: 800; font-size: 1.15rem; 
  color: var(--gr); letter-spacing: -.02em; white-space: nowrap; 
  flex-shrink: 0; 
}
.logo span { color: var(--tx); }

.nscroll { 
  display: flex; gap: 1.2rem; align-items: center; 
  margin-left: auto; margin-right: 1.5rem; 
  overflow-x: auto; -webkit-overflow-scrolling: touch;
}
.nscroll::-webkit-scrollbar { display: none; }

.nt {
  background: none; border: none; cursor: pointer;
  color: var(--mu); font-family: 'DM Sans', sans-serif;
  font-size: .8rem; font-weight: 500;
  padding: .5rem; border-radius: 8px;
  transition: all .2s; white-space: nowrap;
  display: flex; align-items: center; gap: .4rem;
  min-height: 44px;
}
.nt i { font-style: normal; font-size: 1.1rem; }
.nt:hover { color: var(--tx); background: var(--s2); }
.nt.on  { color: var(--gr); background: rgba(0,229,160,.08); }

#cur_m { 
  background: var(--s2); border: 1px solid var(--bd2); 
  color: var(--gr); border-radius: 8px; padding: .4rem .6rem; 
  font-family: 'Syne', sans-serif; font-weight: 700; font-size: .8rem;
  cursor: pointer; outline: none; flex-shrink: 0;
}

/* ── SECTIONS ── */
.sec { display: none; padding: 2rem 1.5rem; max-width: 1140px; margin: 0 auto; position: relative; z-index: 1; animation: fu .3s ease; }
.sec.on { display: block; }
@keyframes fu { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }

.sa { display: flex; align-items: center; gap: .8rem; margin-bottom: 2rem; }
.sa h2 { font-family: 'Syne', sans-serif; font-size: 1.7rem; font-weight: 800; letter-spacing: -.02em; }

/* ── CARDS & FORMS ── */
.card { background: var(--s2); border: 1px solid var(--bd); border-radius: 16px; padding: 1.5rem; margin-bottom: 1.5rem; }
.ch { font-family: 'Syne', sans-serif; font-size: 1rem; font-weight: 700; margin-bottom: 1.25rem; color: var(--tx); border-left: 3px solid var(--gr); padding-left: .75rem; }

.fg { margin-bottom: 1rem; }
.fg label { display: block; font-size: .7rem; font-weight: 700; color: var(--mu); margin-bottom: .4rem; text-transform: uppercase; letter-spacing: .05em; }
.fg input, .fg select {
  width: 100%; background: var(--s1); border: 1px solid var(--bd);
  border-radius: 10px; color: var(--tx); padding: .75rem 1rem;
  font-family: 'DM Sans', sans-serif; font-size: .9rem; transition: all .2s;
}
.fg input:focus { border-color: var(--gr); background: var(--bg); outline: none; }

/* ── BUTTONS ── */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: .5rem; border: none; cursor: pointer; font-family: 'DM Sans', sans-serif; font-weight: 600; border-radius: 10px; transition: all .2s; }
.bp  { background: var(--gr); color: #080c18; padding: .8rem 1.5rem; font-size: .9rem; }
.bp:hover { background: var(--gr2); transform: translateY(-1px); box-shadow: 0 8px 24px rgba(0,229,160,.3); }
.bs  { background: var(--s3); border: 1px solid var(--bd); color: var(--mu2); font-size: .75rem; padding: .4rem .8rem; }
.bs.del:hover { border-color: var(--rd); color: var(--rd); }
.bfull { width: 100%; }

/* ── RENDAS GRID (OUTRAS RENDAS) ── */
.renda-row {
  display: grid; grid-template-columns: 1fr 100px 44px; gap: .75rem;
  align-items: center; background: var(--s3); border-radius: 12px;
  padding: .75rem 1rem; margin-bottom: .75rem; border: 1px solid var(--bd2);
}
.renda-row input {
  background: transparent; border: none; color: var(--tx);
  font-family: 'DM Sans', sans-serif; font-size: .95rem; width: 100%;
  padding: .25rem 0;
}
.renda-row input:focus { outline: none; border-bottom: 1px solid var(--gr); }
.renda-row .v-val { font-weight: 700; color: var(--bl); text-align: right; }

.ass-summary { 
  display: flex; justify-content: space-between; align-items: center; 
  padding: 1rem 1.25rem; background: rgba(0,229,160,.05); 
  border: 1px solid rgba(0,229,160,.15); border-radius: 12px;
}
.ass-summary b { font-family: 'Syne', sans-serif; font-size: 1.2rem; color: var(--gr); }

/* ── RESPONSIVE ── */
@media (max-width: 768px) {
  nav { padding: 0 1rem; gap: .5rem; }
  .logo { font-size: 1rem; margin-right: .5rem; }
  .nscroll { 
    gap: 1.2rem; /* REQUISITO: gap 1.2rem */
    margin-right: 1.5rem; 
  }
  .nt span { display: none; }
  .nt i { font-size: 1.35rem; }
  
  .sec { padding: 1.5rem 1rem; }
  .sa h2 { font-size: 1.4rem; }
  
  /* OUTRAS RENDAS MOBILE ONE-LINE */
  .renda-row { 
    grid-template-columns: 1fr 90px 48px; gap: .6rem; padding: .75rem; 
  }
  .renda-row input { font-size: 0.85rem !important; }
  .renda-row .btn.del { width: 48px; height: 44px; font-size: 1.2rem; }
  
  .btn-add-wrap { display: flex; justify-content: center; margin: 1.5rem 0; }
  .btn-add-wrap .btn { width: 90% !important; height: 50px; } /* REQUISITO: width 90% centralizado */
}

/* ── KPI GRID ── */
.kpi-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1rem; margin-bottom: 2rem; }
.kpi { background: var(--s1); border: 1px solid var(--bd); border-radius: 16px; padding: 1.25rem; }
.kv { font-family: 'Syne', sans-serif; font-size: 1.8rem; font-weight: 800; }
.kv.g { color: var(--gr); } .kv.r { color: var(--rd); } .kv.o { color: var(--or); }

/* ── UTILS ── */
.flex { display: flex; } .aic { align-items: center; } .jb { justify-content: space-between; }
.mt1 { margin-top: .5rem; } .mt2 { margin-top: 1rem; }
.mb1 { margin-bottom: .5rem; } .mb2 { margin-bottom: 1rem; }
.ts { font-size: .75rem; } .tm { color: var(--mu2); }
