/* ============================================================
   Sistema do Cliente — Personal Geronto · Triadeflow TDI
   Design system compartilhado (sidebar + páginas)
   ============================================================ */
:root{
  --petroleo:#003153; --petroleo-2:#01233d; --petroleo-3:#0a3d63;
  --champagne:#8D8444; --champagne-soft:#b6ab5e;
  --ink:#16202b; --muted:#5b6b78; --line:#e3e8ec; --line-2:#eef2f5;
  --bg:#f4f6f8; --card:#ffffff;
  --p1:#b3261e; --p2:#b26a00; --p3:#4a6b2f; --ok:#2e7d52;
  --sidebar-w:252px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;color:var(--ink);background:var(--bg);line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}

/* ---------- Layout shell ---------- */
.app{display:flex;min-height:100vh}
.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--card);border-right:1px solid var(--line);position:fixed;top:0;left:0;height:100vh;display:flex;flex-direction:column;z-index:20}
.main{margin-left:var(--sidebar-w);flex:1;min-width:0}

/* ---------- Sidebar ---------- */
.sb-brand{padding:22px 22px 18px;border-bottom:1px solid var(--line-2)}
.sb-brand img{width:158px;height:auto;display:block}
.sb-brand .sub{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-top:10px}
.sb-nav{padding:16px 12px;flex:1;overflow-y:auto}
.sb-nav .group{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:1.2px;text-transform:uppercase;color:#9aa7b2;padding:8px 12px 6px}
.sb-link{display:flex;align-items:center;gap:12px;padding:10px 13px;border-radius:10px;color:#3a4753;font-size:14.5px;font-weight:500;margin-bottom:3px;transition:background .12s,color .12s;border:1px solid transparent}
.sb-link svg{width:19px;height:19px;flex-shrink:0;stroke:#7a8893;stroke-width:1.9;fill:none}
.sb-link:hover{background:var(--line-2);color:var(--petroleo)}
.sb-link:hover svg{stroke:var(--petroleo)}
.sb-link.active{background:#eaf1f6;color:var(--petroleo);font-weight:600;border-color:#d4e3ee}
.sb-link.active svg{stroke:var(--petroleo)}
.sb-link.active{position:relative}
.sb-link.active::before{content:"";position:absolute;left:-12px;top:9px;bottom:9px;width:3px;border-radius:0 3px 3px 0;background:var(--champagne)}
.sb-foot{padding:14px 16px;border-top:1px solid var(--line-2)}
.client-card{background:linear-gradient(135deg,var(--petroleo),var(--petroleo-2));color:#fff;border-radius:12px;padding:14px}
.client-card .nm{font-weight:700;font-size:14.5px}
.client-card .rl{font-size:12px;color:#aebccb;margin-top:2px}
.client-card .meta{margin-top:10px;display:flex;gap:6px;flex-wrap:wrap}
.client-card .chip{font-family:'JetBrains Mono',monospace;font-size:10.5px;background:rgba(255,255,255,.12);padding:3px 8px;border-radius:6px;color:#dce6ef}

/* ---------- Page header ---------- */
.page-head{background:linear-gradient(135deg,var(--petroleo) 0%,var(--petroleo-2) 100%);color:#fff;padding:34px 40px 30px}
.page-head .tag{display:inline-block;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--champagne-soft);border:1px solid rgba(182,171,94,.4);padding:4px 11px;border-radius:999px;margin-bottom:14px}
.page-head h1{font-size:29px;font-weight:800;letter-spacing:-.4px;line-height:1.12}
.page-head h1 small{display:block;font-size:15.5px;font-weight:500;color:#aebccb;margin-top:7px;letter-spacing:0}
.page-head .meta{margin-top:18px;display:flex;flex-wrap:wrap;gap:7px 20px;font-family:'JetBrains Mono',monospace;font-size:12px;color:#9fb0c0}
.page-head .meta b{color:#cdd9e4;font-weight:500}
.page-head .qa{margin-top:18px;display:flex;flex-wrap:wrap;gap:9px}
.page-head .qa a{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);color:#eaf1f6;font-size:13px;font-weight:500;padding:8px 14px;border-radius:9px;transition:background .12s}
.page-head .qa a:hover{background:rgba(255,255,255,.2)}

/* ---------- Content ---------- */
.content{padding:26px 40px 70px;max-width:1040px}
section.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:24px 26px;margin-bottom:18px}
h2.sec{font-size:12.5px;font-family:'JetBrains Mono',monospace;letter-spacing:1.5px;text-transform:uppercase;color:var(--champagne);margin-bottom:16px;display:flex;align-items:center;gap:10px}
h2.sec .n{display:inline-flex;align-items:center;justify-content:center;width:23px;height:23px;background:var(--petroleo);color:#fff;border-radius:7px;font-size:11.5px;font-weight:700}
h3{font-size:15.5px;font-weight:700;margin:18px 0 7px;color:var(--petroleo)}
h3:first-child{margin-top:0}
p{margin-bottom:9px;font-size:14.5px}
.dl{display:grid;grid-template-columns:auto 1fr;gap:6px 16px;font-size:14.5px}
.dl dt{color:var(--muted);font-weight:500}
.dl dd{font-weight:600}
ul.list{list-style:none;margin:6px 0}
ul.list li{position:relative;padding-left:20px;margin-bottom:7px;font-size:14.5px}
ul.list li::before{content:"";position:absolute;left:2px;top:9px;width:7px;height:7px;background:var(--champagne);border-radius:2px;transform:rotate(45deg)}

/* tables */
table{width:100%;border-collapse:collapse;margin:8px 0;font-size:14px}
th,td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--line);vertical-align:top}
th{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.5px;text-transform:uppercase;color:var(--muted)}
td b{color:var(--petroleo)}
.num{font-family:'JetBrains Mono',monospace;font-weight:700;color:var(--petroleo);font-size:16px}

/* stat cards */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px}
.stat{background:#fafbfc;border:1px solid var(--line);border-radius:12px;padding:16px 18px}
.stat .v{font-family:'JetBrains Mono',monospace;font-size:24px;font-weight:700;color:var(--petroleo)}
.stat .l{font-size:12.5px;color:var(--muted);margin-top:3px}

/* pillars timeline */
.pillars{display:grid;gap:12px}
.pillar{display:grid;grid-template-columns:46px 1fr;gap:16px;align-items:start;padding:14px 16px;border:1px solid var(--line);border-radius:12px;background:#fafbfc}
.pillar .step{width:46px;height:46px;border-radius:12px;background:linear-gradient(135deg,var(--petroleo),var(--petroleo-3));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;font-family:'JetBrains Mono',monospace}
.pillar h4{font-size:15.5px;color:var(--petroleo);margin-bottom:3px}
.pillar p{font-size:13.5px;color:var(--muted);margin:0}
.pillar .when{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--champagne);margin-top:5px;text-transform:uppercase;letter-spacing:.5px}

/* problems */
.prob{border-left:4px solid var(--line);padding:12px 16px;margin-bottom:10px;background:#fafbfc;border-radius:0 10px 10px 0}
.prob.p1{border-color:var(--p1)} .prob.p2{border-color:var(--p2)} .prob.p3{border-color:var(--p3)}
.sev{display:inline-block;font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700;padding:2px 8px;border-radius:5px;color:#fff;margin-right:8px}
.sev.p1{background:var(--p1)} .sev.p2{background:var(--p2)} .sev.p3{background:var(--p3)}
.prob h4{display:inline;font-size:15px;color:var(--ink)}
.prob p{margin:8px 0 0;font-size:14px;color:var(--muted)}

/* highlight + warn */
.highlight{background:linear-gradient(135deg,#fff8e6,#fffdf5);border:1px solid #e8dca8;border-radius:12px;padding:17px 19px;margin-top:10px;font-size:14px}
.highlight strong{color:var(--champagne)}
.warn{background:#fdf3f2;border:1px solid #f0cfcc;border-radius:12px;padding:15px 18px;margin-top:12px;font-size:14px}
.warn b{color:var(--p1)}

/* pills */
.pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.pill{font-size:13px;background:#eef2f5;color:var(--petroleo);padding:6px 13px;border-radius:999px;font-weight:500}

/* steps */
ol.steps{counter-reset:s;list-style:none;margin-top:6px}
ol.steps li{counter-increment:s;position:relative;padding-left:38px;margin-bottom:10px;font-size:14.5px}
ol.steps li::before{counter-increment:none;content:counter(s);position:absolute;left:0;top:-2px;width:26px;height:26px;background:var(--petroleo);color:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;font-family:'JetBrains Mono',monospace}

/* ---------- Checklist (onboarding) ---------- */
.progress-wrap{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px 24px;margin-bottom:18px;position:sticky;top:14px;z-index:5}
.progress-wrap .row{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.progress-wrap .row b{font-size:15px;color:var(--petroleo)}
.progress-wrap .pct{font-family:'JetBrains Mono',monospace;font-weight:700;color:var(--champagne);font-size:15px}
.bar{height:10px;background:var(--line-2);border-radius:999px;overflow:hidden}
.bar span{display:block;height:100%;background:linear-gradient(90deg,var(--petroleo),var(--champagne));width:0;transition:width .35s ease}
.reset-btn{font-size:12px;color:var(--muted);background:none;border:1px solid var(--line);border-radius:7px;padding:5px 10px;cursor:pointer;font-family:'Inter',sans-serif}
.reset-btn:hover{color:var(--p1);border-color:#f0cfcc}
/* timer */
.timer{display:flex;align-items:center;gap:16px;flex-wrap:wrap;padding-bottom:14px;margin-bottom:14px;border-bottom:1px solid var(--line-2)}
.timer .clock{font-family:'JetBrains Mono',monospace;font-size:36px;font-weight:700;color:var(--petroleo);letter-spacing:1px;line-height:1;font-variant-numeric:tabular-nums}
.timer .clock.over{color:var(--p1)}
.timer .ref{font-size:12px;color:var(--muted);margin-top:5px;font-family:'JetBrains Mono',monospace}
.timer .btns{display:flex;gap:8px;margin-left:auto}
.timer button{font-family:'Inter',sans-serif;font-size:13px;font-weight:600;padding:9px 18px;border-radius:9px;border:1px solid var(--line);background:#fff;cursor:pointer;transition:all .12s;color:var(--ink)}
.timer .start{background:var(--petroleo);color:#fff;border-color:var(--petroleo)}
.timer .start:hover{background:var(--petroleo-2)}
.timer .start.running{background:var(--p2);border-color:var(--p2)}
.timer .ghost:hover{border-color:var(--petroleo);color:var(--petroleo)}
.checkgroup{margin-bottom:8px}
.check{display:flex;align-items:flex-start;gap:12px;padding:11px 14px;border:1px solid var(--line);border-radius:11px;margin-bottom:8px;cursor:pointer;transition:background .12s,border-color .12s;background:#fff}
.check:hover{background:#fafbfc}
.check input{appearance:none;-webkit-appearance:none;width:21px;height:21px;border:2px solid #c3ccd4;border-radius:6px;flex-shrink:0;margin-top:1px;cursor:pointer;position:relative;transition:all .12s}
.check input:checked{background:var(--petroleo);border-color:var(--petroleo)}
.check input:checked::after{content:"";position:absolute;left:6px;top:2px;width:5px;height:10px;border:solid #fff;border-width:0 2.5px 2.5px 0;transform:rotate(45deg)}
.check .tx{font-size:14.5px}
.check .tx small{display:block;color:var(--muted);font-size:12.5px;margin-top:2px}
.check.done .tx{color:var(--muted);text-decoration:line-through;text-decoration-color:#c3ccd4}
.check.done .tx small{text-decoration:none}

footer.sysfoot{padding:24px 40px;color:var(--muted);font-size:12.5px;font-family:'JetBrains Mono',monospace;border-top:1px solid var(--line)}

@media(max-width:860px){
  :root{--sidebar-w:0px}
  .sidebar{transform:translateX(-100%)}
  .main{margin-left:0}
  .content,.page-head{padding-left:20px;padding-right:20px}
  .pillar{grid-template-columns:40px 1fr}
}
