/* ============================================================ */
/* LifeOS · Áreas da vida v2.31.17                                */
/* CSS específico — usa vars/tokens do style.css principal       */
/* ============================================================ */

.lda-page{
  display:flex;flex-direction:column;
  gap:14px;
  padding:14px 14px 100px;
  max-width:var(--page-max);
  margin:0 auto;
  min-height:100vh;
}

/* =============== GRID 3x3 =============== */
.lda-grid{
  display:grid;
  grid-template-columns:140px repeat(3, 1fr);
  grid-template-rows:auto repeat(3, minmax(240px, 1fr));
  gap:10px;
  padding:0 4px;
}

/* canto superior esquerdo (vazio) */
.lda-corner{
  background:transparent;
}

/* headers das colunas (níveis) */
.lda-col-hdr{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:10px 12px;
  border-radius:var(--r-md);
  font:600 11px/1 'Geist Mono','Inter',system-ui,sans-serif;
  letter-spacing:0.12em;
  text-transform:uppercase;
  text-align:center;
  gap:4px;
}
.lda-col-hdr-name{font-size:11px}
.lda-col-hdr-sub{font-size:9px;opacity:0.6;letter-spacing:0.18em}

.lda-col-hdr.basico{
  background:color-mix(in srgb, var(--good) 10%, transparent);
  border:1px solid color-mix(in srgb, var(--good) 25%, transparent);
  color:color-mix(in srgb, var(--good) 75%, var(--tx));
}
.lda-col-hdr.medio{
  background:color-mix(in srgb, var(--warn) 10%, transparent);
  border:1px solid color-mix(in srgb, var(--warn) 25%, transparent);
  color:color-mix(in srgb, var(--warn) 80%, var(--tx));
}
.lda-col-hdr.complexo{
  background:color-mix(in srgb, var(--crit) 10%, transparent);
  border:1px solid color-mix(in srgb, var(--crit) 25%, transparent);
  color:color-mix(in srgb, var(--crit) 70%, var(--tx));
}

/* labels das linhas (áreas) */
.lda-row-hdr{
  display:flex;align-items:center;justify-content:center;
  padding:14px 10px;
  font:300 24px/1 'Instrument Serif',serif;font-style: normal;
  color:var(--tx);
  letter-spacing:-0.01em;
  text-align:center;
}

/* células (intersecção) */
.lda-cell{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  display:flex;flex-direction:column;
  overflow:hidden;
  transition:border-color var(--d1);
}
.lda-cell:hover{border-color:var(--line-2)}
.lda-cell.basico{border-left:2px solid color-mix(in srgb, var(--good) 40%, transparent)}
.lda-cell.medio{border-left:2px solid color-mix(in srgb, var(--warn) 40%, transparent)}
.lda-cell.complexo{border-left:2px solid color-mix(in srgb, var(--crit) 40%, transparent)}

.lda-cell-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 12px;
  border-bottom:1px solid var(--line);
  background:rgba(255,255,255,0.015);
}
.lda-cell-count{
  font:600 10px/1 'Geist Mono','Inter',system-ui,sans-serif;
  color:var(--tx3);
  letter-spacing:0.06em;
  text-transform:uppercase;
}
.lda-cell-add{
  width:24px;height:24px;border-radius:6px;
  background:transparent;border:1px solid var(--line-2);
  color:var(--tx2);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition:all var(--d1);
  padding:0;
}
.lda-cell-add:hover{
  background:rgba(255,255,255,0.05);
  border-color:var(--line-2);
  color:var(--tx);
}
.lda-cell-add svg{width:14px;height:14px}

.lda-cell-body{
  flex:1;
  padding:8px;
  display:flex;flex-direction:column;
  gap:4px;
  overflow-y:auto;
  max-height:380px;
  min-height:60px;
}

.lda-cell-empty{
  flex:1;display:flex;align-items:center;justify-content:center;
  font:400 11px/1.4 'Geist','Plus Jakarta Sans',sans-serif;
  color:var(--tx3);
  font-style: normal;
  padding:14px;
  text-align:center;
}

/* itens */
.lda-item{
  display:flex;align-items:flex-start;gap:8px;
  padding:8px 8px 8px 6px;
  border-radius:8px;
  background:transparent;
  cursor:grab;
  transition:background var(--d1);
  position:relative;
}
.lda-item:hover{background:rgba(255,255,255,0.025)}
.lda-item.dragging{opacity:0.4;cursor:grabbing}
.lda-item.drag-over{background:color-mix(in srgb, var(--info) 10%, transparent)}

/* checkbox de item → DS .v-chk. .lda-check fica só como reset do <button>
   + tamanho compacto da matriz (handler usa data-act, não a classe).
   Estado marcado vem do .done no .lda-item (bridge p/ o .v-chk). */
.lda-check{flex-shrink:0;margin-top:1px;padding:0;width:16px;height:16px;appearance:none}
.lda-item.done .v-chk{background:var(--brand);border-color:var(--brand)}
.lda-item.done .v-chk svg{stroke-dashoffset:0}

.lda-item-text{
  flex:1;min-width:0;
  font:400 12.5px/1.4 'Geist','Plus Jakarta Sans',sans-serif;
  color:var(--tx);
  word-break:break-word;
  cursor:pointer;
}
.lda-item.done .lda-item-text{
  text-decoration:line-through;
  color:var(--tx3);
  opacity:0.55;
}

.lda-item-actions{
  flex-shrink:0;
  display:flex;gap:2px;
  opacity:0;
  transition:opacity var(--d1);
}
.lda-item:hover .lda-item-actions{opacity:1}
/* .lda-item-btn migrado pra .v-btn v-btn-gho v-btn--icon v-btn--sm (+danger) — v4.0.14 */

/* drag-handle visual indicator */
.lda-item-handle{
  flex-shrink:0;
  width:12px;height:18px;
  display:flex;align-items:center;justify-content:center;
  color:var(--tx3);
  opacity:0;
  transition:opacity var(--d1);
  cursor:grab;
  margin-top:-1px;
}
.lda-item:hover .lda-item-handle{opacity:0.4}
.lda-item-handle:hover{opacity:1 !important}
.lda-item-handle svg{width:10px;height:10px}

/* tag de célula no modal */
.lda-cell-tag{
  display:inline-flex;align-items:center;gap:6px;
  font:600 9px/1 'Geist Mono','Inter',system-ui,sans-serif;
  letter-spacing:0.10em;text-transform:uppercase;
  padding:6px 9px;border-radius:5px;
  background:rgba(255,255,255,0.04);
  color:var(--tx2);
  margin-top:8px;
}
.lda-cell-tag.basico{background:color-mix(in srgb, var(--good) 12%, transparent);color:color-mix(in srgb, var(--good) 75%, var(--tx))}
.lda-cell-tag.medio{background:color-mix(in srgb, var(--warn) 12%, transparent);color:color-mix(in srgb, var(--warn) 80%, var(--tx))}
.lda-cell-tag.complexo{background:color-mix(in srgb, var(--crit) 12%, transparent);color:color-mix(in srgb, var(--crit) 70%, var(--tx))}

/* ===== Mobile ===== */
@media (max-width:900px){
  .lda-grid{
    grid-template-columns:1fr;
    grid-template-rows:auto;
    gap:18px;
  }
  .lda-corner{display:none}
  .lda-col-hdr{display:none}
  .lda-row-hdr{
    justify-content:flex-start;
    padding:6px 4px 0;
    font-size:22px;
    text-align:left;
  }
  .lda-cell{
    grid-column:1;
  }
  .lda-cell-head{
    padding:10px 14px;
  }
  /* mobile stack: row-hdr seguido pelas 3 cells da área */
  .lda-area-group{
    display:flex;flex-direction:column;gap:8px;
  }
}
