/* ─────────────────────────────────────────── shared screen primitives */

/* form modal — used by Novo/Editar projeto, mantém o mesmo idioma visual
   do command palette e dos cards */
.fm-scrim{
  position:fixed;inset:0;z-index:150;
  background:rgba(10,10,10,.42);
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
  display:grid;place-items:center;
  opacity:0;pointer-events:none;transition:opacity .18s ease;
}
.fm-scrim.open{opacity:1;pointer-events:auto}
.fm-modal{
  width:min(840px, 94vw);max-height:88vh;
  background:var(--surface);border:1px solid var(--line);border-radius:16px;
  box-shadow:0 24px 60px -16px rgba(10,10,10,.45), 0 4px 16px -4px rgba(10,10,10,.18);
  display:flex;flex-direction:column;overflow:hidden;
  transform:translateY(8px) scale(.985);opacity:0;
  transition:transform .22s cubic-bezier(.2,.8,.2,1), opacity .18s ease;
}
.fm-scrim.open .fm-modal{transform:none;opacity:1}
.fm-head{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:18px 22px;border-bottom:1px solid var(--line);
}
.fm-title{font-size:17px;font-weight:700;letter-spacing:-0.015em;color:var(--ink);margin:0}
.fm-sub{font-size:11.5px;color:var(--muted-2);font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;margin-top:3px}
.fm-close{
  appearance:none;border:1px solid var(--line);background:var(--surface);
  width:32px;height:32px;border-radius:9px;display:grid;place-items:center;cursor:pointer;color:var(--ink-2);
}
.fm-close:hover{background:var(--surface-2)}
.fm-body{padding:18px 22px;overflow-y:auto;flex:1}
.fm-section{margin-bottom:20px}
.fm-section:last-child{margin-bottom:6px}
.fm-section-head{
  font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--muted-2);margin-bottom:10px;display:flex;align-items:center;gap:10px;
}
.fm-section-head::after{content:"";flex:1;height:1px;background:var(--line)}
.fm-input,.fm-select,.fm-textarea{
  display:flex;align-items:center;
  background:var(--surface);border:1px solid var(--line);border-radius:9px;
  padding:8px 11px;width:100%;
  font:13.5px var(--font);color:var(--ink);
  transition:border-color .12s ease, box-shadow .12s ease;
}
.fm-input:focus,.fm-select:focus,.fm-textarea:focus{
  outline:0;border-color:var(--ink);box-shadow:0 0 0 3px rgba(168,216,32,.18);
}
.fm-input[aria-invalid="true"]{border-color:var(--danger)}
.fm-textarea{min-height:78px;resize:vertical;font-family:var(--font)}
.fm-checkbox{
  display:flex;align-items:center;gap:8px;cursor:pointer;user-select:none;
  font-size:13px;color:var(--ink-2);
}
.fm-checkbox input{width:15px;height:15px;accent-color:var(--ink)}
.fm-team{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:8px;
}
.fm-team-row{
  display:flex;align-items:center;gap:10px;
  border:1px solid var(--line);border-radius:9px;padding:8px 10px;
  background:var(--surface);
  font-size:13px;color:var(--ink-2);
}
.fm-team-row.on{border-color:var(--ink);background:#FBFBF8}
.fm-team-row .fr-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}
.fm-team-row .fr-lead{
  font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);cursor:pointer;border:1px solid var(--line);border-radius:6px;
  padding:2px 6px;transition:all .12s ease;
}
.fm-team-row .fr-lead:hover{border-color:var(--ink-2);color:var(--ink-2)}
.fm-team-row .fr-lead.on{background:var(--ink);color:var(--lime);border-color:var(--ink)}
.fm-foot{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px 22px;border-top:1px solid var(--line);background:var(--surface-2);
}
.fm-error{
  background:#FFE9E0;border:1px solid #FFC4AD;color:#7a2a00;
  padding:8px 12px;border-radius:9px;font-size:12.5px;
  display:flex;align-items:center;gap:8px;margin-bottom:14px;
}
.fm-foot-actions{display:flex;gap:10px;margin-left:auto}

/* greeting */
.screen-head{
  display:flex;align-items:flex-end;justify-content:space-between;gap:32px;
  margin-bottom:24px;
}
.screen-head .sh-eyebrow{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--muted-2);margin-bottom:4px;
  display:flex;align-items:center;gap:10px;
}
.screen-head .sh-eyebrow .tick{width:18px;height:1px;background:currentColor}
.screen-head .sh-title{
  font-size:34px;font-weight:700;letter-spacing:-0.025em;line-height:1.05;margin:0;
}
.screen-head .sh-title .accent{color:var(--ink);font-weight:700}
.screen-head .sh-sub{color:var(--muted);font-size:14px;margin-top:8px;max-width:60ch}
.screen-head .sh-actions{display:flex;gap:8px;flex-shrink:0}

/* card */
.card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:14px;
  transition:border-color .15s ease, box-shadow .15s ease;
  position:relative;
}
.card:hover{border-color:var(--line-strong)}
.card .card-head{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px 18px;border-bottom:1px solid var(--line);
}
.card .card-title{font-size:13px;font-weight:600;letter-spacing:-0.005em;color:var(--ink)}
.card .card-eyebrow{
  font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted-2);
}
.card .card-body{padding:18px}
.card .card-link{
  font-size:11.5px;color:var(--muted);display:inline-flex;align-items:center;gap:4px;cursor:pointer;
}
.card .card-link:hover{color:var(--ink)}

/* grid */
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}
.col-3{grid-column:span 3}
.col-4{grid-column:span 4}
.col-5{grid-column:span 5}
.col-6{grid-column:span 6}
.col-7{grid-column:span 7}
.col-8{grid-column:span 8}
.col-9{grid-column:span 9}
.col-12{grid-column:span 12}
@media (max-width: 1100px){
  .col-3{grid-column:span 6}
  .col-4{grid-column:span 6}
  .col-5,.col-7,.col-8,.col-9{grid-column:span 12}
}

/* KPI */
.kpi{
  padding:18px;display:flex;flex-direction:column;gap:10px;min-height:130px;
  background:var(--surface);border:1px solid var(--line);border-radius:14px;
  position:relative;overflow:hidden;
}
.kpi .kpi-label{
  font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--muted-2);display:flex;align-items:center;gap:8px;
}
.kpi .kpi-label .kpi-dot{width:6px;height:6px;border-radius:50%;background:var(--lime-deep)}
.kpi .kpi-num{
  font-size:32px;font-weight:700;letter-spacing:-0.025em;line-height:1;color:var(--ink);
  font-variant-numeric:tabular-nums;
}
.kpi .kpi-num small{font-size:14px;color:var(--muted);font-weight:500;letter-spacing:0;margin-left:4px}
.kpi .kpi-delta{
  font-size:12px;color:var(--muted);display:flex;align-items:center;gap:6px;
}
.kpi .kpi-delta b{font-weight:600}
.kpi .kpi-delta b.up{color:#1F8A5B}
.kpi .kpi-delta b.down{color:#C45A2E}
.kpi-spark{position:absolute;right:14px;top:14px;width:88px;height:32px;opacity:.7}
.kpi.accent{background:linear-gradient(160deg, var(--surface) 0%, var(--lime-soft) 180%)}
.kpi.dark{background:#0C0C0A;color:#fff;border-color:transparent}
.kpi.dark .kpi-label{color:rgba(255,255,255,.55)}
.kpi.dark .kpi-num{color:var(--lime)}
.kpi.dark .kpi-delta{color:rgba(255,255,255,.7)}

/* badges */
.badge{
  display:inline-flex;align-items:center;gap:6px;
  font-size:11px;font-weight:600;letter-spacing:.01em;
  padding:3px 8px;border-radius:999px;
  background:var(--surface-2);color:var(--ink-2);
  white-space:nowrap;
}
.badge .b-dot{width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.7}
.badge.lime{background:var(--lime);color:#0a0a0a}
.badge.ink{background:#0C0C0A;color:#fff}
.badge.warn{background:#FFF1D6;color:#7a4a00}
.badge.danger{background:#FFE0D6;color:#7a2a00}
.badge.muted{background:var(--surface-2);color:var(--muted)}
.badge.success{background:#D6EFE0;color:#155a35}
.badge.info{background:#D6E8F5;color:#0a3a5a}

/* phase pill */
.phase-pill{
  display:inline-flex;align-items:center;gap:6px;
  font-size:11px;font-weight:500;padding:3px 9px;border-radius:6px;
  background:var(--surface-2);color:var(--ink-2);
  border:1px solid var(--line);
}
.phase-pill .p-num{
  font-family:var(--mono);font-size:9.5px;color:var(--muted-2);
}

/* avatar */
.av{
  width:28px;height:28px;border-radius:50%;
  display:grid;place-items:center;font-size:10.5px;font-weight:700;
  color:var(--lime);background:#0C0C0A;flex-shrink:0;letter-spacing:.02em;
  box-shadow:0 0 0 2px var(--bg);
}
.av.sm{width:22px;height:22px;font-size:9.5px}
.av.md{width:32px;height:32px;font-size:11.5px}
.av.lg{width:44px;height:44px;font-size:13px}
.av-stack{display:flex;align-items:center}
.av-stack .av+.av{margin-left:-7px}
.av-stack.sm .av+.av{margin-left:-5px}

/* progress bar */
.prog{
  width:100%;height:6px;background:var(--surface-2);border-radius:999px;overflow:hidden;
  position:relative;
}
.prog .prog-fill{
  height:100%;background:linear-gradient(90deg,var(--lime-deep),var(--lime));
  border-radius:999px;transition:width .4s ease;
}
.prog.thin{height:4px}

/* segmented filter */
.seg{
  display:inline-flex;background:var(--surface-2);border-radius:9px;padding:3px;gap:2px;
  border:1px solid var(--line);
}
.seg button{
  appearance:none;border:0;background:transparent;
  padding:5px 12px;font-size:12px;font-weight:500;color:var(--muted);
  border-radius:7px;cursor:pointer;letter-spacing:-0.005em;
}
.seg button[aria-pressed="true"]{background:#0C0C0A;color:#fff}
.seg button:hover:not([aria-pressed="true"]){color:var(--ink)}

/* search input */
.search-in{
  display:flex;align-items:center;gap:10px;
  background:var(--surface);border:1px solid var(--line);border-radius:10px;
  padding:9px 14px;flex:1;min-width:200px;
  transition:border-color .12s ease, box-shadow .12s ease;
}
.search-in:focus-within{border-color:var(--ink);box-shadow:0 0 0 3px rgba(168,216,32,.18)}
.search-in input{
  flex:1;border:0;outline:0;background:transparent;
  font:13.5px var(--font);color:var(--ink);min-width:0;
}
.search-in input::placeholder{color:var(--muted-2)}
.search-in .kbd{flex-shrink:0}

/* table */
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl thead th{
  text-align:left;font-family:var(--mono);font-size:10px;font-weight:600;
  color:var(--muted-2);letter-spacing:.1em;text-transform:uppercase;
  padding:10px 14px;border-bottom:1px solid var(--line);
  background:transparent;
}
.tbl tbody td{
  padding:14px;border-bottom:1px solid var(--line);
  vertical-align:middle;
}
.tbl tbody tr{transition:background .12s ease;cursor:pointer}
.tbl tbody tr:hover{background:var(--surface-2)}
.tbl tbody tr:last-child td{border-bottom:0}

/* phase distribution chart */
.phase-chart{
  display:grid;grid-template-columns:repeat(6,1fr);gap:14px;
}
.phase-col{
  display:flex;flex-direction:column;gap:8px;
}
.phase-bar-wrap{
  height:120px;background:var(--surface-2);border-radius:10px;
  position:relative;overflow:hidden;
  display:flex;align-items:flex-end;
}
.phase-bar{
  width:100%;background:linear-gradient(180deg,var(--lime) 0%,var(--lime-deep) 100%);
  border-radius:10px 10px 6px 6px;
  position:relative;transition:height .5s cubic-bezier(.2,.8,.2,1);
  display:flex;align-items:flex-start;justify-content:center;padding-top:8px;
}
.phase-bar .pb-num{
  font-size:14px;font-weight:700;color:#0a0a0a;letter-spacing:-0.01em;
}
.phase-col .pc-label{
  font-size:11px;color:var(--muted);text-align:center;font-weight:500;line-height:1.25;
}
.phase-col .pc-line{
  display:flex;align-items:center;gap:4px;font-family:var(--mono);font-size:9.5px;
  color:var(--muted-2);justify-content:center;letter-spacing:.06em;
}

/* deadline list */
.dl-row{
  display:grid;grid-template-columns:1fr auto;gap:10px;
  padding:12px 0;border-bottom:1px dashed var(--line);align-items:center;
}
.dl-row:last-child{border-bottom:0}
.dl-row .dl-name{font-size:13px;font-weight:500;color:var(--ink-2);letter-spacing:-0.005em}
.dl-row .dl-sub{font-size:11px;color:var(--muted);margin-top:2px}
.dl-row .dl-days{
  font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.05em;
  padding:4px 8px;border-radius:7px;text-align:center;min-width:74px;
  background:var(--surface-2);color:var(--ink-2);
}
.dl-row .dl-days.late{background:#FFE0D6;color:#7a2a00}
.dl-row .dl-days.soon{background:#FFF1D6;color:#7a4a00}

/* simple bar chart for finance */
.bars{display:flex;flex-direction:column;gap:8px}
.bars-row{display:grid;grid-template-columns:130px 1fr 80px;gap:12px;align-items:center}
.bars-row .br-label{font-size:12px;color:var(--ink-2)}
.bars-row .br-track{height:10px;background:var(--surface-2);border-radius:999px;overflow:hidden}
.bars-row .br-fill{height:100%;background:linear-gradient(90deg,#0C0C0A,#2a2a26);border-radius:999px}
.bars-row.income .br-fill{background:linear-gradient(90deg,var(--lime-deep),var(--lime))}
.bars-row .br-val{font-size:12px;font-variant-numeric:tabular-nums;color:var(--muted);text-align:right}

/* event timeline */
.tl-row{
  display:grid;grid-template-columns:54px 1fr auto;gap:12px;padding:10px 0;
  border-bottom:1px dashed var(--line);align-items:center;
}
.tl-row:last-child{border-bottom:0}
.tl-row .tl-time{
  font-family:var(--mono);font-size:11px;color:var(--ink);letter-spacing:.02em;font-weight:600;
}
.tl-row .tl-name{font-size:13px;color:var(--ink-2);font-weight:500;letter-spacing:-0.005em}
.tl-row .tl-sub{font-size:11px;color:var(--muted);margin-top:2px}
.tl-row .tl-kind{font-size:11px;color:var(--muted-2)}

/* member rows */
.mb-row{
  display:grid;grid-template-columns:auto 1fr auto auto;gap:12px;align-items:center;
  padding:10px 0;border-bottom:1px dashed var(--line);
}
.mb-row:last-child{border-bottom:0}
.mb-row .mb-name{font-size:13px;font-weight:500;color:var(--ink-2)}
.mb-row .mb-role{font-size:11px;color:var(--muted-2);margin-top:1px}
.mb-row .mb-hours{
  font-family:var(--mono);font-size:13px;font-weight:700;letter-spacing:-0.01em;
  color:var(--ink-2);min-width:46px;text-align:right;
}
.mb-row .mb-hours small{font-size:10px;color:var(--muted-2);font-weight:500;margin-left:1px}
.mb-bar{
  width:100px;height:6px;border-radius:999px;background:var(--surface-2);overflow:hidden;
}
.mb-bar .mb-fill{height:100%;background:linear-gradient(90deg,var(--lime-deep),var(--lime));border-radius:999px}

/* tabs */
.tabs{
  display:flex;align-items:flex-end;gap:0;border-bottom:1px solid var(--line);
}
.tabs button{
  appearance:none;border:0;background:transparent;
  padding:12px 18px;font-size:13px;font-weight:500;color:var(--muted);
  border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;
  display:inline-flex;align-items:center;gap:8px;letter-spacing:-0.005em;
  transition:color .15s ease,border-color .15s ease;
}
.tabs button:hover{color:var(--ink)}
.tabs button[aria-pressed="true"]{color:var(--ink);font-weight:600;border-bottom-color:var(--ink)}
.tabs button[aria-pressed="true"]::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--lime);
}
.tabs button{position:relative}
.tabs .count{
  font-family:var(--mono);font-size:10px;background:var(--surface-2);
  color:var(--muted);padding:1px 6px;border-radius:5px;font-weight:600;
}

/* project card grid */
.proj-grid{display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:16px}
@media (max-width: 1280px){.proj-grid{grid-template-columns:repeat(2, minmax(0,1fr))}}
@media (max-width: 780px){.proj-grid{grid-template-columns:1fr}}
.proj-card{
  background:var(--surface);border:1px solid var(--line);border-radius:14px;
  padding:18px;display:flex;flex-direction:column;gap:14px;cursor:pointer;
  transition:border-color .15s ease, box-shadow .15s ease, transform .15s ease;
  position:relative;overflow:hidden;
}
.proj-card:hover{border-color:var(--line-strong);box-shadow:var(--shadow-1);transform:translateY(-1px)}
.proj-card .pc-tag{
  position:absolute;top:0;left:18px;
  font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;font-weight:600;
  background:#0C0C0A;color:var(--lime);padding:2px 8px 3px;border-radius:0 0 5px 5px;
}
.proj-card .pc-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-top:14px}
.proj-card .pc-name{font-size:16px;font-weight:600;letter-spacing:-0.015em;color:var(--ink);line-height:1.2}
.proj-card .pc-client{font-size:11.5px;color:var(--muted);margin-top:4px}
.proj-card .pc-meta{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  font-size:11.5px;color:var(--muted);
}
.proj-card .pc-dates{
  display:flex;gap:14px;font-family:var(--mono);font-size:10.5px;color:var(--muted);letter-spacing:.04em;
}
.proj-card .pc-dates span b{color:var(--ink-2);font-weight:600;display:block;font-size:11px;letter-spacing:0}

/* form-ish fields (used in client detail edit etc.) */
.form-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.fld{display:flex;flex-direction:column;gap:5px}
.lbl{
  font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--muted-2);
}
.fld .lbl{
  font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--muted-2);
}
.fld .val{font-size:13.5px;color:var(--ink);font-weight:500}
.fld .val.link{color:var(--ink);border-bottom:1px solid var(--line-strong);cursor:pointer;width:fit-content}
.fld .val.link:hover{border-bottom-color:var(--ink)}
.fld .val.muted{color:var(--muted)}
.span-2{grid-column:span 2}
.span-3{grid-column:span 3}
.span-4{grid-column:span 4}
.span-6{grid-column:span 6}
.span-12{grid-column:span 12}

/* activity rows */
.act-row{
  background:var(--surface);border:1px solid var(--line);border-radius:12px;
  padding:14px 16px;display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;
}
.act-row .ar-name{font-size:14px;font-weight:600;color:var(--ink);letter-spacing:-0.005em}
.act-row .ar-meta{font-size:11.5px;color:var(--muted);margin-top:3px;display:flex;gap:14px;align-items:center}
.act-row .ar-progress{display:flex;align-items:center;gap:10px}
.act-row .ar-progress .prog{width:140px}
.act-row .ar-counts{
  font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.04em;
}

/* task row */
.task-row{
  display:grid;grid-template-columns:auto 1fr auto auto;gap:14px;
  padding:12px 14px;border:1px solid var(--line);border-radius:10px;
  background:var(--surface);align-items:center;
}
.task-row + .task-row{margin-top:8px}
.task-row.done{opacity:.65}
.task-row.done .tr-name{text-decoration:line-through;color:var(--muted)}
.task-check{
  width:18px;height:18px;border-radius:6px;border:1.5px solid var(--line-strong);
  display:grid;place-items:center;cursor:pointer;transition:all .15s ease;
}
.task-check.on{background:var(--lime);border-color:var(--lime-deep)}
.task-check svg{opacity:0;transition:opacity .15s ease}
.task-check.on svg{opacity:1}
.tr-name{font-size:13.5px;font-weight:500;color:var(--ink-2);letter-spacing:-0.005em}
.tr-sub{display:flex;gap:14px;font-size:11px;color:var(--muted);margin-top:4px;align-items:center}

/* checklist */
.checklist{margin-top:10px;padding:10px 14px;background:var(--surface-2);border-radius:8px;
  display:flex;flex-direction:column;gap:6px}
.checklist-item{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--ink-2)}
.checklist-item.on{color:var(--muted);text-decoration:line-through}
.checklist-item .ci-box{
  width:14px;height:14px;border-radius:4px;border:1.5px solid var(--line-strong);
  display:grid;place-items:center;cursor:pointer;
}
.checklist-item.on .ci-box{background:var(--lime-deep);border-color:var(--lime-deep)}
.checklist-item .ci-box svg{color:#fff;opacity:0}
.checklist-item.on .ci-box svg{opacity:1}

/* timer card */
.timer{
  display:flex;align-items:center;gap:14px;padding:16px;border-radius:12px;
  background:linear-gradient(135deg, #0C0C0A 0%, #1a1a16 100%);color:#fff;
}
.timer .t-clock{
  font-family:var(--mono);font-size:28px;font-weight:700;letter-spacing:.02em;
  color:var(--lime);font-variant-numeric:tabular-nums;
}
.timer .t-label{font-size:11px;color:rgba(255,255,255,.55);letter-spacing:.04em;text-transform:uppercase}
.timer .t-task{font-size:13px;color:rgba(255,255,255,.85);margin-top:2px}
.timer .t-btn{
  margin-left:auto;background:var(--lime);color:#0a0a0a;border:0;cursor:pointer;
  padding:9px 14px;border-radius:9px;font-size:12.5px;font-weight:700;letter-spacing:-0.005em;
  display:inline-flex;align-items:center;gap:6px;
}
.timer .t-btn.stop{background:#FF5C3A;color:#fff}

/* installments */
.inst-row{
  display:grid;grid-template-columns:48px 100px 1fr 130px 90px;gap:12px;align-items:center;
  padding:11px 14px;border-bottom:1px solid var(--line);font-size:13px;
}
.inst-row:last-child{border-bottom:0}
.inst-row .ir-num{font-family:var(--mono);font-size:11px;color:var(--muted-2);font-weight:700;letter-spacing:.05em}
.inst-row .ir-due{font-family:var(--mono);font-size:11.5px;color:var(--ink-2);letter-spacing:.02em}
.inst-row .ir-val{font-variant-numeric:tabular-nums;text-align:right;font-weight:600}

/* doc row */
.doc-row{
  display:grid;grid-template-columns:auto 1fr auto auto;gap:14px;align-items:center;
  padding:10px 14px;border-radius:9px;
  border:1px solid var(--line);background:var(--surface);
}
.doc-row + .doc-row{margin-top:6px}
.doc-row .dr-type{
  width:36px;height:44px;border-radius:5px;background:#0C0C0A;color:var(--lime);
  font-family:var(--mono);font-size:9.5px;font-weight:700;display:grid;place-items:center;letter-spacing:.06em;
  position:relative;
}
.doc-row .dr-type::before{
  content:"";position:absolute;top:0;right:0;width:8px;height:8px;background:#1a1a18;
  border-bottom-left-radius:3px;
}
.doc-row .dr-name{font-size:13px;font-weight:500;color:var(--ink-2)}
.doc-row .dr-sub{font-size:11px;color:var(--muted);margin-top:2px}
.doc-row .dr-size{font-family:var(--mono);font-size:10.5px;color:var(--muted-2);letter-spacing:.04em}

/* breadcrumb back */
.back-bar{
  display:flex;align-items:center;gap:14px;margin-bottom:18px;
}
.back-btn{
  appearance:none;background:var(--surface);border:1px solid var(--line);
  width:34px;height:34px;border-radius:9px;display:grid;place-items:center;cursor:pointer;
  color:var(--ink-2);transition:background .15s ease, border-color .15s ease;
}
.back-btn:hover{background:var(--surface-2);border-color:var(--line-strong)}

/* finance ring (placeholder simple svg) */
.finance-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.fin-kpi{
  padding:14px;border-radius:11px;border:1px solid var(--line);background:var(--surface);
}
.fin-kpi .fk-label{
  font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2);
}
.fin-kpi .fk-val{font-size:22px;font-weight:700;letter-spacing:-0.02em;margin-top:6px;font-variant-numeric:tabular-nums}
.fin-kpi.in .fk-val{color:#1F8A5B}
.fin-kpi.out .fk-val{color:#C45A2E}
.fin-kpi .fk-sub{font-size:11px;color:var(--muted);margin-top:4px}

/* empty state */
.empty{
  text-align:center;padding:60px 24px;color:var(--muted);
  border:1px dashed var(--line-strong);border-radius:14px;background:var(--surface);
}
.empty .em-glyph{
  width:48px;height:48px;margin:0 auto 14px;border-radius:12px;background:var(--surface-2);
  display:grid;place-items:center;color:var(--ink-2);
}
.empty .em-title{font-size:15px;font-weight:600;color:var(--ink);letter-spacing:-0.01em;margin-bottom:4px}
.empty .em-sub{font-size:13px;max-width:42ch;margin:0 auto}

/* clients list row */
.client-row{
  display:grid;grid-template-columns:auto 1fr auto auto auto;gap:16px;align-items:center;
  padding:12px 14px;cursor:pointer;border-radius:11px;
  border:1px solid var(--line);background:var(--surface);
}
.client-row + .client-row{margin-top:6px}
.client-row:hover{background:var(--surface-2);border-color:var(--line-strong)}
.client-row .cr-name{font-size:13.5px;font-weight:600;color:var(--ink);letter-spacing:-0.005em}
.client-row .cr-sub{font-size:11px;color:var(--muted);margin-top:2px}
.client-row .cr-meta{font-size:11.5px;color:var(--muted-2)}
.client-row .cr-meta b{color:var(--ink-2);font-weight:600}
.client-mark{
  width:38px;height:38px;border-radius:9px;background:var(--surface-2);
  display:grid;place-items:center;font-size:11.5px;font-weight:700;color:var(--ink);
  letter-spacing:.02em;
}
.client-row.pj .client-mark{background:#0C0C0A;color:var(--lime)}

/* small data tag */
.dtag{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted-2);
}
.dtag .dt-line{width:14px;height:1px;background:currentColor}

/* ──────────────────────────────────────── CALENDAR */
.cal-wrap{display:grid;grid-template-columns:1fr 280px;gap:16px}
@media (max-width:1100px){.cal-wrap{grid-template-columns:1fr}}

.cal-tools{
  /* Slimmer toolbar so the whole month fits closer to one viewport. */
  display:flex;align-items:center;gap:12px;padding:10px 18px;
  border-bottom:1px solid var(--line);background:var(--surface);
  border-radius:14px 14px 0 0;flex-wrap:wrap;
}
.cal-month-label{
  font-size:16px;font-weight:600;letter-spacing:-0.01em;color:var(--ink);
  font-variant-numeric:tabular-nums;min-width:150px;
}
.cal-month-label small{font-size:11.5px;color:var(--muted);font-weight:500;margin-left:6px}
.cal-arrow{
  appearance:none;border:1px solid var(--line);background:var(--surface);
  width:28px;height:28px;border-radius:8px;display:grid;place-items:center;cursor:pointer;color:var(--ink-2);
}
.cal-arrow:hover{background:var(--surface-2)}

.cal-grid{
  background:var(--surface);
  /* lateral + bottom inset matches .card-body { padding:18px } so the
     calendar grid keeps the same horizontal breathing room as other screens.
     The outer Card border (.card) frames the whole calendar — no need for
     a duplicated border here. */
  padding:0 14px 14px;
  border-radius:0 0 14px 14px;
}
.cal-head{
  display:grid;grid-template-columns:repeat(7,1fr);
  background:var(--surface-2);
  position:sticky;top:0;z-index:2;
}
.cal-head .ch-cell{
  padding:8px 10px;font-family:var(--mono);font-size:10px;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2);
  border-right:1px solid var(--line);
}
.cal-head .ch-cell:last-child{border-right:0}
.cal-body{display:grid;grid-template-columns:repeat(7,1fr);grid-auto-rows:minmax(82px,1fr)}
.cal-day{
  border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:6px 8px;display:flex;flex-direction:column;gap:3px;min-height:82px;
  position:relative;
}
.cal-day:nth-child(7n){border-right:0}
.cal-day.other{background:repeating-linear-gradient(135deg,
  transparent 0 9px, rgba(10,10,10,.015) 9px 10px)}
.cal-day.other .cd-num{color:var(--muted-2)}
.cal-day.today .cd-num{
  background:#0C0C0A;color:var(--lime);width:24px;height:24px;border-radius:7px;
  display:grid;place-items:center;font-size:12px;
}
.cal-day.weekend{background-color:rgba(10,10,10,.013)}
.cd-head{display:flex;align-items:center;justify-content:space-between}
.cd-num{
  font-family:var(--mono);font-size:11.5px;font-weight:700;color:var(--ink);
  letter-spacing:.02em;
}
.cd-holiday-dot{width:6px;height:6px;border-radius:50%;background:#E6C84A}
.cd-event{
  display:flex;align-items:center;gap:4px;
  padding:1px 6px;border-radius:5px;
  font-size:10px;font-weight:500;line-height:1.15;
  cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.cd-event .ce-dot{width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0}
.cd-event .ce-time{font-family:var(--mono);font-size:9px;font-weight:600;letter-spacing:.02em;opacity:.85}
.cd-event:hover{filter:brightness(.94)}
.cd-more{font-size:9.5px;color:var(--muted);padding:0 6px;cursor:pointer}
.cd-more:hover{color:var(--ink)}

.cal-side{display:flex;flex-direction:column;gap:14px}
.cs-block{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:14px}
.cs-block h4{font-size:11px;font-family:var(--mono);letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted-2);margin:0 0 10px;font-weight:600}
.cs-row{
  display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:center;
  padding:6px 0;cursor:pointer;
}
.cs-row .cs-square{width:10px;height:10px;border-radius:3px;background:currentColor}
.cs-row .cs-label{font-size:12px;color:var(--ink-2);font-weight:500}

/* event detail popover */
.evt-pop{
  position:absolute;z-index:90;width:300px;background:var(--surface);
  border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-2);
  padding:14px;
}
.evt-pop .ep-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.evt-pop h5{margin:0;font-size:14px;font-weight:600;letter-spacing:-0.01em}
.evt-pop .ep-meta{font-size:11.5px;color:var(--muted);margin-top:6px}
.evt-pop .ep-row{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--ink-2);margin-top:8px}

/* ──────────────────────────────────────── CHAT */
.chat-wrap{
  display:grid;grid-template-columns:300px 1fr;gap:0;
  border:1px solid var(--line);border-radius:14px;overflow:hidden;
  background:var(--surface);min-height:520px;
  /* When the dock is active, reserve room for it so the chat composer
     isn't hidden behind the floating navigation. */
  height:calc(100vh - 280px - (var(--dock-clearance, 64px) - 64px));
}
body.variant-dock .chat-wrap{ height: calc(100vh - 376px) }
.chat-side{
  background:var(--surface-2);border-right:1px solid var(--line);
  display:flex;flex-direction:column;min-height:0;
}
.chat-side-search{padding:14px;border-bottom:1px solid var(--line)}
.chat-side-list{flex:1;overflow-y:auto;padding:10px}
.chat-side-group{
  font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--muted-2);font-weight:600;padding:10px 8px 6px;
  display:flex;justify-content:space-between;align-items:center;
}
.chan-row{
  display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;
  padding:8px 10px;border-radius:8px;cursor:pointer;
  font-size:13px;color:var(--ink-2);
}
.chan-row:hover{background:rgba(0,0,0,.04)}
.chan-row.active{background:#0C0C0A;color:#fff}
.chan-row.active .chr-name{color:#fff}
.chan-row.active .chr-sub{color:rgba(255,255,255,.55)}
.chan-row .chr-mark{
  width:28px;height:28px;border-radius:8px;background:var(--surface);
  display:grid;place-items:center;font-size:13px;color:var(--ink-2);
  border:1px solid var(--line);font-weight:600;flex-shrink:0;
}
.chan-row.active .chr-mark{background:var(--lime);color:#0a0a0a;border-color:var(--lime)}
.chan-row .chr-name{font-size:13px;font-weight:500;color:var(--ink-2);letter-spacing:-0.005em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chan-row .chr-sub{font-size:11px;color:var(--muted);margin-top:1px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chan-row .chr-badge{
  font-family:var(--mono);font-size:10px;font-weight:700;
  background:var(--ink);color:var(--lime);padding:1px 6px;border-radius:5px;
  letter-spacing:.02em;
}
.chan-row.active .chr-badge{background:var(--lime);color:#0a0a0a}
.chr-mention{
  width:18px;height:18px;border-radius:50%;background:#FF5C3A;color:#fff;
  font-size:10px;font-weight:700;display:grid;place-items:center;
}
.chan-row .chr-online{
  width:8px;height:8px;border-radius:50%;background:#1F8A5B;
  border:2px solid var(--surface-2);
}

.chat-main{display:flex;flex-direction:column;min-height:0;min-width:0}
.chat-top{
  padding:14px 18px;border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:14px;
}
.chat-top h3{margin:0;font-size:15px;font-weight:600;letter-spacing:-0.01em}
.chat-top .chat-sub{font-size:11.5px;color:var(--muted)}
.chat-top .chat-actions{margin-left:auto;display:flex;gap:6px}
.chat-stream{flex:1;overflow-y:auto;padding:18px 22px;display:flex;flex-direction:column;gap:18px}
.chat-day-divider{
  display:flex;align-items:center;gap:12px;
  font-family:var(--mono);font-size:10px;color:var(--muted-2);font-weight:600;letter-spacing:.12em;
  text-transform:uppercase;margin:0 -6px;
}
.chat-day-divider::before, .chat-day-divider::after{
  content:"";flex:1;height:1px;background:var(--line);
}
.msg-row{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:flex-start}
.msg-row .msg-body{min-width:0}
.msg-row .msg-head{display:flex;align-items:baseline;gap:8px}
.msg-row .msg-name{font-size:13.5px;font-weight:600;color:var(--ink);letter-spacing:-0.005em}
.msg-row .msg-role{font-size:11px;color:var(--muted-2);font-weight:500}
.msg-row .msg-time{font-family:var(--mono);font-size:10.5px;color:var(--muted-2);letter-spacing:.02em}
.msg-row .msg-text{font-size:13.5px;color:var(--ink-2);line-height:1.55;margin-top:3px}
.msg-row .msg-mention{color:var(--lime-deep);font-weight:600;background:var(--lime-soft);padding:0 4px;border-radius:4px}
.msg-row .msg-attach{
  display:inline-flex;align-items:center;gap:10px;
  margin-top:8px;padding:8px 12px;border:1px solid var(--line);border-radius:9px;
  background:var(--surface-2);max-width:340px;cursor:pointer;
}
.msg-row .msg-attach:hover{border-color:var(--line-strong)}
.msg-row .msg-attach .ma-type{
  width:30px;height:38px;border-radius:5px;background:#0C0C0A;color:var(--lime);
  font-family:var(--mono);font-size:8.5px;font-weight:700;display:grid;place-items:center;letter-spacing:.06em;
}
.msg-row .msg-attach .ma-name{font-size:12.5px;font-weight:500;color:var(--ink-2)}
.msg-row .msg-attach .ma-size{font-family:var(--mono);font-size:10px;color:var(--muted-2);margin-top:2px;letter-spacing:.04em}
.msg-row .msg-reactions{display:flex;gap:6px;margin-top:8px}
.msg-row .msg-reactions span{
  font-size:11px;padding:2px 7px;border:1px solid var(--line);border-radius:11px;
  background:var(--surface);display:inline-flex;gap:4px;align-items:center;
  color:var(--ink-2);
}
.msg-row .msg-reactions span b{font-weight:600;color:var(--muted)}

.chat-input{
  padding:12px 16px;border-top:1px solid var(--line);
  display:flex;align-items:center;gap:10px;background:var(--surface);
}
.chat-input .ci-box{
  flex:1;display:flex;align-items:center;gap:8px;
  background:var(--surface-2);border:1px solid transparent;
  border-radius:11px;padding:10px 14px;transition:border-color .12s ease;
  position:relative;
}
.chat-input .ci-box:focus-within{border-color:var(--line-strong);background:var(--surface)}
.chat-input .ci-box input{
  flex:1;border:0;outline:0;background:transparent;font:13.5px var(--font);
  color:var(--ink);min-width:0;
}
.chat-input .ci-box input::placeholder{color:var(--muted-2)}
.chat-input .ci-tools{display:flex;gap:2px}
.chat-input .ci-send{
  width:38px;height:38px;border-radius:10px;border:0;background:var(--lime);color:#0a0a0a;
  display:grid;place-items:center;cursor:pointer;
}
.chat-input .ci-send:disabled{background:var(--surface-2);color:var(--muted-2);cursor:default}

/* mention popover */
.mention-pop{
  position:absolute;bottom:calc(100% + 6px);left:0;
  width:240px;background:var(--surface);border:1px solid var(--line);
  border-radius:10px;box-shadow:var(--shadow-2);overflow:hidden;
  font-size:13px;
}
.mention-pop .mp-head{padding:6px 12px;font-family:var(--mono);font-size:10px;color:var(--muted-2);
  letter-spacing:.12em;text-transform:uppercase;border-bottom:1px solid var(--line)}
.mention-pop .mp-row{display:flex;align-items:center;gap:10px;padding:7px 12px;cursor:pointer}
.mention-pop .mp-row:hover, .mention-pop .mp-row.active{background:var(--surface-2)}
.mention-pop .mp-row .mp-name{font-weight:600;color:var(--ink)}
.mention-pop .mp-row .mp-role{font-size:11px;color:var(--muted)}

/* ──────────────────────────────────────── DOCUMENTS */
.docs-wrap{display:grid;grid-template-columns:1fr 300px;gap:16px}
@media (max-width:1100px){.docs-wrap{grid-template-columns:1fr}}
.docs-toolbar{
  display:flex;align-items:center;gap:10px;padding:12px 14px;
  border-bottom:1px solid var(--line);flex-wrap:wrap;
}
.docs-path{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--ink-2)}
.docs-path .pa-crumb{cursor:pointer;color:var(--muted)}
.docs-path .pa-crumb:hover{color:var(--ink)}
.docs-path .pa-cur{color:var(--ink);font-weight:600}
.docs-path .pa-sep{color:var(--muted-2)}
.docs-folders{
  display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding:14px;
}
@media (max-width:1100px){.docs-folders{grid-template-columns:repeat(2,1fr)}}
.folder-card{
  background:var(--surface);border:1px solid var(--line);border-radius:11px;
  padding:14px;display:flex;align-items:center;gap:12px;cursor:pointer;
  transition:border-color .12s ease, background .12s ease;
}
.folder-card:hover{border-color:var(--line-strong);background:var(--surface-2)}
.folder-card .fc-icon{
  width:38px;height:38px;border-radius:9px;background:var(--surface-2);
  display:grid;place-items:center;color:var(--ink-2);
  position:relative;
}
.folder-card.starred .fc-icon::after{
  content:"★";position:absolute;top:-4px;right:-4px;color:#E6C84A;font-size:13px;
}
.folder-card .fc-name{font-size:13.5px;font-weight:600;color:var(--ink);letter-spacing:-0.005em}
.folder-card .fc-sub{font-size:11px;color:var(--muted);margin-top:2px;
  font-family:var(--mono);letter-spacing:.04em}

.docs-tags-bar{
  display:flex;flex-wrap:wrap;gap:6px;padding:0 14px 12px;
}
.docs-tag{
  display:inline-flex;align-items:center;gap:5px;font-size:11px;
  padding:3px 9px;border-radius:999px;border:1px solid var(--line);
  background:var(--surface);color:var(--muted);cursor:pointer;
}
.docs-tag:hover{border-color:var(--line-strong);color:var(--ink-2)}
.docs-tag.on{background:var(--ink);color:#fff;border-color:var(--ink)}

.docs-file-row{
  display:grid;grid-template-columns:36px 1fr 90px 110px 80px auto;gap:14px;
  align-items:center;padding:11px 14px;border-bottom:1px solid var(--line);font-size:13px;
}
.docs-file-row:last-child{border-bottom:0}
.docs-file-row:hover{background:var(--surface-2)}
.docs-file-row .dfr-type{
  width:32px;height:40px;border-radius:5px;background:#0C0C0A;color:var(--lime);
  font-family:var(--mono);font-size:9.5px;font-weight:700;display:grid;place-items:center;letter-spacing:.06em;
}
.docs-file-row .dfr-name{font-size:13px;font-weight:500;color:var(--ink-2)}
.docs-file-row .dfr-tags{display:flex;gap:4px;margin-top:4px;flex-wrap:wrap}
.docs-file-row .dfr-tags .tag{
  font-size:10px;padding:1px 6px;border-radius:5px;background:var(--surface-2);
  color:var(--muted);letter-spacing:.02em;
}
.docs-file-row .dfr-meta{font-family:var(--mono);font-size:10.5px;color:var(--muted-2);letter-spacing:.04em}
.docs-file-row .dfr-by{font-size:12px;color:var(--ink-2);display:flex;align-items:center;gap:6px}
.docs-file-row .dfr-size{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.04em}
.docs-file-row .dfr-star{color:#E6C84A}

.storage-bar{
  width:100%;height:8px;background:var(--surface-2);border-radius:999px;overflow:hidden;
}
.storage-bar .sb-fill{
  height:100%;background:linear-gradient(90deg,var(--lime-deep),var(--lime));border-radius:999px;
}

/* ──────────────────────────────────────── TIMESHEET */
.ts-clock{
  background:linear-gradient(135deg,#0C0C0A 0%, #1a1a16 100%);color:#fff;
  border-radius:18px;padding:28px;display:grid;grid-template-columns:1fr auto;gap:24px;
  position:relative;overflow:hidden;
}
.ts-clock::before{
  content:"";position:absolute;right:-80px;top:-80px;width:300px;height:300px;
  background:radial-gradient(circle, rgba(168,216,32,.18), transparent 60%);
}
.ts-clock-time{
  font-family:var(--mono);font-size:64px;font-weight:700;color:var(--lime);
  letter-spacing:.02em;font-variant-numeric:tabular-nums;line-height:1;
}
.ts-clock-label{font-size:12px;color:rgba(255,255,255,.55);letter-spacing:.06em;text-transform:uppercase;margin-bottom:8px}
.ts-status{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 12px;border-radius:999px;background:rgba(255,255,255,.1);
  font-size:12px;color:#fff;font-weight:500;
}
.ts-status .ts-dot{width:8px;height:8px;border-radius:50%;background:var(--lime);animation:dotPulse 2s ease-in-out infinite}
.ts-actions{display:flex;flex-direction:column;gap:10px;align-items:flex-end;z-index:1}
.ts-btn{
  appearance:none;border:0;cursor:pointer;
  padding:14px 22px;border-radius:12px;font-size:14px;font-weight:700;letter-spacing:-0.005em;
  display:inline-flex;align-items:center;gap:8px;
}
.ts-btn.primary{background:var(--lime);color:#0a0a0a}
.ts-btn.primary:hover{background:var(--lime-deep)}
.ts-btn.secondary{background:rgba(255,255,255,.1);color:#fff;backdrop-filter:blur(10px)}
.ts-btn.secondary:hover{background:rgba(255,255,255,.18)}
.ts-btn.danger{background:#FF5C3A;color:#fff}

.ts-punches{
  display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:24px;
}
.ts-punch{
  background:rgba(255,255,255,.05);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.08);border-radius:11px;padding:14px;
}
.ts-punch .tp-label{font-size:10.5px;color:rgba(255,255,255,.55);letter-spacing:.1em;text-transform:uppercase}
.ts-punch .tp-time{font-family:var(--mono);font-size:18px;font-weight:700;color:#fff;margin-top:6px;letter-spacing:.02em}
.ts-punch .tp-time.unset{color:rgba(255,255,255,.35)}
.ts-punch.done{border-color:rgba(168,216,32,.3);background:rgba(168,216,32,.06)}
.ts-punch.done .tp-time{color:var(--lime)}

.ts-totals{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:18px}

.team-punch-row{
  display:grid;grid-template-columns:auto 1fr repeat(4,90px) 110px 100px;gap:12px;align-items:center;
  padding:13px 14px;border-bottom:1px solid var(--line);font-size:13px;
}
.team-punch-row:last-child{border-bottom:0}
.team-punch-row:hover{background:var(--surface-2)}
.team-punch-row .tpr-name{font-size:13px;font-weight:500;color:var(--ink-2)}
.team-punch-row .tpr-role{font-size:11px;color:var(--muted)}
.team-punch-row .tpr-time{font-family:var(--mono);font-size:12px;color:var(--ink-2);letter-spacing:.02em;text-align:center}
.team-punch-row .tpr-time.empty{color:var(--muted-2)}
.team-punch-row .tpr-total{font-family:var(--mono);font-size:12.5px;font-weight:700;color:var(--ink);letter-spacing:.02em;text-align:right}

/* ──────────────────────────────────────── MEETINGS */
.min-row{
  background:var(--surface);border:1px solid var(--line);border-radius:12px;
  padding:16px 18px;cursor:pointer;
  display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center;
  transition:border-color .12s ease, box-shadow .12s ease, transform .12s ease;
}
.min-row + .min-row{margin-top:8px}
.min-row:hover{border-color:var(--line-strong);box-shadow:var(--shadow-1);transform:translateY(-1px)}
.min-row .mr-date{
  width:62px;height:62px;border-radius:11px;background:var(--surface-2);
  display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0;
}
.min-row .mr-date .mr-day{font-size:22px;font-weight:700;color:var(--ink);letter-spacing:-0.02em;line-height:1}
.min-row .mr-date .mr-mon{font-family:var(--mono);font-size:10px;color:var(--muted);
  text-transform:uppercase;letter-spacing:.12em;margin-top:3px}
.min-row .mr-info .mr-num{font-family:var(--mono);font-size:10px;color:var(--muted-2);
  letter-spacing:.12em;text-transform:uppercase;font-weight:600}
.min-row .mr-info .mr-title{font-size:15px;font-weight:600;color:var(--ink);letter-spacing:-0.01em;margin-top:3px}
.min-row .mr-info .mr-meta{display:flex;gap:14px;font-size:12px;color:var(--muted);margin-top:6px;align-items:center}
.min-row .mr-stats{display:flex;flex-direction:column;align-items:flex-end;gap:6px}

.min-section{margin-bottom:24px}
.min-section h3{
  font-size:13px;font-weight:600;letter-spacing:-0.005em;color:var(--ink);margin:0 0 12px;
  display:flex;align-items:center;gap:10px;
}
.min-section h3::before{
  content:"";width:18px;height:1px;background:var(--ink);
}
.min-list{display:flex;flex-direction:column;gap:6px}
.min-list .ml-item{
  display:grid;grid-template-columns:auto 1fr;gap:10px;font-size:13.5px;color:var(--ink-2);line-height:1.55;
  padding:6px 0;
}
.min-list .ml-item .ml-num{
  font-family:var(--mono);font-size:11px;color:var(--muted-2);font-weight:600;
  letter-spacing:.06em;line-height:1.6;
}
.min-action{
  display:grid;grid-template-columns:auto 1fr auto auto;gap:12px;align-items:center;
  padding:11px 14px;border:1px solid var(--line);border-radius:10px;background:var(--surface);
}
.min-action + .min-action{margin-top:6px}
.min-action .ma-num{font-family:var(--mono);font-size:11px;color:var(--muted-2);font-weight:700;letter-spacing:.04em}
.min-action .ma-task{font-size:13.5px;font-weight:500;color:var(--ink-2);letter-spacing:-0.005em}
.min-action .ma-due{font-family:var(--mono);font-size:11.5px;color:var(--ink-2);letter-spacing:.02em}

/* ──────────────────────────────────────── FINANCE */
.fin-summary{
  display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:18px;
}
@media (max-width:1100px){.fin-summary{grid-template-columns:repeat(2,1fr)}}
.fin-card{
  background:var(--surface);border:1px solid var(--line);border-radius:14px;
  padding:18px;display:flex;flex-direction:column;gap:8px;position:relative;overflow:hidden;
}
.fin-card .fc-label{
  font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--muted-2);display:flex;align-items:center;gap:6px;font-weight:600;
}
.fin-card .fc-val{font-size:24px;font-weight:700;letter-spacing:-0.02em;font-variant-numeric:tabular-nums;color:var(--ink)}
.fin-card .fc-sub{font-size:11.5px;color:var(--muted)}
.fin-card.income .fc-val{color:#1F8A5B}
.fin-card.expense .fc-val{color:#C45A2E}
.fin-card.balance{
  background:linear-gradient(135deg,#0C0C0A 0%, #1a1a16 100%);color:#fff;border-color:transparent;
}
.fin-card.balance .fc-label{color:rgba(255,255,255,.55)}
.fin-card.balance .fc-val{color:var(--lime)}
.fin-card.balance .fc-sub{color:rgba(255,255,255,.7)}

.fin-trend{
  height:160px;position:relative;
  display:grid;grid-template-columns:repeat(6,1fr);gap:14px;align-items:end;
}
.fin-trend-col{
  display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;
}
.fin-trend-col .ft-bars{
  flex:1;width:100%;display:flex;align-items:end;gap:4px;padding:6px;background:var(--surface-2);
  border-radius:9px;position:relative;
}
.fin-trend-col .ft-bar{
  flex:1;border-radius:5px 5px 2px 2px;transition:height .4s ease;position:relative;
}
.fin-trend-col .ft-bar.income{background:linear-gradient(180deg,var(--lime) 0%, var(--lime-deep) 100%)}
.fin-trend-col .ft-bar.expense{background:linear-gradient(180deg,#3a3a35 0%, #0C0C0A 100%)}
.fin-trend-col .ft-bar.current{box-shadow:0 0 0 2px var(--bg), 0 0 0 3px var(--ink)}
.fin-trend-col .ft-label{font-family:var(--mono);font-size:10px;color:var(--muted-2);letter-spacing:.04em}
.fin-trend-col.cur .ft-label{color:var(--ink);font-weight:600}

.fin-row{
  display:grid;grid-template-columns:34px 1fr 200px 110px 110px 110px;gap:14px;align-items:center;
  padding:12px 14px;border-bottom:1px solid var(--line);font-size:13px;
}
.fin-row:last-child{border-bottom:0}
.fin-row:hover{background:var(--surface-2)}
.fin-row .fr-type{
  width:30px;height:30px;border-radius:8px;display:grid;place-items:center;
  font-weight:700;font-size:13px;
}
.fin-row .fr-type.income{background:#D6EFE0;color:#155a35}
.fin-row .fr-type.expense{background:#FFE0D6;color:#7a2a00}
.fin-row .fr-desc{font-size:13.5px;font-weight:500;color:var(--ink-2)}
.fin-row .fr-meta{font-size:11px;color:var(--muted);margin-top:3px;display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.fin-row .fr-cat{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-2)}
.fin-row .fr-cat .fr-dot{width:8px;height:8px;border-radius:50%;background:currentColor}
.fin-row .fr-date{font-family:var(--mono);font-size:11.5px;color:var(--ink-2);letter-spacing:.02em}
.fin-row .fr-date small{display:block;font-size:10px;color:var(--muted);font-family:var(--mono);letter-spacing:.04em;margin-top:2px}
.fin-row .fr-val{font-family:var(--mono);font-size:14px;font-weight:700;letter-spacing:.01em;text-align:right;font-variant-numeric:tabular-nums}
.fin-row .fr-val.income{color:#1F8A5B}
.fin-row .fr-val.expense{color:#C45A2E}

.cat-row{
  display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;
  padding:8px 0;
}
.cat-row .ca-mark{width:10px;height:10px;border-radius:50%;background:currentColor}
.cat-row .ca-name{font-size:13px;color:var(--ink-2);font-weight:500}
.cat-row .ca-val{font-family:var(--mono);font-size:13px;font-weight:700;letter-spacing:.01em}
.cat-bar{
  height:8px;border-radius:999px;background:var(--surface-2);overflow:hidden;margin-top:4px;
}
.cat-bar .cb-fill{height:100%;border-radius:999px;background:currentColor}

/* ──────────────────────────────────────── PEOPLE */
.person-row{
  display:grid;grid-template-columns:auto 1fr 130px 110px 120px auto;gap:16px;align-items:center;
  padding:13px 14px;cursor:pointer;border-radius:11px;
  border:1px solid var(--line);background:var(--surface);
}
.person-row + .person-row{margin-top:6px}
.person-row:hover{background:var(--surface-2);border-color:var(--line-strong)}
.person-row.inactive{opacity:.62}
.person-row .pr-name{font-size:13.5px;font-weight:600;color:var(--ink);letter-spacing:-0.005em}
.person-row .pr-sub{font-size:11px;color:var(--muted);margin-top:2px}
.person-row .pr-meta{font-size:11.5px;color:var(--muted-2)}
.person-row .pr-meta b{color:var(--ink-2);font-weight:600;display:block;font-size:12px}

.person-head{
  display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center;
  padding:24px;background:var(--surface);border:1px solid var(--line);border-radius:14px;margin-bottom:18px;
}
.person-head .ph-av{
  width:72px;height:72px;border-radius:18px;background:#0C0C0A;color:var(--lime);
  display:grid;place-items:center;font-weight:700;font-size:24px;
  box-shadow:0 0 0 4px var(--bg), 0 0 0 5px var(--line);
}
.person-head .ph-stats{display:flex;gap:32px}
.person-head .ph-stats .ps-block .lbl{margin-bottom:6px}
.person-head .ph-stats .ps-block .val{font-size:18px;font-weight:700;letter-spacing:-0.02em}
.person-head .ph-stats .ps-block .sub{font-size:11.5px;color:var(--muted);margin-top:2px}

.salary-row{
  display:grid;grid-template-columns:1fr 140px 140px 80px;gap:12px;align-items:center;
  padding:11px 14px;border-bottom:1px solid var(--line);font-size:13px;
}
.salary-row:last-child{border-bottom:0}
.salary-row.current{background:var(--lime-soft)}
.salary-row .sr-label{font-size:13px;font-weight:500;color:var(--ink-2)}
.salary-row .sr-date{font-family:var(--mono);font-size:11.5px;color:var(--ink-2);letter-spacing:.02em}
.salary-row .sr-val{font-family:var(--mono);font-size:14px;font-weight:700;text-align:right;letter-spacing:.02em}
.salary-row .sr-delta{font-family:var(--mono);font-size:11px;color:#1F8A5B;text-align:right;font-weight:600}

.leave-row{
  display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;
  padding:12px 14px;border-bottom:1px solid var(--line);font-size:13px;
}
.leave-row:last-child{border-bottom:0}
.leave-row .lr-icon{
  width:34px;height:34px;border-radius:9px;background:var(--surface-2);
  display:grid;place-items:center;color:var(--ink-2);
}
.leave-row .lr-period{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.02em}
.leave-row .lr-days{
  font-family:var(--mono);font-size:11.5px;color:var(--ink-2);font-weight:700;
  background:var(--surface-2);padding:4px 10px;border-radius:7px;letter-spacing:.02em;
}

/* ──────────────────────────────────────── SETTINGS */
.settings-grid{
  display:grid;grid-template-columns:240px 1fr;gap:20px;
}
@media (max-width:900px){.settings-grid{grid-template-columns:1fr}}

.settings-nav{display:flex;flex-direction:column;gap:2px;position:sticky;top:128px;align-self:start}
.sn-item{
  appearance:none;border:0;background:transparent;text-align:left;
  display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:center;
  padding:9px 12px;border-radius:9px;cursor:pointer;color:var(--ink-2);
  font-size:13.5px;font-weight:500;letter-spacing:-0.005em;
}
.sn-item:hover{background:var(--surface-2)}
.sn-item.active{background:#0C0C0A;color:#fff}
.sn-item.active .sn-icon{color:var(--lime)}
.sn-item .sn-icon{color:var(--muted)}
.sn-item .sn-sub{font-size:11px;color:var(--muted-2);margin-top:2px}
.sn-item.active .sn-sub{color:rgba(255,255,255,.55)}
.sn-section{
  font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted-2);font-weight:600;padding:14px 12px 4px;
}

.set-field{
  display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--line);
}
.set-field:last-child{border-bottom:0}
.set-field .sf-label{flex:0 0 200px}
.set-field .sf-label .name{font-size:13.5px;font-weight:500;color:var(--ink);letter-spacing:-0.005em}
.set-field .sf-label .hint{font-size:11.5px;color:var(--muted);margin-top:3px}
.set-field .sf-control{flex:1;min-width:0}

.set-input{
  width:100%;padding:9px 12px;border:1px solid var(--line);background:var(--surface);
  border-radius:9px;font:13px var(--font);color:var(--ink);
}
.set-input:focus{outline:0;border-color:var(--ink);box-shadow:0 0 0 3px rgba(168,216,32,.18)}

.user-row{
  display:grid;grid-template-columns:auto 1fr 130px 130px 110px auto;gap:14px;align-items:center;
  padding:13px 14px;border-bottom:1px solid var(--line);font-size:13px;
}
.user-row:last-child{border-bottom:0}
.user-row:hover{background:var(--surface-2)}
.user-row .ur-name{font-size:13px;font-weight:600;color:var(--ink-2)}
.user-row .ur-role{font-size:11px;color:var(--muted)}
.user-row .ur-meta{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.04em}

.role-chip{
  display:inline-flex;align-items:center;gap:6px;
  padding:3px 9px;border-radius:6px;font-size:11px;font-weight:600;letter-spacing:.01em;
}
.role-chip.admin{background:#0C0C0A;color:var(--lime)}
.role-chip.collaborator{background:var(--surface-2);color:var(--ink-2)}

.role-row{
  display:grid;grid-template-columns:1fr auto auto auto;gap:14px;align-items:center;
  padding:13px 14px;border-bottom:1px solid var(--line);font-size:13px;
}
.role-row:last-child{border-bottom:0}
.role-row:hover{background:var(--surface-2)}
.role-row .rr-name{font-size:13.5px;font-weight:600;color:var(--ink-2)}
.role-row .rr-sub{font-size:11px;color:var(--muted);margin-top:2px}
.role-row .rr-hours{font-family:var(--mono);font-size:13px;color:var(--ink-2);font-weight:700;letter-spacing:.02em}
.role-row .rr-count{
  font-family:var(--mono);font-size:11.5px;background:var(--surface-2);
  padding:3px 9px;border-radius:5px;color:var(--muted);font-weight:600;letter-spacing:.04em;
}

.tpl-card{
  background:var(--surface);border:1px solid var(--line);border-radius:14px;
  padding:18px;display:flex;flex-direction:column;gap:14px;cursor:pointer;
  transition:border-color .12s ease, box-shadow .12s ease, transform .12s ease;
}
.tpl-card:hover{border-color:var(--line-strong);box-shadow:var(--shadow-1);transform:translateY(-1px)}
.tpl-card .tc-tag{
  font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted-2);font-weight:600;
}
.tpl-card .tc-name{font-size:16px;font-weight:600;letter-spacing:-0.01em;color:var(--ink);line-height:1.2}
.tpl-card .tc-scope{font-size:12px;color:var(--muted);margin-top:3px}
.tpl-card .tc-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:10px;
  padding:12px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.tpl-card .tc-stat{font-size:11.5px;color:var(--muted)}
.tpl-card .tc-stat b{display:block;font-family:var(--mono);font-size:16px;font-weight:700;color:var(--ink);letter-spacing:-0.005em}
.tpl-card .tc-used{font-size:11px;color:var(--muted-2);font-family:var(--mono);letter-spacing:.04em}

.report-row{
  display:grid;grid-template-columns:auto 1fr auto auto;gap:16px;align-items:center;
  padding:14px 14px;border:1px solid var(--line);border-radius:11px;background:var(--surface);cursor:pointer;
  transition:border-color .12s ease, box-shadow .12s ease, transform .12s ease;
}
.report-row + .report-row{margin-top:6px}
.report-row:hover{border-color:var(--line-strong);box-shadow:var(--shadow-1)}
.report-row .rp-icon{
  width:42px;height:42px;border-radius:11px;background:var(--surface-2);
  display:grid;place-items:center;color:var(--ink-2);
}
.report-row .rp-name{font-size:14px;font-weight:600;color:var(--ink);letter-spacing:-0.005em}
.report-row .rp-desc{font-size:12px;color:var(--muted);margin-top:3px}

/* ──────────────────────────────────────── ArqIA · floating assistant */
.arqia-fab{
  position:fixed; right:24px; bottom:100px; z-index:80;
  display:inline-flex; align-items:center; gap:8px;
  height:44px; padding:0 16px 0 14px;
  background:#0C0C0A; color:#fff;
  border:0; border-radius:999px; cursor:pointer;
  font:600 13px/1 var(--font); letter-spacing:-0.005em;
  box-shadow: 0 16px 36px -10px rgba(10,10,10,.45), 0 4px 14px -4px rgba(10,10,10,.25);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.arqia-fab svg{ color:var(--lime) }
.arqia-fab:hover{ transform: translateY(-1px); background:#1a1a18 }
.arqia-fab:active{ transform: translateY(0) }
.arqia-fab.open{ transform: scale(.96); opacity:.85 }
.arqia-fab-label{ letter-spacing:.02em }
@media (max-width:720px){
  .arqia-fab{ right:16px; bottom:92px; padding:0 14px 0 12px; height:42px }
}
body:not(.variant-dock) .arqia-fab{ bottom:24px }

.arqia-scrim{
  position:fixed; inset:0; z-index:78;
  background:transparent;
}
@media (max-width:720px){
  .arqia-scrim{ background:rgba(10,10,10,.30); backdrop-filter:blur(2px); -webkit-backdrop-filter:blur(2px) }
}

.arqia-panel{
  position:fixed; right:16px; top:88px;
  width:420px; max-width:calc(100vw - 32px);
  bottom: calc(var(--dock-clearance, 64px) + 16px);
  background:var(--surface); color:var(--ink);
  border:1px solid var(--line); border-radius:18px;
  box-shadow: 0 28px 60px -18px rgba(10,10,10,.45), 0 8px 24px -8px rgba(10,10,10,.25);
  z-index:79; display:flex; flex-direction:column; overflow:hidden;
  animation: arqia-in .16s ease-out;
}
@keyframes arqia-in{
  from{ opacity:0; transform: translateY(8px) }
  to  { opacity:1; transform: translateY(0) }
}
@media (max-width:720px){
  .arqia-panel{ right:0; left:0; top:0; bottom:0; width:auto; max-width:100%; border-radius:0; border:0 }
}

.arqia-head{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 16px; border-bottom:1px solid var(--line);
  background:linear-gradient(180deg, var(--surface) 0%, var(--surface-2) 100%);
}
.arqia-title{ font-size:14px; font-weight:700; letter-spacing:-0.01em }
.arqia-sub{ font-size:11.5px; color:var(--muted); margin-top:2px }
.arqia-icobtn{
  appearance:none; background:transparent; border:1px solid var(--line); cursor:pointer;
  width:28px; height:28px; border-radius:8px;
  display:grid; place-items:center; color:var(--ink-2);
}
.arqia-icobtn:hover{ background:var(--surface-2) }

.arqia-stream{
  flex:1; overflow-y:auto; padding:16px;
  display:flex; flex-direction:column; gap:10px;
  background:var(--surface);
}

.arqia-empty{
  margin-top:6px;
}
.arqia-empty-title{
  font-size:14px; font-weight:600; letter-spacing:-0.01em; color:var(--ink-2); margin-bottom:6px;
}
.arqia-empty-sub{
  font-size:12.5px; color:var(--muted); line-height:1.5; margin-bottom:14px;
}
.arqia-suggestions{ display:flex; flex-direction:column; gap:6px }
.arqia-sugg{
  appearance:none; border:1px solid var(--line); background:var(--surface-2);
  padding:10px 12px; border-radius:10px; cursor:pointer;
  text-align:left; font:500 12.5px/1.35 var(--font); color:var(--ink-2);
  transition: background .14s ease, border-color .14s ease;
}
.arqia-sugg:hover{ background:#fff; border-color:var(--line-strong); color:var(--ink) }

.arqia-msg{ display:flex }
.arqia-msg.me{ justify-content:flex-end }
.arqia-msg.bot{ justify-content:flex-start }
.arqia-bubble{
  max-width:86%; padding:10px 12px; border-radius:12px;
  font:400 13px/1.45 var(--font); color:var(--ink); white-space:pre-wrap; word-wrap:break-word;
}
.arqia-msg.me .arqia-bubble{
  background:var(--lime); color:#0a0a0a; border-bottom-right-radius:4px;
  font-weight:500;
}
.arqia-msg.bot .arqia-bubble{
  background:var(--surface-2); border:1px solid var(--line); border-bottom-left-radius:4px;
}
.arqia-typing{ display:inline-flex; align-items:center; gap:4px; padding:12px 14px }
.arqia-typing span{
  width:6px; height:6px; border-radius:50%; background:var(--muted);
  animation: arqia-blink 1.2s infinite ease-in-out;
}
.arqia-typing span:nth-child(2){ animation-delay:.15s }
.arqia-typing span:nth-child(3){ animation-delay:.30s }
@keyframes arqia-blink{
  0%,80%,100%{ opacity:.3; transform:translateY(0) }
  40%{ opacity:1; transform:translateY(-2px) }
}

.arqia-error{
  background:rgba(255,92,58,.08); border:1px solid rgba(255,92,58,.25);
  border-radius:10px; padding:10px 12px; color:#7a2a00;
  font-size:12.5px; line-height:1.5;
}
.arqia-error-msg{ font-weight:500 }
.arqia-error-cta{
  appearance:none; margin-top:8px; background:#0C0C0A; color:#fff;
  border:0; border-radius:8px; padding:6px 12px; font:600 12px var(--font); cursor:pointer;
}
.arqia-error-cta:hover{ background:#1a1a18 }

.arqia-footer{
  padding:8px 16px; border-top:1px solid var(--line);
  background:var(--surface-2);
  font:500 11px/1 var(--mono); letter-spacing:.02em; color:var(--muted-2);
}

.arqia-input{
  padding:10px; border-top:1px solid var(--line);
  display:flex; gap:8px; align-items:flex-end; background:var(--surface);
}
.arqia-input textarea{
  flex:1; resize:none; border:1px solid var(--line); border-radius:10px;
  background:var(--surface-2); color:var(--ink);
  font:400 13px/1.4 var(--font); padding:10px 12px; min-height:42px; max-height:140px;
  outline:none;
}
.arqia-input textarea:focus{ border-color:var(--ink-2); background:#fff }
.arqia-input textarea:disabled{ opacity:.5; cursor:not-allowed }
.arqia-send{
  appearance:none; border:0; background:var(--lime); color:#0a0a0a;
  width:42px; height:42px; border-radius:10px; cursor:pointer;
  display:grid; place-items:center; flex-shrink:0;
  transition: background .14s ease, transform .12s ease;
}
.arqia-send:hover:not(:disabled){ background:var(--lime-deep) }
.arqia-send:active{ transform: scale(.95) }
.arqia-send:disabled{ opacity:.4; cursor:not-allowed }

/* ArqIA — markdown rendering inside bot bubbles. Mantém o ritmo visual
   das bolhas sem que parágrafos/listas explodam o espaçamento. */
.arqia-bubble.arqia-md p{ margin:0 0 6px }
.arqia-bubble.arqia-md p:last-child{ margin-bottom:0 }
.arqia-bubble.arqia-md ul{ margin:4px 0 6px; padding-left:18px }
.arqia-bubble.arqia-md ul:last-child{ margin-bottom:0 }
.arqia-bubble.arqia-md li{ margin:2px 0; line-height:1.45 }
.arqia-bubble.arqia-md strong{ font-weight:600; color:var(--ink) }
.arqia-bubble.arqia-md em{ font-style:italic; color:var(--ink-2) }
