﻿/* ============================================================ */
/* LifeOS · style.css · LEGACY                                  */
/* ------------------------------------------------------------ */
/* v4.0.0: o bloco :root foi removido daqui. Tokens vivem agora */
/* em /design-system/tokens.css (canônico) + camada de compat   */
/* em /assets/base.css (mapeia legacy → Verdant).               */
/* As regras abaixo são removidas progressivamente conforme as  */
/* páginas migram pro DS na Fase 3.                             */
/* ============================================================ */

/* globals (box-sizing, focus, body, scroll, svg) movidos pra /design-system/reset.css */

/* loading splash movido pra /assets/base.css § 3 */

/* ============ WRAP ============ */
.wrap{
  display:grid;
  grid-template-columns:280px 1fr 1fr 300px;
  grid-template-rows:1fr;
  grid-template-areas:
    "lsb pat pam rsb";
  /* v2.39.0: sem header em cima (sidebar é lateral agora). Em mobile a topbar
     já é compensada via padding-top do body — vide sidebar.css. */
  height:100vh;
  padding:14px;gap:14px;overflow:hidden;
  max-width:var(--page-max);
  margin:0 auto;
  min-width:0;
}
.wrap.fade-in{animation:wrapFadeIn 1.6s var(--ease-out) forwards}
@keyframes wrapFadeIn{
  0%{opacity:0;transform:translateY(20px) scale(0.985);filter:blur(10px)}
  60%{filter:blur(0)}
  100%{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}
}
.wrap.fade-in > *{animation:childFadeIn 1s var(--ease-out) both}
.wrap.fade-in > *:nth-child(1){animation-delay:var(--d2)}
.wrap.fade-in > *:nth-child(2){animation-delay:var(--d3)}
.wrap.fade-in > *:nth-child(3){animation-delay:var(--d3)}
.wrap.fade-in > *:nth-child(4){animation-delay:0.50s}
.wrap.fade-in > *:nth-child(5){animation-delay:0.60s}
.wrap.fade-in > *:nth-child(6){animation-delay:0.70s}
.wrap.fade-in > *:nth-child(7){animation-delay:0.80s}
@keyframes childFadeIn{
  from{opacity:0;transform:translateY(10px) scale(0.99)}
  to{opacity:1;transform:translateY(0) scale(1)}
}

/* ============ HEADER ============ */
/* v3.0.2: .lifeos-hdr* dead code removido (sidebar substituiu). .hdr ainda
   é usado por componentes internos (cards de seções). */
.hdr{grid-area:hdr;display:grid;grid-template-columns:1fr auto;align-items:center;gap:20px;padding:0 4px}
.hdr-left{display:flex;align-items:center;gap:32px}
.logo{display:flex;align-items:center;gap:12px}
.logo-ic{
  width:46px;height:46px;border-radius:50%;
  background:transparent;color:#fff;
  display:flex;align-items:center;justify-content:center;
  position:relative;
  filter:drop-shadow(0 0 12px rgba(255,255,255,0.15));
}
.logo-ic svg{width:100%;height:100%;animation:logoBreath 4s ease-in-out infinite}
@keyframes logoBreath{
  0%,100%{transform:scale(1);opacity:1}
  50%{transform:scale(1.06);opacity:0.9}
}
.logo-tx{display:flex;flex-direction:column;gap:2px;line-height:1}
.logo-tx b{font-size:21px;font-weight:800;letter-spacing:-0.02em;color:var(--tx)}
.logo-tx small,.logo-version{
  font-family:var(--ff-mono);font-size:11px;font-weight:600;
  color:var(--tx3);letter-spacing:0.16em;text-transform:uppercase;
}

.date-wrap{display:flex;flex-direction:column;gap:2px;line-height:1.1}
.tl{
  font-family:var(--ff-mono);font-size:10px;font-weight:600;
  color:var(--tx2);letter-spacing:0.20em;text-transform:uppercase;
}
.td{font-size:38px;font-weight:800;letter-spacing:-0.025em;color:var(--tx);line-height:1}
.tdt{font-family:var(--ff-mono);font-size:10px;font-weight:500;color:var(--tx2);margin-top:4px}
.back-btn{
  margin-top:6px;align-self:flex-start;padding:5px 11px;
  background:transparent;border:1px solid var(--line-2);
  border-radius:7px;color:var(--tx2);cursor:pointer;
  font-family:var(--ff-mono);font-size:11px;font-weight:700;
  letter-spacing:0.12em;text-transform:uppercase;transition:all var(--d1);
}
.back-btn:hover{background:var(--panel-2);color:var(--tx);border-color:var(--line-2)}

/* v2.6.1: navegação dia anterior / próximo */
.dt-nav{
  display:flex;gap:6px;margin-top:10px;
}
/* .dt-nav-btn migrado pra .v-btn v-btn-sec v-btn--mono (v4.0.13).
   Hook só pra esticar 50/50 (anterior/próximo) lado a lado. */
.dt-nav-btn{ flex:1; white-space:nowrap; }

.ck{display:flex;align-items:center;gap:10px}
.opt-btn{
  display:inline-flex;align-items:center;gap:8px;padding:9px 14px;
  background:transparent;border:1px solid var(--line-2);
  border-radius:9px;color:var(--tx);cursor:pointer;
  font-size:12px;font-weight:600;transition:all var(--d2);white-space:nowrap;
}
.opt-btn:hover{background:var(--panel-2);color:var(--tx);border-color:var(--line-2)}
.opt-btn svg{width:14px;height:14px}

/* Botão de atalhos (v2.5.1) — entre Opções e Sair */
.shortcuts-btn{
  width:38px;height:38px;background:transparent;
  border:1px solid var(--line-2);border-radius:9px;
  color:var(--tx2);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  padding:0;transition:all var(--d2);
}
.shortcuts-btn:hover{background:var(--panel-2);color:var(--tx);border-color:var(--line-2)}
.shortcuts-btn svg{width:16px;height:16px}

/* .hamburger-btn removido v3.0.2 — substituído por .lifeos-sb-hamburger */

.logout-btn{
  width:38px;height:38px;background:transparent;
  border:1px solid var(--line-2);border-radius:9px;
  color:var(--tx2);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  padding:0;transition:all var(--d2);
}
.logout-btn:hover{background:var(--panel-2);color:var(--tx);border-color:var(--line-2)}
.logout-btn svg{width:15px;height:15px}

.clock-wrap{display:flex;flex-direction:column;align-items:flex-end;gap:6px;margin-left:6px}
.ct{
  display:flex;align-items:baseline;justify-content:flex-end;gap:1px;
  font-family:var(--ff-mono);font-size:24px;font-weight:700;
  color:var(--tx);letter-spacing:-0.01em;font-feature-settings:"tnum";
}
.ct small{font-size:14px;color:var(--tx2);font-weight:500}
.cn{
  display:inline-flex;align-items:center;gap:5px;padding:4px 9px;
  background:var(--panel);border:1px solid var(--line);border-radius:6px;
  font-family:var(--ff-mono);font-size:11px;font-weight:600;
  color:var(--tx2);letter-spacing:0.06em;text-transform:uppercase;
}
.cn svg{width:10px;height:10px}

/* login screen movido pra /assets/base.css § 4 */

/* sync-dot, edit-del, undo/app toast movidos pra /assets/base.css § 5,7,8 */

/* ============ SIDEBARS ============ */
.lsb{grid-area:lsb;display:flex;flex-direction:column;gap:14px;overflow:hidden;min-width:0;min-height:0}
.rsb{grid-area:rsb;display:flex;flex-direction:column;gap:14px;overflow:hidden;min-height:0}
.rsb .lc-sec{flex:1 1 0;min-height:180px;display:flex;flex-direction:column}
.rsb .lc-sec > .collapse-body{flex:1;min-height:0;display:flex;flex-direction:column}
.rsb .lc-sec .lc{flex:1;min-height:80px}
.rsb .fin-sec{flex-shrink:0}

/* ============ PESSOAS ============ */
.pcol{
  background:var(--panel-2);
  border:1px solid rgba(255,255,255,0.07);
  border-radius:var(--r-lg);padding:16px;
  display:flex;flex-direction:column;gap:12px;
  overflow-y:auto;overflow-x:hidden;transition:border-color var(--d2),box-shadow var(--d2);
  box-shadow:0 1px 0 rgba(255,255,255,0.03) inset;
  min-width:0;min-height:0;
  /* v4.0.8: força respeitar a row do grid (1fr). Sem isso, conteudo grande
     da .pbd estica a .pcol verticalmente e o overflow-y:auto nao dispara. */
  height:100%;
}
.pcol.pat{grid-area:pat}
.pcol.pam{grid-area:pam}
.pcol:hover{border-color:rgba(255,255,255,0.12)}
.ph{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 4px 14px;border-bottom:1px solid var(--line)}
.phn{display:flex;align-items:center;gap:11px}
.pha{
  width:38px;height:38px;border-radius:50%;overflow:hidden;
  background:var(--panel-2);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  color:var(--tx2);font-weight:700;font-size:13px;
}
.pha img{width:100%;height:100%;object-fit:cover}
.pl{font-size:18px;font-weight:700;color:var(--tx);letter-spacing:-0.015em}
.pm{display:flex;align-items:center;gap:10px}
.pb{width:80px;height:5px;background:var(--panel-2);border-radius:var(--r-full);overflow:hidden}
.pbf{height:100%;background:var(--tx);transition:width var(--d3) var(--ease-out),background var(--d2);border-radius:var(--r-full)}
.pcol.pat .pbf{background:var(--pat)}
.pcol.pam .pbf{background:var(--pam)}
.pb.done .pbf{background:var(--good);box-shadow:0 0 12px color-mix(in srgb, var(--good) 40%, transparent)}
.pct{font-family:var(--ff-mono);font-size:10px;font-weight:700;color:var(--tx2);letter-spacing:0.04em;font-feature-settings:"tnum"}
.pct.done{color:var(--good)}
/* v4.0.7: scroll na .pcol externa, secoes (Tarefas/Dieta/Saude/Remedios)
   crescem natural. .pbd nao scrolla mais — uma barra vertical por coluna. */
.pbd{display:flex;flex-direction:column;gap:14px;padding-right:2px}

/* ============ SEÇÕES ============ */
.sec{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md);padding:13px 14px}
.pcol .sec{background:var(--bg);border-color:rgba(255,255,255,0.04)}
.sh{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--line);flex-wrap:wrap;gap:6px}
.st{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:700;color:var(--tx);letter-spacing:0.18em;text-transform:uppercase;min-width:0;flex-wrap:wrap}
.sd{display:none}
.sc{font-family:var(--ff-mono);font-size:10px;font-weight:600;color:var(--tx2);letter-spacing:0.04em;font-feature-settings:"tnum"}

/* ============ CHIP PADRÃO DO SITE (v2.31.17) ============ */
/* Chip pílula usado em breakdowns de cards. Padrão único pra todo o LifeOS.
   Variantes:
   - .fin-hero-chip (default cinza)
   - .fin-hero-chip.neg (vermelho — saída/desconto)
   - .fin-hero-chip.pos (verde — entrada)
   - .fin-hero-chip.pat-chip / .pam-chip (PF — owner branding)
*/
.fin-hero-chip{
  display:inline-flex;align-items:center;
  padding:5px 10px;
  background:var(--panel-2);
  border:1px solid var(--line);
  border-radius:var(--r-full);
  font-family:var(--ff-mono,monospace);font-size:12px;font-weight:600;
  color:var(--tx);letter-spacing:0.04em;
}
.fin-hero-chip.neg{
  color:color-mix(in srgb, var(--crit) 70%, var(--tx));
  background:color-mix(in srgb, var(--crit) 10%, transparent);
  border-color:color-mix(in srgb, var(--crit) 28%, transparent);
}
.fin-hero-chip.pos{
  color:color-mix(in srgb, var(--good) 75%, var(--tx));
  background:color-mix(in srgb, var(--good) 10%, transparent);
  border-color:color-mix(in srgb, var(--good) 28%, transparent);
}

/* modals/forms movidos pra /assets/base.css § 9,10 */

/* ============ MEAL CHECK MODAL ============ */
.meal-check-modal{max-width:480px}
.meal-check-header{padding:20px 24px 14px;border-bottom:1px solid var(--line)}
.meal-check-title{font-size:20px;font-weight:800;color:var(--tx);letter-spacing:-0.02em}
.meal-check-sub{font-family:var(--ff-mono);font-size:10px;color:var(--tx2);font-weight:600;letter-spacing:0.10em;text-transform:uppercase;margin-top:4px}
.meal-check-body{padding:18px 24px}
.meal-check-label{font-family:var(--ff-mono);font-size:10px;font-weight:700;color:var(--tx2);letter-spacing:0.14em;text-transform:uppercase;margin-bottom:8px;display:block}
.meal-check-textarea{width:100%;min-height:140px;padding:13px 14px;background:var(--panel-2);border:1px solid var(--line-2);border-radius:9px;color:var(--tx);font-family:var(--ff);font-size:14px;line-height:1.5;font-weight:500;outline:none;resize:vertical;transition:border-color var(--d1)}
.meal-check-textarea:focus{border-color:var(--tx)}
.meal-check-textarea.edited{border-color:var(--warn);box-shadow:0 0 0 3px color-mix(in srgb, var(--warn) 8%, transparent)}
.meal-check-textarea.dim{opacity:0.55}
.meal-check-hint{font-family:var(--ff-mono);font-size:10px;color:var(--tx3);font-weight:500;letter-spacing:0.04em;margin-top:7px}
.meal-check-hint.edited{color:color-mix(in srgb, var(--warn) 80%, var(--tx))}
.meal-check-banner{background:color-mix(in srgb, var(--warn) 10%, transparent);border-top:1px solid color-mix(in srgb, var(--warn) 30%, transparent);border-bottom:1px solid color-mix(in srgb, var(--warn) 30%, transparent);padding:11px 24px;font-size:12px;color:color-mix(in srgb, var(--warn) 55%, var(--tx));line-height:1.4}
.meal-check-banner.skip b{color:color-mix(in srgb, var(--warn) 80%, var(--tx));font-weight:700}
.meal-check-actions{padding:16px 24px 20px;display:flex;gap:8px;justify-content:space-between}
/* .meal-btn migrado pro DS (v4.0.13): .ok → v-btn v-btn-pri (era branco,
   agora verde brand); .skip → v-btn v-btn-gho. Hook flex:1 mantido. */
.meal-check-actions .v-btn{flex:1}

/* confirm modal movido pra /assets/base.css § 10 */

/* save-feedback deprecated — removido */

/* confetti movido pra /assets/base.css § 6 */

/* ============ ANIMAÇÕES ============ */
.v-form-modal.shake{animation:shakeAnim var(--d3) ease-in-out}
@keyframes shakeAnim{0%,100%{transform:translateX(0)}15%,45%,75%{transform:translateX(-7px)}30%,60%,90%{transform:translateX(7px)}}
@keyframes pulseCheck{0%{transform:scale(1)}40%{transform:scale(1.025);box-shadow:0 0 0 5px rgba(255,255,255,0.12)}100%{transform:scale(1);box-shadow:0 0 0 0 rgba(255,255,255,0)}}
.v-task.pulse-check,.v-meal.pulse-check,.li.pulse-check,.hc.pulse-check{animation:pulseCheck var(--d3) ease-out}

/* date/time picker dark-mode movido pra /design-system/reset.css */

/* ============ MOBILE / TABLET ============ */
@media (min-width: 1200px) and (max-width: 1599px){
  /* Desktop pequeno: tudo continua visível mas com scroll interno em pcol */
  .wrap{grid-template-columns:280px 1fr 1fr 300px}
  .pcol{overflow-y:auto}
  .pbd{overflow:visible}
  .lsb,.rsb{overflow-y:auto}
}

@media (max-width: 1199px){
  /* Layout: vertical, sem grid */
  .wrap{display:flex !important;flex-direction:column;height:auto;min-height:100vh;padding:8px;gap:8px}

  /* Header mobile: logo esquerda, hamburger direita — TUDO ELSE escondido */
  .hide-on-mobile{display:none !important}

  /* v3.0.2: bloco .lifeos-hdr* + .hamburger-btn dead removido. .hdr mantido
     pra components internos (.hdr-left etc) usados em cards de seção. */
  .hdr-left{flex-direction:row;justify-content:flex-start;align-items:center;gap:12px}
  .logo-ic{width:34px;height:34px;font-size:18px}
  .logo-tx b{font-size:16px}
  .logo-tx small{font-size:9px}

  /* lsb e rsb viram só containers transparentes — filhos viram irmãos diretos do wrap pra ordenar globalmente */
  .lsb,.rsb{display:contents}

  /* Card de dia/horário sempre visível, fora do accordion */
  .dt-card{order:0}

  /* Ordem dos collapses: notas, compromissos, lista, patrick, pamella, financeiro */
  .qn-sec{order:1}
  .cp-sec{order:2}
  .lc-sec{order:3}
  .pcol.pat{order:4}
  .pcol.pam{order:5}
  .fin-sec{order:6}

  /* Pcols ajuste mobile */
  .pcol{padding:0;min-height:auto;overflow:visible;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md)}
  .pbd{overflow:visible;min-height:0}

  /* Sec quando é collapse: padding e visual */
  .sec.collapsible{padding:0;overflow:hidden}
  .sec.collapsible > .sh{
    margin:0;padding:14px 16px;border-bottom:none;
    cursor:pointer;user-select:none;
    display:flex;align-items:center;gap:10px;
  }
  .sec.collapsible.expanded > .sh{border-bottom:1px solid var(--line)}
  .sec.collapsible > .sh > .st{font-size:13px}
  .sec.collapsible > .sh > .sc{margin-left:auto;font-size:11px}
  .sec.collapsible > .sh > .collapse-chevron{display:block;margin-left:6px;flex-shrink:0}
  .sec.collapsible > .collapse-body{padding:14px 16px}

  /* Botão fin-toggle (mostrar/ocultar fin) escondido no mobile (gerenciamos via collapse) */
  .sec.fin-sec .fin-toggle{display:none}

  /* Pcol como collapse */
  .pcol.collapsible{padding:0;overflow:hidden;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md)}
  .pcol.collapsible > .ph{
    cursor:pointer;user-select:none;
    padding:14px 16px;border-bottom:none;
    display:flex;align-items:center;gap:10px;
  }
  .pcol.collapsible.expanded > .ph{border-bottom:1px solid var(--line)}
  .pcol.collapsible > .ph > .collapse-chevron{display:block;flex-shrink:0;margin-left:6px}
  .pcol.collapsible > .collapse-body{padding:14px 16px}

  /* COLLAPSE: máxima especificidade pra ganhar de qualquer outra regra */
  .wrap .collapsible.collapsed > .collapse-body{display:none !important}
  .wrap .collapsible.expanded > .collapse-body{
    display:block !important;
    animation:collapseSlideDown var(--d2) var(--ease-out);
  }
  @keyframes collapseSlideDown{
    from{opacity:0;transform:translateY(-4px)}
    to{opacity:1;transform:translateY(0)}
  }

  /* Chevron animation */
  .wrap .collapsible .collapse-chevron{
    display:block !important;
    width:18px;height:18px;color:var(--tx2);
    transition:transform var(--d2) ease;
  }
  .wrap .collapsible.expanded > .sh > .collapse-chevron,
  .wrap .collapsible.expanded > .ph > .collapse-chevron{
    transform:rotate(180deg);color:var(--tx);
  }

  /* mobile-other-toggle não é mais necessário (cada um é collapse) */
  .mob-other-toggle{display:none !important}

  /* Sec genérico (sem collapse) — padding normal */
  .sec:not(.collapsible){padding:10px}

  /* Reset COMPLETO no mobile: sec não estica, deixa conteúdo determinar altura */
  .wrap .qn-sec,
  .wrap .cp-sec,
  .wrap .lc-sec,
  .wrap .fin-sec{
    flex:0 0 auto !important;
    height:auto !important;
    min-height:auto !important;
    overflow:visible !important;
    display:block !important;
  }
  .wrap .qn-sec > .collapse-body,
  .wrap .cp-sec > .collapse-body,
  .wrap .lc-sec > .collapse-body,
  .wrap .fin-sec > .collapse-body{
    flex:0 0 auto !important;
    min-height:auto !important;
    overflow:visible !important;
    height:auto !important;
  }
  .wrap .qn-list{max-height:50vh}
  .wrap .lc{max-height:60vh;flex:0 0 auto}

  /* Itens (tarefas, refeições, listas) — padding mobile */
  .v-task,.li,.lci,.v-cpi{padding:11px 12px;min-height:44px;padding-right:68px}
  .v-tc,.lck{width:18px;height:18px}
  .dg{grid-template-columns:1fr 1fr;gap:5px}
  .sg{grid-template-columns:1fr;gap:6px}
  .hc{min-height:auto;padding:11px}
  .fr{padding:10px 11px}.fv{font-size:18px}
  .fg{grid-template-columns:1fr 1fr;gap:4px}
  .ot{padding:10px}.otpc{font-size:20px}

  /* Modais bottom-sheet */
  .v-modal-backdrop{padding:0;align-items:flex-end}
  .modal,.v-form-modal,.cal-modal,.twt-modal{width:100%;max-width:100%;max-height:92vh;border-radius:16px 16px 0 0}
  .v-form-actions{flex-direction:column-reverse}
  .v-form-row{grid-template-columns:1fr}
  .login-box{padding:32px 22px;border-radius:16px}
  .login-title{font-size:26px}
  .undo-toast{bottom:14px;left:8px;right:8px;width:auto;max-width:calc(100% - 16px)}

  /* Botões edit/del polidos */
  .edit-del{width:26px;height:26px;right:6px}
  .edit-del2{width:24px;height:24px;right:38px}
  .cal-day{min-height:42px}
  .cal-day-n{font-size:13px}
  .save-feedback-inner{padding:22px 30px}
  .save-feedback-inner svg{width:50px;height:50px}
  .save-feedback-txt{font-size:16px}

  /* Sidebar: usuário pode ver normalmente */
  .msb{padding-top:max(env(safe-area-inset-top), 0px)}

  /* Menu opções no mobile fica centralizado */
  .opt-menu.mobile{
    min-width:260px;
    max-width:88vw;
  }

  @supports(padding:max(0px)){
    .wrap{padding-left:max(8px,env(safe-area-inset-left));padding-right:max(8px,env(safe-area-inset-right))}
    .hdr{padding-top:max(10px,env(safe-area-inset-top))}
  }
}

/* ============================================================ */
/* CLASSES COMPLEMENTARES                                        */
/* ============================================================ */

/* lista de fixas/expenses */
.list-item{
  display:flex;align-items:center;gap:10px;
  padding:9px 11px;
  background:var(--panel-2);
  border:1px solid var(--line);
  border-radius:6px;
  font-size:12px;
}
.list-item:hover{background:var(--panel-2);border-color:var(--line-2)}
.list-item-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}
.list-item-name{font-size:12px;font-weight:600;color:var(--tx);letter-spacing:-0.005em}
.list-item-sub{font-family:var(--ff-mono);font-size:11px;color:var(--tx3);font-weight:500;letter-spacing:0.04em}
.list-item-value{font-family:var(--ff-mono);font-size:12px;font-weight:700;color:var(--tx);font-feature-settings:"tnum"}
.list-item-actions{display:flex;gap:4px;align-items:center}
.list-action{
  width:24px;height:24px;
  background:transparent;
  border:1px solid var(--line-2);
  border-radius:5px;
  color:var(--tx2);cursor:pointer;
  font-size:11px;line-height:1;padding:0;
  display:flex;align-items:center;justify-content:center;
  transition:all var(--d1);
}
.list-action:hover{background:var(--panel-2);color:var(--tx);border-color:var(--tx2)}
.list-action.del{color:color-mix(in srgb, var(--crit) 70%, var(--tx));border-color:color-mix(in srgb, var(--crit) 25%, transparent);background:color-mix(in srgb, var(--crit) 6%, transparent)}
.list-action.del:hover{background:color-mix(in srgb, var(--crit) 18%, transparent);color:#fff;border-color:color-mix(in srgb, var(--crit) 50%, transparent)}

.list-total{
  display:flex;justify-content:space-between;align-items:center;
  padding:10px 12px;margin-top:6px;
  background:var(--panel);
  border:1px solid var(--line-2);
  border-radius:7px;
}
.list-total-lbl{font-family:var(--ff-mono);font-size:11px;font-weight:700;color:var(--tx2);letter-spacing:0.14em;text-transform:uppercase}
.list-total-val{font-size:14px;font-weight:800;color:var(--tx);letter-spacing:-0.01em;font-feature-settings:"tnum"}

/* ============================================================
 * Componentes universais (eram em dashboard.css mas usados em
 * modais que abrem da home/financeiro que NAO carregam dashboard.css)
 * v4.0.6: .mode-btn, .day-chip, .day-picker, .day-hint, .edit-add
 * ============================================================ */

/* .edit-add: botao "+ adicionar X" tracejado (dashed border) */
.edit-add{
  margin-top:4px;padding:8px;background:transparent;
  border:1px dashed var(--line-2);border-radius:var(--r-sm);
  color:var(--tx2);cursor:pointer;
  font-family:var(--ff-mono);font-size:10px;font-weight:700;
  letter-spacing:0.1em;text-transform:uppercase;
  transition:all var(--d1) var(--ease);width:100%;
}
.edit-add:hover{
  background:var(--panel-2);color:var(--tx);border-color:var(--tx2);
}

/* .mode-btn: toggle group (ex: Recorrente / Data especifica) */
.mode-btn{
  padding:6px 12px;
  background:var(--panel-2);
  border:1px solid var(--line);
  border-radius:var(--r-full);
  color:var(--tx2);
  font-family:var(--ff);
  font-size:11px;
  font-weight:600;
  cursor:pointer;
  transition:all var(--d1) var(--ease);
}
.mode-btn:hover{color:var(--tx);border-color:var(--line-2);}
/* .mode-btn.active eh definido em base.css § 13 (verde brand !important) */

/* .day-picker: container de chips de dias da semana */
.day-picker{
  display:flex;flex-wrap:wrap;gap:6px;
  align-items:center;
}
.day-hint{
  font-size:11px;
  color:var(--tx3);
  margin-top:6px;
  line-height:1.4;
}

/* .day-chip: chip individual do dia (Diaria/Dom/Seg/...) */
.day-chip{
  padding:5px 11px;
  background:var(--panel-2);
  border:1px solid var(--line);
  border-radius:var(--r-full);
  color:var(--tx2);
  font-family:var(--ff-mono);
  font-size:11px;
  font-weight:600;
  letter-spacing:0.04em;
  cursor:pointer;
  transition:all var(--d1) var(--ease);
}
.day-chip:hover{color:var(--tx);border-color:var(--tx2);}
.day-chip.active{
  background:color-mix(in srgb, var(--brand) 14%, transparent);
  border-color:color-mix(in srgb, var(--brand) 45%, transparent);
  color:color-mix(in srgb, var(--brand) 75%, var(--tx));
}
.day-chip.daily{
  font-family:var(--ff);
  font-size:11.5px;
  letter-spacing:normal;
  text-transform:none;
}
.day-chip.daily.active{
  background:var(--brand);
  border-color:var(--brand);
  color:var(--on-brand);
}


/* card-input-row (cartões de crédito quick edit) */
.card-input-row{
  display:flex;gap:6px;align-items:center;
  padding:8px 10px;
  background:var(--panel-2);
  border:1px solid var(--line);
  border-radius:6px;
  margin-top:4px;
}
.card-input-row .v-inp{
  flex:1;padding:7px 10px;font-size:12px;
  background:var(--panel-2);
}
.card-input-row .v-btn{padding:7px 12px;font-size:11px}

/* mode-panel — só estrutura, conteúdo flexível */
.mode-panel{display:flex;flex-direction:column;gap:6px}

/* otfl/otfr — splits do orçamento */
.otfl,.otfr{font-family:var(--ff-mono);font-size:11px;color:var(--tx2);font-weight:500;letter-spacing:0.04em}
.otfr{color:var(--tx3);text-align:right}

/* tasks-sec, diet-sec, health-sec — alias de .sec, sem regra extra */

/* login-spinner — spinner do botão login */
.login-spinner{
  display:inline-block;width:14px;height:14px;
  border:2px solid currentColor;border-top-color:transparent;
  border-radius:50%;
  animation:btnSpin 0.7s linear infinite;
}

/* cal-days — só identificador, herda de .cal-grid */

/* ============ MOBILE TOGGLE PESSOA ============ */
.mob-other-toggle{
  display:none;width:100%;
  margin-top:8px;padding:9px;
  background:transparent;
  border:1px dashed var(--line-2);
  border-radius:7px;
  color:var(--tx2);cursor:pointer;
  font-family:var(--ff-mono);font-size:10px;font-weight:700;
  letter-spacing:0.10em;text-transform:uppercase;
  align-items:center;justify-content:center;gap:6px;
  transition:all var(--d1);
}
.mob-other-toggle svg{width:13px;height:13px;transition:transform var(--d2)}
.mob-other-toggle:hover{background:var(--panel-2);color:var(--tx)}
.mob-other-toggle.expanded svg{transform:rotate(180deg)}

/* ============ EDIT INDICATOR (legacy — backup do borda) ============ */
/* ============ FIN BODY (wrapper) ============ */
.fin-body{display:flex;flex-direction:column;gap:10px}

/* ============================================================ */
/* RESPONSIVIDADE INTERMEDIÁRIA (entre tablet e full HD)         */
/* Quando largura não dá pra mostrar tudo confortável,           */
/* habilita scroll interno nos cards de saúde sem estourar.     */
/* ============================================================ */

/* v2.6.1: 1200-2199px → saúde empilhada (1 coluna interna) */
@media (min-width: 1200px) and (max-width: 2199px){
  .sg{grid-template-columns:1fr !important;gap:14px !important}
  .hc{margin:0}
}
/* ≥2200px usa o default (3 colunas em sg) */

/* v2.31.17: telas menores que 1200px também empilham — antes ficava 2 colunas espremidas
   e cortava conteúdo do card de remédios */
@media (max-width: 1199px){
  .sg{grid-template-columns:1fr !important;gap:14px !important}
  .hc{margin:0}
}

/* ============================================================ */
/* DATE/TIME CARD (sidebar)                                      */
/* ============================================================ */

.dt-card{
  display:flex;flex-direction:column;
  flex-shrink:0;
  background:var(--panel-2);
  border:1px solid rgba(255,255,255,0.07);
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:0 1px 0 rgba(255,255,255,0.03) inset;
}
.dt-top{
  padding:18px 18px 16px;
  display:flex;flex-direction:column;gap:2px;line-height:1;
}
.dt-top .tl{
  font-family:var(--ff-mono);font-size:10px;font-weight:600;
  color:var(--tx2);letter-spacing:0.20em;text-transform:uppercase;
}
.dt-top .td{
  font-size:42px;font-weight:800;letter-spacing:-0.03em;color:var(--tx);
  line-height:1;margin:6px 0 4px;
}
.dt-top .tdt{
  font-family:var(--ff-mono);font-size:10px;font-weight:500;
  color:var(--tx2);letter-spacing:0.04em;
}
.dt-top .back-btn{
  margin-top:8px;align-self:flex-start;padding:5px 11px;
  background:transparent;border:1px solid var(--line-2);
  border-radius:7px;color:var(--tx2);cursor:pointer;
  font-family:var(--ff-mono);font-size:11px;font-weight:700;
  letter-spacing:0.12em;text-transform:uppercase;transition:all var(--d1);
}
.dt-top .back-btn:hover{background:var(--panel-2);color:var(--tx);border-color:var(--line-2)}

.dt-bot{
  display:flex;flex-direction:column;gap:6px;
  padding:14px 18px;
  background:var(--bg);
  border-top:1px solid rgba(255,255,255,0.05);
}
.dt-bot .ct{
  display:flex;align-items:baseline;gap:1px;
  font-family:var(--ff-mono);font-size:30px;font-weight:700;
  color:var(--tx);letter-spacing:-0.01em;font-feature-settings:"tnum";
  line-height:1;
}
.dt-bot .ct small{font-size:16px;color:var(--tx2);font-weight:500}
.dt-bot .cn{
  display:inline-flex;align-items:center;gap:5px;
  align-self:flex-start;
  padding:4px 9px;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.06);
  border-radius:6px;
  font-family:var(--ff-mono);font-size:11px;font-weight:600;
  color:var(--tx2);
  letter-spacing:0.08em;text-transform:uppercase;
}
.dt-bot .cn svg{width:10px;height:10px}

/* dt-card: estados, back-btn e layout do dashboard-geral */
.dt-card{transition:border-color 0.3s,box-shadow 0.3s}
.dt-card.viewing-other{
  border-color:color-mix(in srgb, var(--warn) 40%, transparent);
  box-shadow:0 0 0 1px color-mix(in srgb, var(--warn) 15%, transparent),inset 0 0 30px color-mix(in srgb, var(--warn) 4%, transparent);
}
.dt-card .dt-top{padding:18px 18px 14px;align-items:flex-start;text-align:left}
.dt-card.viewing-other .dt-top{background:color-mix(in srgb, var(--warn) 4%, transparent)}
.dt-top .td{font-size:38px;font-weight:800;letter-spacing:-0.03em;color:var(--tx);line-height:1;margin:0 0 4px}
.dt-top .tdt{font-family:var(--ff-mono);font-size:10px;font-weight:500;color:var(--tx2);letter-spacing:0.04em}
.dt-diff{color:color-mix(in srgb, var(--warn) 80%, var(--tx));font-weight:700;letter-spacing:0.06em}
.dt-top .back-btn{
  display:none;align-items:center;gap:6px;
  margin-top:10px;padding:8px 14px;
  background:color-mix(in srgb, var(--warn) 14%, transparent);
  border:1px solid color-mix(in srgb, var(--warn) 45%, transparent);
  border-radius:8px;
  color:color-mix(in srgb, var(--warn) 80%, var(--tx));cursor:pointer;
  font-family:var(--ff);font-size:12px;font-weight:700;
  letter-spacing:-0.005em;text-transform:none;
  transition:all var(--d2);
}
.dt-top .back-btn[style*="inline-flex"]{display:inline-flex !important}
.dt-top .back-btn:hover{background:color-mix(in srgb, var(--warn) 25%, transparent);border-color:color-mix(in srgb, var(--warn) 70%, transparent);color:#fff}
.dt-top .back-btn svg{width:13px;height:13px}
.dt-bot{
  display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:10px;
  padding:12px 18px 14px;
  background:var(--bg);
  border-top:1px solid rgba(255,255,255,0.05);
  flex-wrap:wrap;
}
.dt-bot .ct{
  display:flex;align-items:baseline;gap:1px;
  font-family:var(--ff-mono);font-size:30px;font-weight:700;
  color:var(--tx);letter-spacing:-0.01em;font-feature-settings:"tnum";
  line-height:1;
}
.dt-bot .ct small{font-size:14px;color:var(--tx2);font-weight:500}
.dt-bot .cn{
  display:inline-flex;align-items:center;gap:5px;
  padding:5px 9px;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.06);
  border-radius:6px;
  font-family:var(--ff-mono);font-size:11px;font-weight:600;
  color:var(--tx2);letter-spacing:0.06em;text-transform:uppercase;
  white-space:normal;line-height:1.25;text-align:left;
  max-width:100%;
}
.dt-bot .cn svg{width:10px;height:10px}
.cal-dot.future,.cal-dot.appt,.cal-dot.skip{display:none}


/* ============ LOGOUT VERMELHO ============ */
.logout-btn.danger{
  background:color-mix(in srgb, var(--crit) 8%, transparent);
  border-color:color-mix(in srgb, var(--crit) 30%, transparent);
  color:color-mix(in srgb, var(--crit) 70%, var(--tx));
}
.logout-btn.danger:hover{
  background:color-mix(in srgb, var(--crit) 18%, transparent);
  border-color:color-mix(in srgb, var(--crit) 55%, transparent);
  color:#fff;
}

/* ============ CHECK ANIMATIONS (risca + fade) ============ */
/* ============ ANIMAÇÕES CHECK — Premium ============ */
@keyframes itemCheckOut{
  0%{
    opacity:1;
    transform:scale(1);
    background:var(--panel-2);
    box-shadow:0 0 0 0 transparent;
    max-height:80px;
  }
  25%{
    opacity:1;
    transform:scale(1.015);
    background:color-mix(in srgb, var(--good) 12%, transparent);
    box-shadow:0 0 0 1px color-mix(in srgb, var(--good) 50%, transparent),0 4px 18px color-mix(in srgb, var(--good) 18%, transparent);
    max-height:80px;
  }
  60%{
    opacity:0.5;
    transform:scale(0.99);
    background:color-mix(in srgb, var(--good) 6%, transparent);
    max-height:80px;
  }
  100%{
    opacity:0;
    transform:scale(0.94);
    max-height:0;
    margin-bottom:0;padding-top:0;padding-bottom:0;
    border-width:0;
  }
}
.v-task.checking-out,.li.checking-out,.lci.checking-out{
  animation:itemCheckOut 0.75s var(--ease) forwards;
  pointer-events:none;overflow:hidden;
  position:relative;
}
.v-task.checking-out .v-tx,
.li.checking-out .lnm,
.lci.checking-out{
  transition:color var(--d3);
  color:var(--good) !important;
}

/* Animação de entrada (desmarcar) — fade-in suave do card voltando */
@keyframes itemCheckIn{
  0%{
    opacity:0;
    transform:scale(0.96) translateY(-4px);
    background:rgba(255,255,255,0.04);
    max-height:0;
  }
  40%{
    opacity:1;
    background:rgba(255,255,255,0.04);
    max-height:80px;
  }
  100%{
    opacity:1;
    transform:scale(1) translateY(0);
    background:var(--panel-2);
    max-height:80px;
  }
}
.v-task.checking-in,.li.checking-in,.lci.checking-in{
  animation:itemCheckIn 0.55s var(--ease-out) both;
}

/* Refeições — mesmo padrão */
@keyframes mealCheckOut{
  0%{
    opacity:1;
    transform:scale(1);
    box-shadow:0 0 0 0 transparent;
    max-height:200px;
  }
  25%{
    opacity:1;
    transform:scale(1.015);
    box-shadow:0 0 0 1px color-mix(in srgb, var(--good) 50%, transparent),0 4px 18px color-mix(in srgb, var(--good) 18%, transparent);
  }
  60%{opacity:0.5;transform:scale(0.99)}
  100%{
    opacity:0;
    transform:scale(0.94);
    max-height:0;padding:0;margin:0;
    border-width:0;
  }
}
.v-meal.checking-out{
  animation:mealCheckOut 0.75s var(--ease) forwards;
  pointer-events:none;overflow:hidden;
}

/* ============ LOGIN VINHETA ============ */
.login-bg-grid{display:none}
.login-bg-glow{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 80% 60% at 50% 50%, transparent 0%, rgba(0,0,0,0.6) 100%);
  animation:none;
}


/* ============================================================ */
/* v2.5.0 — NOVOS COMPONENTES                                    */
/* ============================================================ */

/* ============ ADD BUTTON ROXO (padrão único de adicionar) ============ */
/* .add-btn-purple migrado pra .v-add (showcase) — v4.0.13.
   Variante mini (add-btn-mini) não tinha mais uso no markup. */

/* ============ MENU OPÇÕES (dropdown) ============ */
.opt-menu{
  display:none;
  background:var(--panel);
  border:1px solid var(--line-2);
  border-radius:10px;
  padding:6px;
  min-width:220px;
  box-shadow:0 14px 40px rgba(0,0,0,0.55), 0 2px 8px rgba(0,0,0,0.3);
  z-index:280;
  flex-direction:column;
  gap:2px;
}
.opt-menu.active{display:flex;animation:optMenuIn var(--d2) var(--ease-out)}
@keyframes optMenuIn{
  from{opacity:0;transform:translateY(-6px) scale(0.98)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
.opt-menu-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;
  background:transparent;border:none;border-radius:6px;
  color:var(--tx);cursor:pointer;
  font-family:var(--ff);font-size:13px;font-weight:500;
  text-align:left;width:100%;
  transition:all var(--d1);
}
.opt-menu-item:hover{background:var(--panel-2);color:var(--tx)}
.opt-menu-item svg{width:15px;height:15px;flex-shrink:0;color:var(--tx2)}
.opt-menu-item:hover svg{color:var(--tx)}

/* ============ MOBILE SIDEBAR (.msb-*) — REMOVIDO v3.0.2 ============ */
/* Substituído por shared/sidebar.js + assets/sidebar.css (.lifeos-sb-*) */

/* ============ MODAL DE ATALHOS (v2.5.1) ============ */
.shortcuts-modal{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:14px;
  width:100%;max-width:420px;
  max-height:80vh;overflow:hidden;
  display:flex;flex-direction:column;
  animation:modalIn var(--d2) var(--ease-out);
}

/* ============ COLLAPSE / ACCORDION (mobile) ============ */
.collapsible{transition:none}
.collapse-chevron{
  width:16px;height:16px;
  color:var(--tx2);
  transition:transform var(--d2) ease;
  flex-shrink:0;
  display:none;  /* só aparece no mobile */
}
.collapsible.expanded .collapse-chevron{transform:rotate(180deg)}

/* desktop: mostra tudo, ignora .collapsed e .expanded */
@media (min-width: 1200px){
  /* v4.0.7: scroll vai todo na .pcol externa. .collapse-body simples block,
     .pbd cresce natural com gap entre as seções. Seções (Tarefas/Dieta/Saúde/
     Remédios) ficam com altura ilimitada — quem rola é a coluna. */
  .wrap .collapsible > .collapse-body{display:block !important}
  .wrap .collapsible .collapse-chevron{display:none !important}
  /* Lista de Compras (rsb): ainda quer flex:1 pra ocupar altura da rsb */
  .wrap .rsb .lc-sec > .collapse-body{display:flex !important;flex-direction:column;flex:1;min-height:0}
}


/* ============================================================
 * v2.31.17: Hub modais (Lista, Agenda, Quick Notes)
 * Reusa classes existentes (.lci, .v-cpi, .qn-item) — só precisa
 * do wrapper scrollável.
 * ============================================================ */
.hub-modal-list{
  display:flex;
  flex-direction:column;
  gap:6px;
  max-height:360px;
  overflow-y:auto;
  padding:4px 2px;
}
.hub-modal-list::-webkit-scrollbar{width:6px}
.hub-modal-list::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:3px}

/* ============================================================
 * G3 (v2.44.0): STAGGER ANIMATIONS em listas renderizadas.
 * Uso: adicione data-stagger a um container; filhos diretos animam em sequência.
 * Aplicação: hub-grid, fin-tx-list, fin-cat-list, t-list. Respeita reduced-motion.
 * ============================================================ */
[data-stagger] > *{
  animation:lifeosStaggerIn var(--d3) var(--ease-out) both;
}
[data-stagger] > *:nth-child(1){animation-delay:0ms}
[data-stagger] > *:nth-child(2){animation-delay:50ms}
[data-stagger] > *:nth-child(3){animation-delay:100ms}
[data-stagger] > *:nth-child(4){animation-delay:var(--d1)}
[data-stagger] > *:nth-child(5){animation-delay:var(--d2)}
[data-stagger] > *:nth-child(6){animation-delay:var(--d2)}
[data-stagger] > *:nth-child(7){animation-delay:300ms}
[data-stagger] > *:nth-child(8){animation-delay:var(--d3)}
[data-stagger] > *:nth-child(9){animation-delay:var(--d3)}
[data-stagger] > *:nth-child(n+10){animation-delay:var(--d3)}
@keyframes lifeosStaggerIn{
  from{opacity:0;transform:translateY(6px)}
  to{opacity:1;transform:translateY(0)}
}
@media (prefers-reduced-motion: reduce){
  [data-stagger] > *{animation:none}
}

/* ============================================================
 * G2 (v2.44.0): UNDO MÚLTIPLO — popover com histórico clicável.
 * Aciona com Ctrl+Shift+Z (ou click no .undo-toast em mais de 1 ação).
 * ============================================================ */
.lifeos-undo-history{
  position:fixed;bottom:64px;left:18px;
  min-width:280px;max-width:360px;
  background:var(--panel);
  border:1px solid var(--line-2);
  border-radius:var(--r-md);
  box-shadow:0 18px 48px rgba(0,0,0,.55);
  z-index:var(--z-toast);
  display:none;
  flex-direction:column;
  overflow:hidden;
  animation:lifeosUndoHistIn var(--d2) var(--ease-out);
}
.lifeos-undo-history.open{display:flex}
@keyframes lifeosUndoHistIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.lifeos-undo-history-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;
  border-bottom:1px solid var(--line);
  font:600 11px/1 var(--ff-mono);
  color:var(--tx3);
  text-transform:uppercase;letter-spacing:.08em;
}
.lifeos-undo-history-list{
  max-height:280px;overflow-y:auto;
  display:flex;flex-direction:column;gap:1px;
  padding:6px;
}
.lifeos-undo-history-item{
  display:flex;align-items:center;gap:10px;
  padding:9px 11px;
  border-radius:var(--r-sm);
  background:transparent;border:none;
  color:var(--tx);
  font:500 12.5px/1.3 var(--ff);
  cursor:pointer;text-align:left;
  transition:background var(--d1);
}
.lifeos-undo-history-item:hover,
.lifeos-undo-history-item.focused{background:color-mix(in srgb, var(--brand) 12%, transparent);color:#fff}
.lifeos-undo-history-empty{
  padding:24px 14px;text-align:center;
  color:var(--tx3);font-size:12px;
}

/* ============================================================
 * G4 (v2.44.0): Otto avatar respeita prefers-reduced-motion.
 * Esconde canvas e usa versão estática SVG quando reduced.
 * ============================================================ */
@media (prefers-reduced-motion: reduce){
  #ottoAvatarCanvas, .otto-avatar canvas{display:none !important}
  .otto-avatar::before{
    content:'';display:block;
    width:100%;height:100%;
    background:radial-gradient(circle at center, color-mix(in srgb, var(--brand) 50%, transparent) 0%, color-mix(in srgb, var(--brand) 15%, transparent) 40%, transparent 70%);
    border-radius:50%;
  }
}

/* ============================================================
 * D1 (v2.43.0): BANNER DE HISTORICIDADE — feedback pra edits R23.
 * Aparece após save de edit que cria nova row (effective_from=hoje) e encerra
 * antiga, explicando que mudança não é retroativa. Window.lifeosHistoricityBanner()
 * ============================================================ */
.lifeos-hist-banner{
  position:fixed;left:50%;bottom:78px;
  transform:translateX(-50%) translateY(20px);
  display:flex;align-items:center;gap:9px;
  padding:10px 14px;
  background:color-mix(in srgb, var(--brand) 16%, transparent);
  border:1px solid color-mix(in srgb, var(--brand) 45%, transparent);
  border-radius:var(--r-md);
  color:color-mix(in srgb, var(--brand) 35%, var(--tx));
  font:500 12.5px/1.3 var(--ff);
  box-shadow:0 12px 32px rgba(0,0,0,0.45);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  z-index:var(--z-toast);
  opacity:0;pointer-events:none;
  transition:opacity var(--d2) ease, transform var(--d2) var(--ease-out);
  max-width:min(420px, calc(100vw - 24px));
}
.lifeos-hist-banner.active{
  opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto;
}
.lifeos-hist-banner svg{flex-shrink:0;color:color-mix(in srgb, var(--brand) 70%, var(--tx))}
.lifeos-hist-msg{flex:1}
.lifeos-hist-close{
  background:transparent;border:none;
  color:color-mix(in srgb, var(--brand) 35%, var(--tx));cursor:pointer;
  font-size:18px;line-height:1;padding:0 0 0 6px;
  opacity:0.7;transition:opacity var(--d1);
}
.lifeos-hist-close:hover{opacity:1}
@media (max-width:680px){
  .lifeos-hist-banner{left:12px;right:12px;bottom:70px;transform:translateY(20px)}
  .lifeos-hist-banner.active{transform:translateY(0)}
}
 *
 * <div class="lifeos-skeleton" style="width:80%;height:14px"></div>
 *
 * Aplicar em lugar do conteúdo enquanto loadData() não retorna.
 * Classe shimmer suave; respeita prefers-reduced-motion (G4).
 * ============================================================ */
.lifeos-skeleton{
  display:block;
  background:linear-gradient(
    90deg,
    rgba(255,255,255,0.04) 0%,
    rgba(255,255,255,0.08) 50%,
    rgba(255,255,255,0.04) 100%
  );
  background-size:200% 100%;
  border-radius:var(--r-sm);
  animation:lifeosSkeletonShimmer 1.4s ease-in-out infinite;
}
.lifeos-skeleton-line{
  height:12px;border-radius:var(--r-sm);margin:8px 0;
}
.lifeos-skeleton-line.short{width:40%}
.lifeos-skeleton-line.medium{width:65%}
.lifeos-skeleton-line.long{width:90%}
.lifeos-skeleton-block{
  height:80px;border-radius:var(--r-md);margin:8px 0;
}
@keyframes lifeosSkeletonShimmer{
  0%{background-position:200% 0}
  100%{background-position:-200% 0}
}
@media (prefers-reduced-motion: reduce){
  .lifeos-skeleton{animation:none;background:rgba(255,255,255,0.06)}
}

/* ============================================================
 * H1 (v2.40.0): EMPTY STATES PADRONIZADOS — usar em qualquer lista vazia.
 *
 * <div class="lifeos-empty">
 *   <div class="lifeos-empty-icon"><svg>...</svg></div>
 *   <div class="lifeos-empty-title">Nenhum item</div>
 *   <div class="lifeos-empty-text">Texto orientador opcional</div>
 *   <button class="lifeos-empty-cta">Adicionar primeiro</button>
 * </div>
 * ============================================================ */
.lifeos-empty{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:12px;
  padding:36px 22px;
  text-align:center;
  color:var(--tx2);
}
.lifeos-empty-icon{
  width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
  background:var(--panel-2);
  border:1px solid var(--line);
  border-radius:var(--r-full);
  color:var(--tx3);
  margin-bottom:2px;
}
.lifeos-empty-icon svg{width:18px;height:18px}
.lifeos-empty-title{
  font:600 14px/1.2 var(--ff);
  color:var(--tx);
  letter-spacing:-0.005em;
}
.lifeos-empty-text{
  font:400 12.5px/1.45 var(--ff);
  color:var(--tx3);
  max-width:280px;
}
.lifeos-empty-cta{
  margin-top:6px;
  padding:9px 16px;
  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 12px/1 var(--ff);
  cursor:pointer;
  transition:all var(--d1) var(--ease-out);
  letter-spacing:-0.005em;
}
.lifeos-empty-cta:hover{
  background:color-mix(in srgb, var(--brand) 22%, transparent);
  border-color:color-mix(in srgb, var(--brand) 50%, transparent);
  color:color-mix(in srgb, var(--brand) 35%, var(--tx));
}

/* ============================================================
 * v2.31.17: BANNER DE SUCESSO — feedback uniforme do app inteiro.
 * Position fixed no rodapé, z-index máximo, auto-dismiss 2s.
 * Usado por window.bannerSuccess(msg).
 * ============================================================ */
.banner-success{
  position:fixed;
  bottom:24px;
  left:50%;
  transform:translateX(-50%) translateY(140%);
  z-index:300000;
  pointer-events:none;
  opacity:0;
  transition:transform var(--d3) var(--spring), opacity var(--d2) ease;
}
.banner-success.active{
  transform:translateX(-50%) translateY(0);
  opacity:1;
  pointer-events:auto;
}
.banner-success.closing{
  transform:translateX(-50%) translateY(140%);
  opacity:0;
  transition:transform var(--d3) ease-in, opacity var(--d2) ease-in;
}
.banner-success-content{
  display:flex;align-items:center;gap:10px;
  padding:11px 16px;
  background:color-mix(in srgb, var(--good) 16%, transparent);
  border:1px solid color-mix(in srgb, var(--good) 45%, transparent);
  border-radius:10px;
  color:color-mix(in srgb, var(--good) 75%, var(--tx));
  font-family:var(--ff);
  font-size:13px;
  font-weight:600;
  box-shadow:0 12px 32px rgba(0,0,0,0.45), 0 0 0 1px color-mix(in srgb, var(--good) 10%, transparent);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.banner-success-content svg{flex-shrink:0;color:color-mix(in srgb, var(--good) 75%, var(--tx))}
.banner-success-msg{color:color-mix(in srgb, var(--good) 35%, var(--tx))}
.banner-success-x{
  background:transparent;border:none;
  color:color-mix(in srgb, var(--good) 75%, var(--tx));cursor:pointer;
  font-size:18px;line-height:1;padding:0 0 0 6px;
  margin-left:4px;opacity:0.65;
  transition:opacity var(--d1);
}
.banner-success-x:hover{opacity:1}

/* v2.31.17: quando banner-success está ativo, desloca undo-toast pra cima
   pra não colidir visualmente (banner cobre undo no z-index). */
body:has(.banner-success.active) .undo-toast.active{
  transform:translateX(-50%) translateY(-58px);
}

/* mobile: banner um pouco menor */
@media (max-width: 720px){
  .banner-success{ bottom:16px; left:12px; right:12px; transform:translateY(140%); }
  .banner-success.active{ transform:translateY(0); }
  .banner-success.closing{ transform:translateY(140%); }
  .banner-success-content{ width:100%; justify-content:center }
}

/* ============================================================
 * v2.31.17: counter-flash — pulso verde em números/saldos
 * que mudaram. Aplicar via window.animateCounter ou direto.
 * ============================================================ */
.counter-flash{
  animation:counterFlash 1.2s ease-out;
}
@keyframes counterFlash{
  0%{color:var(--good);text-shadow:0 0 18px color-mix(in srgb, var(--good) 50%, transparent)}
  40%{color:color-mix(in srgb, var(--good) 75%, var(--tx));text-shadow:0 0 8px color-mix(in srgb, var(--good) 25%, transparent)}
  100%{text-shadow:none}
}

/* ============================================================
 * v2.31.17: item-slide-in — entrada de item novo na lista.
 * Aplicar via window.markItemAsAdded(el).
 * ============================================================ */
.item-slide-in{
  animation:itemSlideIn .55s var(--spring), itemGlowFade 1.6s ease-out;
}
@keyframes itemSlideIn{
  0%{opacity:0;transform:translateX(-24px)}
  100%{opacity:1;transform:translateX(0)}
}
@keyframes itemGlowFade{
  0%,30%{
    box-shadow:0 0 0 1px color-mix(in srgb, var(--good) 45%, transparent), 0 0 24px color-mix(in srgb, var(--good) 20%, transparent);
    background-color:color-mix(in srgb, var(--good) 10%, transparent);
  }
  100%{
    box-shadow:0 0 0 1px transparent, 0 0 0 transparent;
    background-color:transparent;
  }
}
