/* ============================================================
 * LifeOS Design System · components.css · v4.0.0 (Verdant)
 * ------------------------------------------------------------
 * Componentes universais prefixados .v-* para zero colisão.
 * Carregar nesta ordem:
 *   1. tokens.css
 *   2. reset.css
 *   3. components.css      ← este
 *   4. base.css            (chassi LifeOS)
 *   5. <página>.css        (page-specific)
 * ============================================================ */


/* ============================================================
 * BUTTON
 * .v-btn + variantes .v-btn-pri/.v-btn-sec/.v-btn-gho
 * ============================================================ */
.v-btn{
  font-family: inherit;
  font-size: var(--t-sm);
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s2);
  padding: 9px var(--s4);
  border-radius: var(--r-sm);
  border: 1px solid transparent;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  transition: transform var(--d1) var(--spring),
              background var(--d2) var(--ease),
              border-color var(--d2) var(--ease),
              color var(--d2) var(--ease);
}
/* v3.14.6: :active scale(.97) REMOVIDO — "afundava" o botão (pedido do dono) */
.v-btn > *,
.v-btn svg{ position: relative; z-index: 1; }
.v-btn svg{
  width: 15px; height: 15px;
  transition: transform var(--d2) var(--spring);
}
/* TSK-046: foco POR TECLADO (tab) bem visível — deixa claro que Enter aciona
   este botão. Só :focus-visible → não aparece em clique de mouse (a queixa
   antiga era do halo no clique/:active, não do tab). */
.v-btn:focus-visible{
  outline: 2px solid var(--brand);
  outline-offset: 2px;
  border-radius: var(--r-sm);
}
.v-btn[disabled],
.v-btn.is-disabled{ opacity: .5; cursor: not-allowed; pointer-events: none; }
.v-btn.is-loading{ cursor: wait; opacity: .85; pointer-events: none; }
.v-btn.is-loading .btn-spinner{
  display: inline-block;
  width: 12px; height: 12px;
  border: 2px solid currentColor;
  border-top-color: transparent;
  border-radius: 50%;
  animation: v-rot .7s linear infinite;
}

.v-btn-pri{
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  color: var(--on-brand);
}
.v-btn-pri::after{
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.4) 50%, transparent 70%);
  transform: translateX(-130%);
  transition: transform .6s var(--ease-out);
}
.v-btn-pri:hover{
  transform: translateY(-2px);
  box-shadow: var(--glow);
}
.v-btn-pri:hover::after{ transform: translateX(130%); }
/* v3.14.6: svg translateX(3px) no hover REMOVIDO — ícone "andava" em direção
   ao texto sem motivo (pedido do dono) */

.v-btn-sec{
  background: var(--panel-2);
  color: var(--tx);
  border-color: var(--line-2);
}
.v-btn-sec:hover{
  border-color: var(--brand);
  background: var(--panel-3);
}

.v-btn-gho{
  background: transparent;
  color: var(--tx2);
}
.v-btn-gho:hover{
  background: var(--panel-2);
  color: var(--tx);
}

/* Size modifiers */
.v-btn--lg{ padding: 13px 22px; font-size: var(--t-base); }
.v-btn--sm{ padding: 6px 12px; font-size: var(--t-xs); }
.v-btn--full{ width: 100%; }
/* Mono modifier — botão secundário com label mono uppercase (headers, "hoje", "gerenciar") */
.v-btn--mono{
  font-family: 'Inter', system-ui, sans-serif;
  font-size: var(--t-xs); font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase;
}

/* Icon-only variant */
.v-btn--icon{
  width: 32px; height: 32px;
  padding: 0;
  flex-shrink: 0;
}
.v-btn--icon svg{ width: 16px; height: 16px; }
.v-btn--icon.v-btn--sm{ width: 28px; height: 28px; }
.v-btn--icon.v-btn--sm svg{ width: 14px; height: 14px; }
.v-btn--icon.v-btn--lg{ width: 40px; height: 40px; }
.v-btn--icon.v-btn--lg svg{ width: 18px; height: 18px; }

/* Active state pro .v-btn-sec (toggle button) */
.v-btn-sec.is-active{
  background: var(--tint);
  border-color: var(--brand);
  color: var(--brand);
}

/* Danger modifier — usado em ações destrutivas (Excluir, Remover) */
.v-btn--danger{
  color: var(--crit) !important;
  border-color: color-mix(in srgb, var(--crit) 35%, transparent);
}
.v-btn--danger:hover{
  background: color-mix(in srgb, var(--crit) 12%, transparent) !important;
  border-color: color-mix(in srgb, var(--crit) 50%, transparent);
  color: var(--crit) !important;
}

/* Good modifier — usado em ações de confirmar/aprovar */
.v-btn--good{
  color: var(--good) !important;
  border-color: color-mix(in srgb, var(--good) 35%, transparent);
}
.v-btn--good:hover{
  background: color-mix(in srgb, var(--good) 12%, transparent) !important;
  border-color: color-mix(in srgb, var(--good) 50%, transparent);
  color: var(--good) !important;
}

/* ============================================================
 * ADD BUTTON (.v-add) — "+ adicionar X" tracejado, largura total
 * ------------------------------------------------------------
 * Padrão universal do LifeOS pra adicionar itens em listas.
 * Antes espalhado em ~10 classes (edit-add, add-bank-btn, qn-add-btn,
 * lc-add-btn, pj-add-invoice-btn...). Agora é UM componente.
 * ============================================================ */
.v-add{
  width: 100%;
  display: flex; align-items: center; justify-content: center; gap: var(--s2);
  padding: 10px;
  background: transparent;
  border: 1px dashed var(--line-2);
  border-radius: var(--r-sm);
  color: var(--tx3);
  font-family: inherit;
  font-size: var(--t-sm); font-weight: 600;
  cursor: pointer;
  transition: background var(--d2) var(--ease), border-color var(--d2) var(--ease), color var(--d2) var(--ease);
}
.v-add:hover{
  background: var(--tint);
  border-color: color-mix(in srgb, var(--brand) 45%, transparent);
  color: var(--brand);
}
.v-add svg{ width: 15px; height: 15px; }
/* variante mono uppercase (alguns contextos usavam label mono) */
.v-add--mono{
  font-family: 'Inter', system-ui, sans-serif;
  font-size: var(--t-xs); font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase;
}


/* ============================================================
 * INPUT / TEXTAREA / SELECT (custom)
 * ============================================================ */
.v-inp{
  font-family: inherit;
  font-size: var(--t-sm);
  width: 200px;
  padding: 9px var(--s3);
  border-radius: var(--r-sm);
  border: 1px solid var(--line-2);
  background: var(--panel-2);
  color: var(--tx);
  transition: border-color var(--d2) var(--ease), box-shadow var(--d2) var(--ease);
}
.v-inp::placeholder{ color: var(--tx4); }
.v-inp:focus{
  outline: none;
  border-color: var(--brand);
  /* v3.14.6: anel de 3px removido — foco indicado só pela borda */
}
.v-inp.v-err{
  border-color: var(--crit);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--crit) 20%, transparent);
}
.v-inp.v-ok{
  border-color: var(--good);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--good) 20%, transparent);
}
.v-inp:disabled{ opacity: .5; cursor: not-allowed; }

.v-ta{
  font-family: inherit;
  font-size: var(--t-sm);
  /* TSK-024: textarea é campo de bloco — sempre 100% da largura do container.
     (antes 240px fixo deixava o "plano de teste" do Jira ~50% com espaço vazio) */
  width: 100%;
  min-height: 80px;
  resize: vertical;
  padding: 9px var(--s3);
  border-radius: var(--r-sm);
  border: 1px solid var(--line-2);
  background: var(--panel-2);
  color: var(--tx);
  transition: border-color var(--d2) var(--ease), box-shadow var(--d2) var(--ease);
}
.v-ta::placeholder{ color: var(--tx4); }
.v-ta:focus{
  outline: none;
  border-color: var(--brand);
}

.v-field-col{ display: flex; flex-direction: column; gap: 0; }
.v-field-col label{
  font-size: var(--t-xs);
  font-weight: 600;
  color: var(--tx2);
  margin-bottom: 6px;
}
.v-field-msg{
  font-size: var(--t-xs);
  margin-top: 4px;
  display: flex; align-items: center; gap: 4px;
}
.v-field-msg.v-err{ color: var(--crit); }
.v-field-msg.v-ok{  color: var(--good); }
.v-field-msg svg{ width: 12px; height: 12px; }


/* ============================================================
 * SWITCH (.v-sw) / CHECKBOX (.v-chk) / RADIO (.v-radio)
 * ============================================================ */
.v-sw{
  width: 42px; height: 24px;
  border-radius: 99px;
  background: var(--panel-3);
  border: 1px solid var(--line-2);
  cursor: pointer;
  padding: 2px;
  /* fix (v3.13.0): .v-sw/.v-k são <span> — sem display, width/height eram
     ignorados e o knob sumia (switch virava um blob vazio). */
  display: inline-flex; align-items: center; flex-shrink: 0;
  box-sizing: border-box;
  transition: background var(--d2) var(--ease), border-color var(--d2) var(--ease);
}
.v-sw .v-k{
  display: block;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--tx3);
  transition: transform var(--d2) var(--spring), background var(--d2) var(--ease);
}
.v-sw.v-on{ background: var(--tint); border-color: var(--brand); }
.v-sw.v-on .v-k{ transform: translateX(18px); background: var(--brand); }

.v-chk{
  width: 20px; height: 20px;
  border-radius: var(--r-xs);
  border: 1px solid var(--line-2);
  background: var(--panel-2);
  cursor: pointer;
  display: grid; place-items: center;
  transition: background var(--d2) var(--ease), border-color var(--d2) var(--ease);
}
.v-chk svg{
  width: 13px; height: 13px;
  color: var(--on-brand);
  stroke-dasharray: 20;
  stroke-dashoffset: 20;
  transition: stroke-dashoffset var(--d2) var(--ease-out);
}
.v-chk.v-on{ background: var(--brand); border-color: var(--brand); }
.v-chk.v-on svg{ stroke-dashoffset: 0; }

.v-radio{
  display: flex; align-items: center; gap: var(--s2);
  font-size: var(--t-sm);
  color: var(--tx2);
  cursor: pointer;
}
.v-radio .v-r{
  width: 20px; height: 20px;
  border-radius: 50%;
  border: 1px solid var(--line-2);
  background: var(--panel-2);
  display: grid; place-items: center;
  transition: border-color var(--d2) var(--ease);
}
.v-radio .v-r::after{
  content: '';
  width: 9px; height: 9px;
  border-radius: 50%;
  background: var(--brand);
  transform: scale(0);
  transition: transform var(--d2) var(--spring);
}
.v-radio.v-on .v-r{ border-color: var(--brand); }
.v-radio.v-on .v-r::after{ transform: scale(1); }


/* ============================================================
 * SEARCH (.v-search)
 * ============================================================ */
.v-search{ position: relative; width: 240px; }
.v-search svg{
  position: absolute;
  left: 11px; top: 50%;
  transform: translateY(-50%);
  width: 15px; height: 15px;
  color: var(--tx3);
  transition: color var(--d2) var(--ease);
  pointer-events: none;
}
.v-search input{
  width: 100%;
  font-family: inherit;
  font-size: var(--t-sm);
  padding: 9px var(--s3) 9px 34px;
  border-radius: var(--r-sm);
  border: 1px solid var(--line-2);
  background: var(--panel-2);
  color: var(--tx);
  transition: border-color var(--d2) var(--ease), box-shadow var(--d2) var(--ease);
}
.v-search input::placeholder{ color: var(--tx4); }
.v-search input:focus{
  outline: none;
  border-color: var(--brand);
}
.v-search input:focus + svg,
.v-search:focus-within svg{ color: var(--brand); }


/* ============================================================
 * SELECT (.v-sel) — substitui <select> nativo
 * ============================================================ */
.v-sel{ position: relative; width: 200px; }
.v-sel-btn{
  width: 100%;
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--s2);
  font-family: inherit;
  font-size: var(--t-sm);
  padding: 9px var(--s3);
  border-radius: var(--r-sm);
  border: 1px solid var(--line-2);
  background: var(--panel-2);
  color: var(--tx);
  cursor: pointer;
  transition: border-color var(--d2) var(--ease), box-shadow var(--d2) var(--ease);
}
.v-sel-btn:hover{ border-color: var(--brand); }
.v-sel-btn:disabled{ opacity: .5; cursor: not-allowed; }
.v-sel.v-open .v-sel-btn{
  border-color: var(--brand);
}
.v-sel-btn svg{
  width: 14px; height: 14px;
  color: var(--tx3);
  transition: transform var(--d2) var(--spring);
}
.v-sel.v-open .v-sel-btn svg{
  transform: rotate(180deg);
  color: var(--brand);
}
.v-sel-val{
  flex: 1; min-width: 0;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  text-align: left;
}
.v-sel-menu{
  /* v3.15.1: o JS (ds.js) reposiciona como fixed ao abrir (não clipa em modal).
     O absolute abaixo é só o estado inicial/fallback. */
  position: absolute;
  top: calc(100% + 6px);
  left: 0; right: 0;
  background: var(--panel);
  border: 1px solid var(--line-2);
  border-radius: var(--r-sm);
  box-shadow: var(--sh);
  padding: var(--s1);
  z-index: 20;
  transform-origin: top;
  opacity: 0;
  transform: scaleY(.85) translateY(-6px);
  visibility: hidden;
  transition: opacity var(--d2) var(--ease),
              transform var(--d2) var(--spring),
              visibility var(--d2);
  max-height: 320px;
  overflow-y: auto;
}
.v-sel.v-open .v-sel-menu,
.v-sel-menu.v-portal-open{ /* portado pro body: não está mais sob .v-sel.v-open */
  opacity: 1;
  transform: none;
  visibility: visible;
}
.v-sel-menu.v-portal-open{ background: var(--panel); } /* garante fundo opaco fora do container */
.v-sel-search-wrap{
  padding: 4px;
  border-bottom: 1px solid var(--line);
  position: sticky; top: 0;
  background: var(--panel);
  z-index: 1;
}
.v-sel-search{
  width: 100%;
  font-family: inherit;
  font-size: var(--t-sm);
  padding: 6px 10px;
  border-radius: var(--r-xs);
  border: 1px solid var(--line);
  background: var(--panel-2);
  color: var(--tx);
}
.v-sel-search:focus{
  outline: none;
  border-color: var(--brand);
}
.v-sel-list{
  display: flex;
  flex-direction: column;
}
.v-sel-opt{
  padding: 8px var(--s3);
  border-radius: var(--r-xs);
  font-size: var(--t-sm);
  color: var(--tx2);
  cursor: pointer;
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--s2);
  background: transparent;
  border: 0;
  text-align: left;
  font-family: inherit;
  width: 100%;
  transition: background var(--d1) var(--ease), color var(--d1) var(--ease);
}
.v-sel-opt:hover,
.v-sel-opt.v-hl{ background: var(--panel-2); color: var(--tx); }
.v-sel-opt.v-sel-on{ color: var(--brand); }
.v-sel-opt-label{
  flex: 1; min-width: 0;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.v-sel-opt svg{
  width: 13px; height: 13px;
  opacity: 0;
  transition: opacity var(--d1);
}
.v-sel-opt.v-sel-on svg{ opacity: 1; }
.v-sel-opt[disabled]{ opacity: .45; cursor: not-allowed; }
.v-sel-empty{
  padding: 14px 12px;
  text-align: center;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: var(--t-xs);
  color: var(--tx4);
}


/* ============================================================
 * BADGES (.v-bdg)
 * ============================================================ */
.v-bdg{
  display: inline-flex; align-items: center; gap: 6px;
  font-size: var(--t-xs);
  font-weight: 600;
  padding: 3px 10px;
  border-radius: var(--r-full);
  border: 1px solid transparent;
  transition: transform var(--d1) var(--spring);
}
.v-bdg:hover{ transform: translateY(-2px); }
.v-bdg .v-d{
  width: 6px; height: 6px;
  border-radius: 50%;
  background: currentColor;
}
.v-bdg-good{ color: var(--good); background: color-mix(in srgb, var(--good) 14%, transparent); }
.v-bdg-warn{ color: var(--warn); background: color-mix(in srgb, var(--warn) 14%, transparent); }
.v-bdg-crit{ color: var(--crit); background: color-mix(in srgb, var(--crit) 14%, transparent); }
.v-bdg-info{ color: var(--info); background: color-mix(in srgb, var(--info) 14%, transparent); }
.v-bdg-neu{ color: var(--tx2); background: var(--panel-2); border-color: var(--line-2); }

/* Modificador mono/micro — pill técnico pequeno pra status inline em listas
 * densas (tarefa pontual/atrasada, status de treino, validade de remédio).
 * Reaproveita as variantes de cor .v-bdg-{warn,crit,good,info,neu}; a borda
 * herda a cor da variante via currentColor. Sem hover-lift (fica estático
 * dentro da linha). */
.v-bdg--mono{
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 10px; font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase;
  gap: 4px;
  padding: 2px 5px;
  border-radius: var(--r-xs);
  border-color: color-mix(in srgb, currentColor 30%, transparent);
}
.v-bdg--mono:hover{ transform: none; }

/* ============================================================
 * PILLS toggle (.v-pill / .v-pill-grp) — radiogroup visual
 * ============================================================ */
.v-pill-grp{ display: flex; gap: 6px; flex-wrap: wrap; }
.v-pill{
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 12px;
  background: var(--panel-2);
  border: 1px solid var(--line-2);
  border-radius: var(--r-full);
  color: var(--tx2);
  font-family: 'Inter', system-ui, sans-serif; font-size: 12px; font-weight: 600;
  cursor: pointer;
  transition: color var(--d1) var(--ease-out), border-color var(--d1) var(--ease-out), background var(--d1) var(--ease-out), transform var(--d1) var(--spring);
}
.v-pill svg{ width: 13px; height: 13px; }
.v-pill:hover{ color: var(--tx); border-color: var(--tx2); transform: translateY(-1px); }
.v-pill.is-active{ background: var(--panel); border-color: var(--tx); color: var(--tx); }
.v-pill.is-active.v-pill-good{ color: var(--good); background: color-mix(in srgb, var(--good) 14%, transparent); border-color: color-mix(in srgb, var(--good) 45%, transparent); }
.v-pill.is-active.v-pill-warn{ color: var(--warn); background: color-mix(in srgb, var(--warn) 14%, transparent); border-color: color-mix(in srgb, var(--warn) 45%, transparent); }
.v-pill.is-active.v-pill-crit{ color: var(--crit); background: color-mix(in srgb, var(--crit) 14%, transparent); border-color: color-mix(in srgb, var(--crit) 45%, transparent); }
.v-pill.is-active.v-pill-info{ color: var(--info); background: color-mix(in srgb, var(--info) 14%, transparent); border-color: color-mix(in srgb, var(--info) 45%, transparent); }
.v-pill[disabled]{ opacity: .4; cursor: not-allowed; }
.v-bdg-mod{ color: var(--tx2); background: var(--panel-2); border-color: var(--line-2); font-family: 'Inter', system-ui, sans-serif; font-size: 10px; letter-spacing: 0.02em; }
.v-bdg .v-bdg-ic{ width: 12px; height: 12px; flex-shrink: 0; }


/* ============================================================
 * UICARD (.v-uicard)
 * ============================================================ */
.v-uicard{
  width: 240px;
  text-align: left;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: var(--s5);
  cursor: pointer;
  position: relative;
  overflow: hidden;
  transition: transform var(--d2) var(--ease-out),
              border-color var(--d2) var(--ease),
              box-shadow var(--d2) var(--ease);
}
.v-uicard:hover{
  transform: translateY(-5px);
  border-color: color-mix(in srgb, var(--brand) 40%, var(--line));
  box-shadow: 0 20px 40px -16px rgba(0,0,0,.5), var(--glow, 0 0 0 0 transparent);
}
.v-uicard > *{ position: relative; }
.v-uicard .v-ico{
  width: 36px; height: 36px;
  border-radius: var(--r-sm);
  display: grid; place-items: center;
  background: var(--panel-2);
  color: var(--brand);
  border: 1px solid var(--line);
  margin-bottom: var(--s4);
  transition: background var(--d2) var(--ease), color var(--d2) var(--ease);
}
.v-uicard:hover .v-ico{ background: var(--brand); color: var(--on-brand); }
.v-uicard .v-ico svg{ width: 18px; height: 18px; }
.v-uicard h4{
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 500;
  font-size: var(--t-md);
  margin-bottom: 4px;
}
.v-uicard p{ font-size: var(--t-sm); color: var(--tx2); }


/* ============================================================
 * ACCORDION (.v-acc)
 * ============================================================ */
.v-acc{
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  overflow: hidden;
  width: 100%;
  max-width: 520px;
}
.v-acc-i{ border-bottom: 1px solid var(--line); }
.v-acc-i:last-child{ border-bottom: 0; }
.v-acc-h{
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--s3);
  padding: var(--s4) var(--s5);
  cursor: pointer;
  font-weight: 600;
  font-size: var(--t-sm);
  transition: background var(--d1) var(--ease), color var(--d1) var(--ease);
}
.v-acc-h:hover{ background: var(--panel-2); color: var(--brand); }
.v-acc-h .v-car{
  width: 14px; height: 14px;
  color: var(--tx3);
  transition: transform var(--d2) var(--spring);
}
.v-acc-i.v-open .v-acc-h .v-car{ transform: rotate(90deg); color: var(--brand); }
.v-acc-b{
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows var(--d2) var(--ease);
}
.v-acc-b > div{ overflow: hidden; }
.v-acc-i.v-open .v-acc-b{ grid-template-rows: 1fr; }
.v-acc-b p{
  padding: 0 var(--s5) var(--s4);
  font-size: var(--t-sm);
  color: var(--tx2);
}


/* ============================================================
 * TABS (.v-tabs)
 * ============================================================ */
.v-tabs{ width: 100%; max-width: 520px; }
.v-tabbar{
  display: flex;
  gap: 2px;
  background: var(--panel-2);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  padding: 3px;
  position: relative;
}
.v-tab{
  flex: 1;
  text-align: center;
  font-size: var(--t-sm);
  font-weight: 600;
  color: var(--tx2);
  padding: 7px;
  border-radius: var(--r-xs);
  cursor: pointer;
  position: relative;
  z-index: 1;
  border: 0;
  background: transparent;
  font-family: inherit;
  transition: color var(--d2) var(--ease);
}
.v-tab.v-active{ color: var(--on-brand); }
.v-tab-ink{
  position: absolute;
  top: 3px; bottom: 3px;
  border-radius: var(--r-xs);
  background: var(--brand);
  transition: left var(--d3) var(--spring), width var(--d3) var(--spring);
  z-index: 0;
}
.v-tab-panel{
  padding: var(--s5) var(--s2);
  font-size: var(--t-sm);
  color: var(--tx2);
  min-height: 48px;
}
.v-tab-panel > div{
  display: none;
  animation: v-fadeIn var(--d3) var(--ease-out);
}
.v-tab-panel > div.v-show{ display: block; }
@keyframes v-fadeIn{
  from{ opacity: 0; transform: translateY(6px); }
  to{   opacity: 1; transform: none; }
}


/* ============================================================
 * MODAL (.v-modal)
 * ============================================================ */
.v-ov{
  position: fixed; inset: 0;
  z-index: 200;
  /* perf (v3.14.5): sem backdrop-filter (blur full-screen pesa no compositor) */
  background: rgba(0,0,0,.62);
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--d2) var(--ease), visibility var(--d2);
}
.v-ov.v-open{ opacity: 1; visibility: visible; }
.v-modal{
  position: fixed;
  z-index: 201;
  left: 50%; top: 50%;
  width: min(92vw, 420px);
  background: var(--panel);
  border: 1px solid var(--line-2);
  border-radius: var(--r-lg);
  padding: var(--s7);
  box-shadow: var(--sh);
  transform: translate(-50%, -44%) scale(.94);
  opacity: 0;
  visibility: hidden;
  transition: transform var(--d2) var(--spring),
              opacity var(--d2) var(--ease),
              visibility var(--d2);
}
.v-modal.v-open{
  transform: translate(-50%, -50%) scale(1);
  opacity: 1;
  visibility: visible;
}
.v-modal--sm{ width: min(92vw, 340px); }
.v-modal--lg{ width: min(92vw, 640px); }
.v-modal h3{
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 500;
  font-size: var(--t-lg);
  margin-bottom: var(--s2);
}
.v-modal p,
.v-modal .v-modal-body{
  color: var(--tx2);
  font-size: var(--t-sm);
  margin-bottom: var(--s6);
}
.v-modal .v-modal-body > *:last-child{ margin-bottom: 0; }
.v-modal .v-acts{
  display: flex;
  gap: var(--s2);
  justify-content: flex-end;
}


/* ============================================================
 * TOAST (.v-toast)
 * ============================================================ */
.v-toast{
  position: fixed;
  z-index: 300;
  bottom: var(--s6);
  left: 50%;
  transform: translate(-50%, 160%);
  background: var(--panel);
  border: 1px solid var(--line-2);
  border-radius: var(--r-full);
  padding: 10px 18px;
  display: flex; align-items: center; gap: var(--s2);
  box-shadow: var(--sh);
  font-size: var(--t-sm);
  font-weight: 600;
  transition: transform var(--d2) var(--spring);
}
.v-toast.v-show{ transform: translate(-50%, 0); }
.v-toast .v-d{
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--brand);
}
.v-toast-good .v-d{ background: var(--good); }
.v-toast-warn .v-d{ background: var(--warn); }
.v-toast-crit .v-d{ background: var(--crit); }
.v-toast-info .v-d{ background: var(--info); }


/* ============================================================
 * ALERT (.v-alert)
 * ============================================================ */
.v-alert{
  display: flex; gap: var(--s3);
  align-items: flex-start;
  width: 100%; max-width: 460px;
  padding: var(--s4);
  border-radius: var(--r-md);
  border: 1px solid;
  background: var(--panel);
}
.v-alert .v-ai{
  flex-shrink: 0;
  width: 18px; height: 18px;
  margin-top: 1px;
}
.v-alert .v-at{
  font-weight: 600;
  font-size: var(--t-sm);
  margin-bottom: 2px;
}
.v-alert .v-ad{
  font-size: var(--t-sm);
  color: var(--tx2);
}
.v-alert-info{ border-color: color-mix(in srgb, var(--info) 35%, var(--line)); background: color-mix(in srgb, var(--info) 7%, var(--panel)); }
.v-alert-info .v-ai, .v-alert-info .v-at{ color: var(--info); }
.v-alert-good{ border-color: color-mix(in srgb, var(--good) 35%, var(--line)); background: color-mix(in srgb, var(--good) 7%, var(--panel)); }
.v-alert-good .v-ai, .v-alert-good .v-at{ color: var(--good); }
.v-alert-warn{ border-color: color-mix(in srgb, var(--warn) 35%, var(--line)); background: color-mix(in srgb, var(--warn) 7%, var(--panel)); }
.v-alert-warn .v-ai, .v-alert-warn .v-at{ color: var(--warn); }
.v-alert-crit{ border-color: color-mix(in srgb, var(--crit) 35%, var(--line)); background: color-mix(in srgb, var(--crit) 7%, var(--panel)); }
.v-alert-crit .v-ai, .v-alert-crit .v-at{ color: var(--crit); }


/* ============================================================
 * TABLE (.v-tbl) + LIST (.v-list)
 * ============================================================ */
.v-tbl-wrap{
  width: 100%;
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  overflow: hidden;
}
.v-tbl{
  width: 100%;
  border-collapse: collapse;
  font-size: var(--t-sm);
}
.v-tbl th{
  text-align: left;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: var(--t-xs);
  font-weight: 500;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--tx3);
  padding: var(--s3) var(--s4);
  background: var(--panel-2);
  border-bottom: 1px solid var(--line);
}
.v-tbl td{
  padding: var(--s3) var(--s4);
  border-bottom: 1px solid var(--line);
  color: var(--tx2);
}
.v-tbl tbody tr{
  transition: background var(--d1) var(--ease);
  cursor: pointer;
}
.v-tbl tbody tr:last-child td{ border-bottom: 0; }
.v-tbl tbody tr:hover{ background: var(--tint); }
.v-tbl td .v-nm{ color: var(--tx); font-weight: 600; }

.v-list{
  width: 100%;
  max-width: 420px;
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  overflow: hidden;
}
.v-list-i{
  display: flex; align-items: center; gap: var(--s3);
  padding: var(--s3) var(--s4);
  border-bottom: 1px solid var(--line);
  cursor: pointer;
  transition: background var(--d1) var(--ease);
}
.v-list-i:last-child{ border-bottom: 0; }
.v-list-i:hover{ background: var(--panel-2); }
.v-list-i .v-gr{
  margin-left: auto;
  color: var(--tx4);
  transition: transform var(--d2) var(--spring);
}
.v-list-i:hover .v-gr{ transform: translateX(3px); color: var(--brand); }
.v-list-i .v-gr svg{ width: 14px; height: 14px; }
.v-list-i .v-it{ font-size: var(--t-sm); font-weight: 600; }
.v-list-i .v-is{ font-size: var(--t-xs); color: var(--tx3); }


/* ============================================================
 * AVATAR (.v-av) + STACK
 * ============================================================ */
.v-av{
  width: 40px; height: 40px;
  border-radius: 50%;
  display: grid; place-items: center;
  font-size: var(--t-sm);
  font-weight: 700;
  color: var(--on-brand);
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  position: relative;
  transition: transform var(--d2) var(--spring);
  cursor: pointer;
}
.v-av:hover{ transform: scale(1.08); }
.v-av .v-pip{
  position: absolute;
  right: -1px; bottom: -1px;
  width: 11px; height: 11px;
  border-radius: 50%;
  background: var(--good);
  border: 2px solid var(--panel);
}
.v-av-stack{ display: flex; }
.v-av-stack .v-av{
  margin-left: -10px;
  border: 2px solid var(--panel);
}
.v-av-stack .v-av:first-child{ margin-left: 0; }
.v-av-stack .v-av:hover{ z-index: 2; }


/* ============================================================
 * PROGRESS (.v-prog) + RING (.v-ring)
 * ============================================================ */
.v-prog{ width: 240px; }
.v-prog-track{
  height: 8px;
  border-radius: 99px;
  background: var(--panel-3);
  overflow: hidden;
}
.v-prog-fill{
  height: 100%;
  border-radius: 99px;
  background: linear-gradient(90deg, var(--brand), var(--brand-2));
  width: 0;
  transition: width 1s var(--ease-out);
}
.v-prog-lbl{
  display: flex;
  justify-content: space-between;
  font-size: var(--t-xs);
  color: var(--tx3);
  margin-bottom: 6px;
}

.v-ring{ transform: rotate(-90deg); }
.v-ring circle{ fill: none; stroke-width: 7; }
.v-ring .v-bg{ stroke: var(--panel-3); }
.v-ring .v-fg{
  stroke: var(--brand);
  stroke-linecap: round;
  stroke-dasharray: 201;
  stroke-dashoffset: 201;
  transition: stroke-dashoffset 1.1s var(--ease-out);
}
.v-ring-wrap{
  position: relative;
  width: 72px; height: 72px;
  display: grid; place-items: center;
}
.v-ring-wrap span{
  position: absolute;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: var(--t-sm);
  font-weight: 700;
  color: var(--brand);
}


/* ============================================================
 * EMPTY STATE (.v-empty)
 * ============================================================ */
.v-empty{
  text-align: center;
  padding: var(--s7) var(--s5);
  max-width: 300px;
}
.v-empty .v-ei{
  width: 52px; height: 52px;
  border-radius: var(--r-md);
  background: var(--panel-2);
  border: 1px solid var(--line);
  display: grid; place-items: center;
  color: var(--tx3);
  margin: 0 auto var(--s4);
}
.v-empty .v-ei svg{ width: 24px; height: 24px; }
.v-empty h4{
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 500;
  font-size: var(--t-md);
  margin-bottom: var(--s2);
}
.v-empty p{
  font-size: var(--t-sm);
  color: var(--tx3);
  margin-bottom: var(--s5);
}


/* ============================================================
 * SKELETON (.v-skel) + SPINNER (.v-spin)
 * ============================================================ */
.v-skel{
  border-radius: var(--r-xs);
  background: linear-gradient(90deg, var(--panel-2) 25%, var(--panel-3) 37%, var(--panel-2) 63%);
  background-size: 400% 100%;
  animation: v-shimmer 1.4s infinite linear;
}
@keyframes v-shimmer{
  from{ background-position: 100% 0; }
  to{   background-position: -100% 0; }
}
.v-skel-card{
  width: 240px;
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: var(--s5);
  display: flex; flex-direction: column;
  gap: var(--s3);
}

.v-spin{
  width: 24px; height: 24px;
  border-radius: 50%;
  border: 3px solid var(--panel-3);
  border-top-color: var(--brand);
  animation: v-rot .7s linear infinite;
}
.v-spin.v-lg{ width: 40px; height: 40px; border-width: 4px; }
@keyframes v-rot{ to { transform: rotate(360deg); } }


/* ============================================================
 * TOOLTIP (.v-tip)
 * ============================================================ */
.v-tip{ position: relative; display: inline-flex; }
.v-tip .v-tip-c{
  position: absolute;
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%) translateY(4px);
  background: var(--tx);
  color: var(--bg);
  font-size: var(--t-xs);
  font-weight: 600;
  padding: 5px 10px;
  border-radius: var(--r-sm);
  white-space: nowrap;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity var(--d2) var(--ease),
              transform var(--d2) var(--spring),
              visibility var(--d2);
  z-index: 30;
}
.v-tip .v-tip-c::after{
  content: '';
  position: absolute;
  top: 100%; left: 50%;
  transform: translateX(-50%);
  border: 5px solid transparent;
  border-top-color: var(--tx);
}
.v-tip:hover .v-tip-c{
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}


/* ============================================================
 * PAGINATION (.v-pag) + BREADCRUMB (.v-crumb)
 * ============================================================ */
.v-pag{
  display: flex;
  gap: var(--s1);
  align-items: center;
}
.v-pag-i{
  min-width: 32px;
  height: 32px;
  padding: 0 8px;
  display: grid; place-items: center;
  border-radius: var(--r-sm);
  border: 1px solid var(--line-2);
  background: var(--panel-2);
  color: var(--tx2);
  font-size: var(--t-sm);
  font-weight: 600;
  cursor: pointer;
  /* perf (v3.14.5): propriedades específicas em vez de `all` — anima só o
     que muda no hover (sem o browser observar layout inteiro do botão). */
  transition: background-color var(--d1) var(--ease), color var(--d1) var(--ease),
    border-color var(--d1) var(--ease), box-shadow var(--d1) var(--ease),
    transform var(--d1) var(--ease), opacity var(--d1) var(--ease);
}
.v-pag-i:hover{ border-color: var(--brand); color: var(--tx); }
.v-pag-i.v-active{
  background: var(--brand);
  color: var(--on-brand);
  border-color: var(--brand);
}
.v-pag-i svg{ width: 14px; height: 14px; }

.v-crumb{
  display: flex; align-items: center;
  gap: var(--s2);
  font-size: var(--t-sm);
}
.v-crumb a{
  color: var(--tx3);
  cursor: pointer;
  transition: color var(--d1) var(--ease);
}
.v-crumb a:hover{ color: var(--brand); }
.v-crumb .v-sep{ color: var(--tx4); }
.v-crumb .v-cur{ color: var(--tx); font-weight: 600; }


/* ============================================================
 * QUICK-ADD (.v-quick-add) + TASK (.v-task)
 * ============================================================ */
.v-quick-add{
  display: flex; align-items: center; gap: var(--s2);
  padding: var(--s2) var(--s3);
  border: 1px dashed var(--line-2);
  border-radius: var(--r-sm);
  margin-bottom: var(--s3);
  transition: border-color var(--d2) var(--ease);
}
.v-quick-add:focus-within{
  border-color: var(--brand);
  border-style: solid;
}
.v-quick-add svg{ width: 16px; height: 16px; color: var(--tx3); }
.v-quick-add input{
  flex: 1;
  background: none;
  border: 0;
  outline: none;
  font-family: inherit;
  font-size: var(--t-sm);
  color: var(--tx);
}
.v-quick-add input::placeholder{ color: var(--tx4); }

.v-task{
  display: flex; align-items: center; gap: var(--s3);
  padding: var(--s3) var(--s4);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  background: var(--panel);
  margin-bottom: var(--s2);
  cursor: pointer;
  transition: border-color var(--d1) var(--ease), background var(--d1) var(--ease);
}
.v-task:hover{ border-color: var(--line-2); background: var(--panel-2); }
.v-task .v-tc{
  width: 20px; height: 20px;
  flex-shrink: 0;
  border-radius: var(--r-xs);
  border: 1.5px solid var(--line-2);
  background: var(--panel-2);
  display: grid; place-items: center;
  transition: background var(--d2) var(--ease), border-color var(--d2) var(--ease);
}
.v-task .v-tc svg{
  width: 13px; height: 13px;
  color: var(--on-brand);
  stroke-dasharray: 20;
  stroke-dashoffset: 20;
  transition: stroke-dashoffset var(--d2) var(--ease-out);
}
.v-task .v-tx{
  flex: 1;
  font-size: var(--t-sm);
  transition: color var(--d2) var(--ease);
}
.v-task .v-tx small{
  display: block;
  font-size: var(--t-xs);
  color: var(--tx3);
  margin-top: 1px;
}
.v-task .v-pri{
  width: 4px; height: 28px;
  border-radius: 99px;
  flex-shrink: 0;
}
.v-pri-hi{ background: var(--crit); }
.v-pri-md{ background: var(--warn); }
.v-pri-lo{ background: var(--tx4); }
.v-task.v-done .v-tc{ background: var(--brand); border-color: var(--brand); }
.v-task.v-done .v-tc svg{ stroke-dashoffset: 0; }
.v-task.v-done .v-tx{
  color: var(--tx3);
  text-decoration: line-through;
  text-decoration-color: var(--tx4);
}
.v-task.v-done .v-pri{ opacity: .3; }
.v-task-enter{ animation: v-taskIn var(--d3) var(--ease-out); }
@keyframes v-taskIn{
  from{ opacity: 0; transform: translateY(-8px) scale(.98); }
  to{   opacity: 1; transform: none; }
}


/* ============================================================
 * TIMELINE (.v-timeline) + EVENT (.v-ev)
 * ============================================================ */
.v-timeline{
  position: relative;
  padding-left: var(--s6);
}
.v-timeline::before{
  content: '';
  position: absolute;
  left: 7px; top: 6px; bottom: 6px;
  width: 2px;
  background: var(--line);
  border-radius: 2px;
}
.v-tl-i{
  position: relative;
  margin-bottom: var(--s4);
}
.v-tl-i::before{
  content: '';
  position: absolute;
  left: -23px; top: 6px;
  width: 12px; height: 12px;
  border-radius: 50%;
  background: var(--panel);
  border: 2px solid var(--brand);
  transition: transform var(--d2) var(--spring), background var(--d2) var(--ease);
}
.v-tl-i:hover::before{ transform: scale(1.3); background: var(--brand); }
.v-tl-i.v-past::before{ border-color: var(--tx4); }
.v-ev{
  display: flex; gap: var(--s3);
  align-items: flex-start;
  padding: var(--s3) var(--s4);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  background: var(--panel);
  cursor: pointer;
  transition: border-color var(--d1) var(--ease), transform var(--d2) var(--ease-out);
}
.v-ev:hover{ border-color: var(--line-2); transform: translateX(3px); }
.v-ev .v-when{
  font-family: 'Inter', system-ui, sans-serif;
  font-size: var(--t-xs);
  color: var(--brand);
  font-weight: 600;
  min-width: 48px;
  padding-top: 1px;
}
.v-ev .v-et{ font-size: var(--t-sm); font-weight: 600; }
.v-ev .v-ed{
  font-size: var(--t-xs);
  color: var(--tx3);
  margin-top: 1px;
  display: flex; align-items: center; gap: 5px;
}
.v-ev .v-ed svg{ width: 11px; height: 11px; }
.v-ev-dot{
  margin-left: auto;
  width: 8px; height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 5px;
}


/* ============================================================
 * MINI CALENDAR (.v-cal)
 * ============================================================ */
.v-cal{
  width: 280px;
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  background: var(--panel);
  overflow: hidden;
}
.v-cal-h{
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--s3) var(--s4);
  border-bottom: 1px solid var(--line);
}
.v-cal-h .v-m{ font-weight: 600; font-size: var(--t-sm); }
.v-cal-h .v-nav{ display: flex; gap: 4px; }
.v-cal-h .v-nav div{
  width: 26px; height: 26px;
  display: grid; place-items: center;
  border-radius: var(--r-xs);
  cursor: pointer;
  color: var(--tx3);
  transition: background var(--d1) var(--ease), color var(--d1) var(--ease);
}
.v-cal-h .v-nav div:hover{ background: var(--panel-2); color: var(--brand); }
.v-cal-h .v-nav svg{ width: 14px; height: 14px; }
.v-cal-grid{
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
  padding: var(--s3);
}
.v-cal-grid .v-dow{
  text-align: center;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 9px;
  color: var(--tx4);
  padding: 4px 0;
  text-transform: uppercase;
}
.v-cal-grid .v-d{
  aspect-ratio: 1;
  display: grid; place-items: center;
  font-size: var(--t-xs);
  border-radius: var(--r-xs);
  cursor: pointer;
  color: var(--tx2);
  position: relative;
  transition: background var(--d1) var(--ease), color var(--d1) var(--ease);
}
.v-cal-grid .v-d:hover{ background: var(--panel-2); color: var(--tx); }
.v-cal-grid .v-d.v-off{ color: var(--tx4); opacity: .5; }
.v-cal-grid .v-d.v-today{
  background: var(--brand);
  color: var(--on-brand);
  font-weight: 700;
}
.v-cal-grid .v-d.v-has::after{
  content: '';
  position: absolute;
  bottom: 3px;
  width: 4px; height: 4px;
  border-radius: 50%;
  background: var(--brand);
}
.v-cal-grid .v-d.v-today.v-has::after{ background: var(--on-brand); }


/* ============================================================
 * FINANCE: BAL (.v-bal) + TXN (.v-txn) + SPEND (.v-spend)
 * ============================================================ */
.v-bal{
  padding: var(--s5) var(--s6);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  background: linear-gradient(135deg, var(--panel), var(--panel-2));
  min-width: 220px;
}
.v-bal .v-lbl{
  font-size: var(--t-xs);
  color: var(--tx3);
  text-transform: uppercase;
  letter-spacing: .1em;
  font-family: 'Inter', system-ui, sans-serif;
  margin-bottom: var(--s2);
}
.v-bal .v-amt{
  font-family: 'Inter', system-ui, sans-serif;
  font-size: var(--t-2xl);
  font-weight: 500;
  letter-spacing: -.02em;
  font-variant-numeric: tabular-nums;
}
.v-bal .v-delta{
  font-size: var(--t-xs);
  margin-top: var(--s2);
  display: flex; align-items: center; gap: 4px;
}
.v-bal .v-delta.v-up{ color: var(--good); }
.v-bal .v-delta.v-down{ color: var(--crit); }
.v-bal .v-delta svg{ width: 12px; height: 12px; }

.v-txn{
  display: flex; align-items: center;
  gap: var(--s3);
  padding: var(--s3) var(--s4);
  border-bottom: 1px solid var(--line);
  transition: background var(--d1) var(--ease);
  cursor: pointer;
}
.v-txn:hover{ background: var(--panel-2); }
.v-txn .v-ti{
  width: 34px; height: 34px;
  border-radius: var(--r-sm);
  display: grid; place-items: center;
  flex-shrink: 0;
  background: var(--panel-2);
  border: 1px solid var(--line);
  color: var(--tx2);
}
.v-txn .v-ti svg{ width: 16px; height: 16px; }
.v-txn .v-td{ flex: 1; }
.v-txn .v-tn{ font-size: var(--t-sm); font-weight: 600; }
.v-txn .v-tcat{ font-size: var(--t-xs); color: var(--tx3); }
.v-txn .v-tv{
  font-family: 'Inter', system-ui, sans-serif;
  font-size: var(--t-sm);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.v-txn .v-tv.v-in{ color: var(--good); }
.v-txn .v-tv.v-out{ color: var(--tx); }
.v-txn-list{
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  overflow: hidden;
}
.v-txn-list .v-txn:last-child{ border-bottom: 0; }

.v-spend{
  display: flex; flex-direction: column;
  gap: var(--s3);
  min-width: 240px;
}
.v-spend-row{
  display: grid;
  grid-template-columns: 84px 1fr auto;
  gap: var(--s3);
  align-items: center;
}
.v-spend-row .v-sl{ font-size: var(--t-xs); color: var(--tx2); }
.v-spend-row .v-sbar{
  height: 8px;
  border-radius: 99px;
  background: var(--panel-3);
  overflow: hidden;
}
.v-spend-row .v-sf{
  height: 100%;
  border-radius: 99px;
  width: 0;
  transition: width .9s var(--ease-out);
}
.v-spend-row .v-sv{
  font-family: 'Inter', system-ui, sans-serif;
  font-size: var(--t-xs);
  color: var(--tx3);
  font-variant-numeric: tabular-nums;
}


/* ============================================================
 * DIET / GYM: GOAL (.v-goal) + MEAL (.v-meal) + WKT (.v-wkt) + HABIT (.v-habit)
 * ============================================================ */
.v-goal{
  display: flex; align-items: center;
  gap: var(--s4);
  padding: var(--s4) var(--s5);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  background: var(--panel);
  min-width: 230px;
}
.v-goal .v-gring{
  position: relative;
  width: 64px; height: 64px;
  flex-shrink: 0;
  display: grid; place-items: center;
}
.v-goal .v-gring svg{ transform: rotate(-90deg); }
.v-goal .v-gring circle{ fill: none; stroke-width: 7; }
.v-goal .v-gring .v-gb{ stroke: var(--panel-3); }
.v-goal .v-gring .v-gf{
  stroke-linecap: round;
  stroke-dasharray: 163;
  stroke-dashoffset: 163;
  transition: stroke-dashoffset 1.1s var(--ease-out);
}
.v-goal .v-gring span{
  position: absolute;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 11px;
  font-weight: 700;
}
.v-goal .v-gmeta .v-gt{ font-size: var(--t-sm); font-weight: 600; }
.v-goal .v-gmeta .v-gv{
  font-family: 'Inter', system-ui, sans-serif;
  font-size: var(--t-xs);
  color: var(--tx3);
  font-variant-numeric: tabular-nums;
  margin-top: 2px;
}

.v-meal{
  display: flex; align-items: center;
  gap: var(--s3);
  padding: var(--s3) var(--s4);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  background: var(--panel);
  margin-bottom: var(--s2);
  transition: border-color var(--d1) var(--ease);
}
.v-meal:hover{ border-color: var(--line-2); }
.v-meal .v-mi{
  width: 36px; height: 36px;
  border-radius: var(--r-sm);
  display: grid; place-items: center;
  background: var(--panel-2);
  color: var(--brand);
  border: 1px solid var(--line);
}
.v-meal .v-mi svg{ width: 19px; height: 19px; }
.v-meal .v-mt{ flex: 1; }
.v-meal .v-mn{ font-size: var(--t-sm); font-weight: 600; }
.v-meal .v-ms{ font-size: var(--t-xs); color: var(--tx3); }
.v-meal .v-mk{
  font-family: 'Inter', system-ui, sans-serif;
  font-size: var(--t-sm);
  font-weight: 700;
  color: var(--brand);
}
.v-meal .v-mk small{ color: var(--tx4); font-weight: 400; }

.v-wkt{
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  overflow: hidden;
  min-width: 260px;
}
.v-wkt-h{
  display: flex; align-items: center;
  gap: var(--s3);
  padding: var(--s3) var(--s4);
  background: var(--panel-2);
  border-bottom: 1px solid var(--line);
  font-weight: 600;
  font-size: var(--t-sm);
}
.v-wkt-h svg{ width: 16px; height: 16px; color: var(--brand); }
.v-wkt-set{
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--s3) var(--s4);
  border-bottom: 1px solid var(--line);
  font-size: var(--t-sm);
  cursor: pointer;
}
.v-wkt-set:last-child{ border-bottom: 0; }
.v-wkt-set .v-sn{ color: var(--tx2); }
.v-wkt-set .v-sr{
  font-family: 'Inter', system-ui, sans-serif;
  color: var(--tx);
  font-weight: 600;
}
.v-wkt-set .v-schk{
  width: 18px; height: 18px;
  border-radius: var(--r-xs);
  border: 1.5px solid var(--line-2);
  cursor: pointer;
  display: grid; place-items: center;
  transition: background var(--d2) var(--ease), border-color var(--d2) var(--ease);
}
.v-wkt-set .v-schk svg{
  width: 11px; height: 11px;
  color: var(--on-brand);
  opacity: 0;
  transition: opacity var(--d1);
}
.v-wkt-set.v-done .v-schk{ background: var(--brand); border-color: var(--brand); }
.v-wkt-set.v-done .v-schk svg{ opacity: 1; }

.v-habit{ min-width: 260px; }
.v-habit-h{
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: var(--s3);
}
.v-habit-h .v-hn{ font-size: var(--t-sm); font-weight: 600; }
.v-habit-h .v-hs{
  font-family: 'Inter', system-ui, sans-serif;
  font-size: var(--t-xs);
  color: var(--brand);
  display: flex; align-items: center; gap: 4px;
}
.v-habit-h .v-hs svg{ width: 12px; height: 12px; }
.v-habit-grid{
  display: grid;
  grid-template-columns: repeat(14, 1fr);
  gap: 4px;
}
.v-habit-grid .v-hd{
  aspect-ratio: 1;
  border-radius: var(--r-xs);
  background: var(--panel-3);
  cursor: pointer;
  transition: background var(--d1) var(--ease), transform var(--d1) var(--spring);
}
.v-habit-grid .v-hd:hover{ transform: scale(1.2); }
.v-habit-grid .v-hd.v-l1{ background: color-mix(in srgb, var(--brand) 35%, var(--panel-3)); }
.v-habit-grid .v-hd.v-l2{ background: color-mix(in srgb, var(--brand) 65%, transparent); }
.v-habit-grid .v-hd.v-l3{ background: var(--brand); }


/* ============================================================
 * DASHBOARD WIDGET (.v-dw) + KPI (.v-kpi)
 * ============================================================ */
.v-dash{
  border: 1px solid var(--line-2);
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--bg);
  box-shadow: var(--sh);
}
.v-dash-top{
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--s4) var(--s5);
  border-bottom: 1px solid var(--line);
  background: var(--panel);
}
.v-dash-top .v-dgreet{
  font-family: 'Inter', system-ui, sans-serif;
  font-size: var(--t-lg);
  font-weight: 500;
}
.v-dash-top .v-dgreet small{
  display: block;
  font-family: 'Inter', sans-serif;
  font-size: var(--t-xs);
  color: var(--tx3);
  font-weight: 400;
  margin-top: 2px;
}
.v-dash-body{
  padding: var(--s5);
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--s4);
}
.v-dw{
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: var(--s4);
  min-width: 0;
  position: relative;
  overflow: hidden;
  transition: border-color var(--d2) var(--ease), transform var(--d2) var(--ease-out);
}
.v-dw:hover{
  border-color: color-mix(in srgb, var(--brand) 35%, var(--line));
  transform: translateY(-3px);
}
.v-dw > *{ position: relative; }
.v-dw-feat{
  background: linear-gradient(150deg, color-mix(in srgb, var(--brand) 20%, var(--panel)), var(--panel) 68%);
  border-color: color-mix(in srgb, var(--brand) 30%, var(--line));
}
.v-dw-feat .v-kv{ color: var(--brand); }
.v-dw-h{
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: var(--s4);
}
.v-dw-h .v-dwt{
  font-size: var(--t-xs);
  font-family: 'Inter', system-ui, sans-serif;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--tx3);
}
.v-dw-h .v-dwa{
  font-size: var(--t-xs);
  color: var(--brand);
  cursor: pointer;
  transition: color var(--d1);
}
.v-dw-h .v-dwa:hover{ color: var(--brand-2); }

/* col-* spans (12-col grid) */
.v-col-3{  grid-column: span 3; }
.v-col-4{  grid-column: span 4; }
.v-col-5{  grid-column: span 5; }
.v-col-6{  grid-column: span 6; }
.v-col-7{  grid-column: span 7; }
.v-col-8{  grid-column: span 8; }
.v-col-12{ grid-column: span 12; }
.v-kpi{ display: flex; flex-direction: column; gap: 2px; }
.v-kpi .v-kv{
  font-family: 'Inter', system-ui, sans-serif;
  font-size: var(--t-xl);
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  letter-spacing: -.02em;
}
.v-kpi .v-kl{ font-size: var(--t-xs); color: var(--tx3); }

@media (max-width: 720px){
  .v-dash-body{ grid-template-columns: 1fr; }
  .v-col-3, .v-col-4, .v-col-5, .v-col-6, .v-col-7, .v-col-8{ grid-column: span 1; }
}


/* ============================================================
 * CODE BLOCK (.v-code)
 * ============================================================ */
.v-code{
  background: var(--code);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: var(--s5);
  font-family: 'Inter', system-ui, sans-serif;
  font-size: var(--t-xs);
  line-height: 1.7;
  color: var(--tx2);
  overflow-x: auto;
  position: relative;
}
.v-code .v-cmt{ color: var(--tx4); }
.v-code .v-kw{ color: var(--brand); }


/* ============================================================
 * MENU BTN (.v-menu-btn) — hamburger mobile
 * ============================================================ */
.v-menu-btn{
  display: none;
  place-items: center;
  position: fixed;
  top: 14px; left: 14px;
  z-index: 140;
  width: 40px; height: 40px;
  border-radius: var(--r-sm);
  background: var(--panel);
  border: 1px solid var(--line-2);
  cursor: pointer;
  color: var(--tx);
}
@media (max-width: 900px){
  .v-menu-btn{ display: grid; }
}


/* ============================================================
 * UTILITIES
 * ============================================================ */
.v-mono{ font-family: 'Inter', system-ui, sans-serif; font-feature-settings: "tnum"; }
.v-flex{ display: flex; }
.v-inline{ display: inline-flex; }
.v-col{ display: flex; flex-direction: column; }
.v-grow{ flex: 1; min-width: 0; }
.v-center{ align-items: center; justify-content: center; }
.v-between{ justify-content: space-between; }
.v-wrap-flex{ flex-wrap: wrap; }

.v-gap-1{ gap: var(--s1); }
.v-gap-2{ gap: var(--s2); }
.v-gap-3{ gap: var(--s3); }
.v-gap-4{ gap: var(--s4); }
.v-gap-5{ gap: var(--s5); }

.v-mt-2{ margin-top: var(--s2); }
.v-mt-3{ margin-top: var(--s3); }
.v-mt-4{ margin-top: var(--s4); }
.v-mb-2{ margin-bottom: var(--s2); }
.v-mb-3{ margin-bottom: var(--s3); }
.v-mb-4{ margin-bottom: var(--s4); }

.v-divider{
  height: 1px;
  background: var(--line);
  border: 0;
  margin: var(--s3) 0;
}


/* ============================================================
 * UTILITIES (extensão pra eliminar inlines em JS)
 * ============================================================ */

/* containers / layout */
.v-grow-1{ flex: 1; }
.v-shrink-0{ flex-shrink: 0; }
.v-w-full{ width: 100%; }
.v-h-full{ height: 100%; }
.v-relative{ position: relative; }
.v-absolute{ position: absolute; }
.v-overflow-hidden{ overflow: hidden; }
.v-overflow-auto{ overflow: auto; }
.v-text-center{ text-align: center; }
.v-text-right{ text-align: right; }
.v-uppercase{ text-transform: uppercase; }

/* padding/margin escala (extensão) */
.v-p-0{ padding: 0; }
.v-p-1{ padding: var(--s1); }
.v-p-2{ padding: var(--s2); }
.v-p-3{ padding: var(--s3); }
.v-p-4{ padding: var(--s4); }
.v-p-5{ padding: var(--s5); }
.v-p-6{ padding: var(--s6); }
.v-px-2{ padding-left: var(--s2); padding-right: var(--s2); }
.v-px-3{ padding-left: var(--s3); padding-right: var(--s3); }
.v-px-4{ padding-left: var(--s4); padding-right: var(--s4); }
.v-py-2{ padding-top: var(--s2); padding-bottom: var(--s2); }
.v-py-3{ padding-top: var(--s3); padding-bottom: var(--s3); }
.v-py-4{ padding-top: var(--s4); padding-bottom: var(--s4); }

.v-m-0{ margin: 0; }
.v-mt-0{ margin-top: 0; }
.v-mt-1{ margin-top: var(--s1); }
.v-mt-5{ margin-top: var(--s5); }
.v-mt-6{ margin-top: var(--s6); }
.v-mb-0{ margin-bottom: 0; }
.v-mb-1{ margin-bottom: var(--s1); }
.v-mb-5{ margin-bottom: var(--s5); }
.v-mr-auto{ margin-right: auto; }
.v-ml-auto{ margin-left: auto; }
.v-hidden{ display: none !important; }
.v-italic{ font-style: normal; }
.v-z-200{ z-index: 200; }
.v-z-210{ z-index: 210; }
.v-z-215{ z-index: 215; }
.v-z-9500{ z-index: 9500; }
.v-bg-pam-deep{ background: var(--pam-deep); }
.v-bar-fill-w{ width: var(--w, 0); transition: width var(--d3) var(--ease-out); }
.v-max-w-modal-sm{ max-width: 520px; }
.v-max-w-440{ max-width: 440px; }
.v-w-110{ width: 110px; }
.v-w-200{ width: 200px; }
.v-minw-0{ min-width: 0; }
.v-grid-2col{ display: grid; grid-template-columns: 1fr 1fr; }
.v-grid-3col{ display: grid; grid-template-columns: 1fr 1fr 1fr; }

/* small hint mono (financeiro/empresas pj-parc-hint duplicate) */
.v-hint-mono{
  font-family: 'Inter', system-ui, sans-serif;
  font-size: var(--t-sm);
  color: var(--tx2);
  margin-top: var(--s1);
}

/* mono small chip (tag "sem banco" etc) */
.v-tag-mono-chip{
  display: inline-block;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 9px;
  color: var(--tx3);
  text-transform: uppercase;
  letter-spacing: 0.10em;
  background: var(--panel-2);
  padding: 2px 5px;
  border-radius: var(--r-xs);
  margin-left: var(--s1);
}

/* mono small label (uppercase, faint) */
.v-label-mono-faint{
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 11px;
  color: var(--tx3);
  letter-spacing: 0.10em;
  text-transform: uppercase;
  margin-top: 3px;
}
.v-label-mono-faint-9{
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 9px;
  font-weight: 700;
  color: var(--tx3);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-top: var(--s3);
  margin-bottom: var(--s1);
}

/* empty state simple text */
.v-empty-text{
  padding: var(--s3) 0;
  text-align: center;
  color: var(--tx3);
  font-size: var(--t-sm);
}
.v-empty-text-italic{
  padding: var(--s1) 0;
  color: var(--tx3);
  font-size: var(--t-sm);
  font-style: normal;
}
/* empty mono-uppercase pra listas densas ("folga", "todas feitas").
   Promovido do dashboard.css (era falso-DS, prefixo .v- fora do DS). */
.v-list-empty{
  padding: 14px;
  text-align: center;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 10px; font-weight: 600;
  color: var(--tx3);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

/* warning callout (banner inline simples) */
.v-callout-warn{
  background: color-mix(in srgb, var(--warn) 10%, transparent);
  border: 1px solid color-mix(in srgb, var(--warn) 35%, transparent);
  border-radius: var(--r-md);
  padding: var(--s3) var(--s4);
  color: color-mix(in srgb, var(--warn) 55%, var(--tx));
  font-size: var(--t-sm);
  line-height: 1.5;
}
.v-code-inline{
  font-family: 'Inter', system-ui, sans-serif;
  background: rgba(0,0,0,0.30);
  padding: 2px 6px;
  border-radius: var(--r-xs);
}

/* small dim text (hint financeiro) */
.v-text-dim-sm{
  color: var(--tx2);
  font-size: var(--t-sm);
}
.v-text-dim-sm-block{
  color: var(--tx2);
  font-size: var(--t-sm);
  display: block;
  margin-top: -4px;
  margin-bottom: var(--s1);
}

/* font-weight + opacity helpers */
.v-fw-400{ font-weight: 400; }
.v-op-70{ opacity: 0.7; }
.v-mr-1{ margin-right: var(--s1); }
.v-mr-2{ margin-right: var(--s2); }

/* compact button (smaller padding) */
.v-btn-compact{ padding: var(--s2) !important; font-size: var(--t-xs) !important; }

/* input bare (sem borda, transparente) */
.v-input-bare{
  border: none !important;
  background: transparent !important;
  padding: 0 !important;
  font-size: 17px;
  font-weight: 700;
  letter-spacing: -0.01em;
}

/* Botão "Hoje" no calendário (small uppercase brand) */
.v-tag-today{
  display: inline-block;
  font-size: var(--t-sm);
  color: var(--good);
  font-weight: 700;
  letter-spacing: .08em;
  margin-left: var(--s1);
  text-transform: uppercase;
}

/* Share row (Botão compartilhar topo da lista) */
.v-share-row{
  display: flex;
  justify-content: flex-end;
  padding: 0 0 var(--s2);
  border-bottom: 1px solid var(--line);
  margin-bottom: var(--s2);
}
.v-share-btn{
  display: inline-flex; align-items: center;
  gap: 6px;
  padding: 7px 12px;
  background: color-mix(in srgb, var(--brand) 14%, transparent);
  border: 1px solid color-mix(in srgb, var(--brand) 32%, transparent);
  border-radius: var(--r-md);
  color: color-mix(in srgb, var(--brand) 70%, var(--tx));
  font: 600 11.5px/1 'Inter', sans-serif;
  cursor: pointer;
  letter-spacing: -.005em;
}

/* SVG icon ajuste vertical (legacy ajuste -2px) */
.v-svg-align-mid{
  vertical-align: -2px;
  margin-right: var(--s1);
}

/* undo history items - flex grow text + small age */
.v-undo-grow{ flex: 1; overflow: hidden; text-overflow: ellipsis; }
.v-undo-age{
  font: 500 10px/1 'Inter', system-ui, sans-serif;
  color: var(--tx3);
}

/* Bloco de explicação card (texto curto info) */
.v-info-block{
  font-size: var(--t-sm);
  color: var(--tx2);
  margin-bottom: var(--s2);
  line-height: 1.5;
}

.v-op-60{ opacity: 0.6; }

/* Form value mono peso 700 */
.v-fv-mono{
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 700;
}

/* Empty state legacy padding 30 */
.v-empty-tall{
  text-align: center;
  padding: 30px;
  color: var(--tx3);
  font-family: 'Inter', sans-serif;
}

/* link sem decoration (botão como anchor) */
.v-link-bare{ text-decoration: none; }

/* twt edit button — ghost styling */
.v-twt-edit-ghost{
  background: rgba(255,255,255,0.04);
  border-color: rgba(255,255,255,0.12);
  color: var(--tx);
}

/* Otto warning card */
.v-otto-card-warn{
  border-color: var(--otto-warning, var(--warn));
  background: color-mix(in srgb, var(--warn) 6%, transparent);
}

/* Otto faint description text */
.v-otto-faint{
  font-size: var(--t-sm);
  color: var(--otto-text-faint, var(--tx3));
  max-width: 480px;
  line-height: 1.6;
  margin-bottom: var(--s6);
}

/* Modal small fixed (jira sm modal) */
.v-bl-modal-sm{ width: min(380px, 100%); }

/* Progress placeholder 35% (upload em curso fake) */
.v-prog-fake-35{ width: 35%; }

/* Routine progress complete */
.v-rot-prog-complete{
  width: 100%;
  background: var(--rot-success, var(--good));
}

/* Border-left dinâmico (cor passada via --c) */
.v-border-left-c{ border-left: 4px solid var(--c, var(--line)); }

/* Bank chip (background+border+color baseados em --c) */
.v-bank-chip{
  background: color-mix(in srgb, var(--c, var(--brand)) 13%, transparent);
  border: 1px solid color-mix(in srgb, var(--c, var(--brand)) 33%, transparent);
  color: var(--c, var(--brand));
}


/* ============================================================
 * DISPLAY TYPOGRAPHY (Verdant signature)
 * ============================================================ */

/* Page title — Inter display com line-up animation.
   Use:
     <h1 class="v-display">
       <span class="v-ln"><span>Patrick &amp; Pamella —</span></span>
       <span class="v-ln"><span>nosso <em>sistema</em></span></span>
     </h1>
*/
.v-display{
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 500;
  font-size: var(--t-2xl);
  line-height: 1.04;
  letter-spacing: -.025em;
  margin-bottom: var(--s4);
  color: var(--tx);
}
.v-display .v-ln{ display: block; overflow: hidden; }
.v-display .v-ln > span{
  display: inline-block;
  opacity: 0;
  transform: translateY(105%) rotate(2deg);
  animation: v-lineUp .9s var(--ease-out) forwards;
}
.v-display .v-ln:nth-child(1) > span{ animation-delay: .22s; }
.v-display .v-ln:nth-child(2) > span{ animation-delay: .34s; }
.v-display .v-ln:nth-child(3) > span{ animation-delay: .46s; }
.v-display em{
  font-style: normal;
  background: linear-gradient(105deg, var(--brand), var(--g500) 60%, var(--amber));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
@keyframes v-lineUp{ to { opacity: 1; transform: none; } }

/* Display sizes */
.v-display--xl{ font-size: var(--t-3xl); }
.v-display--lg{ font-size: var(--t-2xl); }
.v-display--md{ font-size: var(--t-xl); }
.v-display--sm{ font-size: var(--t-lg); }

/* Kicker — mono uppercase com dot pulsing brand */
.v-kicker{
  display: inline-flex; align-items: center;
  gap: var(--s2);
  font-family: 'Inter', system-ui, sans-serif;
  font-size: var(--t-xs);
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--brand);
  margin-bottom: var(--s4);
  opacity: 0;
  animation: v-heroFade .7s var(--ease-out) .1s forwards;
}
.v-kicker::before{
  content: '';
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--brand);
  will-change: transform, opacity;
  animation: v-kickerPulse 2.4s var(--ease) infinite;
}
/* perf (v3.11.1): era box-shadow animado — main thread, repaint contínuo
   em toda página com kicker/breadcrumb, pra sempre. transform/opacity
   rodam no compositor (will-change promove o pseudo a layer própria). */
@keyframes v-kickerPulse{
  0%, 100% { transform: scale(1);   opacity: 1; }
  50%      { transform: scale(.72); opacity: .5; }
}
@keyframes v-heroFade{
  from{ opacity: 0; transform: translateY(10px); }
  to{ opacity: 1; transform: none; }
}

/* Lead text — parágrafo de intro grande, soft */
.v-lead{
  font-size: var(--t-md);
  color: var(--tx2);
  max-width: 620px;
  margin-bottom: var(--s5);
  opacity: 0;
  animation: v-heroFade .8s var(--ease-out) .5s forwards;
}

/* Mono caption — pequeno rótulo mono uppercase */
.v-caption-mono{
  font-family: 'Inter', system-ui, sans-serif;
  font-size: var(--t-xs);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--tx3);
}

/* Hero numeric value — Inter serif + tabular */
.v-hero-num{
  font-family: 'Inter', system-ui, sans-serif;
  font-size: var(--t-2xl);
  font-weight: 500;
  letter-spacing: -.02em;
  font-variant-numeric: tabular-nums;
  line-height: 1;
  color: var(--tx);
}
.v-hero-num--lg{ font-size: var(--t-3xl); }
.v-hero-num--md{ font-size: var(--t-xl); }

/* Close button × (universal, sem cor especifica) */
.v-btn-close-x{
  background: none;
  border: none;
  color: inherit;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  padding: 0;
  transition: opacity var(--d1) var(--ease);
}
.v-btn-close-x:hover{ opacity: .7; }

/* tipografia */
.v-text-xs{ font-size: var(--t-xs); }
.v-text-sm{ font-size: var(--t-sm); }
.v-text-md{ font-size: var(--t-md); }
.v-text-lg{ font-size: var(--t-lg); }
.v-text-xl{ font-size: var(--t-xl); }
.v-fw-500{ font-weight: 500; }
.v-fw-600{ font-weight: 600; }
.v-fw-700{ font-weight: 700; }
.v-color-tx{ color: var(--tx); }
.v-color-tx2{ color: var(--tx2); }
.v-color-tx3{ color: var(--tx3); }
.v-color-tx4{ color: var(--tx4); }
.v-color-brand{ color: var(--brand); }
.v-color-on-brand{ color: var(--on-brand); }
.v-color-good{ color: var(--good); }
.v-color-warn{ color: var(--warn); }
.v-color-crit{ color: var(--crit); }
.v-color-info{ color: var(--info); }
.v-color-amber{ color: var(--amber); }

/* surfaces */
.v-bg-panel{ background: var(--panel); }
.v-bg-panel-2{ background: var(--panel-2); }
.v-bg-panel-3{ background: var(--panel-3); }
.v-border-line{ border: 1px solid var(--line); }
.v-border-line-2{ border: 1px solid var(--line-2); }
.v-rounded-sm{ border-radius: var(--r-sm); }
.v-rounded-md{ border-radius: var(--r-md); }
.v-rounded-lg{ border-radius: var(--r-lg); }
.v-rounded-full{ border-radius: var(--r-full); }

/* background colors */
.v-bg-brand{ background: var(--brand); }
.v-bg-brand-2{ background: var(--brand-2); }
.v-bg-good{ background: var(--good); }
.v-bg-info{ background: var(--info); }
.v-bg-warn{ background: var(--warn); }
.v-bg-crit{ background: var(--crit); }
.v-bg-amber{ background: var(--amber); }
.v-bg-white{ background: var(--tx); }

/* cursor */
.v-cursor-pointer{ cursor: pointer; }
.v-cursor-default{ cursor: default; }

/* dynamic-color helpers (data-passing via --c) */
.v-color-c{ color: var(--c, var(--tx)); }
.v-bg-c{ background: var(--c, transparent); }
.v-border-c{ border-color: var(--c, var(--line)); }
.v-border-color-c{ border-color: var(--c, var(--line)) !important; }

/* dynamic-width helper */
.v-width-w{ width: var(--w, 0); transition: width var(--d3) var(--ease-out); }

/* truncate text */
.v-text-truncate{
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* color Patrick (azul branding) */
.v-color-pat{ color: var(--pat); }
.v-color-pam{ color: var(--pam); }
.v-bg-pat{ background: var(--pat); }
.v-bg-pam{ background: var(--pam); }
.v-border-pat{ border-color: var(--pat); }
.v-border-pam{ border-color: var(--pam); }

/* página-específico legacy: twt filter bar */
.twt-filter-bar{
  margin-bottom: var(--s4);
  padding-bottom: var(--s3);
  border-bottom: 1px solid var(--line);
}

/* mono (números/dados) */
.v-num{
  font-family: 'Inter', system-ui, sans-serif;
  font-feature-settings: "tnum";
  letter-spacing: 0;
}

/* Rich Error / Dialog content (substitui inlines em errors.js, areas-da-vida.js etc) */
.v-rich-backdrop{
  position: fixed; inset: 0;
  z-index: 99999;
  background: rgba(0,0,0,0.78);
  display: flex; align-items: center; justify-content: center;
  padding: var(--s6);
  /* perf (v3.14.5): sem backdrop-filter (blur full-screen pesa no compositor) */
}
.v-rich-modal-close{
  background: transparent;
  border: none;
  color: var(--tx3);
  font-size: 22px;
  cursor: pointer;
  padding: 0;
  width: 28px; height: 28px;
  display: flex; align-items: center; justify-content: center;
  border-radius: var(--r-xs);
  transition: background var(--d1) var(--ease), color var(--d1) var(--ease);
}
.v-rich-modal-close:hover{
  background: var(--panel-2);
  color: var(--tx);
}
.v-items-center{ align-items: center; }
.v-rich-modal{
  max-width: 520px;
  width: 100%;
  padding: var(--s7) var(--s6);
  background: var(--panel);
  border: 1px solid var(--line-2);
  border-radius: var(--r-lg);
  box-shadow: var(--sh);
  display: flex; flex-direction: column;
  gap: var(--s4);
}
.v-rich-modal--crit{ border-color: color-mix(in srgb, var(--crit) 40%, var(--line)); }
.v-rich-modal--warn{ border-color: color-mix(in srgb, var(--warn) 40%, var(--line)); }
.v-rich-modal--good{ border-color: color-mix(in srgb, var(--good) 40%, var(--line)); }
.v-rich-modal-title{
  display: flex; align-items: center;
  gap: var(--s2);
  font: 600 var(--t-md)/1 'Inter', sans-serif;
  color: var(--tx);
}
.v-rich-modal-title.v-crit{ color: var(--crit); }
.v-rich-modal-title.v-warn{ color: var(--warn); }
.v-rich-modal-title.v-good{ color: var(--good); }
.v-rich-modal-msg{
  font: 400 var(--t-sm)/1.5 'Inter', sans-serif;
  color: var(--tx);
}
.v-rich-modal-msg-dim{
  font: 400 var(--t-sm)/1.5 'Inter', sans-serif;
  color: var(--tx2);
}
.v-rich-modal-mono{
  font: 600 var(--t-xs)/1 'Inter', system-ui, sans-serif;
  background: var(--panel-2);
  padding: 4px 8px;
  border-radius: var(--r-xs);
  color: var(--tx2);
  display: inline-block;
}
.v-rich-modal-actions{
  display: flex; gap: var(--s2);
  justify-content: flex-end;
  margin-top: var(--s2);
}

/* Progress bar fill via CSS var */
.v-bar-fill{
  height: 100%;
  width: var(--w, 0);
  background: var(--c, var(--brand));
  border-radius: inherit;
  transition: width var(--d3) var(--ease-out);
}

/* Category icon swatch (cor dinâmica via --c) */
.v-cat-icon{
  display: inline-flex; align-items: center; justify-content: center;
  width: 26px; height: 26px;
  border-radius: var(--r-sm);
  background: color-mix(in srgb, var(--c, var(--tx3)) 14%, transparent);
  color: var(--c, var(--tx3));
  border: 1px solid color-mix(in srgb, var(--c, var(--tx3)) 30%, transparent);
}
.v-cat-icon svg{ width: 14px; height: 14px; }

/* Person tag (Patrick/Pamella) — cor via --c */
.v-person-tag{
  display: inline-flex; align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: var(--r-full);
  font: 600 var(--t-xs)/1 'Inter', sans-serif;
  color: var(--c, var(--tx2));
  border: 1px solid color-mix(in srgb, var(--c, var(--tx2)) 40%, transparent);
  background: color-mix(in srgb, var(--c, var(--tx2)) 12%, transparent);
}

/* Sparkline path — usa currentColor pra cor dinâmica via class .v-color-* */
.v-sparkline{ width: 100%; height: 32px; display: block; }
.v-sparkline path{ stroke: currentColor; stroke-width: 2; fill: none; stroke-linecap: round; stroke-linejoin: round; }
.v-sparkline circle{ fill: currentColor; }

/* v3.15.1: campos dentro de form-group em modal SEMPRE full width.
   (.v-inp/.v-sel têm width:200px fixo — em coluna flex não esticam e
   sobrava metade da modal vazia; bug recorrente em várias modais.) */
.v-modal-body .v-form-group .v-inp,
.v-modal-body .v-form-group select,
.v-modal-body .v-form-group .v-sel,
.v-modal-body .v-form-group .v-ta{
  width: 100%;
  box-sizing: border-box;
}
