/* ============================================================
   Concilia Seg — Design System (v1)
   Fundamento: design-canon (menos-é-mais, sistêmico, AA, calma).
   ============================================================ */

/* ---- Fontes self-host (subset latin, cobre pt-BR) ---- */
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/inter-400.woff2') format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/inter-500.woff2') format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/inter-600.woff2') format('woff2');}
@font-face{font-family:'Plus Jakarta Sans';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/plus-jakarta-sans-600.woff2') format('woff2');}
@font-face{font-family:'Plus Jakarta Sans';font-style:normal;font-weight:700;font-display:swap;src:url('/assets/fonts/plus-jakarta-sans-700.woff2') format('woff2');}
@font-face{font-family:'Plus Jakarta Sans';font-style:normal;font-weight:800;font-display:swap;src:url('/assets/fonts/plus-jakarta-sans-800.woff2') format('woff2');}

/* ---- Tokens ---- */
:root{
  --teal-700:#0A5E66; --teal-600:#0E7C86; --teal-500:#149AA6; --teal-100:#CFEAEC; --teal-50:#ECF7F8;
  --ink:#0B1F2A; --amber-500:#E8A23D;
  --slate-900:#0F172A; --slate-700:#334155; --slate-500:#64748B; --slate-400:#94A3B8;
  --slate-300:#CBD5E1; --slate-200:#E2E8F0; --slate-100:#F1F5F9; --slate-50:#F8FAFC; --white:#FFFFFF;
  --success:#16A34A; --error:#DC2626;
  --font-display:'Plus Jakarta Sans',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --font-body:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --radius:12px; --radius-sm:8px; --radius-lg:20px;
  --shadow-sm:0 1px 2px rgba(11,31,42,.06),0 1px 3px rgba(11,31,42,.05);
  --shadow:0 1px 2px rgba(11,31,42,.06),0 12px 32px rgba(11,31,42,.07);
  --maxw:1120px;
}

/* ---- Reset ---- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);font-size:18px;line-height:1.6;color:var(--slate-700);
  background:var(--white);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img,svg{display:block;max-width:100%;height:auto}
a{color:var(--teal-700);text-decoration:none}
a:hover{color:var(--teal-600)}
h1,h2,h3,h4{font-family:var(--font-display);color:var(--ink);line-height:1.15;letter-spacing:-.02em;font-weight:700}
h1{font-size:clamp(2.1rem,5vw,3.4rem);font-weight:800}
h2{font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:700}
h3{font-size:1.3rem;font-weight:700}
p{margin:0}
:focus-visible{outline:3px solid var(--teal-500);outline-offset:3px;border-radius:4px}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}

/* ---- Layout ---- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:24px}
.section{padding-block:clamp(56px,9vw,104px)}
.section--tint{background:var(--teal-50)}
.section--ink{background:var(--ink);color:#C7D2D8}
.eyebrow{font-family:var(--font-display);font-weight:700;font-size:.82rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--teal-600)}
.lead{font-size:clamp(1.05rem,2.2vw,1.28rem);color:var(--slate-500);max-width:46ch}

/* ---- Skip link ---- */
.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;padding:12px 18px;
  border-radius:0 0 var(--radius) 0;z-index:100;font-weight:600}
.skip-link:focus{left:0}

/* ---- Header ---- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.85);
  backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--slate-200)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;
  min-height:68px;gap:24px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:800;
  font-size:1.18rem;color:var(--ink);letter-spacing:-.02em}
.brand svg,.brand img{width:34px;height:34px}
.brand .seg{color:var(--teal-600)}
.nav{display:flex;align-items:center;gap:28px}
.nav a{color:var(--slate-700);font-weight:500;font-size:.98rem}
.nav a:hover{color:var(--ink)}
@media (max-width:680px){.nav .nav-link{display:none}}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--font-display);font-weight:700;font-size:1rem;line-height:1;
  padding:15px 26px;border-radius:var(--radius);border:1.5px solid transparent;cursor:pointer;
  transition:transform .14s ease,box-shadow .2s ease,background .2s ease,border-color .2s ease;min-height:48px}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--teal-600);color:#fff;box-shadow:0 6px 18px rgba(14,124,134,.28)}
.btn--primary:hover{background:var(--teal-700);color:#fff;box-shadow:0 10px 26px rgba(14,124,134,.34)}
.btn--ghost{background:#fff;color:var(--ink);border-color:var(--slate-300)}
.btn--ghost:hover{border-color:var(--teal-500);color:var(--teal-700)}
.btn--lg{padding:18px 32px;font-size:1.06rem}
.btn-row{display:flex;flex-wrap:wrap;gap:14px}

/* ---- Hero ---- */
.hero{position:relative;overflow:hidden;background:
  radial-gradient(1100px 520px at 88% -8%,var(--teal-50),transparent 62%),
  radial-gradient(800px 420px at -6% 12%,#F2FAFB,transparent 60%),var(--white)}
.hero .container{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;
  padding-block:clamp(56px,8vw,96px)}
.hero h1{margin:18px 0 0}
.hero .lead{margin-top:22px;max-width:50ch}
.hero .btn-row{margin-top:34px}
.hero .trust{margin-top:22px;font-size:.92rem;color:var(--slate-500)}
@media (max-width:860px){.hero .container{grid-template-columns:1fr;gap:40px}.hero-art{order:-1}}

/* ---- Hero art (visual abstrato de conciliação) ---- */
.hero-art{position:relative}
.recon-card{background:#fff;border:1px solid var(--slate-200);border-radius:var(--radius-lg);
  box-shadow:var(--shadow);padding:22px 22px 8px}
.recon-card h4{font-family:var(--font-display);font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;
  color:var(--slate-500);font-weight:700;margin-bottom:14px}
.recon-row{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:14px;
  padding:13px 4px;border-top:1px solid var(--slate-100)}
.recon-row .label{font-weight:500;color:var(--slate-700);font-size:.96rem}
.recon-row .val{font-variant-numeric:tabular-nums;font-weight:600;color:var(--ink);font-size:.96rem}
.pill{display:inline-flex;align-items:center;gap:6px;font-size:.78rem;font-weight:700;
  padding:4px 10px;border-radius:999px}
.pill--ok{background:#E7F6ED;color:#15803D}
.pill--diff{background:#FBEFE0;color:#B45309}

/* ---- Grid de features ---- */
.grid{display:grid;gap:22px}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--2{grid-template-columns:repeat(2,1fr)}
@media (max-width:880px){.grid--3{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.grid--3,.grid--2{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid var(--slate-200);border-radius:var(--radius);padding:26px;
  box-shadow:var(--shadow-sm);transition:transform .18s ease,box-shadow .2s ease,border-color .18s ease}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--teal-100)}
.card .ic{width:46px;height:46px;border-radius:12px;background:var(--teal-50);color:var(--teal-600);
  display:grid;place-items:center;margin-bottom:16px}
.card h3{font-size:1.16rem;margin-bottom:8px}
.card p{font-size:1rem;color:var(--slate-500)}

/* ---- Passos ---- */
.steps{counter-reset:step;display:grid;gap:26px;grid-template-columns:repeat(3,1fr)}
@media (max-width:760px){.steps{grid-template-columns:1fr}}
.step{position:relative;padding-left:64px}
.step::before{counter-increment:step;content:counter(step);position:absolute;left:0;top:-2px;
  width:46px;height:46px;border-radius:12px;background:var(--ink);color:#fff;font-family:var(--font-display);
  font-weight:800;font-size:1.2rem;display:grid;place-items:center}
.step h3{font-size:1.12rem;margin-bottom:6px}
.step p{font-size:.98rem;color:var(--slate-500)}

/* ---- Seção título ---- */
.sec-head{max-width:640px;margin-bottom:48px}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head h2{margin:12px 0 14px}

/* ---- CTA band ---- */
.cta-band{background:linear-gradient(135deg,var(--teal-600),var(--teal-700));color:#fff;
  border-radius:var(--radius-lg);padding:clamp(36px,6vw,64px);text-align:center}
.cta-band h2{color:#fff}
.cta-band p{color:#D6EEF0;margin:14px auto 28px;max-width:48ch}
.cta-band .btn--primary{background:#fff;color:var(--teal-700);box-shadow:0 10px 30px rgba(0,0,0,.18)}
.cta-band .btn--primary:hover{background:#F1FAFB;color:var(--teal-700)}

/* ---- Footer ---- */
.site-footer{background:var(--ink);color:#9FB2BA;padding-block:56px 40px;font-size:.95rem}
.site-footer .container{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
@media (max-width:760px){.site-footer .container{grid-template-columns:1fr}}
.site-footer .brand{color:#fff}.site-footer .brand .seg{color:var(--teal-500)}
.site-footer h5{color:#fff;font-family:var(--font-display);font-size:.82rem;letter-spacing:.06em;
  text-transform:uppercase;margin-bottom:14px;font-weight:700}
.site-footer a{color:#9FB2BA;display:block;padding:5px 0}
.site-footer a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:40px;padding-top:24px;
  display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;font-size:.86rem;color:#74878F}

/* ---- Conteúdo legal (privacidade/termos) ---- */
.legal{max-width:760px;margin-inline:auto}
.legal .updated{color:var(--slate-500);font-size:.92rem;margin-bottom:8px}
.legal h2{font-size:1.5rem;margin:40px 0 12px}
.legal h3{font-size:1.15rem;margin:26px 0 8px}
.legal p,.legal li{color:var(--slate-700);font-size:1.02rem;margin-bottom:12px}
.legal ul,.legal ol{padding-left:22px;margin-bottom:12px}
.legal li{margin-bottom:6px}
.legal a{text-decoration:underline}
.note{background:var(--teal-50);border:1px solid var(--teal-100);border-radius:var(--radius);
  padding:16px 20px;color:var(--slate-700);font-size:.96rem;margin:18px 0}
.page-head{padding-block:clamp(40px,7vw,72px) 0}
