:root{
  --ink:#12231F; --ink-2:#1B302B; --paper:#F5F1E8; --paper-2:#FBF9F3;
  --brass:#BD8B3C; --brass-d:#9C6F28; --line:#E2DCCC; --line-d:rgba(245,241,232,.14);
  --text:#22312D; --muted:#6E7F79; --dim:#9AA8A2;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:"Inter",system-ui,sans-serif;background:var(--paper);color:var(--text);font-size:15px;line-height:1.5}
.mono{font-family:"IBM Plex Mono",monospace;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase}
.dim{color:var(--dim)} .muted{color:var(--muted)}
a{color:inherit;text-decoration:none}
h1,h2{font-family:"Space Grotesk",sans-serif;font-weight:600;letter-spacing:-.01em}

/* ---- shell ---- */
.shell{display:flex;min-height:100vh}
.side{width:236px;flex:none;background:var(--ink);color:var(--paper);display:flex;flex-direction:column;padding:26px 20px}
.logo{font-family:"Space Grotesk";font-weight:700;font-size:1.15rem}
.logo small{display:block;font-family:"IBM Plex Mono";font-weight:400;font-size:.56rem;letter-spacing:.2em;color:var(--dim);text-transform:uppercase;margin-top:3px}
.logo-lg{font-size:1.5rem;margin-bottom:6px}
.nav{display:flex;flex-direction:column;gap:2px;margin-top:38px;flex:1}
.nav a{padding:10px 12px;border-radius:5px;color:#C4D0CB;font-size:.92rem;transition:.15s}
.nav a:hover{background:var(--ink-2);color:#fff}
.nav a.on{background:var(--ink-2);color:#fff;box-shadow:inset 2px 0 0 var(--brass)}
.side-foot{border-top:1px solid var(--line-d);padding-top:18px}
.who{font-weight:600;font-size:.92rem}
.role-tag{font-family:"IBM Plex Mono";font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--brass);margin:3px 0 12px}
.logout{font-size:.82rem;color:var(--dim)} .logout:hover{color:#fff}

.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:24px 36px;border-bottom:1px solid var(--line);background:var(--paper-2)}
.topbar h1{font-size:1.4rem}
.content{padding:30px 36px;max-width:1180px}
.flash{margin:18px 36px 0;background:#EAF3EE;border:1px solid #BFD8CB;color:#1f5138;padding:12px 16px;border-radius:6px;font-size:.9rem}

@media(max-width:760px){
  .shell{flex-direction:column}
  .side{width:100%;flex-direction:row;align-items:center;justify-content:space-between;padding:14px 18px}
  .nav{flex-direction:row;margin:0;gap:4px}.nav a{padding:7px 10px}
  .side-foot{border:none;padding:0;display:flex;gap:10px;align-items:center}
  .role-tag,.who small{display:none}.who{margin:0;font-size:.8rem}
  .content,.topbar{padding-left:18px;padding-right:18px}.flash{margin-left:18px;margin-right:18px}
}

/* ---- cards & layout ---- */
.grid-2{display:grid;grid-template-columns:1.3fr 1fr;gap:22px;align-items:start}
@media(max-width:900px){.grid-2{grid-template-columns:1fr}}
.stack{display:flex;flex-direction:column;gap:22px}
.card{background:var(--paper-2);border:1px solid var(--line);border-radius:10px;padding:22px 24px;margin-bottom:22px}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.card-head h2{font-size:1.05rem}
.accent-card{box-shadow:inset 3px 0 0 var(--brass)}
.gold-frame{border-color:var(--brass);background:linear-gradient(180deg,#FBF6EA,#FBF9F3)}

/* rows */
.row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 12px;border-radius:7px;border:1px solid transparent;transition:.13s}
a.row:hover{background:#fff;border-color:var(--line)}
.row.static{border-bottom:1px solid var(--line);border-radius:0;padding:13px 2px}
.row.static:last-child{border-bottom:none}
.row-title{font-weight:600;font-size:.95rem}
.row-sub{color:var(--muted);font-size:.82rem;margin-top:2px}
.link{color:var(--brass-d);font-weight:600} .link:hover{text-decoration:underline}
.empty{color:var(--dim);font-size:.9rem;padding:14px 2px;font-style:italic}
.hint{color:var(--muted);font-size:.85rem;margin-top:6px;max-width:70ch}

/* kv */
.kv{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--line);font-size:.92rem}
.kv span{color:var(--muted)} .kv b{font-weight:600}

/* badges */
.badge{font-family:"IBM Plex Mono";font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;padding:4px 9px;border-radius:20px;white-space:nowrap}
.badge-neutral{background:#E8E2D3;color:#5C6F68}
.badge-gold{background:var(--brass);color:#fff}
.badge-essencial{background:#E8E2D3;color:#5C6F68}
.badge-estrategico{background:var(--ink);color:var(--brass)}

/* kpis */
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:22px}
@media(max-width:680px){.kpis{grid-template-columns:1fr}}
.kpi{background:var(--ink);color:var(--paper);border-radius:10px;padding:22px 24px}
.kpi.gold{background:linear-gradient(150deg,var(--ink-2),var(--ink));box-shadow:inset 3px 0 0 var(--brass)}
.kpi-n{font-family:"Space Grotesk";font-weight:600;font-size:2.4rem;line-height:1}
.kpi-l{color:var(--dim);font-size:.82rem;margin-top:6px}

/* table */
.tbl{width:100%;border-collapse:collapse;font-size:.9rem}
.tbl th{text-align:left;font-family:"IBM Plex Mono";font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding:8px 10px;border-bottom:1px solid var(--line)}
.tbl td{padding:12px 10px;border-bottom:1px solid var(--line)}
.tbl tbody tr{cursor:pointer;transition:.12s}
.tbl tbody tr:hover{background:#fff}
.tbl .strong{font-weight:600}
.dot-gold{display:inline-grid;place-items:center;width:22px;height:22px;border-radius:50%;background:var(--brass);color:#fff;font-size:.72rem;font-weight:600}

/* feed */
.feed{display:flex;gap:8px;align-items:baseline;padding:8px 0;border-bottom:1px solid var(--line);font-size:.86rem;flex-wrap:wrap}
.feed:last-child{border:none}
.feed-who{font-weight:600} .feed-act{color:var(--text);flex:1}

/* opportunity */
.opp{display:flex;gap:14px;align-items:flex-start;padding:12px 0;border-bottom:1px solid var(--line)}
.opp:last-child{border:none}

.client-head{display:flex;justify-content:space-between;align-items:flex-end;margin:6px 0 18px}
.big{font-size:1.7rem}

/* doc */
.doc{max-width:760px}
.doc-meta{margin-bottom:10px}
.doc-title{font-size:1.5rem;margin-bottom:18px}
.doc-body{font-family:"Inter";font-size:1rem;line-height:1.7;color:#33433E}
.doc-actions{margin-top:24px;padding-top:18px;border-top:1px solid var(--line);display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.doc-actions .dim{font-size:.82rem}
.back{display:inline-block;margin-top:20px;color:var(--muted);font-size:.88rem}
.back:hover{color:var(--brass-d)}

/* forms */
.form-card{max-width:720px}
label{display:block;font-family:"IBM Plex Mono";font-size:.64rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin:16px 0 6px}
input,select,textarea{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:7px;background:#fff;font-family:"Inter";font-size:.95rem;color:var(--text)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px rgba(189,139,60,.15)}
textarea{resize:vertical;line-height:1.6}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.form-row{grid-template-columns:1fr}}
.form-actions{display:flex;gap:12px;margin-top:22px;flex-wrap:wrap}

/* buttons */
.btn-primary,.btn-ghost{font-family:"IBM Plex Mono";font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;padding:11px 20px;border-radius:6px;cursor:pointer;border:1px solid transparent;display:inline-block;transition:.15s}
.btn-primary{background:var(--brass);color:#fff} .btn-primary:hover{background:var(--brass-d)}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--text)} .btn-ghost:hover{border-color:var(--brass);color:var(--brass-d)}
.btn-primary.sm,.btn-ghost.sm{padding:7px 13px;font-size:.64rem}
.block{display:block;text-align:center;margin-top:16px}

/* login */
.login-body{display:grid;place-items:center;min-height:100vh;background:linear-gradient(160deg,var(--ink),#0C1714)}
.login-card{background:var(--paper-2);border-radius:14px;padding:40px;width:min(400px,92vw);box-shadow:0 30px 80px rgba(0,0,0,.4)}
.login-card .logo{color:var(--ink)}
.login-card h2{font-size:1.5rem;margin:18px 0 4px}
.login-card .muted{font-size:.88rem;margin-bottom:20px}
.login-card .btn-primary{width:100%;text-align:center;margin-top:22px;padding:13px}
.form-error{background:#FBEAEA;border:1px solid #E3B7B7;color:#9B2C2C;padding:10px 13px;border-radius:6px;font-size:.85rem;margin-bottom:14px}
