/* ========================================================================
   Cálculo Previdenciário — design "dossiê jurídico-financeiro"
   Fontes auto-hospedadas (sem CDN). Paleta papel/tinta/bronze.
   ===================================================================== */
@font-face{font-family:"Fraunces";src:url("fonts/fraunces-400.woff2") format("woff2");font-weight:400;font-display:swap}
@font-face{font-family:"Fraunces";src:url("fonts/fraunces-600.woff2") format("woff2");font-weight:600;font-display:swap}
@font-face{font-family:"Plex";src:url("fonts/plexsans-400.woff2") format("woff2");font-weight:400;font-display:swap}
@font-face{font-family:"Plex";src:url("fonts/plexsans-500.woff2") format("woff2");font-weight:500;font-display:swap}
@font-face{font-family:"Plex";src:url("fonts/plexsans-600.woff2") format("woff2");font-weight:600;font-display:swap}
@font-face{font-family:"PlexMono";src:url("fonts/plexmono-500.woff2") format("woff2");font-weight:500;font-display:swap}

:root{
  --paper:#F4F0E8; --paper-2:#FBF9F4; --card:#FFFFFF;
  --ink:#19282E; --ink-soft:#5A6A70; --ink-mute:#8A979B;
  --line:#E6DECF; --line-2:#EFE9DC;
  --navy:#15303B; --navy-2:#1E4150;
  --bronze:#9A6B3F; --bronze-2:#B98A52; --bronze-wash:#F2E7D6;
  --green:#2C7A4B; --green-wash:#E6F1E8;
  --amber:#A9772A; --amber-wash:#F6ECD7;
  --red:#9F3B2D; --red-wash:#F3E2DD;
  --shadow:0 1px 2px rgba(25,40,46,.04),0 8px 24px -12px rgba(25,40,46,.18);
  --radius:14px;
  --serif:"Fraunces",Georgia,serif;
  --sans:"Plex","Segoe UI",system-ui,sans-serif;
  --mono:"PlexMono","SF Mono",ui-monospace,monospace;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  font-family:var(--sans);color:var(--ink);background:var(--paper);
  font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;
  background-image:radial-gradient(circle at 12% 0%,rgba(154,107,63,.05),transparent 38%),
                   radial-gradient(circle at 100% 100%,rgba(21,48,59,.05),transparent 42%);
}
.hidden{display:none!important}
.serif{font-family:var(--serif);font-weight:600;letter-spacing:-.01em}
.muted{color:var(--ink-soft);font-size:.875rem}
.erro{color:var(--red);font-size:.84rem;min-height:1em;margin:.2rem 0 0}
em{font-style:italic;font-family:var(--serif)}

/* ---------- Botões ---------- */
.btn{font:inherit;font-weight:500;cursor:pointer;border:1px solid transparent;border-radius:9px;
  padding:.6rem 1.1rem;display:inline-flex;align-items:center;justify-content:center;gap:.4rem;
  text-decoration:none;transition:transform .08s ease,background .15s,box-shadow .15s;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn--solid{background:var(--navy);color:#fff}
.btn--solid:hover{background:var(--navy-2)}
.btn--bronze{background:var(--bronze);color:#fff}
.btn--bronze:hover{background:var(--bronze-2)}
.btn--ghost{background:transparent;border-color:var(--line);color:var(--ink-soft)}
.btn--ghost:hover{background:var(--paper-2);color:var(--ink)}
.btn--ghost.danger{color:var(--red);border-color:#E7CFC9}
.btn--link{background:none;border:none;color:var(--bronze);padding:.4rem 0;font-weight:600}
.btn--link:hover{color:var(--bronze-2)}
.btn--block{width:100%}

/* ---------- Marca ---------- */
.brand{display:flex;align-items:center;gap:.7rem}
.brand__mark{display:grid;place-items:center;width:42px;height:42px;border-radius:11px;
  background:linear-gradient(150deg,var(--navy),var(--navy-2));color:var(--bronze-2);
  font-family:var(--serif);font-weight:600;font-size:1.05rem;letter-spacing:.02em;
  box-shadow:inset 0 0 0 1px rgba(185,138,82,.35)}
.brand__name{font-family:var(--serif);font-weight:600;font-size:1.15rem;line-height:1.05;color:var(--ink)}
.brand__name em{color:var(--bronze)}
.brand--sm .brand__mark{width:34px;height:34px;border-radius:9px;font-size:.85rem}
.brand--sm .brand__name{font-size:1rem}

/* ---------- Campos ---------- */
.field{display:block;margin:.55rem 0}
.field>span{display:block;font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;
  color:var(--ink-soft);margin-bottom:.3rem;font-weight:600}
input,select,textarea{width:100%;padding:.6rem .7rem;border:1px solid var(--line);border-radius:9px;
  font:inherit;background:var(--paper-2);color:var(--ink);transition:border .15s,box-shadow .15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--bronze);
  box-shadow:0 0 0 3px rgba(154,107,63,.14);background:#fff}

/* ========================== LOGIN ========================== */
.auth{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}
.auth__panel{display:flex;flex-direction:column;justify-content:center;padding:clamp(2rem,6vw,5rem);background:var(--paper-2)}
.auth__panel .brand{margin-bottom:2.4rem}
.auth__form{max-width:360px;width:100%}
.auth__form h1{font-family:var(--serif);font-weight:600;font-size:1.7rem;margin:0 0 .2rem}
.auth__form .btn{margin-top:.8rem}
.auth__aside{position:relative;background:linear-gradient(150deg,var(--navy),#0E2229);color:#EFE7D8;overflow:hidden}
.auth__aside::after{content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 80% 10%,rgba(185,138,82,.22),transparent 45%),
            repeating-linear-gradient(135deg,rgba(255,255,255,.02) 0 2px,transparent 2px 22px)}
.auth__aside-inner{position:relative;z-index:1;padding:clamp(2rem,5vw,4.5rem);height:100%;display:flex;flex-direction:column;justify-content:center}
.auth__aside h2{font-family:var(--serif);font-weight:600;font-size:2rem;line-height:1.15;margin:.6rem 0 1rem;max-width:15ch}
.auth__aside .muted{color:#C9BFAC;max-width:38ch}
.kicker{font-family:var(--mono);font-size:.72rem;letter-spacing:.22em;color:var(--bronze-2);margin:0}

/* ========================== APP SHELL ========================== */
.topbar{display:flex;align-items:center;justify-content:space-between;
  padding:.7rem 1.4rem;background:var(--paper-2);border-bottom:1px solid var(--line)}
.topbar__user{display:flex;align-items:center;gap:.8rem}
.chip{font-size:.8rem;color:var(--ink-soft);background:var(--bronze-wash);
  border:1px solid var(--line);padding:.3rem .7rem;border-radius:999px;font-weight:500}
.shell{display:grid;grid-template-columns:280px 1fr;gap:2rem;
  max-width:1480px;margin:0 auto;padding:1.8rem 2rem 4rem}
.sidebar{position:sticky;top:1.6rem;align-self:start}
.sidebar__label{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;
  color:var(--ink-soft);margin:1.5rem 0 .5rem;font-weight:600}
.clientes{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}
.clientes li{padding:.6rem .75rem;border-radius:9px;cursor:pointer;border:1px solid transparent;
  font-weight:500;color:var(--ink-soft);transition:.12s}
.clientes li:hover{background:var(--paper-2);color:var(--ink)}
.clientes li.ativo{background:#fff;border-color:var(--line);color:var(--ink);
  box-shadow:var(--shadow);position:relative}
.clientes li.ativo::before{content:"";position:absolute;left:0;top:18%;bottom:18%;width:3px;
  background:var(--bronze);border-radius:3px}

/* ---------- Cabeçalho de página ---------- */
.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.2rem}
.page-head h2{font-size:1.7rem;margin:0}
.page-head__acoes{display:flex;gap:.6rem}

/* ---------- Painéis ---------- */
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.3rem;margin-bottom:1.1rem;box-shadow:var(--shadow)}
.panel__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.9rem}
.panel__head h3{margin:0;font-size:1rem;font-weight:600}
.grid{display:grid;gap:.8rem}
.grid--2{grid-template-columns:1fr 1fr}

/* ---------- Importar CNIS ---------- */
.panel--import{background:linear-gradient(135deg,#fff,var(--bronze-wash));border-color:#E7D7BE}
.import{display:flex;align-items:center;gap:1rem}
.import__icon{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;
  background:var(--navy);color:var(--bronze-2);font-size:1.5rem;flex-shrink:0}
.import__txt{display:flex;flex-direction:column;gap:.15rem;flex:1}
.import__txt strong{font-size:1rem}
.import__status{margin:.9rem 0 0;padding:.7rem .9rem;border-radius:9px;font-size:.86rem;
  background:var(--paper-2);border:1px solid var(--line)}
.import__status.ok{background:var(--green-wash);border-color:#CBE3D2;color:#1E5A38}
.import__status.bad{background:var(--red-wash);border-color:#E7CFC9;color:var(--red)}
.import__status.load{background:var(--bronze-wash)}

.divider{display:flex;align-items:center;text-align:center;color:var(--ink-soft);
  font-size:.78rem;letter-spacing:.04em;margin:1.2rem 0}
.divider::before,.divider::after{content:"";flex:1;height:1px;background:var(--line)}
.divider span{padding:0 1rem;text-transform:uppercase}

/* ---------- Tabela de vínculos ---------- */
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:10px}
.vtable{width:100%;border-collapse:collapse;font-size:.86rem}
.vtable th{background:var(--paper);text-align:left;font-size:.72rem;text-transform:uppercase;
  letter-spacing:.05em;color:var(--ink-soft);padding:.55rem .6rem;font-weight:600;border-bottom:1px solid var(--line)}
.vtable td{padding:.25rem .4rem;border-bottom:1px solid var(--line-2);vertical-align:middle}
.vtable tr:last-child td{border-bottom:none}
.vtable input,.vtable select{border:1px solid transparent;background:transparent;padding:.4rem .45rem;border-radius:7px}
.vtable input:focus,.vtable select:focus{background:#fff;border-color:var(--bronze)}
.vtable .center{text-align:center}
.vtable .v-del{color:var(--red);background:none;border:none;cursor:pointer;font-size:1rem;line-height:1;padding:.2rem .4rem}
.pill{font-size:.74rem;font-weight:600;padding:.25rem .7rem;border-radius:999px}
.pill--bronze{background:var(--bronze-wash);color:var(--bronze);border:1px solid #E7D7BE}

.form-foot{display:flex;align-items:center;gap:1rem;margin-top:.4rem}

/* ========================== RESULTADO ========================== */
.kpis{display:grid;grid-template-columns:repeat(5,1fr);gap:.8rem;margin-bottom:1.1rem}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:1rem;box-shadow:var(--shadow)}
.kpi__label{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);font-weight:600}
.kpi__value{font-family:var(--mono);font-weight:500;font-size:1.18rem;color:var(--navy);margin-top:.35rem;line-height:1.1}
.kpi__value small{font-size:.72rem;color:var(--ink-soft);font-family:var(--sans)}
.kpi--bronze{background:linear-gradient(150deg,#fff,var(--bronze-wash));border-color:#E7D7BE}
.kpi--bronze .kpi__value{color:var(--bronze)}

/* ---------- Quadro comparativo ---------- */
.regras{display:flex;flex-direction:column;gap:.7rem}
.regra{display:grid;grid-template-columns:1fr auto;gap:.5rem 1rem;align-items:start;
  border:1px solid var(--line);border-left:4px solid var(--ink-mute);border-radius:11px;
  padding:.9rem 1.1rem;background:var(--paper-2)}
.regra--sim{border-left-color:var(--green);background:linear-gradient(120deg,var(--green-wash),#fff 60%)}
.regra--nao{border-left-color:var(--ink-mute)}
.regra__top{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.regra__nome{font-family:var(--serif);font-weight:600;font-size:1.05rem}
.regra__tag{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;
  padding:.2rem .55rem;border-radius:999px}
.regra--sim .regra__tag{background:var(--green);color:#fff}
.regra--nao .regra__tag{background:#EDE7DA;color:var(--ink-soft)}
.regra__det{font-size:.84rem;color:var(--ink-soft);margin-top:.35rem;max-width:64ch}
.regra__premissa{font-size:.74rem;color:var(--amber);margin-top:.3rem;font-weight:500}
.regra__right{text-align:right;min-width:130px}
.regra__rmi{font-family:var(--mono);font-weight:500;font-size:1.3rem;color:var(--navy)}
.regra__rmi small{display:block;font-family:var(--sans);font-size:.68rem;color:var(--ink-soft);font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.regra__data{font-family:var(--mono);font-size:.9rem;color:var(--ink)}
.regra__data small{display:block;font-family:var(--sans);font-size:.68rem;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.05em}

/* ---------- Planejamento ---------- */
.plan-intro{margin:-.4rem 0 .8rem}
.plan{display:flex;flex-direction:column;gap:.9rem}
.plan-cenario{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--paper-2)}
.plan-cenario__head{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.8rem 1rem;background:linear-gradient(120deg,#fff,var(--bronze-wash));border-bottom:1px solid var(--line)}
.plan-cenario__head h4{margin:0;font-family:var(--serif);font-weight:600;font-size:1.05rem}
.pill{font-size:.74rem;font-weight:600;padding:.25rem .7rem;border-radius:999px;background:#EDE7DA;color:var(--ink-soft)}
.ptable{width:100%;border-collapse:collapse;font-size:.85rem}
.ptable th{text-align:left;font-size:.68rem;text-transform:uppercase;letter-spacing:.05em;
  color:var(--ink-soft);font-weight:600;padding:.5rem 1rem;background:var(--paper)}
.ptable td{padding:.5rem 1rem;border-top:1px solid var(--line-2)}
.ptable .mono{font-family:var(--mono);font-size:.86rem;color:var(--navy)}
.ptable .mono.dim{color:var(--ink-soft)}
.ptag{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;
  padding:.1rem .4rem;border-radius:5px;margin-left:.35rem;vertical-align:middle}
.ptag--cedo{background:var(--green-wash);color:#1E5A38}
.ptag--valor{background:var(--bronze-wash);color:var(--bronze)}
.plan-aviso{font-size:.76rem;color:var(--ink-soft);font-style:italic;
  background:var(--amber-wash);border:1px solid #E8D5AE;border-radius:9px;padding:.7rem .9rem;margin:.2rem 0 0}

/* ---------- Vazio ---------- */
.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;color:var(--ink-soft);padding:5rem 1rem;gap:1rem}
.empty__mark{width:64px;height:64px;border-radius:16px;display:grid;place-items:center;
  font-family:var(--serif);font-size:1.4rem;color:var(--bronze);background:var(--bronze-wash);border:1px solid #E7D7BE}

/* ========================== MODAL CNIS ========================== */
.modal{position:fixed;inset:0;background:rgba(21,40,46,.5);backdrop-filter:blur(3px);
  display:grid;place-items:center;z-index:50;padding:1.5rem}
.modal__box{background:var(--paper-2);border-radius:16px;width:min(900px,100%);max-height:88vh;
  display:flex;flex-direction:column;box-shadow:0 30px 80px -20px rgba(0,0,0,.4);overflow:hidden}
.modal__head{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 1.4rem .4rem}
.modal__head h3{margin:0;font-size:1.25rem}
.modal__sub{padding:0 1.4rem}
.hint{margin:.6rem 1.4rem;padding:.7rem .9rem;background:var(--amber-wash);border:1px solid #E8D5AE;
  border-radius:9px;font-size:.82rem;color:#6E5418}
.modal__table{margin:0 1.4rem;flex:1;overflow:auto}
.vtable--review td{padding:.45rem .6rem;font-size:.82rem}
.indic{display:inline-block;font-size:.68rem;font-weight:600;padding:.12rem .45rem;border-radius:6px;margin:1px}
.indic--verde{background:var(--green-wash);color:#1E5A38}
.indic--amarelo{background:var(--amber-wash);color:#6E5418}
.indic--vermelho{background:var(--red-wash);color:var(--red)}
.modal__foot{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.1rem 1.4rem;border-top:1px solid var(--line)}

/* ---------- Responsivo ---------- */
@media (max-width:880px){
  .auth{grid-template-columns:1fr}.auth__aside{display:none}
  .shell{grid-template-columns:1fr}.sidebar{position:static}
  .kpis{grid-template-columns:repeat(2,1fr)}
  .grid--2{grid-template-columns:1fr}
}
