/* Ático — Design System */

:root {
  --bg: #F5F1EA;
  --bg-panel: #FBF8F2;
  --bg-card: #FFFFFF;
  --ink: #1A1715;
  --ink-soft: #4A443F;
  --ink-mute: #8A8279;
  --line: #E8E2D6;
  --line-soft: #EFEAE0;
  --accent: #2D4A3E;
  --accent-soft: #E6EDE8;
  --accent-ink: #1E3329;
  --warn: #B8563E;
  --warn-soft: #F5E4DD;
  --gold: #9A7B3E;
  --gold-soft: #F0E7D1;
  --success: #4F7A63;
  --success-soft: #DDE9E0;
  --shadow-md: 0 4px 20px rgba(26,23,21,0.06), 0 1px 3px rgba(26,23,21,0.04);
  --shadow-lg: 0 20px 50px -20px rgba(26,23,21,0.18);
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
  font-family: 'Geist', -apple-system, BlinkMacSystemFont, sans-serif;
  background: var(--bg);
  color: var(--ink);
  font-size: 14px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ===== AUTH PAGE ===== */
.auth-shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.auth-left {
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-ink) 100%);
  color: var(--bg);
  padding: 48px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
  overflow: hidden;
}

.auth-left::before {
  content: '';
  position: absolute;
  right: -80px;
  top: -80px;
  width: 340px;
  height: 340px;
  background: radial-gradient(circle, rgba(255,255,255,0.08) 0%, transparent 70%);
  border-radius: 50%;
}

.auth-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  position: relative;
}

.auth-brand-mark {
  width: 40px;
  height: 40px;
  background: var(--bg);
  color: var(--accent);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Fraunces', serif;
  font-size: 24px;
  font-weight: 500;
}

.auth-brand-text {
  font-family: 'Fraunces', serif;
  font-size: 24px;
  font-weight: 400;
  letter-spacing: -0.02em;
}

.auth-hero { position: relative; }

.auth-hero h1 {
  font-family: 'Fraunces', serif;
  font-size: 48px;
  font-weight: 400;
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin-bottom: 16px;
}

.auth-hero h1 em {
  font-style: italic;
  color: var(--gold-soft);
  font-weight: 300;
}

.auth-hero p {
  font-size: 15px;
  color: rgba(245,241,234,0.75);
  max-width: 380px;
  line-height: 1.6;
}

.auth-foot { font-size: 12px; color: rgba(245,241,234,0.5); position: relative; }

.auth-right {
  padding: 48px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.auth-form { width: 100%; max-width: 380px; }

.auth-eyebrow {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--ink-mute);
  font-weight: 500;
  margin-bottom: 8px;
}

.auth-title {
  font-family: 'Fraunces', serif;
  font-size: 32px;
  font-weight: 400;
  letter-spacing: -0.02em;
  margin-bottom: 8px;
}

.auth-subtitle { color: var(--ink-soft); margin-bottom: 28px; }

.field { display: block; margin-bottom: 16px; }

.field-label {
  display: block;
  font-size: 12px;
  color: var(--ink-soft);
  margin-bottom: 6px;
  font-weight: 500;
}

.field-input, .field-select, .field-textarea {
  width: 100%;
  padding: 10px 14px;
  border: 1px solid var(--line);
  border-radius: 7px;
  background: var(--bg-card);
  font: inherit;
  color: var(--ink);
  outline: none;
  transition: border-color 0.15s;
  font-family: inherit;
}

.field-input:focus, .field-select:focus, .field-textarea:focus {
  border-color: var(--ink);
}

.field-textarea { resize: vertical; min-height: 70px; }

.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }

/* ===== BUTTONS ===== */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 8px 14px;
  font-size: 13px;
  font-weight: 500;
  border-radius: 7px;
  border: 1px solid var(--line);
  background: var(--bg-card);
  color: var(--ink);
  cursor: pointer;
  transition: all 0.15s;
  font-family: inherit;
}

.btn:hover { border-color: var(--ink-mute); }
.btn:disabled { opacity: 0.5; cursor: not-allowed; }

.btn-primary {
  background: var(--ink);
  color: var(--bg);
  border-color: var(--ink);
}

.btn-primary:hover { background: var(--accent-ink); border-color: var(--accent-ink); }

.btn-block { width: 100%; padding: 12px 18px; }
.btn svg { width: 14px; height: 14px; }

.btn-sm { padding: 4px 10px; font-size: 12px; }
.btn-danger { color: var(--warn); border-color: var(--warn-soft); }
.btn-danger:hover { background: var(--warn-soft); }

.auth-switch {
  margin-top: 22px;
  padding-top: 22px;
  border-top: 1px solid var(--line);
  font-size: 13px;
  color: var(--ink-soft);
  text-align: center;
}

.auth-switch a {
  color: var(--accent);
  font-weight: 500;
  text-decoration: none;
  cursor: pointer;
}

.auth-switch a:hover { text-decoration: underline; }

.auth-error {
  background: var(--warn-soft);
  color: var(--warn);
  padding: 10px 14px;
  border-radius: 6px;
  font-size: 13px;
  margin-bottom: 16px;
  display: none;
}

.auth-error.show { display: block; }

/* ===== APP SHELL ===== */
body.app {
  display: grid;
  grid-template-columns: 248px 1fr;
  height: 100vh;
  overflow: hidden;
  transition: grid-template-columns .25s ease;
}

.sidebar {
  background: var(--bg-panel);
  border-right: 1px solid var(--line);
  padding: 24px 16px;
  display: flex;
  flex-direction: column;
  height: 100vh;
  overflow-y: auto;
  overflow-x: hidden;
  flex-shrink: 0;
  transition: width .25s ease, padding .25s ease;
}

.brand {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 4px 8px;
  margin-bottom: 32px;
}

.brand-mark {
  width: 32px;
  height: 32px;
  background: var(--accent);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--bg);
  font-family: 'Fraunces', serif;
  font-size: 20px;
  font-weight: 500;
}

.brand-name {
  font-family: 'Fraunces', serif;
  font-size: 20px;
  font-weight: 500;
  letter-spacing: -0.02em;
}

.brand-tag {
  font-size: 10px;
  color: var(--ink-mute);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  margin-top: -2px;
}

.nav-section { margin-bottom: 24px; }

.nav-title {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--ink-mute);
  padding: 0 10px;
  margin-bottom: 6px;
  font-weight: 500;
}

.nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 6px;
  color: var(--ink-soft);
  font-size: 13.5px;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
  user-select: none;
  font-weight: 450;
}

.nav-item:hover { background: var(--line-soft); color: var(--ink); }
.nav-item.active { background: var(--ink); color: var(--bg); }
.nav-item svg { width: 16px; height: 16px; flex-shrink: 0; }

.sidebar-footer {
  margin-top: auto;
  padding-top: 16px;
  border-top: 1px solid var(--line);
}

.user-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 8px;
}

.avatar {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--gold), var(--warn));
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--bg);
  font-weight: 500;
  font-size: 12px;
  flex-shrink: 0;
}

.user-meta { flex: 1; min-width: 0; }
.user-name { font-size: 13px; font-weight: 500; }
.user-org { font-size: 11px; color: var(--ink-mute); }

.logout-btn {
  width: 100%;
  margin-top: 8px;
  padding: 6px;
  background: transparent;
  border: none;
  color: var(--ink-mute);
  font-size: 11px;
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-family: inherit;
}

.logout-btn:hover { color: var(--warn); }

.main {
  overflow-y: auto;
  overflow-x: hidden;
  height: 100vh;
}

.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 40px;
  border-bottom: 1px solid var(--line);
  background: var(--bg);
  position: sticky;
  top: 0;
  z-index: 10;
}

.breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--ink-mute);
}

.breadcrumb .current { color: var(--ink); font-weight: 500; }

.top-actions { display: flex; align-items: center; gap: 8px; }

.page {
  padding: 32px 40px 64px;
  display: none;
}

.page.active { display: block; animation: fadeIn 0.3s ease; }

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}

.page-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 32px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--line);
}

.page-eyebrow {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--ink-mute);
  font-weight: 500;
}

.page-title {
  font-family: 'Fraunces', serif;
  font-size: 36px;
  font-weight: 400;
  letter-spacing: -0.02em;
  line-height: 1.1;
}

.page-title em {
  font-style: italic;
  font-weight: 300;
  color: var(--accent);
}

.page-subtitle {
  font-size: 14px;
  color: var(--ink-soft);
  margin-top: 8px;
  max-width: 540px;
}

/* ===== KPI GRID ===== */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 32px;
}

.kpi {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 18px 20px;
}

.kpi-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-mute);
  font-weight: 500;
  margin-bottom: 10px;
}

.kpi-value {
  font-family: 'Fraunces', serif;
  font-size: 30px;
  font-weight: 400;
  letter-spacing: -0.02em;
  line-height: 1;
}

.kpi-value .currency {
  font-size: 16px;
  color: var(--ink-mute);
  margin-right: 4px;
}

.kpi-footer { font-size: 11px; color: var(--ink-mute); margin-top: 8px; }

/* ===== PANELS ===== */
.panel {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: 10px;
  overflow: visible;
  margin-bottom: 24px;
}

.panel-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 18px 22px;
  border-bottom: 1px solid var(--line-soft);
}

.panel-title {
  font-family: 'Fraunces', serif;
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.01em;
}

.panel-title-sub { font-size: 12px; color: var(--ink-mute); margin-top: 2px; }
.panel-body { padding: 22px; }

/* ===== TABLES ===== */
table { width: 100%; border-collapse: collapse; }

th {
  text-align: left;
  padding: 10px 22px;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-mute);
  font-weight: 500;
  background: var(--bg-panel);
  border-bottom: 1px solid var(--line);
}

th:last-child, td:last-child { text-align: right; }

td {
  padding: 14px 22px;
  border-bottom: 1px solid var(--line-soft);
  font-size: 13px;
  vertical-align: middle;
}

tr:last-child td { border-bottom: none; }
tr:hover td { background: var(--bg-panel); }

.cell-primary { font-weight: 500; }
.cell-mono {
  font-family: 'Geist Mono', monospace;
  font-size: 12.5px;
  font-variant-numeric: tabular-nums;
}

.cell-amount {
  font-family: 'Geist Mono', monospace;
  font-variant-numeric: tabular-nums;
  font-weight: 500;
}

.status {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  padding: 3px 8px;
  border-radius: 4px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.status::before {
  content: '';
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: currentColor;
}

.status.paid, .status.received, .status.active { background: var(--success-soft); color: var(--success); }
.status.pending { background: var(--gold-soft); color: var(--gold); }
.status.overdue { background: var(--warn-soft); color: var(--warn); }
.status.scheduled { background: var(--accent-soft); color: var(--accent); }
.status.vacation { background: var(--gold-soft); color: var(--gold); }
.status.leave { background: var(--warn-soft); color: var(--warn); }

.entity-cell { display: flex; align-items: center; gap: 10px; }

.entity-mark {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  background: linear-gradient(135deg, var(--accent), var(--success));
  color: var(--bg);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 500;
  flex-shrink: 0;
}

.entity-sub { font-size: 11px; color: var(--ink-mute); margin-top: 1px; }

/* ===== MODAL ===== */
.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(26,23,21,0.5);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 50;
  backdrop-filter: blur(4px);
}

.modal-backdrop.open { display: flex; }

.modal {
  background: var(--bg-card);
  border-radius: 14px;
  width: 560px;
  max-width: 90vw;
  max-height: 90vh;
  overflow: auto;
  box-shadow: var(--shadow-lg);
}

.modal-head { padding: 24px 28px; border-bottom: 1px solid var(--line); }

.modal-title {
  font-family: 'Fraunces', serif;
  font-size: 22px;
  font-weight: 400;
  letter-spacing: -0.01em;
}

.modal-subtitle { font-size: 13px; color: var(--ink-soft); margin-top: 4px; }
.modal-body { padding: 24px 28px; }

.modal-foot {
  padding: 16px 28px;
  border-top: 1px solid var(--line);
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  background: var(--bg-panel);
}

.upload-area {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border: 2px dashed var(--line);
  border-radius: 10px;
  padding: 40px 20px;
  text-align: center;
  cursor: pointer;
  transition: all 0.15s;
}

.upload-area:hover, .upload-area.dragover {
  border-color: var(--accent);
  background: var(--accent-soft);
}

.upload-area strong { display: block; margin-bottom: 4px; font-weight: 500; }
.upload-area span { font-size: 12px; color: var(--ink-mute); }

.preview-table {
  margin-top: 20px;
  max-height: 300px;
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 8px;
}

.preview-table table th, .preview-table table td { padding: 8px 12px; }

/* ===== AUTOMATIONS ===== */
.auto-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.auto-card {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 22px;
  cursor: pointer;
  transition: all 0.2s;
}

.auto-card:hover {
  border-color: var(--ink);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.auto-card-icon {
  width: 40px;
  height: 40px;
  border-radius: 8px;
  background: var(--accent-soft);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
  font-family: 'Fraunces', serif;
  font-size: 22px;
  color: var(--accent);
}

.auto-card-title {
  font-family: 'Fraunces', serif;
  font-size: 17px;
  font-weight: 500;
  letter-spacing: -0.01em;
  margin-bottom: 6px;
}

.auto-card-desc {
  font-size: 13px;
  color: var(--ink-soft);
  line-height: 1.5;
}

/* ===== MISC ===== */
.loading { color: var(--ink-mute); padding: 40px; text-align: center; }

.toast {
  position: fixed;
  bottom: 24px;
  right: 24px;
  background: var(--ink);
  color: var(--bg);
  padding: 14px 20px;
  border-radius: 8px;
  font-size: 13px;
  box-shadow: var(--shadow-lg);
  display: none;
  z-index: 100;
  max-width: 400px;
}

.toast.show { display: block; animation: slideUp 0.3s ease; }
.toast.success { background: var(--success); }
.toast.error { background: var(--warn); }

@keyframes slideUp {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

.emp-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}

.emp-card {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 20px;
  text-align: center;
}

.emp-avatar {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  margin: 0 auto 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Fraunces', serif;
  font-size: 22px;
  color: var(--bg);
  background: linear-gradient(135deg, var(--accent), var(--success));
}

.emp-name { font-weight: 500; font-size: 14px; }
.emp-role { font-size: 12px; color: var(--ink-mute); margin-top: 2px; }
.emp-dept {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-mute);
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--line-soft);
}

@media (max-width: 1100px) {
  body.app { grid-template-columns: 1fr; }
  .sidebar { display: none; }
  .kpi-grid { grid-template-columns: repeat(2, 1fr); }
  .auto-grid { grid-template-columns: 1fr 1fr; }
  .emp-grid { grid-template-columns: repeat(2, 1fr); }
  .auth-shell { grid-template-columns: 1fr; }
  .auth-left { display: none; }
}

::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--line); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--ink-mute); }

.form-section-title {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--ink-mute);
  font-weight: 500;
  margin: 18px 0 10px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--line-soft);
}
.preview-table {
  max-height: 300px;
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 8px;
}
.preview-table table th,
.preview-table table td { padding: 8px 12px; }
.ptab { animation: fadeIn 0.2s ease; }


/* ===== STATUS SELECT (colorido) ===== */
.status-select {
  -webkit-appearance: none;
  appearance: none;
  padding: 3px 20px 3px 8px;
  border-radius: 4px;
  border: none;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
  cursor: pointer;
  font-family: inherit;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='5'%3E%3Cpath d='M0 0l4 5 4-5z' fill='currentColor' opacity='.6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 5px center;
  outline: none;
}
.status-select.active    { background-color: var(--success-soft); color: var(--success); }
.status-select.vacation  { background-color: var(--gold-soft);    color: var(--gold); }
.status-select.leave     { background-color: var(--warn-soft);    color: var(--warn); }
.status-select.terminated{ background-color: var(--line-soft);    color: var(--ink-mute); }

/* ===== KPI CLICKABLE FILTER ===== */
.kpi.clickable { cursor: pointer; transition: all .15s; }
.kpi.clickable:hover { border-color: var(--ink-mute); box-shadow: var(--shadow-md); }
.kpi.filter-active { border-color: var(--accent) !important; background: var(--accent-soft) !important; }
.kpi.filter-active .kpi-label { color: var(--accent); }

/* ===== DEPT CARD ===== */
.depts-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
.dept-card { background: var(--bg-card); border: 1px solid var(--line); border-radius: 10px; overflow: hidden; }
.dept-card-head { display: flex; justify-content: space-between; align-items: center; padding: 16px 20px; }
.dept-card-name { font-family: 'Fraunces', serif; font-size: 18px; font-weight: 500; letter-spacing: -.01em; }
.dept-card-desc { font-size: 12px; color: var(--ink-mute); margin-top: 2px; }
.dept-leader-row { display: flex; align-items: center; gap: 10px; padding: 10px 20px; background: var(--bg-panel); border-top: 1px solid var(--line-soft); border-bottom: 1px solid var(--line-soft); }
.dept-leader-lbl { font-size: 10px; text-transform: uppercase; letter-spacing: .12em; color: var(--ink-mute); }
.dept-leader-name { font-size: 13px; font-weight: 500; }
.dept-member-row { display: flex; align-items: center; gap: 10px; padding: 9px 20px; border-bottom: 1px solid var(--line-soft); font-size: 13px; }
.dept-member-row:last-of-type { border-bottom: none; }
.dept-member-name { flex: 1; font-weight: 500; }
.dept-member-role { font-size: 12px; color: var(--ink-mute); }
.dept-member-salary { font-family: 'Geist Mono', monospace; font-size: 12px; color: var(--ink-soft); font-variant-numeric: tabular-nums; }
.dept-footer { padding: 10px 20px; background: var(--bg-panel); border-top: 1px solid var(--line-soft); display: flex; gap: 20px; font-size: 12px; color: var(--ink-soft); }
.dept-footer strong { color: var(--ink); font-weight: 500; }
.dept-more-btn { width: 100%; padding: 8px; background: none; border: none; border-top: 1px dashed var(--line); font-size: 12px; color: var(--accent); cursor: pointer; font-family: inherit; }
.dept-more-btn:hover { background: var(--accent-soft); }

/* ===== PAYROLL ROW EXPANDABLE ===== */
.payroll-detail-row td { padding: 0; border-bottom: 1px solid var(--line); }
.payroll-detail-inner { padding: 16px 22px; background: var(--bg-panel); display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; }
.payroll-detail-inner .field { margin-bottom: 0; }
.payroll-benefits-toggle { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--ink-soft); margin-left: auto; }
.toggle-btn { display: flex; background: var(--line-soft); border-radius: 6px; padding: 2px; }
.toggle-btn span { padding: 3px 10px; border-radius: 4px; font-size: 11px; font-weight: 500; cursor: pointer; }
.toggle-btn span.active { background: var(--bg-card); color: var(--ink); box-shadow: 0 1px 2px rgba(0,0,0,.08); }

/* ===== ANALYTICS ===== */
.analytics-area-tabs { display: flex; gap: 6px; margin-bottom: 28px; }
.area-tab { padding: 8px 18px; border-radius: 20px; border: 1px solid var(--line); font-size: 13px; font-weight: 500; cursor: pointer; color: var(--ink-soft); transition: all .15s; }
.area-tab:hover { border-color: var(--ink-mute); color: var(--ink); }
.area-tab.active { background: var(--ink); color: var(--bg); border-color: var(--ink); }
.analytics-section { display: none; }
.analytics-section.active { display: block; animation: fadeIn .3s ease; }
.charts-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 24px; }

/* ===== EDIT BTN ===== */
.btn-edit { color: var(--accent); border-color: var(--accent-soft); background: var(--accent-soft); }
.btn-edit:hover { background: var(--accent); color: var(--bg); border-color: var(--accent); }

/* ===== STATUS SELECT COLORIDO ===== */
select.st-active     { background:var(--success-soft); color:var(--success);  border-color:var(--success);  font-weight:500; }
select.st-vacation   { background:var(--gold-soft);    color:var(--gold);     border-color:var(--gold);     font-weight:500; }
select.st-leave      { background:var(--warn-soft);    color:var(--warn);     border-color:var(--warn);     font-weight:500; }
select.st-terminated { background:var(--line-soft);    color:var(--ink-mute); border-color:var(--line);     font-weight:500; }

/* ===== DEPT MEMBER AVATARS ===== */
.dept-members { display:flex; flex-wrap:wrap; gap:6px; margin-top:12px; }
.dept-member-chip {
  display:flex; align-items:center; gap:6px;
  padding:4px 10px 4px 4px;
  background:var(--bg-panel); border:1px solid var(--line);
  border-radius:20px; font-size:12px;
}
.dept-member-chip .mini-avatar {
  width:22px; height:22px; border-radius:50%;
  background:linear-gradient(135deg,var(--accent),var(--success));
  color:var(--bg); font-size:9px; font-weight:600;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}

/* ===== PAYROLL TABLE COMPACT ===== */
.payroll-table th, .payroll-table td { padding:10px 14px; font-size:12px; }
.payroll-table .cell-amount { font-size:12px; }
.prov-badge { font-size:10px; color:var(--gold); background:var(--gold-soft); padding:1px 6px; border-radius:3px; }

/* ===== KPI CARD CLICKABLE ===== */
.kpi.clickable { cursor:pointer; transition:border-color .15s, box-shadow .15s; }
.kpi.clickable:hover { border-color:var(--ink); box-shadow:var(--shadow-md); }

/* ===== ANALYTICS TABS ===== */
.analytics-tabs { display:flex; gap:4px; margin-bottom:24px; flex-wrap:wrap; }
.analytics-tab {
  padding:7px 16px; border-radius:20px; font-size:13px; font-weight:500;
  cursor:pointer; border:1px solid var(--line); background:var(--bg-card); color:var(--ink-soft);
  transition:all .15s;
}
.analytics-tab:hover { border-color:var(--ink-mute); color:var(--ink); }
.analytics-tab.active { background:var(--ink); border-color:var(--ink); color:var(--bg); }

/* ===== EDIT PENCIL BTN ===== */
.btn-edit {
  width:28px; height:28px; border-radius:5px; border:1px solid var(--line);
  background:var(--bg-card); display:inline-flex; align-items:center; justify-content:center;
  cursor:pointer; transition:border-color .15s; flex-shrink:0;
}
.btn-edit:hover { border-color:var(--accent); background:var(--accent-soft); }
.btn-edit svg { width:13px; height:13px; stroke:var(--ink-soft); }
.btn-edit:hover svg { stroke:var(--accent); }

/* ===== HR TABLE EXPANDED ROW ===== */

.emp-detail-grid {
  display:grid; grid-template-columns:repeat(5,1fr); gap:10px 20px; padding:14px 0;
}
.emp-detail-item .label { font-size:10px; text-transform:uppercase; letter-spacing:.1em; color:var(--ink-mute); margin-bottom:3px; }
.emp-detail-item .value { font-size:12.5px; font-weight:500; }

/* ===== HORIZONTAL SCROLL TABLE ===== */
.table-scroll-wrap {
  overflow-x: auto;
  overflow-y: visible;
  -webkit-overflow-scrolling: touch;
  /* Custom scrollbar at bottom */
  scrollbar-width: thin;
  scrollbar-color: var(--line) transparent;
}
.table-scroll-wrap::-webkit-scrollbar {
  height: 6px;
}
.table-scroll-wrap::-webkit-scrollbar-track {
  background: var(--line-soft);
  border-radius: 3px;
}
.table-scroll-wrap::-webkit-scrollbar-thumb {
  background: var(--ink-mute);
  border-radius: 3px;
}

/* Sticky first column in scrollable tables */
.table-scroll-wrap table {
  min-width: max-content;
}
.table-scroll-wrap th:first-child,
.table-scroll-wrap td:first-child {
  position: sticky;
  left: 0;
  z-index: 2;
  background: var(--bg-card);
  box-shadow: 2px 0 4px rgba(26,23,21,0.06);
}
.table-scroll-wrap th:first-child {
  background: var(--bg-panel);
  z-index: 3;
}
.table-scroll-wrap tr:hover td:first-child {
  background: var(--bg-panel);
}

/* ===== HR TABLE HORIZONTAL SCROLL + STICKY COL ===== */
.table-scroll-wrap {
  overflow-x: auto;
  overflow-y: visible;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: var(--line) transparent;
}

.table-scroll-wrap table {
  min-width: max-content;
  width: 100%;
}

/* Sticky first column */
.table-scroll-wrap th:first-child,
.table-scroll-wrap td:first-child {
  position: sticky;
  left: 0;
  z-index: 3;
  background: var(--bg-panel);
  box-shadow: 2px 0 6px rgba(26,23,21,0.07);
  min-width: 200px;
}

.table-scroll-wrap tr:hover td:first-child {
  background: var(--bg-panel);
}

/* Scrollbar styling */
.table-scroll-wrap::-webkit-scrollbar {
  height: 6px;
}
.table-scroll-wrap::-webkit-scrollbar-track {
  background: var(--line-soft);
  border-radius: 3px;
}
.table-scroll-wrap::-webkit-scrollbar-thumb {
  background: var(--ink-mute);
  border-radius: 3px;
}

/* ===== QUICK ADD ROW ===== */
.quick-add-row {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr auto;
  gap: 8px;
  padding: 12px 22px;
  background: var(--bg-panel);
  border-bottom: 1px solid var(--line);
  align-items: end;
}
.quick-add-row .field-input { padding: 8px 12px; font-size: 13px; }
.quick-add-row .btn { white-space: nowrap; }

/* ===== SETTINGS BUTTON ===== */
.settings-btn {
  width: 100%;
  padding: 8px 14px;
  margin-bottom: 6px;
  border: 1px solid var(--line);
  background: var(--bg-card);
  color: var(--ink-soft);
  border-radius: 8px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: .04em;
  cursor: pointer;
  transition: all .15s;
}
.settings-btn:hover {
  border-color: var(--ink);
  color: var(--ink);
}

/* ===== RECONCILE STATUS BADGE ===== */
.reconcile-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  user-select: none;
  font-size: 12px;
  font-weight: 500;
}
.reconcile-toggle input[type="checkbox"] {
  width: 18px; height: 18px;
  accent-color: var(--success);
  cursor: pointer;
}
.reconcile-toggle.is-reconciled { color: var(--success); }
.reconcile-toggle.is-pending    { color: var(--ink-mute); }

/* Language pills inside settings */
.lang-pills { display: flex; gap: 8px; flex-wrap: wrap; }
.lang-pill {
  padding: 10px 18px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--bg-card);
  cursor: pointer;
  font-size: 14px;
  font-weight: 500;
  color: var(--ink-soft);
  transition: all .15s;
}
.lang-pill:hover { border-color: var(--ink-mute); }
.lang-pill.active {
  background: var(--ink);
  border-color: var(--ink);
  color: var(--bg);
}

/* ===== COLLAPSIBLE SIDEBAR ===== */
.app.sidebar-collapsed {
  grid-template-columns: 64px 1fr;
}
.app.sidebar-collapsed .sidebar { padding: 12px 8px; }
.app.sidebar-collapsed .brand-name,
.app.sidebar-collapsed .brand-tag,
.app.sidebar-collapsed .nav-title,
.app.sidebar-collapsed .nav-item span,
.app.sidebar-collapsed .user-meta,
.app.sidebar-collapsed .settings-btn,
.app.sidebar-collapsed .logout-btn { display: none !important; }

.app.sidebar-collapsed .nav-item {
  padding: 10px;
  justify-content: center;
}
.app.sidebar-collapsed .brand {
  justify-content: center;
  padding: 10px 0 18px;
  border-bottom: 1px solid var(--line-soft);
  margin-bottom: 14px;
}
.app.sidebar-collapsed .nav-section { margin-bottom: 8px; }

.app.sidebar-collapsed .user-card {
  justify-content: center;
  padding: 8px 0;
}

.app.sidebar-collapsed .main {
  margin-left: 64px;
}

/* Sidebar toggle button */
.sidebar-toggle {
  position: absolute;
  top: 22px;
  right: -14px;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--bg-card);
  border: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 100;
  transition: background .15s, border-color .15s;
  box-shadow: var(--shadow-sm);
}
.sidebar-toggle:hover {
  background: var(--ink);
  border-color: var(--ink);
}
.sidebar-toggle:hover svg { stroke: var(--bg); }
.sidebar-toggle svg {
  width: 14px;
  height: 14px;
  stroke: var(--ink-soft);
  transition: transform .25s, stroke .15s;
}
.app.sidebar-collapsed .sidebar-toggle svg {
  transform: rotate(180deg);
}

.sidebar { position: relative; transition: width .22s ease, padding .22s ease; }
.main    { transition: margin-left .22s ease; }

/* ===== COLLAPSIBLE SIDEBAR ===== */
.sidebar {
  transition: width .25s ease;
  position: relative;
}
.sidebar-toggle {
  position: absolute;
  top: 16px;
  right: 12px;
  width: 32px;
  height: 32px;
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: 6px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
  transition: all .15s;
}
.sidebar-toggle svg { width: 16px; height: 16px; stroke: var(--ink-soft); }
.sidebar-toggle:hover {
  border-color: var(--ink);
  background: var(--ink);
}
.sidebar-toggle:hover svg { stroke: var(--bg); }

/* ===== ACTION DROPDOWN MENU ===== */
.action-dropdown { position: relative; display: inline-block; }
.action-menu {
  position: fixed;
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--shadow-lg);
  min-width: 180px;
  z-index: 999;
  flex-direction: column;
  padding: 4px;
  gap: 0;
}
.action-menu button {
  background: transparent;
  border: 0;
  text-align: left;
  padding: 8px 12px;
  font-size: 13px;
  color: var(--ink);
  cursor: pointer;
  border-radius: 5px;
  font-family: inherit;
  width: 100%;
}
.action-menu button:hover { background: var(--bg-panel); }
.action-menu button.danger { color: var(--warn); }
.action-menu button.danger:hover { background: var(--warn-soft); }

/* New status badges */
.status.scheduled { background: var(--accent-soft); color: var(--accent); }
.status.postponed { background: var(--gold-soft); color: var(--gold); }
.status.canceled  { background: var(--line-soft); color: var(--ink-mute); text-decoration: line-through; }

/* ===== ENRICHED QUICK ADD ROW ===== */
.quick-add-row-rich {
  grid-template-columns: 180px 2fr 110px 130px 70px 120px 1.5fr auto;
}
.quick-add-row-rich select.field-input,
.quick-add-row-rich input.field-input {
  font-size: 12px;
  padding: 7px 10px;
}
@media (max-width: 1400px) {
  .quick-add-row-rich {
    grid-template-columns: 1fr 1fr 1fr 1fr;
    grid-auto-rows: minmax(36px, auto);
  }
  .quick-add-row-rich button { grid-column: span 4; }
}

/* Receivable variant — same 8 cols as payable */
#page-receivable .quick-add-row-rich {
  grid-template-columns: 180px 2fr 110px 130px 60px 110px 1.2fr auto;
}

/* Copy button (cashflow page) */
.btn-copy {
  background: transparent;
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 2px 6px;
  font-size: 11px;
  cursor: pointer;
  color: var(--ink-mute);
  margin-left: 6px;
  font-family: var(--font-mono, monospace);
}
.btn-copy:hover {
  background: var(--ink);
  color: var(--bg);
  border-color: var(--ink);
}
.payment-method-badge {
  display: inline-block;
  font-size: 10px;
  font-weight: 600;
  padding: 2px 6px;
  border-radius: 3px;
  background: var(--accent-soft);
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: .04em;
  margin-right: 4px;
}
.installment-badge {
  display: inline-block;
  font-size: 10px;
  padding: 2px 6px;
  border-radius: 3px;
  background: var(--gold-soft);
  color: var(--gold);
  margin-left: 6px;
}

/* ===== SIDEBAR TOOLTIP ON COLLAPSE ===== */
body.sidebar-collapsed .nav-item[data-page] {
  position: relative;
}
body.sidebar-collapsed .nav-item[data-page]:hover::after {
  content: attr(data-tooltip);
  position: absolute;
  left: calc(100% + 10px);
  top: 50%;
  transform: translateY(-50%);
  background: var(--ink);
  color: var(--bg);
  padding: 6px 10px;
  border-radius: 6px;
  font-size: 12px;
  white-space: nowrap;
  z-index: 200;
  pointer-events: none;
  box-shadow: 0 4px 12px rgba(0,0,0,.15);
}

/* Month filter select */
#payable-month-filter,
#receivable-month-filter {
  font-size: 12px;
  font-weight: 500;
  padding: 6px 10px;
  border-radius: 6px;
  border: 1px solid var(--line);
  background: var(--bg-card);
  color: var(--ink);
  cursor: pointer;
  min-width: 100px;
  max-width: 130px;
}
#payable-month-filter:focus,
#receivable-month-filter:focus {
  border-color: var(--accent);
  outline: none;
}

/* ===== CASHFLOW HUB ===== */
.hub-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px;
  margin-top: 4px;
}
.hub-card {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 20px 22px;
  cursor: pointer;
  transition: all .18s ease;
  position: relative;
  overflow: hidden;
}
.hub-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: var(--accent);
  opacity: 0;
  transition: opacity .18s;
}
.hub-card:hover {
  border-color: var(--accent);
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}
.hub-card:hover::before { opacity: 1; }

.hub-card.consolidated {
  border: 2px solid var(--accent);
  background: linear-gradient(135deg, var(--accent-soft) 0%, var(--bg-card) 100%);
}
.hub-card.consolidated::before { opacity: 1; background: var(--accent); }

.hub-card-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 14px;
}
.hub-card-name {
  font-family: 'Fraunces', serif;
  font-size: 17px;
  font-weight: 500;
  letter-spacing: -.01em;
  color: var(--ink);
}
.hub-card-bank {
  font-size: 11px;
  color: var(--ink-mute);
  margin-top: 2px;
}
.hub-card-badge {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  padding: 3px 8px;
  border-radius: 5px;
  background: var(--accent-soft);
  color: var(--accent);
  white-space: nowrap;
}
.hub-card-rows {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.hub-card-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: 13px;
}
.hub-card-row .label { color: var(--ink-mute); }
.hub-card-row .value { font-weight: 600; font-variant-numeric: tabular-nums; }
.hub-card-divider {
  border-top: 1px solid var(--line);
  margin: 4px 0;
}
.hub-card-final {
  font-weight: 700;
  font-size: 14px;
}
.hub-card-actions {
  position: absolute;
  top: 12px; right: 12px;
  display: flex; gap: 4px;
  opacity: 0;
  transition: opacity .15s;
}
.hub-card:hover .hub-card-actions { opacity: 1; }
.hub-card-actions button {
  width: 26px; height: 26px;
  border-radius: 6px;
  border: 1px solid var(--line);
  background: var(--bg-card);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px;
  transition: all .12s;
}
.hub-card-actions button:hover {
  border-color: var(--accent);
  background: var(--accent-soft);
}

.hub-empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: 48px 20px;
  color: var(--ink-mute);
}
.hub-empty-icon { font-size: 48px; margin-bottom: 12px; }
.hub-empty-text { font-size: 15px; margin-bottom: 16px; }

/* Back button */
.btn-back {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  font-weight: 500;
  color: var(--accent);
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px 0;
  margin-bottom: 8px;
  transition: color .12s;
}
.btn-back:hover { color: var(--ink); }

/* Account view KPIs */
#cf-account-kpis .kpi { min-width: 0; }

/* Responsive hub */
@media (max-width: 768px) {
  .hub-cards { grid-template-columns: 1fr; }
}

/* Hub tabs */
.hub-tabs {
  display: flex;
  gap: 0;
  margin: 16px 0 4px;
  border-bottom: 2px solid var(--line);
}
.hub-tab {
  padding: 10px 20px;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink-mute);
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  cursor: pointer;
  transition: all .15s;
}
.hub-tab:hover { color: var(--ink); }
.hub-tab.active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}
/* Tab bar */
.tab-bar{display:flex;gap:0;border-bottom:2px solid var(--line)}
.tab-btn{padding:10px 20px;font-size:14px;font-weight:600;border:none;background:transparent;color:var(--ink-mute);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}
.tab-btn:hover{color:var(--ink)}
.tab-btn.active{color:var(--ink);border-bottom-color:var(--ink)}

/* Cobrança status badges */
.boleto-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.boleto-badge.emitido{background:#e8f0fe;color:#1a73e8}
.boleto-badge.pago{background:#e6f4ea;color:#1e8e3e}
.boleto-badge.vencido{background:#fce8e6;color:#d93025}
/* ============ VISÃO EXECUTIVA — melhorias ============ */
.exec-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.period-seg{display:inline-flex;background:var(--bg-panel);border:1px solid var(--line);border-radius:9px;padding:3px;gap:2px}
.period-seg button{border:none;background:transparent;color:var(--ink-mute);font-size:12px;font-weight:600;padding:6px 14px;border-radius:6px;cursor:pointer;transition:all .15s;font-family:inherit}
.period-seg button:hover{color:var(--ink)}
.period-seg button.active{background:var(--accent);color:var(--bg-panel)}

/* KPI trend */
.kpi-trend{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:700;margin-top:6px;padding:2px 7px;border-radius:20px}
.kpi-trend.up{color:var(--success);background:var(--success-soft)}
.kpi-trend.down{color:var(--warn);background:var(--warn-soft)}
.kpi-trend.flat{color:var(--ink-mute);background:var(--line-soft)}
.kpi-spark{margin-top:10px;height:28px;width:100%}

/* Chart panel header actions */
.chart-actions{display:flex;gap:4px;align-items:center}
.chart-icon-btn{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);background:var(--bg-card);border-radius:7px;cursor:pointer;color:var(--ink-mute);transition:all .15s;padding:0}
.chart-icon-btn:hover{border-color:var(--accent);color:var(--accent)}
.chart-icon-btn svg{width:15px;height:15px}

/* Chart tooltip */
.chart-tip{position:fixed;pointer-events:none;z-index:9999;background:var(--ink);color:var(--bg-panel);padding:8px 11px;border-radius:8px;font-size:12px;line-height:1.5;box-shadow:0 6px 24px rgba(0,0,0,.22);opacity:0;transition:opacity .12s;white-space:nowrap;font-family:'Geist Mono',monospace}
.chart-tip.show{opacity:1}
.chart-tip .tip-title{font-family:'Geist',sans-serif;font-weight:600;font-size:11px;color:var(--gold-soft);margin-bottom:3px}
.chart-tip .tip-row{display:flex;justify-content:space-between;gap:14px}
.chart-tip .tip-dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:5px}

/* Expand modal */
.chart-modal-backdrop{position:fixed;inset:0;background:rgba(26,23,21,.55);backdrop-filter:blur(3px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:32px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .2s,visibility .2s}
.chart-modal-backdrop.show{opacity:1;visibility:visible;pointer-events:auto}
.chart-modal{background:var(--bg-panel);border-radius:16px;width:min(1100px,95vw);height:min(680px,90vh);display:flex;flex-direction:column;box-shadow:0 24px 80px rgba(0,0,0,.3);transform:scale(.97);transition:transform .2s}
.chart-modal-backdrop.show .chart-modal{transform:scale(1)}
.chart-modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--line)}
.chart-modal-title{font-family:'Fraunces',serif;font-size:22px;color:var(--ink)}
.chart-modal-body{flex:1;padding:24px;min-height:0}
.chart-modal-body > div{width:100%;height:100%}

/* Featured chart */
.exec-featured{background:var(--bg-panel);border:1px solid var(--line);border-radius:14px;padding:22px 22px 14px;margin-bottom:22px}
.exec-featured-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:6px}

/* Responsive exec grid */
@media (max-width:900px){
  #exec-widgets,#fin-widgets,#hr-widgets{grid-template-columns:1fr !important}
}

/* Donut */
.donut-legend{display:flex;flex-direction:column;gap:8px;justify-content:center}
.donut-legend-item{display:flex;align-items:center;gap:8px;font-size:13px}
.donut-legend-item .dl-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}
.donut-legend-item .dl-val{margin-left:auto;font-family:'Geist Mono',monospace;color:var(--ink-soft)}

/* ============ PLANILHAS ============ */
.ss-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.ss-card{background:var(--bg-panel);border:1px solid var(--line);border-radius:12px;padding:18px;cursor:pointer;transition:border-color .15s,transform .15s,box-shadow .15s;position:relative}
.ss-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.06)}
.ss-card-icon{width:38px;height:38px;border-radius:9px;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.ss-card-icon svg{width:20px;height:20px}
.ss-card-name{font-family:'Fraunces',serif;font-size:18px;color:var(--ink);margin-bottom:4px}
.ss-card-meta{font-size:12px;color:var(--ink-mute)}
.ss-card-del{position:absolute;top:12px;right:12px;width:26px;height:26px;border:none;background:transparent;color:var(--ink-mute);border-radius:6px;cursor:pointer;opacity:0;transition:opacity .15s,background .15s}
.ss-card:hover .ss-card-del{opacity:1}
.ss-card-del:hover{background:var(--warn-soft);color:var(--warn)}
.ss-empty{grid-column:1/-1;text-align:center;padding:60px 20px;color:var(--ink-mute)}

.ss-name-input{font-family:'Fraunces',serif;font-size:24px;color:var(--ink);border:none;background:transparent;outline:none;width:420px;max-width:60vw;border-bottom:2px solid transparent;transition:border-color .15s;padding:2px 0}
.ss-name-input:focus{border-bottom-color:var(--accent)}
.ss-save-state{font-size:11px;color:var(--ink-mute);margin-top:2px}
.ss-save-state.dirty{color:var(--gold)}

.ss-sheet-wrap{overflow:auto;border:1px solid var(--line);border-radius:10px;background:var(--bg-card);max-height:calc(100vh - 220px)}
table.ss-table{border-collapse:collapse;font-family:'Geist Mono',monospace;font-size:13px}
table.ss-table th,table.ss-table td{border:1px solid var(--line-soft);padding:0;margin:0}
table.ss-table thead th{background:var(--bg-panel);color:var(--ink-mute);font-weight:600;font-size:11px;text-align:center;height:28px;position:sticky;top:0;z-index:2;min-width:96px}
table.ss-table thead th:first-child{left:0;z-index:3;min-width:44px;width:44px}
table.ss-table tbody td.ss-rowhead{background:var(--bg-panel);color:var(--ink-mute);font-size:11px;text-align:center;font-weight:600;position:sticky;left:0;z-index:1;min-width:44px;width:44px}
table.ss-table td input{border:none;background:transparent;width:100%;height:30px;padding:0 8px;font-family:inherit;font-size:13px;color:var(--ink);outline:none;box-sizing:border-box}
table.ss-table td input:focus{background:var(--accent-soft);box-shadow:inset 0 0 0 2px var(--accent)}

/* ============ PLANILHAS — Editor Fase 2 ============ */
.ss-toolbar{display:flex;gap:14px;align-items:center;flex-wrap:wrap;padding:8px 10px;background:var(--bg-panel);border:1px solid var(--line);border-radius:9px 9px 0 0;border-bottom:none}
.ss-tb-group{display:flex;gap:4px;align-items:center;padding-right:14px;border-right:1px solid var(--line)}
.ss-tb-group:last-child{border-right:none}
.ss-tb-btn{display:inline-flex;align-items:center;gap:5px;border:1px solid var(--line);background:var(--bg-card);color:var(--ink-soft);font-size:12px;font-weight:500;padding:6px 10px;border-radius:7px;cursor:pointer;transition:all .12s;font-family:inherit}
.ss-tb-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}
.ss-tb-btn svg{width:14px;height:14px}

.ss-formula-bar{display:flex;align-items:center;gap:0;background:var(--bg-card);border:1px solid var(--line);border-bottom:none}
.ss-cell-ref{min-width:64px;text-align:center;font-family:'Geist Mono',monospace;font-size:12px;font-weight:600;color:var(--ink);padding:8px;border-right:1px solid var(--line);background:var(--bg-panel)}
.ss-fx{padding:0 12px;font-style:italic;font-family:'Fraunces',serif;color:var(--ink-mute);border-right:1px solid var(--line)}
.ss-formula-input{flex:1;border:none;outline:none;background:transparent;padding:9px 12px;font-family:'Geist Mono',monospace;font-size:13px;color:var(--ink)}

.ss-sheet-wrap{overflow:auto;border:1px solid var(--line);border-radius:0;background:var(--bg-card);max-height:calc(100vh - 300px)}
table.ss-table{border-collapse:collapse;font-family:'Geist Mono',monospace;font-size:13px;user-select:none}
table.ss-table th,table.ss-table td{border:1px solid var(--line-soft);padding:0;margin:0}
table.ss-table thead th{background:var(--bg-panel);color:var(--ink-mute);font-weight:600;font-size:11px;text-align:center;height:28px;position:sticky;top:0;z-index:2;min-width:96px;cursor:pointer}
table.ss-table thead th:first-child{left:0;z-index:3;min-width:44px;width:44px}
table.ss-table thead th.col-sel{background:var(--accent-soft);color:var(--accent)}
table.ss-table tbody td.ss-rowhead{background:var(--bg-panel);color:var(--ink-mute);font-size:11px;text-align:center;font-weight:600;position:sticky;left:0;z-index:1;min-width:44px;width:44px;cursor:pointer}
table.ss-table tbody td.ss-rowhead.row-sel{background:var(--accent-soft);color:var(--accent)}
table.ss-table td.ss-cell{height:30px;padding:0 8px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:260px;cursor:cell;position:relative}
table.ss-table td.ss-cell.num{text-align:right}
table.ss-table td.ss-cell.in-range{background:var(--accent-soft)}
table.ss-table td.ss-cell.active{box-shadow:inset 0 0 0 2px var(--accent);background:var(--bg-card)}
table.ss-table td.ss-cell.formula-cell{color:var(--accent)}
table.ss-table td.ss-cell.err{color:var(--warn)}
table.ss-table td.ss-cell input{position:absolute;inset:0;border:none;background:var(--bg-card);width:100%;height:100%;padding:0 8px;font-family:inherit;font-size:13px;color:var(--ink);outline:2px solid var(--accent);box-sizing:border-box;z-index:5}

.ss-statusbar{display:flex;gap:20px;align-items:center;padding:7px 14px;background:var(--bg-panel);border:1px solid var(--line);border-top:none;border-radius:0 0 9px 9px;font-size:12px;color:var(--ink-soft);font-family:'Geist Mono',monospace;min-height:32px}
.ss-statusbar .sb-item{display:flex;gap:6px}
.ss-statusbar .sb-item b{color:var(--ink)}

/* Toolbar Fase 2 — formatação */
.ss-toolbar{flex-wrap:wrap}
.ss-tb-btn.ss-icon{padding:6px 9px;min-width:32px;justify-content:center}
.ss-tb-btn.ss-icon svg{width:16px;height:16px;margin:0}
.ss-tb-select{border:1px solid var(--line);background:var(--bg-card);color:var(--ink-soft);font-size:12px;padding:6px 8px;border-radius:7px;cursor:pointer;font-family:inherit;outline:none}
.ss-tb-select:hover{border-color:var(--accent)}
.ss-tb-btn.active{background:var(--accent);color:var(--bg-panel);border-color:var(--accent)}

/* ============ ALERTAS / LEMBRETES ============ */
.alerts-panel{background:var(--bg-panel);border:1px solid var(--line);border-radius:14px;padding:16px 18px;margin-bottom:22px}
.alerts-head{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-mute);margin-bottom:12px}
.alerts-count{background:var(--warn);color:#fff;border-radius:20px;padding:1px 9px;font-size:11px}
.alerts-list{display:flex;flex-direction:column;gap:8px}
.alert-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:10px;cursor:pointer;transition:transform .12s,box-shadow .12s;border:1px solid transparent}
.alert-item:hover{transform:translateX(3px);box-shadow:0 4px 14px rgba(0,0,0,.06)}
.alert-item.warn{background:var(--warn-soft);border-color:rgba(184,86,62,.25)}
.alert-item.info{background:var(--accent-soft);border-color:rgba(45,74,62,.18)}
.alert-icon{font-size:18px;width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:var(--bg-panel);border-radius:9px;flex-shrink:0}
.alert-body{flex:1;min-width:0}
.alert-title{font-weight:600;font-size:14px;color:var(--ink)}
.alert-sub{font-size:12px;color:var(--ink-soft);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.alert-arrow{color:var(--ink-mute);font-size:16px;flex-shrink:0}
.alert-cfg-row{display:flex;align-items:center;gap:12px;padding:14px 4px;border-bottom:1px solid var(--line-soft);min-height:52px}
.alert-cfg-row:last-child{border-bottom:none}
.alert-cfg-row label{flex:1;font-size:14px;color:var(--ink);cursor:pointer;font-weight:500}
.alert-cfg-row input[type="checkbox"]{appearance:none;-webkit-appearance:none;width:38px;height:22px;border-radius:20px;background:var(--line);position:relative;cursor:pointer;flex-shrink:0;transition:background .18s;border:none}
.alert-cfg-row input[type="checkbox"]::after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .18s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.alert-cfg-row input[type="checkbox"]:checked{background:var(--accent)}
.alert-cfg-row input[type="checkbox"]:checked::after{transform:translateX(16px)}
.alert-cfg-row input[type="number"]{height:36px;border:1px solid var(--line);border-radius:8px;padding:0 10px;font-family:'Geist Mono',monospace;font-size:13px;color:var(--ink);background:var(--bg-card);outline:none;text-align:right}
.alert-cfg-row input[type="number"]:focus{border-color:var(--accent)}
.alert-cfg-row .cfg-suffix{font-size:13px;color:var(--ink-mute);white-space:nowrap}