/* NC Financeiro v2.0 — CSS Principal */
/* Design: Inter Bank — clean, branco, compacto, mobile-first */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');

/* ── Reset & Base ───────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --font: 'Inter', system-ui, sans-serif;
  --c-bg:        #f5f6fa;
  --c-surface:   #ffffff;
  --c-border:    #e8eaed;
  --c-border2:   #d1d5db;
  --c-text:      #111827;
  --c-text2:     #6b7280;
  --c-text3:     #9ca3af;
  --c-primary:   #ff6a00;
  --c-primary-h: #e55e00;
  --c-success:   #059669;
  --c-warning:   #d97706;
  --c-danger:    #dc2626;
  --c-info:      #ff6a00;
  --c-green-bg:  #ecfdf5;
  --c-green-text:#065f46;
  --c-red-bg:    #fef2f2;
  --c-red-text:  #991b1b;
  --c-yellow-bg: #fffbeb;
  --c-yellow-text:#92400e;
  --c-blue-bg:   #fff4ed;
  --c-blue-text: #c44d00;
  --sidebar-w:   220px;
  --topbar-h:    52px;
  --radius:      8px;
  --radius-sm:   6px;
  --shadow-sm:   0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --shadow:      0 4px 12px rgba(0,0,0,.08);
  --transition:  .15s ease;
}

html{font-size:14px;-webkit-text-size-adjust:100%}
body{font-family:var(--font);background:var(--c-bg);color:var(--c-text);line-height:1.5;min-height:100vh}
a{color:var(--c-primary);text-decoration:none}
img{max-width:100%}

/* ── Layout ─────────────────────────────────────────────────── */
.app-wrapper{display:flex;min-height:100vh}

/* Sidebar */
.sidebar{
  width:var(--sidebar-w);flex-shrink:0;
  background:var(--c-surface);border-right:1px solid var(--c-border);
  display:flex;flex-direction:column;
  position:fixed;top:0;left:0;height:100vh;z-index:200;
  transition:transform var(--transition);
  overflow-y:auto;overflow-x:hidden;
}
.sidebar-logo{
  height:var(--topbar-h);display:flex;align-items:center;
  padding:0 16px;border-bottom:1px solid var(--c-border);
  gap:10px;flex-shrink:0;
}
.sidebar-logo .logo-icon{
  width:28px;height:28px;background:var(--c-primary);border-radius:6px;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:13px;font-weight:700;flex-shrink:0;
}
.sidebar-logo .logo-text{font-size:13px;font-weight:600;color:var(--c-text);white-space:nowrap}
.sidebar-logo .logo-ver{font-size:10px;color:var(--c-text3);margin-left:auto}

.sidebar-nav{padding:8px 0;flex:1}
.nav-section{margin-bottom:4px}
.nav-section-title{
  font-size:10px;font-weight:600;text-transform:uppercase;
  letter-spacing:.06em;color:var(--c-text3);
  padding:8px 16px 4px;
}
.nav-item{
  display:flex;align-items:center;gap:9px;
  padding:7px 16px;font-size:13px;font-weight:400;
  color:var(--c-text2);border-radius:0;
  transition:background var(--transition),color var(--transition);
  cursor:pointer;white-space:nowrap;
}
.nav-item svg{width:15px;height:15px;flex-shrink:0;opacity:.7}
.nav-item:hover{background:#f3f4f6;color:var(--c-text)}
.nav-item.active{
  background:var(--c-blue-bg);color:var(--c-primary);font-weight:500;
}
.nav-item.active svg{opacity:1}

.sidebar-footer{
  padding:12px 16px;border-top:1px solid var(--c-border);
  font-size:12px;color:var(--c-text3);
}
.sidebar-footer .user-name{font-size:12px;font-weight:500;color:var(--c-text2)}
.sidebar-footer a{color:var(--c-danger);font-size:11px}

/* Topbar */
.topbar{
  height:var(--topbar-h);background:var(--c-surface);
  border-bottom:1px solid var(--c-border);
  display:flex;align-items:center;padding:0 16px;
  position:fixed;top:0;left:var(--sidebar-w);right:0;z-index:100;
  gap:12px;
}
.topbar-menu-btn{
  display:none;background:none;border:none;cursor:pointer;
  color:var(--c-text2);padding:4px;border-radius:var(--radius-sm);
}
.topbar-title{font-size:14px;font-weight:600;color:var(--c-text)}
.topbar-spacer{flex:1}
.topbar-alerts{position:relative}
.topbar-alerts .badge{
  position:absolute;top:-4px;right:-4px;
  background:var(--c-danger);color:#fff;
  font-size:9px;font-weight:700;min-width:16px;height:16px;
  border-radius:8px;display:flex;align-items:center;justify-content:center;
  padding:0 3px;border:2px solid #fff;
}
.topbar-btn{
  background:none;border:none;cursor:pointer;color:var(--c-text2);
  padding:6px;border-radius:var(--radius-sm);display:flex;align-items:center;
  transition:background var(--transition);
}
.topbar-btn:hover{background:#f3f4f6;color:var(--c-text)}
.topbar-btn svg{width:18px;height:18px}

/* Main content */
.main-content{
  margin-left:var(--sidebar-w);margin-top:var(--topbar-h);
  padding:20px;min-height:calc(100vh - var(--topbar-h));
  width:calc(100% - var(--sidebar-w));
}

/* ── Cards & Surfaces ───────────────────────────────────────── */
.card{
  background:var(--c-surface);border:1px solid var(--c-border);
  border-radius:var(--radius);box-shadow:var(--shadow-sm);
}
.card-header{
  padding:12px 16px;border-bottom:1px solid var(--c-border);
  display:flex;align-items:center;gap:8px;
  font-size:13px;font-weight:600;
}
.card-header .card-title{font-size:13px;font-weight:600;flex:1}
.card-body{padding:16px}
.card-body-sm{padding:12px 16px}

/* KPI Cards */
.kpi-grid{display:grid;gap:12px;grid-template-columns:repeat(2,1fr)}
.kpi-card{
  background:var(--c-surface);border:1px solid var(--c-border);
  border-radius:var(--radius);padding:12px 14px;
  box-shadow:var(--shadow-sm);
}
.kpi-label{font-size:11px;font-weight:500;color:var(--c-text3);text-transform:uppercase;letter-spacing:.04em}
.kpi-value{font-size:20px;font-weight:700;margin-top:2px;letter-spacing:-.5px}
.kpi-sub{font-size:11px;color:var(--c-text3);margin-top:1px}
.kpi-positive{color:var(--c-success)}
.kpi-negative{color:var(--c-danger)}
.kpi-neutral{color:var(--c-text)}
.kpi-info{color:#ff6a00}

/* ── Tables ─────────────────────────────────────────────────── */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;font-size:13px}
th{
  padding:8px 12px;text-align:left;font-size:11px;font-weight:600;
  text-transform:uppercase;letter-spacing:.05em;
  color:var(--c-text3);border-bottom:1px solid var(--c-border);
  white-space:nowrap;background:var(--c-bg);
}
td{
  padding:9px 12px;border-bottom:1px solid var(--c-border);
  vertical-align:middle;
}
tr:last-child td{border-bottom:none}
tr:hover td{background:#fafafa}
.td-mono{font-variant-numeric:tabular-nums;font-size:13px}

/* ── Badges & Pills ─────────────────────────────────────────── */
.badge{
  display:inline-flex;align-items:center;gap:4px;
  font-size:11px;font-weight:500;padding:2px 8px;
  border-radius:20px;white-space:nowrap;
}
.badge-success{background:var(--c-green-bg);color:var(--c-green-text)}
.badge-danger{background:var(--c-red-bg);color:var(--c-red-text)}
.badge-warning{background:var(--c-yellow-bg);color:var(--c-yellow-text)}
.badge-info{background:#fff4ed;color:#c44d00}
.badge-gray{background:#f3f4f6;color:var(--c-text2)}

/* ── Botões ─────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 14px;font-size:13px;font-weight:500;
  border-radius:var(--radius-sm);border:1px solid transparent;
  cursor:pointer;transition:all var(--transition);
  font-family:var(--font);white-space:nowrap;
  text-decoration:none;
}
.btn svg{width:15px;height:15px;flex-shrink:0}
.btn-primary{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}
.btn-primary:hover{background:var(--c-primary-h);border-color:var(--c-primary-h)}
.btn-secondary{background:var(--c-surface);color:var(--c-text2);border-color:var(--c-border2)}
.btn-secondary:hover{background:#f3f4f6;color:var(--c-text)}
.btn-success{background:var(--c-success);color:#fff;border-color:var(--c-success)}
.btn-danger{background:var(--c-danger);color:#fff;border-color:var(--c-danger)}
.btn-ghost{background:none;border-color:transparent;color:var(--c-text2)}
.btn-ghost:hover{background:#f3f4f6;color:var(--c-text)}
.btn-xs{padding:4px 9px;font-size:11px}
.btn-sm{padding:6px 12px;font-size:12px}
.btn-icon{padding:7px;border-radius:var(--radius-sm)}

/* ── Forms ──────────────────────────────────────────────────── */
.form-group{margin-bottom:12px}
label{display:block;font-size:12px;font-weight:500;color:var(--c-text2);margin-bottom:4px}
.form-control{
  width:100%;padding:7px 10px;font-size:13px;font-family:var(--font);
  background:var(--c-surface);border:1px solid var(--c-border2);
  border-radius:var(--radius-sm);color:var(--c-text);
  transition:border-color var(--transition),box-shadow var(--transition);
  -webkit-appearance:none;appearance:none;
}
.form-control:focus{
  outline:none;border-color:var(--c-primary);
  box-shadow:0 0 0 3px rgba(255,106,0,.15);
}
.form-control::placeholder{color:var(--c-text3)}
select.form-control{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:28px}
textarea.form-control{resize:vertical;min-height:70px}
.form-row{display:grid;gap:10px;grid-template-columns:1fr 1fr}
.form-row-3{display:grid;gap:10px;grid-template-columns:1fr 1fr 1fr}
.input-prefix{display:flex;align-items:stretch}
.input-prefix .prefix{
  padding:7px 10px;background:#f3f4f6;border:1px solid var(--c-border2);
  border-right:none;border-radius:var(--radius-sm) 0 0 var(--radius-sm);
  font-size:13px;color:var(--c-text3);white-space:nowrap;display:flex;align-items:center;
}
.input-prefix .form-control{border-radius:0 var(--radius-sm) var(--radius-sm) 0}

/* ── Alerts/Flash ───────────────────────────────────────────── */
.flash{
  padding:10px 14px;border-radius:var(--radius-sm);
  margin-bottom:14px;font-size:13px;display:flex;align-items:center;gap:8px;
  border:1px solid transparent;
}
.flash-success{background:var(--c-green-bg);color:var(--c-green-text);border-color:#a7f3d0}
.flash-error{background:var(--c-red-bg);color:var(--c-red-text);border-color:#fecaca}
.flash-warning{background:var(--c-yellow-bg);color:var(--c-yellow-text);border-color:#fde68a}

/* ── Modal ──────────────────────────────────────────────────── */
.modal-overlay{
  display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);
  z-index:500;align-items:flex-end;justify-content:center;
  padding:0;
}
.modal-overlay.open{display:flex}
.modal{
  background:var(--c-surface);border-radius:16px 16px 0 0;
  width:100%;max-height:90vh;overflow-y:auto;
  padding:0 0 env(safe-area-inset-bottom);
  animation:slideUp .25s ease;
}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.modal-header{
  padding:14px 16px;display:flex;align-items:center;
  border-bottom:1px solid var(--c-border);position:sticky;top:0;
  background:var(--c-surface);z-index:1;
}
.modal-title{font-size:15px;font-weight:600;flex:1}
.modal-close{
  background:none;border:none;cursor:pointer;
  color:var(--c-text3);padding:4px;border-radius:50%;
  display:flex;align-items:center;transition:background var(--transition);
}
.modal-close:hover{background:#f3f4f6;color:var(--c-text)}
.modal-close svg{width:20px;height:20px}
.modal-body{padding:16px}
.modal-footer{
  padding:12px 16px;border-top:1px solid var(--c-border);
  display:flex;gap:8px;justify-content:flex-end;
}

/* ── Extrato Timeline ───────────────────────────────────────── */
.extrato-header{
  display:grid;grid-template-columns:repeat(3,1fr);gap:10px;
  margin-bottom:16px;
}
.extrato-saldo-card{
  background:var(--c-surface);border:1px solid var(--c-border);
  border-radius:var(--radius);padding:12px;text-align:center;
}
.extrato-saldo-label{font-size:11px;color:var(--c-text3);font-weight:500;text-transform:uppercase}
.extrato-saldo-value{font-size:18px;font-weight:700;margin-top:2px}
.extrato-day{margin-bottom:0}
.extrato-day-header{
  padding:6px 12px;background:var(--c-bg);border-bottom:1px solid var(--c-border);
  font-size:11px;font-weight:600;color:var(--c-text3);text-transform:uppercase;
  display:flex;justify-content:space-between;align-items:center;
}
.extrato-row{
  display:grid;grid-template-columns:36px 1fr auto;align-items:center;
  gap:10px;padding:10px 12px;border-bottom:1px solid var(--c-border);
}
.extrato-row:last-child{border-bottom:none}
.extrato-icon{
  width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.extrato-icon.entrada{background:var(--c-green-bg)}
.extrato-icon.saida{background:var(--c-red-bg)}
.extrato-icon svg{width:14px;height:14px}
.extrato-icon.entrada svg{color:var(--c-success)}
.extrato-icon.saida svg{color:var(--c-danger)}
.extrato-desc{font-size:13px;font-weight:500}
.extrato-sub{font-size:11px;color:var(--c-text3)}
.extrato-values{text-align:right}
.extrato-valor{font-size:13px;font-weight:600}
.extrato-valor.positivo{color:var(--c-success)}
.extrato-valor.negativo{color:var(--c-danger)}
.extrato-saldo{font-size:11px;color:var(--c-text3)}

/* ── Alertas / Vencimento colors ────────────────────────────── */
.venc-vencido   td:first-child{border-left:3px solid var(--c-danger)}
.venc-hoje      td:first-child{border-left:3px solid #f97316}
.venc-amanha    td:first-child{border-left:3px solid var(--c-warning)}
.venc-semana    td:first-child{border-left:3px solid var(--c-info)}

/* ── Pagination ─────────────────────────────────────────────── */
.pagination{display:flex;gap:4px;align-items:center;justify-content:center;margin-top:14px;flex-wrap:wrap}
.page-btn{
  min-width:32px;height:32px;padding:0 8px;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--c-border2);border-radius:var(--radius-sm);font-size:13px;
  color:var(--c-text2);background:var(--c-surface);cursor:pointer;text-decoration:none;
  transition:all var(--transition);
}
.page-btn:hover{background:#f3f4f6;color:var(--c-text)}
.page-btn.active{background:var(--c-primary);border-color:var(--c-primary);color:#fff}
.page-btn.disabled{opacity:.4;pointer-events:none}

/* ── Filtros / Search bar ───────────────────────────────────── */
.filter-bar{
  display:flex;gap:8px;align-items:center;flex-wrap:wrap;
  margin-bottom:14px;
}
.filter-bar .form-control{height:34px;font-size:13px}
.search-input-wrap{position:relative;flex:1;min-width:160px}
.search-input-wrap svg{
  position:absolute;left:9px;top:50%;transform:translateY(-50%);
  width:15px;height:15px;color:var(--c-text3);pointer-events:none;
}
.search-input-wrap .form-control{padding-left:32px}

/* ── DRE Table ──────────────────────────────────────────────── */
.dre-table{font-size:12px}
.dre-table th{font-size:10px}
.dre-total{font-weight:700;background:#f8fafc}
.dre-resultado-pos td{background:var(--c-green-bg);color:var(--c-green-text);font-weight:700}
.dre-resultado-neg td{background:var(--c-red-bg);color:var(--c-red-text);font-weight:700}

/* ── Login Page ─────────────────────────────────────────────── */
.login-page{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#f0f4ff 0%,#f5f6fa 100%);
  padding:16px;
}
.login-card{
  background:var(--c-surface);border:1px solid var(--c-border);
  border-radius:12px;padding:32px 28px;width:100%;max-width:360px;
  box-shadow:var(--shadow);
}
.login-logo{text-align:center;margin-bottom:24px}
.login-logo .icon{
  width:52px;height:52px;background:var(--c-primary);border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:22px;font-weight:800;margin:0 auto 10px;
}
.login-logo h1{font-size:18px;font-weight:700}
.login-logo p{font-size:12px;color:var(--c-text3)}

/* ── Empty state ────────────────────────────────────────────── */
.empty-state{
  text-align:center;padding:40px 16px;color:var(--c-text3);
}
.empty-state svg{width:40px;height:40px;opacity:.3;margin-bottom:8px}
.empty-state p{font-size:13px}

/* ── PWA Install banner ─────────────────────────────────────── */
.pwa-banner{
  display:none;position:fixed;bottom:16px;left:16px;right:16px;
  background:var(--c-text);color:#fff;border-radius:12px;
  padding:12px 14px;box-shadow:var(--shadow);z-index:300;
  align-items:center;gap:10px;font-size:13px;
}
.pwa-banner.visible{display:flex}
.pwa-banner .pwa-text{flex:1}
.pwa-banner .pwa-title{font-weight:600;font-size:13px}
.pwa-banner .pwa-sub{font-size:11px;opacity:.7;margin-top:1px}
.pwa-banner button{padding:6px 12px;border-radius:6px;border:none;cursor:pointer;font-size:12px;font-weight:500}
.pwa-install-btn{background:var(--c-primary);color:#fff}
.pwa-dismiss-btn{background:transparent;color:rgba(255,255,255,.6);padding:6px}

/* ── Utilities ──────────────────────────────────────────────── */
.text-right{text-align:right}
.text-center{text-align:center}
.text-muted{color:var(--c-text3)}
.text-sm{font-size:12px}
.text-xs{font-size:11px}
.text-success{color:var(--c-success)}
.text-danger{color:var(--c-danger)}
.text-warning{color:var(--c-warning)}
.fw-600{font-weight:600}
.fw-700{font-weight:700}
.d-flex{display:flex}
.align-center{align-items:center}
.gap-2{gap:8px}
.gap-1{gap:4px}
.mt-1{margin-top:4px}
.mt-2{margin-top:8px}
.mt-3{margin-top:12px}
.mb-1{margin-bottom:4px}
.mb-2{margin-bottom:8px}
.mb-3{margin-bottom:12px}
.mb-4{margin-bottom:16px}
.w-full{width:100%}
.nowrap{white-space:nowrap}

/* ── Mobile overlay ─────────────────────────────────────────── */
.sidebar-overlay{
  display:none;position:fixed;inset:0;background:rgba(0,0,0,.3);
  z-index:150;
}
.sidebar-overlay.open{display:block}

/* ── Responsive ─────────────────────────────────────────────── */
@media(max-width:768px){
  :root{--sidebar-w:0px}
  .sidebar{transform:translateX(-220px);width:220px}
  .sidebar.open{transform:translateX(0)}
  .topbar{left:0}
  .topbar-menu-btn{display:flex}
  .main-content{margin-left:0;padding:14px;width:100%}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .form-row,.form-row-3{grid-template-columns:1fr}
  .modal{border-radius:16px 16px 0 0}
  .extrato-header{grid-template-columns:1fr}
  .filter-bar{gap:6px}
  .filter-bar .form-control{height:36px}
  th,td{padding:7px 10px}
}
@media(min-width:769px){
  .kpi-grid{grid-template-columns:repeat(4,1fr)}
  .modal{
    border-radius:var(--radius);max-width:520px;
    align-self:center;margin:auto;
  }
  .modal-overlay{align-items:center}
}
@media(min-width:1200px){
  .main-content{padding:24px}
}

/* ── Scrollbar ──────────────────────────────────────────────── */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--c-border2);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--c-text3)}

/* ── Utilitários adicionais ─────────────────────────────── */
.flex-wrap{flex-wrap:wrap}
.flex-1{flex:1}
.d-grid{display:grid}
.overflow-x-auto{overflow-x:auto;-webkit-overflow-scrolling:touch}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.cursor-pointer{cursor:pointer}
.select-none{user-select:none;-webkit-user-select:none}
.rounded{border-radius:var(--radius)}
.rounded-full{border-radius:9999px}
.opacity-50{opacity:.5}
.transition{transition:all var(--transition)}
.shadow{box-shadow:var(--shadow)}
.border{border:1px solid var(--c-border)}
.border-t{border-top:1px solid var(--c-border)}
.border-b{border-bottom:1px solid var(--c-border)}
.p-0{padding:0}
.p-2{padding:8px}
.p-3{padding:12px}
.p-4{padding:16px}
.px-2{padding-left:8px;padding-right:8px}
.px-3{padding-left:12px;padding-right:12px}
.py-1{padding-top:4px;padding-bottom:4px}
.py-2{padding-top:8px;padding-bottom:8px}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.min-w-0{min-width:0}
.w-auto{width:auto}

/* ── Fix: SVG icons sem tamanho explícito ───────────────────
   Ícones gerados pela função icon() têm só viewBox, sem width/height.
   Sem constraints, SVG herda o tamanho do container flex e explode. */
.nav-item svg,
.btn svg,
.card-header svg,
.topbar-btn svg,
.modal-close svg,
.modal-title svg,
.topbar-alerts svg,
.empty-state svg,
.flash svg,
.badge svg,
td svg,
th svg {
  width: 16px !important;
  height: 16px !important;
  flex-shrink: 0;
}
.empty-state svg    { width: 36px !important; height: 36px !important; }
.topbar-btn svg     { width: 18px !important; height: 18px !important; }
.modal-close svg    { width: 20px !important; height: 20px !important; }
.sidebar-logo svg   { width: 14px !important; height: 14px !important; }

/* Dashboard: grids 2 colunas → 1 coluna no mobile */
@media(max-width:640px) {
  .dash-grid-2 { grid-template-columns: 1fr !important; }
}

/* ── Tabs ──────────────────────────────────────────────────── */
.tabs-bar {
  display: flex;
  gap: 4px;
  border-bottom: 2px solid var(--c-border);
  padding-bottom: 0;
}
.tab-btn {
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  padding: 8px 16px;
  font-size: 13px;
  font-weight: 500;
  color: var(--c-text2);
  cursor: pointer;
  border-radius: var(--radius-sm) var(--radius-sm) 0 0;
  transition: color .15s, border-color .15s;
  white-space: nowrap;
}
.tab-btn:hover { color: var(--c-text); }
.tab-btn.active {
  color: var(--c-primary);
  border-bottom-color: var(--c-primary);
  font-weight: 600;
}
.tab-content { animation: fadeIn .15s ease; }
@keyframes fadeIn { from { opacity:0; transform:translateY(2px); } to { opacity:1; transform:none; } }

/* ── Dashboard list (mobile-friendly, substitui tabela) ──── */
.dash-list { display: flex; flex-direction: column; }
.dash-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 14px;
  border-bottom: 1px solid var(--c-border);
}
.dash-item:last-child { border-bottom: none; }
.dash-item.venc-vencido { background: var(--c-red-bg); }
.dash-item.venc-hoje    { background: #fffbeb; }
.dash-item.venc-amanha  { background: #fffbeb; }

/* Coluna de data — largura fixa para não quebrar mobile */
.dash-due {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  width: 64px;
  text-align: center;
}
.dash-due-badge {
  font-size: 10px !important;
  padding: 2px 5px !important;
  white-space: nowrap;
  display: block;
  width: 100%;
  text-align: center;
  border-radius: 4px;
}
.dash-due-parc {
  font-size: 10px;
  color: var(--c-text3);
}

.dash-item-main  { flex: 1; min-width: 0; }
.dash-item-meta  { display: flex; align-items: center; gap: 4px; font-size: 11px; color: var(--c-text3); margin-top: 2px; flex-wrap: wrap; }
.dash-item-actions { flex-shrink: 0; text-align: right; }

/* ── Modal TED ─────────────────────────────────────────────── */
.ted-dl { display: flex; flex-direction: column; gap: 10px; }
.ted-dl > div { display: flex; justify-content: space-between; align-items: baseline;
  padding-bottom: 8px; border-bottom: 1px solid var(--c-border); gap: 12px; }
.ted-dl > div:last-child { border-bottom: none; padding-bottom: 0; }
.ted-dl dt { font-size: 11px; color: var(--c-text3); text-transform: uppercase;
  letter-spacing: .04em; flex-shrink: 0; }
.ted-dl dd { font-size: 13px; font-weight: 600; color: var(--c-text); text-align: right; margin: 0; }
