/* ============================================================================
   CASA TEMPO — ERP / Retaguarda · design system NEUTRO e DENSO
   Foco em eficiência operacional: sidebar fixa + tabelas + status pills.
   Acento verde discreto liga à marca sem roubar densidade. NÃO é a UI final.
   ========================================================================== */

:root {
  --bg:        #eef0f3;     /* fundo do app */
  --surface:   #ffffff;
  --surface-2: #f7f8fa;
  --border:    #e3e6ea;
  --border-2:  #d6dadf;
  --ink:       #1f2733;
  --muted:     #5b6573;
  --faint:     #8a93a1;
  --sidebar:   #1d2531;     /* slate escuro */
  --sidebar-2: #283242;
  --sidebar-tx:#aeb7c4;
  --accent:    #5d7050;     /* verde-musgo discreto (liga à marca) */
  --accent-2:  #6f855e;
  --accent-soft:#eef1ea;
  /* status */
  --ok:#2f7d52; --ok-bg:#e7f3ec;
  --warn:#9a6a00; --warn-bg:#fbf2dd;
  --bad:#b23b3b; --bad-bg:#f8e7e7;
  --info:#2f5d8a; --info-bg:#e8eff6;
  --neutral:#5b6573; --neutral-bg:#eceef1;

  --radius:10px; --radius-sm:7px;
  --shadow:0 1px 2px rgba(20,28,40,.05), 0 4px 12px rgba(20,28,40,.05);
  --sidebar-w:230px;
  --font:'Inter', ui-sans-serif, system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
}
* { box-sizing:border-box; }
body { margin:0; background:var(--bg); color:var(--ink); font-family:var(--font); font-size:14px; line-height:1.5; -webkit-font-smoothing:antialiased; }
h1,h2,h3,h4 { margin:0; font-weight:600; letter-spacing:-.01em; }
.tabular { font-variant-numeric:tabular-nums; }
svg { width:16px; height:16px; flex-shrink:0; vertical-align:middle; }   /* tamanho padrão dos ícones */
.section-title svg { color:var(--faint); }
a { color:inherit; text-decoration:none; }
.muted{color:var(--muted)} .faint{color:var(--faint)}

/* ---------- App shell ---------- */
.app { display:flex; min-height:100vh; }
.sidebar { width:var(--sidebar-w); background:var(--sidebar); color:var(--sidebar-tx); position:fixed; top:0; bottom:0; left:0; display:flex; flex-direction:column; z-index:40; }
.sb-brand { display:flex; align-items:center; gap:9px; padding:16px 18px; color:#fff; border-bottom:1px solid rgba(255,255,255,.07); }
.sb-brand .mk { width:30px; height:30px; border-radius:8px; background:var(--accent); display:grid; place-items:center; font-weight:700; font-size:.72rem; color:#fff; }
.sb-brand b { font-weight:600; font-size:.98rem; } .sb-brand span { font-size:.68rem; color:var(--sidebar-tx); display:block; }
.sb-nav { flex:1; overflow:auto; padding:10px 10px 20px; }
.sb-group { font-size:.64rem; text-transform:uppercase; letter-spacing:.12em; color:#5d6979; padding:14px 10px 6px; font-weight:700; }
.sb-link { display:flex; align-items:center; gap:10px; padding:8px 10px; border-radius:8px; color:var(--sidebar-tx); font-size:.86rem; font-weight:500; cursor:pointer; transition:.12s; position:relative; }
.sb-link:hover { background:var(--sidebar-2); color:#fff; }
.sb-link.active { background:var(--sidebar-2); color:#fff; }
.sb-link.active::before { content:""; position:absolute; left:-10px; top:6px; bottom:6px; width:3px; border-radius:0 3px 3px 0; background:var(--accent-2); }
.sb-link svg { width:17px; height:17px; flex-shrink:0; }
.sb-link .cnt { margin-left:auto; background:rgba(255,255,255,.12); color:#fff; font-size:.64rem; font-weight:700; padding:1px 7px; border-radius:999px; }
.sb-foot { padding:12px; border-top:1px solid rgba(255,255,255,.07); font-size:.7rem; color:#5d6979; }

.main { flex:1; margin-left:var(--sidebar-w); display:flex; flex-direction:column; min-width:0; }

/* ---------- Topbar ---------- */
.topbar { height:58px; background:var(--surface); border-bottom:1px solid var(--border); display:flex; align-items:center; gap:14px; padding:0 22px; position:sticky; top:0; z-index:30; }
.topbar h1 { font-size:1.06rem; }
.topbar .crumb { font-size:.74rem; color:var(--faint); }
.search { display:flex; align-items:center; gap:7px; background:var(--surface-2); border:1px solid var(--border); border-radius:8px; padding:7px 11px; min-width:210px; color:var(--faint); }
.search input { border:0; background:transparent; outline:none; font-family:inherit; font-size:.85rem; color:var(--ink); width:100%; }
.search svg { width:15px; height:15px; }
.tb-right { margin-left:auto; display:flex; align-items:center; gap:10px; }
.rolepick { display:flex; align-items:center; gap:8px; background:var(--surface-2); border:1px solid var(--border); border-radius:999px; padding:5px 6px 5px 12px; cursor:pointer; }
.rolepick .ra { width:26px;height:26px;border-radius:50%; background:var(--accent); color:#fff; display:grid; place-items:center; font-size:.7rem; font-weight:700; }
.rolepick b { font-size:.8rem; } .rolepick span { font-size:.66rem; color:var(--faint); display:block; line-height:1; }
.bell { position:relative; width:36px; height:36px; border-radius:8px; display:grid; place-items:center; cursor:pointer; color:var(--muted); border:1px solid var(--border); background:var(--surface); }
.bell:hover{background:var(--surface-2)} .bell svg{width:17px;height:17px}
.bell .dot { position:absolute; top:7px; right:8px; width:7px; height:7px; border-radius:50%; background:var(--bad); border:1.5px solid #fff; }

/* ---------- Content ---------- */
.content { padding:22px; max-width:1320px; width:100%; }
.page-head { display:flex; align-items:flex-end; justify-content:space-between; gap:12px; margin-bottom:18px; flex-wrap:wrap; }
.page-head .eyebrow { font-size:.68rem; text-transform:uppercase; letter-spacing:.12em; color:var(--faint); font-weight:700; }
.page-head h2 { font-size:1.5rem; margin-top:3px; }

/* banner protótipo / fictício */
.proto-banner { background:#fff7e6; border:1px solid #f0dca0; color:#7a5c12; border-radius:8px; padding:9px 13px; font-size:.78rem; display:flex; align-items:center; gap:8px; margin-bottom:16px; }
.proto-banner svg{width:15px;height:15px;flex-shrink:0}

/* ---------- Cards / KPIs ---------- */
.grid { display:grid; gap:14px; }
.card { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); box-shadow:var(--shadow); }
.card-pad { padding:16px; }
.kpi { padding:15px 16px; }
.kpi .lbl { font-size:.74rem; color:var(--muted); display:flex; align-items:center; gap:7px; }
.kpi .lbl svg{width:15px;height:15px;color:var(--faint)}
.kpi .val { font-size:1.7rem; font-weight:700; letter-spacing:-.02em; margin-top:5px; }
.kpi .sub { font-size:.72rem; color:var(--faint); margin-top:2px; }
.kpi .trend.up{color:var(--ok)} .kpi .trend.down{color:var(--bad)}
.section-title { font-size:.92rem; font-weight:600; margin-bottom:10px; display:flex; align-items:center; justify-content:space-between; }

/* ---------- Tables ---------- */
.tbl-wrap { overflow:auto; border:1px solid var(--border); border-radius:var(--radius); background:var(--surface); }
table.tbl { width:100%; border-collapse:collapse; font-size:.84rem; }
.tbl th { text-align:left; font-size:.7rem; text-transform:uppercase; letter-spacing:.06em; color:var(--faint); font-weight:700; padding:10px 14px; border-bottom:1px solid var(--border); background:var(--surface-2); white-space:nowrap; position:sticky; top:0; }
.tbl td { padding:10px 14px; border-bottom:1px solid var(--border); vertical-align:middle; }
.tbl tr:last-child td { border-bottom:0; }
.tbl tbody tr { cursor:default; }
.tbl tbody tr.click { cursor:pointer; }
.tbl tbody tr.click:hover { background:var(--surface-2); }
.card.click { cursor:pointer; transition:box-shadow .12s, border-color .12s; }
.card.click:hover { box-shadow:var(--shadow); border-color:var(--border-2); }
.tbl .name { font-weight:600; }
.cell-sub { font-size:.74rem; color:var(--faint); }
.avatar { width:30px;height:30px;border-radius:50%; background:var(--accent-soft); color:var(--accent); display:inline-grid; place-items:center; font-size:.72rem; font-weight:700; }

/* ---------- Status pills ---------- */
.pill { display:inline-flex; align-items:center; gap:5px; padding:2px 9px; border-radius:999px; font-size:.72rem; font-weight:600; white-space:nowrap; }
.pill::before { content:""; width:6px; height:6px; border-radius:50%; background:currentColor; opacity:.9; }
.pill.ok{color:var(--ok);background:var(--ok-bg)} .pill.warn{color:var(--warn);background:var(--warn-bg)}
.pill.bad{color:var(--bad);background:var(--bad-bg)} .pill.info{color:var(--info);background:var(--info-bg)}
.pill.neutral{color:var(--neutral);background:var(--neutral-bg)}
.pill.flat::before{display:none}
/* Tiers do Score (B2) */
.pill.tier-bronze{color:#8a5a2b;background:#f3e7d8} .pill.tier-prata{color:#5b6573;background:#e8ebef}
.pill.tier-ouro{color:#8a6d12;background:#f7eecb} .pill.tier-diamante{color:#1f7a8c;background:#d9f0f4}

/* ---------- Buttons ---------- */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:7px; padding:8px 14px; border-radius:8px; font-weight:600; font-size:.84rem; border:1px solid var(--border-2); background:var(--surface); color:var(--ink); cursor:pointer; transition:.12s; white-space:nowrap; font-family:inherit; }
.btn:hover { background:var(--surface-2); }
.btn svg{width:15px;height:15px}
.btn-primary { background:var(--accent); border-color:var(--accent); color:#fff; }
.btn-primary:hover { background:var(--accent-2); }
.btn-sm { padding:5px 10px; font-size:.78rem; }
.btn-ghost { border-color:transparent; background:transparent; color:var(--muted); }
.btn-ghost:hover{background:var(--surface-2);color:var(--ink)}
.btn-danger { color:var(--bad); border-color:#e6c4c4; background:#fff; }
.btn-danger:hover{background:var(--bad-bg)}
.btn:disabled{opacity:.45;cursor:not-allowed}
.iconbtn { width:30px;height:30px;border-radius:7px;display:grid;place-items:center;border:1px solid var(--border-2);background:var(--surface);cursor:pointer;color:var(--muted) }
.iconbtn:hover{background:var(--surface-2);color:var(--ink)} .iconbtn svg{width:15px;height:15px}

/* ---------- Filters / chips ---------- */
.filters { display:flex; gap:8px; flex-wrap:wrap; align-items:center; margin-bottom:14px; }
.chip { padding:6px 12px; border-radius:999px; border:1px solid var(--border-2); background:var(--surface); font-size:.78rem; font-weight:500; color:var(--muted); cursor:pointer; }
.chip:hover{border-color:var(--accent);color:var(--ink)}
.chip.on { background:var(--accent); color:#fff; border-color:var(--accent); }
.seg { display:inline-flex; background:var(--surface-2); border:1px solid var(--border); border-radius:8px; padding:2px; }
.seg button { border:0; background:transparent; padding:6px 12px; border-radius:6px; font-size:.8rem; font-weight:600; color:var(--muted); cursor:pointer; }
.seg button.on { background:var(--surface); color:var(--ink); box-shadow:var(--shadow); }

/* ---------- Agenda (calendar week) ---------- */
.agenda { display:grid; grid-template-columns:repeat(6,1fr); gap:10px; }
.ag-col-head { text-align:center; padding:8px 0; border-radius:8px; }
.ag-col-head.hoje { background:var(--accent-soft); }
.ag-col-head .d { font-weight:700; } .ag-col-head .dt { font-size:.72rem; color:var(--faint); }
.ag-cell { display:flex; flex-direction:column; gap:8px; }
.ag-class { border:1px solid var(--border); border-left:3px solid var(--neutral); border-radius:8px; padding:9px 10px; background:var(--surface); cursor:pointer; transition:.12s; }
.ag-class:hover{ box-shadow:var(--shadow); border-color:var(--border-2); }
.ag-class.l-corpo{border-left-color:#6E7A5A} .ag-class.l-mente{border-left-color:#A2854B} .ag-class.l-spa{border-left-color:#A85638}
.ag-class.cancel{opacity:.5} .ag-class .h{font-weight:700;font-size:.82rem} .ag-class .m{font-size:.8rem;font-weight:600;margin:2px 0 6px;line-height:1.25}
.occ { height:5px; border-radius:999px; background:var(--neutral-bg); overflow:hidden; }
.occ > i { display:block; height:100%; border-radius:999px; }
.occ-low > i{background:var(--ok)} .occ-mid > i{background:var(--warn)} .occ-full > i{background:var(--bad)}

/* ---------- Detail / drawer panel ---------- */
.drawer-back { position:fixed; inset:0; background:rgba(20,28,40,.4); z-index:90; }
.drawer { position:fixed; top:0; right:0; bottom:0; width:min(460px,94vw); background:var(--surface); box-shadow:-8px 0 30px rgba(20,28,40,.18); z-index:95; display:flex; flex-direction:column; animation:slide .2s ease; }
@keyframes slide { from{transform:translateX(100%)} to{transform:none} }
.drawer-head { padding:16px 18px; border-bottom:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; }
.drawer-body { padding:18px; overflow:auto; flex:1; }

/* ---------- Modal (forms) ---------- */
.modal-back { position:fixed; inset:0; background:rgba(20,28,40,.45); z-index:100; display:grid; place-items:center; padding:20px; }
.modal { background:var(--surface); border-radius:12px; width:min(540px,96vw); max-height:90vh; overflow:auto; box-shadow:0 20px 60px rgba(20,28,40,.25); }
.modal-head { padding:16px 20px; border-bottom:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; }
.modal-body { padding:20px; }
.modal-foot { padding:14px 20px; border-top:1px solid var(--border); display:flex; gap:10px; justify-content:flex-end; }

/* ---------- Form ---------- */
.field { margin-bottom:13px; } .field.row{display:flex;gap:12px} .field.row>div{flex:1}
.label { display:block; font-size:.76rem; font-weight:600; color:var(--muted); margin-bottom:5px; }
.inp, select.inp { width:100%; padding:9px 11px; border:1px solid var(--border-2); border-radius:7px; font-size:.85rem; font-family:inherit; background:var(--surface); color:var(--ink); }
.inp:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(93,112,80,.12)}

/* ---------- Misc ---------- */
.kvs { display:grid; grid-template-columns:auto 1fr; gap:7px 16px; font-size:.84rem; }
.kvs .k{color:var(--muted)} .kvs .v{text-align:right;font-weight:500}
.hr { height:1px; background:var(--border); border:0; margin:14px 0; }
.bar-row { display:flex; align-items:center; gap:10px; margin-bottom:9px; font-size:.82rem; }
.bar-row .bl { width:120px; color:var(--muted); } .bar-row .bt { flex:1; height:9px; background:var(--surface-2); border-radius:999px; overflow:hidden; }
.bar-row .bt > i { display:block; height:100%; background:var(--accent); border-radius:999px; }
.bar-row .bv { width:80px; text-align:right; font-weight:600; }
.empty { text-align:center; color:var(--faint); padding:36px; }
.toast-wrap { position:fixed; bottom:20px; left:50%; transform:translateX(-50%); z-index:120; display:flex; flex-direction:column; gap:8px; align-items:center; }
.toast { background:var(--ink); color:#fff; padding:10px 18px; border-radius:999px; font-size:.84rem; box-shadow:var(--shadow); animation:tin .2s ease; }
@keyframes tin{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.minmax { font-size:.72rem; color:var(--faint); }
.stepper-num { font-variant-numeric:tabular-nums; }

@media (max-width:1024px){ .sidebar{transform:translateX(-100%);transition:.2s} .sidebar.open{transform:none} .main{margin-left:0} .menu-toggle{display:inline-grid!important} }
.menu-toggle{display:none}
@media (max-width:680px){ .agenda{grid-template-columns:1fr} .search{display:none} .content{padding:14px} .content .grid{grid-template-columns:1fr !important} .drawer{width:100vw} }
